coer-elements 0.0.10 → 0.0.12
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/components/index.d.ts +1 -0
- package/components/lib/coer-button/coer-button.component.d.ts +44 -0
- package/components/lib/components.module.d.ts +6 -4
- package/esm2022/components/index.mjs +2 -1
- package/esm2022/components/lib/coer-button/coer-button.component.mjs +133 -0
- package/esm2022/components/lib/components.module.mjs +15 -9
- package/esm2022/interfaces/index.mjs +7 -0
- package/esm2022/interfaces/lib/app-source.interface.mjs +2 -0
- package/esm2022/interfaces/lib/breadcrumb.interface.mjs +2 -0
- package/esm2022/interfaces/lib/coer-ref.interface.mjs +2 -0
- package/esm2022/interfaces/lib/go-back.interface.mjs +2 -0
- package/esm2022/interfaces/lib/patch.interface.mjs +2 -0
- package/esm2022/interfaces/lib/screen-size.interface.mjs +2 -0
- package/esm2022/public_api.mjs +2 -1
- package/esm2022/signals/index.mjs +4 -0
- package/esm2022/signals/lib/breakpoint.signal.mjs +4 -0
- package/esm2022/signals/lib/is-loading.signal.mjs +3 -0
- package/esm2022/signals/lib/is-modal-open.signal.mjs +3 -0
- package/esm2022/tools/index.mjs +9 -2
- package/esm2022/tools/lib/breadcrumbs.class.mjs +63 -0
- package/esm2022/tools/lib/control-value.class.mjs +46 -0
- package/esm2022/tools/lib/date-time.class.mjs +22 -0
- package/esm2022/tools/lib/files.class.mjs +91 -0
- package/esm2022/tools/lib/generi-tools.mjs +199 -0
- package/esm2022/tools/lib/page.class.mjs +156 -0
- package/esm2022/tools/lib/screen.class.mjs +43 -0
- package/esm2022/tools/lib/source.class.mjs +80 -0
- package/fesm2022/coer-elements.mjs +836 -54
- package/fesm2022/coer-elements.mjs.map +1 -1
- package/interfaces/index.d.ts +6 -0
- package/interfaces/lib/app-source.interface.d.ts +4 -0
- package/interfaces/lib/breadcrumb.interface.d.ts +6 -0
- package/interfaces/lib/coer-ref.interface.d.ts +10 -0
- package/interfaces/lib/go-back.interface.d.ts +6 -0
- package/interfaces/lib/patch.interface.d.ts +5 -0
- package/interfaces/lib/screen-size.interface.d.ts +5 -0
- package/package.json +1 -1
- package/public_api.d.ts +1 -0
- package/signals/index.d.ts +3 -0
- package/signals/lib/breakpoint.signal.d.ts +1 -0
- package/signals/lib/is-loading.signal.d.ts +1 -0
- package/signals/lib/is-modal-open.signal.d.ts +1 -0
- package/src/interfaces/index.ts +6 -0
- package/src/interfaces/lib/app-source.interface.ts +4 -0
- package/src/interfaces/lib/breadcrumb.interface.ts +6 -0
- package/src/interfaces/lib/coer-ref.interface.ts +11 -0
- package/src/interfaces/lib/go-back.interface.ts +6 -0
- package/src/interfaces/lib/patch.interface.ts +5 -0
- package/src/interfaces/lib/screen-size.interface.ts +5 -0
- package/tools/index.d.ts +8 -1
- package/tools/lib/breadcrumbs.class.d.ts +18 -0
- package/tools/lib/date-time.class.d.ts +11 -0
- package/tools/lib/files.class.d.ts +16 -0
- package/tools/lib/generi-tools.d.ts +32 -0
- package/tools/lib/page.class.d.ts +60 -0
- package/tools/lib/screen.class.d.ts +11 -0
- package/tools/lib/source.class.d.ts +20 -0
- package/esm2022/tools/lib/controlValue.mjs +0 -46
- /package/tools/lib/{controlValue.d.ts → control-value.class.d.ts} +0 -0
    
        package/components/index.d.ts
    CHANGED
    
    
| @@ -0,0 +1,44 @@ | |
| 1 | 
            +
            import { EventEmitter, OnDestroy, OnInit } from '@angular/core';
         | 
| 2 | 
            +
            import * as i0 from "@angular/core";
         | 
| 3 | 
            +
            export declare class CoerButton implements OnInit, OnDestroy {
         | 
| 4 | 
            +
                protected _id: string;
         | 
| 5 | 
            +
                private _element;
         | 
| 6 | 
            +
                private _tooltip;
         | 
| 7 | 
            +
                private _tooltipElement;
         | 
| 8 | 
            +
                id: string;
         | 
| 9 | 
            +
                color: import("@angular/core").InputSignal<"warning" | "danger" | "success" | "default" | "primary" | "secondary" | "navigation">;
         | 
| 10 | 
            +
                type: import("@angular/core").InputSignal<"icon" | "filled" | "outline" | "icon-outline" | "icon-no-border">;
         | 
| 11 | 
            +
                icon: import("@angular/core").InputSignal<"" | "delete" | "cancel" | "new" | "save" | "import" | "excel" | "menu" | "edit" | "go" | "back">;
         | 
| 12 | 
            +
                iconPosition: import("@angular/core").InputSignal<"left" | "right">;
         | 
| 13 | 
            +
                animation: import("@angular/core").InputSignal<boolean>;
         | 
| 14 | 
            +
                isLoading: import("@angular/core").InputSignal<boolean>;
         | 
| 15 | 
            +
                isDisabled: import("@angular/core").InputSignal<boolean>;
         | 
| 16 | 
            +
                isInvisible: import("@angular/core").InputSignal<boolean>;
         | 
| 17 | 
            +
                width: import("@angular/core").InputSignal<string>;
         | 
| 18 | 
            +
                minWidth: import("@angular/core").InputSignal<string>;
         | 
| 19 | 
            +
                height: import("@angular/core").InputSignal<string>;
         | 
| 20 | 
            +
                minHeight: import("@angular/core").InputSignal<string>;
         | 
| 21 | 
            +
                marginTop: import("@angular/core").InputSignal<string>;
         | 
| 22 | 
            +
                marginRight: import("@angular/core").InputSignal<string>;
         | 
| 23 | 
            +
                marginBottom: import("@angular/core").InputSignal<string>;
         | 
| 24 | 
            +
                marginLeft: import("@angular/core").InputSignal<string>;
         | 
| 25 | 
            +
                path: import("@angular/core").InputSignal<string | (string | number)[]>;
         | 
| 26 | 
            +
                tooltipPosition: import("@angular/core").InputSignal<"left" | "right" | "top" | "bottom">;
         | 
| 27 | 
            +
                set tooltip(value: string);
         | 
| 28 | 
            +
                onClick: EventEmitter<MouseEvent>;
         | 
| 29 | 
            +
                protected _isEnable: import("@angular/core").Signal<boolean>;
         | 
| 30 | 
            +
                protected _icon: import("@angular/core").Signal<string>;
         | 
| 31 | 
            +
                ngOnInit(): void;
         | 
| 32 | 
            +
                ngOnDestroy(): void;
         | 
| 33 | 
            +
                /** */
         | 
| 34 | 
            +
                private SetEvents;
         | 
| 35 | 
            +
                private SetToolTip;
         | 
| 36 | 
            +
                /** */
         | 
| 37 | 
            +
                protected Click(event: MouseEvent): void;
         | 
| 38 | 
            +
                /** */
         | 
| 39 | 
            +
                Focus(timeout?: number): void;
         | 
| 40 | 
            +
                /** */
         | 
| 41 | 
            +
                Blur(): void;
         | 
| 42 | 
            +
                static ɵfac: i0.ɵɵFactoryDeclaration<CoerButton, never>;
         | 
| 43 | 
            +
                static ɵcmp: i0.ɵɵComponentDeclaration<CoerButton, "coer-button", never, { "id": { "alias": "id"; "required": false; }; "color": { "alias": "color"; "required": false; "isSignal": true; }; "type": { "alias": "type"; "required": false; "isSignal": true; }; "icon": { "alias": "icon"; "required": false; "isSignal": true; }; "iconPosition": { "alias": "iconPosition"; "required": false; "isSignal": true; }; "animation": { "alias": "animation"; "required": false; "isSignal": true; }; "isLoading": { "alias": "isLoading"; "required": false; "isSignal": true; }; "isDisabled": { "alias": "isDisabled"; "required": false; "isSignal": true; }; "isInvisible": { "alias": "isInvisible"; "required": false; "isSignal": true; }; "width": { "alias": "width"; "required": false; "isSignal": true; }; "minWidth": { "alias": "minWidth"; "required": false; "isSignal": true; }; "height": { "alias": "height"; "required": false; "isSignal": true; }; "minHeight": { "alias": "minHeight"; "required": false; "isSignal": true; }; "marginTop": { "alias": "marginTop"; "required": false; "isSignal": true; }; "marginRight": { "alias": "marginRight"; "required": false; "isSignal": true; }; "marginBottom": { "alias": "marginBottom"; "required": false; "isSignal": true; }; "marginLeft": { "alias": "marginLeft"; "required": false; "isSignal": true; }; "path": { "alias": "path"; "required": false; "isSignal": true; }; "tooltipPosition": { "alias": "tooltipPosition"; "required": false; "isSignal": true; }; "tooltip": { "alias": "tooltip"; "required": false; }; }, { "onClick": "onClick"; }, never, ["*"], false, never>;
         | 
| 44 | 
            +
            }
         | 
| @@ -1,10 +1,12 @@ | |
| 1 1 | 
             
            import * as i0 from "@angular/core";
         | 
| 2 2 | 
             
            import * as i1 from "./coer-alert/coer-alert.component";
         | 
| 3 | 
            -
            import * as i2 from " | 
| 4 | 
            -
            import * as i3 from "@angular/ | 
| 5 | 
            -
            import * as i4 from "@angular/ | 
| 3 | 
            +
            import * as i2 from "./coer-button/coer-button.component";
         | 
| 4 | 
            +
            import * as i3 from "@angular/common";
         | 
| 5 | 
            +
            import * as i4 from "@angular/router";
         | 
| 6 | 
            +
            import * as i5 from "@angular/forms";
         | 
| 7 | 
            +
            import * as i6 from "@angular/material/button";
         | 
