@ecodev/natural 45.4.2 → 46.0.0

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.
Files changed (74) hide show
  1. package/esm2020/lib/classes/abstract-controller.mjs +2 -2
  2. package/esm2020/lib/classes/abstract-detail.mjs +10 -3
  3. package/esm2020/lib/classes/abstract-list.mjs +1 -1
  4. package/esm2020/lib/classes/abstract-navigable-list.mjs +1 -1
  5. package/esm2020/lib/classes/rxjs.mjs +1 -1
  6. package/esm2020/lib/classes/validators.mjs +2 -2
  7. package/esm2020/lib/modules/avatar/service/avatar.service.mjs +2 -2
  8. package/esm2020/lib/modules/avatar/service/md5.mjs +4 -4
  9. package/esm2020/lib/modules/columns-picker/columns-picker-column.directive.mjs +1 -1
  10. package/esm2020/lib/modules/common/pipes/swiss-date.pipe.mjs +1 -1
  11. package/esm2020/lib/modules/dropdown-components/type-date/type-date.component.mjs +67 -34
  12. package/esm2020/lib/modules/dropdown-components/type-date-range/type-date-range.component.mjs +4 -4
  13. package/esm2020/lib/modules/dropdown-components/type-hierarchic-selector/type-hierarchic-selector.component.mjs +1 -1
  14. package/esm2020/lib/modules/dropdown-components/type-text/type-text.component.mjs +2 -2
  15. package/esm2020/lib/modules/file/abstract-file.mjs +2 -2
  16. package/esm2020/lib/modules/file/component/file.component.mjs +32 -24
  17. package/esm2020/lib/modules/file/file-drop.directive.mjs +1 -1
  18. package/esm2020/lib/modules/file/file-select.directive.mjs +1 -1
  19. package/esm2020/lib/modules/fixed-button/fixed-button.component.mjs +2 -2
  20. package/esm2020/lib/modules/hierarchic-selector/classes/hierarchic-filters-configuration.mjs +1 -1
  21. package/esm2020/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.service.mjs +1 -1
  22. package/esm2020/lib/modules/logger/error-handler.mjs +1 -1
  23. package/esm2020/lib/modules/panels/fallback-if-no-opened-panels.urlmatcher.mjs +2 -2
  24. package/esm2020/lib/modules/panels/panels.service.mjs +2 -2
  25. package/esm2020/lib/modules/panels/types.mjs +1 -1
  26. package/esm2020/lib/modules/relations/relations.component.mjs +2 -2
  27. package/esm2020/lib/modules/search/classes/graphql-doctrine.mjs +11 -5
  28. package/esm2020/lib/modules/search/classes/transformers.mjs +51 -1
  29. package/esm2020/lib/modules/search/input/input.component.mjs +4 -4
  30. package/esm2020/lib/modules/search/public-api.mjs +2 -2
  31. package/esm2020/lib/modules/search/search/search.component.mjs +2 -2
  32. package/esm2020/lib/modules/search/types/facet.mjs +1 -1
  33. package/esm2020/lib/modules/search/types/values.mjs +1 -1
  34. package/esm2020/lib/modules/select/abstract-select.component.mjs +2 -2
  35. package/esm2020/lib/modules/select/select/select.component.mjs +1 -1
  36. package/esm2020/lib/modules/select/select-enum/select-enum.component.mjs +1 -2
  37. package/esm2020/lib/modules/select/select-hierarchic/select-hierarchic.component.mjs +1 -1
  38. package/esm2020/lib/modules/sidenav/sidenav/sidenav.component.mjs +2 -3
  39. package/esm2020/lib/modules/sidenav/sidenav-content/sidenav-content.component.mjs +2 -3
  40. package/esm2020/lib/modules/sidenav/sidenav.service.mjs +1 -1
  41. package/esm2020/lib/modules/table-button/table-button.component.mjs +2 -2
  42. package/esm2020/lib/services/abstract-model.service.mjs +8 -1
  43. package/esm2020/lib/services/debounce.service.mjs +1 -1
  44. package/esm2020/lib/services/persistence.service.mjs +4 -2
  45. package/esm2020/lib/services/swiss-parsing-date-adapter.service.mjs +1 -1
  46. package/fesm2015/ecodev-natural.mjs +1299 -1194
  47. package/fesm2015/ecodev-natural.mjs.map +1 -1
  48. package/fesm2020/ecodev-natural.mjs +712 -609
  49. package/fesm2020/ecodev-natural.mjs.map +1 -1
  50. package/lib/classes/abstract-controller.d.ts +0 -1
  51. package/lib/modules/avatar/service/avatar.service.d.ts +0 -1
  52. package/lib/modules/dropdown-components/type-date/type-date.component.d.ts +6 -2
  53. package/lib/modules/dropdown-components/type-date-range/type-date-range.component.d.ts +1 -1
  54. package/lib/modules/dropdown-components/type-hierarchic-selector/type-hierarchic-selector.component.d.ts +1 -2
  55. package/lib/modules/dropdown-components/type-text/type-text.component.d.ts +2 -2
  56. package/lib/modules/file/abstract-file.d.ts +1 -1
  57. package/lib/modules/file/component/file.component.d.ts +32 -9
  58. package/lib/modules/fixed-button/fixed-button.component.d.ts +0 -1
  59. package/lib/modules/hierarchic-selector/classes/hierarchic-filters-configuration.d.ts +1 -2
  60. package/lib/modules/panels/types.d.ts +1 -2
  61. package/lib/modules/relations/relations.component.d.ts +2 -2
  62. package/lib/modules/search/classes/transformers.d.ts +15 -0
  63. package/lib/modules/search/input/input.component.d.ts +6 -5
  64. package/lib/modules/search/public-api.d.ts +1 -1
  65. package/lib/modules/search/search/search.component.d.ts +2 -2
  66. package/lib/modules/search/types/facet.d.ts +1 -2
  67. package/lib/modules/search/types/values.d.ts +2 -4
  68. package/lib/modules/select/abstract-select.component.d.ts +2 -2
  69. package/lib/modules/select/select-enum/select-enum.component.d.ts +0 -1
  70. package/lib/modules/sidenav/sidenav/sidenav.component.d.ts +0 -1
  71. package/lib/modules/sidenav/sidenav-content/sidenav-content.component.d.ts +0 -1
  72. package/lib/modules/table-button/table-button.component.d.ts +2 -2
  73. package/lib/services/debounce.service.d.ts +1 -1
  74. package/package.json +1 -1
@@ -204,4 +204,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImpor
204
204
  }], disabled: [{
205
205
  type: Input
206
206
  }] } });
