@ecodev/natural 42.4.0 → 43.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 (28) hide show
  1. package/esm2020/lib/classes/query-variable-manager.mjs +2 -2
  2. package/esm2020/lib/classes/rxjs.mjs +2 -1
  3. package/esm2020/lib/modules/columns-picker/columns-picker-column.directive.mjs +6 -2
  4. package/esm2020/lib/modules/common/directives/linkable-tab.directive.mjs +2 -2
  5. package/esm2020/lib/modules/logger/error-handler.mjs +26 -11
  6. package/esm2020/lib/modules/logger/public-api.mjs +3 -3
  7. package/esm2020/lib/modules/relations/relations.component.mjs +9 -4
  8. package/esm2020/lib/modules/search/dropdown-container/dropdown-container.component.mjs +3 -3
  9. package/esm2020/lib/modules/search/dropdown-container/dropdown.service.mjs +1 -1
  10. package/esm2020/lib/modules/search/input/input.component.mjs +3 -1
  11. package/esm2020/lib/modules/sidenav/sidenav-container/sidenav-container.component.mjs +4 -5
  12. package/esm2020/lib/modules/table-button/table-button.component.mjs +21 -6
  13. package/esm2020/lib/services/abstract-model.service.mjs +45 -39
  14. package/fesm2015/ecodev-natural.mjs +112 -63
  15. package/fesm2015/ecodev-natural.mjs.map +1 -1
  16. package/fesm2020/ecodev-natural.mjs +109 -62
  17. package/fesm2020/ecodev-natural.mjs.map +1 -1
  18. package/lib/modules/columns-picker/columns-picker-column.directive.d.ts +1 -1
  19. package/lib/modules/logger/error-handler.d.ts +19 -3
  20. package/lib/modules/logger/public-api.d.ts +2 -2
  21. package/lib/modules/relations/relations.component.d.ts +1 -0
  22. package/lib/modules/search/dropdown-container/dropdown-container.component.d.ts +1 -1
  23. package/lib/modules/search/dropdown-container/dropdown.service.d.ts +1 -1
  24. package/lib/modules/search/input/input.component.d.ts +2 -2
  25. package/lib/modules/sidenav/sidenav-container/sidenav-container.component.d.ts +2 -3
  26. package/lib/modules/table-button/table-button.component.d.ts +9 -6
  27. package/lib/services/abstract-model.service.d.ts +2 -2
  28. package/package.json +1 -1
@@ -90,4 +90,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.0", ngImpor
90
90
  providedIn: 'root',
91
91
  }]
92
92
  }], ctorParameters: function () { return [{ type: i1.Overlay }, { type: i0.Injector }]; } });
93
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.service.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/search/dropdown-container/dropdown.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAA6C,aAAa,EAAC,MAAM,sBAAsB,CAAC;AAC/F,OAAO,EAAC,eAAe,EAAgB,MAAM,qBAAqB,CAAC;AACnE,OAAO,EAA2B,UAAU,EAAE,cAAc,EAAE,QAAQ,EAAiB,MAAM,eAAe,CAAC;AAC7G,OAAO,EAAC,SAAS,EAAC,MAAM,gBAAgB,CAAC;AAEzC,OAAO,EACH,+BAA+B,EAC/B,iCAAiC,GAEpC,MAAM,gCAAgC,CAAC;AACxC,OAAO,EAAC,kBAAkB,EAAC,MAAM,gBAAgB,CAAC;;;AAQlD,MAAM,CAAC,MAAM,qBAAqB,GAAG,IAAI,cAAc,CAAsB,qBAAqB,CAAC,CAAC;AAKpG,MAAM,OAAO,sBAAsB;IAC/B,YAAoC,OAAgB,EAAmB,QAAkB;QAArD,YAAO,GAAP,OAAO,CAAS;QAAmB,aAAQ,GAAR,QAAQ,CAAU;IAAG,CAAC;IAEtF,IAAI,CACP,SAA2C,EAC3C,gBAA4B,EAC5B,eAAiC,EACjC,kBAA2B;QAE3B,iBAAiB;QACjB,MAAM,aAAa,GAAiC;YAChD,kBAAkB,EAAE,kBAAkB;SACzC,CAAC;QAEF,MAAM,eAAe,GAAqB;YACtC;gBACI,OAAO,EAAE,+BAA+B;gBACxC,QAAQ,EAAE,aAAa;aAC1B;SACJ,CAAC;QAEF,MAAM,iBAAiB,GAAG,QAAQ,CAAC,MAAM,CAAC,EAAC,SAAS,EAAE,eAAe,EAAE,MAAM,EAAE,IAAI,CAAC,QAAQ,EAAC,CAAC,CAAC;QAE/F,YAAY;QACZ,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,gBAAgB,CAAC,CAAC,CAAC;QAChF,MAAM,eAAe,GAAG,IAAI,eAAe,CAAC,iCAAiC,EAAE,SAAS,EAAE,iBAAiB,CAAC,CAAC;QAC7G,MAAM,YAAY,GAAoD,UAAU,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;QAEzG,MAAM,iBAAiB,GAAG,YAAY,CAAC,QAAQ,CAAC;QAChD,MAAM,WAAW,GAAG,IAAI,kBAAkB,CACtC,iBAAiB,EACjB,SAAS,EACT,eAAe,EACf,IAAI,CAAC,QAAQ,EACb,YAAY,CACf,CAAC;QAEF,kCAAkC;QAClC,iBAAiB,CAAC,cAAc,EAAE,CAAC;QAEnC,MAAM,KAAK,GAAG,GAAS,EAAE;YACrB,IAAI,WAAW,CAAC,iBAAiB,CAAC,OAAO,EAAE,IAAI,WAAW,CAAC,iBAAiB,CAAC,OAAO,EAAE,EAAE;gBACpF,WAAW,CAAC,KAAK,CAAC;oBACd,SAAS,EAAE,WAAW,CAAC,iBAAiB,CAAC,YAAY,EAAE;iBAC1D,CAAC,CAAC;aACN;iBAAM;gBACH,WAAW,CAAC,KAAK,EAAE,CAAC;aACvB;QACL,CAAC,CAAC;QAEF,uEAAuE;QACvE,iBAAiB,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,EAAE;YACpC,UAAU,CAAC,OAAO,EAAE,CAAC;YACrB,KAAK,EAAE,CAAC;QACZ,CAAC,CAAC,CAAC;QAEH,8CAA8C;QAC9C,UAAU;aACL,aAAa,EAAE;aACf,IAAI,CAAC,SAAS,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC;aACzC,SAAS,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC,KAAK,EAAE,CAAC,CAAC;QAEhD,OAAO,WAAW,CAAC;IACvB,CAAC;IAED;;OAEG;IACK,gBAAgB,CAAC,OAAmB;QACxC,OAAO,IAAI,aAAa,CAAC;YACrB,gBAAgB,EAAE,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC;YAC3C,WAAW,EAAE,IAAI;YACjB,aAAa,EAAE,kCAAkC;SACpD,CAAC,CAAC;IACP,CAAC;IAEO,WAAW,CAAC,OAAmB;QACnC,OAAO,IAAI,CAAC,OAAO;aACd,QAAQ,EAAE;aACV,mBAAmB,CAAC,OAAO,CAAC;aAC5B,sBAAsB,CAAC,IAAI,CAAC;aAC5B,kBAAkB,CAAC,EAAE,CAAC;aACtB,QAAQ,CAAC,KAAK,CAAC;aACf,aAAa,CAAC;YACX;gBACI,OAAO,EAAE,OAAO;gBAChB,OAAO,EAAE,QAAQ;gBACjB,QAAQ,EAAE,OAAO;gBACjB,QAAQ,EAAE,KAAK;gBACf,OAAO,EAAE,EAAE;aACd;SACJ,CAAC,CAAC;IACX,CAAC;;mHA5FQ,sBAAsB;uHAAtB,sBAAsB,cAFnB,MAAM;2FAET,sBAAsB;kBAHlC,UAAU;mBAAC;oBACR,UAAU,EAAE,MAAM;iBACrB","sourcesContent":["import {FlexibleConnectedPositionStrategy, Overlay, OverlayConfig} from '@angular/cdk/overlay';\nimport {ComponentPortal, ComponentType} from '@angular/cdk/portal';\nimport {ComponentRef, ElementRef, Injectable, InjectionToken, Injector, StaticProvider} from '@angular/core';\nimport {takeUntil} from 'rxjs/operators';\nimport {FilterGroupConditionField} from '../classes/graphql-doctrine.types';\nimport {\n    NATURAL_DROPDOWN_CONTAINER_DATA,\n    NaturalDropdownContainerComponent,\n    NaturalDropdownContainerData,\n} from './dropdown-container.component';\nimport {NaturalDropdownRef} from './dropdown-ref';\nimport {DropdownComponent} from '../types/dropdown-component';\n\nexport interface NaturalDropdownData<C = any> {\n    condition: FilterGroupConditionField | null;\n    configuration: C;\n}\n\nexport const NATURAL_DROPDOWN_DATA = new InjectionToken<NaturalDropdownData>('NaturalDropdownData');\n\n@Injectable({\n    providedIn: 'root',\n})\nexport class NaturalDropdownService {\n    public constructor(private readonly overlay: Overlay, private readonly injector: Injector) {}\n\n    public open(\n        component: ComponentType<DropdownComponent>,\n        connectedElement: ElementRef,\n        customProviders: StaticProvider[],\n        showValidateButton: boolean,\n    ): NaturalDropdownRef {\n        // Container data\n        const containerData: NaturalDropdownContainerData = {\n            showValidateButton: showValidateButton,\n        };\n\n        const injectionTokens: StaticProvider[] = [\n            {\n                provide: NATURAL_DROPDOWN_CONTAINER_DATA,\n                useValue: containerData,\n            },\n        ];\n\n        const containerInjector = Injector.create({providers: injectionTokens, parent: this.injector});\n\n        // Container\n        const overlayRef = this.overlay.create(this.getOverlayConfig(connectedElement));\n        const containerPortal = new ComponentPortal(NaturalDropdownContainerComponent, undefined, containerInjector);\n        const containerRef: ComponentRef<NaturalDropdownContainerComponent> = overlayRef.attach(containerPortal);\n\n        const dropdownContainer = containerRef.instance;\n        const dropdownRef = new NaturalDropdownRef(\n            dropdownContainer,\n            component,\n            customProviders,\n            this.injector,\n            containerRef,\n        );\n\n        // Start animation that shows menu\n        dropdownContainer.startAnimation();\n\n        const close = (): void => {\n            if (dropdownRef.componentInstance.isValid() && dropdownRef.componentInstance.isDirty()) {\n                dropdownRef.close({\n                    condition: dropdownRef.componentInstance.getCondition(),\n                });\n            } else {\n                dropdownRef.close();\n            }\n        };\n\n        // When parent closes, remove overlay from dom and update \"return\" valu\n        dropdownContainer.closed.subscribe(() => {\n            overlayRef.dispose();\n            close();\n        });\n\n        // When click on backdrop, validate result.. ?\n        overlayRef\n            .backdropClick()\n            .pipe(takeUntil(dropdownContainer.closed))\n            .subscribe(() => dropdownContainer.close());\n\n        return dropdownRef;\n    }\n\n    /**\n     * This method builds the configuration object needed to create the overlay, the OverlayState.\n     */\n    private getOverlayConfig(element: ElementRef): OverlayConfig {\n        return new OverlayConfig({\n            positionStrategy: this.getPosition(element),\n            hasBackdrop: true,\n            backdropClass: 'cdk-overlay-transparent-backdrop',\n        });\n    }\n\n    private getPosition(element: ElementRef): FlexibleConnectedPositionStrategy {\n        return this.overlay\n            .position()\n            .flexibleConnectedTo(element)\n            .withFlexibleDimensions(true)\n            .withViewportMargin(30)\n            .withPush(false)\n            .withPositions([\n                {\n                    originX: 'start',\n                    originY: 'bottom',\n                    overlayX: 'start',\n                    overlayY: 'top',\n                    offsetY: 10,\n                },\n            ]);\n    }\n}\n"]}
93
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.service.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/search/dropdown-container/dropdown.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {FlexibleConnectedPositionStrategy, Overlay, OverlayConfig} from '@angular/cdk/overlay';\nimport {ComponentPortal, ComponentType} from '@angular/cdk/portal';\nimport {ComponentRef, ElementRef, Injectable, InjectionToken, Injector, StaticProvider} from '@angular/core';\nimport {takeUntil} from 'rxjs/operators';\nimport {FilterGroupConditionField} from '../classes/graphql-doctrine.types';\nimport {\n    NATURAL_DROPDOWN_CONTAINER_DATA,\n    NaturalDropdownContainerComponent,\n    NaturalDropdownContainerData,\n} from './dropdown-container.component';\nimport {NaturalDropdownRef} from './dropdown-ref';\nimport {DropdownComponent} from '../types/dropdown-component';\n\nexport interface NaturalDropdownData<C = any> {\n    condition: FilterGroupConditionField | null;\n    configuration: C;\n}\n\nexport const NATURAL_DROPDOWN_DATA = new InjectionToken<NaturalDropdownData>('NaturalDropdownData');\n\n@Injectable({\n    providedIn: 'root',\n})\nexport class NaturalDropdownService {\n    public constructor(private readonly overlay: Overlay, private readonly injector: Injector) {}\n\n    public open(\n        component: ComponentType<DropdownComponent>,\n        connectedElement: ElementRef<HTMLElement>,\n        customProviders: StaticProvider[],\n        showValidateButton: boolean,\n    ): NaturalDropdownRef {\n        // Container data\n        const containerData: NaturalDropdownContainerData = {\n            showValidateButton: showValidateButton,\n        };\n\n        const injectionTokens: StaticProvider[] = [\n            {\n                provide: NATURAL_DROPDOWN_CONTAINER_DATA,\n                useValue: containerData,\n            },\n        ];\n\n        const containerInjector = Injector.create({providers: injectionTokens, parent: this.injector});\n\n        // Container\n        const overlayRef = this.overlay.create(this.getOverlayConfig(connectedElement));\n        const containerPortal = new ComponentPortal(NaturalDropdownContainerComponent, undefined, containerInjector);\n        const containerRef: ComponentRef<NaturalDropdownContainerComponent> = overlayRef.attach(containerPortal);\n\n        const dropdownContainer = containerRef.instance;\n        const dropdownRef = new NaturalDropdownRef(\n            dropdownContainer,\n            component,\n            customProviders,\n            this.injector,\n            containerRef,\n        );\n\n        // Start animation that shows menu\n        dropdownContainer.startAnimation();\n\n        const close = (): void => {\n            if (dropdownRef.componentInstance.isValid() && dropdownRef.componentInstance.isDirty()) {\n                dropdownRef.close({\n                    condition: dropdownRef.componentInstance.getCondition(),\n                });\n            } else {\n                dropdownRef.close();\n            }\n        };\n\n        // When parent closes, remove overlay from dom and update \"return\" valu\n        dropdownContainer.closed.subscribe(() => {\n            overlayRef.dispose();\n            close();\n        });\n\n        // When click on backdrop, validate result.. ?\n        overlayRef\n            .backdropClick()\n            .pipe(takeUntil(dropdownContainer.closed))\n            .subscribe(() => dropdownContainer.close());\n\n        return dropdownRef;\n    }\n\n    /**\n     * This method builds the configuration object needed to create the overlay, the OverlayState.\n     */\n    private getOverlayConfig(element: ElementRef<HTMLElement>): OverlayConfig {\n        return new OverlayConfig({\n            positionStrategy: this.getPosition(element),\n            hasBackdrop: true,\n            backdropClass: 'cdk-overlay-transparent-backdrop',\n        });\n    }\n\n    private getPosition(element: ElementRef<HTMLElement>): FlexibleConnectedPositionStrategy {\n        return this.overlay\n            .position()\n            .flexibleConnectedTo(element)\n            .withFlexibleDimensions(true)\n            .withViewportMargin(30)\n            .withPush(false)\n            .withPositions([\n                {\n                    originX: 'start',\n                    originY: 'bottom',\n                    overlayX: 'start',\n                    overlayY: 'top',\n                    offsetY: 10,\n                },\n            ]);\n    }\n}\n"]}
@@ -201,6 +201,8 @@ export class NaturalInputComponent {
201
201
  configuration: facet.configuration,
202
202
  };
203
203
  const injector = Injector.create({ providers: this.createProviders(data), parent: this.injector });
204
+ // TODO replace by this when https://github.com/angular/angular/commit/d1e83e1b30f2cea9f2ed16bff2d3b969335072ab is released
205
+ // this.dropdownComponentRef = createComponent(facet.component, {environmentInjector: injector});
204
206
  const factory = this.componentFactoryResolver.resolveComponentFactory(facet.component);
205
207
  this.dropdownComponentRef = factory.create(injector);
206
208
  return this.dropdownComponentRef.instance;
@@ -325,4 +327,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.0", ngImpor
325
327
  type: HostListener,
326
328
  args: ['focus']
327
329
  }] } });