| 6 8 | 
             
            export declare class ComponentsModule {
         | 
| 7 9 | 
             
                static ɵfac: i0.ɵɵFactoryDeclaration<ComponentsModule, never>;
         | 
| 8 | 
            -
                static ɵmod: i0.ɵɵNgModuleDeclaration<ComponentsModule, [typeof i1.CoerAlert], [typeof  | 
| 10 | 
            +
                static ɵmod: i0.ɵɵNgModuleDeclaration<ComponentsModule, [typeof i1.CoerAlert, typeof i2.CoerButton], [typeof i3.CommonModule, typeof i4.RouterModule, typeof i5.FormsModule, typeof i5.ReactiveFormsModule, typeof i6.MatButtonModule], [typeof i1.CoerAlert, typeof i2.CoerButton]>;
         | 
| 9 11 | 
             
                static ɵinj: i0.ɵɵInjectorDeclaration<ComponentsModule>;
         | 
| 10 12 | 
             
            }
         | 
| @@ -1,3 +1,4 @@ | |
| 1 1 | 
             
            export * from './lib/components.module';
         | 
| 2 2 | 
             
            export * from './lib/coer-alert/coer-alert.component';
         | 
| 3 | 
            -
             | 
| 3 | 
            +
            export * from './lib/coer-button/coer-button.component';
         | 
| 4 | 
            +
            //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jb2VyLWVsZW1lbnRzL3NyYy9jb21wb25lbnRzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLHlDQUF5QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy5tb2R1bGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb2VyLWFsZXJ0L2NvZXItYWxlcnQuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29lci1idXR0b24vY29lci1idXR0b24uY29tcG9uZW50JzsiXX0=
         | 
| @@ -0,0 +1,133 @@ | |
| 1 | 
            +
            import { Component, computed, EventEmitter, input, Input, Output } from '@angular/core';
         | 
| 2 | 
            +
            import { Tools } from '../../../tools';
         | 
| 3 | 
            +
            import { Tooltip } from 'bootstrap';
         | 
| 4 | 
            +
            import * as i0 from "@angular/core";
         | 
| 5 | 
            +
            import * as i1 from "@angular/common";
         | 
| 6 | 
            +
            import * as i2 from "@angular/router";
         | 
| 7 | 
            +
            import * as i3 from "@angular/material/button";
         | 
| 8 | 
            +
            export class CoerButton {
         | 
| 9 | 
            +
                constructor() {
         | 
| 10 | 
            +
                    //Variables
         | 
| 11 | 
            +
                    this._id = Tools.GetGuid('coer-button');
         | 
| 12 | 
            +
                    this._tooltip = '';
         | 
| 13 | 
            +
                    //Inputs
         | 
| 14 | 
            +
                    this.id = '';
         | 
| 15 | 
            +
                    this.color = input('default');
         | 
| 16 | 
            +
                    this.type = input('filled');
         | 
| 17 | 
            +
                    this.icon = input('');
         | 
| 18 | 
            +
                    this.iconPosition = input('left');
         | 
| 19 | 
            +
                    this.animation = input(false);
         | 
| 20 | 
            +
                    this.isLoading = input(false);
         | 
| 21 | 
            +
                    this.isDisabled = input(false);
         | 
| 22 | 
            +
                    this.isInvisible = input(false);
         | 
| 23 | 
            +
                    this.width = input('125px');
         | 
| 24 | 
            +
                    this.minWidth = input('30px');
         | 
| 25 | 
            +
                    this.height = input('40px');
         | 
| 26 | 
            +
                    this.minHeight = input('30px');
         | 
| 27 | 
            +
                    this.marginTop = input('0px');
         | 
| 28 | 
            +
                    this.marginRight = input('0px');
         | 
| 29 | 
            +
                    this.marginBottom = input('0px');
         | 
| 30 | 
            +
                    this.marginLeft = input('0px');
         | 
| 31 | 
            +
                    this.path = input([]);
         | 
| 32 | 
            +
                    this.tooltipPosition = input('left');
         | 
| 33 | 
            +
                    //Outputs
         | 
| 34 | 
            +
                    this.onClick = new EventEmitter();
         | 
| 35 | 
            +
                    //computed
         | 
| 36 | 
            +
                    this._isEnable = computed(() => {
         | 
| 37 | 
            +
                        return !this.isLoading() && !this.isDisabled() && !this.isInvisible();
         | 
| 38 | 
            +
                    });
         | 
| 39 | 
            +
                    //computed
         | 
| 40 | 
            +
                    this._icon = computed(() => {
         | 
| 41 | 
            +
                        switch (this.icon()) {
         | 
| 42 | 
            +
                            case 'new': return 'fa-solid fa-plus fa-lg';
         | 
| 43 | 
            +
                            case 'save': return 'fa-solid fa-floppy-disk fa-lg';
         | 
| 44 | 
            +
                            case 'cancel': return 'fa-solid fa-xmark fa-lg';
         | 
| 45 | 
            +
                            case 'import': return 'fa-solid fa-file-arrow-up fa-lg';
         | 
| 46 | 
            +
                            case 'excel': return 'bi bi-filetype-xlsx fa-lg';
         | 
| 47 | 
            +
                            case 'menu': return 'fa-solid fa-bars';
         | 
| 48 | 
            +
                            case 'delete': return 'fa-solid fa-trash-can';
         | 
| 49 | 
            +
                            case 'edit': return 'fa-solid fa-pen fa-lg';
         | 
| 50 | 
            +
                            case 'go': return 'bi bi-box-arrow-right';
         | 
| 51 | 
            +
                            case 'back': return 'bi bi-box-arrow-left';
         | 
| 52 | 
            +
                            default: return '';
         | 
| 53 | 
            +
                        }
         | 
| 54 | 
            +
                    });
         | 
| 55 | 
            +
                }
         | 
| 56 | 
            +
                set tooltip(value) {
         | 
| 57 | 
            +
                    this._tooltip = value;
         | 
| 58 | 
            +
                    if (value && this._tooltipElement) {
         | 
| 59 | 
            +
                        this._tooltipElement.setContent({ '.tooltip-inner': this._tooltip });
         | 
| 60 | 
            +
                    }
         | 
| 61 | 
            +
                }
         | 
| 62 | 
            +
                ngOnInit() {
         | 
| 63 | 
            +
                    this.SetToolTip();
         | 
| 64 | 
            +
                    this.SetEvents();
         | 
| 65 | 
            +
                }
         | 
| 66 | 
            +
                ngOnDestroy() {
         | 
| 67 | 
            +
                    if (this._tooltipElement) {
         | 
| 68 | 
            +
                        Tools.Sleep().then(() => this._tooltipElement.dispose());
         | 
| 69 | 
            +
                    }
         | 
| 70 | 
            +
                }
         | 
| 71 | 
            +
                /** */
         | 
| 72 | 
            +
                SetEvents() {
         | 
| 73 | 
            +
                    Tools.Sleep().then(() => {
         | 
| 74 | 
            +
                        this._element = document.getElementById(`${this._id}-inner-button`);
         | 
| 75 | 
            +
                        if (Tools.IsNotNull(this._element)) {
         | 
| 76 | 
            +
                            this._element.addEventListener('focus', () => {
         | 
| 77 | 
            +
                                if (!this._isEnable())
         | 
| 78 | 
            +
                                    this.Blur();
         | 
| 79 | 
            +
                            });
         | 
| 80 | 
            +
                        }
         | 
| 81 | 
            +
                    });
         | 
| 82 | 
            +
                }
         | 
| 83 | 
            +
                SetToolTip() {
         | 
| 84 | 
            +
                    Tools.Sleep().then(() => {
         | 
| 85 | 
            +
                        const htmlElement = document.getElementById(`${this._id}-container`);
         | 
| 86 | 
            +
                        if (Tools.IsNotNull(htmlElement)) {
         | 
| 87 | 
            +
                            htmlElement.addEventListener('mouseleave', () => {
         | 
| 88 | 
            +
                                if (Tools.IsNotNull(htmlElement) && Tools.IsNotNull(this._tooltipElement)) {
         | 
| 89 | 
            +
                                    this._tooltipElement.hide();
         | 
| 90 | 
            +
                                }
         | 
| 91 | 
            +
                            });
         | 
| 92 | 
            +
                            this._tooltipElement = new Tooltip(htmlElement, {
         | 
| 93 | 
            +
                                html: true,
         | 
| 94 | 
            +
                                title: this._tooltip,
         | 
| 95 | 
            +
                                placement: this.tooltipPosition
         | 
| 96 | 
            +
                            });
         | 
| 97 | 
            +
                        }
         | 
| 98 | 
            +
                    });
         | 
| 99 | 
            +
                }
         | 
| 100 | 
            +
                /** */
         | 
| 101 | 
            +
                Click(event) {
         | 
| 102 | 
            +
                    if (this._isEnable()) {
         | 
| 103 | 
            +
                        this.onClick.emit(event);
         | 
| 104 | 
            +
                    }
         | 
| 105 | 
            +
                    this.Blur();
         | 
| 106 | 
            +
                }
         | 
| 107 | 
            +
                /** */
         | 
| 108 | 
            +
                Focus(timeout = 0) {
         | 
| 109 | 
            +
                    Tools.Sleep(timeout).then(() => {
         | 
| 110 | 
            +
                        if (this._isEnable())
         | 
| 111 | 
            +
                            this._element.focus();
         | 
| 112 | 
            +
                    });
         | 
| 113 | 
            +
                }
         | 
| 114 | 
            +
                /** */
         | 
| 115 | 
            +
                Blur() {
         | 
| 116 | 
            +
                    Tools.Sleep().then(() => {
         | 
| 117 | 
            +
                        this._element.blur();
         | 
| 118 | 
            +
                    });
         | 
| 119 | 
            +
                }
         | 
| 120 | 
            +
                static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CoerButton, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
         | 
| 121 | 
            +
                static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: CoerButton, selector: "coer-button", inputs: { id: { classPropertyName: "id", publicName: "id", isSignal: false, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null }, type: { classPropertyName: "type", publicName: "type", isSignal: true, isRequired: false, transformFunction: null }, icon: { classPropertyName: "icon", publicName: "icon", isSignal: true, isRequired: false, transformFunction: null }, iconPosition: { classPropertyName: "iconPosition", publicName: "iconPosition", isSignal: true, isRequired: false, transformFunction: null }, animation: { classPropertyName: "animation", publicName: "animation", isSignal: true, isRequired: false, transformFunction: null }, isLoading: { classPropertyName: "isLoading", publicName: "isLoading", isSignal: true, isRequired: false, transformFunction: null }, isDisabled: { classPropertyName: "isDisabled", publicName: "isDisabled", isSignal: true, isRequired: false, transformFunction: null }, isInvisible: { classPropertyName: "isInvisible", publicName: "isInvisible", isSignal: true, isRequired: false, transformFunction: null }, width: { classPropertyName: "width", publicName: "width", isSignal: true, isRequired: false, transformFunction: null }, minWidth: { classPropertyName: "minWidth", publicName: "minWidth", isSignal: true, isRequired: false, transformFunction: null }, height: { classPropertyName: "height", publicName: "height", isSignal: true, isRequired: false, transformFunction: null }, minHeight: { classPropertyName: "minHeight", publicName: "minHeight", isSignal: true, isRequired: false, transformFunction: null }, marginTop: { classPropertyName: "marginTop", publicName: "marginTop", isSignal: true, isRequired: false, transformFunction: null }, marginRight: { classPropertyName: "marginRight", publicName: "marginRight", isSignal: true, isRequired: false, transformFunction: null }, marginBottom: { classPropertyName: "marginBottom", publicName: "marginBottom", isSignal: true, isRequired: false, transformFunction: null }, marginLeft: { classPropertyName: "marginLeft", publicName: "marginLeft", isSignal: true, isRequired: false, transformFunction: null }, path: { classPropertyName: "path", publicName: "path", isSignal: true, isRequired: false, transformFunction: null }, tooltipPosition: { classPropertyName: "tooltipPosition", publicName: "tooltipPosition", isSignal: true, isRequired: false, transformFunction: null }, tooltip: { classPropertyName: "tooltip", publicName: "tooltip", isSignal: false, isRequired: false, transformFunction: null } }, outputs: { onClick: "onClick" }, ngImport: i0, template: "<div [ngClass]=\"{ 'coer-button': true, 'invisible': isInvisible() }\">\r\n    <a [id]=\"_id + '-container'\"\r\n        [routerLink]=\"(path().length > 0 && _isEnable()) ? path() : null\"\r\n        [ngClass]=\"{ 'loading': isLoading(), 'animate__animated animate__zoomIn': true, 'animate__disabled': !animation() }\"\r\n        [ngStyle]=\"{ 'margin-top': marginTop(), 'margin-right': marginRight(), 'margin-bottom': marginBottom(), 'margin-left': marginLeft()  }\">\r\n        @if(type() =='filled' || type() == 'outline') {\r\n            <button mat-button\r\n                [id]=\"_id + '-inner-button'\"\r\n                type=\"button\"\r\n                (click)=\"Click($event)\"\r\n                [ngClass]=\"{\r\n                    'primary-filled': (color() == 'primary' && type() =='filled'),\r\n                    'secondary-filled': (color() == 'secondary' && type() =='filled'),\r\n                    'success-filled': (color() == 'success' && type() =='filled'),\r\n                    'warning-filled': (color() == 'warning' && type() =='filled'),\r\n                    'danger-filled': (color() == 'danger' && type() =='filled'),\r\n                    'navigation-filled': (color() == 'navigation' && type() =='filled'),\r\n                    'primary-outline': (color() == 'primary' && type() =='outline'),\r\n                    'secondary-outline': (color() == 'secondary' && type() =='outline'),\r\n                    'success-outline': (color() == 'success' && type() =='outline'),\r\n                    'warning-outline': (color() == 'warning' && type() =='outline'),\r\n                    'danger-outline': (color() == 'danger' && type() =='outline'),\r\n                    'navigation-outline': (color() == 'navigation'),\r\n                    'readonly': isDisabled(),\r\n                    'cursor-wait': isLoading()\r\n                }\"\r\n                [ngStyle]=\"{\r\n                    'width': width(),\r\n                    'min-width': minWidth(),\r\n                    'height': height(),\r\n                    'min-height': minHeight()\r\n                }\">\r\n                <span class=\"slot\" *ngIf=\"!isLoading(); else loading\" >\r\n                    <span *ngIf=\"(iconPosition() == 'left')\">\r\n                        <i [class]=\"_icon()\"></i>\r\n                    </span>\r\n\r\n                    <span [ngClass]=\"{ 'ms-2': (iconPosition() == 'left'), 'me-2': (iconPosition() == 'right') }\">\r\n                        <ng-content></ng-content>\r\n                    </span>\r\n\r\n                    <span *ngIf=\"(iconPosition() == 'right')\">\r\n                        <i [class]=\"_icon()\"></i>\r\n                    </span>\r\n                </span>\r\n\r\n                <ng-template #loading>\r\n                    <span class=\"slot fa-fade\">\r\n                        <span class=\"me-2\"> Loading </span>\r\n                        <i class=\"spinner-border\"></i>\r\n                    </span>\r\n                </ng-template>\r\n            </button>\r\n        }\r\n\r\n        @else {\r\n            @if (type() == 'icon') {\r\n                <button mat-icon-button\r\n                    [id]=\"_id + '-inner-button'\"\r\n                    (click)=\"Click($event)\"\r\n                    [ngClass]=\"{\r\n                        'primary-filled': (color() == 'primary'),\r\n                        'secondary-filled': (color() == 'secondary'),\r\n                        'success-filled': (color() == 'success'),\r\n                        'warning-filled': (color() == 'warning'),\r\n                        'danger-filled': (color() == 'danger'),\r\n                        'navigation-filled': (color() == 'navigation'),\r\n                        'readonly': (isDisabled() || isLoading()),\r\n                        'cursor-wait': isLoading()\r\n                    }\">\r\n                    <i [class]=\"_icon()\"></i>\r\n                </button>\r\n            }\r\n\r\n            @else if (type() == 'icon-outline') {\r\n                <button mat-icon-button\r\n                    [id]=\"_id + '-inner-button'\"\r\n                    (click)=\"Click($event)\"\r\n                    [ngClass]=\"{\r\n                        'primary-outline': (color() == 'primary'),\r\n                        'secondary-outline': (color() == 'secondary'),\r\n                        'success-outline': (color() == 'success'),\r\n                        'warning-outline': (color() == 'warning'),\r\n                        'danger-outline': (color() == 'danger'),\r\n                        'navigation-outline': (color() == 'navigation'),\r\n                        'readonly': (isDisabled() || isLoading()),\r\n                        'cursor-wait': isLoading()\r\n                    }\">\r\n                    <i [class]=\"_icon()\"></i>\r\n                </button>\r\n            }\r\n\r\n            @else if (type() == 'icon-no-border') {\r\n                <button mat-icon-button\r\n                    [id]=\"_id + '-inner-button'\"\r\n                    (click)=\"Click($event)\"\r\n                    [ngClass]=\"{\r\n                        'primary-outline': (color() == 'primary'),\r\n                        'secondary-outline': (color() == 'secondary'),\r\n                        'success-outline': (color() == 'success'),\r\n                        'warning-outline': (color() == 'warning'),\r\n                        'danger-outline': (color() == 'danger'),\r\n                        'navigation-outline': (color() == 'navigation'),\r\n                        'readonly': (isDisabled() || isLoading()),\r\n                        'icon-no-border': true\r\n                    }\">\r\n                    <i [class]=\"_icon()\"></i>\r\n                </button>\r\n            }\r\n        }\r\n    </a>\r\n</div>", styles: [".text-blue{color:#0d6efd!important}.text-blue-bold{color:#0d6efd!important;font-weight:700!important}.background-blue{background-color:#0d6efd!important}.background-border-blue{background-color:#0d6efd!important;border-color:#0d6efd!important}.border-blue{border-color:#0d6efd!important}.text-gray{color:#6c757d!important}.text-gray-bold{color:#6c757d!important;font-weight:700!important}.background-gray{background-color:#6c757d!important}.background-border-gray{background-color:#6c757d!important;border-color:#6c757d!important}.border-gray{border-color:#6c757d!important}.text-green{color:#198754!important}.text-green-bold{color:#198754!important;font-weight:700!important}.background-green{background-color:#198754!important}.background-border-green{background-color:#198754!important;border-color:#198754!important}.border-green{border-color:#198754!important}.text-yellow{color:#ffc107!important}.text-yellow-bold{color:#ffc107!important;font-weight:700!important}.background-yellow{background-color:#ffc107!important}.background-border-yellow{background-color:#ffc107!important;border-color:#ffc107!important}.border-yellow{border-color:#ffc107!important}.text-red{color:#dc3545!important}.text-red-bold{color:#dc3545!important;font-weight:700!important}.background-red{background-color:#dc3545!important}.background-border-red{background-color:#dc3545!important;border-color:#dc3545!important}.border-red{border-color:#dc3545!important}.text-white{color:#f5f5f5!important}.text-white-bold{color:#f5f5f5!important;font-weight:700!important}.background-white{background-color:#f5f5f5!important}.background-border-white{background-color:#f5f5f5!important;border-color:#f5f5f5!important}.border-white{border-color:#f5f5f5!important}.text-black{color:#252525!important}.text-black-bold{color:#252525!important;font-weight:700!important}.background-black{background-color:#252525!important}.background-border-black{background-color:#252525!important;border-color:#252525!important}.border-black{border-color:#252525!important}.text-orange{color:#fd6031!important}.text-orange-bold{color:#fd6031!important;font-weight:700!important}.background-orange{background-color:#fd6031!important}.background-border-orange{background-color:#fd6031!important;border-color:#fd6031!important}.border-orange{border-color:#fd6031!important}coer-button{display:contents!important}div.coer-button{display:contents!important}div.coer-button a{display:inline-block!important}div.coer-button a.animate__disabled{animation-duration:0s!important}div.coer-button button{font-size:17px!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important}div.coer-button .slot{width:100px!important;display:flex!important;align-items:center!important;justify-content:center!important;text-overflow:ellipsis!important;overflow:hidden!important}div.coer-button button.primary-filled{background-color:#0d6efd!important;color:#f5f5f5!important}div.coer-button button.secondary-filled{background-color:#6c757d!important;color:#f5f5f5!important}div.coer-button button.success-filled{background-color:#198754!important;color:#f5f5f5!important}div.coer-button button.warning-filled{background-color:#ffc107!important;color:#252525!important}div.coer-button button.danger-filled{background-color:#dc3545!important;color:#f5f5f5!important}div.coer-button button.navigation-filled{background-color:#fd6031!important;color:#f5f5f5!important}div.coer-button button.primary-outline{background-color:#fff!important;border:1px solid #0d6efd!important;color:#0d6efd!important}div.coer-button button.secondary-outline{background-color:#fff!important;border:1px solid #6c757d!important;color:#6c757d!important}div.coer-button button.success-outline{background-color:#fff!important;border:1px solid #198754!important;color:#198754!important}div.coer-button button.warning-outline{background-color:#fff!important;border:1px solid #ffc107!important;color:#ffc107!important}div.coer-button button.danger-outline{background-color:#fff!important;border:1px solid #dc3545!important;color:#dc3545!important}div.coer-button button.navigation-outline{background-color:#fff!important;border:1px solid #fd6031!important;color:#fd6031!important}div.coer-button button.primary-filled:not(.readonly):hover,div.coer-button button.primary-filled:not(.readonly):focus,div.coer-button button.primary-outline:not(.readonly):hover,div.coer-button button.primary-outline:not(.readonly):focus,div.coer-button button.secondary-filled:not(.readonly):hover,div.coer-button button.secondary-filled:not(.readonly):focus,div.coer-button button.secondary-outline:not(.readonly):hover,div.coer-button button.secondary-outline:not(.readonly):focus,div.coer-button button.success-filled:not(.readonly):hover,div.coer-button button.success-filled:not(.readonly):focus,div.coer-button button.success-outline:not(.readonly):hover,div.coer-button button.success-outline:not(.readonly):focus,div.coer-button button.warning-filled:not(.readonly):hover,div.coer-button button.warning-filled:not(.readonly):focus,div.coer-button button.warning-outline:not(.readonly):hover,div.coer-button button.warning-outline:not(.readonly):focus,div.coer-button button.danger-filled:not(.readonly):hover,div.coer-button button.danger-filled:not(.readonly):focus,div.coer-button button.danger-outline:not(.readonly):hover,div.coer-button button.danger-outline:not(.readonly):focus{filter:brightness(1.1)!important}div.coer-button button.primary-filled:not(.readonly):focus,div.coer-button button.primary-outline:not(.readonly):focus{box-shadow:0 0 20px #0d6efd!important}div.coer-button button.secondary-filled:not(.readonly):focus,div.coer-button button.secondary-outline:not(.readonly):focus{box-shadow:0 0 20px #6c757d!important}div.coer-button button.success-filled:not(.readonly):focus,div.coer-button button.success-outline:not(.readonly):focus{box-shadow:0 0 20px #198754!important}div.coer-button button.warning-filled:not(.readonly):focus,div.coer-button button.warning-outline:not(.readonly):focus{box-shadow:0 0 20px #ffc107!important}div.coer-button button.danger-filled:not(.readonly):focus,div.coer-button button.danger-outline:not(.readonly):focus{box-shadow:0 0 20px #dc3545!important}div.coer-button button.navigation-filled:not(.readonly):focus,div.coer-button button.navigation-outline:not(.readonly):focus{box-shadow:0 0 20px #fd6031!important}div.coer-button button.mdc-icon-button.mat-mdc-icon-button{width:40px!important;height:40px!important;padding:0!important}div.coer-button button.mdc-icon-button.mat-mdc-icon-button.icon-no-border{width:25px!important;height:25px!important;background-color:transparent!important;border:none!important;overflow:visible!important}div.coer-button button.mdc-icon-button.mat-mdc-icon-button.icon-no-border *{font-size:medium!important}div.coer-button button.mdc-icon-button.mat-mdc-icon-button.icon-no-border i.bi-box-arrow-left,div.coer-button button.mdc-icon-button.mat-mdc-icon-button.icon-no-border i.bi-box-arrow-in-right{font-size:20px!important}div.coer-button button.readonly,div.coer-button button.readonly:hover,div.coer-button button.readonly:focus{background-color:#dfdede!important;border-color:#dfdede!important;color:#fff!important}div.coer-button coer-button[ishidden=true],div.coer-button coer-button[ng-reflect-invisible=true]{position:relative!important;top:10000vh;left:10000vw}div.coer-button a.loading{cursor:wait!important}div.coer-button i{vertical-align:middle!important}div.coer-button i.spinner-border{width:15px!important;height:15px!important;font-size:16px!important}div.coer-button span{font-weight:700!important}div#coer-tool-bar coer-button *{color:#fd6031!important}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i2.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: i3.MatButton, selector: "    button[mat-button], button[mat-raised-button], button[mat-flat-button],    button[mat-stroked-button]  ", exportAs: ["matButton"] }, { kind: "component", type: i3.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }] }); }
         | 
| 122 | 
            +
            }
         | 
| 123 | 
            +
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CoerButton, decorators: [{
         | 
| 124 | 
            +
                        type: Component,
         | 
| 125 | 
            +
                        args: [{ selector: 'coer-button', template: "<div [ngClass]=\"{ 'coer-button': true, 'invisible': isInvisible() }\">\r\n    <a [id]=\"_id + '-container'\"\r\n        [routerLink]=\"(path().length > 0 && _isEnable()) ? path() : null\"\r\n        [ngClass]=\"{ 'loading': isLoading(), 'animate__animated animate__zoomIn': true, 'animate__disabled': !animation() }\"\r\n        [ngStyle]=\"{ 'margin-top': marginTop(), 'margin-right': marginRight(), 'margin-bottom': marginBottom(), 'margin-left': marginLeft()  }\">\r\n        @if(type() =='filled' || type() == 'outline') {\r\n            <button mat-button\r\n                [id]=\"_id + '-inner-button'\"\r\n                type=\"button\"\r\n                (click)=\"Click($event)\"\r\n                [ngClass]=\"{\r\n                    'primary-filled': (color() == 'primary' && type() =='filled'),\r\n                    'secondary-filled': (color() == 'secondary' && type() =='filled'),\r\n                    'success-filled': (color() == 'success' && type() =='filled'),\r\n                    'warning-filled': (color() == 'warning' && type() =='filled'),\r\n                    'danger-filled': (color() == 'danger' && type() =='filled'),\r\n                    'navigation-filled': (color() == 'navigation' && type() =='filled'),\r\n                    'primary-outline': (color() == 'primary' && type() =='outline'),\r\n                    'secondary-outline': (color() == 'secondary' && type() =='outline'),\r\n                    'success-outline': (color() == 'success' && type() =='outline'),\r\n                    'warning-outline': (color() == 'warning' && type() =='outline'),\r\n                    'danger-outline': (color() == 'danger' && type() =='outline'),\r\n                    'navigation-outline': (color() == 'navigation'),\r\n                    'readonly': isDisabled(),\r\n                    'cursor-wait': isLoading()\r\n                }\"\r\n                [ngStyle]=\"{\r\n                    'width': width(),\r\n                    'min-width': minWidth(),\r\n                    'height': height(),\r\n                    'min-height': minHeight()\r\n                }\">\r\n                <span class=\"slot\" *ngIf=\"!isLoading(); else loading\" >\r\n                    <span *ngIf=\"(iconPosition() == 'left')\">\r\n                        <i [class]=\"_icon()\"></i>\r\n                    </span>\r\n\r\n                    <span [ngClass]=\"{ 'ms-2': (iconPosition() == 'left'), 'me-2': (iconPosition() == 'right') }\">\r\n                        <ng-content></ng-content>\r\n                    </span>\r\n\r\n                    <span *ngIf=\"(iconPosition() == 'right')\">\r\n                        <i [class]=\"_icon()\"></i>\r\n                    </span>\r\n                </span>\r\n\r\n                <ng-template #loading>\r\n                    <span class=\"slot fa-fade\">\r\n                        <span class=\"me-2\"> Loading </span>\r\n                        <i class=\"spinner-border\"></i>\r\n                    </span>\r\n                </ng-template>\r\n            </button>\r\n        }\r\n\r\n        @else {\r\n            @if (type() == 'icon') {\r\n                <button mat-icon-button\r\n                    [id]=\"_id + '-inner-button'\"\r\n                    (click)=\"Click($event)\"\r\n                    [ngClass]=\"{\r\n                        'primary-filled': (color() == 'primary'),\r\n                        'secondary-filled': (color() == 'secondary'),\r\n                        'success-filled': (color() == 'success'),\r\n                        'warning-filled': (color() == 'warning'),\r\n                        'danger-filled': (color() == 'danger'),\r\n                        'navigation-filled': (color() == 'navigation'),\r\n                        'readonly': (isDisabled() || isLoading()),\r\n                        'cursor-wait': isLoading()\r\n                    }\">\r\n                    <i [class]=\"_icon()\"></i>\r\n                </button>\r\n            }\r\n\r\n            @else if (type() == 'icon-outline') {\r\n                <button mat-icon-button\r\n                    [id]=\"_id + '-inner-button'\"\r\n                    (click)=\"Click($event)\"\r\n                    [ngClass]=\"{\r\n                        'primary-outline': (color() == 'primary'),\r\n                        'secondary-outline': (color() == 'secondary'),\r\n                        'success-outline': (color() == 'success'),\r\n                        'warning-outline': (color() == 'warning'),\r\n                        'danger-outline': (color() == 'danger'),\r\n                        'navigation-outline': (color() == 'navigation'),\r\n                        'readonly': (isDisabled() || isLoading()),\r\n                        'cursor-wait': isLoading()\r\n                    }\">\r\n                    <i [class]=\"_icon()\"></i>\r\n                </button>\r\n            }\r\n\r\n            @else if (type() == 'icon-no-border') {\r\n                <button mat-icon-button\r\n                    [id]=\"_id + '-inner-button'\"\r\n                    (click)=\"Click($event)\"\r\n                    [ngClass]=\"{\r\n                        'primary-outline': (color() == 'primary'),\r\n                        'secondary-outline': (color() == 'secondary'),\r\n                        'success-outline': (color() == 'success'),\r\n                        'warning-outline': (color() == 'warning'),\r\n                        'danger-outline': (color() == 'danger'),\r\n                        'navigation-outline': (color() == 'navigation'),\r\n                        'readonly': (isDisabled() || isLoading()),\r\n                        'icon-no-border': true\r\n                    }\">\r\n                    <i [class]=\"_icon()\"></i>\r\n                </button>\r\n            }\r\n        }\r\n    </a>\r\n</div>", styles: [".text-blue{color:#0d6efd!important}.text-blue-bold{color:#0d6efd!important;font-weight:700!important}.background-blue{background-color:#0d6efd!important}.background-border-blue{background-color:#0d6efd!important;border-color:#0d6efd!important}.border-blue{border-color:#0d6efd!important}.text-gray{color:#6c757d!important}.text-gray-bold{color:#6c757d!important;font-weight:700!important}.background-gray{background-color:#6c757d!important}.background-border-gray{background-color:#6c757d!important;border-color:#6c757d!important}.border-gray{border-color:#6c757d!important}.text-green{color:#198754!important}.text-green-bold{color:#198754!important;font-weight:700!important}.background-green{background-color:#198754!important}.background-border-green{background-color:#198754!important;border-color:#198754!important}.border-green{border-color:#198754!important}.text-yellow{color:#ffc107!important}.text-yellow-bold{color:#ffc107!important;font-weight:700!important}.background-yellow{background-color:#ffc107!important}.background-border-yellow{background-color:#ffc107!important;border-color:#ffc107!important}.border-yellow{border-color:#ffc107!important}.text-red{color:#dc3545!important}.text-red-bold{color:#dc3545!important;font-weight:700!important}.background-red{background-color:#dc3545!important}.background-border-red{background-color:#dc3545!important;border-color:#dc3545!important}.border-red{border-color:#dc3545!important}.text-white{color:#f5f5f5!important}.text-white-bold{color:#f5f5f5!important;font-weight:700!important}.background-white{background-color:#f5f5f5!important}.background-border-white{background-color:#f5f5f5!important;border-color:#f5f5f5!important}.border-white{border-color:#f5f5f5!important}.text-black{color:#252525!important}.text-black-bold{color:#252525!important;font-weight:700!important}.background-black{background-color:#252525!important}.background-border-black{background-color:#252525!important;border-color:#252525!important}.border-black{border-color:#252525!important}.text-orange{color:#fd6031!important}.text-orange-bold{color:#fd6031!important;font-weight:700!important}.background-orange{background-color:#fd6031!important}.background-border-orange{background-color:#fd6031!important;border-color:#fd6031!important}.border-orange{border-color:#fd6031!important}coer-button{display:contents!important}div.coer-button{display:contents!important}div.coer-button a{display:inline-block!important}div.coer-button a.animate__disabled{animation-duration:0s!important}div.coer-button button{font-size:17px!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important}div.coer-button .slot{width:100px!important;display:flex!important;align-items:center!important;justify-content:center!important;text-overflow:ellipsis!important;overflow:hidden!important}div.coer-button button.primary-filled{background-color:#0d6efd!important;color:#f5f5f5!important}div.coer-button button.secondary-filled{background-color:#6c757d!important;color:#f5f5f5!important}div.coer-button button.success-filled{background-color:#198754!important;color:#f5f5f5!important}div.coer-button button.warning-filled{background-color:#ffc107!important;color:#252525!important}div.coer-button button.danger-filled{background-color:#dc3545!important;color:#f5f5f5!important}div.coer-button button.navigation-filled{background-color:#fd6031!important;color:#f5f5f5!important}div.coer-button button.primary-outline{background-color:#fff!important;border:1px solid #0d6efd!important;color:#0d6efd!important}div.coer-button button.secondary-outline{background-color:#fff!important;border:1px solid #6c757d!important;color:#6c757d!important}div.coer-button button.success-outline{background-color:#fff!important;border:1px solid #198754!important;color:#198754!important}div.coer-button button.warning-outline{background-color:#fff!important;border:1px solid #ffc107!important;color:#ffc107!important}div.coer-button button.danger-outline{background-color:#fff!important;border:1px solid #dc3545!important;color:#dc3545!important}div.coer-button button.navigation-outline{background-color:#fff!important;border:1px solid #fd6031!important;color:#fd6031!important}div.coer-button button.primary-filled:not(.readonly):hover,div.coer-button button.primary-filled:not(.readonly):focus,div.coer-button button.primary-outline:not(.readonly):hover,div.coer-button button.primary-outline:not(.readonly):focus,div.coer-button button.secondary-filled:not(.readonly):hover,div.coer-button button.secondary-filled:not(.readonly):focus,div.coer-button button.secondary-outline:not(.readonly):hover,div.coer-button button.secondary-outline:not(.readonly):focus,div.coer-button button.success-filled:not(.readonly):hover,div.coer-button button.success-filled:not(.readonly):focus,div.coer-button button.success-outline:not(.readonly):hover,div.coer-button button.success-outline:not(.readonly):focus,div.coer-button button.warning-filled:not(.readonly):hover,div.coer-button button.warning-filled:not(.readonly):focus,div.coer-button button.warning-outline:not(.readonly):hover,div.coer-button button.warning-outline:not(.readonly):focus,div.coer-button button.danger-filled:not(.readonly):hover,div.coer-button button.danger-filled:not(.readonly):focus,div.coer-button button.danger-outline:not(.readonly):hover,div.coer-button button.danger-outline:not(.readonly):focus{filter:brightness(1.1)!important}div.coer-button button.primary-filled:not(.readonly):focus,div.coer-button button.primary-outline:not(.readonly):focus{box-shadow:0 0 20px #0d6efd!important}div.coer-button button.secondary-filled:not(.readonly):focus,div.coer-button button.secondary-outline:not(.readonly):focus{box-shadow:0 0 20px #6c757d!important}div.coer-button button.success-filled:not(.readonly):focus,div.coer-button button.success-outline:not(.readonly):focus{box-shadow:0 0 20px #198754!important}div.coer-button button.warning-filled:not(.readonly):focus,div.coer-button button.warning-outline:not(.readonly):focus{box-shadow:0 0 20px #ffc107!important}div.coer-button button.danger-filled:not(.readonly):focus,div.coer-button button.danger-outline:not(.readonly):focus{box-shadow:0 0 20px #dc3545!important}div.coer-button button.navigation-filled:not(.readonly):focus,div.coer-button button.navigation-outline:not(.readonly):focus{box-shadow:0 0 20px #fd6031!important}div.coer-button button.mdc-icon-button.mat-mdc-icon-button{width:40px!important;height:40px!important;padding:0!important}div.coer-button button.mdc-icon-button.mat-mdc-icon-button.icon-no-border{width:25px!important;height:25px!important;background-color:transparent!important;border:none!important;overflow:visible!important}div.coer-button button.mdc-icon-button.mat-mdc-icon-button.icon-no-border *{font-size:medium!important}div.coer-button button.mdc-icon-button.mat-mdc-icon-button.icon-no-border i.bi-box-arrow-left,div.coer-button button.mdc-icon-button.mat-mdc-icon-button.icon-no-border i.bi-box-arrow-in-right{font-size:20px!important}div.coer-button button.readonly,div.coer-button button.readonly:hover,div.coer-button button.readonly:focus{background-color:#dfdede!important;border-color:#dfdede!important;color:#fff!important}div.coer-button coer-button[ishidden=true],div.coer-button coer-button[ng-reflect-invisible=true]{position:relative!important;top:10000vh;left:10000vw}div.coer-button a.loading{cursor:wait!important}div.coer-button i{vertical-align:middle!important}div.coer-button i.spinner-border{width:15px!important;height:15px!important;font-size:16px!important}div.coer-button span{font-weight:700!important}div#coer-tool-bar coer-button *{color:#fd6031!important}\n"] }]
         | 
| 126 | 
            +
                    }], propDecorators: { id: [{
         | 
| 127 | 
            +
                            type: Input
         | 
| 128 | 
            +
                        }], tooltip: [{
         | 
| 129 | 
            +
                            type: Input
         | 
| 130 | 
            +
                        }], onClick: [{
         | 
| 131 | 
            +
                            type: Output
         | 
| 132 | 
            +
                        }] } });
         | 