207
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/select/select/select.component.ts","../../../../../../../projects/natural/src/lib/modules/select/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Component, ContentChild, Input, OnDestroy, OnInit, TemplateRef, ViewChild} from '@angular/core';\nimport {ControlValueAccessor} from '@angular/forms';\nimport {MatAutocompleteTrigger} from '@angular/material/autocomplete';\nimport {merge} from 'lodash-es';\nimport {Observable} from 'rxjs';\nimport {debounceTime, distinctUntilChanged, finalize, map, takeUntil} from 'rxjs/operators';\nimport {PaginatedData} from '../../../classes/data-source';\nimport {NaturalQueryVariablesManager, QueryVariables} from '../../../classes/query-variable-manager';\nimport {NaturalAbstractModelService} from '../../../services/abstract-model.service';\nimport {ExtractTallOne, ExtractVall, Literal} from '../../../types/types';\nimport {AbstractSelect} from '../abstract-select.component';\n\ntype V<TService> = string | ExtractTallOne<TService>;\n\n/**\n * Default usage:\n * <natural-select [service]=\"amazingServiceInstance\" [(model)]=\"amazingModel\" (modelChange)=amazingChangeFn($event)></natural-select>\n *\n * Custom template usage :\n * <natural-select [service]=\"svc\" [(ngModel)]=\"model\">\n *     <ng-template let-item=\"item\">\n *         <span>{{ item.xxx }}</span>\n *     </ng-template>\n * </natural-select>\n *\n * [(ngModel)] and (ngModelChange) are optional\n *\n * Placeholder :\n * <natural-select placeholder=\"amazing placeholder\">\n *\n * Never float placeholder :\n * <natural-select placeholder=\"amazing placeholder\" floatPlaceholder=\"never\">\n *\n * Search with like %xxx% on specified attribute name instead of custom filter on whole object\n * <natural-select [searchField]=\"string\">\n *\n * Allows to input free string without selecting an option from autocomplete suggestions\n * <natural-select [optionRequired]=\"false\">\n */\n@Component({\n    selector: 'natural-select',\n    templateUrl: './select.component.html',\n    styleUrls: ['./select.component.scss'],\n})\nexport class NaturalSelectComponent<\n        TService extends NaturalAbstractModelService<\n            any,\n            any,\n            PaginatedData<Literal>,\n            QueryVariables,\n            any,\n            any,\n            any,\n            any,\n            any,\n            any\n        >,\n    >\n    extends AbstractSelect<V<TService>, V<TService>>\n    implements OnInit, OnDestroy, ControlValueAccessor, AfterViewInit\n{\n    @ViewChild(MatAutocompleteTrigger) public autoTrigger!: MatAutocompleteTrigger;\n    @ContentChild(TemplateRef) public itemTemplate?: TemplateRef<any>;\n\n    /**\n     * Service with watchAll function that accepts queryVariables.\n     */\n    @Input() public service!: TService;\n\n    /**\n     * If false, allows to input free string without selecting an option from autocomplete suggestions\n     */\n    @Input() public optionRequired = true;\n\n    /**\n     * The filter attribute to bind when searching for a term\n     */\n    @Input() public searchField: 'custom' | string = 'custom';\n\n    /**\n     * Additional filter for query\n     */\n    @Input()\n    public set filter(filter: ExtractVall<TService>['filter'] | null | undefined) {\n        this.variablesManager.set('additional-filter', {filter: filter});\n    }\n\n    /**\n     * Items returned by server to show in listing\n     */\n    public items: null | Observable<readonly any[]> = null;\n\n    /**\n     * Whether a we are searching something\n     */\n    public loading = false;\n\n    /**\n     * Number of items not shown in result list\n     * Shows a message after list if positive\n     */\n    public moreNbItems = 0;\n\n    /**\n     * Default page size\n     */\n    private pageSize = 10;\n\n    /**\n     * Init search options\n     */\n    private variablesManager = new NaturalQueryVariablesManager<QueryVariables>();\n\n    /**\n     * Whether the value can be changed\n     */\n    @Input()\n    public set disabled(disabled: boolean) {\n        disabled ? this.internalCtrl.disable() : this.internalCtrl.enable();\n    }\n\n    public ngAfterViewInit(): void {\n        this.internalCtrl.valueChanges\n            .pipe(takeUntil(this.ngUnsubscribe), distinctUntilChanged(), debounceTime(300))\n            .subscribe(val => this.search(val));\n    }\n\n    public onInternalFormChange(): void {\n        // If we allow free string typing, then we propagate it as it is being typed\n        if (!this.optionRequired) {\n            this.propagateValue(this.internalCtrl.value);\n        }\n    }\n\n    public ngOnInit(): void {\n        super.ngOnInit();\n        this.initService();\n    }\n\n    private initService(): void {\n        // Assert given service has a watchAll function\n        if (typeof this.service.watchAll !== 'function') {\n            throw new TypeError('Provided service does not contain watchAll function');\n        }\n\n        const defaultPagination = {\n            pagination: {\n                pageIndex: 0,\n                pageSize: this.pageSize,\n            },\n        };\n\n        const variables = merge(defaultPagination, this.getSearchFilter(null));\n        this.variablesManager.set('variables', variables);\n    }\n\n    public startSearch(): void {\n        // Start search only once\n        if (this.items) {\n            return;\n        }\n\n        // Init query, and when query results arrive, finish loading, and count items\n        this.items = this.service.watchAll(this.variablesManager).pipe(\n            takeUntil(this.ngUnsubscribe),\n            finalize(() => (this.loading = false)),\n            map(data => {\n                this.loading = false;\n                const nbTotal = data.length;\n                const nbListed = Math.min(data.length, this.pageSize);\n                this.moreNbItems = nbTotal - nbListed;\n\n                return data.items;\n            }),\n        );\n\n        this.loading = true;\n        this.items.subscribe();\n    }\n\n    public propagateValue(value: V<TService> | null): void {\n        this.loading = false;\n\n        // If we cleared value via button, but we allow free string typing, then force to empty string\n        if (!this.optionRequired && value === null) {\n            value = '';\n        }\n\n        super.propagateValue(value);\n    }\n\n    /**\n     * Very important to return something, above all if [select]='displayedValue' attribute value is used\n     */\n    public getDisplayFn(): (item: V<TService> | null) => string {\n        if (this.displayWith) {\n            return this.displayWith;\n        }\n\n        return (item: any) => {\n            if (!item) {\n                return '';\n            }\n\n            if (typeof item === 'string') {\n                return item;\n            }\n\n            return item.fullName || item.name || item.iban || item[this.searchField] || item.id;\n        };\n    }\n\n    public clear(emitEvent = true): void {\n        this.search(null);\n        super.clear(emitEvent);\n    }\n\n    public search(term: V<TService> | null): void {\n        if (typeof term === 'string' || term === null) {\n            if (term) {\n                this.loading = !!this.items;\n            }\n\n            this.variablesManager.merge('variables', this.getSearchFilter(term as string | null));\n        }\n    }\n\n    public showClearButton(): boolean {\n        return this.internalCtrl?.enabled && !!this.clearLabel && !!this.internalCtrl.value;\n    }\n\n    private getSearchFilter(term: string | null): QueryVariables {\n        let field: Literal = {};\n\n        if (this.searchField === 'custom') {\n            field = {custom: term ? {search: {value: term}} : null};\n        } else if (term) {\n            field[this.searchField] = {like: {value: '%' + term + '%'}};\n        }\n\n        return {filter: {groups: [{conditions: [field]}]}};\n    }\n}\n","<!-- Autocomplete menu -->\n<mat-autocomplete\n    #ac=\"matAutocomplete\"\n    (optionSelected)=\"propagateValue($event.option.value)\"\n    [displayWith]=\"getDisplayFn()\"\n    panelWidth=\"auto !important\"\n>\n    <mat-option *ngFor=\"let item of items | async\" [value]=\"item\">\n        <ng-template\n            [ngTemplateOutletContext]=\"{item: item}\"\n            [ngTemplateOutlet]=\"itemTemplate ? itemTemplate : defaultACItem\"\n        ></ng-template>\n    </mat-option>\n    <div *ngIf=\"moreNbItems > 0\" class=\"mat-caption\" i18n style=\"padding: 5px 10px\"\n        >{{ moreNbItems }} élément(s) supplémentaire(s)</div\n    >\n</mat-autocomplete>\n\n<ng-template #defaultACItem let-item=\"item\">\n    <span>{{ getDisplayFn()(item) }}</span>\n</ng-template>\n\n<!-- Input for autocomplete -->\n<mat-form-field [floatLabel]=\"floatPlaceholder\">\n    <mat-label>{{ placeholder }}</mat-label>\n\n    <input\n        (blur)=\"touch(); blur.emit()\"\n        (change)=\"onInternalFormChange()\"\n        (click)=\"autoTrigger.openPanel()\"\n        (focus)=\"startSearch()\"\n        (keydown.esc)=\"clear()\"\n        [formControl]=\"internalCtrl\"\n        [matAutocomplete]=\"ac\"\n        aria-label=\"Recherche et sélection\"\n        i18n-aria-label\n        matInput\n        [errorStateMatcher]=\"matcher\"\n    />\n\n    <!-- Meta data -->\n    <natural-icon *ngIf=\"!loading && showIcon\" [name]=\"icon\" matPrefix></natural-icon>\n    <mat-progress-spinner\n        *ngIf=\"loading\"\n        [diameter]=\"21\"\n        [strokeWidth]=\"5\"\n        matPrefix\n        mode=\"indeterminate\"\n    ></mat-progress-spinner>\n\n    <!-- Clear button -->\n    <div class=\"suffix-buttons\" matSuffix>\n        <button\n            (click)=\"clear(); $event.stopPropagation()\"\n            *ngIf=\"internalCtrl.value && internalCtrl.enabled && !clearLabel\"\n            mat-icon-button\n            i18n-matTooltip\n            matTooltip=\"Désélectionner\"\n        >\n            <natural-icon name=\"close\"></natural-icon>\n        </button>\n        <button\n            *ngIf=\"internalCtrl.value && navigateTo\"\n            [routerLink]=\"navigateTo\"\n            (click)=\"$event.stopPropagation()\"\n            mat-button\n            mat-icon-button\n            i18n-matTooltip\n            matTooltip=\"Naviguer vers\"\n        >\n            <natural-icon name=\"open_in_browser\"></natural-icon>\n        </button>\n    </div>\n\n    <mat-error *ngIf=\"hasRequiredError()\" i18n>Ce champ est requis</mat-error>\n</mat-form-field>\n\n<!-- Additional (un)select/(un)link buttons for more visual cohesion with natural-relations --><!-- [clearLabel] and/or [selectLabel] has to be given as attribute input -->\n<div *ngIf=\"showClearButton()\" class=\"external-buttons\">\n    <button (click)=\"clear()\" *ngIf=\"showClearButton()\" color=\"warn\" mat-button>{{ clearLabel }}</button>\n</div>\n"]}
207
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/select/select/select.component.ts","../../../../../../../projects/natural/src/lib/modules/select/select/select.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAgB,SAAS,EAAE,YAAY,EAAE,KAAK,EAAqB,WAAW,EAAE,SAAS,EAAC,MAAM,eAAe,CAAC;AAEvH,OAAO,EAAC,sBAAsB,EAAC,MAAM,gCAAgC,CAAC;AACtE,OAAO,EAAC,KAAK,EAAC,MAAM,WAAW,CAAC;AAEhC,OAAO,EAAC,YAAY,EAAE,oBAAoB,EAAE,QAAQ,EAAE,GAAG,EAAE,SAAS,EAAC,MAAM,gBAAgB,CAAC;AAE5F,OAAO,EAAC,4BAA4B,EAAiB,MAAM,yCAAyC,CAAC;AAGrG,OAAO,EAAC,cAAc,EAAC,MAAM,8BAA8B,CAAC;;;;;;;;;;;;;AAI5D;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AAMH,MAAM,OAAO,sBAcT,SAAQ,cAAwC;IAnBpD;;QA8BI;;WAEG;QACa,mBAAc,GAAG,IAAI,CAAC;QAEtC;;WAEG;QACa,gBAAW,GAAsB,QAAQ,CAAC;QAU1D;;WAEG;QACI,UAAK,GAAsC,IAAI,CAAC;QAEvD;;WAEG;QACI,YAAO,GAAG,KAAK,CAAC;QAEvB;;;WAGG;QACI,gBAAW,GAAG,CAAC,CAAC;QAEvB;;WAEG;QACK,aAAQ,GAAG,EAAE,CAAC;QAEtB;;WAEG;QACK,qBAAgB,GAAG,IAAI,4BAA4B,EAAkB,CAAC;KAmIjF;IAnKG;;OAEG;IACH,IACW,MAAM,CAAC,MAA0D;QACxE,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,mBAAmB,EAAE,EAAC,MAAM,EAAE,MAAM,EAAC,CAAC,CAAC;IACrE,CAAC;IA4BD;;OAEG;IACH,IACoB,QAAQ,CAAC,QAAiB;QAC1C,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC;IACxE,CAAC;IAEM,eAAe;QAClB,IAAI,CAAC,YAAY,CAAC,YAAY;aACzB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,EAAE,oBAAoB,EAAE,EAAE,YAAY,CAAC,GAAG,CAAC,CAAC;aAC9E,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;IAC5C,CAAC;IAEM,oBAAoB;QACvB,4EAA4E;QAC5E,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE;YACtB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;SAChD;IACL,CAAC;IAEe,QAAQ;QACpB,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,IAAI,CAAC,WAAW,EAAE,CAAC;IACvB,CAAC;IAEO,WAAW;QACf,+CAA+C;QAC/C,IAAI,OAAO,IAAI,CAAC,OAAO,CAAC,QAAQ,KAAK,UAAU,EAAE;YAC7C,MAAM,IAAI,SAAS,CAAC,qDAAqD,CAAC,CAAC;SAC9E;QAED,MAAM,iBAAiB,GAAG;YACtB,UAAU,EAAE;gBACR,SAAS,EAAE,CAAC;gBACZ,QAAQ,EAAE,IAAI,CAAC,QAAQ;aAC1B;SACJ,CAAC;QAEF,MAAM,SAAS,GAAG,KAAK,CAAC,iBAAiB,EAAE,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC;QACvE,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC;IACtD,CAAC;IAEM,WAAW;QACd,yBAAyB;QACzB,IAAI,IAAI,CAAC,KAAK,EAAE;YACZ,OAAO;SACV;QAED,6EAA6E;QAC7E,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,IAAI,CAC1D,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,EAC7B,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,CAAC,EACtC,GAAG,CAAC,IAAI,CAAC,EAAE;YACP,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACrB,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC;YAC5B,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;YACtD,IAAI,CAAC,WAAW,GAAG,OAAO,GAAG,QAAQ,CAAC;YAEtC,OAAO,IAAI,CAAC,KAAK,CAAC;QACtB,CAAC,CAAC,CACL,CAAC;QAEF,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,CAAC;IAC3B,CAAC;IAEe,cAAc,CAAC,KAAyB;QACpD,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QAErB,8FAA8F;QAC9F,IAAI,CAAC,IAAI,CAAC,cAAc,IAAI,KAAK,KAAK,IAAI,EAAE;YACxC,KAAK,GAAG,EAAE,CAAC;SACd;QAED,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;IAED;;OAEG;IACI,YAAY;QACf,IAAI,IAAI,CAAC,WAAW,EAAE;YAClB,OAAO,IAAI,CAAC,WAAW,CAAC;SAC3B;QAED,OAAO,CAAC,IAAS,EAAE,EAAE;YACjB,IAAI,CAAC,IAAI,EAAE;gBACP,OAAO,EAAE,CAAC;aACb;YAED,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE;gBAC1B,OAAO,IAAI,CAAC;aACf;YAED,OAAO,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,IAAI,CAAC,EAAE,CAAC;QACxF,CAAC,CAAC;IACN,CAAC;IAEe,KAAK,CAAC,SAAS,GAAG,IAAI;QAClC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAClB,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;IAC3B,CAAC;IAEM,MAAM,CAAC,IAAwB;QAClC,IAAI,OAAO,IAAI,KAAK,QAAQ,IAAI,IAAI,KAAK,IAAI,EAAE;YAC3C,IAAI,IAAI,EAAE;gBACN,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC;aAC/B;YAED,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,WAAW,EAAE,IAAI,CAAC,eAAe,CAAC,IAAqB,CAAC,CAAC,CAAC;SACzF;IACL,CAAC;IAEe,eAAe;QAC3B,OAAO,IAAI,CAAC,YAAY,EAAE,OAAO,IAAI,CAAC,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC;IACxF,CAAC;IAEO,eAAe,CAAC,IAAmB;QACvC,IAAI,KAAK,GAAY,EAAE,CAAC;QAExB,IAAI,IAAI,CAAC,WAAW,KAAK,QAAQ,EAAE;YAC/B,KAAK,GAAG,EAAC,MAAM,EAAE,IAAI,CAAC,CAAC,CAAC,EAAC,MAAM,EAAE,EAAC,KAAK,EAAE,IAAI,EAAC,EAAC,CAAC,CAAC,CAAC,IAAI,EAAC,CAAC;SAC3D;aAAM,IAAI,IAAI,EAAE;YACb,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,EAAC,IAAI,EAAE,EAAC,KAAK,EAAE,GAAG,GAAG,IAAI,GAAG,GAAG,EAAC,EAAC,CAAC;SAC/D;QAED,OAAO,EAAC,MAAM,EAAE,EAAC,MAAM,EAAE,CAAC,EAAC,UAAU,EAAE,CAAC,KAAK,CAAC,EAAC,CAAC,EAAC,EAAC,CAAC;IACvD,CAAC;;mHArMQ,sBAAsB;uGAAtB,sBAAsB,sOAkBjB,WAAW,6FADd,sBAAsB,uEC7DrC,o5FAiFA;2FDrCa,sBAAsB;kBALlC,SAAS;+BACI,gBAAgB;8BAqBgB,WAAW;sBAApD,SAAS;uBAAC,sBAAsB;gBACC,YAAY;sBAA7C,YAAY;uBAAC,WAAW;gBAKT,OAAO;sBAAtB,KAAK;gBAKU,cAAc;sBAA7B,KAAK;gBAKU,WAAW;sBAA1B,KAAK;gBAMK,MAAM;sBADhB,KAAK;gBAmCc,QAAQ;sBAD3B,KAAK","sourcesContent":["import {AfterViewInit, Component, ContentChild, Input, OnDestroy, OnInit, TemplateRef, ViewChild} from '@angular/core';\nimport {ControlValueAccessor} from '@angular/forms';\nimport {MatAutocompleteTrigger} from '@angular/material/autocomplete';\nimport {merge} from 'lodash-es';\nimport {Observable} from 'rxjs';\nimport {debounceTime, distinctUntilChanged, finalize, map, takeUntil} from 'rxjs/operators';\nimport {PaginatedData} from '../../../classes/data-source';\nimport {NaturalQueryVariablesManager, QueryVariables} from '../../../classes/query-variable-manager';\nimport {NaturalAbstractModelService} from '../../../services/abstract-model.service';\nimport {ExtractTallOne, ExtractVall, Literal} from '../../../types/types';\nimport {AbstractSelect} from '../abstract-select.component';\n\ntype V<TService> = string | ExtractTallOne<TService>;\n\n/**\n * Default usage:\n * <natural-select [service]=\"amazingServiceInstance\" [(model)]=\"amazingModel\" (modelChange)=amazingChangeFn($event)></natural-select>\n *\n * Custom template usage :\n * <natural-select [service]=\"svc\" [(ngModel)]=\"model\">\n *     <ng-template let-item=\"item\">\n *         <span>{{ item.xxx }}</span>\n *     </ng-template>\n * </natural-select>\n *\n * [(ngModel)] and (ngModelChange) are optional\n *\n * Placeholder :\n * <natural-select placeholder=\"amazing placeholder\">\n *\n * Never float placeholder :\n * <natural-select placeholder=\"amazing placeholder\" floatPlaceholder=\"never\">\n *\n * Search with like %xxx% on specified attribute name instead of custom filter on whole object\n * <natural-select [searchField]=\"string\">\n *\n * Allows to input free string without selecting an option from autocomplete suggestions\n * <natural-select [optionRequired]=\"false\">\n */\n@Component({\n    selector: 'natural-select',\n    templateUrl: './select.component.html',\n    styleUrls: ['./select.component.scss'],\n})\nexport class NaturalSelectComponent<\n        TService extends NaturalAbstractModelService<\n            any,\n            any,\n            PaginatedData<Literal>,\n            QueryVariables,\n            any,\n            any,\n            any,\n            any,\n            any,\n            any\n        >,\n    >\n    extends AbstractSelect<V<TService>, V<TService>>\n    implements OnInit, OnDestroy, ControlValueAccessor, AfterViewInit\n{\n    @ViewChild(MatAutocompleteTrigger) public autoTrigger!: MatAutocompleteTrigger;\n    @ContentChild(TemplateRef) public itemTemplate?: TemplateRef<any>;\n\n    /**\n     * Service with watchAll function that accepts queryVariables.\n     */\n    @Input() public service!: TService;\n\n    /**\n     * If false, allows to input free string without selecting an option from autocomplete suggestions\n     */\n    @Input() public optionRequired = true;\n\n    /**\n     * The filter attribute to bind when searching for a term\n     */\n    @Input() public searchField: 'custom' | string = 'custom';\n\n    /**\n     * Additional filter for query\n     */\n    @Input()\n    public set filter(filter: ExtractVall<TService>['filter'] | null | undefined) {\n        this.variablesManager.set('additional-filter', {filter: filter});\n    }\n\n    /**\n     * Items returned by server to show in listing\n     */\n    public items: null | Observable<readonly any[]> = null;\n\n    /**\n     * Whether a we are searching something\n     */\n    public loading = false;\n\n    /**\n     * Number of items not shown in result list\n     * Shows a message after list if positive\n     */\n    public moreNbItems = 0;\n\n    /**\n     * Default page size\n     */\n    private pageSize = 10;\n\n    /**\n     * Init search options\n     */\n    private variablesManager = new NaturalQueryVariablesManager<QueryVariables>();\n\n    /**\n     * Whether the value can be changed\n     */\n    @Input()\n    public override set disabled(disabled: boolean) {\n        disabled ? this.internalCtrl.disable() : this.internalCtrl.enable();\n    }\n\n    public ngAfterViewInit(): void {\n        this.internalCtrl.valueChanges\n            .pipe(takeUntil(this.ngUnsubscribe), distinctUntilChanged(), debounceTime(300))\n            .subscribe(val => this.search(val));\n    }\n\n    public onInternalFormChange(): void {\n        // If we allow free string typing, then we propagate it as it is being typed\n        if (!this.optionRequired) {\n            this.propagateValue(this.internalCtrl.value);\n        }\n    }\n\n    public override ngOnInit(): void {\n        super.ngOnInit();\n        this.initService();\n    }\n\n    private initService(): void {\n        // Assert given service has a watchAll function\n        if (typeof this.service.watchAll !== 'function') {\n            throw new TypeError('Provided service does not contain watchAll function');\n        }\n\n        const defaultPagination = {\n            pagination: {\n                pageIndex: 0,\n                pageSize: this.pageSize,\n            },\n        };\n\n        const variables = merge(defaultPagination, this.getSearchFilter(null));\n        this.variablesManager.set('variables', variables);\n    }\n\n    public startSearch(): void {\n        // Start search only once\n        if (this.items) {\n            return;\n        }\n\n        // Init query, and when query results arrive, finish loading, and count items\n        this.items = this.service.watchAll(this.variablesManager).pipe(\n            takeUntil(this.ngUnsubscribe),\n            finalize(() => (this.loading = false)),\n            map(data => {\n                this.loading = false;\n                const nbTotal = data.length;\n                const nbListed = Math.min(data.length, this.pageSize);\n                this.moreNbItems = nbTotal - nbListed;\n\n                return data.items;\n            }),\n        );\n\n        this.loading = true;\n        this.items.subscribe();\n    }\n\n    public override propagateValue(value: V<TService> | null): void {\n        this.loading = false;\n\n        // If we cleared value via button, but we allow free string typing, then force to empty string\n        if (!this.optionRequired && value === null) {\n            value = '';\n        }\n\n        super.propagateValue(value);\n    }\n\n    /**\n     * Very important to return something, above all if [select]='displayedValue' attribute value is used\n     */\n    public getDisplayFn(): (item: V<TService> | null) => string {\n        if (this.displayWith) {\n            return this.displayWith;\n        }\n\n        return (item: any) => {\n            if (!item) {\n                return '';\n            }\n\n            if (typeof item === 'string') {\n                return item;\n            }\n\n            return item.fullName || item.name || item.iban || item[this.searchField] || item.id;\n        };\n    }\n\n    public override clear(emitEvent = true): void {\n        this.search(null);\n        super.clear(emitEvent);\n    }\n\n    public search(term: V<TService> | null): void {\n        if (typeof term === 'string' || term === null) {\n            if (term) {\n                this.loading = !!this.items;\n            }\n\n            this.variablesManager.merge('variables', this.getSearchFilter(term as string | null));\n        }\n    }\n\n    public override showClearButton(): boolean {\n        return this.internalCtrl?.enabled && !!this.clearLabel && !!this.internalCtrl.value;\n    }\n\n    private getSearchFilter(term: string | null): QueryVariables {\n        let field: Literal = {};\n\n        if (this.searchField === 'custom') {\n            field = {custom: term ? {search: {value: term}} : null};\n        } else if (term) {\n            field[this.searchField] = {like: {value: '%' + term + '%'}};\n        }\n\n        return {filter: {groups: [{conditions: [field]}]}};\n    }\n}\n","<!-- Autocomplete menu -->\n<mat-autocomplete\n    #ac=\"matAutocomplete\"\n    (optionSelected)=\"propagateValue($event.option.value)\"\n    [displayWith]=\"getDisplayFn()\"\n    panelWidth=\"auto !important\"\n>\n    <mat-option *ngFor=\"let item of items | async\" [value]=\"item\">\n        <ng-template\n            [ngTemplateOutletContext]=\"{item: item}\"\n            [ngTemplateOutlet]=\"itemTemplate ? itemTemplate : defaultACItem\"\n        ></ng-template>\n    </mat-option>\n    <div *ngIf=\"moreNbItems > 0\" class=\"mat-caption\" i18n style=\"padding: 5px 10px\"\n        >{{ moreNbItems }} élément(s) supplémentaire(s)</div\n    >\n</mat-autocomplete>\n\n<ng-template #defaultACItem let-item=\"item\">\n    <span>{{ getDisplayFn()(item) }}</span>\n</ng-template>\n\n<!-- Input for autocomplete -->\n<mat-form-field [floatLabel]=\"floatPlaceholder\">\n    <mat-label>{{ placeholder }}</mat-label>\n\n    <input\n        (blur)=\"touch(); blur.emit()\"\n        (change)=\"onInternalFormChange()\"\n        (click)=\"autoTrigger.openPanel()\"\n        (focus)=\"startSearch()\"\n        (keydown.esc)=\"clear()\"\n        [formControl]=\"internalCtrl\"\n        [matAutocomplete]=\"ac\"\n        aria-label=\"Recherche et sélection\"\n        i18n-aria-label\n        matInput\n        [errorStateMatcher]=\"matcher\"\n    />\n\n    <!-- Meta data -->\n    <natural-icon *ngIf=\"!loading && showIcon\" [name]=\"icon\" matPrefix></natural-icon>\n    <mat-progress-spinner\n        *ngIf=\"loading\"\n        [diameter]=\"21\"\n        [strokeWidth]=\"5\"\n        matPrefix\n        mode=\"indeterminate\"\n    ></mat-progress-spinner>\n\n    <!-- Clear button -->\n    <div class=\"suffix-buttons\" matSuffix>\n        <button\n            (click)=\"clear(); $event.stopPropagation()\"\n            *ngIf=\"internalCtrl.value && internalCtrl.enabled && !clearLabel\"\n            mat-icon-button\n            i18n-matTooltip\n            matTooltip=\"Désélectionner\"\n        >\n            <natural-icon name=\"close\"></natural-icon>\n        </button>\n        <button\n            *ngIf=\"internalCtrl.value && navigateTo\"\n            [routerLink]=\"navigateTo\"\n            (click)=\"$event.stopPropagation()\"\n            mat-button\n            mat-icon-button\n            i18n-matTooltip\n            matTooltip=\"Naviguer vers\"\n        >\n            <natural-icon name=\"open_in_browser\"></natural-icon>\n        </button>\n    </div>\n\n    <mat-error *ngIf=\"hasRequiredError()\" i18n>Ce champ est requis</mat-error>\n</mat-form-field>\n\n<!-- Additional (un)select/(un)link buttons for more visual cohesion with natural-relations --><!-- [clearLabel] and/or [selectLabel] has to be given as attribute input -->\n<div *ngIf=\"showClearButton()\" class=\"external-buttons\">\n    <button (click)=\"clear()\" *ngIf=\"showClearButton()\" color=\"warn\" mat-button>{{ clearLabel }}</button>\n</div>\n"]}
@@ -12,7 +12,6 @@ export class NaturalSelectEnumComponent extends AbstractSelect {
12
12
  constructor(enumService, ngControl) {
13
13
  super(ngControl);
14
14
  this.enumService = enumService;
15
- this.ngControl = ngControl;
16
15
  /**
17
16
  * Whether the user should be allowed to select multiple options
18
17
  */
@@ -44,4 +43,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImpor
44
43
  }], multiple: [{
45
44
  type: Input
46
45
  }] } });
47
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LWVudW0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvc2VsZWN0L3NlbGVjdC1lbnVtL3NlbGVjdC1lbnVtLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL3NlbGVjdC9zZWxlY3QtZW51bS9zZWxlY3QtZW51bS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLEtBQUssRUFBVSxRQUFRLEVBQUUsSUFBSSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBSXZFLE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSw4QkFBOEIsQ0FBQzs7Ozs7Ozs7O0FBUzVELE1BQU0sT0FBTywwQkFBMkIsU0FBUSxjQUFvQjtJQXVCaEUsWUFDcUIsV0FBK0IsRUFDWixTQUEyQjtRQUUvRCxLQUFLLENBQUMsU0FBUyxDQUFDLENBQUM7UUFIQSxnQkFBVyxHQUFYLFdBQVcsQ0FBb0I7UUFDWixjQUFTLEdBQVQsU0FBUyxDQUFrQjtRQVRuRTs7V0FFRztRQUNhLGFBQVEsR0FBWSxLQUFLLENBQUM7SUFTMUMsQ0FBQztJQUVNLFFBQVE7UUFDWCxLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDakIsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDckQsQ0FBQztJQUVNLFlBQVk7UUFDZixNQUFNLElBQUksS0FBSyxDQUFDLDZCQUE2QixDQUFDLENBQUM7SUFDbkQsQ0FBQzs7dUhBckNRLDBCQUEwQjsyR0FBMUIsMEJBQTBCLG9NQ2J2Qyxtd0JBcUJBOzJGRFJhLDBCQUEwQjtrQkFMdEMsU0FBUzsrQkFDSSxxQkFBcUI7OzBCQTZCMUIsUUFBUTs7MEJBQUksSUFBSTs0Q0FyQkwsUUFBUTtzQkFBdkIsS0FBSztnQkFLVSxTQUFTO3NCQUF4QixLQUFLO2dCQUtVLGNBQWM7c0JBQTdCLEtBQUs7Z0JBS1UsUUFBUTtzQkFBdkIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBJbnB1dCwgT25Jbml0LCBPcHRpb25hbCwgU2VsZn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0NvbnRyb2xWYWx1ZUFjY2Vzc29yLCBOZ0NvbnRyb2x9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7T2JzZXJ2YWJsZX0gZnJvbSAncnhqcyc7XG5pbXBvcnQge0lFbnVtLCBOYXR1cmFsRW51bVNlcnZpY2V9IGZyb20gJy4uLy4uLy4uL3NlcnZpY2VzL2VudW0uc2VydmljZSc7XG5pbXBvcnQge0Fic3RyYWN0U2VsZWN0fSBmcm9tICcuLi9hYnN0cmFjdC1zZWxlY3QuY29tcG9uZW50JztcblxudHlwZSBWID0gSUVudW1bJ3ZhbHVlJ10gfCBJRW51bVsndmFsdWUnXVtdO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ25hdHVyYWwtc2VsZWN0LWVudW0nLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9zZWxlY3QtZW51bS5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vc2VsZWN0LWVudW0uY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgTmF0dXJhbFNlbGVjdEVudW1Db21wb25lbnQgZXh0ZW5kcyBBYnN0cmFjdFNlbGVjdDxWLCBWPiBpbXBsZW1lbnRzIE9uSW5pdCwgQ29udHJvbFZhbHVlQWNjZXNzb3Ige1xuICAgIC8qKlxuICAgICAqIFRoZSBuYW1lIG9mIHRoZSBlbnVtIHR5cGUsIGVnOiBgXCJBY3Rpb25TdGF0dXNcImBcbiAgICAgKi9cbiAgICBASW5wdXQoKSBwdWJsaWMgZW51bU5hbWUhOiBzdHJpbmc7XG5cbiAgICAvKipcbiAgICAgKiBJZiBnaXZlbiBhbiBleHRyYSBvcHRpb24gaXMgYWRkZWQgdG8gc2VsZWN0IGBudWxsYCB3aXRoIGdpdmVuIGxhYmVsXG4gICAgICovXG4gICAgQElucHV0KCkgcHVibGljIG51bGxMYWJlbD86IHN0cmluZztcblxuICAgIC8qKlxuICAgICAqIEZ1bmN0aW9ucyB0aGF0IHJlY2VpdmVzIGFuIGVudW0gdmFsdWUgYW5kIHJldHVybnMgd2hldGhlciB0aGF0IHZhbHVlIGlzIGRpc2FibGVkXG4gICAgICovXG4gICAgQElucHV0KCkgcHVibGljIG9wdGlvbkRpc2FibGVkPzogKGl0ZW06IElFbnVtKSA9PiBib29sZWFuO1xuXG4gICAgLyoqXG4gICAgICogV2hldGhlciB0aGUgdXNlciBzaG91bGQgYmUgYWxsb3dlZCB0byBzZWxlY3QgbXVsdGlwbGUgb3B0aW9uc1xuICAgICAqL1xuICAgIEBJbnB1dCgpIHB1YmxpYyBtdWx0aXBsZTogYm9vbGVhbiA9IGZhbHNlO1xuXG4gICAgcHVibGljIGl0ZW1zPzogT2JzZXJ2YWJsZTxJRW51bVtdPjtcblxuICAgIHB1YmxpYyBjb25zdHJ1Y3RvcihcbiAgICAgICAgcHJpdmF0ZSByZWFkb25seSBlbnVtU2VydmljZTogTmF0dXJhbEVudW1TZXJ2aWNlLFxuICAgICAgICBAT3B0aW9uYWwoKSBAU2VsZigpIHB1YmxpYyByZWFkb25seSBuZ0NvbnRyb2w6IE5nQ29udHJvbCB8IG51bGwsXG4gICAgKSB7XG4gICAgICAgIHN1cGVyKG5nQ29udHJvbCk7XG4gICAgfVxuXG4gICAgcHVibGljIG5nT25Jbml0KCk6IHZvaWQge1xuICAgICAgICBzdXBlci5uZ09uSW5pdCgpO1xuICAgICAgICB0aGlzLml0ZW1zID0gdGhpcy5lbnVtU2VydmljZS5nZXQodGhpcy5lbnVtTmFtZSk7XG4gICAgfVxuXG4gICAgcHVibGljIGdldERpc3BsYXlGbigpOiAoaXRlbTogViB8IG51bGwpID0+IHN0cmluZyB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcignVGhpcyBzaG91bGQgbmV2ZXIgYmUgY2FsbGVkJyk7XG4gICAgfVxufVxuIiwiPG1hdC1mb3JtLWZpZWxkPlxuICAgIDxtYXQtbGFiZWw+e3sgcGxhY2Vob2xkZXIgfX08L21hdC1sYWJlbD5cbiAgICA8bWF0LXNlbGVjdFxuICAgICAgICAoc2VsZWN0aW9uQ2hhbmdlKT1cInByb3BhZ2F0ZVZhbHVlKCRldmVudC52YWx1ZSlcIlxuICAgICAgICBbZm9ybUNvbnRyb2xdPVwiaW50ZXJuYWxDdHJsXCJcbiAgICAgICAgKGJsdXIpPVwidG91Y2goKTsgYmx1ci5lbWl0KClcIlxuICAgICAgICBbZXJyb3JTdGF0ZU1hdGNoZXJdPVwibWF0Y2hlclwiXG4gICAgICAgIFttdWx0aXBsZV09XCJtdWx0aXBsZVwiXG4gICAgPlxuICAgICAgICA8bWF0LW9wdGlvbiAqbmdJZj1cIm51bGxMYWJlbFwiIFt2YWx1ZV09XCJudWxsXCI+e3sgbnVsbExhYmVsIH19PC9tYXQtb3B0aW9uPlxuICAgICAgICA8bWF0LW9wdGlvblxuICAgICAgICAgICAgKm5nRm9yPVwibGV0IGl0ZW0gb2YgaXRlbXMgfCBhc3luY1wiXG4gICAgICAgICAgICBbdmFsdWVdPVwiaXRlbS52YWx1ZVwiXG4gICAgICAgICAgICBbZGlzYWJsZWRdPVwib3B0aW9uRGlzYWJsZWQgPyBvcHRpb25EaXNhYmxlZChpdGVtKSA6IGZhbHNlXCJcbiAgICAgICAgPlxuICAgICAgICAgICAge3sgaXRlbS5uYW1lIHwgY2FwaXRhbGl6ZSB9fVxuICAgICAgICA8L21hdC1vcHRpb24+XG4gICAgPC9tYXQtc2VsZWN0PlxuXG4gICAgPG1hdC1lcnJvciAqbmdJZj1cImhhc1JlcXVpcmVkRXJyb3IoKVwiIGkxOG4+Q2UgY2hhbXAgZXN0IHJlcXVpczwvbWF0LWVycm9yPjwvbWF0LWZvcm0tZmllbGRcbj5cbiJdfQ==
46
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LWVudW0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvc2VsZWN0L3NlbGVjdC1lbnVtL3NlbGVjdC1lbnVtLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL3NlbGVjdC9zZWxlY3QtZW51bS9zZWxlY3QtZW51bS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLEtBQUssRUFBVSxRQUFRLEVBQUUsSUFBSSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBSXZFLE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSw4QkFBOEIsQ0FBQzs7Ozs7Ozs7O0FBUzVELE1BQU0sT0FBTywwQkFBMkIsU0FBUSxjQUFvQjtJQXVCaEUsWUFDcUIsV0FBK0IsRUFDNUIsU0FBMkI7UUFFL0MsS0FBSyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBSEEsZ0JBQVcsR0FBWCxXQUFXLENBQW9CO1FBUnBEOztXQUVHO1FBQ2EsYUFBUSxHQUFHLEtBQUssQ0FBQztJQVNqQyxDQUFDO0lBRWUsUUFBUTtRQUNwQixLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDakIsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDckQsQ0FBQztJQUVNLFlBQVk7UUFDZixNQUFNLElBQUksS0FBSyxDQUFDLDZCQUE2QixDQUFDLENBQUM7SUFDbkQsQ0FBQzs7dUhBckNRLDBCQUEwQjsyR0FBMUIsMEJBQTBCLG9NQ2J2Qyxtd0JBcUJBOzJGRFJhLDBCQUEwQjtrQkFMdEMsU0FBUzsrQkFDSSxxQkFBcUI7OzBCQTZCMUIsUUFBUTs7MEJBQUksSUFBSTs0Q0FyQkwsUUFBUTtzQkFBdkIsS0FBSztnQkFLVSxTQUFTO3NCQUF4QixLQUFLO2dCQUtVLGNBQWM7c0JBQTdCLEtBQUs7Z0JBS1UsUUFBUTtzQkFBdkIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBJbnB1dCwgT25Jbml0LCBPcHRpb25hbCwgU2VsZn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0NvbnRyb2xWYWx1ZUFjY2Vzc29yLCBOZ0NvbnRyb2x9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7T2JzZXJ2YWJsZX0gZnJvbSAncnhqcyc7XG5pbXBvcnQge0lFbnVtLCBOYXR1cmFsRW51bVNlcnZpY2V9IGZyb20gJy4uLy4uLy4uL3NlcnZpY2VzL2VudW0uc2VydmljZSc7XG5pbXBvcnQge0Fic3RyYWN0U2VsZWN0fSBmcm9tICcuLi9hYnN0cmFjdC1zZWxlY3QuY29tcG9uZW50JztcblxudHlwZSBWID0gSUVudW1bJ3ZhbHVlJ10gfCBJRW51bVsndmFsdWUnXVtdO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ25hdHVyYWwtc2VsZWN0LWVudW0nLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9zZWxlY3QtZW51bS5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vc2VsZWN0LWVudW0uY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgTmF0dXJhbFNlbGVjdEVudW1Db21wb25lbnQgZXh0ZW5kcyBBYnN0cmFjdFNlbGVjdDxWLCBWPiBpbXBsZW1lbnRzIE9uSW5pdCwgQ29udHJvbFZhbHVlQWNjZXNzb3Ige1xuICAgIC8qKlxuICAgICAqIFRoZSBuYW1lIG9mIHRoZSBlbnVtIHR5cGUsIGVnOiBgXCJBY3Rpb25TdGF0dXNcImBcbiAgICAgKi9cbiAgICBASW5wdXQoKSBwdWJsaWMgZW51bU5hbWUhOiBzdHJpbmc7XG5cbiAgICAvKipcbiAgICAgKiBJZiBnaXZlbiBhbiBleHRyYSBvcHRpb24gaXMgYWRkZWQgdG8gc2VsZWN0IGBudWxsYCB3aXRoIGdpdmVuIGxhYmVsXG4gICAgICovXG4gICAgQElucHV0KCkgcHVibGljIG51bGxMYWJlbD86IHN0cmluZztcblxuICAgIC8qKlxuICAgICAqIEZ1bmN0aW9ucyB0aGF0IHJlY2VpdmVzIGFuIGVudW0gdmFsdWUgYW5kIHJldHVybnMgd2hldGhlciB0aGF0IHZhbHVlIGlzIGRpc2FibGVkXG4gICAgICovXG4gICAgQElucHV0KCkgcHVibGljIG9wdGlvbkRpc2FibGVkPzogKGl0ZW06IElFbnVtKSA9PiBib29sZWFuO1xuXG4gICAgLyoqXG4gICAgICogV2hldGhlciB0aGUgdXNlciBzaG91bGQgYmUgYWxsb3dlZCB0byBzZWxlY3QgbXVsdGlwbGUgb3B0aW9uc1xuICAgICAqL1xuICAgIEBJbnB1dCgpIHB1YmxpYyBtdWx0aXBsZSA9IGZhbHNlO1xuXG4gICAgcHVibGljIGl0ZW1zPzogT2JzZXJ2YWJsZTxJRW51bVtdPjtcblxuICAgIHB1YmxpYyBjb25zdHJ1Y3RvcihcbiAgICAgICAgcHJpdmF0ZSByZWFkb25seSBlbnVtU2VydmljZTogTmF0dXJhbEVudW1TZXJ2aWNlLFxuICAgICAgICBAT3B0aW9uYWwoKSBAU2VsZigpIG5nQ29udHJvbDogTmdDb250cm9sIHwgbnVsbCxcbiAgICApIHtcbiAgICAgICAgc3VwZXIobmdDb250cm9sKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgb3ZlcnJpZGUgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgICAgIHN1cGVyLm5nT25Jbml0KCk7XG4gICAgICAgIHRoaXMuaXRlbXMgPSB0aGlzLmVudW1TZXJ2aWNlLmdldCh0aGlzLmVudW1OYW1lKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgZ2V0RGlzcGxheUZuKCk6IChpdGVtOiBWIHwgbnVsbCkgPT4gc3RyaW5nIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdUaGlzIHNob3VsZCBuZXZlciBiZSBjYWxsZWQnKTtcbiAgICB9XG59XG4iLCI8bWF0LWZvcm0tZmllbGQ+XG4gICAgPG1hdC1sYWJlbD57eyBwbGFjZWhvbGRlciB9fTwvbWF0LWxhYmVsPlxuICAgIDxtYXQtc2VsZWN0XG4gICAgICAgIChzZWxlY3Rpb25DaGFuZ2UpPVwicHJvcGFnYXRlVmFsdWUoJGV2ZW50LnZhbHVlKVwiXG4gICAgICAgIFtmb3JtQ29udHJvbF09XCJpbnRlcm5hbEN0cmxcIlxuICAgICAgICAoYmx1cik9XCJ0b3VjaCgpOyBibHVyLmVtaXQoKVwiXG4gICAgICAgIFtlcnJvclN0YXRlTWF0Y2hlcl09XCJtYXRjaGVyXCJcbiAgICAgICAgW211bHRpcGxlXT1cIm11bHRpcGxlXCJcbiAgICA+XG4gICAgICAgIDxtYXQtb3B0aW9uICpuZ0lmPVwibnVsbExhYmVsXCIgW3ZhbHVlXT1cIm51bGxcIj57eyBudWxsTGFiZWwgfX08L21hdC1vcHRpb24+XG4gICAgICAgIDxtYXQtb3B0aW9uXG4gICAgICAgICAgICAqbmdGb3I9XCJsZXQgaXRlbSBvZiBpdGVtcyB8IGFzeW5jXCJcbiAgICAgICAgICAgIFt2YWx1ZV09XCJpdGVtLnZhbHVlXCJcbiAgICAgICAgICAgIFtkaXNhYmxlZF09XCJvcHRpb25EaXNhYmxlZCA/IG9wdGlvbkRpc2FibGVkKGl0ZW0pIDogZmFsc2VcIlxuICAgICAgICA+XG4gICAgICAgICAgICB7eyBpdGVtLm5hbWUgfCBjYXBpdGFsaXplIH19XG4gICAgICAgIDwvbWF0LW9wdGlvbj5cbiAgICA8L21hdC1zZWxlY3Q+XG5cbiAgICA8bWF0LWVycm9yICpuZ0lmPVwiaGFzUmVxdWlyZWRFcnJvcigpXCIgaTE4bj5DZSBjaGFtcCBlc3QgcmVxdWlzPC9tYXQtZXJyb3I+PC9tYXQtZm9ybS1maWVsZFxuPlxuIl19
@@ -124,4 +124,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImpor
124
124
  }], filters: [{
125
125
  type: Input
126
126
  }] } });
