Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/crazyht/ngx-tree-select
Angular select component with tree items
https://github.com/crazyht/ngx-tree-select
angular4 library ngx select treeview
Last synced: 2 months ago
JSON representation
Angular select component with tree items
- Host: GitHub
- URL: https://github.com/crazyht/ngx-tree-select
- Owner: Crazyht
- License: mit
- Created: 2017-01-02T20:17:20.000Z (about 8 years ago)
- Default Branch: dev
- Last Pushed: 2022-12-10T15:45:16.000Z (about 2 years ago)
- Last Synced: 2024-04-14T13:13:03.713Z (10 months ago)
- Topics: angular4, library, ngx, select, treeview
- Language: TypeScript
- Homepage: https://crazyht.github.io/ngx-tree-select/
- Size: 2.7 MB
- Stars: 56
- Watchers: 3
- Forks: 45
- Open Issues: 56
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# Ngx-tree-select
[![Greenkeeper badge](https://badges.greenkeeper.io/Crazyht/ngx-tree-select.svg)](https://greenkeeper.io/)
[![Build Status](https://travis-ci.org/Crazyht/ngx-tree-select.svg?branch=dev)](https://travis-ci.org/Crazyht/ngx-tree-select)
[![npm version](https://badge.fury.io/js/ngx-tree-select.svg)](https://badge.fury.io/js/ngx-tree-select)
## Features:
- Dropdown with 'flat' items (Like normal select)
- Dropdown with hierarchical items
- Simple or multiple selected items
- With hierarchical datas you can force child selection or allow select parent
- ngModel & standard validation compliant
- Can limit displayed selected items (... link allow your user to see entire selection)## Installation
This is how to install the components:
```bash
npm install ngx-tree-select
```or
```bash
yarn add ngx-tree-select
```And on your application module:
```ts
import {NgxTreeSelectModule} from 'ngx-tree-select';@NgModule({
declarations: [ ...],
imports: [
BrowserModule,
....,
NgxTreeSelectModule.forRoot({
allowFilter: true,
filterPlaceholder: 'Type your filter here...',
maxVisibleItemCount: 5,
idField: 'id',
textField: 'name',
childrenField: 'children',
allowParentSelection: true
})
],
})
export class AppModule { }
```See below for SystemJs / UMD installation.
# Default options
When you call ```NgxTreeSelectModule.forRoot``` you must pass default options. This options can be empty object "{}" or you can add one or more settings :
- **allowFilter** : display filter input on dropdown
- **filterPlaceholder** : determine placeholder text for filter
- **maxVisibleItemCount** : determine maximum number of items are displayed on multiple select
- **idField** : determine which property of your items is used as unique identifier
- **textField** : determine which property of your items is displayed
- **childrenField** : determine which property of yours items contains children items
- **allowParentSelection** : if set to **true**, you can select parent, else when you select parent all children are selected
- **expandMode** : Define which item are expand at initilization. Possible value are : **None**, **Selection** or **All**# Using the Tree Select
We will need to add first a version of Font Awesome to our page, for example:
```html
```
Then we can use the Tree Select like this:
```html
Simple select is required
Multiple select is required
You must choose at least 2 items on Multiple select
You must choose maximum 4 items on Multiple select
```# Component attributes
When you place **tree-select** on HTML template you can define :
- **items** : list of items
- **multiple** : allow multiple selection
- **disabled** : disable component
- **allowFilter** : display filter input on dropdown
- **filterPlaceholder** : determine placeholder text for filter
- **maxVisibleItemCount** : determine maximum number of items are displayed on multiple select
- **idField** : determine which property of your items is used as unique identifier
- **textField** : determine which property of your items is displayed
- **childrenField** : determine which property of yours items contains children items
- **allowParentSelection** : if set to **true**, you can select parent, else when you select parent all children are selected
- **expandMode** : Define which item are expand at initilization. Possible value are : **None**, **Selection** or **All****tree-select** component use default options define when you call ```NgxTreeSelectModule.forRoot``` except if you override it with attribute on HTML template.
# Running the Demo Application
This command will build and start the demo application:```bash
npm start
```# Running This Module In Development
First let's build the library using this command:
```bash
npm run lib:build
```Then let's link it:
```bash
cd dist_package\ngx-tree-select
npm link
```On another folder on the same machine where we have for example a running Angular CLI, we then do:
```bash
npm link ngx-tree-select
```# Running the Tests
The tests can be executed with the following commands:
```bash
npm run test
npm run e2e
```## Using SystemJs via the UMD bundle ?
Make sure to add this to your `map` configuration, if you need the module served from a CDN:
```javascript
map: {...
'ngx-tree-select': 'https://unpkg.com/ngx-tree-select@/ngx-tree-select.rollup.umd.min.js'
}
```Otherwise if serving from `node_modules`directly:
```javascript
map: {
...
'ngx-tree-select': 'node_modules/ngx-tree-select/bundles/ngx-tree-select.umd.min.js'
}
```And in our packages property:
```javascript
packages: {
...
'ngx-tree-select': {
main: 'index.js',
defaultExtension: 'js'
}}
```# License
[MIT](https://opensource.org/licenses/MIT)