| 133 | 
            +
            //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"coer-button.component.js","sourceRoot":"","sources":["../../../../../../projects/coer-elements/src/components/lib/coer-button/coer-button.component.ts","../../../../../../projects/coer-elements/src/components/lib/coer-button/coer-button.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,YAAY,EAAE,KAAK,EAAE,KAAK,EAAqB,MAAM,EAAE,MAAM,eAAe,CAAC;AAC3G,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAA;AACtC,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;;;;;AAOpC,MAAM,OAAO,UAAU;IALvB;QAOI,WAAW;QACD,QAAG,GAAW,KAAK,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QAE7C,aAAQ,GAAW,EAAE,CAAC;QAG9B,QAAQ;QACC,OAAE,GAAW,EAAE,CAAC;QAClB,UAAK,GAAG,KAAK,CAAwF,SAAS,CAAC,CAAC;QAChH,SAAI,GAAG,KAAK,CAAmE,QAAQ,CAAC,CAAC;QACzF,SAAI,GAAG,KAAK,CAAmG,EAAE,CAAC,CAAC;QACnH,iBAAY,GAAG,KAAK,CAAmB,MAAM,CAAC,CAAC;QAC/C,cAAS,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;QAClC,cAAS,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;QAClC,eAAU,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;QACnC,gBAAW,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;QACpC,UAAK,GAAG,KAAK,CAAS,OAAO,CAAC,CAAC;QAC/B,aAAQ,GAAG,KAAK,CAAS,MAAM,CAAC,CAAC;QACjC,WAAM,GAAG,KAAK,CAAS,MAAM,CAAC,CAAC;QAC/B,cAAS,GAAG,KAAK,CAAS,MAAM,CAAC,CAAC;QAClC,cAAS,GAAG,KAAK,CAAS,KAAK,CAAC,CAAC;QACjC,gBAAW,GAAG,KAAK,CAAS,KAAK,CAAC,CAAC;QACnC,iBAAY,GAAG,KAAK,CAAS,KAAK,CAAC,CAAC;QACpC,eAAU,GAAG,KAAK,CAAS,KAAK,CAAC,CAAC;QAClC,SAAI,GAAG,KAAK,CAA+B,EAAE,CAAC,CAAC;QAC/C,oBAAe,GAAG,KAAK,CAAsC,MAAM,CAAC,CAAC;QAS5E,SAAS;QACC,YAAO,GAAG,IAAI,YAAY,EAAc,CAAC;QAGnD,UAAU;QACA,cAAS,GAAG,QAAQ,CAAU,GAAG,EAAE;YACzC,OAAO,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;QAC1E,CAAC,CAAC,CAAC;QAGH,UAAU;QACA,UAAK,GAAG,QAAQ,CAAS,GAAG,EAAE;YACpC,QAAO,IAAI,CAAC,IAAI,EAAE,EAAE,CAAC;gBACjB,KAAK,KAAK,CAAC,CAAC,OAAO,wBAAwB,CAAC;gBAC5C,KAAK,MAAM,CAAC,CAAC,OAAO,+BAA+B,CAAC;gBACpD,KAAK,QAAQ,CAAC,CAAC,OAAO,yBAAyB,CAAC;gBAChD,KAAK,QAAQ,CAAC,CAAC,OAAO,iCAAiC,CAAC;gBACxD,KAAK,OAAO,CAAC,CAAC,OAAO,2BAA2B,CAAC;gBACjD,KAAK,MAAM,CAAC,CAAC,OAAO,kBAAkB,CAAC;gBACvC,KAAK,QAAQ,CAAC,CAAC,OAAO,uBAAuB,CAAC;gBAC9C,KAAK,MAAM,CAAC,CAAC,OAAO,uBAAuB,CAAC;gBAC5C,KAAK,IAAI,CAAC,CAAC,OAAO,uBAAuB,CAAC;gBAC1C,KAAK,MAAM,CAAC,CAAC,OAAO,sBAAsB,CAAC;gBAC3C,OAAO,CAAC,CAAC,OAAO,EAAE,CAAC;YACvB,CAAC;QACL,CAAC,CAAC,CAAC;KA0EN;IA1GG,IAAa,OAAO,CAAC,KAAa;QAC9B,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,KAAK,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YAChC,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,EAAE,gBAAgB,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QACzE,CAAC;IACL,CAAC;IA8BD,QAAQ;QACJ,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,CAAC,SAAS,EAAE,CAAC;IACrB,CAAC;IAED,WAAW;QACP,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YACvB,KAAK,CAAC,KAAK,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,CAAC,CAAC;QAC7D,CAAC;IACL,CAAC;IAGD,MAAM;IACE,SAAS;QACb,KAAK,CAAC,KAAK,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;YACpB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,cAAc,CAAC,GAAG,IAAI,CAAC,GAAG,eAAe,CAAuB,CAAC;YAE1F,IAAI,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC;gBACjC,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,OAAO,EAAE,GAAG,EAAE;oBACzC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;wBAAE,IAAI,CAAC,IAAI,EAAE,CAAC;gBACvC,CAAC,CAAC,CAAC;YACP,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAGO,UAAU;QACd,KAAK,CAAC,KAAK,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;YACpB,MAAM,WAAW,GAAG,QAAQ,CAAC,cAAc,CAAC,GAAG,IAAI,CAAC,GAAG,YAAY,CAAE,CAAC;YAEtE,IAAI,KAAK,CAAC,SAAS,CAAC,WAAW,CAAC,EAAE,CAAC;gBAC/B,WAAW,CAAC,gBAAgB,CAAC,YAAY,EAAE,GAAG,EAAE;oBAC5C,IAAI,KAAK,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,eAAe,CAAC,EAAE,CAAC;wBACxE,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,CAAC;oBAChC,CAAC;gBACL,CAAC,CAAC,CAAC;gBAEH,IAAI,CAAC,eAAe,GAAG,IAAI,OAAO,CAAC,WAAW,EAAE;oBAC5C,IAAI,EAAE,IAAI;oBACV,KAAK,EAAE,IAAI,CAAC,QAAQ;oBACpB,SAAS,EAAE,IAAI,CAAC,eAAe;iBAClC,CAAC,CAAC;YACP,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAGD,MAAM;IACI,KAAK,CAAC,KAAiB;QAC7B,IAAI,IAAI,CAAC,SAAS,EAAE,EAAE,CAAC;YACnB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC7B,CAAC;QAED,IAAI,CAAC,IAAI,EAAE,CAAC;IAChB,CAAC;IAGD,MAAM;IACC,KAAK,CAAC,UAAkB,CAAC;QAC5B,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE;YAC3B,IAAI,IAAI,CAAC,SAAS,EAAE;gBAAE,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;QAChD,CAAC,CAAC,CAAC;IACP,CAAC;IAGD,MAAM;IACC,IAAI;QACP,KAAK,CAAC,KAAK,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;YACpB,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACzB,CAAC,CAAC,CAAC;IACP,CAAC;+GAtIQ,UAAU;mGAAV,UAAU,4nFCTvB,ouLA+GM;;4FDtGO,UAAU;kBALtB,SAAS;+BACI,aAAa;8BAad,EAAE;sBAAV,KAAK;gBAoBO,OAAO;sBAAnB,KAAK;gBAQI,OAAO;sBAAhB,MAAM","sourcesContent":["import { Component, computed, EventEmitter, input, Input, OnDestroy, OnInit, Output } from '@angular/core';\r\nimport { Tools } from '../../../tools'\r\nimport { Tooltip } from 'bootstrap';\r\n\r\n@Component({\r\n    selector: 'coer-button',\r\n    templateUrl: './coer-button.component.html',\r\n    styleUrl: './coer-button.component.scss',\r\n})\r\nexport class CoerButton implements OnInit, OnDestroy {\r\n\r\n    //Variables\r\n    protected _id: string = Tools.GetGuid('coer-button');\r\n    private _element!: HTMLButtonElement;\r\n    private _tooltip: string = '';\r\n    private _tooltipElement!: Tooltip;\r\n\r\n    //Inputs\r\n    @Input() id: string = '';\r\n    public color = input<'default' | 'primary' | 'secondary' | 'success' | 'warning' | 'danger' | 'navigation'>('default');\r\n    public type = input<'filled' | 'outline' | 'icon'| 'icon-outline' | 'icon-no-border'>('filled');\r\n    public icon = input<'new' | 'save' | 'cancel' | 'import' | 'excel' | 'menu' | 'delete' | 'edit' | 'go' | 'back' | ''>('');\r\n    public iconPosition = input<'left' | 'right'>('left');\r\n    public animation = input<boolean>(false);\r\n    public isLoading = input<boolean>(false);\r\n    public isDisabled = input<boolean>(false);\r\n    public isInvisible = input<boolean>(false);\r\n    public width = input<string>('125px');\r\n    public minWidth = input<string>('30px');\r\n    public height = input<string>('40px');\r\n    public minHeight = input<string>('30px');\r\n    public marginTop = input<string>('0px');\r\n    public marginRight = input<string>('0px');\r\n    public marginBottom = input<string>('0px');\r\n    public marginLeft = input<string>('0px');\r\n    public path = input<string | (string | number)[]>([]);\r\n    public tooltipPosition = input<'top' | 'right' | 'bottom' | 'left'>('left');\r\n\r\n    @Input() set tooltip(value: string) {\r\n        this._tooltip = value;\r\n        if (value && this._tooltipElement) {\r\n            this._tooltipElement.setContent({ '.tooltip-inner': this._tooltip });\r\n        }\r\n    }\r\n\r\n    //Outputs\r\n    @Output() onClick = new EventEmitter<MouseEvent>();\r\n\r\n\r\n    //computed\r\n    protected _isEnable = computed<boolean>(() => {\r\n        return !this.isLoading() && !this.isDisabled() && !this.isInvisible();\r\n    });\r\n\r\n\r\n    //computed\r\n    protected _icon = computed<string>(() => {\r\n        switch(this.icon()) {\r\n            case 'new': return 'fa-solid fa-plus fa-lg';\r\n            case 'save': return 'fa-solid fa-floppy-disk fa-lg';\r\n            case 'cancel': return 'fa-solid fa-xmark fa-lg';\r\n            case 'import': return 'fa-solid fa-file-arrow-up fa-lg';\r\n            case 'excel': return 'bi bi-filetype-xlsx fa-lg';\r\n            case 'menu': return 'fa-solid fa-bars';\r\n            case 'delete': return 'fa-solid fa-trash-can';\r\n            case 'edit': return 'fa-solid fa-pen fa-lg';\r\n            case 'go': return 'bi bi-box-arrow-right';\r\n            case 'back': return 'bi bi-box-arrow-left';\r\n            default: return '';\r\n        }\r\n    });\r\n\r\n\r\n    ngOnInit() {\r\n        this.SetToolTip();\r\n        this.SetEvents();\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        if (this._tooltipElement) {\r\n            Tools.Sleep().then(() => this._tooltipElement.dispose());\r\n        }\r\n    }\r\n\r\n\r\n    /** */\r\n    private SetEvents(): void {\r\n        Tools.Sleep().then(() => {\r\n            this._element = document.getElementById(`${this._id}-inner-button`)! as HTMLButtonElement;\r\n\r\n            if (Tools.IsNotNull(this._element)) {\r\n                this._element.addEventListener('focus', () => {\r\n                    if (!this._isEnable()) this.Blur();\r\n                });\r\n            }\r\n        });\r\n    }\r\n\r\n\r\n    private SetToolTip(): void {\r\n        Tools.Sleep().then(() => {\r\n            const htmlElement = document.getElementById(`${this._id}-container`)!;\r\n\r\n            if (Tools.IsNotNull(htmlElement)) {\r\n                htmlElement.addEventListener('mouseleave', () => {\r\n                    if (Tools.IsNotNull(htmlElement) && Tools.IsNotNull(this._tooltipElement)) {\r\n                        this._tooltipElement.hide();\r\n                    }\r\n                });\r\n\r\n                this._tooltipElement = new Tooltip(htmlElement, {\r\n                    html: true,\r\n                    title: this._tooltip,\r\n                    placement: this.tooltipPosition\r\n                });\r\n            }\r\n        });\r\n    }\r\n\r\n\r\n    /** */\r\n    protected Click(event: MouseEvent) {\r\n        if (this._isEnable()) {\r\n            this.onClick.emit(event);\r\n        }\r\n\r\n        this.Blur();\r\n    }\r\n\r\n\r\n    /** */\r\n    public Focus(timeout: number = 0): void {\r\n        Tools.Sleep(timeout).then(() => {\r\n            if (this._isEnable()) this._element.focus();\r\n        });\r\n    }\r\n\r\n\r\n    /** */\r\n    public Blur(): void {\r\n        Tools.Sleep().then(() => {\r\n            this._element.blur();\r\n        });\r\n    }\r\n}","<div [ngClass]=\"{ 'coer-button': true, 'invisible': isInvisible() }\">\r\n    <a [id]=\"_id + '-container'\"\r\n        [routerLink]=\"(path().length > 0 && _isEnable()) ? path() : null\"\r\n        [ngClass]=\"{ 'loading': isLoading(), 'animate__animated animate__zoomIn': true, 'animate__disabled': !animation() }\"\r\n        [ngStyle]=\"{ 'margin-top': marginTop(), 'margin-right': marginRight(), 'margin-bottom': marginBottom(), 'margin-left': marginLeft()  }\">\r\n        @if(type() =='filled' || type() == 'outline') {\r\n            <button mat-button\r\n                [id]=\"_id + '-inner-button'\"\r\n                type=\"button\"\r\n                (click)=\"Click($event)\"\r\n                [ngClass]=\"{\r\n                    'primary-filled': (color() == 'primary' && type() =='filled'),\r\n                    'secondary-filled': (color() == 'secondary' && type() =='filled'),\r\n                    'success-filled': (color() == 'success' && type() =='filled'),\r\n                    'warning-filled': (color() == 'warning' && type() =='filled'),\r\n                    'danger-filled': (color() == 'danger' && type() =='filled'),\r\n                    'navigation-filled': (color() == 'navigation' && type() =='filled'),\r\n                    'primary-outline': (color() == 'primary' && type() =='outline'),\r\n                    'secondary-outline': (color() == 'secondary' && type() =='outline'),\r\n                    'success-outline': (color() == 'success' && type() =='outline'),\r\n                    'warning-outline': (color() == 'warning' && type() =='outline'),\r\n                    'danger-outline': (color() == 'danger' && type() =='outline'),\r\n                    'navigation-outline': (color() == 'navigation'),\r\n                    'readonly': isDisabled(),\r\n                    'cursor-wait': isLoading()\r\n                }\"\r\n                [ngStyle]=\"{\r\n                    'width': width(),\r\n                    'min-width': minWidth(),\r\n                    'height': height(),\r\n                    'min-height': minHeight()\r\n                }\">\r\n                <span class=\"slot\" *ngIf=\"!isLoading(); else loading\" >\r\n                    <span *ngIf=\"(iconPosition() == 'left')\">\r\n                        <i [class]=\"_icon()\"></i>\r\n                    </span>\r\n\r\n                    <span [ngClass]=\"{ 'ms-2': (iconPosition() == 'left'), 'me-2': (iconPosition() == 'right') }\">\r\n                        <ng-content></ng-content>\r\n                    </span>\r\n\r\n                    <span *ngIf=\"(iconPosition() == 'right')\">\r\n                        <i [class]=\"_icon()\"></i>\r\n                    </span>\r\n                </span>\r\n\r\n                <ng-template #loading>\r\n                    <span class=\"slot fa-fade\">\r\n                        <span class=\"me-2\"> Loading </span>\r\n                        <i class=\"spinner-border\"></i>\r\n                    </span>\r\n                </ng-template>\r\n            </button>\r\n        }\r\n\r\n        @else {\r\n            @if (type() == 'icon') {\r\n                <button mat-icon-button\r\n                    [id]=\"_id + '-inner-button'\"\r\n                    (click)=\"Click($event)\"\r\n                    [ngClass]=\"{\r\n                        'primary-filled': (color() == 'primary'),\r\n                        'secondary-filled': (color() == 'secondary'),\r\n                        'success-filled': (color() == 'success'),\r\n                        'warning-filled': (color() == 'warning'),\r\n                        'danger-filled': (color() == 'danger'),\r\n                        'navigation-filled': (color() == 'navigation'),\r\n                        'readonly': (isDisabled() || isLoading()),\r\n                        'cursor-wait': isLoading()\r\n                    }\">\r\n                    <i [class]=\"_icon()\"></i>\r\n                </button>\r\n            }\r\n\r\n            @else if (type() == 'icon-outline') {\r\n                <button mat-icon-button\r\n                    [id]=\"_id + '-inner-button'\"\r\n                    (click)=\"Click($event)\"\r\n                    [ngClass]=\"{\r\n                        'primary-outline': (color() == 'primary'),\r\n                        'secondary-outline': (color() == 'secondary'),\r\n                        'success-outline': (color() == 'success'),\r\n                        'warning-outline': (color() == 'warning'),\r\n                        'danger-outline': (color() == 'danger'),\r\n                        'navigation-outline': (color() == 'navigation'),\r\n                        'readonly': (isDisabled() || isLoading()),\r\n                        'cursor-wait': isLoading()\r\n                    }\">\r\n                    <i [class]=\"_icon()\"></i>\r\n                </button>\r\n            }\r\n\r\n            @else if (type() == 'icon-no-border') {\r\n                <button mat-icon-button\r\n                    [id]=\"_id + '-inner-button'\"\r\n                    (click)=\"Click($event)\"\r\n                    [ngClass]=\"{\r\n                        'primary-outline': (color() == 'primary'),\r\n                        'secondary-outline': (color() == 'secondary'),\r\n                        'success-outline': (color() == 'success'),\r\n                        'warning-outline': (color() == 'warning'),\r\n                        'danger-outline': (color() == 'danger'),\r\n                        'navigation-outline': (color() == 'navigation'),\r\n                        'readonly': (isDisabled() || isLoading()),\r\n                        'icon-no-border': true\r\n                    }\">\r\n                    <i [class]=\"_icon()\"></i>\r\n                </button>\r\n            }\r\n        }\r\n    </a>\r\n</div>"]}
         | 
