UNPKG

@asi-ngtools/lib

Version:

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

250 lines (249 loc) 19.7 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { Component, Input, forwardRef, ElementRef, ContentChild, ViewChild, Renderer2 } from '@angular/core'; import { NG_VALUE_ACCESSOR, FormControl } from '@angular/forms'; import { DefaultControlValueAccessor } from './../../common/default-control-value-accessor'; import { AsiComponentTemplateOptionDef, AsiComponentTemplateTagDef } from './../../common/asi-component-template'; import { debounceTime, switchMap, tap } from 'rxjs/operators'; import * as nh from '../../../native-helper'; /** * asi-autocomplete-multiple component */ var AsiAutoCompleteMultipleComponent = /** @class */ (function (_super) { tslib_1.__extends(AsiAutoCompleteMultipleComponent, _super); function AsiAutoCompleteMultipleComponent(renderer) { var _this = _super.call(this) || this; _this.renderer = renderer; /** * Label position */ _this.labelPosition = 'top'; /** * Placeholder if needed */ _this.placeholder = ''; /** * Delay between the moment you stop typing and onRequestData is called */ _this.delay = 500; /** * Option to keep the list open once an item is selected */ _this.closeAfterSelect = false; _this.autoCompleteControl = new FormControl(); _this.open = false; // Var used to manage component initialization _this.firstRequestDone = null; _this.init = false; _this.currentValue = null; return _this; } /** * @return {?} */ AsiAutoCompleteMultipleComponent.prototype.checkInput = /** * @return {?} */ function () { if (null == this.onRequestData) { throw new Error("AsiAutoCompleteMultipleComponent : @Input 'onRequestData' is required"); } }; /** * @return {?} */ AsiAutoCompleteMultipleComponent.prototype.ngOnInit = /** * @return {?} */ function () { var _this = this; this.checkInput(); this.renderer.addClass(this.container.nativeElement, 'label-' + this.labelPosition); this.autoCompleteControl.valueChanges .pipe(debounceTime(this.delay), tap(function (value) { return (_this.currentValue = value); }), switchMap(function (value) { return nh.observe(_this.onRequestData(value, !_this.firstRequestDone)); })) .subscribe(function (data) { _this.data = data; if (_this.firstRequestDone && data && data.length > 0) { _this.open = true; } _this.firstRequestDone = true; }); }; /** * @return {?} */ AsiAutoCompleteMultipleComponent.prototype.onDropdownClose = /** * @return {?} */ function () { this.open = false; }; /** * @return {?} */ AsiAutoCompleteMultipleComponent.prototype.ngOnChanges = /** * @return {?} */ function () { if (this.init) { this.open = true; } else { if (this.firstRequestDone) { this.init = true; } } }; /** * @param {?} data * @return {?} */ AsiAutoCompleteMultipleComponent.prototype.addValue = /** * @param {?} data * @return {?} */ function (data) { this.value = (this.value ? /** @type {?} */ (this.value) : []).concat([data]); if (this.closeAfterSelect) { this.open = false; } }; /** * @param {?} data * @return {?} */ AsiAutoCompleteMultipleComponent.prototype.removeValue = /** * @param {?} data * @return {?} */ function (data) { /** @type {?} */ var tab = this.value; nh.remove(tab, function (value) { return data === value; }); this.value = tab; if (nh.isEmpty(this.value)) { this.value = null; } }; /** * @param {?} value * @return {?} */ AsiAutoCompleteMultipleComponent.prototype.writeValue = /** * @param {?} value * @return {?} */ function (value) { this._value = value; if (this.init === false) { this.autoCompleteControl.setValue(this.currentValue); } else { this.currentValue = value; if (this.value == null) { this.autoCompleteControl.setValue(this.currentValue, { emitEvent: false }); } } }; AsiAutoCompleteMultipleComponent.decorators = [ { type: Component, args: [{ selector: 'asi-autocomplete-multiple', template: "<div class=\"tag-container\">\r\n <div class=\"tag\" *ngFor=\"let aValue of value\">\r\n <span>\r\n <ng-template [ngTemplateOutlet]=\"tagDef.template\" [ngTemplateOutletContext]=\"{$implicit : aValue}\"></ng-template>\r\n </span>\r\n <button type=\"button\" [disabled]=\"disabled\" class=\"remove-icon-container\" (click)=\"removeValue(aValue)\">\r\n <span class=\"remove-icon\" [innerHTML]=\"'&#10005;'\"></span>\r\n </button>\r\n </div>\r\n</div>\r\n<div class=\"autocomplete-container\" #container>\r\n <label class=\"input-label\" *ngIf=\"label != null\">{{label | translate}}</label>\r\n <div class=\"autocomplete\">\r\n <input [attr.id]=\"id\" [attr.name]=\"name\"\r\n [attr.disabled]=\"disabled ? '' : null\" class=\"asi-focus-error\"\r\n [placeholder]=\"placeholder\" [formControl]=\"autoCompleteControl\"/>\r\n\r\n <asi-dropdown [open]=\"open\" (onClose)=\"onDropdownClose()\" dropDownClass=\"asi-autocomplete-multiple-dropdown\">\r\n <div class=\"drop-down-autocomplete-multiple\">\r\n <div class=\"drop-down-panel\" [ngClass]=\"{'open' : open }\">\r\n <button [id]=\"'asi-acmddi-'+ id\" type=\"button\" class=\"drop-down-item\" (click)=\"addValue(aData)\" *ngFor=\"let aData of data\">\r\n <div class=\"option\">\r\n <span class=\"item\">\r\n <ng-template *ngIf=\"aData != null\" [ngTemplateOutlet]=\"optionDef.template\" [ngTemplateOutletContext]=\"{$implicit : aData}\"></ng-template>\r\n </span>\r\n </div>\r\n </button>\r\n </div>\r\n </div>\r\n </asi-dropdown>\r\n\r\n </div>\r\n</div>\r\n", host: { class: 'asi-component asi-autocomplete-multiple' }, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(function () { return AsiAutoCompleteMultipleComponent; }), multi: true } ] }] } ]; /** @nocollapse */ AsiAutoCompleteMultipleComponent.ctorParameters = function () { return [ { type: Renderer2 } ]; }; AsiAutoCompleteMultipleComponent.propDecorators = { id: [{ type: Input }], name: [{ type: Input }], label: [{ type: Input }], labelPosition: [{ type: Input }], placeholder: [{ type: Input }], delay: [{ type: Input }], closeAfterSelect: [{ type: Input }], onRequestData: [{ type: Input }], optionDef: [{ type: ContentChild, args: [AsiComponentTemplateOptionDef,] }], tagDef: [{ type: ContentChild, args: [AsiComponentTemplateTagDef,] }], container: [{ type: ViewChild, args: ['container',] }] }; return AsiAutoCompleteMultipleComponent; }(DefaultControlValueAccessor)); export { AsiAutoCompleteMultipleComponent }; if (false) { /** * html id * @type {?} */ AsiAutoCompleteMultipleComponent.prototype.id; /** * html name * @type {?} */ AsiAutoCompleteMultipleComponent.prototype.name; /** * Label to display (is translated) * @type {?} */ AsiAutoCompleteMultipleComponent.prototype.label; /** * Label position * @type {?} */ AsiAutoCompleteMultipleComponent.prototype.labelPosition; /** * Placeholder if needed * @type {?} */ AsiAutoCompleteMultipleComponent.prototype.placeholder; /** * Delay between the moment you stop typing and onRequestData is called * @type {?} */ AsiAutoCompleteMultipleComponent.prototype.delay; /** * Option to keep the list open once an item is selected * @type {?} */ AsiAutoCompleteMultipleComponent.prototype.closeAfterSelect; /** * Function called to request new data (can return Observable/Promise/Object) : Throw error if null * @type {?} */ AsiAutoCompleteMultipleComponent.prototype.onRequestData; /** @type {?} */ AsiAutoCompleteMultipleComponent.prototype.optionDef; /** @type {?} */ AsiAutoCompleteMultipleComponent.prototype.tagDef; /** @type {?} */ AsiAutoCompleteMultipleComponent.prototype.container; /** @type {?} */ AsiAutoCompleteMultipleComponent.prototype.data; /** @type {?} */ AsiAutoCompleteMultipleComponent.prototype.autoCompleteControl; /** @type {?} */ AsiAutoCompleteMultipleComponent.prototype.open; /** @type {?} */ AsiAutoCompleteMultipleComponent.prototype.firstRequestDone; /** @type {?} */ AsiAutoCompleteMultipleComponent.prototype.init; /** @type {?} */ AsiAutoCompleteMultipleComponent.prototype.currentValue; /** @type {?} */ AsiAutoCompleteMultipleComponent.prototype.renderer; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asi-autocomplete-multiple.component.js","sourceRoot":"ng://@asi-ngtools/lib/","sources":["lib/components/asi-autocomplete/multiple/asi-autocomplete-multiple.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, forwardRef, OnInit, ElementRef, ContentChild, ViewChild, OnChanges, Renderer2 } from '@angular/core';\nimport { NG_VALUE_ACCESSOR, FormControl } from '@angular/forms';\nimport { DefaultControlValueAccessor } from './../../common/default-control-value-accessor';\nimport { AsiComponentTemplateOptionDef, AsiComponentTemplateTagDef } from './../../common/asi-component-template';\nimport { debounceTime, switchMap, tap } from 'rxjs/operators';\nimport * as nh from '../../../native-helper';\n/**\n * asi-autocomplete-multiple component\n */\n@Component({\n  selector: 'asi-autocomplete-multiple',\n  templateUrl: 'asi-autocomplete-multiple.component.html',\n  host: { class: 'asi-component asi-autocomplete-multiple' },\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => AsiAutoCompleteMultipleComponent),\n      multi: true\n    }\n  ]\n})\nexport class AsiAutoCompleteMultipleComponent extends DefaultControlValueAccessor implements OnInit, OnChanges {\n  /** html id */\n  @Input() id: string;\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 if needed */\n  @Input() placeholder = '';\n\n  /** Delay between the moment you stop typing and onRequestData is called */\n  @Input() delay = 500;\n\n  /** Option to keep the list open once an item is selected */\n  @Input() closeAfterSelect = false;\n\n  /** Function called to request new data (can return Observable/Promise/Object) : Throw error if null */\n  @Input() onRequestData: Function;\n\n  @ContentChild(AsiComponentTemplateOptionDef) optionDef: AsiComponentTemplateOptionDef;\n  @ContentChild(AsiComponentTemplateTagDef) tagDef: AsiComponentTemplateTagDef;\n\n  @ViewChild('container') container: ElementRef;\n\n  data: Array<any>;\n\n  autoCompleteControl = new FormControl();\n  open = false;\n\n  // Var used to manage component initialization\n  firstRequestDone: Boolean = null;\n  init = false;\n\n  currentValue: any = null;\n\n  constructor(private renderer: Renderer2) {\n    super();\n  }\n\n  private checkInput() {\n    if (null == this.onRequestData) {\n      throw new Error(\"AsiAutoCompleteMultipleComponent : @Input 'onRequestData' is required\");\n    }\n  }\n\n  ngOnInit() {\n    this.checkInput();\n    this.renderer.addClass(this.container.nativeElement, 'label-' + this.labelPosition);\n\n    this.autoCompleteControl.valueChanges\n      .pipe(\n        debounceTime(this.delay),\n        tap((value) => (this.currentValue = value)),\n        switchMap((value) => nh.observe(this.onRequestData(value, !this.firstRequestDone)))\n      )\n      .subscribe((data: any) => {\n        this.data = data;\n        if (this.firstRequestDone && data && data.length > 0) {\n          this.open = true;\n        }\n        this.firstRequestDone = true;\n      });\n  }\n\n  onDropdownClose() {\n    this.open = false;\n  }\n\n  ngOnChanges() {\n    if (this.init) {\n      this.open = true;\n    } else {\n      if (this.firstRequestDone) {\n        this.init = true;\n      }\n    }\n  }\n\n  addValue(data: any) {\n    this.value = (this.value ? this.value as any[] : []).concat([data]);\n    if (this.closeAfterSelect) {\n      this.open = false;\n    }\n  }\n\n  removeValue(data: any) {\n    const tab = this.value;\n    nh.remove(tab, (value) => {\n      return data === value;\n    });\n    this.value = tab;\n\n    if (nh.isEmpty(this.value)) {\n      this.value = null;\n    }\n  }\n\n  writeValue(value: any) {\n    this._value = value;\n    if (this.init === false) {\n      this.autoCompleteControl.setValue(this.currentValue);\n    } else {\n      this.currentValue = value;\n      if (this.value == null) {\n        this.autoCompleteControl.setValue(this.currentValue, { emitEvent: false });\n      }\n    }\n  }\n}\n"]}