@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
JavaScript
/**
* @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"]}