328
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/search/input/input.component.ts","../../../../../../../projects/natural/src/lib/modules/search/input/input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ComponentFactoryResolver,\n    ComponentRef,\n    ElementRef,\n    EventEmitter,\n    HostListener,\n    Injector,\n    Input,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Output,\n    SimpleChanges,\n    StaticProvider,\n    ViewChild,\n} from '@angular/core';\nimport {FormControl, FormGroupDirective, NgForm, ValidationErrors, ValidatorFn} from '@angular/forms';\nimport {ErrorStateMatcher, MatRipple} from '@angular/material/core';\nimport {FilterGroupConditionField} from '../classes/graphql-doctrine.types';\nimport {getFacetFromSelection} from '../classes/utils';\nimport {NaturalDropdownRef} from '../dropdown-container/dropdown-ref';\nimport {\n    NATURAL_DROPDOWN_DATA,\n    NaturalDropdownData,\n    NaturalDropdownService,\n} from '../dropdown-container/dropdown.service';\nimport {FacetSelectorComponent, FacetSelectorConfiguration} from '../facet-selector/facet-selector.component';\nimport {DropdownComponent} from '../types/dropdown-component';\nimport {DropdownFacet, Facet, FlagFacet, NaturalSearchFacets} from '../types/facet';\nimport {DropdownResult, NaturalSearchSelection} from '../types/values';\n\n// Required to check invalid fields when initializing natural-search\nexport class AlwaysErrorStateMatcher implements ErrorStateMatcher {\n    public isErrorState(control: FormControl | null, form: FormGroupDirective | NgForm | null): boolean {\n        return !!control && control.invalid;\n    }\n}\n\nfunction isComponentValid(component: DropdownComponent): ValidatorFn {\n    return (): ValidationErrors | null => {\n        if (!component.isValid()) {\n            return {component: true};\n        }\n\n        return null;\n    };\n}\n\n@Component({\n    selector: 'natural-input',\n    templateUrl: './input.component.html',\n    styleUrls: ['./input.component.scss'],\n})\nexport class NaturalInputComponent implements OnInit, OnChanges, OnDestroy {\n    /**\n     * Controls the ripple effect, used when opening a dropdown\n     */\n    @ViewChild(MatRipple, {static: true}) public ripple!: MatRipple;\n\n    /**\n     * Native element ref for <input> related to this <natural-input> component\n     */\n    @ViewChild('input', {static: true}) public input!: ElementRef;\n\n    /**\n     * Label for this field\n     */\n    @Input() public placeholder?: string;\n\n    /**\n     * Name of the field on which do a global search (without facet)\n     */\n    @Input() public searchFieldName = 'search';\n\n    /**\n     * Selected setted for this component\n     */\n    @Input() public selection: NaturalSearchSelection | null = null;\n\n    /**\n     * Available facets, allows the user to pick one, than generated then a selection\n     */\n    @Input() public facets!: NaturalSearchFacets;\n\n    /**\n     * Emits when user a added/updated/deleted a search (from global context or from facet)\n     */\n    @Output() public readonly selectionChange = new EventEmitter<NaturalSearchSelection>();\n\n    /**\n     * Emits when user removes the search by pressing the cross icon\n     */\n    @Output() public readonly cleared = new EventEmitter<NaturalInputComponent>();\n\n    /**\n     * Selected facet from the list of available facets\n     */\n    public facet: Facet | null = null;\n\n    /**\n     * Controller for the input field\n     */\n    public formCtrl: FormControl = new FormControl();\n\n    /**\n     * Customer error matcher that should validate on each change (including initialisation)\n     */\n    public errorMatcher = new AlwaysErrorStateMatcher();\n\n    /**\n     * Reference of the opened dropdown container\n     */\n    private dropdownRef: NaturalDropdownRef | null = null;\n\n    /**\n     * Reference of the component inside the dropdown container\n     */\n    private dropdownComponentRef: ComponentRef<DropdownComponent> | null = null;\n\n    /**\n     *  Minimum input length (number of chars)\n     *  See length attribute\n     */\n    private readonly minLength = 5;\n\n    /**\n     * Size of the input (number of chars)\n     * Match the input.size attribute\n     */\n    public length = this.minLength;\n\n    /**\n     * Flag, that, if marked as yes, prevents the opening of the dropdown\n     * Is used to prevent dropdown opening when natural-search takes the focus from parent context (like on modal opening)\n     */\n    private neutralizeDropdownOpening = false;\n\n    /**\n     * Custom management for taking the focus from parent context\n     * When focusing manually on the <input>, a dropdown is opened\n     * But when the focus is given from angular in a parent context (like a dialog) the dropdown would open and we don't want it.\n     */\n    @HostListener('focus')\n    public focus(): void {\n        this.neutralizeDropdownOpening = true;\n        this.input.nativeElement.focus();\n        this.neutralizeDropdownOpening = false;\n    }\n\n    public constructor(\n        private readonly element: ElementRef,\n        private readonly dropdownService: NaturalDropdownService,\n        private readonly injector: Injector,\n        private readonly componentFactoryResolver: ComponentFactoryResolver,\n    ) {}\n\n    public ngOnInit(): void {\n        this.input.nativeElement.addEventListener('focus', () => {\n            this.openDropdown();\n        });\n\n        this.input.nativeElement.addEventListener('keyup', () => {\n            if (!this.dropdownRef) {\n                return;\n            }\n\n            if (this.formCtrl.value !== '') {\n                this.dropdownRef.close();\n            }\n        });\n\n        if (!this.placeholder) {\n            this.placeholder = $localize`Recherche`;\n        }\n\n        const placeholderSize = (this.facet ? this.facet.display.length : this.placeholder.length) * 0.66;\n        this.length = Math.max(this.minLength, Math.ceil(placeholderSize));\n    }\n\n    public ngOnDestroy(): void {\n        if (this.dropdownComponentRef) {\n            this.dropdownComponentRef.destroy();\n        }\n    }\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        if (!this.facets && this.selection) {\n            setTimeout(() => this.clear());\n        } else if (this.facets && this.selection) {\n            this.facet = getFacetFromSelection(this.facets, this.selection);\n\n            if (this.isDropdown()) {\n                const dropdownComponent = this.createComponent(this.facet as DropdownFacet<FacetSelectorConfiguration>);\n\n                this.formCtrl.setValidators([isComponentValid(dropdownComponent)]);\n                dropdownComponent.renderedValue.subscribe(value => {\n                    this.formCtrl.setValue(value);\n                });\n            } else if (this.isFlag()) {\n                this.formCtrl.setValue('');\n            } else if (\n                this.selection &&\n                this.selection.field === this.searchFieldName &&\n                this.selection.condition.like\n            ) {\n                // global search mode\n                this.formCtrl.setValue(this.selection.condition.like.value);\n            } else {\n                // If component is invalid (no facet and not a global search), clear from result and destroy component\n                setTimeout(() => this.clear());\n            }\n        }\n    }\n\n    public search(event: Event): void {\n        event.stopPropagation();\n        event.preventDefault();\n\n        if (!this.formCtrl.value) {\n            return;\n        }\n\n        if (this.isDropdown()) {\n            return;\n        }\n\n        if (this.formCtrl.valid && this.formCtrl.dirty) {\n            this.selectionChange.emit(this.getSelection({like: {value: this.formCtrl.value}}));\n        }\n    }\n\n    public clear(): void {\n        this.facet = null;\n        this.selection = null;\n        this.formCtrl.setValue(null);\n        this.cleared.emit(this);\n    }\n\n    public openDropdown(): void {\n        if (this.dropdownRef || this.neutralizeDropdownOpening) {\n            // Prevent to open multiple dropdowns.\n            // Happens as we open on \"focus\", and alt+tab re-activate focus on an element that already had\n            // focus when leaving window with another alt+tab\n            return;\n        }\n\n        this.launchRipple();\n\n        // If there is no facet and no string typed, show panel to select the facet\n        if (!this.facet && !this.formCtrl.value) {\n            this.openFacetSelectorDropdown();\n        } else {\n            // If a facet is selected, open specific component dropdown\n            this.openTypeDropdown();\n        }\n    }\n\n    public isDropdown(): boolean {\n        return !!(this.facet && (this.facet as DropdownFacet<unknown>).component);\n    }\n\n    public isFlag(): boolean {\n        return !!(this.facet && (this.facet as FlagFacet).condition);\n    }\n\n    private createComponent(facet: DropdownFacet<unknown>): DropdownComponent {\n        // Always destroy and recreate component\n        // Todo : test if facet has changed, if not re-use the component\n        if (this.dropdownComponentRef) {\n            this.dropdownComponentRef.destroy();\n        }\n\n        const condition = this.selection ? (this.selection.condition as FilterGroupConditionField) : null;\n        const data: NaturalDropdownData = {\n            condition: condition,\n            configuration: facet.configuration,\n        };\n\n        const injector = Injector.create({providers: this.createProviders(data), parent: this.injector});\n        const factory = this.componentFactoryResolver.resolveComponentFactory<DropdownComponent>(facet.component);\n        this.dropdownComponentRef = factory.create(injector);\n\n        return this.dropdownComponentRef.instance;\n    }\n\n    private createProviders(data: NaturalDropdownData): StaticProvider[] {\n        // Customize injector to allow data and dropdown reference injection in component\n        return [\n            {\n                provide: NaturalDropdownRef,\n                useValue: null,\n            },\n            {\n                provide: NATURAL_DROPDOWN_DATA,\n                useValue: data,\n            },\n        ];\n    }\n\n    private launchRipple(): void {\n        const rippleRef = this.ripple.launch({\n            persistent: true,\n            centered: true,\n        });\n\n        rippleRef.fadeOut();\n    }\n\n    private openFacetSelectorDropdown(): void {\n        if (!this.facets || (this.facets && !this.facets.length)) {\n            return;\n        }\n\n        const data: NaturalDropdownData<FacetSelectorConfiguration> = {\n            condition: {},\n            configuration: {\n                facets: this.facets,\n            },\n        };\n\n        const injectorTokens = this.createProviders(data);\n        this.dropdownRef = this.dropdownService.open(FacetSelectorComponent, this.element, injectorTokens, false);\n        this.dropdownRef.closed.subscribe(result => {\n            this.dropdownRef = null;\n            if (result !== undefined) {\n                if (result.facet) {\n                    this.setFacet(result.facet);\n                } else if (result.condition) {\n                    this.setValue(result);\n                }\n            }\n        });\n    }\n\n    private openTypeDropdown(): void {\n        if (!this.isDropdown()) {\n            return;\n        }\n\n        const dropdownFacet = this.facet as DropdownFacet<unknown>;\n\n        const data: NaturalDropdownData = {\n            condition: this.selection ? this.selection.condition : null,\n            configuration: dropdownFacet.configuration,\n        };\n\n        const injectorTokens = this.createProviders(data);\n        const component = dropdownFacet.component;\n        this.dropdownRef = this.dropdownService.open(\n            component,\n            this.element,\n            injectorTokens,\n            dropdownFacet.showValidateButton !== undefined ? dropdownFacet.showValidateButton : true,\n        );\n\n        this.dropdownRef.closed.subscribe(result => {\n            this.dropdownRef = null;\n            if (result !== undefined) {\n                this.setValue(result);\n            }\n        });\n    }\n\n    private setFacet(facet: Facet): void {\n        this.facet = facet;\n\n        if (this.isDropdown()) {\n            this.openTypeDropdown();\n        } else if (this.isFlag()) {\n            this.setValue({\n                condition: (facet as FlagFacet).condition,\n            });\n        } else {\n            this.input.nativeElement.focus();\n        }\n    }\n\n    private setValue(result: DropdownResult): void {\n        if (this.facet) {\n            this.selectionChange.emit(this.getSelection(result.condition));\n        }\n    }\n\n    private getSelection(condition: NaturalSearchSelection['condition']): NaturalSearchSelection {\n        const selection: NaturalSearchSelection = {\n            field: this.facet ? this.facet.field : this.searchFieldName,\n            condition: condition,\n        };\n\n        if (this.facet && this.facet.name) {\n            selection.name = this.facet.name;\n        }\n\n        return selection;\n    }\n}\n","<!-- click condition should match to allow click action only when no other button is visible -->\n<mat-form-field #field matRipple (click)=\"!selection && !(facet && !selection) ? openDropdown() : null\">\n    <mat-label *ngIf=\"facet\">{{ facet.display }}</mat-label>\n    <mat-label *ngIf=\"!facet\">{{ placeholder }}</mat-label>\n\n    <input\n        #input\n        (blur)=\"search($event)\"\n        (keydown.enter)=\"search($event)\"\n        [attr.size]=\"length\"\n        [errorStateMatcher]=\"errorMatcher\"\n        [formControl]=\"formCtrl\"\n        [readonly]=\"(isDropdown() && !!selection) || isFlag()\"\n        autocomplete=\"off\"\n        matInput\n        type=\"text\"\n    />\n\n    <!-- TODO : replace this void button -->\n    <div *ngIf=\"!facet && !selection\" class=\"search-icon\" matPrefix>\n        <natural-icon name=\"search\"></natural-icon>\n    </div>\n\n    <button (click)=\"clear()\" *ngIf=\"selection\" mat-icon-button matSuffix>\n        <natural-icon name=\"close\"></natural-icon>\n    </button>\n\n    <button (click)=\"clear()\" *ngIf=\"facet && !selection\" mat-icon-button matSuffix>\n        <natural-icon name=\"undo\"></natural-icon>\n    </button>\n</mat-form-field>\n<div class=\"hide\">{{ formCtrl.value ? formCtrl.value : facet ? facet.display : placeholder }}</div>\n"]}
330
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/search/input/input.component.ts","../../../../../../../projects/natural/src/lib/modules/search/input/input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ComponentFactoryResolver,\n    ComponentRef,\n    ElementRef,\n    EventEmitter,\n    HostListener,\n    Injector,\n    Input,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Output,\n    SimpleChanges,\n    StaticProvider,\n    ViewChild,\n} from '@angular/core';\nimport {FormControl, FormGroupDirective, NgForm, ValidationErrors, ValidatorFn} from '@angular/forms';\nimport {ErrorStateMatcher, MatRipple} from '@angular/material/core';\nimport {FilterGroupConditionField} from '../classes/graphql-doctrine.types';\nimport {getFacetFromSelection} from '../classes/utils';\nimport {NaturalDropdownRef} from '../dropdown-container/dropdown-ref';\nimport {\n    NATURAL_DROPDOWN_DATA,\n    NaturalDropdownData,\n    NaturalDropdownService,\n} from '../dropdown-container/dropdown.service';\nimport {FacetSelectorComponent, FacetSelectorConfiguration} from '../facet-selector/facet-selector.component';\nimport {DropdownComponent} from '../types/dropdown-component';\nimport {DropdownFacet, Facet, FlagFacet, NaturalSearchFacets} from '../types/facet';\nimport {DropdownResult, NaturalSearchSelection} from '../types/values';\n\n// Required to check invalid fields when initializing natural-search\nexport class AlwaysErrorStateMatcher implements ErrorStateMatcher {\n    public isErrorState(control: FormControl | null, form: FormGroupDirective | NgForm | null): boolean {\n        return !!control && control.invalid;\n    }\n}\n\nfunction isComponentValid(component: DropdownComponent): ValidatorFn {\n    return (): ValidationErrors | null => {\n        if (!component.isValid()) {\n            return {component: true};\n        }\n\n        return null;\n    };\n}\n\n@Component({\n    selector: 'natural-input',\n    templateUrl: './input.component.html',\n    styleUrls: ['./input.component.scss'],\n})\nexport class NaturalInputComponent implements OnInit, OnChanges, OnDestroy {\n    /**\n     * Controls the ripple effect, used when opening a dropdown\n     */\n    @ViewChild(MatRipple, {static: true}) public ripple!: MatRipple;\n\n    /**\n     * Native element ref for <input> related to this <natural-input> component\n     */\n    @ViewChild('input', {static: true}) public input!: ElementRef<HTMLInputElement>;\n\n    /**\n     * Label for this field\n     */\n    @Input() public placeholder?: string;\n\n    /**\n     * Name of the field on which do a global search (without facet)\n     */\n    @Input() public searchFieldName = 'search';\n\n    /**\n     * Selected setted for this component\n     */\n    @Input() public selection: NaturalSearchSelection | null = null;\n\n    /**\n     * Available facets, allows the user to pick one, than generated then a selection\n     */\n    @Input() public facets!: NaturalSearchFacets;\n\n    /**\n     * Emits when user a added/updated/deleted a search (from global context or from facet)\n     */\n    @Output() public readonly selectionChange = new EventEmitter<NaturalSearchSelection>();\n\n    /**\n     * Emits when user removes the search by pressing the cross icon\n     */\n    @Output() public readonly cleared = new EventEmitter<NaturalInputComponent>();\n\n    /**\n     * Selected facet from the list of available facets\n     */\n    public facet: Facet | null = null;\n\n    /**\n     * Controller for the input field\n     */\n    public formCtrl: FormControl = new FormControl();\n\n    /**\n     * Customer error matcher that should validate on each change (including initialisation)\n     */\n    public errorMatcher = new AlwaysErrorStateMatcher();\n\n    /**\n     * Reference of the opened dropdown container\n     */\n    private dropdownRef: NaturalDropdownRef | null = null;\n\n    /**\n     * Reference of the component inside the dropdown container\n     */\n    private dropdownComponentRef: ComponentRef<DropdownComponent> | null = null;\n\n    /**\n     *  Minimum input length (number of chars)\n     *  See length attribute\n     */\n    private readonly minLength = 5;\n\n    /**\n     * Size of the input (number of chars)\n     * Match the input.size attribute\n     */\n    public length = this.minLength;\n\n    /**\n     * Flag, that, if marked as yes, prevents the opening of the dropdown\n     * Is used to prevent dropdown opening when natural-search takes the focus from parent context (like on modal opening)\n     */\n    private neutralizeDropdownOpening = false;\n\n    /**\n     * Custom management for taking the focus from parent context\n     * When focusing manually on the <input>, a dropdown is opened\n     * But when the focus is given from angular in a parent context (like a dialog) the dropdown would open and we don't want it.\n     */\n    @HostListener('focus')\n    public focus(): void {\n        this.neutralizeDropdownOpening = true;\n        this.input.nativeElement.focus();\n        this.neutralizeDropdownOpening = false;\n    }\n\n    public constructor(\n        private readonly element: ElementRef<HTMLElement>,\n        private readonly dropdownService: NaturalDropdownService,\n        private readonly injector: Injector,\n        private readonly componentFactoryResolver: ComponentFactoryResolver,\n    ) {}\n\n    public ngOnInit(): void {\n        this.input.nativeElement.addEventListener('focus', () => {\n            this.openDropdown();\n        });\n\n        this.input.nativeElement.addEventListener('keyup', () => {\n            if (!this.dropdownRef) {\n                return;\n            }\n\n            if (this.formCtrl.value !== '') {\n                this.dropdownRef.close();\n            }\n        });\n\n        if (!this.placeholder) {\n            this.placeholder = $localize`Recherche`;\n        }\n\n        const placeholderSize = (this.facet ? this.facet.display.length : this.placeholder.length) * 0.66;\n        this.length = Math.max(this.minLength, Math.ceil(placeholderSize));\n    }\n\n    public ngOnDestroy(): void {\n        if (this.dropdownComponentRef) {\n            this.dropdownComponentRef.destroy();\n        }\n    }\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        if (!this.facets && this.selection) {\n            setTimeout(() => this.clear());\n        } else if (this.facets && this.selection) {\n            this.facet = getFacetFromSelection(this.facets, this.selection);\n\n            if (this.isDropdown()) {\n                const dropdownComponent = this.createComponent(this.facet as DropdownFacet<FacetSelectorConfiguration>);\n\n                this.formCtrl.setValidators([isComponentValid(dropdownComponent)]);\n                dropdownComponent.renderedValue.subscribe(value => {\n                    this.formCtrl.setValue(value);\n                });\n            } else if (this.isFlag()) {\n                this.formCtrl.setValue('');\n            } else if (\n                this.selection &&\n                this.selection.field === this.searchFieldName &&\n                this.selection.condition.like\n            ) {\n                // global search mode\n                this.formCtrl.setValue(this.selection.condition.like.value);\n            } else {\n                // If component is invalid (no facet and not a global search), clear from result and destroy component\n                setTimeout(() => this.clear());\n            }\n        }\n    }\n\n    public search(event: Event): void {\n        event.stopPropagation();\n        event.preventDefault();\n\n        if (!this.formCtrl.value) {\n            return;\n        }\n\n        if (this.isDropdown()) {\n            return;\n        }\n\n        if (this.formCtrl.valid && this.formCtrl.dirty) {\n            this.selectionChange.emit(this.getSelection({like: {value: this.formCtrl.value}}));\n        }\n    }\n\n    public clear(): void {\n        this.facet = null;\n        this.selection = null;\n        this.formCtrl.setValue(null);\n        this.cleared.emit(this);\n    }\n\n    public openDropdown(): void {\n        if (this.dropdownRef || this.neutralizeDropdownOpening) {\n            // Prevent to open multiple dropdowns.\n            // Happens as we open on \"focus\", and alt+tab re-activate focus on an element that already had\n            // focus when leaving window with another alt+tab\n            return;\n        }\n\n        this.launchRipple();\n\n        // If there is no facet and no string typed, show panel to select the facet\n        if (!this.facet && !this.formCtrl.value) {\n            this.openFacetSelectorDropdown();\n        } else {\n            // If a facet is selected, open specific component dropdown\n            this.openTypeDropdown();\n        }\n    }\n\n    public isDropdown(): boolean {\n        return !!(this.facet && (this.facet as DropdownFacet<unknown>).component);\n    }\n\n    public isFlag(): boolean {\n        return !!(this.facet && (this.facet as FlagFacet).condition);\n    }\n\n    private createComponent(facet: DropdownFacet<unknown>): DropdownComponent {\n        // Always destroy and recreate component\n        // Todo : test if facet has changed, if not re-use the component\n        if (this.dropdownComponentRef) {\n            this.dropdownComponentRef.destroy();\n        }\n\n        const condition = this.selection ? (this.selection.condition as FilterGroupConditionField) : null;\n        const data: NaturalDropdownData = {\n            condition: condition,\n            configuration: facet.configuration,\n        };\n\n        const injector = Injector.create({providers: this.createProviders(data), parent: this.injector});\n        // TODO replace by this when https://github.com/angular/angular/commit/d1e83e1b30f2cea9f2ed16bff2d3b969335072ab is released\n        // this.dropdownComponentRef = createComponent(facet.component, {environmentInjector: injector});\n        const factory = this.componentFactoryResolver.resolveComponentFactory<DropdownComponent>(facet.component);\n        this.dropdownComponentRef = factory.create(injector);\n\n        return this.dropdownComponentRef.instance;\n    }\n\n    private createProviders(data: NaturalDropdownData): StaticProvider[] {\n        // Customize injector to allow data and dropdown reference injection in component\n        return [\n            {\n                provide: NaturalDropdownRef,\n                useValue: null,\n            },\n            {\n                provide: NATURAL_DROPDOWN_DATA,\n                useValue: data,\n            },\n        ];\n    }\n\n    private launchRipple(): void {\n        const rippleRef = this.ripple.launch({\n            persistent: true,\n            centered: true,\n        });\n\n        rippleRef.fadeOut();\n    }\n\n    private openFacetSelectorDropdown(): void {\n        if (!this.facets || (this.facets && !this.facets.length)) {\n            return;\n        }\n\n        const data: NaturalDropdownData<FacetSelectorConfiguration> = {\n            condition: {},\n            configuration: {\n                facets: this.facets,\n            },\n        };\n\n        const injectorTokens = this.createProviders(data);\n        this.dropdownRef = this.dropdownService.open(FacetSelectorComponent, this.element, injectorTokens, false);\n        this.dropdownRef.closed.subscribe(result => {\n            this.dropdownRef = null;\n            if (result !== undefined) {\n                if (result.facet) {\n                    this.setFacet(result.facet);\n                } else if (result.condition) {\n                    this.setValue(result);\n                }\n            }\n        });\n    }\n\n    private openTypeDropdown(): void {\n        if (!this.isDropdown()) {\n            return;\n        }\n\n        const dropdownFacet = this.facet as DropdownFacet<unknown>;\n\n        const data: NaturalDropdownData = {\n            condition: this.selection ? this.selection.condition : null,\n            configuration: dropdownFacet.configuration,\n        };\n\n        const injectorTokens = this.createProviders(data);\n        const component = dropdownFacet.component;\n        this.dropdownRef = this.dropdownService.open(\n            component,\n            this.element,\n            injectorTokens,\n            dropdownFacet.showValidateButton !== undefined ? dropdownFacet.showValidateButton : true,\n        );\n\n        this.dropdownRef.closed.subscribe(result => {\n            this.dropdownRef = null;\n            if (result !== undefined) {\n                this.setValue(result);\n            }\n        });\n    }\n\n    private setFacet(facet: Facet): void {\n        this.facet = facet;\n\n        if (this.isDropdown()) {\n            this.openTypeDropdown();\n        } else if (this.isFlag()) {\n            this.setValue({\n                condition: (facet as FlagFacet).condition,\n            });\n        } else {\n            this.input.nativeElement.focus();\n        }\n    }\n\n    private setValue(result: DropdownResult): void {\n        if (this.facet) {\n            this.selectionChange.emit(this.getSelection(result.condition));\n        }\n    }\n\n    private getSelection(condition: NaturalSearchSelection['condition']): NaturalSearchSelection {\n        const selection: NaturalSearchSelection = {\n            field: this.facet ? this.facet.field : this.searchFieldName,\n            condition: condition,\n        };\n\n        if (this.facet && this.facet.name) {\n            selection.name = this.facet.name;\n        }\n\n        return selection;\n    }\n}\n","<!-- click condition should match to allow click action only when no other button is visible -->\n<mat-form-field #field matRipple (click)=\"!selection && !(facet && !selection) ? openDropdown() : null\">\n    <mat-label *ngIf=\"facet\">{{ facet.display }}</mat-label>\n    <mat-label *ngIf=\"!facet\">{{ placeholder }}</mat-label>\n\n    <input\n        #input\n        (blur)=\"search($event)\"\n        (keydown.enter)=\"search($event)\"\n        [attr.size]=\"length\"\n        [errorStateMatcher]=\"errorMatcher\"\n        [formControl]=\"formCtrl\"\n        [readonly]=\"(isDropdown() && !!selection) || isFlag()\"\n        autocomplete=\"off\"\n        matInput\n        type=\"text\"\n    />\n\n    <!-- TODO : replace this void button -->\n    <div *ngIf=\"!facet && !selection\" class=\"search-icon\" matPrefix>\n        <natural-icon name=\"search\"></natural-icon>\n    </div>\n\n    <button (click)=\"clear()\" *ngIf=\"selection\" mat-icon-button matSuffix>\n        <natural-icon name=\"close\"></natural-icon>\n    </button>\n\n    <button (click)=\"clear()\" *ngIf=\"facet && !selection\" mat-icon-button matSuffix>\n        <natural-icon name=\"undo\"></natural-icon>\n    </button>\n</mat-form-field>\n<div class=\"hide\">{{ formCtrl.value ? formCtrl.value : facet ? facet.display : placeholder }}</div>\n"]}
@@ -6,9 +6,8 @@ import * as i1 from "../sidenav.service";
6
6
  import * as i2 from "@angular/material/sidenav";
