Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

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

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)