@esfaenza/forms-and-validations 15.2.39 → 15.2.40
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-multiselect/form-multiselect.component.mjs +4 -4
- package/fesm2015/esfaenza-forms-and-validations.mjs +3 -3
- package/fesm2015/esfaenza-forms-and-validations.mjs.map +1 -1
- package/fesm2020/esfaenza-forms-and-validations.mjs +3 -3
- package/fesm2020/esfaenza-forms-and-validations.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -110,14 +110,14 @@ export class FormMultiSelectComponent extends BaseFormControl {
|
|
|
110
110
|
/** @ignore Override per gestire input in uscita */
|
|
111
111
|
changed() {
|
|
112
112
|
let toEmit = null;
|
|
113
|
-
if (
|
|
113
|
+
if (this.UseJsonList)
|
|
114
|
+
toEmit = JSON.stringify(this.Model.map(m => m.id));
|
|
115
|
+
else if (!this.UseKeyValues && !this.UseCommaSeparatedList)
|
|
114
116
|
toEmit = this.Model.map(m => m.id);
|
|
115
117
|
else if (this.UseKeyValues)
|
|
116
118
|
toEmit = this.Model.map(m => ({ id: m.id, description: m.description }));
|
|
117
119
|
else if (this.UseCommaSeparatedList)
|
|
118
120
|
toEmit = this.Model.map(m => m.id).join(',');
|
|
119
|
-
else if (this.UseJsonList)
|
|
120
|
-
toEmit = JSON.stringify(this.Model.map(m => m.id));
|
|
121
121
|
this.EvaluatedModel = this.Model.map(t => t.itemName).join(', ');
|
|
122
122
|
super.changed(toEmit, false, true);
|
|
123
123
|
super.finalized();
|
|
@@ -160,4 +160,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
160
160
|
}], UseJsonList: [{
|
|
161
161
|
type: Input
|
|
162
162
|
}] } });
|
|
163
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-multiselect.component.js","sourceRoot":"","sources":["../../../../../../projects/forms-and-validations/src/lib/forms/form-multiselect/form-multiselect.component.ts","../../../../../../projects/forms-and-validations/src/lib/forms/form-multiselect/form-multiselect.component.html"],"names":[],"mappings":"AAAA,UAAU;AACV,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAiB,iBAAiB,EAAE,MAAM,eAAe,CAAC;AACpI,OAAO,EAAwB,aAAa,EAAa,MAAM,gBAAgB,CAAC;AAEhF,iBAAiB;AACjB,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAE9D,OAAO,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AAE7D,eAAe;AACf,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,EAAE,2BAA2B,EAAE,MAAM,kCAAkC,CAAC;;;;;;;AAG/E;;;;;GAKG;AASH,MAAM,OAAO,wBAAyB,SAAQ,eAAe;IA2BzD,2BAA2B;IAC3B,YAAY,GAAsB,EAAS,EAAuB,EAAsB,SAAoB,EAAqC,WAAuB,EAAc,EAAwB,EAAc,UAA4B,EAAqC,aAAqB,EAAsC,cAAwB;QAC5W,KAAK,CAAC,GAAG,EAAE,SAAS,EAAE,WAAW,EAAE,EAAE,EAAE,UAAU,EAAE,aAAa,EAAE,cAAc,CAAC,CAAC;QAD3C,OAAE,GAAF,EAAE,CAAqB;QA1BlE;;;;WAIG;QACK,aAAQ,GAA4D,EAAE,CAAC;QAE/E,gKAAgK;QACxJ,2BAAsB,GAAY,KAAK,CAAC;QAEhD,4EAA4E;QACnE,gBAAW,GAAW,EAAE,CAAC;QAElC,uGAAuG;QAC9F,iBAAY,GAAY,KAAK,CAAC;QAEvC,yIAAyI;QAChI,0BAAqB,GAAY,KAAK,CAAC;QAEhD,kEAAkE;QACzD,gBAAW,GAAY,KAAK,CAAC;QAEtC,mEAAmE;QAC5D,aAAQ,GAAuJ,IAAI,CAAC;QAMvK,oIAAoI;QACpI,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAED,cAAc;IACP,KAAK,CAAC,WAAW,CAAC,OAAsB;QAC3C,MAAM,SAAS,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC;QACpC,IAAI,SAAS,EACb;YACI,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC5B,IAAI,IAAI,CAAC,sBAAsB,EAAE;gBAC7B,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;gBAC/B,IAAI,CAAC,sBAAsB,GAAG,KAAK,CAAC;aACvC;SACJ;QAED,MAAM,QAAQ,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC;QACrC,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,YAAY,IAAI,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,IAAI,KAAK,CAAC,CAAC;IAC9F,CAAC;IAED;;;;OAIG;IACK,gBAAgB,CAAC,QAAiB;QACtC,IAAI,CAAC,QAAQ,GAAG;YACZ,aAAa,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,mBAAmB,CAAC;YAC/C,eAAe,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,qBAAqB,CAAC;YACnD,IAAI,EAAE,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,8BAA8B,CAAC;YACrE,cAAc,EAAE,IAAI;YACpB,QAAQ,EAAE,QAAQ;YAClB,QAAQ,EAAE,aAAa;YACvB,SAAS,EAAE,KAAK;SACnB,CAAC;IACN,CAAC;IAED,cAAc;IACd,iBAAiB,KAAW,CAAC;IAE7B;;;;;OAKG;IACH,mBAAmB;QACf,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,qDAAqD;IACrD,UAAU,CAAC,GAAmB;QAC1B,IAAI,CAAC,QAAQ,GAAG,GAAG,CAAC;QACpB,IAAI,MAAM,GAA0C,EAAE,CAAC;QAEvD,IAAG,IAAI,CAAC,qBAAqB,IAAI,GAAG,IAAI,CAAC,OAAO,GAAG,KAAK,QAAQ,IAAI,GAAG,YAAY,MAAM,CAAC;YACtF,GAAG,GAAY,GAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAEnC,IAAG,IAAI,CAAC,WAAW,IAAI,GAAG,IAAI,CAAC,OAAO,GAAG,KAAK,QAAQ,IAAI,GAAG,YAAY,MAAM,CAAC;YAC5E,GAAG,GAAG,IAAI,CAAC,KAAK,CAAS,GAAG,CAAC,CAAC;QAElC,oFAAoF;QACpF,4EAA4E;QAC5E,IAAI,GAAG,IAAI,GAAG,CAAC,MAAM,GAAG,CAAC,EAAE;YACf,GAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;gBACrB,IAAI,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBAC9E,IAAI,IAAI;oBACJ,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;qBAC7C,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,WAAW,CAAC,MAAM,IAAI,CAAC;oBACtD,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC;YAC3C,CAAC,CAAC,CAAC;SACN;QAED,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAChE,KAAK,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;IAC7B,CAAC;IAED,mDAAmD;IACnD,OAAO;QACH,IAAI,MAAM,GAAG,IAAI,CAAC;QAClB,IAAI,CAAC,IAAI,CAAC,YAAY,IAAI,CAAC,IAAI,CAAC,qBAAqB;YACjD,MAAM,GAAW,IAAI,CAAC,KAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;aAC3C,IAAI,IAAI,CAAC,YAAY;YACtB,MAAM,GAAW,IAAI,CAAC,KAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE,WAAW,EAAE,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;aACjF,IAAI,IAAI,CAAC,qBAAqB;YAC/B,MAAM,GAAW,IAAI,CAAC,KAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;aACrD,IAAI,IAAI,CAAC,WAAW;YACrB,MAAM,GAAG,IAAI,CAAC,SAAS,CAAS,IAAI,CAAC,KAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAEhE,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACjE,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;QACnC,KAAK,CAAC,SAAS,EAAE,CAAC;IACtB,CAAC;;qHA3HQ,wBAAwB,2IA4BiG,aAAa,iIAA+H,aAAa,6BAA6C,cAAc;yGA5B7U,wBAAwB,sPC5BrC,k0FAoCc,6vHDdK,CAAC,EAAE,OAAO,EAAE,mBAAmB,EAAE,QAAQ,EAAE,2BAA2B,EAAE,CAAC;2FAM/E,wBAAwB;kBARpC,SAAS;+BACI,kBAAkB,iBACb,CAAC,EAAE,OAAO,EAAE,mBAAmB,EAAE,QAAQ,EAAE,2BAA2B,EAAE,CAAC,iBAGzE,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,OAAO;;0BA8BqB,QAAQ;;0BAAI,IAAI;;0BAA0B,QAAQ;;0BAAI,MAAM;2BAAC,aAAa;;0BAA4B,QAAQ;;0BAA8B,QAAQ;;0BAAkC,QAAQ;;0BAAI,MAAM;2BAAC,aAAa;;0BAA0B,QAAQ;;0BAAI,MAAM;2BAAC,cAAc;4CAf7U,WAAW;sBAAnB,KAAK;gBAGG,YAAY;sBAApB,KAAK;gBAGG,qBAAqB;sBAA7B,KAAK;gBAGG,WAAW;sBAAnB,KAAK","sourcesContent":["// Angular\r\nimport { ChangeDetectionStrategy, Component, Inject, Input, Optional, Self, SimpleChanges, ViewEncapsulation } from \"@angular/core\";\r\nimport { ControlValueAccessor, NG_VALIDATORS, NgControl } from \"@angular/forms\";\r\n\r\n// Configurazioni\r\nimport { LocalizationService } from \"@esfaenza/localizations\";\r\nimport { AccessControlService, ComponentContext } from '@esfaenza/access-control';\r\nimport { ACO_CUSTOMKEY, FAV_DEBUG_MODE } from '../../tokens';\r\n\r\n// Applicazione\r\nimport { BaseFormControl } from \"../base-form-control\";\r\nimport { FormMultiSelectComponentLoc } from \"./form-multiselect.component.loc\";\r\nimport { ChangeDetectorRef } from \"@angular/core\";\r\n\r\n/**\r\n * Componente che permette di effettuare una selezione multipla fra gli oggetti passati nell'Input **Source**\r\n * \r\n * N.B: Al contrario degli altri componenti form-* questo viene tenuto con **changeDetection: ChangeDetectionStrategy.Default** in quanto il componente \r\n * utilizzato internamente (angular2-multiselect) non è stato assolutamente pensato per essere usato con **ChangeDetectionStrategy.OnPush**\r\n */\r\n@Component({\r\n    selector: \"form-multiselect\",\r\n    viewProviders: [{ provide: LocalizationService, useClass: FormMultiSelectComponentLoc }],\r\n    templateUrl: \"form-multiselect.component.html\",\r\n    styleUrls: [\"form-multiselect.component.css\"],\r\n    encapsulation: ViewEncapsulation.None,\r\n    changeDetection: ChangeDetectionStrategy.Default\r\n})\r\nexport class FormMultiSelectComponent extends BaseFormControl implements ControlValueAccessor {\r\n\r\n    /**\r\n     * Modello temporaneo **NON** compatibile in maniera diretta con il componente **angular2-multiselect** usato internamente\r\n     * \r\n     * Serve da appoggio per effettuare un re-bind qualora la sorgente cambiasse e qualora **RebindModelAfterSource** fosse true\r\n     */\r\n    private TmpModel: string | string[] | {id: string, description: string}[] = [];\r\n\r\n    /** Indica se la prossima modifica alla Source deve anche effettuare un re-bind del modello. Serve se la **BoundSource** passa da non avere oggetti ad averne */\r\n    private RebindModelAfterSource: boolean = false;\r\n\r\n    /** Permette di specificare il testo della Label flottante material-style */\r\n    @Input() SelectLabel: string = \"\";\r\n\r\n    /** Permette al componente di gestire come modello non una lista di chiavi, ma una lista di KeyValue */\r\n    @Input() UseKeyValues: boolean = false;\r\n\r\n    /** Indica al componente di emettere una lista di chiavi separate da virgola piuttosto che una lista vera e propria di chiavi/KeyValue */\r\n    @Input() UseCommaSeparatedList: boolean = false;\r\n\r\n    /** Indica se effettuare l'emit come lista di valori in un Json */\r\n    @Input() UseJsonList: boolean = false;\r\n\r\n    /** Impostazioni del componente interno **angular2-multiselect** */\r\n    public Settings: { selectAllText: string, unSelectAllText: string, text: string, enableCheckAll: boolean, disabled: boolean, labelKey: string, tagToBody: boolean } = null;\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        // Default dei settings per evitare che siano mai nulli, altrimenti il cazzo di CuppaLab salta in araia che è veramente una bellezza\r\n        this.evaluateSettings(false);\r\n    }\r\n\r\n    /** @ignore */\r\n    public async ngOnChanges(changes: SimpleChanges) {\r\n        const newSource = changes[\"Source\"];\r\n        if (newSource)\r\n        {\r\n            this.tryBindSourceDisplay();\r\n            if (this.RebindModelAfterSource) {\r\n                this.writeValue(this.TmpModel);\r\n                this.RebindModelAfterSource = false;\r\n            }\r\n        }\r\n\r\n        const readonly = changes[\"Readonly\"];\r\n        this.evaluateSettings(readonly ? readonly.currentValue ?? false : this.Readonly ?? false);\r\n    }\r\n\r\n    /**\r\n     * Scrive i nuovi settings per il componente\r\n     * \r\n     * @param {boolean} disabled Indica se il componente dev'essere disabilitato o meno\r\n     */\r\n    private evaluateSettings(disabled: boolean) {\r\n        this.Settings = {\r\n            selectAllText: this.lc.loc(\"Select everything\"),\r\n            unSelectAllText: this.lc.loc(\"Deselect everything\"),\r\n            text: this.SelectLabel || this.lc.loc(\"Select one or more values...\"),\r\n            enableCheckAll: true,\r\n            disabled: disabled,\r\n            labelKey: \"description\",\r\n            tagToBody: false\r\n        };\r\n    }\r\n\r\n    /** @ignore */\r\n    onNotNullValueSet(): void { }\r\n\r\n    /**\r\n     * Indica se il comopnente in questione è in grado di gestire ngControl nulli. \r\n     * In questo componente è normale che sia così quindi restituisce semplicemente **true**\r\n     * \r\n     * @returns {boolean} **true** se gestisco ngControl nulli, **false** altrimenti\r\n     */\r\n    handleNullNgControl(): boolean {\r\n        return true;\r\n    }\r\n\r\n    /** @ignore Override per gestire input in ingresso */\r\n    writeValue(obj: any[] | string): void {\r\n        this.TmpModel = obj;\r\n        let toPass: { id: string, description: string }[] = [];\r\n\r\n        if(this.UseCommaSeparatedList && obj && (typeof obj === 'string' || obj instanceof String))\r\n            obj = (<string>obj).split(',');\r\n\r\n        if(this.UseJsonList && obj && (typeof obj === 'string' || obj instanceof String))\r\n            obj = JSON.parse(<string>obj);\r\n\r\n        //Qui arrivano solo gli id, o {id: x, description: y} in caso sono in UseKeyValues, \r\n        //devo tirare fuori gli oggetti relativi e piazzarli come lista per il Model\r\n        if (obj && obj.length > 0) {\r\n            (<any[]>obj).forEach(t => {\r\n                let item = this.BoundSource.find(o => o.id == (this.UseKeyValues ? t.id : t));\r\n                if (item)\r\n                    toPass.push(JSON.parse(JSON.stringify(item)));\r\n                else if (!this.BoundSource || this.BoundSource.length == 0)\r\n                    this.RebindModelAfterSource = true;\r\n            });\r\n        }\r\n\r\n        this.EvaluatedModel = toPass.map(t => t.description).join(', ');\r\n        super.writeValue(toPass);\r\n    }\r\n\r\n    /** @ignore Override per gestire input in uscita */\r\n    changed() {\r\n        let toEmit = null;\r\n        if (!this.UseKeyValues && !this.UseCommaSeparatedList)\r\n            toEmit = (<any[]>this.Model).map(m => m.id);\r\n        else if (this.UseKeyValues)\r\n            toEmit = (<any[]>this.Model).map(m => ({ id: m.id, description: m.description }));\r\n        else if (this.UseCommaSeparatedList)\r\n            toEmit = (<any[]>this.Model).map(m => m.id).join(',');\r\n        else if (this.UseJsonList)\r\n            toEmit = JSON.stringify((<any[]>this.Model).map(m => m.id));\r\n\r\n        this.EvaluatedModel = this.Model.map(t => t.itemName).join(', ');\r\n        super.changed(toEmit, false, true);\r\n        super.finalized();\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\r\n<ng-template #controlTemplate>\r\n    <div [class.ms-placeholder]=\"!Model || Model.length == 0\" (click)=\"focused($event)\">\r\n        <angular2-multiselect #validationControl=\"ngModel\" type=\"text\"\r\n            [(ngModel)]=\"Model\" name=\"{{GeneratedName}}\"\r\n            [settings]=\"Settings\" [data]=\"BoundSource\"\r\n            (onSelect)=\"changed();\" \r\n            (onDeSelect)=\"changed();\" \r\n            (onSelectAll)=\"changed();\"\r\n            (onDeSelectAll)=\"changed();\" \r\n            (onDeSelectAll)=\"Model = []; changed();\">\r\n        </angular2-multiselect>\r\n    </div>\r\n</ng-template>"]}
|
|
163
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-multiselect.component.js","sourceRoot":"","sources":["../../../../../../projects/forms-and-validations/src/lib/forms/form-multiselect/form-multiselect.component.ts","../../../../../../projects/forms-and-validations/src/lib/forms/form-multiselect/form-multiselect.component.html"],"names":[],"mappings":"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","sourcesContent":["// Angular\r\nimport { ChangeDetectionStrategy, Component, Inject, Input, Optional, Self, SimpleChanges, ViewEncapsulation } from \"@angular/core\";\r\nimport { ControlValueAccessor, NG_VALIDATORS, NgControl } from \"@angular/forms\";\r\n\r\n// Configurazioni\r\nimport { LocalizationService } from \"@esfaenza/localizations\";\r\nimport { AccessControlService, ComponentContext } from '@esfaenza/access-control';\r\nimport { ACO_CUSTOMKEY, FAV_DEBUG_MODE } from '../../tokens';\r\n\r\n// Applicazione\r\nimport { BaseFormControl } from \"../base-form-control\";\r\nimport { FormMultiSelectComponentLoc } from \"./form-multiselect.component.loc\";\r\nimport { ChangeDetectorRef } from \"@angular/core\";\r\n\r\n/**\r\n * Componente che permette di effettuare una selezione multipla fra gli oggetti passati nell'Input **Source**\r\n * \r\n * N.B: Al contrario degli altri componenti form-* questo viene tenuto con **changeDetection: ChangeDetectionStrategy.Default** in quanto il componente \r\n * utilizzato internamente (angular2-multiselect) non è stato assolutamente pensato per essere usato con **ChangeDetectionStrategy.OnPush**\r\n */\r\n@Component({\r\n    selector: \"form-multiselect\",\r\n    viewProviders: [{ provide: LocalizationService, useClass: FormMultiSelectComponentLoc }],\r\n    templateUrl: \"form-multiselect.component.html\",\r\n    styleUrls: [\"form-multiselect.component.css\"],\r\n    encapsulation: ViewEncapsulation.None,\r\n    changeDetection: ChangeDetectionStrategy.Default\r\n})\r\nexport class FormMultiSelectComponent extends BaseFormControl implements ControlValueAccessor {\r\n\r\n    /**\r\n     * Modello temporaneo **NON** compatibile in maniera diretta con il componente **angular2-multiselect** usato internamente\r\n     * \r\n     * Serve da appoggio per effettuare un re-bind qualora la sorgente cambiasse e qualora **RebindModelAfterSource** fosse true\r\n     */\r\n    private TmpModel: string | string[] | {id: string, description: string}[] = [];\r\n\r\n    /** Indica se la prossima modifica alla Source deve anche effettuare un re-bind del modello. Serve se la **BoundSource** passa da non avere oggetti ad averne */\r\n    private RebindModelAfterSource: boolean = false;\r\n\r\n    /** Permette di specificare il testo della Label flottante material-style */\r\n    @Input() SelectLabel: string = \"\";\r\n\r\n    /** Permette al componente di gestire come modello non una lista di chiavi, ma una lista di KeyValue */\r\n    @Input() UseKeyValues: boolean = false;\r\n\r\n    /** Indica al componente di emettere una lista di chiavi separate da virgola piuttosto che una lista vera e propria di chiavi/KeyValue */\r\n    @Input() UseCommaSeparatedList: boolean = false;\r\n\r\n    /** Indica se effettuare l'emit come lista di valori in un Json */\r\n    @Input() UseJsonList: boolean = false;\r\n\r\n    /** Impostazioni del componente interno **angular2-multiselect** */\r\n    public Settings: { selectAllText: string, unSelectAllText: string, text: string, enableCheckAll: boolean, disabled: boolean, labelKey: string, tagToBody: boolean } = null;\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        // Default dei settings per evitare che siano mai nulli, altrimenti il cazzo di CuppaLab salta in araia che è veramente una bellezza\r\n        this.evaluateSettings(false);\r\n    }\r\n\r\n    /** @ignore */\r\n    public async ngOnChanges(changes: SimpleChanges) {\r\n        const newSource = changes[\"Source\"];\r\n        if (newSource)\r\n        {\r\n            this.tryBindSourceDisplay();\r\n            if (this.RebindModelAfterSource) {\r\n                this.writeValue(this.TmpModel);\r\n                this.RebindModelAfterSource = false;\r\n            }\r\n        }\r\n\r\n        const readonly = changes[\"Readonly\"];\r\n        this.evaluateSettings(readonly ? readonly.currentValue ?? false : this.Readonly ?? false);\r\n    }\r\n\r\n    /**\r\n     * Scrive i nuovi settings per il componente\r\n     * \r\n     * @param {boolean} disabled Indica se il componente dev'essere disabilitato o meno\r\n     */\r\n    private evaluateSettings(disabled: boolean) {\r\n        this.Settings = {\r\n            selectAllText: this.lc.loc(\"Select everything\"),\r\n            unSelectAllText: this.lc.loc(\"Deselect everything\"),\r\n            text: this.SelectLabel || this.lc.loc(\"Select one or more values...\"),\r\n            enableCheckAll: true,\r\n            disabled: disabled,\r\n            labelKey: \"description\",\r\n            tagToBody: false\r\n        };\r\n    }\r\n\r\n    /** @ignore */\r\n    onNotNullValueSet(): void { }\r\n\r\n    /**\r\n     * Indica se il comopnente in questione è in grado di gestire ngControl nulli. \r\n     * In questo componente è normale che sia così quindi restituisce semplicemente **true**\r\n     * \r\n     * @returns {boolean} **true** se gestisco ngControl nulli, **false** altrimenti\r\n     */\r\n    handleNullNgControl(): boolean {\r\n        return true;\r\n    }\r\n\r\n    /** @ignore Override per gestire input in ingresso */\r\n    writeValue(obj: any[] | string): void {\r\n        this.TmpModel = obj;\r\n        let toPass: { id: string, description: string }[] = [];\r\n\r\n        if(this.UseCommaSeparatedList && obj && (typeof obj === 'string' || obj instanceof String))\r\n            obj = (<string>obj).split(',');\r\n\r\n        if(this.UseJsonList && obj && (typeof obj === 'string' || obj instanceof String))\r\n            obj = JSON.parse(<string>obj);\r\n\r\n        //Qui arrivano solo gli id, o {id: x, description: y} in caso sono in UseKeyValues, \r\n        //devo tirare fuori gli oggetti relativi e piazzarli come lista per il Model\r\n        if (obj && obj.length > 0) {\r\n            (<any[]>obj).forEach(t => {\r\n                let item = this.BoundSource.find(o => o.id == (this.UseKeyValues ? t.id : t));\r\n                if (item)\r\n                    toPass.push(JSON.parse(JSON.stringify(item)));\r\n                else if (!this.BoundSource || this.BoundSource.length == 0)\r\n                    this.RebindModelAfterSource = true;\r\n            });\r\n        }\r\n\r\n        this.EvaluatedModel = toPass.map(t => t.description).join(', ');\r\n        super.writeValue(toPass);\r\n    }\r\n\r\n    /** @ignore Override per gestire input in uscita */\r\n    changed() {\r\n        let toEmit = null;\r\n        if (this.UseJsonList)\r\n            toEmit = JSON.stringify((<any[]>this.Model).map(m => m.id));\r\n        else if (!this.UseKeyValues && !this.UseCommaSeparatedList)\r\n            toEmit = (<any[]>this.Model).map(m => m.id);\r\n        else if (this.UseKeyValues)\r\n            toEmit = (<any[]>this.Model).map(m => ({ id: m.id, description: m.description }));\r\n        else if (this.UseCommaSeparatedList)\r\n            toEmit = (<any[]>this.Model).map(m => m.id).join(',');\r\n\r\n        this.EvaluatedModel = this.Model.map(t => t.itemName).join(', ');\r\n        super.changed(toEmit, false, true);\r\n        super.finalized();\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\r\n<ng-template #controlTemplate>\r\n    <div [class.ms-placeholder]=\"!Model || Model.length == 0\" (click)=\"focused($event)\">\r\n        <angular2-multiselect #validationControl=\"ngModel\" type=\"text\"\r\n            [(ngModel)]=\"Model\" name=\"{{GeneratedName}}\"\r\n            [settings]=\"Settings\" [data]=\"BoundSource\"\r\n            (onSelect)=\"changed();\" \r\n            (onDeSelect)=\"changed();\" \r\n            (onSelectAll)=\"changed();\"\r\n            (onDeSelectAll)=\"changed();\" \r\n            (onDeSelectAll)=\"Model = []; changed();\">\r\n        </angular2-multiselect>\r\n    </div>\r\n</ng-template>"]}
|
|
@@ -3593,14 +3593,14 @@ class FormMultiSelectComponent extends BaseFormControl {
|
|
|
3593
3593
|
/** @ignore Override per gestire input in uscita */
|
|
3594
3594
|
changed() {
|
|
3595
3595
|
let toEmit = null;
|
|
3596
|
-
if (
|
|
3596
|
+
if (this.UseJsonList)
|
|
3597
|
+
toEmit = JSON.stringify(this.Model.map(m => m.id));
|
|
3598
|
+
else if (!this.UseKeyValues && !this.UseCommaSeparatedList)
|
|
3597
3599
|
toEmit = this.Model.map(m => m.id);
|
|
3598
3600
|
else if (this.UseKeyValues)
|
|
3599
3601
|
toEmit = this.Model.map(m => ({ id: m.id, description: m.description }));
|
|
3600
3602
|
else if (this.UseCommaSeparatedList)
|
|
3601
3603
|
toEmit = this.Model.map(m => m.id).join(',');
|
|
3602
|
-
else if (this.UseJsonList)
|
|
3603
|
-
toEmit = JSON.stringify(this.Model.map(m => m.id));
|
|
3604
3604
|
this.EvaluatedModel = this.Model.map(t => t.itemName).join(', ');
|
|
3605
3605
|
super.changed(toEmit, false, true);
|
|
3606
3606
|
super.finalized();
|