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