Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/migliori/universal-icon-picker
Vanilla JS Icon Picker for any Icon Library
https://github.com/migliori/universal-icon-picker
html icons javascript picker vanilla-javascript
Last synced: about 12 hours ago
JSON representation
Vanilla JS Icon Picker for any Icon Library
- Host: GitHub
- URL: https://github.com/migliori/universal-icon-picker
- Owner: migliori
- License: mit
- Created: 2022-02-23T09:43:10.000Z (almost 3 years ago)
- Default Branch: main
- Last Pushed: 2024-07-26T15:15:08.000Z (6 months ago)
- Last Synced: 2025-01-04T15:09:16.247Z (8 days ago)
- Topics: html, icons, javascript, picker, vanilla-javascript
- Language: CSS
- Homepage: https://universal-icon-picker.miglisoft.com
- Size: 4.8 MB
- Stars: 80
- Watchers: 3
- Forks: 13
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Universal Icon Picker
![Language: Vanilla JS](https://img.shields.io/badge/-vanilla%20js-555?logo=JavaScript)
![Dependencies: none](https://img.shields.io/badge/dependencies-none-04B54E)
![GitHub file size in bytes](https://img.shields.io/github/size/migliori/universal-icon-picker/assets/js/universal-icon-picker.min.js)
[![GPLv3 license](https://img.shields.io/badge/License-GPLv3-blue.svg)](http://perso.crans.org/besson/LICENSE.html)Nice small Javascript **Icon Picker for any icon library**
*Vanilla Javascript* - *No dependency* - *2.6ko gzipped*
Originally forked from [aesthetic-icon-picker](https://github.com/sh-sabbir/aesthetic-icon-picker/tree/20d6aa6134311b44891809cc852dbf247a029495)
## Demo
[https://universal-icon-picker.miglisoft.com](https://universal-icon-picker.miglisoft.com)
## Features
- Load any icon library from a single JSON file
- Load the icon fonts stylesheets from local files or CDNs
- Autoload the icon fonts (JSON + stylesheets) or load them only on request
- Add as many icon libraries as you like to each instance of the plugin
- Create multiple instances and triggers on the same page
- Change the icon libraries attached to an instance whenever you want
- Group icons of the same family by categories
- Load one or more styles from the same icon family individually
- Search / Filter icons
- Built-in `onSelect()` and `onReset()` callback functions
- Attach the Icon Picker to any HTML element
- Add your favourite icon libraries very easily## Integrated icon libraries
### Font Awesome
- All
- Solid
- Regular
- Brands### Material Icons
- Filled
- Outlined
- Round
- Sharp
- Two-tone### Other icon libraries
- Bootstrap Icons
- Elegant Icons
- Feather Icons
- Fomantic UI Icons
- Foundation Icons
- Happy Icons
- Icomoon
- Open-iconic
- Tabler Icons
- Weather Icons
- Zondicons## Installation
Clone / download or install with npm
```bash
npm install @migliori/[email protected]
```## Usage/Examples
```html
Click to open
document.addEventListener('DOMContentLoaded', function(event) {
var uip = new UniversalIconPicker('#selector', options);
});
```
## Options
| option | type | value |
|------------------|------------|----------------------------------------------------------------------------------------------------------------------------------------|
| allowEmpty | *Boolean* | Add an empty icon selector in the beginning of each icon list.
Default: true |
| iconLibraries | *Array* | Array of JSON icon libraries in `assets/icons-libraries`.
Default: `null` |
| iconLibrariesCss | *Array* | Array of CSS icon libraries in `assets/stylesheets` or from any CDN. Leave empty if your page already loads them.
Default: `null` |
| mode | *String* | `'autoload'` or `'onrequest'`. Default: `'autoload'` |
| parentElement | *String* | Selector for the parent element to attach the icon picker to. Default: `body` |
| onReset | *Function* | Callback function when the user clicks the `reset` button.
Default: `null` |
| onSelect | *Function* | Callback function when the user clicks the `insert` button.
Default: `null` |
| resetSelector | *String* | Selector for the HTML *reset* button on your page.
Default: `null` |
| language | *String* | Language code for the UI messages.
E.g.: 'en'
Default: `navigator.language || navigator.userLanguage` (browser language) |
| loadCustomCss | *Boolean* | If true, universal icon picker does **not** load its own css allowing for custom css. Default: `false` |
## Configuring loaded assetsUniverstal icon picker will retrieve some assets from the server based on where ths script itself was retrieved from (`assets/js/universal-icon-picker.min.js`) :
1. Icons from the `assets/images`folder
2. Icon library json files from the `assets/icon-libraries` folderAlso, the naming of the library names in the sidebar is derived from their file name in `assets/icon-libraries`.
In most cases this will just work fine. For some installations, however, you need to adjust the exact paths from where to retrieve those assets.
### Configuring icon assets
Three option settings overwrite the paths for the three icons used:
| option | type | value |
|------------------|----------|------------------------------------------------------|
| closeUrl | *String* | Path of the close button icon (some type of "x") |
| starUrl | *String* | Path of the star icon for the side bar |
| searchUrl | *String* | Path of the magnifying glass icon for the search bar |### Configuring library assets
Library assets are defined by `iconLibraries`. If the library does include a slash (`/`) it is assumed to be an URL or path of the library's json file. If it does not include a slash the library is searched for in the `assets/icon-libraries` folder.
### Example
```javascript
const options = {
iconLibraries: [
'happy-icons.min.json',
'font-awesome.min.json'
],
iconLibrariesCss: [
'happy-icons.min.css',
'https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0/css/all.min.css'
],
resetSelector: '#uip-reset-btn',
onSelect: function(jsonIconData) {
document.getElementById('output-icon').innerHTML = jsonIconData.iconMarkup;console.log(jsonIconData);
/* will output something like:
{
"libraryId": "fa-solid",
"libraryName": "fontAwesome",
"iconHtml": "",
"iconMarkup": "<i class="fa-solid fa-oil-can"></i>",
"iconClass": "fa-solid fa-oil-can",
"iconText": ""
}
*/
},
onReset: function() {
document.getElementById('output-icon').innerHTML = '';
}
}// Instanciate the Icon Picker
var uip = new UniversalIconPicker('#selector', options);
```See the source code of the [demo](https://universal-icon-picker.miglisoft.com) for more examples
## Public methods
- ### setOptions(options)
Update the *options* of an Icon Picker instance
Example:
```javascript
// Instanciate the Icon Pickervar uip = new UniversalIconPicker('#selector', options);
// later, change the icon libraries
uip.setOptions({
iconLibraries: ['weather-icons.min.json'],
iconLibrariesCss: ['weather-icons.min.css']
});```
Live demo: [https://universal-icon-picker.miglisoft.com/demo/demo-4.html](https://universal-icon-picker.miglisoft.com/demo/demo-4.html)
## Change / Upgrade Fontawesome version & icons
A built-in tool is provided to get the Fontawesome icon list from the Fontawesome API and for Bootstrap icons to scrape the Bootstrap icon list from their website.
To choose the Fontawesome version:
1. open `tools/fontawesome-icons-list.html` in your code editor and change the version number:
```html
// set the fontawesome version version here
const fontawesomeVersion = '6.0.0';
```2. open it in your browser to retrieve the JSON list
3. save the complete list in `assets/icon-libraries/font-awesome.json` and each style (brands, regular, solid) in the appropriate json file (`assets/icon-libraries/font-awesome-brands.json`, ...)
4. minify the json files to `.min.json`
For Bootstrap icons use `tools/bootstrap-icons-list.html`. It scrapes the latest version from the website. You will need to add the version number manually to the generated json file.
## Screenshots
![Universal Icon Picker Screenshot](https://universal-icon-picker.miglisoft.com/demo/assets/images/screenshot.png)
## Contributing
Contributions are always welcome!
Please contact us for any improvement suggestions or send your pull requests
## Changelog
2024/09/26
- add the type="button" attribute to the icon picker button
- add the parentElement option to attach the icon picker to a specific element2024/04/16
- add language option to set the UI language
2023/03/09
- add loadCustomCss option
- Double click inserts icon2023/02/09
- add Fomantic UI icons
2022/11/18
- update npm package
2022/02/26
- detect absolute css urls starting without protocol ; ie: '//domain.com/my-font.css'
- allow more complex trigger button selectors ; ie: '#div button["name=iconpicker-opener"]'
- add the "onBeforeOpen" option
- add the "onBeforeOpen" demo (demo 5)2022/02/23
- First release
- fix icon selections when changing the icon library programatically with setOptions()
- update README## License
[MIT](https://choosealicense.com/licenses/mit/)
## Credits
Thanks to Sabbir for his [Aesthetic Icon Picker](https://github.com/sh-sabbir/aesthetic-icon-picker/tree/20d6aa6134311b44891809cc852dbf247a029495), which gave me a clean & strong base code for this project.