@mobsolutions/ngx-dadata
Version:
[](https://badge.fury.io/js/%40kolkov%2Fngx-dadata) [](https://travis-ci.org/kolkov/ngx-dadata) [![Coverage Stat
335 lines • 26.2 kB
JavaScript
/**
* @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"]}