| @@ -5,7 +5,7 @@ import { FormsModule, ReactiveFormsModule } from '@angular/forms'; | |
| 5 5 | 
             
            //import { DirectivesModule } from 'src/app/shared/directives/directives.module';
         | 
| 6 6 | 
             
            //import { PipesModule } from 'src/app/shared/pipes/pipes.module';
         | 
| 7 7 | 
             
            //Angular Material
         | 
| 8 | 
            -
             | 
| 8 | 
            +
            import { MatButtonModule } from '@angular/material/button';
         | 
| 9 9 | 
             
            //import { MatCheckboxModule } from '@angular/material/checkbox';
         | 
| 10 10 | 
             
            //import { MatInputModule } from '@angular/material/input';
         | 
| 11 11 | 
             
            //import { MatFormFieldModule } from '@angular/material/form-field';
         | 
| @@ -13,8 +13,8 @@ import { FormsModule, ReactiveFormsModule } from '@angular/forms'; | |
| 13 13 | 
             
            //import { MatTabsModule } from '@angular/material/tabs';
         | 
| 14 14 | 
             
            //Components
         | 
| 15 15 | 
             
            import { CoerAlert } from './coer-alert/coer-alert.component';
         | 
| 16 | 
            +
            import { CoerButton } from './coer-button/coer-button.component';
         | 
