UNPKG

design-angular-kit

Version:

Un toolkit Angular conforme alle linee guida di design per i servizi web della PA

178 lines 26.6 kB
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewChild } from '@angular/core'; import { ItAbstractFormComponent } from '../../../abstracts/abstract-form.component'; import { AsyncPipe } from '@angular/common'; import { ReactiveFormsModule } from '@angular/forms'; import { SelectAutocomplete } from 'bootstrap-italia'; import * as i0 from "@angular/core"; export class ItAutocompleteComponent extends ItAbstractFormComponent { constructor() { super(...arguments); /** * Autocomplete elements. * @default [] */ this.source = []; /** * Autocomplete if required. * @default false */ this.required = false; /** * Prevents suggestions from appearing if fewer than N characters are typed * @default 0 */ this.minLength = 0; /** * Default value */ this.defaultValue = ''; /** * Function to set assistive hint label. For more information https://github.com/alphagov/accessible-autocomplete?tab=readme-ov-file#internationalization */ this.assistiveHintLabel = () => 'Quando i risultati del completamento automatico sono disponibili, usa le frecce su e giù per rivedere e Invio per selezionare. Utenti di dispositivi touch, esplora tramite tocco o con gesti di scorrimento'; /** * Function to set label in case of no result. For more information https://github.com/alphagov/accessible-autocomplete?tab=readme-ov-file#internationalization */ this.noResultsLabel = () => 'Nessun risultato trovato'; /** * Function to set label that alerts you that query's too short. For more information https://github.com/alphagov/accessible-autocomplete?tab=readme-ov-file#internationalization */ this.statusQueryTooShortLabel = minQueryLength => `Digita ${minQueryLength} o più caratteri per mostrare le opzioni di ricerca`; /** * Function to set no results label. For more information https://github.com/alphagov/accessible-autocomplete?tab=readme-ov-file#internationalization */ this.statusNoResultsLabel = () => 'Nessun risultato di ricerca'; /** * Function to set selected option label. For more information https://github.com/alphagov/accessible-autocomplete?tab=readme-ov-file#internationalization */ this.statusSelectedOptionLabel = (selectedOption, length, index) => `${selectedOption} ${index + 1} di ${length} è sottolineato`; /** * Function to set status results label. For more information https://github.com/alphagov/accessible-autocomplete?tab=readme-ov-file#internationalization */ this.statusResultsLabel = (length, contentSelectedOption) => { const words = { result: length === 1 ? 'risultato' : 'risultati', is: length === 1 ? 'è' : 'sono', available: length === 1 ? 'disponibile' : 'disponibili', }; return `${length} ${words.result} ${words.is} ${words.available}. ${contentSelectedOption}`; }; /** * Fired when value changes */ this.selected = new EventEmitter(); this.value = ''; this._interval = 0; this._inputEl = null; } ngOnInit() { super.ngOnInit(); if (!this.control.value && !!this.value) { this.writeValue(this.value); this.onChange(this.value); } } clear() { this._inputEl.value = ''; } _findInput() { this._interval = setInterval(() => { this._inputEl = document.getElementById(this.id); if (this._inputEl) { clearInterval(this._interval); this._initInputEl(); } }, 500); } _setAndCheck(value) { this.value = value == '' ? undefined : value; if (this.control.touched) { this.writeValue(this.value); this.onChange(this.value); } if (this.isValid == false && this.isInvalid == false) { this._inputEl?.classList.remove('just-validate-success-field'); this._inputEl?.classList.remove('is-invalid'); } else if (this.isValid == true) { this._inputEl?.classList.add('just-validate-success-field'); this._inputEl?.classList.remove('is-invalid'); } else if (this.isInvalid == true) { this._inputEl?.classList.add('is-invalid'); this._inputEl?.classList.remove('just-validate-success-field'); } } _initInputEl() { if (this._inputEl) { this._inputEl.onfocus = (ev) => this._setAndCheck(ev.target.value); this._inputEl.onblur = (ev) => this._setAndCheck(ev.target.value); this._inputEl.oninput = (ev) => { this.markAsTouched(); this._setAndCheck(ev.target.value); }; } } ngAfterViewInit() { if (this.selectAutocompleteEl) { super.ngAfterViewInit(); const element = this.selectAutocompleteEl.nativeElement; this.selectAutocomplete = new SelectAutocomplete(element, { id: this.id, name: this.name || this.id, source: this.source, required: this.required, minLength: this.minLength, defaultValue: this.defaultValue, tAssistiveHint: this.assistiveHintLabel, tNoResults: this.noResultsLabel, tStatusQueryTooShort: this.statusQueryTooShortLabel, tStatusNoResults: this.statusNoResultsLabel, tStatusSelectedOption: this.statusSelectedOptionLabel, tStatusResults: this.statusResultsLabel, onConfirm: (selectedElement) => { this.markAsTouched(); this._setAndCheck(selectedElement); this.selected.emit(selectedElement); }, }); this._findInput(); } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: ItAutocompleteComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.6", type: ItAutocompleteComponent, isStandalone: true, selector: "it-autocomplete", inputs: { source: "source", required: "required", name: "name", description: "description", minLength: "minLength", defaultValue: "defaultValue", assistiveHintLabel: "assistiveHintLabel", noResultsLabel: "noResultsLabel", statusQueryTooShortLabel: "statusQueryTooShortLabel", statusNoResultsLabel: "statusNoResultsLabel", statusSelectedOptionLabel: "statusSelectedOptionLabel", statusResultsLabel: "statusResultsLabel" }, outputs: { selected: "selected" }, viewQueries: [{ propertyName: "selectAutocompleteEl", first: true, predicate: ["selectAutocomplete"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"form-group\">\n @if (label) {\n <label [for]=\"id\" [class.active]=\"!!control.value\">{{ label }}</label>\n }\n <div #selectAutocomplete name=\"region\" [id]=\"id + 'Wrapper'\" class=\"autocomplete-wrapper\"></div>\n\n @if (description) {\n <small [id]=\"id + '-description'\" class=\"form-text\">{{ description }}</small>\n }\n @if (isInvalid) {\n <div class=\"form-feedback just-validate-error-label\" [id]=\"id + '-error'\">\n <div #customError><ng-content select=\"[error]\"></ng-content></div>\n @if (!customError.hasChildNodes()) {\n {{ invalidMessage | async }}\n }\n </div>\n }\n</div>\n", dependencies: [{ kind: "ngmodule", type: ReactiveFormsModule }, { kind: "pipe", type: AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: ItAutocompleteComponent, decorators: [{ type: Component, args: [{ standalone: true, selector: 'it-autocomplete', changeDetection: ChangeDetectionStrategy.OnPush, imports: [ReactiveFormsModule, AsyncPipe], template: "<div class=\"form-group\">\n @if (label) {\n <label [for]=\"id\" [class.active]=\"!!control.value\">{{ label }}</label>\n }\n <div #selectAutocomplete name=\"region\" [id]=\"id + 'Wrapper'\" class=\"autocomplete-wrapper\"></div>\n\n @if (description) {\n <small [id]=\"id + '-description'\" class=\"form-text\">{{ description }}</small>\n }\n @if (isInvalid) {\n <div class=\"form-feedback just-validate-error-label\" [id]=\"id + '-error'\">\n <div #customError><ng-content select=\"[error]\"></ng-content></div>\n @if (!customError.hasChildNodes()) {\n {{ invalidMessage | async }}\n }\n </div>\n }\n</div>\n" }] }], propDecorators: { source: [{ type: Input }], required: [{ type: Input }], name: [{ type: Input }], description: [{ type: Input }], minLength: [{ type: Input }], defaultValue: [{ type: Input }], assistiveHintLabel: [{ type: Input }], noResultsLabel: [{ type: Input }], statusQueryTooShortLabel: [{ type: Input }], statusNoResultsLabel: [{ type: Input }], statusSelectedOptionLabel: [{ type: Input }], statusResultsLabel: [{ type: Input }], selected: [{ type: Output }], selectAutocompleteEl: [{ type: ViewChild, args: ['selectAutocomplete'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"","sources":["../../../../../../../projects/design-angular-kit/src/lib/components/form/autocomplete/autocomplete.component.ts","../../../../../../../projects/design-angular-kit/src/lib/components/form/autocomplete/autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, Input, Output, ViewChild } from '@angular/core';\nimport { ItAbstractFormComponent } from '../../../abstracts/abstract-form.component';\nimport { AsyncPipe } from '@angular/common';\nimport { ReactiveFormsModule } from '@angular/forms';\nimport { SelectAutocomplete } from 'bootstrap-italia';\n\ntype functionSource = (query: string, populateResults: (results: string[]) => void) => void;\n\n@Component({\n  standalone: true,\n  selector: 'it-autocomplete',\n  templateUrl: './autocomplete.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [ReactiveFormsModule, AsyncPipe],\n})\nexport class ItAutocompleteComponent extends ItAbstractFormComponent<string | null | undefined> {\n  /**\n   * Autocomplete elements.\n   * @default []\n   */\n  @Input() source: string[] | functionSource = [];\n\n  /**\n   * Autocomplete if required.\n   * @default false\n   */\n  @Input() required: boolean = false;\n\n  /**\n   * Input field name\n   */\n  @Input() name: string | undefined;\n\n  /**\n   * The input description\n   */\n  @Input() description: string | undefined;\n\n  /**\n   * Prevents suggestions from appearing if fewer than N characters are typed\n   * @default 0\n   */\n  @Input() minLength: number = 0;\n\n  /**\n   * Default value\n   */\n  @Input() defaultValue: string | null = '';\n\n  /**\n   * Function to set assistive hint label. For more information https://github.com/alphagov/accessible-autocomplete?tab=readme-ov-file#internationalization\n   */\n  @Input() assistiveHintLabel: () => string = () =>\n    'Quando i risultati del completamento automatico sono disponibili, usa le frecce su e giù per rivedere e Invio per selezionare. Utenti di dispositivi touch, esplora tramite tocco o con gesti di scorrimento';\n\n  /**\n   * Function to set label in case of no result. For more information https://github.com/alphagov/accessible-autocomplete?tab=readme-ov-file#internationalization\n   */\n  @Input() noResultsLabel: () => string = () => 'Nessun risultato trovato';\n\n  /**\n   * Function to set label that alerts you that query's too short. For more information https://github.com/alphagov/accessible-autocomplete?tab=readme-ov-file#internationalization\n   */\n  @Input() statusQueryTooShortLabel: (minQueryLength: number) => string = minQueryLength =>\n    `Digita ${minQueryLength} o più caratteri per mostrare le opzioni di ricerca`;\n\n  /**\n   * Function to set no results label. For more information https://github.com/alphagov/accessible-autocomplete?tab=readme-ov-file#internationalization\n   */\n  @Input() statusNoResultsLabel: () => string = () => 'Nessun risultato di ricerca';\n\n  /**\n   * Function to set selected option label. For more information https://github.com/alphagov/accessible-autocomplete?tab=readme-ov-file#internationalization\n   */\n  @Input() statusSelectedOptionLabel: (selectedOption: string, length: number, index: number) => string = (selectedOption, length, index) =>\n    `${selectedOption} ${index + 1} di ${length} è sottolineato`;\n\n  /**\n   * Function to set status results label. For more information https://github.com/alphagov/accessible-autocomplete?tab=readme-ov-file#internationalization\n   */\n  @Input() statusResultsLabel: (length: number, contentSelectedOption: string) => string = (length, contentSelectedOption) => {\n    const words = {\n      result: length === 1 ? 'risultato' : 'risultati',\n      is: length === 1 ? 'è' : 'sono',\n      available: length === 1 ? 'disponibile' : 'disponibili',\n    };\n\n    return `${length} ${words.result} ${words.is} ${words.available}. ${contentSelectedOption}`;\n  };\n\n  /**\n   * Fired when value changes\n   */\n  @Output() selected = new EventEmitter();\n\n  @ViewChild('selectAutocomplete') private selectAutocompleteEl?: ElementRef<HTMLButtonElement>;\n\n  private selectAutocomplete?: SelectAutocomplete;\n\n  private value: string | undefined = '';\n  private _interval: any = 0;\n  private _inputEl: HTMLElement | null = null;\n\n  override ngOnInit() {\n    super.ngOnInit();\n    if (!this.control.value && !!this.value) {\n      this.writeValue(this.value);\n      this.onChange(this.value);\n    }\n  }\n\n  clear() {\n    (this._inputEl as HTMLInputElement).value = '';\n  }\n\n  _findInput() {\n    this._interval = setInterval(() => {\n      this._inputEl = document.getElementById(this.id);\n      if (this._inputEl) {\n        clearInterval(this._interval);\n        this._initInputEl();\n      }\n    }, 500);\n  }\n\n  private _setAndCheck(value: string) {\n    this.value = value == '' ? undefined : value;\n    if (this.control.touched) {\n      this.writeValue(this.value);\n      this.onChange(this.value);\n    }\n    if (this.isValid == false && this.isInvalid == false) {\n      this._inputEl?.classList.remove('just-validate-success-field');\n      this._inputEl?.classList.remove('is-invalid');\n    } else if (this.isValid == true) {\n      this._inputEl?.classList.add('just-validate-success-field');\n      this._inputEl?.classList.remove('is-invalid');\n    } else if (this.isInvalid == true) {\n      this._inputEl?.classList.add('is-invalid');\n      this._inputEl?.classList.remove('just-validate-success-field');\n    }\n  }\n\n  private _initInputEl() {\n    if (this._inputEl) {\n      this._inputEl.onfocus = (ev: Event) => this._setAndCheck((ev.target as HTMLInputElement).value);\n      this._inputEl.onblur = (ev: Event) => this._setAndCheck((ev.target as HTMLInputElement).value);\n      this._inputEl.oninput = (ev: Event) => {\n        this.markAsTouched();\n        this._setAndCheck((ev.target as HTMLInputElement).value);\n      };\n    }\n  }\n\n  override ngAfterViewInit() {\n    if (this.selectAutocompleteEl) {\n      super.ngAfterViewInit();\n      const element = this.selectAutocompleteEl.nativeElement;\n      this.selectAutocomplete = new SelectAutocomplete(element, {\n        id: this.id,\n        name: this.name || this.id,\n        source: this.source,\n        required: this.required,\n        minLength: this.minLength,\n        defaultValue: this.defaultValue,\n        tAssistiveHint: this.assistiveHintLabel,\n        tNoResults: this.noResultsLabel,\n        tStatusQueryTooShort: this.statusQueryTooShortLabel,\n        tStatusNoResults: this.statusNoResultsLabel,\n        tStatusSelectedOption: this.statusSelectedOptionLabel,\n        tStatusResults: this.statusResultsLabel,\n        onConfirm: (selectedElement: string) => {\n          this.markAsTouched();\n          this._setAndCheck(selectedElement);\n          this.selected.emit(selectedElement);\n        },\n      });\n      this._findInput();\n    }\n  }\n}\n","<div class=\"form-group\">\n  @if (label) {\n    <label [for]=\"id\" [class.active]=\"!!control.value\">{{ label }}</label>\n  }\n  <div #selectAutocomplete name=\"region\" [id]=\"id + 'Wrapper'\" class=\"autocomplete-wrapper\"></div>\n\n  @if (description) {\n    <small [id]=\"id + '-description'\" class=\"form-text\">{{ description }}</small>\n  }\n  @if (isInvalid) {\n    <div class=\"form-feedback just-validate-error-label\" [id]=\"id + '-error'\">\n      <div #customError><ng-content select=\"[error]\"></ng-content></div>\n      @if (!customError.hasChildNodes()) {\n        {{ invalidMessage | async }}\n      }\n    </div>\n  }\n</div>\n"]}