@esfaenza/forms-and-validations 15.2.34 → 15.2.35
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/forms/form-autocomplete/form-autocomplete.component.mjs +4 -1
- package/fesm2015/esfaenza-forms-and-validations.mjs +3 -0
- package/fesm2015/esfaenza-forms-and-validations.mjs.map +1 -1
- package/fesm2020/esfaenza-forms-and-validations.mjs +3 -0
- package/fesm2020/esfaenza-forms-and-validations.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -81,6 +81,7 @@ export class FormAutocompleteComponent extends BaseFormControl {
|
|
|
81
81
|
setTimeout(() => {
|
|
82
82
|
this.Model = val ? val.description : value;
|
|
83
83
|
this.EvaluatedModel = this.Model;
|
|
84
|
+
this.cdr.markForCheck();
|
|
84
85
|
});
|
|
85
86
|
}
|
|
86
87
|
/**
|
|
@@ -127,10 +128,12 @@ export class FormAutocompleteComponent extends BaseFormControl {
|
|
|
127
128
|
super.changed(null);
|
|
128
129
|
if (!event && this.MinChars == 0 && !this.SearchFunction) {
|
|
129
130
|
this.FilteredBoundSource = this.BoundSource;
|
|
131
|
+
this.cdr.markForCheck();
|
|
130
132
|
return;
|
|
131
133
|
}
|
|
132
134
|
if (!event || event.length < this.MinChars) {
|
|
133
135
|
this.FilteredBoundSource = [];
|
|
136
|
+
this.cdr.markForCheck();
|
|
134
137
|
return;
|
|
135
138
|
}
|
|
136
139
|
if (!this.SearchFunction && (!this.Source || this.Source.length == 0))
|
|
@@ -263,4 +266,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
263
266
|
}], MultiElementsThreshold: [{
|
|
264
267
|
type: Input
|
|
265
268
|
}] } });
|
|
266
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-autocomplete.component.js","sourceRoot":"","sources":["../../../../../../projects/forms-and-validations/src/lib/forms/form-autocomplete/form-autocomplete.component.ts","../../../../../../projects/forms-and-validations/src/lib/forms/form-autocomplete/form-autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["// Angular\r\nimport { ChangeDetectionStrategy, Component, Inject, Input, Optional, ChangeDetectorRef, Self, SimpleChanges } from \"@angular/core\";\r\nimport { ControlValueAccessor, NG_VALIDATORS, NgControl } from \"@angular/forms\";\r\n\r\n// Applicazione\r\nimport { BaseFormControl } from \"../base-form-control\";\r\n\r\n// Configurazioni\r\nimport { AccessControlService, ComponentContext } from '@esfaenza/access-control';\r\nimport { LocalizationService } from \"@esfaenza/localizations\";\r\nimport { ACO_CUSTOMKEY, FAV_DEBUG_MODE } from '../../tokens';\r\n\r\nimport { Observable } from \"rxjs\";\r\n\r\n//Localizzazione\r\nimport { FormAutocompleteComponentLoc } from \"./form-autocomplete.component.loc\";\r\n\r\n/** Componente di input che si auto-completa in base al valore attuale */\r\n@Component({\r\n    selector: \"form-autocomplete\",\r\n    templateUrl: \"form-autocomplete.component.html\",\r\n    providers: [{ provide: LocalizationService, useClass: FormAutocompleteComponentLoc }],\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class FormAutocompleteComponent extends BaseFormControl implements ControlValueAccessor {\r\n\r\n    /** Permette di specificare il testo della Label flottante material-style */\r\n    @Input() SelectLabel: string = \"\";\r\n\r\n    /** Contesto per la funzione di ricerca */\r\n    @Input() SearchFunctionContext: any;\r\n\r\n    /** Funzione di ricerca che verrà chiamata dal componente */\r\n    @Input() SearchFunction: (search: string, byid: boolean, context?: any) => Observable<{ id: string, description: string }[]> = null;\r\n\r\n    /** Numero minimo di caratteri con cui cercare */\r\n    @Input() MinChars: number = 3;\r\n\r\n    /** Definisce che ad ogni selezione deve chiudere la tendina */\r\n    @Input() HideChoicesOnSelection: boolean = false;\r\n\r\n    /** Override del placeholder per select requried */\r\n    @Input() RequiredPlaceholder: string = null;\r\n\r\n    /** Indica se i controlli devono essere effettuati tenendo conto del Case o meno. Vale solo qualora la **Source** fosse fornita */\r\n    @Input() CaseSensitive: boolean = false;\r\n\r\n    /** Indica se usare la modalità multiselezione o no */\r\n    @Input() Multi: boolean = false;\r\n\r\n    /** Indica se usare la modalità multiselezione o no */\r\n    @Input() MultiElementsThreshold: number = 10;\r\n\r\n    /**\r\n     * Indica se ignorare il prossimo evento writeValue che normalmente dovrebbe richiedere la nuova source. Serve per quando l'utente seleziona un elemento:\r\n     * Subito dopo partirebbe un altro evento modelChange che ricaricherebbe nuovamente la source\r\n     */\r\n    private ignoreNextWriteValue: boolean = false;\r\n\r\n    /** Sorgente Bindata Filtrata in base al contenuto della casella di testo */\r\n    public FilteredBoundSource: { id: string, description: string }[] = [];\r\n\r\n    /** @ignore Costruttore  */\r\n    constructor(cdr: ChangeDetectorRef, public lc: LocalizationService, @Optional() @Self() ngControl: NgControl, @Optional() @Inject(NG_VALIDATORS) _validators: Array<any>, @Optional() ac: AccessControlService, @Optional() AppContext: ComponentContext, @Optional() @Inject(ACO_CUSTOMKEY) ACO_CUSTOMKEY: string, @Optional() @Inject(FAV_DEBUG_MODE) FAV_DEBUG_MODE: boolean) {\r\n        super(cdr, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY, FAV_DEBUG_MODE);\r\n    }\r\n\r\n    /** @ignore */\r\n    writeValue(value: any): void {\r\n        if (!value) return;\r\n\r\n        if (this.SearchFunction) {\r\n\r\n            this.doSearchProtected(value, true, this.SearchFunctionContext, (t) => {\r\n                this.Source = t;\r\n                this.tryBindSourceDisplay();\r\n                setTimeout(() => { this.finalizeValue(value); });\r\n            });\r\n            return;\r\n        }\r\n\r\n        if (!this.Multi)\r\n            this.finalizeValue(value);\r\n    }\r\n\r\n    /**\r\n     * Dato un valore verifica se può restituire le informazioni trovate in **Source** con id uguale a **value** o se deve restituire il valore in se\r\n     * \r\n     * @param {any} value Valore scritto nell'input di testo\r\n     */\r\n    private finalizeValue(value: any) {\r\n        var val = this.BoundSource.find(t => t.id == value);\r\n        this.propagateChange(val ? val.id : value);\r\n\r\n        // Alor... praticamente qui potrebbero arrivare degli switcheroni in cui il Model è uguale all'inizio e alla fine dello stack, per qualche motivo\r\n        // quindi per assicurarmi che il valore venga preso correttamente faccio il classico metti a null poi metti su\r\n        // Notare che mettere il modello a null scatena i writevalue ma tutti i writevalue che si collegao a questo giro dovrebbero essere NOOP su null\r\n        this.Model = null;\r\n        setTimeout(() => {\r\n            this.Model = val ? val.description : value;\r\n            this.EvaluatedModel = this.Model;\r\n        });\r\n    }\r\n\r\n    /**\r\n     * Quando viene scritto un nuovo valore bisogna controllare se per botta di culo fosse un id, in tal caso dev'essere rieffettuato il bind\r\n     * per mostrare solo la descrizione nell'autocomplete\r\n     */\r\n    public evaluateIdResearch(onFailure: Function) {\r\n        let tmpModel = this.Model;\r\n        if (!tmpModel || !this.SearchFunction) {\r\n            onFailure?.();\r\n            return;\r\n        }\r\n\r\n        this.doSearchProtected(tmpModel, true, this.SearchFunctionContext, (t) => {\r\n            if (t && t.length > 0) {\r\n                this.Source = t;\r\n                this.tryBindSourceDisplay();\r\n                if (!this.Multi)\r\n                    setTimeout(() => { this.finalizeValue(tmpModel); });\r\n                else\r\n                    this.cdr.markForCheck();\r\n            }\r\n            else\r\n                onFailure?.();\r\n        });\r\n    }\r\n\r\n    /**\r\n     * Evento di filtro della sorgente dati in base all'input utente\r\n     * \r\n     * @param {string} event Input utente\r\n     */\r\n    public filterSource(event: string) {\r\n\r\n        // Contorllo prima di tutto se è un ID. in caso contrario effettuo la ricerca\r\n        this.evaluateIdResearch(() => {\r\n            this.doFilterSource(event);\r\n        })\r\n    }\r\n\r\n    doFilterSource(event: string){\r\n        if (this.ignoreNextWriteValue) {\r\n            this.ignoreNextWriteValue = false;\r\n            return;\r\n        }\r\n\r\n        // Quando filtro la source, se non devo ignorare l'evento devo comunque assicurarmi di impostare il valore selezionato a null\r\n        if (!this.Multi)\r\n            super.changed(null);\r\n\r\n        if (!event && this.MinChars == 0 && !this.SearchFunction) {\r\n            this.FilteredBoundSource = this.BoundSource;\r\n            return;\r\n        }\r\n\r\n        if (!event || event.length < this.MinChars) {\r\n            this.FilteredBoundSource = [];\r\n            return;\r\n        }\r\n\r\n        if (!this.SearchFunction && (!this.Source || this.Source.length == 0))\r\n            throw \"Impossibile filtrare gli elementi senza una funzione di ricerca che restituisca una lista di { id: string, description: string }\";\r\n\r\n        if (this.SearchFunction) {\r\n            this.throttla(\"filtersource\", () => {\r\n                this.doSearchProtected(event, false, this.SearchFunctionContext, (t) => {\r\n                    this.Source = t;\r\n                    this.tryBindSourceDisplay();\r\n                    // In questo caso è già filtrata dalla SearchFunction\r\n                    this.FilteredBoundSource = this.BoundSource;\r\n                    this.removeFilteredSourceOnDescriptionSelection();\r\n                    this.cdr.markForCheck();\r\n                })\r\n            }, 400);\r\n        }\r\n        else {\r\n            this.throttla(\"filtersource\", () => {\r\n                // In questo caso devo filtrare io in memoria\r\n                this.FilteredBoundSource = this.BoundSource.filter(t => (this.CaseSensitive && t.description.includes(event)) || (!this.CaseSensitive && t.description.toLowerCase().includes(event.toLowerCase())));\r\n                this.removeFilteredSourceOnDescriptionSelection();\r\n                this.cdr.markForCheck();\r\n            }, 100);\r\n        }\r\n    }\r\n\r\n    timer = null;\r\n    maxCallsPerSecond = 4;\r\n    callsDoneThisThreeSeconds = 0;\r\n\r\n    // Permetto al massimo 4 chiamate ogni 3 secondi, se nell'arco di 3 secondi ci sono più di 4 chiamate, ignoro le eccedenti\r\n    doSearchProtected(search: string, byid: boolean, context?: any, onRes?: Function) {\r\n        if (!this.timer) {\r\n            this.timer = setTimeout(() => {\r\n                this.callsDoneThisThreeSeconds = 0;\r\n                clearTimeout(this.timer);\r\n                this.timer = null;\r\n            }, 3000);\r\n        }\r\n\r\n        if (this.callsDoneThisThreeSeconds >= this.maxCallsPerSecond)\r\n            return;\r\n\r\n        this.callsDoneThisThreeSeconds++;\r\n        this.SearchFunction(search, byid, context).subscribe(t => {\r\n            onRes(t);\r\n        });\r\n    }\r\n\r\n    /** @ignore */\r\n    private removeFilteredSourceOnDescriptionSelection() {\r\n        if (this.FilteredBoundSource.length == 1 && (this.FilteredBoundSource[0].description === this.Model) && !this.Multi) {\r\n            let model = this.BoundSource[0].id\r\n            this.Model = model;\r\n            this.EvaluatedModel = this.BoundSource[0].description;\r\n            this.FilteredBoundSource = [];\r\n            setTimeout(() => { this.finalizeValue(model); });\r\n        }\r\n    }\r\n\r\n    /** @ignore */\r\n    public ngOnChanges(changes: SimpleChanges) {\r\n        let newSource = changes[\"Source\"];\r\n        if (newSource) {\r\n            this.tryBindSourceDisplay();\r\n\r\n            // Prima assegnazione se cambia la source sotto (quindi se viene bindata direttamente da HTML)\r\n            if ((this.Model?.length || 0) >= this.MinChars && !this.SearchFunction)\r\n                this.FilteredBoundSource = this.BoundSource;\r\n            else\r\n                this.FilteredBoundSource = [];\r\n\r\n            this.cdr.markForCheck();\r\n        }\r\n    }\r\n\r\n    /** @ignore Override che marca anche il prossimo evento di filterSource da ignorare */\r\n    changed(forcedValue: any = null, markForCheck: boolean = false) {\r\n        if (!this.Multi)\r\n            this.ignoreNextWriteValue = true;\r\n\r\n        if (forcedValue == \"\" && this.Multi)\r\n            this.Model = \"\";\r\n\r\n        var selecteds: string[] = forcedValue ? [forcedValue] : this.Model ? (this.Model.Multi ? this.Model.split(',') : [this.Model]) : [];\r\n        this.EvaluatedModel = selecteds.map(s => this.BoundSource && this.BoundSource.length > 0 ? this.BoundSource.find(t => t.id == s)?.description : \"\").join(', ');\r\n\r\n        super.changed(forcedValue, markForCheck);\r\n    }\r\n\r\n    /** @ignore */\r\n    onNotNullValueSet(): void { }\r\n\r\n    //******************** Funzione di throttling per non spammare richieste in caso di animazioni attivate\r\n    //TODO: spostarla in un metodo di utilità (esfaenza/extensions)\r\n    /** @ignore */\r\n    private executionTimers: { [index: string]: any } = {};\r\n    /** @ignore */\r\n    private throttla(id: string, func: Function, throttleTime: number): void {\r\n        //Se ho la funzione che vuole eseguire ripulisco quel timeout\r\n        if (this.executionTimers[id])\r\n            clearTimeout(this.executionTimers[id]);\r\n\r\n        //Ricreo il timeout per eseguire quella funzione dopo throttleTime millisecondi\r\n        this.executionTimers[id] = setTimeout(() => { func(); this.executionTimers[id] = null; }, throttleTime);\r\n    }\r\n    //*************************\r\n}","<!-- Uguale in tutti i componenti --------------------------------------------------------------------------->\r\n<ng-container *ngIf=\"!FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\">\r\n    <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">\r\n        <ng-container *ngIf=\"DisplayLayout == 'form'\">{{ EvaluatedModel }}</ng-container>\r\n        <div *ngIf=\"DisplayLayout == 'inline'\" class=\"app-inline\">{{ EvaluatedModel }}</div>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n    <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n</ng-container>\r\n\r\n<div *ngIf=\"FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\" class=\"{{FormGroupClass + (Last ? ' app-margin-bottom-0 app-margin-right-0 ' : '') + (DisplayLayout == 'inline' && DisplayMode ? (' app-inline-block ' + (!Last ? 'app-margin-right-10' : '')) : ' form-group row')}}\">\r\n\r\n    <label class=\"col-md-{{(DisplayMode && DisplayLayout == 'inline' ? 'none app-bold app-margin-bottom-0' : LabelColWidth) + (DisplayMode ? ' app-bold' : ' m-t-5') }}\">{{Label}}{{Required && !DisplayMode ? '*' : ''}}{{Label ? \":\" : \"\"}}</label>\r\n    <span *ngIf=\"DisplayMode && DisplayLayout == 'inline' && InlineSeparator != ''\">{{InlineSeparator}}</span>\r\n    <div class=\"col-md-{{DisplayMode && DisplayLayout == 'inline' ? 'none app-inline-block' : InputColWidth}}\">\r\n\r\n        <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">{{ EvaluatedModel }}</ng-container>\r\n        <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n        <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n    </div>\r\n    <div class=\"clearfix\"></div>\r\n</div>\r\n<!----------------------------------------------------------------------------------------------------------->\r\n<!-- Form-Model: {{Model}} -->\r\n<ng-template #controlTemplate>\r\n    <val-autocomplete *ngIf=\"!Multi\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [noValidate]=\"!Validation\"\r\n               [submitted]=\"Form?.submitted\"\r\n               [Readonly]=\"Readonly\"\r\n               [label]=\"SelectLabel\"\r\n               type=\"text\"\r\n               [(ngModel)]=\"Model\"\r\n               [id]=\"GeneratedName\"\r\n               name=\"{{GeneratedName}}\"\r\n               #validationControl=\"ngModel\"\r\n               (inputChange)=\"filterSource($event);\"\r\n               (inputFocus)=\"focused($event);\"\r\n               (inputFinalized)=\"finalized()\"\r\n               (optionChange)=\"changed($event);\"\r\n               [placeholder]=\"Required ? ((RequiredPlaceholder != null ? RequiredPlaceholder : (('Seleziona' | localize : lc) + '...'))) : Placeholder\"\r\n               [validationFailed]=\"FailedValidationMessage\"\r\n               [FilteredSource]=\"FilteredBoundSource\">\r\n    </val-autocomplete>\r\n\r\n    <val-autocomplete-multi *ngIf=\"Multi\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [noValidate]=\"!Validation\"\r\n               [submitted]=\"Form?.submitted\"\r\n               [Readonly]=\"Readonly\"\r\n               [label]=\"SelectLabel\"\r\n               [ChipThreshold]=\"MultiElementsThreshold\"\r\n               [HideChoicesOnSelection]=\"HideChoicesOnSelection\"\r\n               type=\"text\"\r\n               [(ngModel)]=\"Model\"\r\n               [id]=\"GeneratedName\"\r\n               name=\"{{GeneratedName}}\"\r\n               #validationControl=\"ngModel\"\r\n               (inputChange)=\"filterSource($event);\"\r\n               (inputFocus)=\"focused($event);\"\r\n               (inputFinalized)=\"finalized()\"\r\n               (optionChange)=\"changed($event);\"\r\n               [placeholder]=\"Required ? ((RequiredPlaceholder != null ? RequiredPlaceholder : (('Seleziona' | localize : lc) + '...'))) : Placeholder\"\r\n               [validationFailed]=\"FailedValidationMessage\"\r\n               [FilteredSource]=\"FilteredBoundSource\">\r\n\r\n    </val-autocomplete-multi>\r\n</ng-template>"]}
|
|
269
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-autocomplete.component.js","sourceRoot":"","sources":["../../../../../../projects/forms-and-validations/src/lib/forms/form-autocomplete/form-autocomplete.component.ts","../../../../../../projects/forms-and-validations/src/lib/forms/form-autocomplete/form-autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["// Angular\r\nimport { ChangeDetectionStrategy, Component, Inject, Input, Optional, ChangeDetectorRef, Self, SimpleChanges } from \"@angular/core\";\r\nimport { ControlValueAccessor, NG_VALIDATORS, NgControl } from \"@angular/forms\";\r\n\r\n// Applicazione\r\nimport { BaseFormControl } from \"../base-form-control\";\r\n\r\n// Configurazioni\r\nimport { AccessControlService, ComponentContext } from '@esfaenza/access-control';\r\nimport { LocalizationService } from \"@esfaenza/localizations\";\r\nimport { ACO_CUSTOMKEY, FAV_DEBUG_MODE } from '../../tokens';\r\n\r\nimport { Observable } from \"rxjs\";\r\n\r\n//Localizzazione\r\nimport { FormAutocompleteComponentLoc } from \"./form-autocomplete.component.loc\";\r\n\r\n/** Componente di input che si auto-completa in base al valore attuale */\r\n@Component({\r\n    selector: \"form-autocomplete\",\r\n    templateUrl: \"form-autocomplete.component.html\",\r\n    providers: [{ provide: LocalizationService, useClass: FormAutocompleteComponentLoc }],\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class FormAutocompleteComponent extends BaseFormControl implements ControlValueAccessor {\r\n\r\n    /** Permette di specificare il testo della Label flottante material-style */\r\n    @Input() SelectLabel: string = \"\";\r\n\r\n    /** Contesto per la funzione di ricerca */\r\n    @Input() SearchFunctionContext: any;\r\n\r\n    /** Funzione di ricerca che verrà chiamata dal componente */\r\n    @Input() SearchFunction: (search: string, byid: boolean, context?: any) => Observable<{ id: string, description: string }[]> = null;\r\n\r\n    /** Numero minimo di caratteri con cui cercare */\r\n    @Input() MinChars: number = 3;\r\n\r\n    /** Definisce che ad ogni selezione deve chiudere la tendina */\r\n    @Input() HideChoicesOnSelection: boolean = false;\r\n\r\n    /** Override del placeholder per select requried */\r\n    @Input() RequiredPlaceholder: string = null;\r\n\r\n    /** Indica se i controlli devono essere effettuati tenendo conto del Case o meno. Vale solo qualora la **Source** fosse fornita */\r\n    @Input() CaseSensitive: boolean = false;\r\n\r\n    /** Indica se usare la modalità multiselezione o no */\r\n    @Input() Multi: boolean = false;\r\n\r\n    /** Indica se usare la modalità multiselezione o no */\r\n    @Input() MultiElementsThreshold: number = 10;\r\n\r\n    /**\r\n     * Indica se ignorare il prossimo evento writeValue che normalmente dovrebbe richiedere la nuova source. Serve per quando l'utente seleziona un elemento:\r\n     * Subito dopo partirebbe un altro evento modelChange che ricaricherebbe nuovamente la source\r\n     */\r\n    private ignoreNextWriteValue: boolean = false;\r\n\r\n    /** Sorgente Bindata Filtrata in base al contenuto della casella di testo */\r\n    public FilteredBoundSource: { id: string, description: string }[] = [];\r\n\r\n    /** @ignore Costruttore  */\r\n    constructor(cdr: ChangeDetectorRef, public lc: LocalizationService, @Optional() @Self() ngControl: NgControl, @Optional() @Inject(NG_VALIDATORS) _validators: Array<any>, @Optional() ac: AccessControlService, @Optional() AppContext: ComponentContext, @Optional() @Inject(ACO_CUSTOMKEY) ACO_CUSTOMKEY: string, @Optional() @Inject(FAV_DEBUG_MODE) FAV_DEBUG_MODE: boolean) {\r\n        super(cdr, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY, FAV_DEBUG_MODE);\r\n    }\r\n\r\n    /** @ignore */\r\n    writeValue(value: any): void {\r\n        if (!value) return;\r\n\r\n        if (this.SearchFunction) {\r\n\r\n            this.doSearchProtected(value, true, this.SearchFunctionContext, (t) => {\r\n                this.Source = t;\r\n                this.tryBindSourceDisplay();\r\n                setTimeout(() => { this.finalizeValue(value); });\r\n            });\r\n            return;\r\n        }\r\n\r\n        if (!this.Multi)\r\n            this.finalizeValue(value);\r\n    }\r\n\r\n    /**\r\n     * Dato un valore verifica se può restituire le informazioni trovate in **Source** con id uguale a **value** o se deve restituire il valore in se\r\n     * \r\n     * @param {any} value Valore scritto nell'input di testo\r\n     */\r\n    private finalizeValue(value: any) {\r\n        var val = this.BoundSource.find(t => t.id == value);\r\n        this.propagateChange(val ? val.id : value);\r\n\r\n        // Alor... praticamente qui potrebbero arrivare degli switcheroni in cui il Model è uguale all'inizio e alla fine dello stack, per qualche motivo\r\n        // quindi per assicurarmi che il valore venga preso correttamente faccio il classico metti a null poi metti su\r\n        // Notare che mettere il modello a null scatena i writevalue ma tutti i writevalue che si collegao a questo giro dovrebbero essere NOOP su null\r\n        this.Model = null;\r\n        setTimeout(() => {\r\n            this.Model = val ? val.description : value;\r\n            this.EvaluatedModel = this.Model;\r\n            this.cdr.markForCheck();\r\n        });\r\n    }\r\n\r\n    /**\r\n     * Quando viene scritto un nuovo valore bisogna controllare se per botta di culo fosse un id, in tal caso dev'essere rieffettuato il bind\r\n     * per mostrare solo la descrizione nell'autocomplete\r\n     */\r\n    public evaluateIdResearch(onFailure: Function) {\r\n        let tmpModel = this.Model;\r\n        if (!tmpModel || !this.SearchFunction) {\r\n            onFailure?.();\r\n            return;\r\n        }\r\n\r\n        this.doSearchProtected(tmpModel, true, this.SearchFunctionContext, (t) => {\r\n            if (t && t.length > 0) {\r\n                this.Source = t;\r\n                this.tryBindSourceDisplay();\r\n                if (!this.Multi)\r\n                    setTimeout(() => { this.finalizeValue(tmpModel); });\r\n                else\r\n                    this.cdr.markForCheck();\r\n            }\r\n            else\r\n                onFailure?.();\r\n        });\r\n    }\r\n\r\n    /**\r\n     * Evento di filtro della sorgente dati in base all'input utente\r\n     * \r\n     * @param {string} event Input utente\r\n     */\r\n    public filterSource(event: string) {\r\n\r\n        // Contorllo prima di tutto se è un ID. in caso contrario effettuo la ricerca\r\n        this.evaluateIdResearch(() => {\r\n            this.doFilterSource(event);\r\n        })\r\n    }\r\n\r\n    doFilterSource(event: string){\r\n        if (this.ignoreNextWriteValue) {\r\n            this.ignoreNextWriteValue = false;\r\n            return;\r\n        }\r\n\r\n        // Quando filtro la source, se non devo ignorare l'evento devo comunque assicurarmi di impostare il valore selezionato a null\r\n        if (!this.Multi)\r\n            super.changed(null);\r\n\r\n        if (!event && this.MinChars == 0 && !this.SearchFunction) {\r\n            this.FilteredBoundSource = this.BoundSource;\r\n            this.cdr.markForCheck();\r\n            return;\r\n        }\r\n\r\n        if (!event || event.length < this.MinChars) {\r\n            this.FilteredBoundSource = [];\r\n            this.cdr.markForCheck();\r\n            return;\r\n        }\r\n\r\n        if (!this.SearchFunction && (!this.Source || this.Source.length == 0))\r\n            throw \"Impossibile filtrare gli elementi senza una funzione di ricerca che restituisca una lista di { id: string, description: string }\";\r\n\r\n        if (this.SearchFunction) {\r\n            this.throttla(\"filtersource\", () => {\r\n                this.doSearchProtected(event, false, this.SearchFunctionContext, (t) => {\r\n                    this.Source = t;\r\n                    this.tryBindSourceDisplay();\r\n                    // In questo caso è già filtrata dalla SearchFunction\r\n                    this.FilteredBoundSource = this.BoundSource;\r\n                    this.removeFilteredSourceOnDescriptionSelection();\r\n                    this.cdr.markForCheck();\r\n                })\r\n            }, 400);\r\n        }\r\n        else {\r\n            this.throttla(\"filtersource\", () => {\r\n                // In questo caso devo filtrare io in memoria\r\n                this.FilteredBoundSource = this.BoundSource.filter(t => (this.CaseSensitive && t.description.includes(event)) || (!this.CaseSensitive && t.description.toLowerCase().includes(event.toLowerCase())));\r\n                this.removeFilteredSourceOnDescriptionSelection();\r\n                this.cdr.markForCheck();\r\n            }, 100);\r\n        }\r\n    }\r\n\r\n    timer = null;\r\n    maxCallsPerSecond = 4;\r\n    callsDoneThisThreeSeconds = 0;\r\n\r\n    // Permetto al massimo 4 chiamate ogni 3 secondi, se nell'arco di 3 secondi ci sono più di 4 chiamate, ignoro le eccedenti\r\n    doSearchProtected(search: string, byid: boolean, context?: any, onRes?: Function) {\r\n        if (!this.timer) {\r\n            this.timer = setTimeout(() => {\r\n                this.callsDoneThisThreeSeconds = 0;\r\n                clearTimeout(this.timer);\r\n                this.timer = null;\r\n            }, 3000);\r\n        }\r\n\r\n        if (this.callsDoneThisThreeSeconds >= this.maxCallsPerSecond)\r\n            return;\r\n\r\n        this.callsDoneThisThreeSeconds++;\r\n        this.SearchFunction(search, byid, context).subscribe(t => {\r\n            onRes(t);\r\n        });\r\n    }\r\n\r\n    /** @ignore */\r\n    private removeFilteredSourceOnDescriptionSelection() {\r\n        if (this.FilteredBoundSource.length == 1 && (this.FilteredBoundSource[0].description === this.Model) && !this.Multi) {\r\n            let model = this.BoundSource[0].id\r\n            this.Model = model;\r\n            this.EvaluatedModel = this.BoundSource[0].description;\r\n            this.FilteredBoundSource = [];\r\n            setTimeout(() => { this.finalizeValue(model); });\r\n        }\r\n    }\r\n\r\n    /** @ignore */\r\n    public ngOnChanges(changes: SimpleChanges) {\r\n        let newSource = changes[\"Source\"];\r\n        if (newSource) {\r\n            this.tryBindSourceDisplay();\r\n\r\n            // Prima assegnazione se cambia la source sotto (quindi se viene bindata direttamente da HTML)\r\n            if ((this.Model?.length || 0) >= this.MinChars && !this.SearchFunction)\r\n                this.FilteredBoundSource = this.BoundSource;\r\n            else\r\n                this.FilteredBoundSource = [];\r\n\r\n            this.cdr.markForCheck();\r\n        }\r\n    }\r\n\r\n    /** @ignore Override che marca anche il prossimo evento di filterSource da ignorare */\r\n    changed(forcedValue: any = null, markForCheck: boolean = false) {\r\n        if (!this.Multi)\r\n            this.ignoreNextWriteValue = true;\r\n\r\n        if (forcedValue == \"\" && this.Multi)\r\n            this.Model = \"\";\r\n\r\n        var selecteds: string[] = forcedValue ? [forcedValue] : this.Model ? (this.Model.Multi ? this.Model.split(',') : [this.Model]) : [];\r\n        this.EvaluatedModel = selecteds.map(s => this.BoundSource && this.BoundSource.length > 0 ? this.BoundSource.find(t => t.id == s)?.description : \"\").join(', ');\r\n\r\n        super.changed(forcedValue, markForCheck);\r\n    }\r\n\r\n    /** @ignore */\r\n    onNotNullValueSet(): void { }\r\n\r\n    //******************** Funzione di throttling per non spammare richieste in caso di animazioni attivate\r\n    //TODO: spostarla in un metodo di utilità (esfaenza/extensions)\r\n    /** @ignore */\r\n    private executionTimers: { [index: string]: any } = {};\r\n    /** @ignore */\r\n    private throttla(id: string, func: Function, throttleTime: number): void {\r\n        //Se ho la funzione che vuole eseguire ripulisco quel timeout\r\n        if (this.executionTimers[id])\r\n            clearTimeout(this.executionTimers[id]);\r\n\r\n        //Ricreo il timeout per eseguire quella funzione dopo throttleTime millisecondi\r\n        this.executionTimers[id] = setTimeout(() => { func(); this.executionTimers[id] = null; }, throttleTime);\r\n    }\r\n    //*************************\r\n}","<!-- Uguale in tutti i componenti --------------------------------------------------------------------------->\r\n<ng-container *ngIf=\"!FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\">\r\n    <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">\r\n        <ng-container *ngIf=\"DisplayLayout == 'form'\">{{ EvaluatedModel }}</ng-container>\r\n        <div *ngIf=\"DisplayLayout == 'inline'\" class=\"app-inline\">{{ EvaluatedModel }}</div>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n    <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n</ng-container>\r\n\r\n<div *ngIf=\"FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\" class=\"{{FormGroupClass + (Last ? ' app-margin-bottom-0 app-margin-right-0 ' : '') + (DisplayLayout == 'inline' && DisplayMode ? (' app-inline-block ' + (!Last ? 'app-margin-right-10' : '')) : ' form-group row')}}\">\r\n\r\n    <label class=\"col-md-{{(DisplayMode && DisplayLayout == 'inline' ? 'none app-bold app-margin-bottom-0' : LabelColWidth) + (DisplayMode ? ' app-bold' : ' m-t-5') }}\">{{Label}}{{Required && !DisplayMode ? '*' : ''}}{{Label ? \":\" : \"\"}}</label>\r\n    <span *ngIf=\"DisplayMode && DisplayLayout == 'inline' && InlineSeparator != ''\">{{InlineSeparator}}</span>\r\n    <div class=\"col-md-{{DisplayMode && DisplayLayout == 'inline' ? 'none app-inline-block' : InputColWidth}}\">\r\n\r\n        <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">{{ EvaluatedModel }}</ng-container>\r\n        <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n        <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n    </div>\r\n    <div class=\"clearfix\"></div>\r\n</div>\r\n<!----------------------------------------------------------------------------------------------------------->\r\n<!-- Form-Model: {{Model}} -->\r\n<ng-template #controlTemplate>\r\n    <val-autocomplete *ngIf=\"!Multi\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [noValidate]=\"!Validation\"\r\n               [submitted]=\"Form?.submitted\"\r\n               [Readonly]=\"Readonly\"\r\n               [label]=\"SelectLabel\"\r\n               type=\"text\"\r\n               [(ngModel)]=\"Model\"\r\n               [id]=\"GeneratedName\"\r\n               name=\"{{GeneratedName}}\"\r\n               #validationControl=\"ngModel\"\r\n               (inputChange)=\"filterSource($event);\"\r\n               (inputFocus)=\"focused($event);\"\r\n               (inputFinalized)=\"finalized()\"\r\n               (optionChange)=\"changed($event);\"\r\n               [placeholder]=\"Required ? ((RequiredPlaceholder != null ? RequiredPlaceholder : (('Seleziona' | localize : lc) + '...'))) : Placeholder\"\r\n               [validationFailed]=\"FailedValidationMessage\"\r\n               [FilteredSource]=\"FilteredBoundSource\">\r\n    </val-autocomplete>\r\n\r\n    <val-autocomplete-multi *ngIf=\"Multi\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [noValidate]=\"!Validation\"\r\n               [submitted]=\"Form?.submitted\"\r\n               [Readonly]=\"Readonly\"\r\n               [label]=\"SelectLabel\"\r\n               [ChipThreshold]=\"MultiElementsThreshold\"\r\n               [HideChoicesOnSelection]=\"HideChoicesOnSelection\"\r\n               type=\"text\"\r\n               [(ngModel)]=\"Model\"\r\n               [id]=\"GeneratedName\"\r\n               name=\"{{GeneratedName}}\"\r\n               #validationControl=\"ngModel\"\r\n               (inputChange)=\"filterSource($event);\"\r\n               (inputFocus)=\"focused($event);\"\r\n               (inputFinalized)=\"finalized()\"\r\n               (optionChange)=\"changed($event);\"\r\n               [placeholder]=\"Required ? ((RequiredPlaceholder != null ? RequiredPlaceholder : (('Seleziona' | localize : lc) + '...'))) : Placeholder\"\r\n               [validationFailed]=\"FailedValidationMessage\"\r\n               [FilteredSource]=\"FilteredBoundSource\">\r\n\r\n    </val-autocomplete-multi>\r\n</ng-template>"]}
|
|
@@ -3738,6 +3738,7 @@ class FormAutocompleteComponent extends BaseFormControl {
|
|
|
3738
3738
|
setTimeout(() => {
|
|
3739
3739
|
this.Model = val ? val.description : value;
|
|
3740
3740
|
this.EvaluatedModel = this.Model;
|
|
3741
|
+
this.cdr.markForCheck();
|
|
3741
3742
|
});
|
|
3742
3743
|
}
|
|
3743
3744
|
/**
|
|
@@ -3784,10 +3785,12 @@ class FormAutocompleteComponent extends BaseFormControl {
|
|
|
3784
3785
|
super.changed(null);
|
|
3785
3786
|
if (!event && this.MinChars == 0 && !this.SearchFunction) {
|
|
3786
3787
|
this.FilteredBoundSource = this.BoundSource;
|
|
3788
|
+
this.cdr.markForCheck();
|
|
3787
3789
|
return;
|
|
3788
3790
|
}
|
|
3789
3791
|
if (!event || event.length < this.MinChars) {
|
|
3790
3792
|
this.FilteredBoundSource = [];
|
|
3793
|
+
this.cdr.markForCheck();
|
|
3791
3794
|
return;
|
|
3792
3795
|
}
|
|
3793
3796
|
if (!this.SearchFunction && (!this.Source || this.Source.length == 0))
|