Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/manishjanky/ngx-select-dropdown
Custom Dropdown for Angular 4+ with multiple and single selection options
https://github.com/manishjanky/ngx-select-dropdown
angular angular4 component custom custom-dropdown dropdown library multiselect multiselectdropdown ngx-select-dropdown select single-select
Last synced: 6 days ago
JSON representation
Custom Dropdown for Angular 4+ with multiple and single selection options
- Host: GitHub
- URL: https://github.com/manishjanky/ngx-select-dropdown
- Owner: manishjanky
- License: mit
- Created: 2018-01-19T10:21:52.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2023-12-07T15:19:21.000Z (about 1 year ago)
- Last Synced: 2024-12-13T21:08:12.069Z (13 days ago)
- Topics: angular, angular4, component, custom, custom-dropdown, dropdown, library, multiselect, multiselectdropdown, ngx-select-dropdown, select, single-select
- Language: TypeScript
- Homepage:
- Size: 9.97 MB
- Stars: 117
- Watchers: 7
- Forks: 81
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: License
Awesome Lists containing this project
README
# ngx-select-dropdown
[![GitHub license](https://img.shields.io/github/license/manishjanky/ngx-select-dropdown.svg)](https://github.com/me-and/mdf/blob/master/LICENSE)
[![npm](https://img.shields.io/npm/v/ngx-select-dropdown.svg)]()
[![Build Status](https://travis-ci.org/manishjanky/ngx-select-dropdown.svg?branch=master)](https://travis-ci.org/manishjanky/ngx-select-dropdown)
[![Codecov branch](https://codecov.io/gh/manishjanky/ngx-select-dropdown/branch/master/graphs/badge.svg)]()
![npm](https://img.shields.io/npm/dy/ngx-select-dropdown)
[![GitHub top language](https://img.shields.io/github/languages/top/manishjanky/ngx-select-dropdown.svg)]()
[![GitHub code size in bytes](https://img.shields.io/github/languages/code-size/manishjanky/ngx-select-dropdown.svg)]()`ngx-select-dropdown` Custom Dropdown component for Angular 4+ with multiple and single selection options, with customization options
## Features
* single select dropdown
* multi select dropdown
* search dropdown list
* arrows keys support
* limit number of items displayed in dropdown
* custom sort
* angular forms support
* angular v4 and above supported
* cross browser support
* custom template options## Examples
* [demo-page](https://manishjanky.github.io/ngx-select-dropdown/)
## Installation
* `npm install ngx-select-dropdown`
### Using with webpack and tsc builds/ angular-cli builds
* import `SelectDropDownModule` into your app.module;
````
import { SelectDropDownModule } from 'ngx-select-dropdown'
````
* add `SelectDropDownModule` to the imports of your NgModule:
`````
@NgModule({
imports: [
...,
SelectDropDownModule
],
...
})
class YourModule { ... }
`````* include css styles in you `angular-cli.json` for versions earlier than 1.4.0
`````
"styles": [
"../node_modules/ngx-select-dropdown/dist/assets/style.css"
],
`````* use `` in your templates to add the custom dropdown in your view like below
````
````
* use with reactive form like
````````
* use custom templates options like below. `item` and `config` variables available in the template context
````
{{item.name}}
````
## Configuration
### Input
* `multiple: boolean` - `true/false` beased if multiple selection required or not `Defaults to false`.
* `options: Array` - Array of string/objects that are to be the dropdown options.
* `disabled: boolean` - disabled attribute to disable the dropdown when required.
* `instanceId: any` - instanceId of the dropdwon component instance.
* `config: NgxDropdownConfig` - configuration object.
* `selectedItemTemplate: TemplateRef` - Custom template ref for the selected item
* `optionItemTemplate: TemplateRef` - Custom template ref for the options items(available options)
* `dropdownButtonTemplate: TemplateRef` - Custom template ref for the dropdwon button element
* `notFoundTemplate: TemplateRef` - Custom template ref for the no matched found message
````
config = {
displayFn:(item: any) => { return item.hello.world; } //to support flexible text displaying for each item
displayKey:"description", //if objects array passed which key to be displayed defaults to description
search:true //true/false for the search functionlity defaults to false,
height: 'auto' //height of the list so that if there are more no of items it can show a scroll defaults to auto. With auto height scroll will never appear
placeholder:'Select' // text to be displayed when no item is selected defaults to Select,
customComparator: ()=>{} // a custom function using which user wants to sort the items. default is undefined and Array.sort() will be used in that case,
limitTo: 0 // number thats limits the no of options displayed in the UI (if zero, options will not be limited)
moreText: 'more' // text to be displayed whenmore than one items are selected like Option 1 + 5 more
noResultsFound: 'No results found!' // text to be displayed when no items are found while searching
searchPlaceholder:'Search' // label thats displayed in search input,
searchOnKey: 'name' // key on which search should be performed this will be selective search. if undefined this will be extensive search on all keys
clearOnSelection: false // clears search criteria when an option is selected if set to true, default is false
inputDirection: 'ltr' // the direction of the search input can be rtl or ltr(default)
selectAllLabel: 'Select all' // label that is displayed in multiple selection for select all
enableSelectAll: false, // enable select all option to select all available items, default is false
}
````### Output
* `change: Event` - change event when user changes the selected options
* `open: Event` - open event when the dropdown toogles on
* `close: Event` - close event when the dropdown toogles off
* `searchChange: Event` - search change event when the search text changes### Dropdown service
* `openDropdown(instanceId:string)` - method to open a particular dropdown instance
* `closeDropdown(instanceId:string)` - method to close a particular dropdown instance
* `isOpen(instanceId:string)` - method to check if a particular instance dropdown is open
* `openInstances` - instanceId list of all the open instances### Change detection
As of now `ngx-select-dropdown` uses Default change detection startegy which means dirty checking checks for immutable data types. And in Javascript Objects and arrays are mutable. So when changing any of the @Input parameters if you mutate an object change detection will not detect it. For ex:-
````
this.options.push({id: 34, description: 'Adding new item'});// or
config.height = '200px';
`````
Both the above scenarios will not trigger the change detection. In order for the componet to detect the changes what you need to do is:-
````
this.options = [...this.options, {id: 34, description: 'Adding new item'}];// or
config = {...config, height:'200px'};
````
## Changelog
* v0.1.0
````
Added a change event so that user can attach a change event handler.
If multiselect the selected text will display first item and + count for eg. (Option 1 + 2 more) .
````
* v0.2.0
````
Angular 4 and above support.
Bug with search functionality fixed.
````
* v0.3.0
````
Support for Observable data source for options and async pipe.
IE bug with styling.
Few other minor bug fixes.
````
* v0.4.0
````
Use arrows keys and enter to select items from available options.
Case insensitive search.
Few other minor bug fixes.
````
* v0.5.0
````
Support for scroll bar with too many list items.
Few other minor bug fixes.
````
* v0.7.0
````
Support for limito pipe to limit number of options displayed in case of too many options.
Support for customComparator / custom sort function
Few other minor bug fixes.
````
* v0.7.2
````
Support for angular 6
Removed dependency on rxjs
````
* v0.8.0
````
No Results found indicator with custom text passed with config
Custom text for *more* when more than 1 items selected
Open event emitted
Close event emitted
Search placeholder text
````
* v1.0.0
````
Search on a specified key value.
Support for Reactive forms
Few other minor imoprovements and fixes
````
* v1.2.0
````
Search text change event searchChange
````
* v1.3.0
````
Clear search on selection config
Disable with reactive forms .disable()
````
* v1.5.0
````
Custom function for displaying text for each option
Add disabled class to different items based on item.disabled
````
* v2.0.0
````
Angular library approach opted for development
Angular Ivy compatibility
````
* v3.0.0
````
Dropdown singleton service to interact with dropdown instances
Instance identifier
Upgraded to Angular v14 development environment
````
* v3.0.1
````
Auto drop based on the screen position
Over-ride css styles for available and selected items using class names `selected-item(s)` and `available-item(s)`
````
* v3.2.0
````
Ability to select all available items using a select all checkbox
````
* v3.3.0
````
Custom templates for available options, selected items and the dropdown button
Other minor fixes
````
## Help ImproveFound a bug or an issue with this? [Open a new issue](https://github.com/manishjanky/ngx-select-dropdown/issues) here on GitHub.
## Contributing to this project
Anyone and everyone is welcome to contribute. Please take a moment to
review the [guidelines for contributing](CONTRIBUTING.md).* [Bug reports](CONTRIBUTING.md#bugs)
* [Feature requests](CONTRIBUTING.md#features)
* [Pull requests](CONTRIBUTING.md#pull-requests)