127
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-hierarchic.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/select/select-hierarchic/select-hierarchic.component.ts","../../../../../../../projects/natural/src/lib/modules/select/select-hierarchic/select-hierarchic.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input, OnDestroy, OnInit, Optional, Self} from '@angular/core';\nimport {ControlValueAccessor, NgControl} from '@angular/forms';\nimport {MatDialogConfig} from '@angular/material/dialog';\nimport {Literal} from '../../../types/types';\nimport {HierarchicFiltersConfiguration} from '../../hierarchic-selector/classes/hierarchic-filters-configuration';\nimport {\n    HierarchicDialogConfig,\n    NaturalHierarchicConfiguration,\n    NaturalHierarchicSelectorDialogService,\n    OrganizedModelSelection,\n} from '../../hierarchic-selector/public-api';\nimport {AbstractSelect} from '../abstract-select.component';\n\nfunction defaultDisplayFn(item: Literal | null): string {\n    if (!item) {\n        return '';\n    }\n\n    return item.fullName || item.name || item.iban || item.id || item;\n}\n\n/**\n * Default usage:\n * <natural-select [config]=\"myConfig\" [(ngModel)]=\"amazingModel\"\n * (ngModelChange)=amazingChangeFn($event)></natural-select>\n *\n * [(ngModel)] and (ngModelChange) are optional\n *\n * Placeholder :\n * <natural-select placeholder=\"amazing placeholder\">\n *\n * Never float placeholder :\n * <natural-select placeholder=\"amazing placeholder\" floatPlaceholder=\"never\">\n */\n@Component({\n    selector: 'natural-select-hierarchic',\n    templateUrl: './select-hierarchic.component.html',\n    styleUrls: ['./select-hierarchic.component.scss'],\n})\nexport class NaturalSelectHierarchicComponent\n    extends AbstractSelect<Literal, string>\n    implements OnInit, OnDestroy, ControlValueAccessor\n{\n    /**\n     * If provided cause a new select button to appear\n     */\n    @Input() public selectLabel?: string;\n\n    /**\n     * Configuration for hierarchic relations\n     */\n    @Input() public config!: NaturalHierarchicConfiguration[];\n\n    /**\n     * Filters formatted for hierarchic selector\n     */\n    @Input() public filters?: HierarchicFiltersConfiguration;\n\n    /**\n     * The selected value as an object. The internal value is `internalCtrl.value`, and that is a string.\n     */\n    private value: Literal | null = null;\n\n    /**\n     * On Firefox, the combination of <input (focus)> event and dialog opening cause some strange bug where focus event is called multiple\n     * times This prevents it.\n     */\n    private lockOpenDialog = false;\n\n    public constructor(\n        private readonly hierarchicSelectorDialogService: NaturalHierarchicSelectorDialogService,\n        @Optional() @Self() ngControl: NgControl | null,\n    ) {\n        super(ngControl);\n    }\n\n    /**\n     * Very important to return something, above all if [select]='displayedValue' attribute value is used\n     */\n    public getDisplayFn(): (item: Literal | null) => string {\n        if (this.displayWith) {\n            return this.displayWith;\n        }\n\n        return defaultDisplayFn;\n    }\n\n    /**\n     * Override parent because our internalCtrl store the textual representation as string instead of raw Literal\n     */\n    public writeValue(value: Literal | string | null): void {\n        this.value = value as Literal;\n        this.internalCtrl.setValue(this.getDisplayFn()(this.value));\n    }\n\n    public openDialog(): void {\n        if (this.internalCtrl.disabled) {\n            return;\n        }\n\n        if (this.lockOpenDialog) {\n            return;\n        }\n\n        this.lockOpenDialog = true;\n\n        if (this.onTouched) {\n            this.onTouched();\n        }\n\n        const selectAtKey = this.getSelectKey();\n        const selected: OrganizedModelSelection = {};\n\n        if (this.internalCtrl.value) {\n            selected[selectAtKey] = [this.value];\n        }\n\n        const hierarchicConfig: HierarchicDialogConfig = {\n            hierarchicConfig: this.config,\n            hierarchicSelection: selected,\n            hierarchicFilters: this.filters,\n            multiple: false,\n        };\n\n        const dialogFocus: MatDialogConfig = {restoreFocus: false};\n\n        this.hierarchicSelectorDialogService\n            .open(hierarchicConfig, dialogFocus)\n            .afterClosed()\n            .subscribe(result => {\n                this.lockOpenDialog = false;\n                if (result && result.hierarchicSelection) {\n                    const selection = result.hierarchicSelection;\n                    // Find the only selection amongst all possible keys\n                    const keyWithSelection = Object.keys(selection).find(key => selection[key][0]);\n                    const singleSelection = keyWithSelection ? selection[keyWithSelection][0] : null;\n\n                    this.writeValue(singleSelection);\n                    this.propagateValue(singleSelection);\n                }\n            });\n    }\n\n    public showSelectButton(): boolean {\n        return !!(this.internalCtrl?.enabled && this.selectLabel && this.config);\n    }\n\n    private getSelectKey(): string {\n        const selectKey = this.config.filter(c => !!c.selectableAtKey)[0].selectableAtKey;\n\n        if (!selectKey) {\n            throw new Error('Hierarchic selector must be configured with at least one selectableAtKey');\n        }\n\n        return selectKey;\n    }\n}\n","<mat-form-field [floatLabel]=\"floatPlaceholder\">\n    <mat-label>{{ placeholder }}</mat-label>\n\n    <!-- Input for hierarchical selector -->\n    <input\n        (blur)=\"blur.emit()\"\n        (focus)=\"openDialog()\"\n        (keydown.esc)=\"clear()\"\n        [formControl]=\"internalCtrl\"\n        [errorStateMatcher]=\"matcher\"\n        aria-label=\"Recherche et sélection\"\n        i18n-aria-label\n        matInput\n    />\n\n    <!-- Meta data -->\n    <natural-icon *ngIf=\"showIcon\" [name]=\"icon\" matPrefix></natural-icon>\n\n    <!-- Clear button -->\n    <div class=\"suffix-buttons\" matSuffix>\n        <button\n            (click)=\"clear(); $event.stopPropagation()\"\n            *ngIf=\"internalCtrl.value && internalCtrl.enabled && !clearLabel\"\n            mat-icon-button\n            i18n-matTooltip\n            matTooltip=\"Désélectionner\"\n        >\n            <natural-icon name=\"close\"></natural-icon>\n        </button>\n        <button\n            *ngIf=\"internalCtrl.value && navigateTo\"\n            [routerLink]=\"navigateTo\"\n            (click)=\"$event.stopPropagation()\"\n            mat-button\n            mat-icon-button\n            i18n-matTooltip\n            matTooltip=\"Naviguer vers\"\n        >\n            <natural-icon name=\"open_in_browser\"></natural-icon>\n        </button>\n    </div>\n\n    <mat-error *ngIf=\"hasRequiredError()\" i18n>Ce champ est requis</mat-error>\n</mat-form-field>\n\n<!--    Additional (un)select/(un)link buttons for more visual cohesion with natural-relations --><!-- [clearLabel] and/or [selectLabel] has to be given as attribute input -->\n<div *ngIf=\"showSelectButton() || showClearButton()\" class=\"external-buttons\">\n    <button (click)=\"openDialog()\" *ngIf=\"showSelectButton()\" color=\"primary\" mat-flat-button>{{ selectLabel }}</button>\n    <button (click)=\"clear()\" *ngIf=\"showClearButton()\" color=\"warn\" mat-button>{{ clearLabel }}</button>\n</div>\n"]}
127
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-hierarchic.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/select/select-hierarchic/select-hierarchic.component.ts","../../../../../../../projects/natural/src/lib/modules/select/select-hierarchic/select-hierarchic.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input, OnDestroy, OnInit, Optional, Self} from '@angular/core';\nimport {ControlValueAccessor, NgControl} from '@angular/forms';\nimport {MatDialogConfig} from '@angular/material/dialog';\nimport {Literal} from '../../../types/types';\nimport {HierarchicFiltersConfiguration} from '../../hierarchic-selector/classes/hierarchic-filters-configuration';\nimport {\n    HierarchicDialogConfig,\n    NaturalHierarchicConfiguration,\n    NaturalHierarchicSelectorDialogService,\n    OrganizedModelSelection,\n} from '../../hierarchic-selector/public-api';\nimport {AbstractSelect} from '../abstract-select.component';\n\nfunction defaultDisplayFn(item: Literal | null): string {\n    if (!item) {\n        return '';\n    }\n\n    return item.fullName || item.name || item.iban || item.id || item;\n}\n\n/**\n * Default usage:\n * <natural-select [config]=\"myConfig\" [(ngModel)]=\"amazingModel\"\n * (ngModelChange)=amazingChangeFn($event)></natural-select>\n *\n * [(ngModel)] and (ngModelChange) are optional\n *\n * Placeholder :\n * <natural-select placeholder=\"amazing placeholder\">\n *\n * Never float placeholder :\n * <natural-select placeholder=\"amazing placeholder\" floatPlaceholder=\"never\">\n */\n@Component({\n    selector: 'natural-select-hierarchic',\n    templateUrl: './select-hierarchic.component.html',\n    styleUrls: ['./select-hierarchic.component.scss'],\n})\nexport class NaturalSelectHierarchicComponent\n    extends AbstractSelect<Literal, string>\n    implements OnInit, OnDestroy, ControlValueAccessor\n{\n    /**\n     * If provided cause a new select button to appear\n     */\n    @Input() public selectLabel?: string;\n\n    /**\n     * Configuration for hierarchic relations\n     */\n    @Input() public config!: NaturalHierarchicConfiguration[];\n\n    /**\n     * Filters formatted for hierarchic selector\n     */\n    @Input() public filters?: HierarchicFiltersConfiguration;\n\n    /**\n     * The selected value as an object. The internal value is `internalCtrl.value`, and that is a string.\n     */\n    private value: Literal | null = null;\n\n    /**\n     * On Firefox, the combination of <input (focus)> event and dialog opening cause some strange bug where focus event is called multiple\n     * times This prevents it.\n     */\n    private lockOpenDialog = false;\n\n    public constructor(\n        private readonly hierarchicSelectorDialogService: NaturalHierarchicSelectorDialogService,\n        @Optional() @Self() ngControl: NgControl | null,\n    ) {\n        super(ngControl);\n    }\n\n    /**\n     * Very important to return something, above all if [select]='displayedValue' attribute value is used\n     */\n    public getDisplayFn(): (item: Literal | null) => string {\n        if (this.displayWith) {\n            return this.displayWith;\n        }\n\n        return defaultDisplayFn;\n    }\n\n    /**\n     * Override parent because our internalCtrl store the textual representation as string instead of raw Literal\n     */\n    public override writeValue(value: Literal | string | null): void {\n        this.value = value as Literal;\n        this.internalCtrl.setValue(this.getDisplayFn()(this.value));\n    }\n\n    public openDialog(): void {\n        if (this.internalCtrl.disabled) {\n            return;\n        }\n\n        if (this.lockOpenDialog) {\n            return;\n        }\n\n        this.lockOpenDialog = true;\n\n        if (this.onTouched) {\n            this.onTouched();\n        }\n\n        const selectAtKey = this.getSelectKey();\n        const selected: OrganizedModelSelection = {};\n\n        if (this.internalCtrl.value) {\n            selected[selectAtKey] = [this.value];\n        }\n\n        const hierarchicConfig: HierarchicDialogConfig = {\n            hierarchicConfig: this.config,\n            hierarchicSelection: selected,\n            hierarchicFilters: this.filters,\n            multiple: false,\n        };\n\n        const dialogFocus: MatDialogConfig = {restoreFocus: false};\n\n        this.hierarchicSelectorDialogService\n            .open(hierarchicConfig, dialogFocus)\n            .afterClosed()\n            .subscribe(result => {\n                this.lockOpenDialog = false;\n                if (result && result.hierarchicSelection) {\n                    const selection = result.hierarchicSelection;\n                    // Find the only selection amongst all possible keys\n                    const keyWithSelection = Object.keys(selection).find(key => selection[key][0]);\n                    const singleSelection = keyWithSelection ? selection[keyWithSelection][0] : null;\n\n                    this.writeValue(singleSelection);\n                    this.propagateValue(singleSelection);\n                }\n            });\n    }\n\n    public showSelectButton(): boolean {\n        return !!(this.internalCtrl?.enabled && this.selectLabel && this.config);\n    }\n\n    private getSelectKey(): string {\n        const selectKey = this.config.filter(c => !!c.selectableAtKey)[0].selectableAtKey;\n\n        if (!selectKey) {\n            throw new Error('Hierarchic selector must be configured with at least one selectableAtKey');\n        }\n\n        return selectKey;\n    }\n}\n","<mat-form-field [floatLabel]=\"floatPlaceholder\">\n    <mat-label>{{ placeholder }}</mat-label>\n\n    <!-- Input for hierarchical selector -->\n    <input\n        (blur)=\"blur.emit()\"\n        (focus)=\"openDialog()\"\n        (keydown.esc)=\"clear()\"\n        [formControl]=\"internalCtrl\"\n        [errorStateMatcher]=\"matcher\"\n        aria-label=\"Recherche et sélection\"\n        i18n-aria-label\n        matInput\n    />\n\n    <!-- Meta data -->\n    <natural-icon *ngIf=\"showIcon\" [name]=\"icon\" matPrefix></natural-icon>\n\n    <!-- Clear button -->\n    <div class=\"suffix-buttons\" matSuffix>\n        <button\n            (click)=\"clear(); $event.stopPropagation()\"\n            *ngIf=\"internalCtrl.value && internalCtrl.enabled && !clearLabel\"\n            mat-icon-button\n            i18n-matTooltip\n            matTooltip=\"Désélectionner\"\n        >\n            <natural-icon name=\"close\"></natural-icon>\n        </button>\n        <button\n            *ngIf=\"internalCtrl.value && navigateTo\"\n            [routerLink]=\"navigateTo\"\n            (click)=\"$event.stopPropagation()\"\n            mat-button\n            mat-icon-button\n            i18n-matTooltip\n            matTooltip=\"Naviguer vers\"\n        >\n            <natural-icon name=\"open_in_browser\"></natural-icon>\n        </button>\n    </div>\n\n    <mat-error *ngIf=\"hasRequiredError()\" i18n>Ce champ est requis</mat-error>\n</mat-form-field>\n\n<!--    Additional (un)select/(un)link buttons for more visual cohesion with natural-relations --><!-- [clearLabel] and/or [selectLabel] has to be given as attribute input -->\n<div *ngIf=\"showSelectButton() || showClearButton()\" class=\"external-buttons\">\n    <button (click)=\"openDialog()\" *ngIf=\"showSelectButton()\" color=\"primary\" mat-flat-button>{{ selectLabel }}</button>\n    <button (click)=\"clear()\" *ngIf=\"showClearButton()\" color=\"warn\" mat-button>{{ clearLabel }}</button>\n</div>\n"]}
@@ -1,7 +1,6 @@
1
1
  import { Component } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
3
  export class NaturalSidenavComponent {
4
- constructor() { }
5
4
  }
6
5
  NaturalSidenavComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: NaturalSidenavComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
7
6
  NaturalSidenavComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.1", type: NaturalSidenavComponent, selector: "natural-sidenav", ngImport: i0, template: '<ng-content></ng-content>', isInline: true });
@@ -11,5 +10,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImpor
11
10
  selector: 'natural-sidenav',
12
11
  template: '<ng-content></ng-content>',
13
12
  }]
14
- }], ctorParameters: function () { return []; } });
15
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZW5hdi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uYXR1cmFsL3NyYy9saWIvbW9kdWxlcy9zaWRlbmF2L3NpZGVuYXYvc2lkZW5hdi5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLGVBQWUsQ0FBQzs7QUFNeEMsTUFBTSxPQUFPLHVCQUF1QjtJQUNoQyxnQkFBc0IsQ0FBQzs7b0hBRGQsdUJBQXVCO3dHQUF2Qix1QkFBdUIsdURBRnRCLDJCQUEyQjsyRkFFNUIsdUJBQXVCO2tCQUpuQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxpQkFBaUI7b0JBQzNCLFFBQVEsRUFBRSwyQkFBMkI7aUJBQ3hDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21wb25lbnR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ25hdHVyYWwtc2lkZW5hdicsXG4gICAgdGVtcGxhdGU6ICc8bmctY29udGVudD48L25nLWNvbnRlbnQ+Jyxcbn0pXG5leHBvcnQgY2xhc3MgTmF0dXJhbFNpZGVuYXZDb21wb25lbnQge1xuICAgIHB1YmxpYyBjb25zdHJ1Y3RvcigpIHt9XG59XG4iXX0=
13
+ }] });
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZW5hdi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uYXR1cmFsL3NyYy9saWIvbW9kdWxlcy9zaWRlbmF2L3NpZGVuYXYvc2lkZW5hdi5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLGVBQWUsQ0FBQzs7QUFNeEMsTUFBTSxPQUFPLHVCQUF1Qjs7b0hBQXZCLHVCQUF1Qjt3R0FBdkIsdUJBQXVCLHVEQUZ0QiwyQkFBMkI7MkZBRTVCLHVCQUF1QjtrQkFKbkMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsaUJBQWlCO29CQUMzQixRQUFRLEVBQUUsMkJBQTJCO2lCQUN4QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50fSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICduYXR1cmFsLXNpZGVuYXYnLFxuICAgIHRlbXBsYXRlOiAnPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PicsXG59KVxuZXhwb3J0IGNsYXNzIE5hdHVyYWxTaWRlbmF2Q29tcG9uZW50IHt9XG4iXX0=
@@ -1,12 +1,11 @@
1
1
  import { Component } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
