design-angular-kit
Version:
Un toolkit Angular conforme alle linee guida di design per i servizi web della PA
178 lines • 26.6 kB
JavaScript
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"]}