UNPKG

@asi-ngtools/lib

Version:

This project is a little components library, simple to use, which will help you to simplify your project.

273 lines (272 loc) 20.7 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { Component, Input, ViewChild, Renderer2, ElementRef, forwardRef, ContentChild } from '@angular/core'; import { FormControl, NG_VALUE_ACCESSOR } from '@angular/forms'; import { AsiComponentTemplateTreeLeafDef, AsiComponentTemplateTreeNodeDef, AsiComponentTemplateClearDef } from '../common/asi-component-template'; import { AsiTreeViewComponent } from '../asi-tree-view/asi-tree-view.component'; import { DefaultControlValueAccessor } from '../common/default-control-value-accessor'; import * as nh from '../../native-helper'; var AsiTreeSelectComponent = /** @class */ (function (_super) { tslib_1.__extends(AsiTreeSelectComponent, _super); function AsiTreeSelectComponent(renderer, elementRef) { var _this = _super.call(this) || this; _this.renderer = renderer; _this.elementRef = elementRef; /** * Label position */ _this.labelPosition = 'top'; /** * Field containing the label of the item to display */ _this.labelField = 'label'; /** * Field containing the children of an item */ _this.childrenField = 'children'; /** * Allow selection of nodes which have children */ _this.allowParentSelection = false; /** * Display a clear button */ _this.clearButton = false; _this.formControl = new FormControl(); _this.dropdownOpened = false; _this.isLeaf = function (item) { return item && nh.isEmpty(item[_this.childrenField]); }; return _this; } /** * @return {?} */ AsiTreeSelectComponent.prototype.ngOnInit = /** * @return {?} */ function () { this.renderer.addClass(this.elementRef.nativeElement, 'label-' + this.labelPosition); }; /** * @param {?} node * @return {?} */ AsiTreeSelectComponent.prototype.onNodeSelected = /** * @param {?} node * @return {?} */ function (node) { /** @type {?} */ var item = node.data; if (this.isLeaf(item) || this.allowParentSelection) { this.asiTreeView.filterNodes(function () { return true; }); this.dropdownOpened = false; if (item && item[this.labelField]) { this.value = item; this.formControl.setValue(item[this.labelField], { emitEvent: false }); } else { this.value = null; this.formControl.setValue(null, { emitEvent: false }); } } }; /** * @param {?} filter * @return {?} */ AsiTreeSelectComponent.prototype.onFilter = /** * @param {?} filter * @return {?} */ function (filter) { var _this = this; if (filter) { if (this.filter) { this.asiTreeView.filterNodes(function (item) { return _this.filter && _this.filter(item, filter); }); } } else { this.asiTreeView.filterNodes(function () { return true; }); } }; /** * @return {?} */ AsiTreeSelectComponent.prototype.toggleDropdown = /** * @return {?} */ function () { this.dropdownOpened = !this.disabled && !this.dropdownOpened; }; /** * @return {?} */ AsiTreeSelectComponent.prototype.onDropdownClosed = /** * @return {?} */ function () { this.dropdownOpened = false; }; /** * @return {?} */ AsiTreeSelectComponent.prototype.clear = /** * @return {?} */ function () { this.dropdownOpened = false; this.value = null; this.formControl.reset(); }; /** * @return {?} */ AsiTreeSelectComponent.prototype.displayClearButton = /** * @return {?} */ function () { return this.clearButton && this.value; }; // override DefaultControlValueAccessor#writeValue /** * @param {?} value * @return {?} */ AsiTreeSelectComponent.prototype.writeValue = /** * @param {?} value * @return {?} */ function (value) { this._value = value; if (this.value && this.value[this.labelField]) { this.formControl.setValue(this.value[this.labelField], { emitEvent: false }); } else { this.formControl.reset(); } }; AsiTreeSelectComponent.decorators = [ { type: Component, args: [{ selector: 'asi-tree-select', template: "<label class=\"input-label\" *ngIf=\"label\">{{label | translate}}</label>\n\n<div class=\"select\" [class.disabled]=\"disabled\">\n <div class=\"header asi-focus-error\" #selectHeader>\n <asi-input [placeholder]=\"placeholder\" [formControl]=\"formControl\" [disabled]=\"disabled\" [id]=\"id\" [name]=\"name\"\n (onValueChange)=\"onFilter($event)\" (click)=\"toggleDropdown()\"></asi-input>\n <asi-fa-icon *ngIf=\"displayClearButton()\" (click)=\"clear()\" icon=\"fas fa-times\" class=\"smaller\"></asi-fa-icon>\n <asi-fa-icon [icon]=\"(dropdownOpened) ? 'fa fa-chevron-up' : 'fa fa-chevron-down'\" [disabled]=\"disabled\"\n (click)=\"toggleDropdown()\"></asi-fa-icon>\n </div>\n\n <div class=\"options\">\n <asi-dropdown [relativeTo]=\"selectHeaderContainer\" [calculWidth]=\"true\" [open]=\"dropdownOpened\"\n (onClose)=\"onDropdownClosed()\" dropDownClass=\"asi-tree-select-dropdown\">\n <div class=\"drop-down-tree-select\">\n <div class=\"drop-down-panel\">\n <div *ngIf=\"clearDef\" (click)=\"clear()\" class=\"clear-value-item\">\n <ng-template [ngTemplateOutlet]=\"clearDef.template\"></ng-template>\n </div>\n\n <asi-tree-view [data]=\"data\" [isLeaf]=\"isLeaf\" [nodeName]=\"childrenField\"\n (onNodeSelected)=\"onNodeSelected($event)\" iconOpen=\"far fa-plus-square\" iconClose=\"far fa-minus-square\">\n <asi-tree-node *asiTreeNodeDef=\"let node\">\n <div class=\"drop-down-item\">\n <ng-template [ngTemplateOutlet]=\"nodeDef.template\" [ngTemplateOutletContext]=\"{$implicit : node}\">\n </ng-template>\n </div>\n </asi-tree-node>\n\n <asi-tree-leaf *asiTreeLeafDef=\"let node\">\n <div class=\"drop-down-item\">\n <ng-template [ngTemplateOutlet]=\"leafDef.template\" [ngTemplateOutletContext]=\"{$implicit : node}\">\n </ng-template>\n </div>\n </asi-tree-leaf>\n </asi-tree-view>\n </div>\n </div>\n </asi-dropdown>\n </div>\n</div>\n", host: { 'class': 'asi-component asi-tree-select' }, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(function () { return AsiTreeSelectComponent; }), multi: true } ] }] } ]; /** @nocollapse */ AsiTreeSelectComponent.ctorParameters = function () { return [ { type: Renderer2 }, { type: ElementRef } ]; }; AsiTreeSelectComponent.propDecorators = { id: [{ type: Input }], name: [{ type: Input }], label: [{ type: Input }], labelPosition: [{ type: Input }], placeholder: [{ type: Input }], data: [{ type: Input }], labelField: [{ type: Input }], childrenField: [{ type: Input }], allowParentSelection: [{ type: Input }], filter: [{ type: Input }], clearButton: [{ type: Input }], selectHeaderContainer: [{ type: ViewChild, args: ['selectHeader',] }], asiTreeView: [{ type: ViewChild, args: [AsiTreeViewComponent,] }], clearDef: [{ type: ContentChild, args: [AsiComponentTemplateClearDef,] }], nodeDef: [{ type: ContentChild, args: [AsiComponentTemplateTreeNodeDef,] }], leafDef: [{ type: ContentChild, args: [AsiComponentTemplateTreeLeafDef,] }] }; return AsiTreeSelectComponent; }(DefaultControlValueAccessor)); export { AsiTreeSelectComponent }; if (false) { /** * html id * @type {?} */ AsiTreeSelectComponent.prototype.id; /** * html name * @type {?} */ AsiTreeSelectComponent.prototype.name; /** * Label to display (is translated) * @type {?} */ AsiTreeSelectComponent.prototype.label; /** * Label position * @type {?} */ AsiTreeSelectComponent.prototype.labelPosition; /** * Placeholder * @type {?} */ AsiTreeSelectComponent.prototype.placeholder; /** * Select data * @type {?} */ AsiTreeSelectComponent.prototype.data; /** * Field containing the label of the item to display * @type {?} */ AsiTreeSelectComponent.prototype.labelField; /** * Field containing the children of an item * @type {?} */ AsiTreeSelectComponent.prototype.childrenField; /** * Allow selection of nodes which have children * @type {?} */ AsiTreeSelectComponent.prototype.allowParentSelection; /** * Functions used to decide if an item should be displayed when a filter is applied (returns a boolean) * @type {?} */ AsiTreeSelectComponent.prototype.filter; /** * Display a clear button * @type {?} */ AsiTreeSelectComponent.prototype.clearButton; /** @type {?} */ AsiTreeSelectComponent.prototype.selectHeaderContainer; /** @type {?} */ AsiTreeSelectComponent.prototype.asiTreeView; /** @type {?} */ AsiTreeSelectComponent.prototype.clearDef; /** @type {?} */ AsiTreeSelectComponent.prototype.nodeDef; /** @type {?} */ AsiTreeSelectComponent.prototype.leafDef; /** @type {?} */ AsiTreeSelectComponent.prototype.formControl; /** @type {?} */ AsiTreeSelectComponent.prototype.dropdownOpened; /** @type {?} */ AsiTreeSelectComponent.prototype.isLeaf; /** @type {?} */ AsiTreeSelectComponent.prototype.renderer; /** @type {?} */ AsiTreeSelectComponent.prototype.elementRef; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asi-tree-select.component.js","sourceRoot":"ng://@asi-ngtools/lib/","sources":["lib/components/asi-tree-select/asi-tree-select.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, ViewChild, OnInit, Renderer2, ElementRef, forwardRef, ContentChild } from '@angular/core';\nimport { FormControl, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport {\n  AsiComponentTemplateTreeLeafDef,\n  AsiComponentTemplateTreeNodeDef,\n  AsiComponentTemplateClearDef\n} from '../common/asi-component-template';\nimport { AsiTreeViewComponent } from '../asi-tree-view/asi-tree-view.component';\nimport { AsiTreeViewNodeComponent } from '../asi-tree-view/node/asi-tree-view-node.component';\nimport { DefaultControlValueAccessor } from '../common/default-control-value-accessor';\nimport * as nh from '../../native-helper';\n\n@Component({\n  selector: 'asi-tree-select',\n  templateUrl: 'asi-tree-select.component.html',\n  host: { 'class': 'asi-component asi-tree-select' },\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => AsiTreeSelectComponent),\n      multi: true\n    }\n  ]\n})\nexport class AsiTreeSelectComponent extends DefaultControlValueAccessor implements OnInit {\n\n  /** html id */\n  @Input() id: string;\n\n  /** html name */\n  @Input() name: string;\n\n  /** Label to display (is translated) */\n  @Input() label: string;\n\n  /** Label position */\n  @Input() labelPosition: 'top' | 'left' | 'right' | 'bottom' | 'bottom-center' | 'top-center' = 'top';\n\n  /** Placeholder */\n  @Input() placeholder: string;\n\n  /** Select data */\n  @Input() data: any[];\n\n  /** Field containing the label of the item to display */\n  @Input() labelField = 'label';\n\n  /** Field containing the children of an item */\n  @Input() childrenField = 'children';\n\n  /** Allow selection of nodes which have children */\n  @Input() allowParentSelection = false;\n\n  /** Functions used to decide if an item should be displayed when a filter is applied (returns a boolean) */\n  @Input() filter: (item: any, filter: string) => boolean;\n\n  /** Display a clear button */\n  @Input() clearButton = false;\n\n  @ViewChild('selectHeader') selectHeaderContainer: ElementRef;\n  @ViewChild(AsiTreeViewComponent) asiTreeView: AsiTreeViewComponent;\n\n  @ContentChild(AsiComponentTemplateClearDef) clearDef: AsiComponentTemplateClearDef;\n  @ContentChild(AsiComponentTemplateTreeNodeDef) nodeDef: AsiComponentTemplateTreeNodeDef;\n  @ContentChild(AsiComponentTemplateTreeLeafDef) leafDef: AsiComponentTemplateTreeLeafDef;\n\n  formControl = new FormControl();\n  dropdownOpened = false;\n\n  constructor(\n    private renderer: Renderer2,\n    private elementRef: ElementRef\n  ) { super(); }\n\n  ngOnInit() {\n    this.renderer.addClass(this.elementRef.nativeElement, 'label-' + this.labelPosition);\n  }\n\n  isLeaf = (item: any) => {\n    return item && nh.isEmpty(item[this.childrenField]);\n  };\n\n  onNodeSelected(node: AsiTreeViewNodeComponent) {\n    const item = node.data;\n    if (this.isLeaf(item) || this.allowParentSelection) {\n      this.asiTreeView.filterNodes(() => true);\n      this.dropdownOpened = false;\n\n      if (item && item[this.labelField]) {\n        this.value = item;\n        this.formControl.setValue(item[this.labelField], { emitEvent: false });\n      } else {\n        this.value = null;\n        this.formControl.setValue(null, { emitEvent: false });\n      }\n    }\n  }\n\n  onFilter(filter: string) {\n    if (filter) {\n      if (this.filter) {\n        this.asiTreeView.filterNodes((item: any) => {\n          return this.filter && this.filter(item, filter);\n        });\n      }\n    } else {\n      this.asiTreeView.filterNodes(() => true);\n    }\n  }\n\n  toggleDropdown() {\n    this.dropdownOpened = !this.disabled && !this.dropdownOpened;\n  }\n\n  onDropdownClosed() {\n    this.dropdownOpened = false;\n  }\n\n  clear() {\n    this.dropdownOpened = false;\n    this.value = null;\n    this.formControl.reset();\n  }\n\n  displayClearButton(): boolean {\n    return this.clearButton && this.value;\n  }\n\n  // override DefaultControlValueAccessor#writeValue\n  writeValue(value: any): void {\n    this._value = value;\n    if (this.value && this.value[this.labelField]) {\n      this.formControl.setValue(this.value[this.labelField], { emitEvent: false });\n    } else {\n      this.formControl.reset();\n    }\n  }\n\n}\n"]}