| 16 17 | 
             
            import * as i0 from "@angular/core";
         | 
| 17 | 
            -
            //import { CoerButton } from './coer-button/coer-button.component';
         | 
| 18 18 | 
             
            //import { CoerCheckbox } from './coer-checkbox/coer-checkbox.component';
         | 
| 19 19 | 
             
            //import { CoerFilebox } from './coer-filebox/coer-filebox.component';
         | 
| 20 20 | 
             
            //import { CoerForm } from './coer-form/coer-form.component';
         | 
| @@ -29,14 +29,20 @@ import * as i0 from "@angular/core"; | |
| 29 29 | 
             
            //import { CoerTextBox } from './coer-textbox/coer-textbox.component';
         | 
| 30 30 | 
             
            export class ComponentsModule {
         | 
| 31 31 | 
             
                static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ComponentsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
         | 
| 32 | 
            -
                static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.12", ngImport: i0, type: ComponentsModule, declarations: [CoerAlert | 
| 32 | 
            +
                static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.12", ngImport: i0, type: ComponentsModule, declarations: [CoerAlert,
         | 
| 33 | 
            +
                        CoerButton], imports: [CommonModule,
         | 
| 33 34 | 
             
                        RouterModule,
         | 
| 34 35 | 
             
                        FormsModule,
         | 
| 35 | 
            -
                        ReactiveFormsModule | 
| 36 | 
            +
                        ReactiveFormsModule,
         | 
| 37 | 
            +
                        //PipesModule,
         | 
| 38 | 
            +
                        MatButtonModule], exports: [CoerAlert,
         | 
| 39 | 
            +
                        CoerButton] }); }
         | 
| 36 40 | 
             
                static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ComponentsModule, imports: [CommonModule,
         | 
| 37 41 | 
             
                        RouterModule,
         | 
| 38 42 | 
             
                        FormsModule,
         | 
| 39 | 
            -
                        ReactiveFormsModule | 
| 43 | 
            +
                        ReactiveFormsModule,
         | 
| 44 | 
            +
                        //PipesModule,
         | 
| 45 | 
            +
                        MatButtonModule] }); }
         | 
| 40 46 | 
             
            }
         | 