7
7
  import * as i3 from "@angular/common";
8
8
  export class NaturalSidenavContainerComponent {
9
- constructor(sidenavService, element) {
9
+ constructor(sidenavService) {
10
10
  this.sidenavService = sidenavService;
11
- this.element = element;
12
11
  /**
13
12
  * The side that the drawer is attached to
14
13
  */
@@ -59,12 +58,12 @@ export class NaturalSidenavContainerComponent {
59
58
  this.sidenavService.toggleMinimized();
60
59
  }
61
60
  }
62
- NaturalSidenavContainerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalSidenavContainerComponent, deps: [{ token: i1.NaturalSidenavService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
61
+ NaturalSidenavContainerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalSidenavContainerComponent, deps: [{ token: i1.NaturalSidenavService }], target: i0.ɵɵFactoryTarget.Component });
63
62
  NaturalSidenavContainerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.0", type: NaturalSidenavContainerComponent, selector: "natural-sidenav-container", inputs: { name: "name", position: "position", mobileAutoClose: "mobileAutoClose", minimizedWidth: "minimizedWidth", noScroll: "noScroll" }, host: { properties: { "attr.no-scroll": "this.noScroll" } }, providers: [NaturalSidenavService], viewQueries: [{ propertyName: "menuContainer", first: true, predicate: MatSidenavContainer, descendants: true, static: true }, { propertyName: "menuSidenav", first: true, predicate: MatSidenav, descendants: true, static: true }], ngImport: i0, template: "<mat-sidenav-container (backdropClick)=\"sidenavService.setOpened(false)\">\n <mat-sidenav\n [mode]=\"sidenavService.activeMode\"\n [ngClass]=\"sidenavService.isMinimized ? 'menuMinimized' : ''\"\n [opened]=\"sidenavService.isOpened\"\n [style.min-width.px]=\"sidenavService.isMinimized && minimizedWidth ? minimizedWidth : null\"\n [style.width.px]=\"sidenavService.isMinimized && minimizedWidth ? minimizedWidth : null\"\n [position]=\"position\"\n >\n <ng-content select=\"natural-sidenav\"></ng-content>\n </mat-sidenav>\n\n <mat-sidenav-content>\n <div>\n <ng-content select=\"natural-sidenav-content\"></ng-content>\n </div>\n </mat-sidenav-content>\n</mat-sidenav-container>\n", styles: [":host{display:flex;flex-direction:column}:host mat-sidenav-container{display:flex;flex-direction:column;flex:1}:host mat-sidenav-content>div{overflow:auto}:host .menuMinimized{overflow-x:hidden}:host .buttons{display:flex;flex-direction:row;justify-content:flex-end}\n"], components: [{ type: i2.MatSidenavContainer, selector: "mat-sidenav-container", exportAs: ["matSidenavContainer"] }, { type: i2.MatSidenav, selector: "mat-sidenav", inputs: ["fixedInViewport", "fixedTopGap", "fixedBottomGap"], exportAs: ["matSidenav"] }, { type: i2.MatSidenavContent, selector: "mat-sidenav-content" }], directives: [{ type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] });
64
63
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalSidenavContainerComponent, decorators: [{
65
64
  type: Component,
66
65
  args: [{ selector: 'natural-sidenav-container', providers: [NaturalSidenavService], template: "<mat-sidenav-container (backdropClick)=\"sidenavService.setOpened(false)\">\n <mat-sidenav\n [mode]=\"sidenavService.activeMode\"\n [ngClass]=\"sidenavService.isMinimized ? 'menuMinimized' : ''\"\n [opened]=\"sidenavService.isOpened\"\n [style.min-width.px]=\"sidenavService.isMinimized && minimizedWidth ? minimizedWidth : null\"\n [style.width.px]=\"sidenavService.isMinimized && minimizedWidth ? minimizedWidth : null\"\n [position]=\"position\"\n >\n <ng-content select=\"natural-sidenav\"></ng-content>\n </mat-sidenav>\n\n <mat-sidenav-content>\n <div>\n <ng-content select=\"natural-sidenav-content\"></ng-content>\n </div>\n </mat-sidenav-content>\n</mat-sidenav-container>\n", styles: [":host{display:flex;flex-direction:column}:host mat-sidenav-container{display:flex;flex-direction:column;flex:1}:host mat-sidenav-content>div{overflow:auto}:host .menuMinimized{overflow-x:hidden}:host .buttons{display:flex;flex-direction:row;justify-content:flex-end}\n"] }]
67
- }], ctorParameters: function () { return [{ type: i1.NaturalSidenavService }, { type: i0.ElementRef }]; }, propDecorators: { name: [{
66
+ }], ctorParameters: function () { return [{ type: i1.NaturalSidenavService }]; }, propDecorators: { name: [{
68
67
  type: Input
69
68
  }], position: [{
70
69
  type: Input
@@ -84,4 +83,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.0", ngImpor
84
83
  type: ViewChild,
85
84
  args: [MatSidenav, { static: true }]
86
85
  }] } });
