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

335 lines 26.2 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 {?} */ const NGX_DADATA_VALUE_ACCESSOR = { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef((/** * @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 {?} */ (c) => { /** @type {?} */ const err = { rangeError: { given: c.value, expected: value, } }; return (c.value !== value) ? err : null; }); } export class NgxDadataComponent { /** * @param {?} dataService * @param {?} _r */ constructor(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 {?} */ () => { }); this.propagateChange = (/** * @return {?} */ () => { }); this.validateFn = (/** * @return {?} */ () => { }); } /** * @return {?} */ get value() { return this.v; } /** * @param {?} v * @return {?} */ set value(v) { if (v !== this.v) { this.v = v; this.propagateChange(v); } } /** * @return {?} */ ngOnInit() { /*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 {?} */ () => timer(this.config.delay ? this.config.delay : 500)))).subscribe((/** * @param {?} x * @return {?} */ x => { this.dataService.getData(x, this.type, this.limit).subscribe((/** * @param {?} y * @return {?} */ (y) => { this.data = y.suggestions; })); })); } /** * @param {?} changes * @return {?} */ ngOnChanges(changes) { if (changes.value) { } } /** * @param {?} value * @return {?} */ getData(value) { this.inputString$.next(value); this.currentFocus = -1; } /** * @param {?} e * @param {?} item * @return {?} */ onClick(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 {?} */ onOutsideClick() { this.data = []; } /** * @return {?} */ onArrowDown() { this.removeFocus(this.currentFocus); if (this.currentFocus >= this.data.length - 1) { this.currentFocus = 0; } else { this.currentFocus++; } this.setFocus(this.currentFocus); } /** * @return {?} */ onArrowUp() { this.removeFocus(this.currentFocus); if (this.currentFocus === 0) { this.currentFocus = this.data.length - 1; } else { this.currentFocus--; } this.setFocus(this.currentFocus); } /** * @return {?} */ onEnter() { 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 {?} */ setFocus(id) { /** @type {?} */ const activeEl = document.getElementById(id + 'item'); this._r.addClass(activeEl, 'active'); } /** * @param {?} id * @return {?} */ removeFocus(id) { if (id !== -1) { /** @type {?} */ const activeEl = document.getElementById(id + 'item'); this._r.removeClass(activeEl, 'active'); } } /** * @param {?} value * @return {?} */ writeValue(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 * @return {?} */ registerOnChange(fn) { // this.onSuggestionSelected = fn; this.propagateChange = fn; } /** * Set the function to be called * when the control receives a touch event. * * @param {?} fn a function * @return {?} */ registerOnTouched(fn) { this.onTouched = fn; } /** * Implements disabled state for this element * * @param {?} isDisabled * @return {?} */ setDisabledState(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 = () => [ { 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',] }] }; 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"]}