3
  export class NaturalSidenavContentComponent {
4
- constructor() { }
5
4
  }
6
5
  NaturalSidenavContentComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: NaturalSidenavContentComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
7
6
  NaturalSidenavContentComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.1", type: NaturalSidenavContentComponent, selector: "natural-sidenav-content", ngImport: i0, template: '<ng-content></ng-content>', isInline: true, styles: [":host{flex:1;display:flex;flex-direction:column;overflow:auto}\n"] });
8
7
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: NaturalSidenavContentComponent, decorators: [{
9
8
  type: Component,
10
9
  args: [{ selector: 'natural-sidenav-content', template: '<ng-content></ng-content>', styles: [":host{flex:1;display:flex;flex-direction:column;overflow:auto}\n"] }]
11
- }], ctorParameters: function () { return []; } });
12
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZW5hdi1jb250ZW50LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL3NpZGVuYXYvc2lkZW5hdi1jb250ZW50L3NpZGVuYXYtY29udGVudC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLGVBQWUsQ0FBQzs7QUFPeEMsTUFBTSxPQUFPLDhCQUE4QjtJQUN2QyxnQkFBc0IsQ0FBQzs7MkhBRGQsOEJBQThCOytHQUE5Qiw4QkFBOEIsK0RBSDdCLDJCQUEyQjsyRkFHNUIsOEJBQThCO2tCQUwxQyxTQUFTOytCQUNJLHlCQUF5QixZQUN6QiwyQkFBMkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnbmF0dXJhbC1zaWRlbmF2LWNvbnRlbnQnLFxuICAgIHRlbXBsYXRlOiAnPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PicsXG4gICAgc3R5bGVVcmxzOiBbJy4vc2lkZW5hdi1jb250ZW50LmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIE5hdHVyYWxTaWRlbmF2Q29udGVudENvbXBvbmVudCB7XG4gICAgcHVibGljIGNvbnN0cnVjdG9yKCkge31cbn1cbiJdfQ==
10
+ }] });
11
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZW5hdi1jb250ZW50LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL3NpZGVuYXYvc2lkZW5hdi1jb250ZW50L3NpZGVuYXYtY29udGVudC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLGVBQWUsQ0FBQzs7QUFPeEMsTUFBTSxPQUFPLDhCQUE4Qjs7MkhBQTlCLDhCQUE4QjsrR0FBOUIsOEJBQThCLCtEQUg3QiwyQkFBMkI7MkZBRzVCLDhCQUE4QjtrQkFMMUMsU0FBUzsrQkFDSSx5QkFBeUIsWUFDekIsMkJBQTJCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21wb25lbnR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ25hdHVyYWwtc2lkZW5hdi1jb250ZW50JyxcbiAgICB0ZW1wbGF0ZTogJzxuZy1jb250ZW50PjwvbmctY29udGVudD4nLFxuICAgIHN0eWxlVXJsczogWycuL3NpZGVuYXYtY29udGVudC5jb21wb25lbnQuc2NzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBOYXR1cmFsU2lkZW5hdkNvbnRlbnRDb21wb25lbnQge31cbiJdfQ==
@@ -192,4 +192,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImpor
192
192
  type: Inject,