87
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZW5hdi1jb250YWluZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvc2lkZW5hdi9zaWRlbmF2LWNvbnRhaW5lci9zaWRlbmF2LWNvbnRhaW5lci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uYXR1cmFsL3NyYy9saWIvbW9kdWxlcy9zaWRlbmF2L3NpZGVuYXYtY29udGFpbmVyL3NpZGVuYXYtY29udGFpbmVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQWMsV0FBVyxFQUFFLEtBQUssRUFBcUIsU0FBUyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3RHLE9BQU8sRUFBWSxVQUFVLEVBQUUsbUJBQW1CLEVBQUMsTUFBTSwyQkFBMkIsQ0FBQztBQUNyRixPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSxvQkFBb0IsQ0FBQzs7Ozs7QUFRekQsTUFBTSxPQUFPLGdDQUFnQztJQXNDekMsWUFBbUMsY0FBcUMsRUFBa0IsT0FBbUI7UUFBMUUsbUJBQWMsR0FBZCxjQUFjLENBQXVCO1FBQWtCLFlBQU8sR0FBUCxPQUFPLENBQVk7UUFoQzdHOztXQUVHO1FBQ2EsYUFBUSxHQUEwQixPQUFPLENBQUM7UUFFMUQ7OztXQUdHO1FBQ2Esb0JBQWUsR0FBRyxJQUFJLENBQUM7UUFFdkM7O1dBRUc7UUFDYSxtQkFBYyxHQUFHLEdBQUcsQ0FBQztRQUVyQzs7O1dBR0c7UUFDNEMsYUFBUSxHQUFHLEtBQUssQ0FBQztJQVlnRCxDQUFDO0lBRWpILElBQVcsV0FBVztRQUNsQixPQUFPLElBQUksQ0FBQyxjQUFjLENBQUMsV0FBVyxDQUFDO0lBQzNDLENBQUM7SUFFRCxJQUFXLFlBQVk7UUFDbkIsT0FBTyxJQUFJLENBQUMsY0FBYyxDQUFDLFlBQVksRUFBRSxDQUFDO0lBQzlDLENBQUM7SUFFTSxRQUFRO1FBQ1gsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsYUFBYSxFQUFFLElBQUksQ0FBQyxXQUFXLEVBQUUsSUFBSSxFQUFFLElBQUksQ0FBQyxlQUFlLENBQUMsQ0FBQztJQUMxRyxDQUFDO0lBRU0sV0FBVztRQUNkLElBQUksQ0FBQyxjQUFjLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3RDLENBQUM7SUFFTSxNQUFNO1FBQ1QsSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLEVBQUUsQ0FBQztJQUNqQyxDQUFDO0lBRU0sS0FBSztRQUNSLElBQUksQ0FBQyxjQUFjLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDaEMsQ0FBQztJQUVNLElBQUk7UUFDUCxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQy9CLENBQUM7SUFFTSxRQUFRO1FBQ1gsSUFBSSxDQUFDLGNBQWMsQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUNuQyxDQUFDO0lBRU0sTUFBTTtRQUNULElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxFQUFFLENBQUM7SUFDakMsQ0FBQztJQUVNLGVBQWU7UUFDbEIsSUFBSSxDQUFDLGNBQWMsQ0FBQyxlQUFlLEVBQUUsQ0FBQztJQUMxQyxDQUFDOzs2SEE5RVEsZ0NBQWdDO2lIQUFoQyxnQ0FBZ0MsNlBBRjlCLENBQUMscUJBQXFCLENBQUMseUVBaUN2QixtQkFBbUIsNEZBS25CLFVBQVUsOERDOUN6Qixzd0JBa0JBOzJGRFJhLGdDQUFnQztrQkFONUMsU0FBUzsrQkFDSSwyQkFBMkIsYUFHMUIsQ0FBQyxxQkFBcUIsQ0FBQztxSUFNbEIsSUFBSTtzQkFBbkIsS0FBSztnQkFLVSxRQUFRO3NCQUF2QixLQUFLO2dCQU1VLGVBQWU7c0JBQTlCLEtBQUs7Z0JBS1UsY0FBYztzQkFBN0IsS0FBSztnQkFNeUMsUUFBUTtzQkFBdEQsV0FBVzt1QkFBQyxnQkFBZ0I7O3NCQUFHLEtBQUs7Z0JBS21CLGFBQWE7c0JBQXBFLFNBQVM7dUJBQUMsbUJBQW1CLEVBQUUsRUFBQyxNQUFNLEVBQUUsSUFBSSxFQUFDO2dCQUtDLFdBQVc7c0JBQXpELFNBQVM7dUJBQUMsVUFBVSxFQUFFLEVBQUMsTUFBTSxFQUFFLElBQUksRUFBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBFbGVtZW50UmVmLCBIb3N0QmluZGluZywgSW5wdXQsIE9uRGVzdHJveSwgT25Jbml0LCBWaWV3Q2hpbGR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtNYXREcmF3ZXIsIE1hdFNpZGVuYXYsIE1hdFNpZGVuYXZDb250YWluZXJ9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3NpZGVuYXYnO1xuaW1wb3J0IHtOYXR1cmFsU2lkZW5hdlNlcnZpY2V9IGZyb20gJy4uL3NpZGVuYXYuc2VydmljZSc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnbmF0dXJhbC1zaWRlbmF2LWNvbnRhaW5lcicsXG4gICAgdGVtcGxhdGVVcmw6ICcuL3NpZGVuYXYtY29udGFpbmVyLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9zaWRlbmF2LWNvbnRhaW5lci5jb21wb25lbnQuc2NzcyddLFxuICAgIHByb3ZpZGVyczogW05hdHVyYWxTaWRlbmF2U2VydmljZV0sXG59KVxuZXhwb3J0IGNsYXNzIE5hdHVyYWxTaWRlbmF2Q29udGFpbmVyQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3kge1xuICAgIC8qKlxuICAgICAqIFVuaXF1ZSBpZGVudGlmaWVyIHVzZWQgZm9yIHRoZSBsb2NhbCBzdG9yYWdlXG4gICAgICovXG4gICAgQElucHV0KCkgcHVibGljIG5hbWUhOiBzdHJpbmc7XG5cbiAgICAvKipcbiAgICAgKiBUaGUgc2lkZSB0aGF0IHRoZSBkcmF3ZXIgaXMgYXR0YWNoZWQgdG9cbiAgICAgKi9cbiAgICBASW5wdXQoKSBwdWJsaWMgcG9zaXRpb246IE1hdERyYXdlclsncG9zaXRpb24nXSA9ICdzdGFydCc7XG5cbiAgICAvKipcbiAgICAgKiBJZiB0cnVlIGxpc3RlbnMgdG8gcm91dGUgY2hhbmdlcyB0byBjbG9zZSBzaWRlIG5hdiBhZnRlciBhIHJvdXRlIGNoYW5nZSBpZiBtb2JpbGUgdmlldyBpcyBhY3RpdmVcbiAgICAgKiBBY3R1YWxseSBhIG5hdmlnYXRpb24gdG8gY3VycmVudCByb3V0ZSBkb2VzIG5vdCBlbWl0IGEgcm91dGUgY2hhbmdlLCBhbmQgdGhlIHNpZGVuYXYgZG9uJ3QgY2xvc2UuXG4gICAgICovXG4gICAgQElucHV0KCkgcHVibGljIG1vYmlsZUF1dG9DbG9zZSA9IHRydWU7XG5cbiAgICAvKipcbiAgICAgKiBXaWR0aCBvZiB0aGUgbWluaW1pemVkIG1lbnVcbiAgICAgKi9cbiAgICBASW5wdXQoKSBwdWJsaWMgbWluaW1pemVkV2lkdGggPSAxNTA7XG5cbiAgICAvKipcbiAgICAgKiBJZiB0cnVlLCBwcmV2ZW50cyBcIm5hdGl2ZVwiIG1hdGVyaWFsIHNpZGVuYXYgdG8gc2Nyb2xsIGF0IGNvbnRhaW5lciBsZXZlbCBhbmQgZGVsZWdhdGVzIHRoZSBzY3JvbGwgcmVzcG9uc2FiaWxpdHkgdG8gdGhlIHRyYW5zY2x1ZGVkXG4gICAgICogY29udGVudFxuICAgICAqL1xuICAgIEBIb3N0QmluZGluZygnYXR0ci5uby1zY3JvbGwnKSBASW5wdXQoKSBwdWJsaWMgbm9TY3JvbGwgPSBmYWxzZTtcblxuICAgIC8qKlxuICAgICAqIElubmVyIFwibmF0aXZlXCIgbWF0ZXJpYWwgc2lkZW5hdiBjb250YWluZXJcbiAgICAgKi9cbiAgICBAVmlld0NoaWxkKE1hdFNpZGVuYXZDb250YWluZXIsIHtzdGF0aWM6IHRydWV9KSBwcml2YXRlIG1lbnVDb250YWluZXIhOiBNYXRTaWRlbmF2Q29udGFpbmVyO1xuXG4gICAgLyoqXG4gICAgICogSW5uZXIgXCJuYXRpdmVcIiBtYXRlcmlhbCBzaWRlbmF2XG4gICAgICovXG4gICAgQFZpZXdDaGlsZChNYXRTaWRlbmF2LCB7c3RhdGljOiB0cnVlfSkgcHJpdmF0ZSBtZW51U2lkZW5hdiE6IE1hdFNpZGVuYXY7XG5cbiAgICBwdWJsaWMgY29uc3RydWN0b3IocHVibGljIHJlYWRvbmx5IHNpZGVuYXZTZXJ2aWNlOiBOYXR1cmFsU2lkZW5hdlNlcnZpY2UsIHB1YmxpYyByZWFkb25seSBlbGVtZW50OiBFbGVtZW50UmVmKSB7fVxuXG4gICAgcHVibGljIGdldCBpc01pbmltaXplZCgpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuc2lkZW5hdlNlcnZpY2UuaXNNaW5pbWl6ZWQ7XG4gICAgfVxuXG4gICAgcHVibGljIGdldCBpc01vYmlsZVZpZXcoKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiB0aGlzLnNpZGVuYXZTZXJ2aWNlLmlzTW9iaWxlVmlldygpO1xuICAgIH1cblxuICAgIHB1YmxpYyBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5zaWRlbmF2U2VydmljZS5pbml0KHRoaXMubmFtZSwgdGhpcy5tZW51Q29udGFpbmVyLCB0aGlzLm1lbnVTaWRlbmF2LCB0aGlzLCB0aGlzLm1vYmlsZUF1dG9DbG9zZSk7XG4gICAgfVxuXG4gICAgcHVibGljIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgICAgICB0aGlzLnNpZGVuYXZTZXJ2aWNlLmRlc3Ryb3kodGhpcyk7XG4gICAgfVxuXG4gICAgcHVibGljIHRvZ2dsZSgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5zaWRlbmF2U2VydmljZS50b2dnbGUoKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgY2xvc2UoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuc2lkZW5hdlNlcnZpY2UuY2xvc2UoKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgb3BlbigpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5zaWRlbmF2U2VydmljZS5vcGVuKCk7XG4gICAgfVxuXG4gICAgcHVibGljIG1pbmltaXplKCk6IHZvaWQge1xuICAgICAgICB0aGlzLnNpZGVuYXZTZXJ2aWNlLm1pbmltaXplKCk7XG4gICAgfVxuXG4gICAgcHVibGljIGV4cGFuZCgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5zaWRlbmF2U2VydmljZS5leHBhbmQoKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgdG9nZ2xlTWluaW1pemVkKCk6IHZvaWQge1xuICAgICAgICB0aGlzLnNpZGVuYXZTZXJ2aWNlLnRvZ2dsZU1pbmltaXplZCgpO1xuICAgIH1cbn1cbiIsIjxtYXQtc2lkZW5hdi1jb250YWluZXIgKGJhY2tkcm9wQ2xpY2spPVwic2lkZW5hdlNlcnZpY2Uuc2V0T3BlbmVkKGZhbHNlKVwiPlxuICAgIDxtYXQtc2lkZW5hdlxuICAgICAgICBbbW9kZV09XCJzaWRlbmF2U2VydmljZS5hY3RpdmVNb2RlXCJcbiAgICAgICAgW25nQ2xhc3NdPVwic2lkZW5hdlNlcnZpY2UuaXNNaW5pbWl6ZWQgPyAnbWVudU1pbmltaXplZCcgOiAnJ1wiXG4gICAgICAgIFtvcGVuZWRdPVwic2lkZW5hdlNlcnZpY2UuaXNPcGVuZWRcIlxuICAgICAgICBbc3R5bGUubWluLXdpZHRoLnB4XT1cInNpZGVuYXZTZXJ2aWNlLmlzTWluaW1pemVkICYmIG1pbmltaXplZFdpZHRoID8gbWluaW1pemVkV2lkdGggOiBudWxsXCJcbiAgICAgICAgW3N0eWxlLndpZHRoLnB4XT1cInNpZGVuYXZTZXJ2aWNlLmlzTWluaW1pemVkICYmIG1pbmltaXplZFdpZHRoID8gbWluaW1pemVkV2lkdGggOiBudWxsXCJcbiAgICAgICAgW3Bvc2l0aW9uXT1cInBvc2l0aW9uXCJcbiAgICA+XG4gICAgICAgIDxuZy1jb250ZW50IHNlbGVjdD1cIm5hdHVyYWwtc2lkZW5hdlwiPjwvbmctY29udGVudD5cbiAgICA8L21hdC1zaWRlbmF2PlxuXG4gICAgPG1hdC1zaWRlbmF2LWNvbnRlbnQ+XG4gICAgICAgIDxkaXY+XG4gICAgICAgICAgICA8bmctY29udGVudCBzZWxlY3Q9XCJuYXR1cmFsLXNpZGVuYXYtY29udGVudFwiPjwvbmctY29udGVudD5cbiAgICAgICAgPC9kaXY+XG4gICAgPC9tYXQtc2lkZW5hdi1jb250ZW50PlxuPC9tYXQtc2lkZW5hdi1jb250YWluZXI+XG4iXX0=
86
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZW5hdi1jb250YWluZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvc2lkZW5hdi9zaWRlbmF2LWNvbnRhaW5lci9zaWRlbmF2LWNvbnRhaW5lci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uYXR1cmFsL3NyYy9saWIvbW9kdWxlcy9zaWRlbmF2L3NpZGVuYXYtY29udGFpbmVyL3NpZGVuYXYtY29udGFpbmVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsV0FBVyxFQUFFLEtBQUssRUFBcUIsU0FBUyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQzFGLE9BQU8sRUFBWSxVQUFVLEVBQUUsbUJBQW1CLEVBQUMsTUFBTSwyQkFBMkIsQ0FBQztBQUNyRixPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSxvQkFBb0IsQ0FBQzs7Ozs7QUFRekQsTUFBTSxPQUFPLGdDQUFnQztJQXNDekMsWUFBbUMsY0FBcUM7UUFBckMsbUJBQWMsR0FBZCxjQUFjLENBQXVCO1FBaEN4RTs7V0FFRztRQUNhLGFBQVEsR0FBMEIsT0FBTyxDQUFDO1FBRTFEOzs7V0FHRztRQUNhLG9CQUFlLEdBQUcsSUFBSSxDQUFDO1FBRXZDOztXQUVHO1FBQ2EsbUJBQWMsR0FBRyxHQUFHLENBQUM7UUFFckM7OztXQUdHO1FBQzRDLGFBQVEsR0FBRyxLQUFLLENBQUM7SUFZVyxDQUFDO0lBRTVFLElBQVcsV0FBVztRQUNsQixPQUFPLElBQUksQ0FBQyxjQUFjLENBQUMsV0FBVyxDQUFDO0lBQzNDLENBQUM7SUFFRCxJQUFXLFlBQVk7UUFDbkIsT0FBTyxJQUFJLENBQUMsY0FBYyxDQUFDLFlBQVksRUFBRSxDQUFDO0lBQzlDLENBQUM7SUFFTSxRQUFRO1FBQ1gsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsYUFBYSxFQUFFLElBQUksQ0FBQyxXQUFXLEVBQUUsSUFBSSxFQUFFLElBQUksQ0FBQyxlQUFlLENBQUMsQ0FBQztJQUMxRyxDQUFDO0lBRU0sV0FBVztRQUNkLElBQUksQ0FBQyxjQUFjLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3RDLENBQUM7SUFFTSxNQUFNO1FBQ1QsSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLEVBQUUsQ0FBQztJQUNqQyxDQUFDO0lBRU0sS0FBSztRQUNSLElBQUksQ0FBQyxjQUFjLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDaEMsQ0FBQztJQUVNLElBQUk7UUFDUCxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQy9CLENBQUM7SUFFTSxRQUFRO1FBQ1gsSUFBSSxDQUFDLGNBQWMsQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUNuQyxDQUFDO0lBRU0sTUFBTTtRQUNULElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxFQUFFLENBQUM7SUFDakMsQ0FBQztJQUVNLGVBQWU7UUFDbEIsSUFBSSxDQUFDLGNBQWMsQ0FBQyxlQUFlLEVBQUUsQ0FBQztJQUMxQyxDQUFDOzs2SEE5RVEsZ0NBQWdDO2lIQUFoQyxnQ0FBZ0MsNlBBRjlCLENBQUMscUJBQXFCLENBQUMseUVBaUN2QixtQkFBbUIsNEZBS25CLFVBQVUsOERDOUN6Qixzd0JBa0JBOzJGRFJhLGdDQUFnQztrQkFONUMsU0FBUzsrQkFDSSwyQkFBMkIsYUFHMUIsQ0FBQyxxQkFBcUIsQ0FBQzs0R0FNbEIsSUFBSTtzQkFBbkIsS0FBSztnQkFLVSxRQUFRO3NCQUF2QixLQUFLO2dCQU1VLGVBQWU7c0JBQTlCLEtBQUs7Z0JBS1UsY0FBYztzQkFBN0IsS0FBSztnQkFNeUMsUUFBUTtzQkFBdEQsV0FBVzt1QkFBQyxnQkFBZ0I7O3NCQUFHLEtBQUs7Z0JBS21CLGFBQWE7c0JBQXBFLFNBQVM7dUJBQUMsbUJBQW1CLEVBQUUsRUFBQyxNQUFNLEVBQUUsSUFBSSxFQUFDO2dCQUtDLFdBQVc7c0JBQXpELFNBQVM7dUJBQUMsVUFBVSxFQUFFLEVBQUMsTUFBTSxFQUFFLElBQUksRUFBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBIb3N0QmluZGluZywgSW5wdXQsIE9uRGVzdHJveSwgT25Jbml0LCBWaWV3Q2hpbGR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtNYXREcmF3ZXIsIE1hdFNpZGVuYXYsIE1hdFNpZGVuYXZDb250YWluZXJ9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3NpZGVuYXYnO1xuaW1wb3J0IHtOYXR1cmFsU2lkZW5hdlNlcnZpY2V9IGZyb20gJy4uL3NpZGVuYXYuc2VydmljZSc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnbmF0dXJhbC1zaWRlbmF2LWNvbnRhaW5lcicsXG4gICAgdGVtcGxhdGVVcmw6ICcuL3NpZGVuYXYtY29udGFpbmVyLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9zaWRlbmF2LWNvbnRhaW5lci5jb21wb25lbnQuc2NzcyddLFxuICAgIHByb3ZpZGVyczogW05hdHVyYWxTaWRlbmF2U2VydmljZV0sXG59KVxuZXhwb3J0IGNsYXNzIE5hdHVyYWxTaWRlbmF2Q29udGFpbmVyQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3kge1xuICAgIC8qKlxuICAgICAqIFVuaXF1ZSBpZGVudGlmaWVyIHVzZWQgZm9yIHRoZSBsb2NhbCBzdG9yYWdlXG4gICAgICovXG4gICAgQElucHV0KCkgcHVibGljIG5hbWUhOiBzdHJpbmc7XG5cbiAgICAvKipcbiAgICAgKiBUaGUgc2lkZSB0aGF0IHRoZSBkcmF3ZXIgaXMgYXR0YWNoZWQgdG9cbiAgICAgKi9cbiAgICBASW5wdXQoKSBwdWJsaWMgcG9zaXRpb246IE1hdERyYXdlclsncG9zaXRpb24nXSA9ICdzdGFydCc7XG5cbiAgICAvKipcbiAgICAgKiBJZiB0cnVlIGxpc3RlbnMgdG8gcm91dGUgY2hhbmdlcyB0byBjbG9zZSBzaWRlIG5hdiBhZnRlciBhIHJvdXRlIGNoYW5nZSBpZiBtb2JpbGUgdmlldyBpcyBhY3RpdmVcbiAgICAgKiBBY3R1YWxseSBhIG5hdmlnYXRpb24gdG8gY3VycmVudCByb3V0ZSBkb2VzIG5vdCBlbWl0IGEgcm91dGUgY2hhbmdlLCBhbmQgdGhlIHNpZGVuYXYgZG9uJ3QgY2xvc2UuXG4gICAgICovXG4gICAgQElucHV0KCkgcHVibGljIG1vYmlsZUF1dG9DbG9zZSA9IHRydWU7XG5cbiAgICAvKipcbiAgICAgKiBXaWR0aCBvZiB0aGUgbWluaW1pemVkIG1lbnVcbiAgICAgKi9cbiAgICBASW5wdXQoKSBwdWJsaWMgbWluaW1pemVkV2lkdGggPSAxNTA7XG5cbiAgICAvKipcbiAgICAgKiBJZiB0cnVlLCBwcmV2ZW50cyBcIm5hdGl2ZVwiIG1hdGVyaWFsIHNpZGVuYXYgdG8gc2Nyb2xsIGF0IGNvbnRhaW5lciBsZXZlbCBhbmQgZGVsZWdhdGVzIHRoZSBzY3JvbGwgcmVzcG9uc2FiaWxpdHkgdG8gdGhlIHRyYW5zY2x1ZGVkXG4gICAgICogY29udGVudFxuICAgICAqL1xuICAgIEBIb3N0QmluZGluZygnYXR0ci5uby1zY3JvbGwnKSBASW5wdXQoKSBwdWJsaWMgbm9TY3JvbGwgPSBmYWxzZTtcblxuICAgIC8qKlxuICAgICAqIElubmVyIFwibmF0aXZlXCIgbWF0ZXJpYWwgc2lkZW5hdiBjb250YWluZXJcbiAgICAgKi9cbiAgICBAVmlld0NoaWxkKE1hdFNpZGVuYXZDb250YWluZXIsIHtzdGF0aWM6IHRydWV9KSBwcml2YXRlIG1lbnVDb250YWluZXIhOiBNYXRTaWRlbmF2Q29udGFpbmVyO1xuXG4gICAgLyoqXG4gICAgICogSW5uZXIgXCJuYXRpdmVcIiBtYXRlcmlhbCBzaWRlbmF2XG4gICAgICovXG4gICAgQFZpZXdDaGlsZChNYXRTaWRlbmF2LCB7c3RhdGljOiB0cnVlfSkgcHJpdmF0ZSBtZW51U2lkZW5hdiE6IE1hdFNpZGVuYXY7XG5cbiAgICBwdWJsaWMgY29uc3RydWN0b3IocHVibGljIHJlYWRvbmx5IHNpZGVuYXZTZXJ2aWNlOiBOYXR1cmFsU2lkZW5hdlNlcnZpY2UpIHt9XG5cbiAgICBwdWJsaWMgZ2V0IGlzTWluaW1pemVkKCk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gdGhpcy5zaWRlbmF2U2VydmljZS5pc01pbmltaXplZDtcbiAgICB9XG5cbiAgICBwdWJsaWMgZ2V0IGlzTW9iaWxlVmlldygpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuc2lkZW5hdlNlcnZpY2UuaXNNb2JpbGVWaWV3KCk7XG4gICAgfVxuXG4gICAgcHVibGljIG5nT25Jbml0KCk6IHZvaWQge1xuICAgICAgICB0aGlzLnNpZGVuYXZTZXJ2aWNlLmluaXQodGhpcy5uYW1lLCB0aGlzLm1lbnVDb250YWluZXIsIHRoaXMubWVudVNpZGVuYXYsIHRoaXMsIHRoaXMubW9iaWxlQXV0b0Nsb3NlKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgICAgIHRoaXMuc2lkZW5hdlNlcnZpY2UuZGVzdHJveSh0aGlzKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgdG9nZ2xlKCk6IHZvaWQge1xuICAgICAgICB0aGlzLnNpZGVuYXZTZXJ2aWNlLnRvZ2dsZSgpO1xuICAgIH1cblxuICAgIHB1YmxpYyBjbG9zZSgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5zaWRlbmF2U2VydmljZS5jbG9zZSgpO1xuICAgIH1cblxuICAgIHB1YmxpYyBvcGVuKCk6IHZvaWQge1xuICAgICAgICB0aGlzLnNpZGVuYXZTZXJ2aWNlLm9wZW4oKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgbWluaW1pemUoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuc2lkZW5hdlNlcnZpY2UubWluaW1pemUoKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgZXhwYW5kKCk6IHZvaWQge1xuICAgICAgICB0aGlzLnNpZGVuYXZTZXJ2aWNlLmV4cGFuZCgpO1xuICAgIH1cblxuICAgIHB1YmxpYyB0b2dnbGVNaW5pbWl6ZWQoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuc2lkZW5hdlNlcnZpY2UudG9nZ2xlTWluaW1pemVkKCk7XG4gICAgfVxufVxuIiwiPG1hdC1zaWRlbmF2LWNvbnRhaW5lciAoYmFja2Ryb3BDbGljayk9XCJzaWRlbmF2U2VydmljZS5zZXRPcGVuZWQoZmFsc2UpXCI+XG4gICAgPG1hdC1zaWRlbmF2XG4gICAgICAgIFttb2RlXT1cInNpZGVuYXZTZXJ2aWNlLmFjdGl2ZU1vZGVcIlxuICAgICAgICBbbmdDbGFzc109XCJzaWRlbmF2U2VydmljZS5pc01pbmltaXplZCA/ICdtZW51TWluaW1pemVkJyA6ICcnXCJcbiAgICAgICAgW29wZW5lZF09XCJzaWRlbmF2U2VydmljZS5pc09wZW5lZFwiXG4gICAgICAgIFtzdHlsZS5taW4td2lkdGgucHhdPVwic2lkZW5hdlNlcnZpY2UuaXNNaW5pbWl6ZWQgJiYgbWluaW1pemVkV2lkdGggPyBtaW5pbWl6ZWRXaWR0aCA6IG51bGxcIlxuICAgICAgICBbc3R5bGUud2lkdGgucHhdPVwic2lkZW5hdlNlcnZpY2UuaXNNaW5pbWl6ZWQgJiYgbWluaW1pemVkV2lkdGggPyBtaW5pbWl6ZWRXaWR0aCA6IG51bGxcIlxuICAgICAgICBbcG9zaXRpb25dPVwicG9zaXRpb25cIlxuICAgID5cbiAgICAgICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwibmF0dXJhbC1zaWRlbmF2XCI+PC9uZy1jb250ZW50PlxuICAgIDwvbWF0LXNpZGVuYXY+XG5cbiAgICA8bWF0LXNpZGVuYXYtY29udGVudD5cbiAgICAgICAgPGRpdj5cbiAgICAgICAgICAgIDxuZy1jb250ZW50IHNlbGVjdD1cIm5hdHVyYWwtc2lkZW5hdi1jb250ZW50XCI+PC9uZy1jb250ZW50PlxuICAgICAgICA8L2Rpdj5cbiAgICA8L21hdC1zaWRlbmF2LWNvbnRlbnQ+XG48L21hdC1zaWRlbmF2LWNvbnRhaW5lcj5cbiJdfQ==
@@ -1,13 +1,16 @@
1
1
  import { Component, Input, ViewEncapsulation } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
