@douglas-serena/ng-inputs
Version:
angular entry library
215 lines • 29.3 kB
JavaScript
import { __awaiter } from "tslib";
import { HttpClient } from '@angular/common/http';
import { ChangeDetectorRef, Component, ElementRef, EventEmitter, forwardRef, HostListener, Input, Output, Renderer2, ViewChild, } from '@angular/core';
import { ControlContainer, NG_VALUE_ACCESSOR } from '@angular/forms';
import { NgInputConfigService } from '../../core/ng-input-config.service';
import { SelectCustomControlValueAccessor } from '../select-custom-control-value-accessor.domain';
export class NgSearchComponent extends SelectCustomControlValueAccessor {
constructor(controlContainer, elementRef, renderer, httpClient, configService, changeDetectorRef) {
super(controlContainer, elementRef, renderer, configService, changeDetectorRef);
this.controlContainer = controlContainer;
this.elementRef = elementRef;
this.renderer = renderer;
this.httpClient = httpClient;
this.configService = configService;
this.notFound = 'Sem resultado.';
this.pathLabel = 'label';
this.value = null;
this.options = [];
this.uri = null;
this.responseData = null;
this.return = null;
this.loading = false;
this.focused = false;
this.timeInput = 0;
this.timeBlur = 0;
this.blur = new EventEmitter();
this.timeFocus = 0;
this.focus = new EventEmitter();
}
onInput({ target }) {
clearTimeout(this.timeInput);
this.timeInput = setTimeout(() => __awaiter(this, void 0, void 0, function* () {
const { value } = target;
if (value.length === 0)
return;
if (!this.focused)
this.focused = true;
if (this.uri) {
let uri = this.createUrl(this.uri);
uri = uri === null || uri === void 0 ? void 0 : uri.replace('{value}', value);
this.loading = true;
try {
const response = yield this.httpClient.get(uri).toPromise();
this.options = this.responseData
? this.getMultiLabels(response, this.responseData.split('.'))
: response;
this.format();
}
catch (error) {
if (!this.configService.environments.debug) {
console.log(error);
}
}
this.loading = false;
}
}), 300);
}
createUrl(uri) {
const variables = uri.match(/(\{[\w\_]+\})+/g);
variables === null || variables === void 0 ? void 0 : variables.forEach((variable) => {
const key = variable.replace(/([\{\}])+/g, '');
const env = this.configService.environments[key];
if (env)
uri = uri === null || uri === void 0 ? void 0 : uri.replace(variable, env);
});
return uri;
}
handleKeyDown(event) {
const { key } = event;
const keys = {
ArrowUp: () => {
event.preventDefault();
if (!this.focused) {
this.focused = true;
return;
}
const index = this.options.findIndex((option) => option.dssSelect);
if (index === -1) {
this.options[this.options.length - 1].dssSelect = true;
return;
}
this.options[index].dssSelect = false;
if (index === 0) {
this.options[this.options.length - 1].dssSelect = true;
return;
}
this.options[index - 1].dssSelect = true;
},
ArrowDown: () => {
event.preventDefault();
if (!this.focused) {
this.focused = true;
return;
}
const index = this.options.findIndex((option) => option.dssSelect);
if (index === -1) {
this.options[0].dssSelect = true;
}
this.options[index].dssSelect = false;
if (index === this.options.length - 1) {
this.options[0].dssSelect = true;
return;
}
this.options[index + 1].dssSelect = true;
},
Enter: () => {
event.preventDefault();
if (!this.focused) {
this.focused = true;
return;
}
const index = this.options.findIndex((option) => option.dssSelect);
if (index !== -1) {
this.focused = false;
this.itemSelect = index;
this.inputChange(this.options[index]);
}
},
};
try {
keys[key]();
}
catch (_a) { }
}
ngOnInit() {
var _a;
this.required = (_a = this.control.errors) === null || _a === void 0 ? void 0 : _a.required;
if (!this.required)
this.required = Object.keys(this.errors).includes('required');
this.format();
}
onBlur(event) {
clearTimeout(this.timeBlur);
this.timeBlur = setTimeout(() => {
this.focused = false;
this.blur.emit(event);
}, 300);
}
onFocus(event) {
this.onInput(event);
clearTimeout(this.timeFocus);
this.timeFocus = setTimeout(() => {
this.focused = true;
this.focus.emit(event);
}, 100);
}
ngOnChanges({ options, value, }) {
if (!!options && !!options.currentValue) {
this.format();
}
if (!!value && !!value.currentValue) {
this.inputChange(this.value);
}
}
inputChange(value) {
this.control.setValue(value instanceof Object
? this.getMultiLabels(value, this.pathLabel.split('.'))
: value);
if (typeof value === 'string') {
this.onWrite(value);
}
else {
const newValue = Object.assign({}, value);
delete newValue.dssLabel;
delete newValue.dssSelect;
setTimeout(() => {
this.onWrite(!!this.return
? this.getMultiLabels(newValue, this.return.split('.'))
: newValue);
}, 250);
}
}
format() {
this.options.map((option, index) => {
option.dssLabel = this.getMultiLabels(option, this.pathLabel.split('.'));
option.dssSelect = this.itemSelect === index;
});
}
}
NgSearchComponent.decorators = [
{ type: Component, args: [{
selector: 'dss-search',
template: "<div\r\n class=\"form-group form-control-search\"\r\n [ngClass]=\"{\r\n invalid: control.invalid && control.touched,\r\n valid: control.valid && control.touched,\r\n 'form-group-label': !!label,\r\n active: !!control?.value\r\n }\"\r\n>\r\n <div class=\"form-content\">\r\n <i\r\n class=\"form-icon-floating icon-background left\"\r\n [ngClass]=\"{ search: !loading, loading: loading }\"\r\n ></i>\r\n\r\n <input\r\n #inputRef\r\n type=\"search\"\r\n class=\"form-control browser-default\"\r\n [placeholder]=\"_placeholder\"\r\n [id]=\"name\"\r\n [formControl]=\"control\"\r\n [readonly]=\"readonly\"\r\n autocomplete=\"off\"\r\n autocapitalize=\"off\"\r\n (blur)=\"onBlur($event)\"\r\n (focus)=\"onFocus($event)\"\r\n [ngClass]=\"{\r\n readonly: readonly,\r\n 'is-invalid': !readonly && control.invalid && control.touched\r\n }\"\r\n />\r\n\r\n <!-- BORDER -->\r\n <span class=\"focus-border\">\r\n <i></i>\r\n </span>\r\n\r\n <!-- LABEL -->\r\n <label *ngIf=\"!!label\" [for]=\"name\">\r\n {{ label }}<span *ngIf=\"required\" class=\"required\">*</span>\r\n </label>\r\n\r\n <ul\r\n class=\"options-list hidden\"\r\n [class.hidden]=\"control.value?.length === 0 || loading || !focused\"\r\n >\r\n <ng-content *ngIf=\"options.length === 0\"> </ng-content>\r\n <li\r\n *ngIf=\"options.length === 0; else template_options\"\r\n class=\"not-found option-item\"\r\n >\r\n {{ notFound }}\r\n </li>\r\n\r\n <ng-template #template_options>\r\n <li\r\n *ngFor=\"let option of options; let index = index\"\r\n role=\"listitem\"\r\n class=\"option-item\"\r\n [class.hover]=\"option.dssSelect\"\r\n [class.select]=\"itemSelect === index\"\r\n (click)=\"inputChange(option); itemSelect = index\"\r\n >\r\n {{ option.dssLabel }}\r\n </li>\r\n </ng-template>\r\n </ul>\r\n </div>\r\n\r\n <ng-container *ngFor=\"let error of getKeys(errors)\">\r\n <!-- MESSAGE ERROR -->\r\n <div *ngIf=\"getError(error)\" class=\"message error\">\r\n {{ errors[error] }}\r\n </div>\r\n </ng-container>\r\n\r\n <!-- MESSAGE HELp -->\r\n <div *ngIf=\"!!help\" class=\"message\">\r\n {{ help }}\r\n </div>\r\n</div>\r\n",
providers: [
{
provide: NG_VALUE_ACCESSOR,
multi: true,
useExisting: forwardRef(() => NgSearchComponent),
},
]
},] }
];
NgSearchComponent.ctorParameters = () => [
{ type: ControlContainer },
{ type: ElementRef },
{ type: Renderer2 },
{ type: HttpClient },
{ type: NgInputConfigService },
{ type: ChangeDetectorRef }
];
NgSearchComponent.propDecorators = {
inputRef: [{ type: ViewChild, args: ['inputRef',] }],
notFound: [{ type: Input }],
pathLabel: [{ type: Input }],
value: [{ type: Input }],
options: [{ type: Input }],
uri: [{ type: Input }],
responseData: [{ type: Input }],
return: [{ type: Input }],
onInput: [{ type: HostListener, args: ['input', ['$event'],] }],
handleKeyDown: [{ type: HostListener, args: ['keydown', ['$event'],] }],
blur: [{ type: Output }],
focus: [{ type: Output }]
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng-search.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-inputs/src/lib/ng-select/ng-search/ng-search.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\r\nimport {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  forwardRef,\r\n  HostListener,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  Renderer2,\r\n  SimpleChange,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { ControlContainer, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { NgInputConfigService } from '../../core/ng-input-config.service';\r\nimport { SelectCustomControlValueAccessor } from '../select-custom-control-value-accessor.domain';\r\n\r\n@Component({\r\n  selector: 'dss-search',\r\n  templateUrl: './ng-search.component.html',\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: forwardRef(() => NgSearchComponent),\r\n    },\r\n  ],\r\n})\r\nexport class NgSearchComponent\r\n  extends SelectCustomControlValueAccessor\r\n  implements OnInit\r\n{\r\n  @ViewChild('inputRef') inputRef: ElementRef<HTMLInputElement>;\r\n  @Input() notFound: string = 'Sem resultado.';\r\n  @Input() pathLabel = 'label';\r\n  @Input() value: any = null;\r\n  @Input() options: any[] = [];\r\n  @Input() uri: string | null = null;\r\n  @Input() responseData: string | null = null;\r\n  @Input() return: string | null = null;\r\n\r\n  loading = false;\r\n  focused = false;\r\n  itemSelect?: number;\r\n\r\n  constructor(\r\n    protected controlContainer: ControlContainer,\r\n    protected elementRef: ElementRef,\r\n    protected renderer: Renderer2,\r\n    private httpClient: HttpClient,\r\n    private configService: NgInputConfigService,\r\n    changeDetectorRef: ChangeDetectorRef\r\n  ) {\r\n    super(\r\n      controlContainer,\r\n      elementRef,\r\n      renderer,\r\n      configService,\r\n      changeDetectorRef\r\n    );\r\n  }\r\n\r\n  timeInput: any = 0;\r\n  @HostListener('input', ['$event'])\r\n  onInput({ target }: Event) {\r\n    clearTimeout(this.timeInput);\r\n    this.timeInput = setTimeout(async () => {\r\n      const { value } = target as HTMLInputElement;\r\n\r\n      if (value.length === 0) return;\r\n      if (!this.focused) this.focused = true;\r\n\r\n      if (this.uri) {\r\n        let uri = this.createUrl(this.uri);\r\n        uri = uri?.replace('{value}', value) as string;\r\n\r\n        this.loading = true;\r\n        try {\r\n          const response = await this.httpClient.get(uri).toPromise();\r\n          this.options = this.responseData\r\n            ? this.getMultiLabels(response, this.responseData.split('.'))\r\n            : response;\r\n          this.format();\r\n        } catch (error) {\r\n          if (!this.configService.environments.debug) {\r\n            console.log(error);\r\n          }\r\n        }\r\n        this.loading = false;\r\n      }\r\n    }, 300);\r\n  }\r\n\r\n  createUrl(uri: string) {\r\n    const variables = uri.match(/(\\{[\\w\\_]+\\})+/g);\r\n    variables?.forEach((variable) => {\r\n      const key = variable.replace(/([\\{\\}])+/g, '');\r\n      const env = this.configService.environments[key];\r\n      if (env) uri = uri?.replace(variable, env) as string;\r\n    });\r\n    return uri;\r\n  }\r\n\r\n  @HostListener('keydown', ['$event'])\r\n  handleKeyDown(event: KeyboardEvent) {\r\n    const { key } = event;\r\n\r\n    const keys = {\r\n      ArrowUp: () => {\r\n        event.preventDefault();\r\n\r\n        if (!this.focused) {\r\n          this.focused = true;\r\n          return;\r\n        }\r\n\r\n        const index = this.options.findIndex((option) => option.dssSelect);\r\n\r\n        if (index === -1) {\r\n          this.options[this.options.length - 1].dssSelect = true;\r\n          return;\r\n        }\r\n\r\n        this.options[index].dssSelect = false;\r\n\r\n        if (index === 0) {\r\n          this.options[this.options.length - 1].dssSelect = true;\r\n          return;\r\n        }\r\n\r\n        this.options[index - 1].dssSelect = true;\r\n      },\r\n      ArrowDown: () => {\r\n        event.preventDefault();\r\n\r\n        if (!this.focused) {\r\n          this.focused = true;\r\n          return;\r\n        }\r\n\r\n        const index = this.options.findIndex((option) => option.dssSelect);\r\n\r\n        if (index === -1) {\r\n          this.options[0].dssSelect = true;\r\n        }\r\n        this.options[index].dssSelect = false;\r\n\r\n        if (index === this.options.length - 1) {\r\n          this.options[0].dssSelect = true;\r\n          return;\r\n        }\r\n\r\n        this.options[index + 1].dssSelect = true;\r\n      },\r\n      Enter: () => {\r\n        event.preventDefault();\r\n\r\n        if (!this.focused) {\r\n          this.focused = true;\r\n          return;\r\n        }\r\n\r\n        const index = this.options.findIndex((option) => option.dssSelect);\r\n        if (index !== -1) {\r\n          this.focused = false;\r\n          this.itemSelect = index;\r\n          this.inputChange(this.options[index]);\r\n        }\r\n      },\r\n    };\r\n    try {\r\n      keys[key as 'ArrowUp']();\r\n    } catch {}\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.required = this.control.errors?.required;\r\n\r\n    if (!this.required)\r\n      this.required = Object.keys(this.errors).includes('required');\r\n    this.format();\r\n  }\r\n\r\n  timeBlur: any = 0;\r\n  @Output() blur = new EventEmitter();\r\n  onBlur(event: Event) {\r\n    clearTimeout(this.timeBlur);\r\n    this.timeBlur = setTimeout(() => {\r\n      this.focused = false;\r\n      this.blur.emit(event);\r\n    }, 300);\r\n  }\r\n\r\n  timeFocus: any = 0;\r\n  @Output() focus = new EventEmitter();\r\n  onFocus(event: Event) {\r\n    this.onInput(event);\r\n    clearTimeout(this.timeFocus);\r\n    this.timeFocus = setTimeout(() => {\r\n      this.focused = true;\r\n      this.focus.emit(event);\r\n    }, 100);\r\n  }\r\n\r\n  ngOnChanges({\r\n    options,\r\n    value,\r\n  }: {\r\n    options: SimpleChange;\r\n    value: SimpleChange;\r\n  }) {\r\n    if (!!options && !!options.currentValue) {\r\n      this.format();\r\n    }\r\n    if (!!value && !!value.currentValue) {\r\n      this.inputChange(this.value);\r\n    }\r\n  }\r\n\r\n  inputChange(value: any) {\r\n    this.control.setValue(\r\n      value instanceof Object\r\n        ? this.getMultiLabels(value, this.pathLabel.split('.'))\r\n        : value\r\n    );\r\n\r\n    if (typeof value === 'string') {\r\n      this.onWrite(value);\r\n    } else {\r\n      const newValue = { ...value };\r\n\r\n      delete newValue.dssLabel;\r\n      delete newValue.dssSelect;\r\n\r\n      setTimeout(() => {\r\n        this.onWrite(\r\n          !!this.return\r\n            ? this.getMultiLabels(newValue, this.return.split('.'))\r\n            : newValue\r\n        );\r\n      }, 250);\r\n    }\r\n  }\r\n\r\n  format() {\r\n    this.options.map((option, index) => {\r\n      option.dssLabel = this.getMultiLabels(option, this.pathLabel.split('.'));\r\n      option.dssSelect = this.itemSelect === index;\r\n    });\r\n  }\r\n}\r\n"]}