{"id":13515654,"url":"https://github.com/orchidjs/tom-select","last_synced_at":"2026-02-07T01:08:40.117Z","repository":{"id":37211575,"uuid":"287333022","full_name":"orchidjs/tom-select","owner":"orchidjs","description":"Tom Select is a lightweight (~16kb gzipped) hybrid of a textbox and select box. Forked from selectize.js to provide a framework agnostic autocomplete widget with native-feeling keyboard navigation. Useful for tagging, contact lists, etc.","archived":false,"fork":false,"pushed_at":"2025-04-14T12:45:23.000Z","size":23410,"stargazers_count":1866,"open_issues_count":49,"forks_count":140,"subscribers_count":20,"default_branch":"master","last_synced_at":"2025-05-10T21:29:11.117Z","etag":null,"topics":["choice","choices","dropdown","input","javascript","select","select-multiple","select2","selectbox","typescript","vanilla-javascript","vanilla-js"],"latest_commit_sha":null,"homepage":"https://tom-select.js.org","language":"JavaScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"apache-2.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/orchidjs.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":".github/FUNDING.yml","license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null},"funding":{"github":null,"patreon":null,"open_collective":"tom-select","ko_fi":null,"tidelift":null,"community_bridge":null,"liberapay":null,"issuehunt":null,"otechie":null,"custom":null}},"created_at":"2020-08-13T16:48:52.000Z","updated_at":"2025-05-10T14:19:22.000Z","dependencies_parsed_at":"2023-02-08T10:50:30.116Z","dependency_job_id":"cd076e00-ffb0-4098-8acf-918ff93834ff","html_url":"https://github.com/orchidjs/tom-select","commit_stats":{"total_commits":1878,"total_committers":126,"mean_commits":"14.904761904761905","dds":"0.36581469648562304","last_synced_commit":"fadaeb42f2f181454e6e7ce75e2791292d96b93b"},"previous_names":[],"tags_count":128,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/orchidjs%2Ftom-select","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/orchidjs%2Ftom-select/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/orchidjs%2Ftom-select/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/orchidjs%2Ftom-select/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/orchidjs","download_url":"https://codeload.github.com/orchidjs/tom-select/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":253592890,"owners_count":21932900,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["choice","choices","dropdown","input","javascript","select","select-multiple","select2","selectbox","typescript","vanilla-javascript","vanilla-js"],"created_at":"2024-08-01T05:01:14.239Z","updated_at":"2026-02-07T01:08:35.083Z","avatar_url":"https://github.com/orchidjs.png","language":"JavaScript","funding_links":["https://opencollective.com/tom-select"],"categories":["JavaScript"],"sub_categories":[],"readme":"\u003cp align=\"center\"\u003e\n\u003ch1 align=\"center\"\u003eTom Select\u003c/h1\u003e\n\u003c/p\u003e\n\n\u003cp align=\"center\"\u003e\n\u003ca href=\"https://github.com/orchidjs/tom-select\" class=\"m-1 d-inline-block\"\u003e\u003cimg alt=\"GitHub Repo stars\" src=\"https://img.shields.io/github/stars/orchidjs/tom-select?label=GitHub%20stars\u0026color=007ec6\"\u003e\u003c/a\u003e\n\u003ca href=\"https://www.jsdelivr.com/package/npm/tom-select\" class=\"m-1 d-inline-block\"\u003e\u003cimg alt=\"jsDelivr hits (npm)\" src=\"https://img.shields.io/jsdelivr/npm/hm/tom-select?label=jsDelivr%20hits\u0026color=007ec6\"\u003e\u003c/a\u003e\n\u003ca href=\"https://www.npmjs.com/package/tom-select\" class=\"m-1 d-inline-block\"\u003e\u003cimg alt=\"npmjs.org\" src=\"https://img.shields.io/npm/v/tom-select.svg?color=007ec6\"\u003e\u003c/a\u003e\n\u003ca href=\"https://github.com/orchidjs/tom-select/actions/workflows/tests.yml\" class=\"m-1 d-inline-block\"\u003e\u003cimg alt=\"tests\" src=\"https://github.com/orchidjs/tom-select/actions/workflows/tests.yml/badge.svg\"\u003e\u003c/a\u003e\n\u003ca href=\"https://coveralls.io/github/orchidjs/tom-select\" class=\"m-1 d-inline-block\"\u003e\u003cimg alt=\"Coveralls Coverage\" src=\"https://img.shields.io/coveralls/github/orchidjs/tom-select?color=4c1\"\u003e\u003c/a\u003e\n\u003ca href=\"https://github.com/orchidjs/tom-select/issues\" class=\"m-1 d-inline-block\"\u003e\u003cimg alt=\"GitHub Issues\" src=\"https://img.shields.io/github/issues/orchidjs/tom-select\"\u003e\u003c/a\u003e\n\u003c/p\u003e\n\nTom Select is a dynamic, framework agnostic, and lightweight (~16kb gzipped) \u0026lt;select\u0026gt; UI control.\nWith autocomplete and native-feeling keyboard navigation, it's useful for tagging, contact lists, country selectors, and so on.\nTom Select was forked from [selectize.js](https://tom-select.js.org/docs/selectize.js/) with the goal of modernizing the code base, decoupling from jQuery, and expanding functionality.\n\n\n### Features\n\n- **Smart Option Searching / Ranking**\u003cbr\u003eOptions are efficiently scored and sorted on-the-fly (using [sifter](https://github.com/orchidjs/sifter.js)). Want to search an item's title *and* description? No problem.\n- **Caret between items**\u003cbr\u003eOrder matters sometimes. With the \u003ca href=\"https://tom-select.js.org/plugins/caret-position\"\u003eCaret Position Plugin\u003c/a\u003e, you can use the \u003ckbd\u003e\u0026larr;\u003c/kbd\u003e and \u003ckbd\u003e\u0026rarr;\u003c/kbd\u003e arrow keys to move between selected items\u003c/li\u003e\n- **Select \u0026amp; delete multiple items at once**\u003cbr\u003eHold down \u003ckbd\u003ecommand\u003c/kbd\u003e on Mac or \u003ckbd\u003ectrl\u003c/kbd\u003e on Windows to select more than one item to delete.\n- **Díåcritîçs supported**\u003cbr\u003eGreat for international environments.\n- **Item creation**\u003cbr\u003eAllow users to create items on the fly (async saving is supported; the control locks until the callback is fired).\n- **Remote data loading**\u003cbr\u003eFor when you have thousands of options and want them provided by the server as the user types.\n- **Extensible**\u003cbr\u003e [Plugin API](https://tom-select.js.org/docs/plugins/) for developing custom features (uses [microplugin](https://github.com/brianreavis/microplugin.js)).\n- **Accessible**, **Touch Support**, **Clean API**, ...\n\n## Usage\n\n```html\n\u003cinput id=\"tom-select-it\" /\u003e\n\u003clink rel=\"stylesheet\" href=\"/css/tom-select.default.css\"\u003e\n\u003cscript src=\"/js/tom-select.complete.js\"\u003e\u003c/script\u003e\n\u003cscript\u003e\nvar config = {};\nnew TomSelect('#tom-select-it',config);\n\u003c/script\u003e\n```\n\nAvailable configuration settings are [documented here](https://tom-select.js.org/docs)\n\n\n## Installation\n\nAll pre-built files needed to use Tom Select can be found in the \"dist\" folder via any of these sources:\n\n\u003ctable class=\"table mt-5\"\u003e\n\t\u003ctr\u003e\n\t\t\u003cth class=\"border-top-0\"\u003eSource\u003c/th\u003e\n\t\t\u003cth class=\"border-top-0\"\u003e\u003c/th\u003e\n\t\u003c/tr\u003e\n\t\u003ctr\u003e\n\t\t\u003ctd\u003e\u003ca href=\"https://www.jsdelivr.com/package/npm/tom-select?path=dist\"\u003ejsDelivr\u003c/a\u003e\u003c/td\u003e\n\t\t\u003ctd\u003e\n\t\tThe fastest way to add Tom Select into your project is to just include the js and css from jsDelivr.\n\u003cpre\u003e\n\u0026lt;link href=\"https://cdn.jsdelivr.net/npm/tom-select/dist/css/tom-select.css\" rel=\"stylesheet\"\u0026gt;\n\u0026lt;script src=\"https://cdn.jsdelivr.net/npm/tom-select/dist/js/tom-select.complete.min.js\"\u0026gt;\u0026lt;/script\u0026gt;\n\u003c/pre\u003e\n\t\t\u003c/td\u003e\n\t\u003c/tr\u003e\n\t\u003ctr\u003e\n\t\t\u003ctd\u003e\u003ca href=\"https://www.npmjs.com/package/tom-select\"\u003enpm\u003c/a\u003e\u003c/td\u003e\n\t\t\u003ctd\u003e\u003cpre\u003e\u003ccode\u003enpm i tom-select\u003c/code\u003e\u003c/pre\u003e\n\t\t\u003cdiv\u003e\u003ca href=\"https://tom-select.js.org/docs/contribute/\"\u003eAdditional CLI usage\u003c/a\u003e\u003c/div\u003e\n\t\t\u003c/td\u003e\n\t\u003c/tr\u003e\n\t\u003ctr\u003e\n\t\t\u003ctd\u003e\u003ca href=\"https://github.com/orchidjs/tom-select/\"\u003eGitHub\u003c/a\u003e\u003c/td\u003e\n\t\t\u003ctd\u003eClone or \u003ca href=\"https://github.com/orchidjs/tom-select/archive/master.zip\"\u003edownload\u003c/a\u003e the full repo.\n\t\tUse \u003ccode\u003enpm run build\u003c/code\u003e \u003ca href=\"/docs/contribute\"\u003eand other commands\u003c/a\u003e to build from source, test and start the doc server.\n\t\t\u003c/td\u003e\n\t\u003c/tr\u003e\n\u003c/table\u003e\n\n\n## Files\n- [tom-select.complete.js](https://cdn.jsdelivr.net/npm/tom-select/dist/js/tom-select.complete.js) — Includes dependencies and plugins\n- [tom-select.base.js](https://cdn.jsdelivr.net/npm/tom-select/dist/js/tom-select.base.js) — Does not include any plugins\n- [CSS](https://www.jsdelivr.com/package/npm/tom-select?path=dist%2Fcss) — Compiled themes\n- [SCSS](https://www.jsdelivr.com/package/npm/tom-select?path=dist%2Fscss) — Uncompiled theme sources\n\n\n## Sponsors\n\u003cp\u003e\nMany thanks to all our sponsors who help make development possible. \u003ca href=\"https://opencollective.com/tom-select\"\u003eBecome a sponsor\u003c/a\u003e.\n\u003c/p\u003e\n\u003cp\u003e\n\u003ca href=\"https://opencollective.com/tom-select/sponsor/0/website\"\u003e\u003cimg src=\"https://opencollective.com/tom-select/sponsor/0/avatar.svg\" alt=\"Trust My Paper Logo\"\u003e\u003c/a\u003e\n\u003ca href=\"https://opencollective.com/tom-select/sponsor/2/website\"\u003e\u003cimg src=\"https://opencollective.com/tom-select/sponsor/2/avatar.svg\" alt=\"WiseEssays.com\"\u003e\u003c/a\u003e\n\u003c/p\u003e\n\u003cbr\u003e\n\n\n\n## License\n\nCopyright \u0026copy; 2013–2023 [Contributors](https://github.com/orchidjs/tom-select/graphs/contributors)\n\nLicensed under the Apache License, Version 2.0 (the \"License\"); you may not use this file except in compliance with the License. You may obtain a copy of the License at: http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Forchidjs%2Ftom-select","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Forchidjs%2Ftom-select","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Forchidjs%2Ftom-select/lists"}