UNPKG

@mobsolutions/ngx-dadata

Version:

[![npm version](https://badge.fury.io/js/%40kolkov%2Fngx-dadata.svg)](https://badge.fury.io/js/%40kolkov%2Fngx-dadata) [![Build Status](https://travis-ci.org/kolkov/ngx-dadata.svg?branch=master)](https://travis-ci.org/kolkov/ngx-dadata) [![Coverage Stat

415 lines 28.9 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, ElementRef, EventEmitter, forwardRef, HostListener, Input, Output, Renderer2, ViewChild } from '@angular/core'; import { DadataType, NgxDadataService } from './ngx-dadata.service'; import { Subject, timer } from 'rxjs'; import { debounce } from 'rxjs/operators'; import { DadataConfigDefault } from './dadata-config'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; /** @type {?} */ var NGX_DADATA_VALUE_ACCESSOR = { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef((/** * @return {?} */ function () { return NgxDadataComponent; })), multi: true }; /*const NGX_DADATA_VALIDATOR = { provide: NG_VALIDATORS, useExisting: forwardRef(() => NgxDadataComponent), multi: true, };*/ /** * @param {?} value * @return {?} */ export function createDaDataValidator(value) { return (/** * @param {?} c * @return {?} */ function (c) { /** @type {?} */ var err = { rangeError: { given: c.value, expected: value, } }; return (c.value !== value) ? err : null; }); } var NgxDadataComponent = /** @class */ (function () { function NgxDadataComponent(dataService, _r) { this.dataService = dataService; this._r = _r; this.v = ''; this.currentFocus = -1; this.data = []; this.config = DadataConfigDefault; this.disabled = null; this.type = DadataType.address; this.limit = DadataConfigDefault.limit; this.placeholder = ''; this.selected = new EventEmitter(); this.inputString$ = new Subject(); // onSuggestionSelected = (value: string) => {}; this.onTouched = (/** * @return {?} */ function () { }); this.propagateChange = (/** * @return {?} */ function () { }); this.validateFn = (/** * @return {?} */ function () { }); } Object.defineProperty(NgxDadataComponent.prototype, "value", { get: /** * @return {?} */ function () { return this.v; }, set: /** * @param {?} v * @return {?} */ function (v) { if (v !== this.v) { this.v = v; this.propagateChange(v); } }, enumerable: true, configurable: true }); /** * @return {?} */ NgxDadataComponent.prototype.ngOnInit = /** * @return {?} */ function () { var _this = this; /*this.validateFn = createDaDataValidator(this._value); this.propagateChange(this._value);*/ this.type = this.config.type; this.dataService.setApiKey(this.apiKey ? this.apiKey : this.config.apiKey); this.inputString$.pipe(debounce((/** * @return {?} */ function () { return timer(_this.config.delay ? _this.config.delay : 500); }))).subscribe((/** * @param {?} x * @return {?} */ function (x) { _this.dataService.getData(x, _this.type, _this.limit).subscribe((/** * @param {?} y * @return {?} */ function (y) { _this.data = y.suggestions; })); })); }; /** * @param {?} changes * @return {?} */ NgxDadataComponent.prototype.ngOnChanges = /** * @param {?} changes * @return {?} */ function (changes) { if (changes.value) { } }; /** * @param {?} value * @return {?} */ NgxDadataComponent.prototype.getData = /** * @param {?} value * @return {?} */ function (value) { this.inputString$.next(value); this.currentFocus = -1; }; /** * @param {?} e * @param {?} item * @return {?} */ NgxDadataComponent.prototype.onClick = /** * @param {?} e * @param {?} item * @return {?} */ function (e, item) { // e.preventDefault(); this.inputValue.nativeElement.value = item.value; this.propagateChange(item.value); this.inputValue.nativeElement.focus(); this.selectedSuggestion = item; this.data = []; this.currentFocus = -1; // this.writeValue(item.value); this.selected.emit(item); // this.selectedData.emit(item.data); // this.selectedString.emit(item.value); }; /** * @return {?} */ NgxDadataComponent.prototype.onOutsideClick = /** * @return {?} */ function () { this.data = []; }; /** * @return {?} */ NgxDadataComponent.prototype.onArrowDown = /** * @return {?} */ function () { this.removeFocus(this.currentFocus); if (this.currentFocus >= this.data.length - 1) { this.currentFocus = 0; } else { this.currentFocus++; } this.setFocus(this.currentFocus); }; /** * @return {?} */ NgxDadataComponent.prototype.onArrowUp = /** * @return {?} */ function () { this.removeFocus(this.currentFocus); if (this.currentFocus === 0) { this.currentFocus = this.data.length - 1; } else { this.currentFocus--; } this.setFocus(this.currentFocus); }; /** * @return {?} */ NgxDadataComponent.prototype.onEnter = /** * @return {?} */ function () { this.selectedSuggestion = this.data[this.currentFocus]; this.inputValue.nativeElement.value = this.selectedSuggestion.value; this.data = []; this.currentFocus = -1; this.propagateChange(this.selectedSuggestion.value); // this.writeValue(this.selectedSuggestion.value); this.selected.emit(this.selectedSuggestion); // this.selectedData.emit(this.selectedSuggestion.data); // this.selectedString.emit(this.selectedSuggestion.value); }; /** * @param {?} id * @return {?} */ NgxDadataComponent.prototype.setFocus = /** * @param {?} id * @return {?} */ function (id) { /** @type {?} */ var activeEl = document.getElementById(id + 'item'); this._r.addClass(activeEl, 'active'); }; /** * @param {?} id * @return {?} */ NgxDadataComponent.prototype.removeFocus = /** * @param {?} id * @return {?} */ function (id) { if (id !== -1) { /** @type {?} */ var activeEl = document.getElementById(id + 'item'); this._r.removeClass(activeEl, 'active'); } }; /** * @param {?} value * @return {?} */ NgxDadataComponent.prototype.writeValue = /** * @param {?} value * @return {?} */ function (value) { if (value !== undefined) { this.v = value; } // this.onSuggestionSelected(value); }; /** * Set the function to be called * when the control receives a change event. * * @param fn a function */ /** * Set the function to be called * when the control receives a change event. * * @param {?} fn a function * @return {?} */ NgxDadataComponent.prototype.registerOnChange = /** * Set the function to be called * when the control receives a change event. * * @param {?} fn a function * @return {?} */ function (fn) { // this.onSuggestionSelected = fn; this.propagateChange = fn; }; /** * Set the function to be called * when the control receives a touch event. * * @param fn a function */ /** * Set the function to be called * when the control receives a touch event. * * @param {?} fn a function * @return {?} */ NgxDadataComponent.prototype.registerOnTouched = /** * Set the function to be called * when the control receives a touch event. * * @param {?} fn a function * @return {?} */ function (fn) { this.onTouched = fn; }; /** * Implements disabled state for this element * * @param isDisabled */ /** * Implements disabled state for this element * * @param {?} isDisabled * @return {?} */ NgxDadataComponent.prototype.setDisabledState = /** * Implements disabled state for this element * * @param {?} isDisabled * @return {?} */ function (isDisabled) { alert('disabled!'); this.disabled = isDisabled; }; NgxDadataComponent.decorators = [ { type: Component, args: [{ selector: 'ngx-dadata', template: "<div class=\"autocomplete\">\r\n <label for=\"address_input\"></label>\r\n <input [disabled]=\"disabled ? true : null\" type=\"text\" class=\"primary-input\" #inputValue (input)=\"getData(inputValue.value)\"\r\n [placeholder]=\"placeholder\" (keyup.ArrowDown)=\"onArrowDown()\" (keyup.ArrowUp)=\"onArrowUp()\"\r\n (keyup.Enter)=\"onEnter()\" spellcheck=\"false\" [(ngModel)]=\"value\" autocomplete=\"new-password\" />\r\n <div *ngIf=\"data.length\">\r\n <div class=\"autocomplete-items\">\r\n <div class=\"autocomplele-item\" *ngFor=\"let item of data;let i = index\" (click)=\"onClick($event, item)\" [id]=\"i+'item'\">\r\n {{item.value}}\r\n <ng-template [ngIf]=\"type==='party'\">\r\n <br/>\r\n <span>{{item.data?.inn}} {{item.data?.address?.value}}</span>\r\n </ng-template>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n", providers: [NGX_DADATA_VALUE_ACCESSOR,], styles: [".autocomplete{position:relative}.autocomplete-items{position:absolute;border:1px solid #d4d4d4;border-bottom:none;border-top:none;z-index:99;top:100%;left:0;right:0}.autocomplete-items .autocomplele-item{padding:5px 10px;cursor:pointer;background-color:#fff;border-bottom:1px solid #d4d4d4}.autocomplete-items .autocomplele-item:hover{background-color:#e9e9e9}.autocomplete-items .autocomplele-item.active{background-color:#1e90ff!important;color:#fff}.autocomplete-items .autocomplele-item span{color:#555;font-size:80%}"] }] } ]; /** @nocollapse */ NgxDadataComponent.ctorParameters = function () { return [ { type: NgxDadataService }, { type: Renderer2 } ]; }; NgxDadataComponent.propDecorators = { config: [{ type: Input }], apiKey: [{ type: Input }], disabled: [{ type: Input }], type: [{ type: Input }], limit: [{ type: Input }], placeholder: [{ type: Input }], selectedSuggestion: [{ type: Output }], selected: [{ type: Output }], inputValue: [{ type: ViewChild, args: ['inputValue' /*, { static: true }*/,] }], onOutsideClick: [{ type: HostListener, args: ['document:click',] }] }; return NgxDadataComponent; }()); export { NgxDadataComponent }; if (false) { /** * @type {?} * @private */ NgxDadataComponent.prototype.v; /** @type {?} */ NgxDadataComponent.prototype.currentFocus; /** @type {?} */ NgxDadataComponent.prototype.data; /** @type {?} */ NgxDadataComponent.prototype.config; /** @type {?} */ NgxDadataComponent.prototype.apiKey; /** @type {?} */ NgxDadataComponent.prototype.disabled; /** @type {?} */ NgxDadataComponent.prototype.type; /** @type {?} */ NgxDadataComponent.prototype.limit; /** @type {?} */ NgxDadataComponent.prototype.placeholder; /** @type {?} */ NgxDadataComponent.prototype.selectedSuggestion; /** @type {?} */ NgxDadataComponent.prototype.selected; /** @type {?} */ NgxDadataComponent.prototype.inputValue; /** * @type {?} * @private */ NgxDadataComponent.prototype.inputString$; /** @type {?} */ NgxDadataComponent.prototype.onTouched; /** @type {?} */ NgxDadataComponent.prototype.propagateChange; /** @type {?} */ NgxDadataComponent.prototype.validateFn; /** * @type {?} * @private */ NgxDadataComponent.prototype.dataService; /** * @type {?} * @private */ NgxDadataComponent.prototype._r; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-dadata.component.js","sourceRoot":"ng://@mobsolutions/ngx-dadata/","sources":["lib/ngx-dadata.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  forwardRef,\r\n  HostListener,\r\n  Input,\r\n  OnChanges,\r\n  OnInit,\r\n  Output,\r\n  Renderer2,\r\n  SimpleChanges,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport {DadataType, NgxDadataService} from './ngx-dadata.service';\r\nimport {Subject, timer} from 'rxjs';\r\nimport {debounce} from 'rxjs/operators';\r\nimport {DadataResponse} from './models/dadata-response';\r\nimport {DadataSuggestion} from './models/suggestion';\r\nimport {DadataConfig, DadataConfigDefault} from './dadata-config';\r\nimport {ControlValueAccessor, FormControl, NG_VALIDATORS, NG_VALUE_ACCESSOR} from '@angular/forms';\r\n\r\nconst NGX_DADATA_VALUE_ACCESSOR = {\r\n  provide: NG_VALUE_ACCESSOR,\r\n  useExisting: forwardRef(() => NgxDadataComponent),\r\n  multi: true\r\n};\r\n\r\n/*const NGX_DADATA_VALIDATOR = {\r\n  provide: NG_VALIDATORS,\r\n  useExisting: forwardRef(() => NgxDadataComponent),\r\n  multi: true,\r\n};*/\r\n\r\nexport function createDaDataValidator(value) {\r\n  return (c: FormControl) => {\r\n    const err = {\r\n      rangeError: {\r\n        given: c.value,\r\n        expected: value,\r\n      }\r\n    };\r\n\r\n    return (c.value !== value) ? err : null;\r\n  };\r\n}\r\n\r\n@Component({\r\n  selector: 'ngx-dadata',\r\n  templateUrl: './ngx-dadata.component.html',\r\n  styleUrls: ['./ngx-dadata.component.scss'],\r\n  providers: [NGX_DADATA_VALUE_ACCESSOR, /*NGX_DADATA_VALIDATOR*/]\r\n})\r\nexport class NgxDadataComponent implements OnInit, ControlValueAccessor, OnChanges {\r\n  private v: any = '';\r\n  currentFocus = -1;\r\n\r\n  data: DadataSuggestion[] = [];\r\n\r\n  @Input() config: DadataConfig = DadataConfigDefault;\r\n  @Input() apiKey: string;\r\n  @Input() disabled = null;\r\n  @Input() type = DadataType.address;\r\n  @Input() limit = DadataConfigDefault.limit;\r\n  @Input() placeholder = '';\r\n\r\n  @Output() selectedSuggestion: DadataSuggestion;\r\n  @Output() selected = new EventEmitter<DadataSuggestion>();\r\n  // @Output() selectedData = new EventEmitter<DaDataAddress | DaDataFIO | DaDataBank | DaDataParty | DaDataEmail>();\r\n  // @Output() selectedString = new EventEmitter<string>();\r\n\r\n  @ViewChild('inputValue'/*, { static: true }*/) inputValue: ElementRef;\r\n\r\n  private inputString$ = new Subject<string>();\r\n\r\n  // onSuggestionSelected = (value: string) => {};\r\n  onTouched = () => {};\r\n  propagateChange: any = () => {};\r\n  validateFn: any = () => {};\r\n\r\n  constructor(private dataService: NgxDadataService, private _r: Renderer2) {\r\n  }\r\n\r\n  get value(): any {\r\n    return this.v;\r\n  }\r\n\r\n  set value(v: any) {\r\n    if (v !== this.v) {\r\n      this.v = v;\r\n      this.propagateChange(v);\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    /*this.validateFn = createDaDataValidator(this._value);\r\n    this.propagateChange(this._value);*/\r\n    this.type = this.config.type;\r\n    this.dataService.setApiKey(this.apiKey ? this.apiKey : this.config.apiKey);\r\n    this.inputString$.pipe(\r\n      debounce(() => timer(this.config.delay ? this.config.delay : 500)),\r\n    ).subscribe(x => {\r\n      this.dataService.getData(x, this.type, this.limit).subscribe((y: DadataResponse) => {\r\n        this.data = y.suggestions;\r\n      });\r\n    });\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (changes.value) {\r\n\r\n    }\r\n  }\r\n\r\n  getData(value: string) {\r\n    this.inputString$.next(value);\r\n    this.currentFocus = -1;\r\n  }\r\n\r\n  onClick(e: MouseEvent, item: DadataSuggestion) {\r\n    // e.preventDefault();\r\n    this.inputValue.nativeElement.value = item.value;\r\n    this.propagateChange(item.value);\r\n    this.inputValue.nativeElement.focus();\r\n    this.selectedSuggestion = item;\r\n    this.data = [];\r\n    this.currentFocus = -1;\r\n\r\n    // this.writeValue(item.value);\r\n    this.selected.emit(item);\r\n    // this.selectedData.emit(item.data);\r\n    // this.selectedString.emit(item.value);\r\n  }\r\n\r\n  @HostListener('document:click')\r\n  onOutsideClick() {\r\n    this.data = [];\r\n  }\r\n\r\n  onArrowDown() {\r\n    this.removeFocus(this.currentFocus);\r\n    if (this.currentFocus >= this.data.length - 1) {\r\n      this.currentFocus = 0;\r\n    } else {\r\n      this.currentFocus++;\r\n    }\r\n    this.setFocus(this.currentFocus);\r\n  }\r\n\r\n  onArrowUp() {\r\n    this.removeFocus(this.currentFocus);\r\n    if (this.currentFocus === 0) {\r\n      this.currentFocus = this.data.length - 1;\r\n    } else {\r\n      this.currentFocus--;\r\n    }\r\n    this.setFocus(this.currentFocus);\r\n  }\r\n\r\n  onEnter() {\r\n    this.selectedSuggestion = this.data[this.currentFocus];\r\n    this.inputValue.nativeElement.value = this.selectedSuggestion.value;\r\n    this.data = [];\r\n    this.currentFocus = -1;\r\n    this.propagateChange(this.selectedSuggestion.value);\r\n    // this.writeValue(this.selectedSuggestion.value);\r\n    this.selected.emit(this.selectedSuggestion);\r\n    // this.selectedData.emit(this.selectedSuggestion.data);\r\n    // this.selectedString.emit(this.selectedSuggestion.value);\r\n  }\r\n\r\n  setFocus(id: number) {\r\n    const activeEl = document.getElementById(id + 'item');\r\n    this._r.addClass(activeEl, 'active');\r\n  }\r\n\r\n  removeFocus(id: number) {\r\n    if (id !== -1) {\r\n      const activeEl = document.getElementById(id + 'item');\r\n      this._r.removeClass(activeEl, 'active');\r\n    }\r\n  }\r\n\r\n  writeValue(value: any): void {\r\n    if (value !== undefined) {\r\n      this.v = value;\r\n    }\r\n    // this.onSuggestionSelected(value);\r\n  }\r\n\r\n  /**\r\n   * Set the function to be called\r\n   * when the control receives a change event.\r\n   *\r\n   * @param fn a function\r\n   */\r\n  registerOnChange(fn: any): void {\r\n    // this.onSuggestionSelected = fn;\r\n    this.propagateChange = fn;\r\n  }\r\n\r\n  /**\r\n   * Set the function to be called\r\n   * when the control receives a touch event.\r\n   *\r\n   * @param fn a function\r\n   */\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  /**\r\n   * Implements disabled state for this element\r\n   *\r\n   * @param isDisabled\r\n   */\r\n  setDisabledState(isDisabled: boolean): void {\r\n    alert('disabled!');\r\n    this.disabled = isDisabled;\r\n  }\r\n}\r\n"]}