| 41 47 | 
             
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ComponentsModule, decorators: [{
         | 
| 42 48 | 
             
                        type: NgModule,
         | 
| @@ -47,7 +53,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo | |
| 47 53 | 
             
                                    FormsModule,
         | 
| 48 54 | 
             
                                    ReactiveFormsModule,
         | 
| 49 55 | 
             
                                    //PipesModule,
         | 
| 50 | 
            -
                                     | 
| 56 | 
            +
                                    MatButtonModule,
         | 
| 51 57 | 
             
                                    //MatCheckboxModule,
         | 
| 52 58 | 
             
                                    //MatInputModule,
         | 
| 53 59 | 
             
                                    //MatFormFieldModule,
         | 
| @@ -57,7 +63,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo | |
| 57 63 | 
             
                                ],
         | 
| 58 64 | 
             
                                declarations: [
         | 
| 59 65 | 
             
                                    CoerAlert,
         | 
| 60 | 
            -
                                     | 
| 66 | 
            +
                                    CoerButton,
         | 
| 61 67 | 
             
                                    //CoerCheckbox,
         | 
| 62 68 | 
             
                                    //CoerFilebox,
         | 
| 63 69 | 
             
                                    //CoerForm,
         | 
| @@ -73,7 +79,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo | |
| 73 79 | 
             
                                ],
         | 
| 74 80 | 
             
                                exports: [
         | 
| 75 81 | 
             
                                    CoerAlert,
         | 
| 76 | 
            -
                                     | 
| 82 | 
            +
                                    CoerButton,
         | 
| 77 83 | 
             
                                    //CoerCheckbox,
         | 
| 78 84 | 
             
                                    //CoerFilebox,
         | 
| 79 85 | 
             
                                    //CoerForm,
         | 
| @@ -89,4 +95,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo | |
| 89 95 | 
             
                                ]
         | 
| 90 96 | 
             
                            }]
         | 
| 91 97 | 
             
                    }] });
         | 
| 92 | 
            -
            //# sourceMappingURL=data:application/json;base64, | 
| 98 | 
            +
            //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50cy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb2VyLWVsZW1lbnRzL3NyYy9jb21wb25lbnRzL2xpYi9jb21wb25lbnRzLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLGlGQUFpRjtBQUNqRixrRUFBa0U7QUFFbEUsa0JBQWtCO0FBQ2xCLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxpRUFBaUU7QUFDakUsMkRBQTJEO0FBQzNELG9FQUFvRTtBQUNwRSx3RUFBd0U7QUFDeEUseURBQXlEO0FBRXpELFlBQVk7QUFDWixPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDOUQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLHFDQUFxQyxDQUFDOztBQUNqRSx5RUFBeUU7QUFDekUsc0VBQXNFO0FBQ3RFLDZEQUE2RDtBQUM3RCw2REFBNkQ7QUFDN0QsZ0VBQWdFO0FBQ2hFLDRFQUE0RTtBQUM1RSw4RUFBOEU7QUFDOUUsNEVBQTRFO0FBQzVFLG1FQUFtRTtBQUNuRSwwREFBMEQ7QUFDMUQseUVBQXlFO0FBQ3pFLHNFQUFzRTtBQWtEdEUsTUFBTSxPQUFPLGdCQUFnQjsrR0FBaEIsZ0JBQWdCO2dIQUFoQixnQkFBZ0IsaUJBaENyQixTQUFTO1lBQ1QsVUFBVSxhQWZWLFlBQVk7WUFDWixZQUFZO1lBQ1osV0FBVztZQUNYLG1CQUFtQjtZQUNuQixjQUFjO1lBQ2QsZUFBZSxhQXlCZixTQUFTO1lBQ1QsVUFBVTtnSEFlTCxnQkFBZ0IsWUE5Q3JCLFlBQVk7WUFDWixZQUFZO1lBQ1osV0FBVztZQUNYLG1CQUFtQjtZQUNuQixjQUFjO1lBQ2QsZUFBZTs7NEZBeUNWLGdCQUFnQjtrQkFoRDVCLFFBQVE7bUJBQUM7b0JBQ04sT0FBTyxFQUFFO3dCQUNMLFlBQVk7d0JBQ1osWUFBWTt3QkFDWixXQUFXO3dCQUNYLG1CQUFtQjt3QkFDbkIsY0FBYzt3QkFDZCxlQUFlO3dCQUNmLG9CQUFvQjt3QkFDcEIsaUJBQWlCO3dCQUNqQixxQkFBcUI7d0JBQ3JCLHVCQUF1Qjt3QkFDdkIsZ0JBQWdCO3dCQUNoQixrQkFBa0I7cUJBQ3JCO29CQUNELFlBQVksRUFBRTt3QkFDVixTQUFTO3dCQUNULFVBQVU7d0JBQ1YsZUFBZTt3QkFDZixjQUFjO3dCQUNkLFdBQVc7d0JBQ1gsV0FBVzt3QkFDWCxZQUFZO3dCQUNaLGdCQUFnQjt3QkFDaEIsZ0JBQWdCO3dCQUNoQixnQkFBZ0I7d0JBQ2hCLGFBQWE7d0JBQ2IsZUFBZTt3QkFDZixVQUFVO3dCQUNWLGNBQWM7cUJBQ2pCO29CQUNELE9BQU8sRUFBRTt3QkFDTCxTQUFTO3dCQUNULFVBQVU7d0JBQ1YsZUFBZTt3QkFDZixjQUFjO3dCQUNkLFdBQVc7d0JBQ1gsV0FBVzt3QkFDWCxZQUFZO3dCQUNaLGdCQUFnQjt3QkFDaEIsZ0JBQWdCO3dCQUNoQixnQkFBZ0I7d0JBQ2hCLGFBQWE7d0JBQ2IsZUFBZTt3QkFDZixVQUFVO3dCQUNWLGNBQWM7cUJBQ2pCO2lCQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgUm91dGVyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcclxuaW1wb3J0IHsgRm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbi8vaW1wb3J0IHsgRGlyZWN0aXZlc01vZHVsZSB9IGZyb20gJ3NyYy9hcHAvc2hhcmVkL2RpcmVjdGl2ZXMvZGlyZWN0aXZlcy5tb2R1bGUnO1xyXG4vL2ltcG9ydCB7IFBpcGVzTW9kdWxlIH0gZnJvbSAnc3JjL2FwcC9zaGFyZWQvcGlwZXMvcGlwZXMubW9kdWxlJztcclxuXHJcbi8vQW5ndWxhciBNYXRlcmlhbFxyXG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xyXG4vL2ltcG9ydCB7IE1hdENoZWNrYm94TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY2hlY2tib3gnO1xyXG4vL2ltcG9ydCB7IE1hdElucHV0TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaW5wdXQnO1xyXG4vL2ltcG9ydCB7IE1hdEZvcm1GaWVsZE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2Zvcm0tZmllbGQnO1xyXG4vL2ltcG9ydCB7IE1hdFNsaWRlVG9nZ2xlTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc2xpZGUtdG9nZ2xlJztcclxuLy9pbXBvcnQgeyBNYXRUYWJzTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvdGFicyc7XHJcblxyXG4vL0NvbXBvbmVudHNcclxuaW1wb3J0IHsgQ29lckFsZXJ0IH0gZnJvbSAnLi9jb2VyLWFsZXJ0L2NvZXItYWxlcnQuY29tcG9uZW50JztcclxuaW1wb3J0IHsgQ29lckJ1dHRvbiB9IGZyb20gJy4vY29lci1idXR0b24vY29lci1idXR0b24uY29tcG9uZW50JztcclxuLy9pbXBvcnQgeyBDb2VyQ2hlY2tib3ggfSBmcm9tICcuL2NvZXItY2hlY2tib3gvY29lci1jaGVja2JveC5jb21wb25lbnQnO1xyXG4vL2ltcG9ydCB7IENvZXJGaWxlYm94IH0gZnJvbSAnLi9jb2VyLWZpbGVib3gvY29lci1maWxlYm94LmNvbXBvbmVudCc7XHJcbi8vaW1wb3J0IHsgQ29lckZvcm0gfSBmcm9tICcuL2NvZXItZm9ybS9jb2VyLWZvcm0uY29tcG9uZW50JztcclxuLy9pbXBvcnQgeyBDb2VyR3JpZCB9IGZyb20gJy4vY29lci1ncmlkL2NvZXItZ3JpZC5jb21wb25lbnQnO1xyXG4vL2ltcG9ydCB7IENvZXJNb2RhbCB9IGZyb20gJy4vY29lci1tb2RhbC9jb2VyLW1vZGFsLmNvbXBvbmVudCc7XHJcbi8vaW1wb3J0IHsgQ29lck51bWJlckJveCB9IGZyb20gJy4vY29lci1udW1iZXJib3gvY29lci1udW1iZXJib3guY29tcG9uZW50JztcclxuLy9pbXBvcnQgeyBDb2VyUGFnZVRpdGxlIH0gZnJvbSAnLi9jb2VyLXBhZ2UtdGl0bGUvY29lci1wYWdlLXRpdGxlLmNvbXBvbmVudCc7XHJcbi8vaW1wb3J0IHsgQ29lclNlbGVjdGJveCB9IGZyb20gJy4vY29lci1zZWxlY3Rib3gvY29lci1zZWxlY3Rib3guY29tcG9uZW50JztcclxuLy9pbXBvcnQgeyBDb2VyU3dpdGNoIH0gZnJvbSAnLi9jb2VyLXN3aXRjaC9jb2VyLXN3aXRjaC5jb21wb25lbnQnO1xyXG4vL2ltcG9ydCB7IENvZXJUYWIgfSBmcm9tICcuL2NvZXItdGFiL2NvZXItdGFiLmNvbXBvbmVudCc7XHJcbi8vaW1wb3J0IHsgQ29lclRleHRhcmVhIH0gZnJvbSAnLi9jb2VyLXRleHRhcmVhL2NvZXItdGV4dGFyZWEuY29tcG9uZW50JztcclxuLy9pbXBvcnQgeyBDb2VyVGV4dEJveCB9IGZyb20gJy4vY29lci10ZXh0Ym94L2NvZXItdGV4dGJveC5jb21wb25lbnQnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICAgIGltcG9ydHM6IFtcclxuICAgICAgICBDb21tb25Nb2R1bGUsXHJcbiAgICAgICAgUm91dGVyTW9kdWxlLFxyXG4gICAgICAgIEZvcm1zTW9kdWxlLFxyXG4gICAgICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXHJcbiAgICAgICAgLy9QaXBlc01vZHVsZSxcclxuICAgICAgICBNYXRCdXR0b25Nb2R1bGUsXHJcbiAgICAgICAgLy9NYXRDaGVja2JveE1vZHVsZSxcclxuICAgICAgICAvL01hdElucHV0TW9kdWxlLFxyXG4gICAgICAgIC8vTWF0Rm9ybUZpZWxkTW9kdWxlLFxyXG4gICAgICAgIC8vTWF0U2xpZGVUb2dnbGVNb2R1bGUsXHJcbiAgICAgICAgLy9NYXRUYWJzTW9kdWxlLFxyXG4gICAgICAgIC8vRGlyZWN0aXZlc01vZHVsZVxyXG4gICAgXSxcclxuICAgIGRlY2xhcmF0aW9uczogW1xyXG4gICAgICAgIENvZXJBbGVydCxcclxuICAgICAgICBDb2VyQnV0dG9uLFxyXG4gICAgICAgIC8vQ29lckNoZWNrYm94LFxyXG4gICAgICAgIC8vQ29lckZpbGVib3gsXHJcbiAgICAgICAgLy9Db2VyRm9ybSxcclxuICAgICAgICAvL0NvZXJHcmlkLFxyXG4gICAgICAgIC8vQ29lck1vZGFsLFxyXG4gICAgICAgIC8vQ29lck51bWJlckJveCxcclxuICAgICAgICAvL0NvZXJQYWdlVGl0bGUsXHJcbiAgICAgICAgLy9Db2VyU2VsZWN0Ym94LFxyXG4gICAgICAgIC8vQ29lclN3aXRjaCxcclxuICAgICAgICAvL0NvZXJUZXh0YXJlYSxcclxuICAgICAgICAvL0NvZXJUYWIsXHJcbiAgICAgICAgLy9Db2VyVGV4dEJveCxcclxuICAgIF0sXHJcbiAgICBleHBvcnRzOiBbXHJcbiAgICAgICAgQ29lckFsZXJ0LFxyXG4gICAgICAgIENvZXJCdXR0b24sXHJcbiAgICAgICAgLy9Db2VyQ2hlY2tib3gsXHJcbiAgICAgICAgLy9Db2VyRmlsZWJveCxcclxuICAgICAgICAvL0NvZXJGb3JtLFxyXG4gICAgICAgIC8vQ29lckdyaWQsXHJcbiAgICAgICAgLy9Db2VyTW9kYWwsXHJcbiAgICAgICAgLy9Db2VyTnVtYmVyQm94LFxyXG4gICAgICAgIC8vQ29lclBhZ2VUaXRsZSxcclxuICAgICAgICAvL0NvZXJTZWxlY3Rib3gsXHJcbiAgICAgICAgLy9Db2VyU3dpdGNoLFxyXG4gICAgICAgIC8vQ29lclRleHRhcmVhLFxyXG4gICAgICAgIC8vQ29lclRhYixcclxuICAgICAgICAvL0NvZXJUZXh0Qm94LFxyXG4gICAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgQ29tcG9uZW50c01vZHVsZSB7IH1cclxuLy9leHBvcnQgKiBmcm9tICcuL2NvZXItYWxlcnQvY29lci1hbGVydC5jb21wb25lbnQnO1xyXG4vL2V4cG9ydCAqIGZyb20gJy4vY29lci1idXR0b24vY29lci1idXR0b24uY29tcG9uZW50JztcclxuLy9leHBvcnQgKiBmcm9tICcuL2NvZXItY2hlY2tib3gvY29lci1jaGVja2JveC5jb21wb25lbnQnO1xyXG4vL2V4cG9ydCAqIGZyb20gJy4vY29lci1maWxlYm94L2NvZXItZmlsZWJveC5jb21wb25lbnQnO1xyXG4vL2V4cG9ydCAqIGZyb20gJy4vY29lci1maWxlYm94L2NvZXItZmlsZWJveC5pbnRlcmZhY2UnO1xyXG4vL2V4cG9ydCAqIGZyb20gJy4vY29lci1mb3JtL2NvZXItZm9ybS5jb21wb25lbnQnO1xyXG4vL2V4cG9ydCAqIGZyb20gJy4vY29lci1ncmlkL2NvZXItZ3JpZC5jb21wb25lbnQnO1xyXG4vL2V4cG9ydCAqIGZyb20gJy4vY29lci1ncmlkL2NvZXItZ3JpZC5pbnRlcmZhY2UnO1xyXG4vL2V4cG9ydCAqIGZyb20gJy4vY29lci1ncmlkL2NvZXItZ3JpZC50ZW1wbGF0ZXMnO1xyXG4vL2V4cG9ydCAqIGZyb20gJy4vY29lci1tb2RhbC9jb2VyLW1vZGFsLmNvbXBvbmVudCc7XHJcbi8vZXhwb3J0ICogZnJvbSAnLi9jb2VyLW51bWJlcmJveC9jb2VyLW51bWJlcmJveC5jb21wb25lbnQnO1xyXG4vL2V4cG9ydCAqIGZyb20gJy4vY29lci1wYWdlLXRpdGxlL2NvZXItcGFnZS10aXRsZS5jb21wb25lbnQnO1xyXG4vL2V4cG9ydCAqIGZyb20gJy4vY29lci1wYWdlLXRpdGxlL3BhZ2VUaXRsZS5pbnRlcmZhY2UnO1xyXG4vL2V4cG9ydCAqIGZyb20gJy4vY29lci1zZWxlY3Rib3gvY29lci1zZWxlY3Rib3guY29tcG9uZW50JztcclxuLy9leHBvcnQgKiBmcm9tICcuL2NvZXItc3dpdGNoL2NvZXItc3dpdGNoLmNvbXBvbmVudCc7XHJcbi8vZXhwb3J0ICogZnJvbSAnLi9jb2VyLXRhYi9jb2VyLXRhYi5jb21wb25lbnQnO1xyXG4vL2V4cG9ydCAqIGZyb20gJy4vY29lci10ZXh0Ym94L2NvZXItdGV4dGJveC5jb21wb25lbnQnOyJdfQ==
         | 
