@asi-ngtools/lib
Version:
This project is a little components library, simple to use, which will help you to simplify your project.
235 lines (234 loc) • 18.5 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component, Input, forwardRef, ContentChild, Renderer2, ElementRef, ViewChild } from '@angular/core';
import { DefaultControlValueAccessor } from './../../common/default-control-value-accessor';
import { NG_VALUE_ACCESSOR, FormControl } from '@angular/forms';
import { AsiComponentTemplateOptionDef, AsiComponentTemplateSelectedDef } from './../../common/asi-component-template';
import { debounceTime, switchMap, tap } from 'rxjs/operators';
import * as nh from '../../../native-helper';
import { AsiDropDown } from '../../asi-dropdown/asi-dropdown.component';
/**
* asi-autocomplete component
*/
var AsiAutoCompleteComponent = /** @class */ (function (_super) {
tslib_1.__extends(AsiAutoCompleteComponent, _super);
function AsiAutoCompleteComponent(renderer, elementRef) {
var _this = _super.call(this) || this;
_this.renderer = renderer;
_this.elementRef = elementRef;
/**
* Label position
*/
_this.labelPosition = 'top';
/**
* Delay between the moment you stop typing and onRequestData is called
*/
_this.delay = 500;
/**
* A placeholder if needed
*/
_this.placeholder = '';
_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 {?}
*/
AsiAutoCompleteComponent.prototype.checkInput = /**
* @return {?}
*/
function () {
if (null == this.onRequestData) {
throw new Error('AsiAutoCompleteComponent : \'onRequestData\' is required');
}
};
/**
* @return {?}
*/
AsiAutoCompleteComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _this = this;
this.checkInput();
this.renderer.addClass(this.elementRef.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 {?}
*/
AsiAutoCompleteComponent.prototype.onDropdownClose = /**
* @return {?}
*/
function () {
this.open = false;
};
/**
* @return {?}
*/
AsiAutoCompleteComponent.prototype.ngOnChanges = /**
* @return {?}
*/
function () {
if (this.init) {
this.open = true;
}
else {
if (this.firstRequestDone) {
this.init = true;
}
}
};
/**
* @param {?} data
* @return {?}
*/
AsiAutoCompleteComponent.prototype.selectValue = /**
* @param {?} data
* @return {?}
*/
function (data) {
this.value = data;
this.open = false;
};
/**
* @return {?}
*/
AsiAutoCompleteComponent.prototype.clearValue = /**
* @return {?}
*/
function () {
var _this = this;
this.value = null;
this.autoCompleteControl.setValue(this.currentValue, { emitEvent: false });
setTimeout(function () { _this.open = true; });
};
/**
* @param {?} value
* @return {?}
*/
AsiAutoCompleteComponent.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 });
}
}
};
AsiAutoCompleteComponent.decorators = [
{ type: Component, args: [{
selector: 'asi-autocomplete',
template: "<label class=\"input-label\" *ngIf=\"label != null\">{{label | translate}}</label>\n\n<div class=\"autocomplete\">\n\n <!-- typehead input -->\n <input [attr.id]=\"id\" [attr.name]=\"name\" [attr.disabled]=\"disabled ? '' : null\" class=\"asi-focus-error\"\n [placeholder]=\"placeholder\" *ngIf=\"value == null\" [formControl]=\"autoCompleteControl\" />\n\n <!-- data to display -->\n <div class=\" autocomplete-header\" *ngIf=\"value != null\">\n <button [disabled]=\"disabled\" type=\"button\" class=\"clean-a\">\n <div class=\"select-value\">\n <ng-template [ngTemplateOutlet]=\"selectedDef.template\" [ngTemplateOutletContext]=\"{$implicit : value}\">\n </ng-template>\n </div>\n </button>\n <button [disabled]=\"disabled\" class=\"remove-icon-container\" (click)=\"clearValue()\">\n <span class=\"remove-icon\" [innerHTML]=\"'✕'\"></span>\n </button>\n </div>\n\n <asi-dropdown [open]=\"open\" (onClose)=\"onDropdownClose()\" dropDownClass=\"asi-autocomplete-dropdown\" #dropDown>\n <div class=\"drop-down-autocomplete\">\n <div class=\"drop-down-panel\">\n <button [id]=\"'asi-acddi-'+ id\" type=\"button\" class=\"drop-down-item\" (click)=\"selectValue(aData)\"\n *ngFor=\"let aData of data, let id = index\">\n <div class=\"option\">\n <span class=\"item\">\n <ng-template *ngIf=\"aData != null\" [ngTemplateOutlet]=\"optionDef.template\"\n [ngTemplateOutletContext]=\"{$implicit : aData}\"></ng-template>\n </span>\n </div>\n </button>\n </div>\n </div>\n </asi-dropdown>\n</div>\n",
host: { 'class': 'asi-component asi-autocomplete' },
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(function () { return AsiAutoCompleteComponent; }),
multi: true
}
]
}] }
];
/** @nocollapse */
AsiAutoCompleteComponent.ctorParameters = function () { return [
{ type: Renderer2 },
{ type: ElementRef }
]; };
AsiAutoCompleteComponent.propDecorators = {
id: [{ type: Input }],
name: [{ type: Input }],
label: [{ type: Input }],
labelPosition: [{ type: Input }],
delay: [{ type: Input }],
placeholder: [{ type: Input }],
onRequestData: [{ type: Input }],
optionDef: [{ type: ContentChild, args: [AsiComponentTemplateOptionDef,] }],
selectedDef: [{ type: ContentChild, args: [AsiComponentTemplateSelectedDef,] }],
asiDropDown: [{ type: ViewChild, args: ['dropDown',] }]
};
return AsiAutoCompleteComponent;
}(DefaultControlValueAccessor));
export { AsiAutoCompleteComponent };
if (false) {
/**
* html id
* @type {?}
*/
AsiAutoCompleteComponent.prototype.id;
/**
* html name
* @type {?}
*/
AsiAutoCompleteComponent.prototype.name;
/**
* Label to display (is translated)
* @type {?}
*/
AsiAutoCompleteComponent.prototype.label;
/**
* Label position
* @type {?}
*/
AsiAutoCompleteComponent.prototype.labelPosition;
/**
* Delay between the moment you stop typing and onRequestData is called
* @type {?}
*/
AsiAutoCompleteComponent.prototype.delay;
/**
* A placeholder if needed
* @type {?}
*/
AsiAutoCompleteComponent.prototype.placeholder;
/**
* Function called to request new data (can return Observable/Promise/Object): Throw error if null
* @type {?}
*/
AsiAutoCompleteComponent.prototype.onRequestData;
/** @type {?} */
AsiAutoCompleteComponent.prototype.optionDef;
/** @type {?} */
AsiAutoCompleteComponent.prototype.selectedDef;
/** @type {?} */
AsiAutoCompleteComponent.prototype.asiDropDown;
/** @type {?} */
AsiAutoCompleteComponent.prototype.autoCompleteControl;
/** @type {?} */
AsiAutoCompleteComponent.prototype.open;
/** @type {?} */
AsiAutoCompleteComponent.prototype.data;
/** @type {?} */
AsiAutoCompleteComponent.prototype.firstRequestDone;
/** @type {?} */
AsiAutoCompleteComponent.prototype.init;
/** @type {?} */
AsiAutoCompleteComponent.prototype.currentValue;
/** @type {?} */
AsiAutoCompleteComponent.prototype.renderer;
/** @type {?} */
AsiAutoCompleteComponent.prototype.elementRef;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asi-autocomplete.component.js","sourceRoot":"ng://@asi-ngtools/lib/","sources":["lib/components/asi-autocomplete/simple/asi-autocomplete.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component, Input, forwardRef, ContentChild, OnInit, OnChanges, Renderer2, ElementRef, ViewChild\n} from '@angular/core';\n\nimport { DefaultControlValueAccessor } from './../../common/default-control-value-accessor';\nimport { NG_VALUE_ACCESSOR, FormControl } from '@angular/forms';\n\nimport { AsiComponentTemplateOptionDef, AsiComponentTemplateSelectedDef } from './../../common/asi-component-template';\nimport { debounceTime, switchMap, tap } from 'rxjs/operators';\nimport * as nh from '../../../native-helper'\nimport { AsiDropDown } from '../../asi-dropdown/asi-dropdown.component';\n\n/**\n * asi-autocomplete component\n */\n@Component({\n  selector: 'asi-autocomplete',\n  templateUrl: 'asi-autocomplete.component.html',\n  host: { 'class': 'asi-component asi-autocomplete' },\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => AsiAutoCompleteComponent),\n      multi: true\n    }\n  ]\n})\nexport class AsiAutoCompleteComponent extends DefaultControlValueAccessor implements OnInit, OnChanges {\n\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  /** Delay between the moment you stop typing and onRequestData is called */\n  @Input() delay = 500;\n\n  /** A placeholder if needed */\n  @Input() placeholder = '';\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(AsiComponentTemplateSelectedDef) selectedDef: AsiComponentTemplateSelectedDef;\n\n  @ViewChild('dropDown') asiDropDown: AsiDropDown;\n\n  autoCompleteControl = new FormControl();\n\n  open = false;\n\n  data: Array<any>;\n\n  // Var used to manage component initialization\n  firstRequestDone: Boolean = null;\n  init = false;\n\n  private currentValue: any = null;\n\n  constructor(private renderer: Renderer2, private elementRef: ElementRef) {\n    super();\n  }\n\n  private checkInput() {\n    if (null == this.onRequestData) {\n      throw new Error('AsiAutoCompleteComponent : @Input \\'onRequestData\\' is required');\n    }\n  }\n\n  ngOnInit() {\n    this.checkInput();\n    this.renderer.addClass(this.elementRef.nativeElement, 'label-' + this.labelPosition);\n\n    this.autoCompleteControl.valueChanges.pipe(debounceTime(this.delay),\n      tap(value => this.currentValue = value),\n      switchMap((value) => nh.observe(this.onRequestData(value, !this.firstRequestDone))))\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  selectValue(data: any) {\n    this.value = data;\n    this.open = false;\n  }\n\n  clearValue() {\n    this.value = null;\n    this.autoCompleteControl.setValue(this.currentValue, { emitEvent: false });\n    setTimeout(() => { this.open = true });\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"]}