- import * as i1 from "@angular/material/button";
4
- import * as i2 from "../icon/icon.component";
3
+ import * as i1 from "../icon/icon.component";
4
+ import * as i2 from "@angular/material/button";
5
5
  import * as i3 from "@angular/common";
6
6
  import * as i4 from "@angular/router";
7
7
  /**
8
8
  * Button that fits well in a `<mat-table>` and support either
9
9
  * route navigation via `navigate` or external URL via `href`.
10
10
  *
11
+ * If neither `navigate` nor `href` has a meaningful value, then
12
+ * it will show the icon and/or label in `<span>` instead of a button
13
+ *
11
14
  * External URL will always be opened in new tab.
12
15
  */
13
16
  export class NaturalTableButtonComponent {
@@ -17,14 +20,26 @@ export class NaturalTableButtonComponent {
17
20
  this.navigate = [];
18
21
  this.preserveFragment = false;
19
22
  this.raised = false;
23
+ this.type = 'none';
24
+ }
25
+ ngOnChanges(changes) {
26
+ if (this.navigate?.length || Object.keys(this.queryParams).length) {
27
+ this.type = 'routerLink';
28
+ }
29
+ else if (this.href) {
30
+ this.type = 'href';
31
+ }
32
+ else {
33
+ this.type = 'none';
34
+ }
20
35
  }
21
36
  }