| @@ -0,0 +1,7 @@ | |
| 1 | 
            +
            export * from './lib/app-source.interface';
         | 
| 2 | 
            +
            export * from './lib/breadcrumb.interface';
         | 
| 3 | 
            +
            export * from './lib/coer-ref.interface';
         | 
| 4 | 
            +
            export * from './lib/go-back.interface';
         | 
| 5 | 
            +
            export * from './lib/patch.interface';
         | 
| 6 | 
            +
            export * from './lib/screen-size.interface';
         | 
| 7 | 
            +
            //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jb2VyLWVsZW1lbnRzL3NyYy9pbnRlcmZhY2VzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLDZCQUE2QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvYXBwLXNvdXJjZS5pbnRlcmZhY2UnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9icmVhZGNydW1iLmludGVyZmFjZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvZXItcmVmLmludGVyZmFjZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2dvLWJhY2suaW50ZXJmYWNlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvcGF0Y2guaW50ZXJmYWNlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvc2NyZWVuLXNpemUuaW50ZXJmYWNlJzsiXX0=
         | 
| @@ -0,0 +1,2 @@ | |
| 1 | 
            +
            export {};
         | 
| 2 | 
            +
            //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwLXNvdXJjZS5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb2VyLWVsZW1lbnRzL3NyYy9pbnRlcmZhY2VzL2xpYi9hcHAtc291cmNlLmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBJQXBwU291cmNlIHtcclxuICAgIHBhZ2U6IHN0cmluZztcclxuICAgIHBhdGg6IHN0cmluZztcclxufSJdfQ==
         | 
| @@ -0,0 +1,2 @@ | |
| 1 | 
            +
            export {};
         | 
| 2 | 
            +
            //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnJlYWRjcnVtYi5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb2VyLWVsZW1lbnRzL3NyYy9pbnRlcmZhY2VzL2xpYi9icmVhZGNydW1iLmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBJQnJlYWRjcnVtYiB7XHJcbiAgICBwYWdlOiBzdHJpbmc7XHJcbiAgICBwYXRoPzogc3RyaW5nIHwgbnVsbDtcclxuICAgIHF1ZXJ5UGFyYW1zPzogYW55O1xyXG4gICAgY2xpY2s/OiAoKCkgPT4gYW55KTtcclxufSJdfQ==
         | 
| @@ -0,0 +1,2 @@ | |
| 1 | 
            +
            export {};
         | 
| 2 | 
            +
            //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29lci1yZWYuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29lci1lbGVtZW50cy9zcmMvaW50ZXJmYWNlcy9saWIvY29lci1yZWYuaW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUZW1wbGF0ZVJlZiwgV3JpdGFibGVTaWduYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgSUNvZXJSZWYge1xyXG4gICAgY29lclJlZjogV3JpdGFibGVTaWduYWw8c3RyaW5nPjtcclxuICAgIHRpdGxlOiBXcml0YWJsZVNpZ25hbDxzdHJpbmc+O1xyXG4gICAgaWNvbjogV3JpdGFibGVTaWduYWw8c3RyaW5nPjtcclxuICAgIGlzRGlzYWJsZWQ6IFdyaXRhYmxlU2lnbmFsPGJvb2xlYW4+O1xyXG4gICAgc2hvdzogV3JpdGFibGVTaWduYWw8Ym9vbGVhbj47XHJcbiAgICB0b29sdGlwOiBXcml0YWJsZVNpZ25hbDxzdHJpbmc+O1xyXG4gICAgdGVtcGxhdGU6IFRlbXBsYXRlUmVmPGFueT47XHJcbn0iXX0=
         | 
| @@ -0,0 +1,2 @@ | |
| 1 | 
            +
            export {};
         | 
| 2 | 
            +
            //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ28tYmFjay5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb2VyLWVsZW1lbnRzL3NyYy9pbnRlcmZhY2VzL2xpYi9nby1iYWNrLmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBJR29CYWNrIHtcclxuICAgIHNob3c6IGJvb2xlYW47XHJcbiAgICBwYXRoPzogc3RyaW5nIHwgbnVsbDtcclxuICAgIHF1ZXJ5UGFyYW1zPzogYW55O1xyXG4gICAgY2xpY2s/OiAoKCkgPT4gYW55KTtcclxufSJdfQ==
         | 
| @@ -0,0 +1,2 @@ | |
| 1 | 
            +
            export {};
         | 
| 2 | 
            +
            //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGF0Y2guaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29lci1lbGVtZW50cy9zcmMvaW50ZXJmYWNlcy9saWIvcGF0Y2guaW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIElQYXRjaCB7XHJcbiAgICBvcDogJ3JlbW92ZScgfCAnYWRkJyB8ICdyZXBsYWNlJztcclxuICAgIHBhdGg6IHN0cmluZztcclxuICAgIHZhbHVlOiBhbnk7XHJcbn0iXX0=
         | 
| @@ -0,0 +1,2 @@ | |
| 1 | 
            +
            export {};
         | 
| 2 | 
            +
            //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NyZWVuLXNpemUuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29lci1lbGVtZW50cy9zcmMvaW50ZXJmYWNlcy9saWIvc2NyZWVuLXNpemUuaW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIElTY3JlZW5TaXplIHtcclxuICAgIHdpZHRoOiBudW1iZXI7XHJcbiAgICBoZWlnaHQ6IG51bWJlcjtcclxuICAgIGJyZWFrcG9pbjogJ3hzJyB8ICdzbScgfCAnbWQnIHwgJ2xnJyB8ICd4bCcgfCAneHhsJztcclxufSJdfQ==
         | 
    
        package/esm2022/public_api.mjs
    CHANGED
    
    | @@ -1,3 +1,4 @@ | |
| 1 1 | 
             
            export * from './components';
         | 
| 2 | 
            +
            export * from './signals';
         | 
| 2 3 | 
             
            export * from './tools';
         | 
| 3 | 
            -
            //# sourceMappingURL=data:application/json;base64, | 
| 4 | 
            +
            //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2NvZXItZWxlbWVudHMvc3JjL3B1YmxpY19hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxXQUFXLENBQUM7QUFDMUIsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudHMnO1xyXG5leHBvcnQgKiBmcm9tICcuL3NpZ25hbHMnO1xyXG5leHBvcnQgKiBmcm9tICcuL3Rvb2xzJzsiXX0=
         | 
| @@ -0,0 +1,4 @@ | |
| 1 | 
            +
            export * from './lib/breakpoint.signal';
         | 
| 2 | 
            +
            export * from './lib/is-loading.signal';
         | 
| 3 | 
            +
            export * from './lib/is-modal-open.signal';
         | 
| 4 | 
            +
            //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jb2VyLWVsZW1lbnRzL3NyYy9zaWduYWxzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLDRCQUE0QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvYnJlYWtwb2ludC5zaWduYWwnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9pcy1sb2FkaW5nLnNpZ25hbCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2lzLW1vZGFsLW9wZW4uc2lnbmFsJzsiXX0=
         | 
| @@ -0,0 +1,4 @@ | |
| 1 | 
            +
            import { signal } from '@angular/core';
         | 
| 2 | 
            +
            import { Screen } from '../../tools';
         | 
| 3 | 
            +
            export const breakpointSIGNAL = signal(Screen?.BREAKPOINT || 'xs');
         | 
| 4 | 
            +
            //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnJlYWtwb2ludC5zaWduYWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb2VyLWVsZW1lbnRzL3NyYy9zaWduYWxzL2xpYi9icmVha3BvaW50LnNpZ25hbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDckMsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQUcsTUFBTSxDQUEyQyxNQUFNLEVBQUUsVUFBVSxJQUFJLElBQUksQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgc2lnbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFNjcmVlbiB9IGZyb20gJy4uLy4uL3Rvb2xzJztcclxuZXhwb3J0IGNvbnN0IGJyZWFrcG9pbnRTSUdOQUwgPSBzaWduYWw8J3hzJyB8ICdzbScgfCAnbWQnIHwgJ2xnJyB8ICd4bCcgfCAneHhsJz4oU2NyZWVuPy5CUkVBS1BPSU5UIHx8ICd4cycpOyJdfQ==
         | 
| @@ -0,0 +1,3 @@ | |
| 1 | 
            +
            import { signal } from "@angular/core";
         | 
| 2 | 
            +
            export const isLoadingSIG = signal(false);
         | 
| 3 | 
            +
            //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXMtbG9hZGluZy5zaWduYWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb2VyLWVsZW1lbnRzL3NyYy9zaWduYWxzL2xpYi9pcy1sb2FkaW5nLnNpZ25hbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE1BQU0sQ0FBQyxNQUFNLFlBQVksR0FBRyxNQUFNLENBQVUsS0FBSyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBzaWduYWwgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5leHBvcnQgY29uc3QgaXNMb2FkaW5nU0lHID0gc2lnbmFsPGJvb2xlYW4+KGZhbHNlKTsiXX0=
         | 
| @@ -0,0 +1,3 @@ | |
| 1 | 
            +
            import { signal } from "@angular/core";
         | 
| 2 | 
            +
            export const isModalOpenSIG = signal(false);
         | 
| 3 | 
            +
            //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXMtbW9kYWwtb3Blbi5zaWduYWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb2VyLWVsZW1lbnRzL3NyYy9zaWduYWxzL2xpYi9pcy1tb2RhbC1vcGVuLnNpZ25hbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRyxNQUFNLENBQVUsS0FBSyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBzaWduYWwgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5leHBvcnQgY29uc3QgaXNNb2RhbE9wZW5TSUcgPSBzaWduYWw8Ym9vbGVhbj4oZmFsc2UpOyJdfQ==
         | 
    
        package/esm2022/tools/index.mjs
    CHANGED
    
    | @@ -1,2 +1,9 @@ | |
| 1 | 
            -
            export * from './lib/ | 
| 2 | 
            -
             | 
| 1 | 
            +
            export * from './lib/breadcrumbs.class';
         | 
| 2 | 
            +
            export * from './lib/control-value.class';
         | 
| 3 | 
            +
            export * from './lib/date-time.class';
         | 
| 4 | 
            +
            export * from './lib/files.class';
         | 
| 5 | 
            +
            export * from './lib/generi-tools';
         | 
| 6 | 
            +
            export * from './lib/page.class';
         | 
| 7 | 
            +
            export * from './lib/screen.class';
         | 
| 8 | 
            +
            export * from './lib/source.class';
         | 
| 9 | 
            +
            //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jb2VyLWVsZW1lbnRzL3NyYy90b29scy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsb0JBQW9CLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xpYi9icmVhZGNydW1icy5jbGFzcyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbnRyb2wtdmFsdWUuY2xhc3MnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kYXRlLXRpbWUuY2xhc3MnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWxlcy5jbGFzcyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2dlbmVyaS10b29scyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3BhZ2UuY2xhc3MnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zY3JlZW4uY2xhc3MnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zb3VyY2UuY2xhc3MnO1xyXG4iXX0=
         | 
| @@ -0,0 +1,63 @@ | |
| 1 | 
            +
            import { Tools } from './generi-tools';
         | 