193
193
  args: [SESSION_STORAGE]
194
194
  }] }, { type: i3.NaturalSidenavStackService }]; } });
195
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sidenav.service.js","sourceRoot":"","sources":["../../../../../../projects/natural/src/lib/modules/sidenav/sidenav.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Inject, Injectable} from '@angular/core';\nimport {MediaObserver} from '@angular/flex-layout';\nimport {MatDrawer, MatDrawerContainer, MatDrawerMode} from '@angular/material/sidenav';\nimport {NavigationEnd, Router} from '@angular/router';\nimport {filter, takeUntil} from 'rxjs/operators';\nimport {NaturalAbstractController} from '../../classes/abstract-controller';\nimport {NaturalSidenavContainerComponent} from './sidenav-container/sidenav-container.component';\nimport {NaturalStorage, SESSION_STORAGE} from '../common/services/memory-storage';\nimport {NaturalSidenavStackService} from './sidenav-stack.service';\n\n/**\n * Assert that given value is not null\n */\nfunction assert<T>(value: T): asserts value {\n    if (!value) {\n        throw new Error('Must call NaturalSidenavService.init() before using the service');\n    }\n}\n\n/**\n * @TODO : Fix nav minimize and maximize resize\n * Since Material 2 beta 10, when nav is resized the body is not resized\n * https://github.com/angular/material2/issues/6743\n * Maybe the better is to wait next release\n */\n@Injectable({providedIn: 'root'})\nexport class NaturalSidenavService extends NaturalAbstractController {\n    /**\n     * Navigation modes\n     * First is for desktop view\n     * Second is for mobile view\n     */\n    private modes: MatDrawerMode[] = ['side', 'push'];\n\n    /**\n     * Activated mode\n     * Default to desktop view\n     */\n    private mode: MatDrawerMode = this.modes[0];\n\n    /**\n     * Wherever is nav is opened or not\n     */\n    private opened = true;\n\n    /**\n     * Stores the opened status during mobile view, to restore if we come back to desktop view\n     */\n    private tmpOpened: boolean = this.opened;\n\n    /**\n     * Wherever is nav is minimized or not\n     */\n    private minimized = false;\n\n    /**\n     * LocalStorage key that stores the minimized status\n     */\n    private readonly minimizedStorageKey = 'menu-minimized';\n\n    /**\n     * LocalStorage key that stores the opened status\n     */\n    private readonly openedStorageKey = 'menu-opened';\n\n    private minimizedStorageKeyWithName: string | null = null;\n    private openedStorageKeyWithName: string | null = null;\n\n    public constructor(\n        public readonly mediaObserver: MediaObserver,\n        private readonly router: Router,\n        @Inject(SESSION_STORAGE) private readonly sessionStorage: NaturalStorage,\n        private readonly naturalSidenavStackService: NaturalSidenavStackService,\n    ) {\n        super();\n    }\n\n    public get activeMode(): MatDrawerMode {\n        return this.mode;\n    }\n\n    public get isOpened(): boolean {\n        return this.opened;\n    }\n\n    public get isMinimized(): boolean {\n        return this.minimized;\n    }\n\n    public destroy(component: NaturalSidenavContainerComponent): void {\n        this.naturalSidenavStackService.unregister(component);\n    }\n\n    public init(\n        name: string,\n        container: MatDrawerContainer,\n        drawer: MatDrawer,\n        component: NaturalSidenavContainerComponent,\n        autoClose: boolean = false,\n    ): void {\n        if (!name || name === '') {\n            throw new Error('No sidenav name provided, use <natural-sidenav-container name=\"menu\">');\n        }\n\n        this.naturalSidenavStackService.register(component);\n\n        this.minimizedStorageKeyWithName = name + '-' + this.minimizedStorageKey;\n        this.openedStorageKeyWithName = name + '-' + this.openedStorageKey;\n\n        // Init from LocalStorage\n        this.minimized = this.getMinimizedStatus();\n        this.opened = this.getMenuOpenedStatus();\n        this.tmpOpened = this.opened;\n\n        let oldIsBig: boolean | null = null;\n        this.mediaObserver\n            .asObservable()\n            .pipe(takeUntil(this.ngUnsubscribe))\n            .subscribe(() => {\n                const isBig = !this.isMobileView();\n                this.mode = isBig ? this.modes[0] : this.modes[1];\n\n                if (oldIsBig === null || isBig !== oldIsBig) {\n                    oldIsBig = isBig;\n\n                    // If decrease window size, save status of menu before closing it\n                    if (!isBig) {\n                        this.tmpOpened = this.opened;\n                        this.opened = false;\n                    }\n\n                    // If increase window size, and sidebar was open before, re-open it.\n                    if (isBig && this.tmpOpened) {\n                        this.opened = true;\n                        this.minimized = this.getMinimizedStatus();\n                    }\n                }\n            });\n\n        if (autoClose) {\n            this.router.events\n                .pipe(\n                    takeUntil(this.ngUnsubscribe),\n                    filter(e => e instanceof NavigationEnd),\n                )\n                .subscribe(() => {\n                    this.navItemClicked();\n                });\n        }\n    }\n\n    public isMobileView(): boolean {\n        return !this.mediaObserver.isActive('gt-sm');\n    }\n\n    /**\n     * Close nav on mobile view after a click\n     */\n    public navItemClicked(): void {\n        if (this.isMobileView()) {\n            this.close();\n        }\n    }\n\n    /**\n     * Change minimized status and stores the new value\n     */\n    public setMinimized(value: boolean): void {\n        this.minimized = value;\n        assert(this.minimizedStorageKeyWithName);\n        this.sessionStorage.setItem(this.minimizedStorageKeyWithName, value ? 'true' : 'false');\n    }\n\n    public minimize(): void {\n        this.setMinimized(true);\n    }\n\n    public expand(): void {\n        this.setMinimized(false);\n    }\n\n    public toggleMinimized(): void {\n        this.setMinimized(!this.minimized);\n    }\n\n    /**\n     * Get the stored minimized status\n     */\n    public getMinimizedStatus(): boolean {\n        assert(this.minimizedStorageKeyWithName);\n        const value = this.sessionStorage.getItem(this.minimizedStorageKeyWithName);\n\n        return value === null ? false : value === 'true';\n    }\n\n    /**\n     * Get the stored opened status\n     * Default on an opened status if nothing is stored\n     */\n    public getMenuOpenedStatus(): boolean {\n        assert(this.openedStorageKeyWithName);\n        const value = this.sessionStorage.getItem(this.openedStorageKeyWithName);\n\n        return value === null || value === 'true';\n    }\n\n    /**\n     * Toggle menu but expand it if mobile mode is activated\n     * Stores the status in local storage\n     */\n    public toggle(): void {\n        this.setOpened(!this.opened);\n    }\n\n    public close(): void {\n        this.setOpened(false);\n    }\n\n    public open(): void {\n        this.setOpened(true);\n    }\n\n    public setOpened(value: boolean): void {\n        this.opened = value;\n\n        if (this.opened && this.isMobileView()) {\n            this.minimized = false;\n        } else if (!this.isMobileView()) {\n            assert(this.openedStorageKeyWithName);\n            this.sessionStorage.setItem(this.openedStorageKeyWithName, this.opened ? 'true' : 'false');\n        }\n    }\n}\n"]}
195
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sidenav.service.js","sourceRoot":"","sources":["../../../../../../projects/natural/src/lib/modules/sidenav/sidenav.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Inject, Injectable} from '@angular/core';\nimport {MediaObserver} from '@angular/flex-layout';\nimport {MatDrawer, MatDrawerContainer, MatDrawerMode} from '@angular/material/sidenav';\nimport {NavigationEnd, Router} from '@angular/router';\nimport {filter, takeUntil} from 'rxjs/operators';\nimport {NaturalAbstractController} from '../../classes/abstract-controller';\nimport {NaturalSidenavContainerComponent} from './sidenav-container/sidenav-container.component';\nimport {NaturalStorage, SESSION_STORAGE} from '../common/services/memory-storage';\nimport {NaturalSidenavStackService} from './sidenav-stack.service';\n\n/**\n * Assert that given value is not null\n */\nfunction assert<T>(value: T): asserts value {\n    if (!value) {\n        throw new Error('Must call NaturalSidenavService.init() before using the service');\n    }\n}\n\n/**\n * @TODO : Fix nav minimize and maximize resize\n * Since Material 2 beta 10, when nav is resized the body is not resized\n * https://github.com/angular/material2/issues/6743\n * Maybe the better is to wait next release\n */\n@Injectable({providedIn: 'root'})\nexport class NaturalSidenavService extends NaturalAbstractController {\n    /**\n     * Navigation modes\n     * First is for desktop view\n     * Second is for mobile view\n     */\n    private modes: MatDrawerMode[] = ['side', 'push'];\n\n    /**\n     * Activated mode\n     * Default to desktop view\n     */\n    private mode: MatDrawerMode = this.modes[0];\n\n    /**\n     * Wherever is nav is opened or not\n     */\n    private opened = true;\n\n    /**\n     * Stores the opened status during mobile view, to restore if we come back to desktop view\n     */\n    private tmpOpened: boolean = this.opened;\n\n    /**\n     * Wherever is nav is minimized or not\n     */\n    private minimized = false;\n\n    /**\n     * LocalStorage key that stores the minimized status\n     */\n    private readonly minimizedStorageKey = 'menu-minimized';\n\n    /**\n     * LocalStorage key that stores the opened status\n     */\n    private readonly openedStorageKey = 'menu-opened';\n\n    private minimizedStorageKeyWithName: string | null = null;\n    private openedStorageKeyWithName: string | null = null;\n\n    public constructor(\n        public readonly mediaObserver: MediaObserver,\n        private readonly router: Router,\n        @Inject(SESSION_STORAGE) private readonly sessionStorage: NaturalStorage,\n        private readonly naturalSidenavStackService: NaturalSidenavStackService,\n    ) {\n        super();\n    }\n\n    public get activeMode(): MatDrawerMode {\n        return this.mode;\n    }\n\n    public get isOpened(): boolean {\n        return this.opened;\n    }\n\n    public get isMinimized(): boolean {\n        return this.minimized;\n    }\n\n    public destroy(component: NaturalSidenavContainerComponent): void {\n        this.naturalSidenavStackService.unregister(component);\n    }\n\n    public init(\n        name: string,\n        container: MatDrawerContainer,\n        drawer: MatDrawer,\n        component: NaturalSidenavContainerComponent,\n        autoClose = false,\n    ): void {\n        if (!name || name === '') {\n            throw new Error('No sidenav name provided, use <natural-sidenav-container name=\"menu\">');\n        }\n\n        this.naturalSidenavStackService.register(component);\n\n        this.minimizedStorageKeyWithName = name + '-' + this.minimizedStorageKey;\n        this.openedStorageKeyWithName = name + '-' + this.openedStorageKey;\n\n        // Init from LocalStorage\n        this.minimized = this.getMinimizedStatus();\n        this.opened = this.getMenuOpenedStatus();\n        this.tmpOpened = this.opened;\n\n        let oldIsBig: boolean | null = null;\n        this.mediaObserver\n            .asObservable()\n            .pipe(takeUntil(this.ngUnsubscribe))\n            .subscribe(() => {\n                const isBig = !this.isMobileView();\n                this.mode = isBig ? this.modes[0] : this.modes[1];\n\n                if (oldIsBig === null || isBig !== oldIsBig) {\n                    oldIsBig = isBig;\n\n                    // If decrease window size, save status of menu before closing it\n                    if (!isBig) {\n                        this.tmpOpened = this.opened;\n                        this.opened = false;\n                    }\n\n                    // If increase window size, and sidebar was open before, re-open it.\n                    if (isBig && this.tmpOpened) {\n                        this.opened = true;\n                        this.minimized = this.getMinimizedStatus();\n                    }\n                }\n            });\n\n        if (autoClose) {\n            this.router.events\n                .pipe(\n                    takeUntil(this.ngUnsubscribe),\n                    filter(e => e instanceof NavigationEnd),\n                )\n                .subscribe(() => {\n                    this.navItemClicked();\n                });\n        }\n    }\n\n    public isMobileView(): boolean {\n        return !this.mediaObserver.isActive('gt-sm');\n    }\n\n    /**\n     * Close nav on mobile view after a click\n     */\n    public navItemClicked(): void {\n        if (this.isMobileView()) {\n            this.close();\n        }\n    }\n\n    /**\n     * Change minimized status and stores the new value\n     */\n    public setMinimized(value: boolean): void {\n        this.minimized = value;\n        assert(this.minimizedStorageKeyWithName);\n        this.sessionStorage.setItem(this.minimizedStorageKeyWithName, value ? 'true' : 'false');\n    }\n\n    public minimize(): void {\n        this.setMinimized(true);\n    }\n\n    public expand(): void {\n        this.setMinimized(false);\n    }\n\n    public toggleMinimized(): void {\n        this.setMinimized(!this.minimized);\n    }\n\n    /**\n     * Get the stored minimized status\n     */\n    public getMinimizedStatus(): boolean {\n        assert(this.minimizedStorageKeyWithName);\n        const value = this.sessionStorage.getItem(this.minimizedStorageKeyWithName);\n\n        return value === null ? false : value === 'true';\n    }\n\n    /**\n     * Get the stored opened status\n     * Default on an opened status if nothing is stored\n     */\n    public getMenuOpenedStatus(): boolean {\n        assert(this.openedStorageKeyWithName);\n        const value = this.sessionStorage.getItem(this.openedStorageKeyWithName);\n\n        return value === null || value === 'true';\n    }\n\n    /**\n     * Toggle menu but expand it if mobile mode is activated\n     * Stores the status in local storage\n     */\n    public toggle(): void {\n        this.setOpened(!this.opened);\n    }\n\n    public close(): void {\n        this.setOpened(false);\n    }\n\n    public open(): void {\n        this.setOpened(true);\n    }\n\n    public setOpened(value: boolean): void {\n        this.opened = value;\n\n        if (this.opened && this.isMobileView()) {\n            this.minimized = false;\n        } else if (!this.isMobileView()) {\n            assert(this.openedStorageKeyWithName);\n            this.sessionStorage.setItem(this.openedStorageKeyWithName, this.opened ? 'true' : 'false');\n        }\n    }\n}\n"]}
@@ -24,7 +24,7 @@ export class NaturalTableButtonComponent {
24
24
  this.buttonClick = new EventEmitter();
25
25
  this.type = 'none';
26
26
  }
27
- ngOnChanges(changes) {
27
+ ngOnChanges() {
28
28
  if (this.navigate?.length || Object.keys(this.queryParams).length) {
29
29
  this.type = 'routerLink';
30
30
  }
@@ -67,4 +67,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImpor
67
67
  }], buttonClick: [{
68
68
  type: Output
69
69
  }] } });