22
37
  NaturalTableButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalTableButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
23
- NaturalTableButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.0", type: NaturalTableButtonComponent, selector: "natural-table-button", inputs: { queryParams: "queryParams", queryParamsHandling: "queryParamsHandling", label: "label", icon: "icon", href: "href", navigate: "navigate", fragment: "fragment", preserveFragment: "preserveFragment", raised: "raised", color: "color" }, ngImport: i0, template: "<!-- Because directives can't be applied conditionally (routerLink, mat-button and mat-icon-button), we have to use different elements -->\n\n<ng-container *ngIf=\"!raised\">\n <!-- App routed link with label... -->\n <a\n *ngIf=\"!href && label\"\n [color]=\"color\"\n [queryParams]=\"queryParams\"\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=\"!href && !label\"\n [color]=\"color\"\n [queryParamsHandling]=\"queryParamsHandling\"\n [queryParams]=\"queryParams\"\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 <!-- External link with label... -->\n <a *ngIf=\"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=\"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=\"!href && label\"\n [color]=\"color\"\n [queryParams]=\"queryParams\"\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=\"!href && !label\"\n [color]=\"color\"\n [queryParamsHandling]=\"queryParamsHandling\"\n [queryParams]=\"queryParams\"\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\n <!-- External link with label... -->\n <a *ngIf=\"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 *ngIf=\"href && !label\" [attr.href]=\"href\" [color]=\"color\" mat-icon-button mat-raised-button target=\"_blank\">\n <natural-icon *ngIf=\"icon\" [name]=\"icon\"></natural-icon>\n </a>\n</ng-container>\n", styles: ["natural-table-button{flex:1;display:flex;flex-direction:row;justify-content:flex-start;align-items:center}natural-table-button a.mat-button{flex:1;display:flex;flex-direction:row;align-items:center;justify-content:flex-start}natural-table-button a.mat-button .mat-button-wrapper{display:flex;flex-direction:row;align-items:center}natural-table-button a.mat-button .mat-button-wrapper>*{display:flex;flex-direction:row;align-items:center}natural-table-button a.mat-button .mat-button-wrapper>:not(:last-child){margin-right:5px}\n"], components: [{ type: i1.MatAnchor, selector: "a[mat-button], a[mat-raised-button], a[mat-icon-button], a[mat-fab], a[mat-mini-fab], a[mat-stroked-button], a[mat-flat-button]", inputs: ["disabled", "disableRipple", "color", "tabIndex"], exportAs: ["matButton", "matAnchor"] }, { type: i2.NaturalIconComponent, selector: "natural-icon", inputs: ["label", "labelColor", "labelPosition", "name", "size"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo", "routerLink"] }], encapsulation: i0.ViewEncapsulation.None });
38
+ NaturalTableButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.0", type: NaturalTableButtonComponent, selector: "natural-table-button", inputs: { queryParams: "queryParams", queryParamsHandling: "queryParamsHandling", label: "label", icon: "icon", href: "href", navigate: "navigate", fragment: "fragment", preserveFragment: "preserveFragment", raised: "raised", color: "color" }, usesOnChanges: true, ngImport: i0, template: "<!-- 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 <!-- 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\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", styles: ["natural-table-button{flex:1;display:flex;flex-direction:row;justify-content:flex-start;align-items:center}natural-table-button a.mat-button{flex:1;display:flex;flex-direction:row;align-items:center;justify-content:flex-start}natural-table-button a.mat-button .mat-button-wrapper{display:flex;flex-direction:row;align-items:center}natural-table-button a.mat-button .mat-button-wrapper>*{display:flex;flex-direction:row;align-items:center}natural-table-button a.mat-button .mat-button-wrapper>:not(:last-child){margin-right:5px}natural-table-button>span{padding:0 16px}\n"], components: [{ type: i1.NaturalIconComponent, selector: "natural-icon", inputs: ["label", "labelColor", "labelPosition", "name", "size"] }, { type: i2.MatAnchor, selector: "a[mat-button], a[mat-raised-button], a[mat-icon-button], a[mat-fab], a[mat-mini-fab], a[mat-stroked-button], a[mat-flat-button]", inputs: ["disabled", "disableRipple", "color", "tabIndex"], exportAs: ["matButton", "matAnchor"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo", "routerLink"] }], encapsulation: i0.ViewEncapsulation.None });
24
39
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalTableButtonComponent, decorators: [{
25
40
  type: Component,
26
- args: [{ selector: 'natural-table-button', encapsulation: ViewEncapsulation.None, template: "<!-- Because directives can't be applied conditionally (routerLink, mat-button and mat-icon-button), we have to use different elements -->\n\n<ng-container *ngIf=\"!raised\">\n <!-- App routed link with label... -->\n <a\n *ngIf=\"!href && label\"\n [color]=\"color\"\n [queryParams]=\"queryParams\"\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=\"!href && !label\"\n [color]=\"color\"\n [queryParamsHandling]=\"queryParamsHandling\"\n [queryParams]=\"queryParams\"\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 <!-- External link with label... -->\n <a *ngIf=\"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=\"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=\"!href && label\"\n [color]=\"color\"\n [queryParams]=\"queryParams\"\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=\"!href && !label\"\n [color]=\"color\"\n [queryParamsHandling]=\"queryParamsHandling\"\n [queryParams]=\"queryParams\"\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\n <!-- External link with label... -->\n <a *ngIf=\"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 *ngIf=\"href && !label\" [attr.href]=\"href\" [color]=\"color\" mat-icon-button mat-raised-button target=\"_blank\">\n <natural-icon *ngIf=\"icon\" [name]=\"icon\"></natural-icon>\n </a>\n</ng-container>\n", styles: ["natural-table-button{flex:1;display:flex;flex-direction:row;justify-content:flex-start;align-items:center}natural-table-button a.mat-button{flex:1;display:flex;flex-direction:row;align-items:center;justify-content:flex-start}natural-table-button a.mat-button .mat-button-wrapper{display:flex;flex-direction:row;align-items:center}natural-table-button a.mat-button .mat-button-wrapper>*{display:flex;flex-direction:row;align-items:center}natural-table-button a.mat-button .mat-button-wrapper>:not(:last-child){margin-right:5px}\n"] }]
27
- }], ctorParameters: function () { return []; }, propDecorators: { queryParams: [{
41
+ args: [{ selector: 'natural-table-button', encapsulation: ViewEncapsulation.None, template: "<!-- 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 <!-- 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\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", styles: ["natural-table-button{flex:1;display:flex;flex-direction:row;justify-content:flex-start;align-items:center}natural-table-button a.mat-button{flex:1;display:flex;flex-direction:row;align-items:center;justify-content:flex-start}natural-table-button a.mat-button .mat-button-wrapper{display:flex;flex-direction:row;align-items:center}natural-table-button a.mat-button .mat-button-wrapper>*{display:flex;flex-direction:row;align-items:center}natural-table-button a.mat-button .mat-button-wrapper>:not(:last-child){margin-right:5px}natural-table-button>span{padding:0 16px}\n"] }]
42
+ }], propDecorators: { queryParams: [{
28
43
  type: Input
29
44
  }], queryParamsHandling: [{
30
45
  type: Input
@@ -45,4 +60,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.0", ngImpor
45
60
  }], color: [{
46
61
  type: Input
47
62
  }] } });