| 2 | 
            +
            export class Breadcrumbs {
         | 
| 3 | 
            +
                static { this.storage = 'COER-System'; }
         | 
| 4 | 
            +
                /** */
         | 
| 5 | 
            +
                static Add(page, path) {
         | 
| 6 | 
            +
                    const breadcrumbs = this.Get();
         | 
| 7 | 
            +
                    const paths = breadcrumbs.map(item => item.path);
         | 
| 8 | 
            +
                    if (!paths.includes(path)) {
         | 
| 9 | 
            +
                        breadcrumbs.push({ page, path });
         | 
| 10 | 
            +
                        this.Save(breadcrumbs);
         | 
| 11 | 
            +
                    }
         | 
| 12 | 
            +
                }
         | 
| 13 | 
            +
                /** */
         | 
| 14 | 
            +
                static Get() {
         | 
| 15 | 
            +
                    let storage = sessionStorage.getItem(this.storage);
         | 
| 16 | 
            +
                    if (storage) {
         | 
| 17 | 
            +
                        storage = JSON.parse(storage);
         | 
| 18 | 
            +
                        if (storage.hasOwnProperty('breadcrumbs')) {
         | 
| 19 | 
            +
                            return Tools.BreakReference(storage.breadcrumbs);
         | 
| 20 | 
            +
                        }
         | 
| 21 | 
            +
                    }
         | 
| 22 | 
            +
                    return [];
         | 
| 23 | 
            +
                }
         | 
| 24 | 
            +
                /** */
         | 
| 25 | 
            +
                static GetFirst() {
         | 
| 26 | 
            +
                    const breadcrumbs = this.Get();
         | 
| 27 | 
            +
                    return (breadcrumbs.length > 0) ? breadcrumbs.shift() : null;
         | 
| 28 | 
            +
                }
         | 
| 29 | 
            +
                /** */
         | 
| 30 | 
            +
                static Save(breadcrumbs) {
         | 
| 31 | 
            +
                    let storage = sessionStorage.getItem(this.storage);
         | 
| 32 | 
            +
                    if (storage)
         | 
| 33 | 
            +
                        storage = JSON.parse(storage);
         | 
| 34 | 
            +
                    storage = Object.assign({}, storage, { breadcrumbs });
         | 
| 35 | 
            +
                    sessionStorage.setItem(this.storage, JSON.stringify(storage));
         | 
| 36 | 
            +
                }
         | 
| 37 | 
            +
                /** */
         | 
| 38 | 
            +
                static Remove(path) {
         | 
| 39 | 
            +
                    let breadcrumbs = this.Get();
         | 
| 40 | 
            +
                    const index = breadcrumbs.findIndex(x => x.path.toLowerCase().trim() === path.toLowerCase().trim());
         | 
| 41 | 
            +
                    if (index >= 0) {
         | 
| 42 | 
            +
                        breadcrumbs = Tools.BreakReference(breadcrumbs).splice(0, index + 1);
         | 
| 43 | 
            +
                        this.Save(breadcrumbs);
         | 
| 44 | 
            +
                    }
         | 
| 45 | 
            +
                }
         | 
| 46 | 
            +
                /** */
         | 
| 47 | 
            +
                static SetLast(page, path) {
         | 
| 48 | 
            +
                    const breadcrumbs = this.Get();
         | 
| 49 | 
            +
                    if (breadcrumbs.length > 0) {
         | 
| 50 | 
            +
                        breadcrumbs[breadcrumbs.length - 1] = { page, path };
         | 
| 51 | 
            +
                        this.Save(breadcrumbs);
         | 
| 52 | 
            +
                    }
         | 
| 53 | 
            +
                }
         | 
| 54 | 
            +
                /** */
         | 
| 55 | 
            +
                static RemoveLast() {
         | 
| 56 | 
            +
                    const breadcrumbs = this.Get();
         | 
| 57 | 
            +
                    if (breadcrumbs.length > 0) {
         | 
| 58 | 
            +
                        breadcrumbs.pop();
         | 
| 59 | 
            +
                        this.Save(breadcrumbs);
         | 
| 60 | 
            +
                    }
         | 
| 61 | 
            +
                }
         | 
| 62 | 
            +
            }
         | 
| 63 | 
            +
            //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnJlYWRjcnVtYnMuY2xhc3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb2VyLWVsZW1lbnRzL3NyYy90b29scy9saWIvYnJlYWRjcnVtYnMuY2xhc3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLEtBQUssRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRXZDLE1BQU0sT0FBTyxXQUFXO2FBRUksWUFBTyxHQUFHLGFBQWEsQ0FBQztJQUVoRCxNQUFNO0lBQ0MsTUFBTSxDQUFDLEdBQUcsQ0FBQyxJQUFZLEVBQUUsSUFBWTtRQUN4QyxNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUM7UUFDL0IsTUFBTSxLQUFLLEdBQUcsV0FBVyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUVqRCxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDO1lBQ3hCLFdBQVcsQ0FBQyxJQUFJLENBQUMsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztZQUNqQyxJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQzNCLENBQUM7SUFDTCxDQUFDO0lBR0QsTUFBTTtJQUNDLE1BQU0sQ0FBQyxHQUFHO1FBQ2IsSUFBSSxPQUFPLEdBQUcsY0FBYyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFRLENBQUM7UUFFMUQsSUFBSSxPQUFPLEVBQUUsQ0FBQztZQUNWLE9BQU8sR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1lBRTlCLElBQUksT0FBTyxDQUFDLGNBQWMsQ0FBQyxhQUFhLENBQUMsRUFBRSxDQUFDO2dCQUN4QyxPQUFPLEtBQUssQ0FBQyxjQUFjLENBQUMsT0FBTyxDQUFDLFdBQVcsQ0FBQyxDQUFDO1lBQ3JELENBQUM7UUFDTCxDQUFDO1FBRUQsT0FBTyxFQUFFLENBQUM7SUFDZCxDQUFDO0lBR0QsTUFBTTtJQUNDLE1BQU0sQ0FBQyxRQUFRO1FBQ2xCLE1BQU0sV0FBVyxHQUFHLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQztRQUMvQixPQUFPLENBQUMsV0FBVyxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsV0FBVyxDQUFDLEtBQUssRUFBRyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUM7SUFDbEUsQ0FBQztJQUdELE1BQU07SUFDQyxNQUFNLENBQUMsSUFBSSxDQUFDLFdBQXlCO1FBQ3hDLElBQUksT0FBTyxHQUFHLGNBQWMsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBUSxDQUFDO1FBQzFELElBQUksT0FBTztZQUFFLE9BQU8sR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQzNDLE9BQU8sR0FBRyxNQUFNLENBQUMsTUFBTSxDQUFDLEVBQUUsRUFBRSxPQUFPLEVBQUUsRUFBRSxXQUFXLEVBQUUsQ0FBQyxDQUFDO1FBQ3RELGNBQWMsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7SUFDbEUsQ0FBQztJQUdELE1BQU07SUFDQyxNQUFNLENBQUMsTUFBTSxDQUFDLElBQVk7UUFDN0IsSUFBSSxXQUFXLEdBQUcsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDO1FBQzdCLE1BQU0sS0FBSyxHQUFHLFdBQVcsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDLElBQUksRUFBRSxLQUFLLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDO1FBRXBHLElBQUksS0FBSyxJQUFJLENBQUMsRUFBRSxDQUFDO1lBQ2IsV0FBVyxHQUFHLEtBQUssQ0FBQyxjQUFjLENBQUMsV0FBVyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsRUFBRSxLQUFLLEdBQUcsQ0FBQyxDQUFDLENBQUM7WUFDckUsSUFBSSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUMzQixDQUFDO0lBQ0wsQ0FBQztJQUdELE1BQU07SUFDQyxNQUFNLENBQUMsT0FBTyxDQUFDLElBQVksRUFBRSxJQUFZO1FBQzVDLE1BQU0sV0FBVyxHQUFHLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQztRQUUvQixJQUFJLFdBQVcsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFLENBQUM7WUFDekIsV0FBVyxDQUFDLFdBQVcsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLEdBQUcsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUM7WUFDckQsSUFBSSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUMzQixDQUFDO0lBQ0wsQ0FBQztJQUdELE1BQU07SUFDQyxNQUFNLENBQUMsVUFBVTtRQUNwQixNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUM7UUFFL0IsSUFBSSxXQUFXLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRSxDQUFDO1lBQ3pCLFdBQVcsQ0FBQyxHQUFHLEVBQUUsQ0FBQztZQUNsQixJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQzNCLENBQUM7SUFDTCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSUFwcFNvdXJjZSB9IGZyb20gXCIuLi8uLi9pbnRlcmZhY2VzXCI7XHJcbmltcG9ydCB7IFRvb2xzIH0gZnJvbSAnLi9nZW5lcmktdG9vbHMnO1xyXG5cclxuZXhwb3J0IGNsYXNzIEJyZWFkY3J1bWJzIHtcclxuXHJcbiAgICBwcml2YXRlIHN0YXRpYyByZWFkb25seSBzdG9yYWdlID0gJ0NPRVItU3lzdGVtJztcclxuXHJcbiAgICAvKiogKi9cclxuICAgIHB1YmxpYyBzdGF0aWMgQWRkKHBhZ2U6IHN0cmluZywgcGF0aDogc3RyaW5nKTogdm9pZCB7XHJcbiAgICAgICAgY29uc3QgYnJlYWRjcnVtYnMgPSB0aGlzLkdldCgpO1xyXG4gICAgICAgIGNvbnN0IHBhdGhzID0gYnJlYWRjcnVtYnMubWFwKGl0ZW0gPT4gaXRlbS5wYXRoKTtcclxuXHJcbiAgICAgICAgaWYgKCFwYXRocy5pbmNsdWRlcyhwYXRoKSkge1xyXG4gICAgICAgICAgICBicmVhZGNydW1icy5wdXNoKHsgcGFnZSwgcGF0aCB9KTtcclxuICAgICAgICAgICAgdGhpcy5TYXZlKGJyZWFkY3J1bWJzKTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG5cclxuICAgIC8qKiAqL1xyXG4gICAgcHVibGljIHN0YXRpYyBHZXQoKTogSUFwcFNvdXJjZVtdIHtcclxuICAgICAgICBsZXQgc3RvcmFnZSA9IHNlc3Npb25TdG9yYWdlLmdldEl0ZW0odGhpcy5zdG9yYWdlKSBhcyBhbnk7XHJcblxyXG4gICAgICAgIGlmIChzdG9yYWdlKSB7XHJcbiAgICAgICAgICAgIHN0b3JhZ2UgPSBKU09OLnBhcnNlKHN0b3JhZ2UpO1xyXG5cclxuICAgICAgICAgICAgaWYgKHN0b3JhZ2UuaGFzT3duUHJvcGVydHkoJ2JyZWFkY3J1bWJzJykpIHtcclxuICAgICAgICAgICAgICAgIHJldHVybiBUb29scy5CcmVha1JlZmVyZW5jZShzdG9yYWdlLmJyZWFkY3J1bWJzKTtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgcmV0dXJuIFtdO1xyXG4gICAgfVxyXG5cclxuXHJcbiAgICAvKiogKi9cclxuICAgIHB1YmxpYyBzdGF0aWMgR2V0Rmlyc3QoKTogSUFwcFNvdXJjZSB8IG51bGwge1xyXG4gICAgICAgIGNvbnN0IGJyZWFkY3J1bWJzID0gdGhpcy5HZXQoKTtcclxuICAgICAgICByZXR1cm4gKGJyZWFkY3J1bWJzLmxlbmd0aCA+IDApID8gYnJlYWRjcnVtYnMuc2hpZnQoKSEgOiBudWxsO1xyXG4gICAgfVxyXG5cclxuXHJcbiAgICAvKiogKi9cclxuICAgIHB1YmxpYyBzdGF0aWMgU2F2ZShicmVhZGNydW1iczogSUFwcFNvdXJjZVtdKTogdm9pZCB7XHJcbiAgICAgICAgbGV0IHN0b3JhZ2UgPSBzZXNzaW9uU3RvcmFnZS5nZXRJdGVtKHRoaXMuc3RvcmFnZSkgYXMgYW55O1xyXG4gICAgICAgIGlmIChzdG9yYWdlKSBzdG9yYWdlID0gSlNPTi5wYXJzZShzdG9yYWdlKTtcclxuICAgICAgICBzdG9yYWdlID0gT2JqZWN0LmFzc2lnbih7fSwgc3RvcmFnZSwgeyBicmVhZGNydW1icyB9KTtcclxuICAgICAgICBzZXNzaW9uU3RvcmFnZS5zZXRJdGVtKHRoaXMuc3RvcmFnZSwgSlNPTi5zdHJpbmdpZnkoc3RvcmFnZSkpO1xyXG4gICAgfVxyXG5cclxuXHJcbiAgICAvKiogKi9cclxuICAgIHB1YmxpYyBzdGF0aWMgUmVtb3ZlKHBhdGg6IHN0cmluZyk6IHZvaWQge1xyXG4gICAgICAgIGxldCBicmVhZGNydW1icyA9IHRoaXMuR2V0KCk7XHJcbiAgICAgICAgY29uc3QgaW5kZXggPSBicmVhZGNydW1icy5maW5kSW5kZXgoeCA9PiB4LnBhdGgudG9Mb3dlckNhc2UoKS50cmltKCkgPT09IHBhdGgudG9Mb3dlckNhc2UoKS50cmltKCkpO1xyXG5cclxuICAgICAgICBpZiAoaW5kZXggPj0gMCkge1xyXG4gICAgICAgICAgICBicmVhZGNydW1icyA9IFRvb2xzLkJyZWFrUmVmZXJlbmNlKGJyZWFkY3J1bWJzKS5zcGxpY2UoMCwgaW5kZXggKyAxKTtcclxuICAgICAgICAgICAgdGhpcy5TYXZlKGJyZWFkY3J1bWJzKTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG5cclxuICAgIC8qKiAqL1xyXG4gICAgcHVibGljIHN0YXRpYyBTZXRMYXN0KHBhZ2U6IHN0cmluZywgcGF0aDogc3RyaW5nKTogdm9pZCB7XHJcbiAgICAgICAgY29uc3QgYnJlYWRjcnVtYnMgPSB0aGlzLkdldCgpO1xyXG5cclxuICAgICAgICBpZiAoYnJlYWRjcnVtYnMubGVuZ3RoID4gMCkge1xyXG4gICAgICAgICAgICBicmVhZGNydW1ic1ticmVhZGNydW1icy5sZW5ndGggLSAxXSA9IHsgcGFnZSwgcGF0aCB9O1xyXG4gICAgICAgICAgICB0aGlzLlNhdmUoYnJlYWRjcnVtYnMpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcblxyXG4gICAgLyoqICovXHJcbiAgICBwdWJsaWMgc3RhdGljIFJlbW92ZUxhc3QoKTogdm9pZCB7XHJcbiAgICAgICAgY29uc3QgYnJlYWRjcnVtYnMgPSB0aGlzLkdldCgpO1xyXG5cclxuICAgICAgICBpZiAoYnJlYWRjcnVtYnMubGVuZ3RoID4gMCkge1xyXG4gICAgICAgICAgICBicmVhZGNydW1icy5wb3AoKTtcclxuICAgICAgICAgICAgdGhpcy5TYXZlKGJyZWFkY3J1bWJzKTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcbn0iXX0=
         |