70
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-button.component.js","sourceRoot":"","sources":["../../../../../../projects/natural/src/lib/modules/table-button/table-button.component.ts","../../../../../../projects/natural/src/lib/modules/table-button/table-button.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,YAAY,EAAE,KAAK,EAAa,MAAM,EAAiB,iBAAiB,EAAC,MAAM,eAAe,CAAC;;;;;;AAIlH;;;;;;;;;GASG;AAOH,MAAM,OAAO,2BAA2B;IANxC;QAOoB,gBAAW,GAAW,EAAE,CAAC;QACzB,wBAAmB,GAAwB,EAAE,CAAC;QAI9C,aAAQ,GAA6B,EAAE,CAAC;QAExC,qBAAgB,GAAG,KAAK,CAAC;QACzB,WAAM,GAAG,KAAK,CAAC;QAEL,gBAAW,GAAG,IAAI,YAAY,EAAc,CAAC;QAChE,SAAI,GAA6C,MAAM,CAAC;KAalE;IAXU,WAAW,CAAC,OAAsB;QACrC,IAAI,IAAI,CAAC,QAAQ,EAAE,MAAM,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,MAAM,EAAE;YAC/D,IAAI,CAAC,IAAI,GAAG,YAAY,CAAC;SAC5B;aAAM,IAAI,IAAI,CAAC,IAAI,EAAE;YAClB,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC;SACtB;aAAM,IAAI,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE;YAClC,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC;SACvB;aAAM;YACH,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC;SACtB;IACL,CAAC;;wHAxBQ,2BAA2B;4GAA3B,2BAA2B,8WCpBxC,u5IA8HA;2FD1Ga,2BAA2B;kBANvC,SAAS;+BACI,sBAAsB,iBAGjB,iBAAiB,CAAC,IAAI;8BAGrB,WAAW;sBAA1B,KAAK;gBACU,mBAAmB;sBAAlC,KAAK;gBACU,KAAK;sBAApB,KAAK;gBACU,IAAI;sBAAnB,KAAK;gBACU,IAAI;sBAAnB,KAAK;gBACU,QAAQ;sBAAvB,KAAK;gBACU,QAAQ;sBAAvB,KAAK;gBACU,gBAAgB;sBAA/B,KAAK;gBACU,MAAM;sBAArB,KAAK;gBACU,KAAK;sBAApB,KAAK;gBACoB,WAAW;sBAApC,MAAM","sourcesContent":["import {Component, EventEmitter, Input, OnChanges, Output, SimpleChanges, ViewEncapsulation} from '@angular/core';\nimport {Params, QueryParamsHandling, RouterLink} from '@angular/router';\nimport {ThemePalette} from '@angular/material/core';\n\n/**\n * Button that fits well in a `<mat-table>` and support either\n * route navigation via `navigate`, or external URL via `href`,\n * or callback via `buttonClick`.\n *\n * If neither `navigate` nor `href` nor `buttonClick` have a meaningful value, then\n * it will show the icon and/or label in a `<span>` instead of a button.\n *\n * External URL will always be opened in new tab.\n */\n@Component({\n    selector: 'natural-table-button',\n    templateUrl: './table-button.component.html',\n    styleUrls: ['./table-button.component.scss'],\n    encapsulation: ViewEncapsulation.None,\n})\nexport class NaturalTableButtonComponent implements OnChanges {\n    @Input() public queryParams: Params = {};\n    @Input() public queryParamsHandling: QueryParamsHandling = '';\n    @Input() public label?: string | null;\n    @Input() public icon?: string | null;\n    @Input() public href?: string | null;\n    @Input() public navigate: RouterLink['routerLink'] = [];\n    @Input() public fragment?: string | undefined;\n    @Input() public preserveFragment = false;\n    @Input() public raised = false;\n    @Input() public color: ThemePalette;\n    @Output() public readonly buttonClick = new EventEmitter<MouseEvent>();\n    public type: 'routerLink' | 'href' | 'click' | 'none' = 'none';\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        if (this.navigate?.length || Object.keys(this.queryParams).length) {\n            this.type = 'routerLink';\n        } else if (this.href) {\n            this.type = 'href';\n        } else if (this.buttonClick.observed) {\n            this.type = 'click';\n        } else {\n            this.type = 'none';\n        }\n    }\n}\n","<!-- Because directives can't be applied conditionally (routerLink, mat-button and mat-icon-button), we have to use different elements -->\n\n<!-- Edge case of a button without any kind of link at all -->\n<span *ngIf=\"type === 'none'\">\n    <natural-icon *ngIf=\"icon\" [name]=\"icon\"></natural-icon>\n    <span *ngIf=\"label\">{{ label }}</span>\n</span>\n\n<ng-container *ngIf=\"!raised\">\n    <!-- App routed link with label... -->\n    <a\n        *ngIf=\"type === 'routerLink' && label\"\n        [color]=\"color\"\n        [queryParams]=\"queryParams\"\n        [queryParamsHandling]=\"queryParamsHandling\"\n        [routerLink]=\"navigate\"\n        [fragment]=\"fragment\"\n        [preserveFragment]=\"preserveFragment\"\n        mat-button\n    >\n        <natural-icon *ngIf=\"icon\" [name]=\"icon\"></natural-icon>\n        <span>{{ label }}</span>\n    </a>\n\n    <!-- ... and without label -->\n    <a\n        *ngIf=\"type === 'routerLink' && !label\"\n        [color]=\"color\"\n        [queryParams]=\"queryParams\"\n        [queryParamsHandling]=\"queryParamsHandling\"\n        [routerLink]=\"navigate\"\n        [fragment]=\"fragment\"\n        [preserveFragment]=\"preserveFragment\"\n        mat-icon-button\n    >\n        <natural-icon *ngIf=\"icon\" [name]=\"icon\"></natural-icon>\n    </a>\n\n    <!-- Click with label... -->\n    <a *ngIf=\"type === 'click' && label\" [color]=\"color\" (click)=\"buttonClick.emit($event)\" mat-button>\n        <natural-icon *ngIf=\"icon\" [name]=\"icon\"></natural-icon>\n        <span>{{ label }}</span>\n    </a>\n\n    <!-- ... and without label -->\n    <a *ngIf=\"type === 'click' && !label\" (click)=\"buttonClick.emit($event)\" mat-icon-button>\n        <natural-icon *ngIf=\"icon\" [name]=\"icon\"></natural-icon>\n    </a>\n\n    <!-- External link with label... -->\n    <a *ngIf=\"type === 'href' && label\" [attr.href]=\"href\" [color]=\"color\" mat-button target=\"_blank\">\n        <natural-icon *ngIf=\"icon\" [name]=\"icon\"></natural-icon>\n        <span>{{ label }}</span>\n    </a>\n\n    <!-- ... and without label -->\n    <a *ngIf=\"type === 'href' && !label\" [attr.href]=\"href\" [color]=\"color\" mat-icon-button target=\"_blank\">\n        <natural-icon *ngIf=\"icon\" [name]=\"icon\"></natural-icon>\n    </a>\n</ng-container>\n\n<ng-container *ngIf=\"raised\">\n    <!-- App routed link with label... -->\n    <a\n        *ngIf=\"type === 'routerLink' && label\"\n        [color]=\"color\"\n        [queryParams]=\"queryParams\"\n        [queryParamsHandling]=\"queryParamsHandling\"\n        [routerLink]=\"navigate\"\n        [fragment]=\"fragment\"\n        [preserveFragment]=\"preserveFragment\"\n        mat-raised-button\n    >\n        <natural-icon *ngIf=\"icon\" [name]=\"icon\"></natural-icon>\n        <span>{{ label }}</span>\n    </a>\n\n    <!-- ... and without label -->\n    <a\n        *ngIf=\"type === 'routerLink' && !label\"\n        [color]=\"color\"\n        [queryParams]=\"queryParams\"\n        [queryParamsHandling]=\"queryParamsHandling\"\n        [routerLink]=\"navigate\"\n        [fragment]=\"fragment\"\n        [preserveFragment]=\"preserveFragment\"\n        mat-icon-button\n        mat-raised-button\n    >\n        <natural-icon *ngIf=\"icon\" [name]=\"icon\"></natural-icon>\n    </a>\n    <!-- Click with label... -->\n    <a *ngIf=\"type === 'click' && label\" [color]=\"color\" (click)=\"buttonClick.emit($event)\" mat-raised-button>\n        <natural-icon *ngIf=\"icon\" [name]=\"icon\"></natural-icon>\n        <span>{{ label }}</span>\n    </a>\n\n    <!-- ... and without label -->\n    <a\n        *ngIf=\"type === 'click' && !label\"\n        [color]=\"color\"\n        (click)=\"buttonClick.emit($event)\"\n        mat-icon-button\n        mat-raised-button\n    >\n        <natural-icon *ngIf=\"icon\" [name]=\"icon\"></natural-icon>\n    </a>\n\n    <!-- External link with label... -->\n    <a *ngIf=\"type === 'href' && label\" [attr.href]=\"href\" [color]=\"color\" mat-raised-button target=\"_blank\">\n        <natural-icon *ngIf=\"icon\" [name]=\"icon\"></natural-icon>\n        <span>{{ label }}</span>\n    </a>\n\n    <!-- ... and without label -->\n    <a\n        *ngIf=\"type === 'href' && !label\"\n        [attr.href]=\"href\"\n        [color]=\"color\"\n        mat-icon-button\n        mat-raised-button\n        target=\"_blank\"\n    >\n        <natural-icon *ngIf=\"icon\" [name]=\"icon\"></natural-icon>\n    </a>\n</ng-container>\n"]}
70
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-button.component.js","sourceRoot":"","sources":["../../../../../../projects/natural/src/lib/modules/table-button/table-button.component.ts","../../../../../../projects/natural/src/lib/modules/table-button/table-button.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,YAAY,EAAE,KAAK,EAAa,MAAM,EAAE,iBAAiB,EAAC,MAAM,eAAe,CAAC;;;;;;AAInG;;;;;;;;;GASG;AAOH,MAAM,OAAO,2BAA2B;IANxC;QAOoB,gBAAW,GAAW,EAAE,CAAC;QACzB,wBAAmB,GAAwB,EAAE,CAAC;QAI9C,aAAQ,GAA6B,EAAE,CAAC;QAExC,qBAAgB,GAAG,KAAK,CAAC;QACzB,WAAM,GAAG,KAAK,CAAC;QAEL,gBAAW,GAAG,IAAI,YAAY,EAAc,CAAC;QAChE,SAAI,GAA6C,MAAM,CAAC;KAalE;IAXU,WAAW;QACd,IAAI,IAAI,CAAC,QAAQ,EAAE,MAAM,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,MAAM,EAAE;YAC/D,IAAI,CAAC,IAAI,GAAG,YAAY,CAAC;SAC5B;aAAM,IAAI,IAAI,CAAC,IAAI,EAAE;YAClB,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC;SACtB;aAAM,IAAI,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE;YAClC,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC;SACvB;aAAM;YACH,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC;SACtB;IACL,CAAC;;wHAxBQ,2BAA2B;4GAA3B,2BAA2B,8WCpBxC,u5IA8HA;2FD1Ga,2BAA2B;kBANvC,SAAS;+BACI,sBAAsB,iBAGjB,iBAAiB,CAAC,IAAI;8BAGrB,WAAW;sBAA1B,KAAK;gBACU,mBAAmB;sBAAlC,KAAK;gBACU,KAAK;sBAApB,KAAK;gBACU,IAAI;sBAAnB,KAAK;gBACU,IAAI;sBAAnB,KAAK;gBACU,QAAQ;sBAAvB,KAAK;gBACU,QAAQ;sBAAvB,KAAK;gBACU,gBAAgB;sBAA/B,KAAK;gBACU,MAAM;sBAArB,KAAK;gBACU,KAAK;sBAApB,KAAK;gBACoB,WAAW;sBAApC,MAAM","sourcesContent":["import {Component, EventEmitter, Input, OnChanges, Output, ViewEncapsulation} from '@angular/core';\nimport {Params, QueryParamsHandling, RouterLink} from '@angular/router';\nimport {ThemePalette} from '@angular/material/core';\n\n/**\n * Button that fits well in a `<mat-table>` and support either\n * route navigation via `navigate`, or external URL via `href`,\n * or callback via `buttonClick`.\n *\n * If neither `navigate` nor `href` nor `buttonClick` have a meaningful value, then\n * it will show the icon and/or label in a `<span>` instead of a button.\n *\n * External URL will always be opened in new tab.\n */\n@Component({\n    selector: 'natural-table-button',\n    templateUrl: './table-button.component.html',\n    styleUrls: ['./table-button.component.scss'],\n    encapsulation: ViewEncapsulation.None,\n})\nexport class NaturalTableButtonComponent implements OnChanges {\n    @Input() public queryParams: Params = {};\n    @Input() public queryParamsHandling: QueryParamsHandling = '';\n    @Input() public label?: string | null;\n    @Input() public icon?: string | null;\n    @Input() public href?: string | null;\n    @Input() public navigate: RouterLink['routerLink'] = [];\n    @Input() public fragment?: string | undefined;\n    @Input() public preserveFragment = false;\n    @Input() public raised = false;\n    @Input() public color: ThemePalette;\n    @Output() public readonly buttonClick = new EventEmitter<MouseEvent>();\n    public type: 'routerLink' | 'href' | 'click' | 'none' = 'none';\n\n    public ngOnChanges(): void {\n        if (this.navigate?.length || Object.keys(this.queryParams).length) {\n            this.type = 'routerLink';\n        } else if (this.href) {\n            this.type = 'href';\n        } else if (this.buttonClick.observed) {\n            this.type = 'click';\n        } else {\n            this.type = 'none';\n        }\n    }\n}\n","<!-- Because directives can't be applied conditionally (routerLink, mat-button and mat-icon-button), we have to use different elements -->\n\n<!-- Edge case of a button without any kind of link at all -->\n<span *ngIf=\"type === 'none'\">\n    <natural-icon *ngIf=\"icon\" [name]=\"icon\"></natural-icon>\n    <span *ngIf=\"label\">{{ label }}</span>\n</span>\n\n<ng-container *ngIf=\"!raised\">\n    <!-- App routed link with label... -->\n    <a\n        *ngIf=\"type === 'routerLink' && label\"\n        [color]=\"color\"\n        [queryParams]=\"queryParams\"\n        [queryParamsHandling]=\"queryParamsHandling\"\n        [routerLink]=\"navigate\"\n        [fragment]=\"fragment\"\n        [preserveFragment]=\"preserveFragment\"\n        mat-button\n    >\n        <natural-icon *ngIf=\"icon\" [name]=\"icon\"></natural-icon>\n        <span>{{ label }}</span>\n    </a>\n\n    <!-- ... and without label -->\n    <a\n        *ngIf=\"type === 'routerLink' && !label\"\n        [color]=\"color\"\n        [queryParams]=\"queryParams\"\n        [queryParamsHandling]=\"queryParamsHandling\"\n        [routerLink]=\"navigate\"\n        [fragment]=\"fragment\"\n        [preserveFragment]=\"preserveFragment\"\n        mat-icon-button\n    >\n        <natural-icon *ngIf=\"icon\" [name]=\"icon\"></natural-icon>\n    </a>\n\n    <!-- Click with label... -->\n    <a *ngIf=\"type === 'click' && label\" [color]=\"color\" (click)=\"buttonClick.emit($event)\" mat-button>\n        <natural-icon *ngIf=\"icon\" [name]=\"icon\"></natural-icon>\n        <span>{{ label }}</span>\n    </a>\n\n    <!-- ... and without label -->\n    <a *ngIf=\"type === 'click' && !label\" (click)=\"buttonClick.emit($event)\" mat-icon-button>\n        <natural-icon *ngIf=\"icon\" [name]=\"icon\"></natural-icon>\n    </a>\n\n    <!-- External link with label... -->\n    <a *ngIf=\"type === 'href' && label\" [attr.href]=\"href\" [color]=\"color\" mat-button target=\"_blank\">\n        <natural-icon *ngIf=\"icon\" [name]=\"icon\"></natural-icon>\n        <span>{{ label }}</span>\n    </a>\n\n    <!-- ... and without label -->\n    <a *ngIf=\"type === 'href' && !label\" [attr.href]=\"href\" [color]=\"color\" mat-icon-button target=\"_blank\">\n        <natural-icon *ngIf=\"icon\" [name]=\"icon\"></natural-icon>\n    </a>\n</ng-container>\n\n<ng-container *ngIf=\"raised\">\n    <!-- App routed link with label... -->\n    <a\n        *ngIf=\"type === 'routerLink' && label\"\n        [color]=\"color\"\n        [queryParams]=\"queryParams\"\n        [queryParamsHandling]=\"queryParamsHandling\"\n        [routerLink]=\"navigate\"\n        [fragment]=\"fragment\"\n        [preserveFragment]=\"preserveFragment\"\n        mat-raised-button\n    >\n        <natural-icon *ngIf=\"icon\" [name]=\"icon\"></natural-icon>\n        <span>{{ label }}</span>\n    </a>\n\n    <!-- ... and without label -->\n    <a\n        *ngIf=\"type === 'routerLink' && !label\"\n        [color]=\"color\"\n        [queryParams]=\"queryParams\"\n        [queryParamsHandling]=\"queryParamsHandling\"\n        [routerLink]=\"navigate\"\n        [fragment]=\"fragment\"\n        [preserveFragment]=\"preserveFragment\"\n        mat-icon-button\n        mat-raised-button\n    >\n        <natural-icon *ngIf=\"icon\" [name]=\"icon\"></natural-icon>\n    </a>\n    <!-- Click with label... -->\n    <a *ngIf=\"type === 'click' && label\" [color]=\"color\" (click)=\"buttonClick.emit($event)\" mat-raised-button>\n        <natural-icon *ngIf=\"icon\" [name]=\"icon\"></natural-icon>\n        <span>{{ label }}</span>\n    </a>\n\n    <!-- ... and without label -->\n    <a\n        *ngIf=\"type === 'click' && !label\"\n        [color]=\"color\"\n        (click)=\"buttonClick.emit($event)\"\n        mat-icon-button\n        mat-raised-button\n    >\n        <natural-icon *ngIf=\"icon\" [name]=\"icon\"></natural-icon>\n    </a>\n\n    <!-- External link with label... -->\n    <a *ngIf=\"type === 'href' && label\" [attr.href]=\"href\" [color]=\"color\" mat-raised-button target=\"_blank\">\n        <natural-icon *ngIf=\"icon\" [name]=\"icon\"></natural-icon>\n        <span>{{ label }}</span>\n    </a>\n\n    <!-- ... and without label -->\n    <a\n        *ngIf=\"type === 'href' && !label\"\n        [attr.href]=\"href\"\n        [color]=\"color\"\n        mat-icon-button\n        mat-raised-button\n        target=\"_blank\"\n    >\n        <natural-icon *ngIf=\"icon\" [name]=\"icon\"></natural-icon>\n    </a>\n</ng-container>\n"]}