48
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL3RhYmxlLWJ1dHRvbi90YWJsZS1idXR0b24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvdGFibGUtYnV0dG9uL3RhYmxlLWJ1dHRvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLEtBQUssRUFBRSxpQkFBaUIsRUFBQyxNQUFNLGVBQWUsQ0FBQzs7Ozs7O0FBSWxFOzs7OztHQUtHO0FBT0gsTUFBTSxPQUFPLDJCQUEyQjtJQWNwQztRQWJnQixnQkFBVyxHQUV2QixFQUFFLENBQUM7UUFDUyx3QkFBbUIsR0FBd0IsRUFBRSxDQUFDO1FBSTlDLGFBQVEsR0FBNkIsRUFBRSxDQUFDO1FBRXhDLHFCQUFnQixHQUFHLEtBQUssQ0FBQztRQUN6QixXQUFNLEdBQUcsS0FBSyxDQUFDO0lBR1QsQ0FBQzs7d0hBZGQsMkJBQTJCOzRHQUEzQiwyQkFBMkIsZ1RDaEJ4Qyw0NEZBb0ZBOzJGRHBFYSwyQkFBMkI7a0JBTnZDLFNBQVM7K0JBQ0ksc0JBQXNCLGlCQUdqQixpQkFBaUIsQ0FBQyxJQUFJOzBFQUdyQixXQUFXO3NCQUExQixLQUFLO2dCQUdVLG1CQUFtQjtzQkFBbEMsS0FBSztnQkFDVSxLQUFLO3NCQUFwQixLQUFLO2dCQUNVLElBQUk7c0JBQW5CLEtBQUs7Z0JBQ1UsSUFBSTtzQkFBbkIsS0FBSztnQkFDVSxRQUFRO3NCQUF2QixLQUFLO2dCQUNVLFFBQVE7c0JBQXZCLEtBQUs7Z0JBQ1UsZ0JBQWdCO3NCQUEvQixLQUFLO2dCQUNVLE1BQU07c0JBQXJCLEtBQUs7Z0JBQ1UsS0FBSztzQkFBcEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBJbnB1dCwgVmlld0VuY2Fwc3VsYXRpb259IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtRdWVyeVBhcmFtc0hhbmRsaW5nLCBSb3V0ZXJMaW5rfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuaW1wb3J0IHtUaGVtZVBhbGV0dGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NvcmUnO1xuXG4vKipcbiAqIEJ1dHRvbiB0aGF0IGZpdHMgd2VsbCBpbiBhIGA8bWF0LXRhYmxlPmAgYW5kIHN1cHBvcnQgZWl0aGVyXG4gKiByb3V0ZSBuYXZpZ2F0aW9uIHZpYSBgbmF2aWdhdGVgIG9yIGV4dGVybmFsIFVSTCB2aWEgYGhyZWZgLlxuICpcbiAqIEV4dGVybmFsIFVSTCB3aWxsIGFsd2F5cyBiZSBvcGVuZWQgaW4gbmV3IHRhYi5cbiAqL1xuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICduYXR1cmFsLXRhYmxlLWJ1dHRvbicsXG4gICAgdGVtcGxhdGVVcmw6ICcuL3RhYmxlLWJ1dHRvbi5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vdGFibGUtYnV0dG9uLmNvbXBvbmVudC5zY3NzJ10sXG4gICAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbn0pXG5leHBvcnQgY2xhc3MgTmF0dXJhbFRhYmxlQnV0dG9uQ29tcG9uZW50IHtcbiAgICBASW5wdXQoKSBwdWJsaWMgcXVlcnlQYXJhbXM6IHtcbiAgICAgICAgW2s6IHN0cmluZ106IGFueTtcbiAgICB9ID0ge307XG4gICAgQElucHV0KCkgcHVibGljIHF1ZXJ5UGFyYW1zSGFuZGxpbmc6IFF1ZXJ5UGFyYW1zSGFuZGxpbmcgPSAnJztcbiAgICBASW5wdXQoKSBwdWJsaWMgbGFiZWw/OiBzdHJpbmcgfCBudWxsO1xuICAgIEBJbnB1dCgpIHB1YmxpYyBpY29uPzogc3RyaW5nIHwgbnVsbDtcbiAgICBASW5wdXQoKSBwdWJsaWMgaHJlZj86IHN0cmluZyB8IG51bGw7XG4gICAgQElucHV0KCkgcHVibGljIG5hdmlnYXRlOiBSb3V0ZXJMaW5rWydyb3V0ZXJMaW5rJ10gPSBbXTtcbiAgICBASW5wdXQoKSBwdWJsaWMgZnJhZ21lbnQ/OiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gICAgQElucHV0KCkgcHVibGljIHByZXNlcnZlRnJhZ21lbnQgPSBmYWxzZTtcbiAgICBASW5wdXQoKSBwdWJsaWMgcmFpc2VkID0gZmFsc2U7XG4gICAgQElucHV0KCkgcHVibGljIGNvbG9yOiBUaGVtZVBhbGV0dGU7XG5cbiAgICBwdWJsaWMgY29uc3RydWN0b3IoKSB7fVxufVxuIiwiPCEtLSBCZWNhdXNlIGRpcmVjdGl2ZXMgY2FuJ3QgYmUgYXBwbGllZCBjb25kaXRpb25hbGx5IChyb3V0ZXJMaW5rLCBtYXQtYnV0dG9uIGFuZCBtYXQtaWNvbi1idXR0b24pLCB3ZSBoYXZlIHRvIHVzZSBkaWZmZXJlbnQgZWxlbWVudHMgLS0+XG5cbjxuZy1jb250YWluZXIgKm5nSWY9XCIhcmFpc2VkXCI+XG4gICAgPCEtLSBBcHAgcm91dGVkIGxpbmsgd2l0aCBsYWJlbC4uLiAtLT5cbiAgICA8YVxuICAgICAgICAqbmdJZj1cIiFocmVmICYmIGxhYmVsXCJcbiAgICAgICAgW2NvbG9yXT1cImNvbG9yXCJcbiAgICAgICAgW3F1ZXJ5UGFyYW1zXT1cInF1ZXJ5UGFyYW1zXCJcbiAgICAgICAgW3JvdXRlckxpbmtdPVwibmF2aWdhdGVcIlxuICAgICAgICBbZnJhZ21lbnRdPVwiZnJhZ21lbnRcIlxuICAgICAgICBbcHJlc2VydmVGcmFnbWVudF09XCJwcmVzZXJ2ZUZyYWdtZW50XCJcbiAgICAgICAgbWF0LWJ1dHRvblxuICAgID5cbiAgICAgICAgPG5hdHVyYWwtaWNvbiAqbmdJZj1cImljb25cIiBbbmFtZV09XCJpY29uXCI+PC9uYXR1cmFsLWljb24+XG4gICAgICAgIDxzcGFuPnt7IGxhYmVsIH19PC9zcGFuPlxuICAgIDwvYT5cblxuICAgIDwhLS0gLi4uIGFuZCB3aXRob3V0IGxhYmVsIC0tPlxuICAgIDxhXG4gICAgICAgICpuZ0lmPVwiIWhyZWYgJiYgIWxhYmVsXCJcbiAgICAgICAgW2NvbG9yXT1cImNvbG9yXCJcbiAgICAgICAgW3F1ZXJ5UGFyYW1zSGFuZGxpbmddPVwicXVlcnlQYXJhbXNIYW5kbGluZ1wiXG4gICAgICAgIFtxdWVyeVBhcmFtc109XCJxdWVyeVBhcmFtc1wiXG4gICAgICAgIFtyb3V0ZXJMaW5rXT1cIm5hdmlnYXRlXCJcbiAgICAgICAgW2ZyYWdtZW50XT1cImZyYWdtZW50XCJcbiAgICAgICAgW3ByZXNlcnZlRnJhZ21lbnRdPVwicHJlc2VydmVGcmFnbWVudFwiXG4gICAgICAgIG1hdC1pY29uLWJ1dHRvblxuICAgID5cbiAgICAgICAgPG5hdHVyYWwtaWNvbiAqbmdJZj1cImljb25cIiBbbmFtZV09XCJpY29uXCI+PC9uYXR1cmFsLWljb24+XG4gICAgPC9hPlxuXG4gICAgPCEtLSBFeHRlcm5hbCBsaW5rIHdpdGggbGFiZWwuLi4gLS0+XG4gICAgPGEgKm5nSWY9XCJocmVmICYmIGxhYmVsXCIgW2F0dHIuaHJlZl09XCJocmVmXCIgW2NvbG9yXT1cImNvbG9yXCIgbWF0LWJ1dHRvbiB0YXJnZXQ9XCJfYmxhbmtcIj5cbiAgICAgICAgPG5hdHVyYWwtaWNvbiAqbmdJZj1cImljb25cIiBbbmFtZV09XCJpY29uXCI+PC9uYXR1cmFsLWljb24+XG4gICAgICAgIDxzcGFuPnt7IGxhYmVsIH19PC9zcGFuPlxuICAgIDwvYT5cblxuICAgIDwhLS0gLi4uIGFuZCB3aXRob3V0IGxhYmVsIC0tPlxuICAgIDxhICpuZ0lmPVwiaHJlZiAmJiAhbGFiZWxcIiBbYXR0ci5ocmVmXT1cImhyZWZcIiBbY29sb3JdPVwiY29sb3JcIiBtYXQtaWNvbi1idXR0b24gdGFyZ2V0PVwiX2JsYW5rXCI+XG4gICAgICAgIDxuYXR1cmFsLWljb24gKm5nSWY9XCJpY29uXCIgW25hbWVdPVwiaWNvblwiPjwvbmF0dXJhbC1pY29uPlxuICAgIDwvYT5cbjwvbmctY29udGFpbmVyPlxuXG48bmctY29udGFpbmVyICpuZ0lmPVwicmFpc2VkXCI+XG4gICAgPCEtLSBBcHAgcm91dGVkIGxpbmsgd2l0aCBsYWJlbC4uLiAtLT5cbiAgICA8YVxuICAgICAgICAqbmdJZj1cIiFocmVmICYmIGxhYmVsXCJcbiAgICAgICAgW2NvbG9yXT1cImNvbG9yXCJcbiAgICAgICAgW3F1ZXJ5UGFyYW1zXT1cInF1ZXJ5UGFyYW1zXCJcbiAgICAgICAgW3JvdXRlckxpbmtdPVwibmF2aWdhdGVcIlxuICAgICAgICBbZnJhZ21lbnRdPVwiZnJhZ21lbnRcIlxuICAgICAgICBbcHJlc2VydmVGcmFnbWVudF09XCJwcmVzZXJ2ZUZyYWdtZW50XCJcbiAgICAgICAgbWF0LXJhaXNlZC1idXR0b25cbiAgICA+XG4gICAgICAgIDxuYXR1cmFsLWljb24gKm5nSWY9XCJpY29uXCIgW25hbWVdPVwiaWNvblwiPjwvbmF0dXJhbC1pY29uPlxuICAgICAgICA8c3Bhbj57eyBsYWJlbCB9fTwvc3Bhbj5cbiAgICA8L2E+XG5cbiAgICA8IS0tIC4uLiBhbmQgd2l0aG91dCBsYWJlbCAtLT5cbiAgICA8YVxuICAgICAgICAqbmdJZj1cIiFocmVmICYmICFsYWJlbFwiXG4gICAgICAgIFtjb2xvcl09XCJjb2xvclwiXG4gICAgICAgIFtxdWVyeVBhcmFtc0hhbmRsaW5nXT1cInF1ZXJ5UGFyYW1zSGFuZGxpbmdcIlxuICAgICAgICBbcXVlcnlQYXJhbXNdPVwicXVlcnlQYXJhbXNcIlxuICAgICAgICBbcm91dGVyTGlua109XCJuYXZpZ2F0ZVwiXG4gICAgICAgIFtmcmFnbWVudF09XCJmcmFnbWVudFwiXG4gICAgICAgIFtwcmVzZXJ2ZUZyYWdtZW50XT1cInByZXNlcnZlRnJhZ21lbnRcIlxuICAgICAgICBtYXQtaWNvbi1idXR0b25cbiAgICAgICAgbWF0LXJhaXNlZC1idXR0b25cbiAgICA+XG4gICAgICAgIDxuYXR1cmFsLWljb24gKm5nSWY9XCJpY29uXCIgW25hbWVdPVwiaWNvblwiPjwvbmF0dXJhbC1pY29uPlxuICAgIDwvYT5cblxuICAgIDwhLS0gRXh0ZXJuYWwgbGluayB3aXRoIGxhYmVsLi4uIC0tPlxuICAgIDxhICpuZ0lmPVwiaHJlZiAmJiBsYWJlbFwiIFthdHRyLmhyZWZdPVwiaHJlZlwiIFtjb2xvcl09XCJjb2xvclwiIG1hdC1yYWlzZWQtYnV0dG9uIHRhcmdldD1cIl9ibGFua1wiPlxuICAgICAgICA8bmF0dXJhbC1pY29uICpuZ0lmPVwiaWNvblwiIFtuYW1lXT1cImljb25cIj48L25hdHVyYWwtaWNvbj5cbiAgICAgICAgPHNwYW4+e3sgbGFiZWwgfX08L3NwYW4+XG4gICAgPC9hPlxuXG4gICAgPCEtLSAuLi4gYW5kIHdpdGhvdXQgbGFiZWwgLS0+XG4gICAgPGEgKm5nSWY9XCJocmVmICYmICFsYWJlbFwiIFthdHRyLmhyZWZdPVwiaHJlZlwiIFtjb2xvcl09XCJjb2xvclwiIG1hdC1pY29uLWJ1dHRvbiBtYXQtcmFpc2VkLWJ1dHRvbiB0YXJnZXQ9XCJfYmxhbmtcIj5cbiAgICAgICAgPG5hdHVyYWwtaWNvbiAqbmdJZj1cImljb25cIiBbbmFtZV09XCJpY29uXCI+PC9uYXR1cmFsLWljb24+XG4gICAgPC9hPlxuPC9uZy1jb250YWluZXI+XG4iXX0=
63
+ //# 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,KAAK,EAA4B,iBAAiB,EAAC,MAAM,eAAe,CAAC;;;;;;AAI5F;;;;;;;;GAQG;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;QAExB,SAAI,GAAmC,MAAM,CAAC;KAWxD;IATU,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;YACH,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC;SACtB;IACL,CAAC;;wHArBQ,2BAA2B;4GAA3B,2BAA2B,qUCnBxC,+3GAmGA;2FDhFa,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","sourcesContent":["import {Component, Input, OnChanges, 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 *\n * If neither `navigate` nor `href` has a meaningful value, then\n * it will show the icon and/or label in `<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    public type: 'routerLink' | 'href' | '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 {\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    <!-- 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\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"]}