zek 17.3.34 → 17.3.36
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/esm2022/lib/components/base.component.mjs +1 -1
- package/esm2022/lib/components/core-ui.component.mjs +5 -5
- package/esm2022/lib/components/core.component.mjs +1 -1
- package/esm2022/lib/components/edit-base.component.mjs +17 -17
- package/esm2022/lib/components/list-base.component.mjs +18 -18
- package/esm2022/lib/modules/age/age.pipe.mjs +2 -2
- package/esm2022/lib/modules/alert/toast/toast.mjs +3 -3
- package/esm2022/lib/modules/bb/bb.component.mjs +2 -2
- package/esm2022/lib/modules/card/card/card.mjs +1 -1
- package/esm2022/lib/modules/datepicker/date-value-accessor.mjs +6 -6
- package/esm2022/lib/modules/file-viewer/file-viewer.mjs +2 -2
- package/esm2022/lib/modules/google-login-button/google-login-button.mjs +2 -2
- package/esm2022/lib/modules/google-login-button/loader.mjs +1 -1
- package/esm2022/lib/modules/modal/modal/modal.component.mjs +5 -5
- package/esm2022/lib/modules/numeric/numeric.directive.mjs +6 -6
- package/esm2022/lib/modules/pager/pager/pager.mjs +1 -1
- package/esm2022/lib/modules/progress/progress.mjs +3 -3
- package/esm2022/lib/modules/radio/radio.mjs +2 -2
- package/esm2022/lib/modules/recaptcha/loader.mjs +3 -3
- package/esm2022/lib/modules/select/select.mjs +5 -5
- package/esm2022/lib/modules/select2/select2.mjs +2 -2
- package/esm2022/lib/modules/select2-multiple/select2-multiple.mjs +3 -3
- package/esm2022/lib/modules/validators/validator.mjs +4 -4
- package/esm2022/lib/modules/wizard/wizard/wizard.mjs +2 -2
- package/esm2022/lib/services/alert.service.mjs +2 -2
- package/esm2022/lib/services/auth-guard.service.mjs +17 -2
- package/esm2022/lib/services/auth.service.mjs +10 -10
- package/esm2022/lib/services/http-error-handler.service.mjs +3 -3
- package/esm2022/lib/services/web.api.mjs +2 -2
- package/esm2022/lib/utils/array-helper.mjs +8 -8
- package/esm2022/lib/utils/bootstrap.helper.mjs +1 -1
- package/esm2022/lib/utils/convert.mjs +2 -2
- package/esm2022/lib/utils/css-helper.mjs +6 -6
- package/esm2022/lib/utils/date-helper.mjs +32 -47
- package/esm2022/lib/utils/error-helper.mjs +3 -3
- package/esm2022/lib/utils/excel-helper.mjs +2 -2
- package/esm2022/lib/utils/file.helper.mjs +4 -4
- package/esm2022/lib/utils/filter-helper.mjs +2 -2
- package/esm2022/lib/utils/handler.mjs +5 -5
- package/esm2022/lib/utils/html-helper.mjs +4 -4
- package/esm2022/lib/utils/jwt-helper.mjs +4 -4
- package/esm2022/lib/utils/math-helper.mjs +1 -3
- package/esm2022/lib/utils/object-helper.mjs +3 -5
- package/esm2022/lib/utils/overlap-helper.mjs +4 -4
- package/esm2022/lib/utils/storage-helper.mjs +3 -3
- package/esm2022/lib/utils/string-helper.mjs +6 -5
- package/esm2022/lib/utils/thenBy.mjs +9 -9
- package/esm2022/lib/utils/time-helper.mjs +12 -13
- package/esm2022/lib/utils/tmp-helper.mjs +2 -2
- package/esm2022/lib/utils/url-helper.mjs +6 -6
- package/fesm2022/zek.mjs +200 -206
- package/fesm2022/zek.mjs.map +1 -1
- package/lib/services/alert.service.d.ts +2 -2
- package/lib/services/auth-guard.service.d.ts +2 -1
- package/lib/utils/bootstrap.helper.d.ts +1 -1
- package/lib/utils/handler.d.ts +1 -1
- package/lib/utils/thenBy.d.ts +1 -1
- package/package.json +1 -1
|
@@ -53,7 +53,7 @@ export class ZekModal extends CoreComponent {
|
|
|
53
53
|
});
|
|
54
54
|
}
|
|
55
55
|
setTimeout(() => {
|
|
56
|
-
|
|
56
|
+
const modalEl = this.getModalElement();
|
|
57
57
|
if (modalEl) {
|
|
58
58
|
this.shownHandler = handler.addListener(modalEl, 'shown.bs.modal', () => {
|
|
59
59
|
this.onShown.emit();
|
|
@@ -149,7 +149,7 @@ export class ZekModal extends CoreComponent {
|
|
|
149
149
|
return document.getElementById(this.modalId);
|
|
150
150
|
}
|
|
151
151
|
getModal() {
|
|
152
|
-
|
|
152
|
+
const modalEl = this.getModalElement();
|
|
153
153
|
return new bootstrap.Modal(modalEl, { backdrop: 'static' });
|
|
154
154
|
}
|
|
155
155
|
cssButton() {
|
|
@@ -182,14 +182,14 @@ export class ZekModal extends CoreComponent {
|
|
|
182
182
|
this._modal.hide();
|
|
183
183
|
}
|
|
184
184
|
else {
|
|
185
|
-
|
|
185
|
+
const btn = document.getElementById(this.cancelButtonId);
|
|
186
186
|
if (btn) {
|
|
187
187
|
btn.click();
|
|
188
188
|
}
|
|
189
189
|
}
|
|
190
190
|
}
|
|
191
191
|
ok() {
|
|
192
|
-
|
|
192
|
+
const event = new ValidEventArgs();
|
|
193
193
|
this.onValidating.emit(event);
|
|
194
194
|
if (!event.valid)
|
|
195
195
|
return;
|
|
@@ -342,4 +342,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImpor
|
|
|
342
342
|
type: Component,
|
|
343
343
|
args: [{ selector: 'zek-restore-modal', template: "<div (keydown.enter)=\"keyDown($event)\" class=\"modal fade\" data-bs-backdrop=\"static\" id=\"{{modalId}}\" tabindex=\"-1\" attr.aria-labelledby=\"{{lableId}}\" aria-hidden=\"true\">\r\n <div class=\"modal-dialog\" [ngClass]=\"{\r\n 'modal-sm': size === 'sm',\r\n 'modal-lg': size === 'lg', \r\n 'modal-xl': size === 'xl'\r\n }\" [class.modal-dialog-scrollable]=\"scrollable\" [class.modal-fullscreen]=\"fullscreen\">\r\n <div class=\"modal-content\">\r\n <div class=\"modal-header\" *ngIf=\"showHeader\">\r\n <ng-content select=\"header\"></ng-content>\r\n <h5 class=\"modal-title\" id=\"{{lableId}}\">{{title}}</h5>\r\n <button type=\"button\" class=\"btn-close\" data-bs-dismiss=\"modal\" aria-label=\"Close\"></button>\r\n </div>\r\n <div class=\"modal-body\">\r\n {{text}}\r\n <ng-content></ng-content>\r\n </div>\r\n <div class=\"modal-footer\" *ngIf=\"showFooter\">\r\n <ng-content select=\"footer\"></ng-content>\r\n <button [class.visually-hidden]=\"!showOk\" [disabled]=\"disabledOk\" type=\"button\" class=\"btn {{cssButton()}}\" id=\"{{okButtonId}}\" (click)=\"ok()\">\r\n <i *ngIf=\"icon\" class=\"{{ icon }}\"></i> {{ okButtonText }}\r\n </button>\r\n <button [class.visually-hidden]=\"!showCancel\" type=\"button\" class=\"btn btn-secondary\" id=\"{{cancelButtonId}}\" data-bs-dismiss=\"modal\">\r\n <i class=\"fa-solid fa-ban\"></i> {{ 'Action.Cancel' | translate }}\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n</div>" }]
|
|
344
344
|
}], ctorParameters: () => [] });
|
|
345
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../../../../projects/zek/src/lib/modules/modal/modal/modal.component.ts","../../../../../../../projects/zek/src/lib/modules/modal/modal/modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Output, EventEmitter, Input, inject } from '@angular/core';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { BooleanInput, CoreComponent } from '../../../components';\r\nimport { BootstrapHelper, ComponentType, Convert, handler, RandomHelper } from '../../../utils';\r\nimport { ValidEventArgs } from '../../../models/valid-event-args.model';\r\nimport { ModalSize } from '../../../models';\r\n\r\ndeclare let bootstrap: any;\r\nlet uniqueId = 0;\r\n\r\n@Component({\r\n    selector: 'zek-modal',\r\n    templateUrl: './modal.component.html'\r\n})\r\nexport class ZekModal extends CoreComponent {\r\n    protected readonly translate = inject(TranslateService);\r\n\r\n    constructor() {\r\n        super();\r\n        this.elementId = RandomHelper.randomHex();\r\n    }\r\n    override async destroy() {\r\n        await super.destroy();\r\n        this._modal?.dispose();\r\n        this._modal = null;\r\n\r\n        if (this.hiddenHandler) {\r\n            handler.removeListener(this.hiddenHandler);\r\n        }\r\n        if (this.shownHandler) {\r\n            handler.removeListener(this.shownHandler);\r\n        }\r\n    }\r\n    override init() {\r\n        super.init()\r\n        if (!this.okButtonText) {\r\n            this.translate.get('Action.Ok').subscribe(text => {\r\n                this.okButtonText = text;\r\n            });\r\n        }\r\n\r\n        setTimeout(() => {\r\n            let modalEl = this.getModalElement();\r\n            if (modalEl) {\r\n                this.shownHandler = handler.addListener(modalEl, 'shown.bs.modal', () => {\r\n                    this.onShown.emit();\r\n                });\r\n\r\n                this.hiddenHandler = handler.addListener(modalEl, 'hidden.bs.modal', () => {\r\n                    this.onHidden.emit();\r\n                });\r\n            }\r\n        }, 1);\r\n    }\r\n\r\n    private _uniqueId: string = `zek-modal-${++uniqueId}`;\r\n    /** The unique ID for the radio button. */\r\n    @Input() id: string = this._uniqueId;\r\n    modalId = `${this.id}-modal`;\r\n    lableId = `${this.id}-lable`;\r\n    cancelButtonId = `${this.id}-cancel-button`;\r\n    okButtonId = `${this.id}-ok-button`;\r\n\r\n    shownHandler?: number | null;\r\n    hiddenHandler?: number | null;\r\n\r\n    @Input() model: any;\r\n    readonly elementId: string;\r\n\r\n\r\n    private _showOk = true;\r\n    @Input()\r\n    get showOk(): boolean {\r\n        return this._showOk;\r\n    }\r\n    set showOk(v: BooleanInput) {\r\n        this._showOk = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n    private _disabledOk = false;\r\n    @Input()\r\n    get disabledOk(): boolean {\r\n        return this._disabledOk;\r\n    }\r\n    set disabledOk(v: BooleanInput) {\r\n        this._disabledOk = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n    private _showCancel = true;\r\n    @Input()\r\n    get showCancel(): boolean {\r\n        return this._showCancel;\r\n    }\r\n    set showCancel(v: BooleanInput) {\r\n        this._showCancel = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n\r\n    private _autoHide = true;\r\n    @Input()\r\n    get autoHide(): boolean {\r\n        return this._autoHide;\r\n    }\r\n    set autoHide(v: BooleanInput) {\r\n        this._autoHide = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n\r\n    @Input() title?: string | null;\r\n\r\n    @Input() text?: string | null;\r\n\r\n    @Input() icon?: string | null;\r\n\r\n    @Input() okButtonText?: string | null;\r\n\r\n    @Output() onShown = new EventEmitter<any>();\r\n\r\n    @Output() onHidden = new EventEmitter<any>();\r\n\r\n    @Output() onOk = new EventEmitter<any>();\r\n\r\n    @Input() componentType = ComponentType.Primary;\r\n\r\n\r\n\r\n    private _size: ModalSize = '';\r\n    @Input()\r\n    get size() {\r\n        return this._size;\r\n    }\r\n    set size(v: ModalSize) {\r\n        this._size = v;\r\n    }\r\n\r\n    /**\r\n     * @deprecated Please use size property\r\n     */\r\n    @Input()\r\n    get large(): boolean {\r\n        return this._size === 'lg';\r\n    }\r\n    set large(v: BooleanInput) {\r\n        this._size = Convert.toBooleanProperty(v) ? 'lg' : '';\r\n    }\r\n\r\n    /**\r\n     * @deprecated Please use size property\r\n     */\r\n    @Input()\r\n    get xl(): boolean {\r\n        return this._size === 'xl';\r\n    }\r\n    set xl(v: BooleanInput) {\r\n        this._size = Convert.toBooleanProperty(v) ? 'xl' : '';\r\n    }\r\n\r\n\r\n    private _scrollable = false;\r\n    @Input()\r\n    get scrollable(): boolean {\r\n        return this._scrollable;\r\n    }\r\n    set scrollable(v: BooleanInput) {\r\n        this._scrollable = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n    private _fullscreen = false;\r\n    @Input()\r\n    get fullscreen(): boolean {\r\n        return this._fullscreen;\r\n    }\r\n    set fullscreen(v: BooleanInput) {\r\n        this._fullscreen = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n    private _showHeader = true;\r\n    @Input()\r\n    get showHeader(): boolean {\r\n        return this._showHeader;\r\n    }\r\n    set showHeader(v: BooleanInput) {\r\n        this._showHeader = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n    private _showFooter = true;\r\n    @Input()\r\n    get showFooter(): boolean {\r\n        return this._showFooter;\r\n    }\r\n    set showFooter(v: BooleanInput) {\r\n        this._showFooter = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n\r\n\r\n\r\n    @Output() onValidating = new EventEmitter<ValidEventArgs>(false);\r\n    // @Input() xxl: boolean;\r\n\r\n    private _modal: any;\r\n    // public get modal(): any {\r\n    //     if (!this._modal) {\r\n    //         this.getModal();\r\n    //     }\r\n    //     return this._modal;\r\n    // }\r\n    // public set modal(v: any) {\r\n    //     this._modal = v;\r\n    // }\r\n\r\n    protected getModalElement() {\r\n        return document.getElementById(this.modalId);\r\n    }\r\n    protected getModal() {\r\n        let modalEl = this.getModalElement();\r\n        return new bootstrap.Modal(modalEl, { backdrop: 'static' });\r\n    }\r\n\r\n\r\n\r\n\r\n    cssButton() {\r\n        return BootstrapHelper.cssButton(this.componentType);\r\n    }\r\n\r\n    // private isShown = false;\r\n    show(model?: any) {\r\n        if (!model) model = {};\r\n        this.model = model;\r\n\r\n        // this.modal?.show();\r\n\r\n\r\n        if (!this._modal) {\r\n            this._modal = this.getModal();\r\n        }\r\n        if (this._modal) {\r\n            this._modal.show();\r\n            // this.isShown = true;\r\n        }\r\n    }\r\n\r\n    hide() {\r\n        // this.modal?.hide();\r\n\r\n        // if (this.isShown) {\r\n        //     if (this._modal) {\r\n        //         this._modal.hide();\r\n        //         this.isShown = false;\r\n        //     }\r\n        // } else {\r\n\r\n        // }\r\n\r\n        if (this._modal) {\r\n            this._modal.hide();\r\n        }\r\n        else {\r\n            let btn = document.getElementById(this.cancelButtonId);\r\n            if (btn) {\r\n                btn.click();\r\n            }\r\n        }\r\n    }\r\n\r\n    ok() {\r\n        let event = new ValidEventArgs();\r\n        this.onValidating.emit(event);\r\n        if (!event.valid) return;\r\n\r\n        if (this.autoHide)\r\n            this.hide();\r\n\r\n        this.onOk.emit(this.model);\r\n    }\r\n\r\n    keyDown(e: Event) {\r\n        e.preventDefault();\r\n        this.ok();\r\n    }\r\n}\r\n\r\n/**\r\n * @deprecated Please use ZekModal\r\n */\r\n@Component({\r\n    selector: 'zek-delete-modal',\r\n    templateUrl: './modal.component.html'\r\n})\r\nexport class ZekDeleteModal extends ZekModal {\r\n    constructor() {\r\n        super();\r\n        this.icon = 'fa-solid fa-trash';\r\n        this.translate.get('Action.Delete').subscribe((res: string) => this.title = res);\r\n        this.translate.get('Alert.DeleteQuestion').subscribe((res: string) => this.text = res);\r\n        this.componentType = ComponentType.Delete;\r\n    }\r\n}\r\n\r\n/**\r\n * @deprecated Please use ZekModal\r\n */\r\n@Component({\r\n    selector: 'zek-approve-modal',\r\n    templateUrl: './modal.component.html'\r\n})\r\nexport class ZekApproveModal extends ZekModal {\r\n    constructor() {\r\n        super();\r\n        this.icon = 'fa-solid fa-thumbs-up';\r\n        this.translate.get('Action.Approve').subscribe((res: string) => this.title = res);\r\n        this.translate.get('Alert.ApproveQuestion').subscribe((res: string) => this.text = res);\r\n        this.componentType = ComponentType.Success;\r\n    }\r\n}\r\n\r\n/**\r\n * @deprecated Please use ZekModal\r\n */\r\n@Component({\r\n    selector: 'zek-submit-modal',\r\n    templateUrl: './modal.component.html'\r\n})\r\nexport class ZekSubmitModal extends ZekModal {\r\n    constructor() {\r\n        super();\r\n        this.icon = 'fa-solid fa-thumbs-up';\r\n        this.translate.get('Action.Submit').subscribe((res: string) => this.title = res);\r\n        this.translate.get('Alert.SubmitQuestion').subscribe((res: string) => this.text = res);\r\n        this.componentType = ComponentType.Success;\r\n    }\r\n}\r\n\r\n/**\r\n * @deprecated Please use ZekModal\r\n */\r\n@Component({\r\n    selector: 'zek-disapprove-modal',\r\n    templateUrl: './modal.component.html'\r\n})\r\nexport class ZekDisapproveModal extends ZekModal {\r\n    constructor() {\r\n        super();\r\n        this.icon = 'fa-solid fa-thumbs-down';\r\n        this.translate.get('Action.Disapprove').subscribe((res: string) => this.title = res);\r\n        this.translate.get('Alert.DisapproveQuestion').subscribe((res: string) => this.text = res);\r\n        this.componentType = ComponentType.Delete;\r\n    }\r\n}\r\n\r\n\r\n/**\r\n * @deprecated Please use ZekModal\r\n */\r\n@Component({\r\n    selector: 'zek-restore-modal',\r\n    templateUrl: './modal.component.html'\r\n})\r\nexport class ZekRestoreModal extends ZekModal {\r\n    constructor() {\r\n        super();\r\n        this.icon = 'fa-solid fa-rotate-right';\r\n        this.translate.get('Action.Restore').subscribe((res: string) => this.title = res);\r\n        this.translate.get('Action.RestoreQuestion').subscribe((res: string) => this.text = res);\r\n        this.componentType = ComponentType.Success;\r\n    }\r\n}","<div (keydown.enter)=\"keyDown($event)\" class=\"modal fade\" data-bs-backdrop=\"static\" id=\"{{modalId}}\" tabindex=\"-1\" attr.aria-labelledby=\"{{lableId}}\" aria-hidden=\"true\">\r\n    <div class=\"modal-dialog\" [ngClass]=\"{\r\n        'modal-sm': size === 'sm',\r\n        'modal-lg': size === 'lg', \r\n        'modal-xl': size === 'xl'\r\n    }\" [class.modal-dialog-scrollable]=\"scrollable\" [class.modal-fullscreen]=\"fullscreen\">\r\n        <div class=\"modal-content\">\r\n            <div class=\"modal-header\" *ngIf=\"showHeader\">\r\n                <ng-content select=\"header\"></ng-content>\r\n                <h5 class=\"modal-title\" id=\"{{lableId}}\">{{title}}</h5>\r\n                <button type=\"button\" class=\"btn-close\" data-bs-dismiss=\"modal\" aria-label=\"Close\"></button>\r\n            </div>\r\n            <div class=\"modal-body\">\r\n                {{text}}\r\n                <ng-content></ng-content>\r\n            </div>\r\n            <div class=\"modal-footer\" *ngIf=\"showFooter\">\r\n                <ng-content select=\"footer\"></ng-content>\r\n                <button [class.visually-hidden]=\"!showOk\" [disabled]=\"disabledOk\" type=\"button\" class=\"btn {{cssButton()}}\" id=\"{{okButtonId}}\" (click)=\"ok()\">\r\n                    <i *ngIf=\"icon\" class=\"{{ icon }}\"></i> {{ okButtonText }}\r\n                </button>\r\n                <button [class.visually-hidden]=\"!showCancel\" type=\"button\" class=\"btn btn-secondary\" id=\"{{cancelButtonId}}\" data-bs-dismiss=\"modal\">\r\n                    <i class=\"fa-solid fa-ban\"></i> {{ 'Action.Cancel' | translate }}\r\n                </button>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>"]}
|
|
345
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../../../../projects/zek/src/lib/modules/modal/modal/modal.component.ts","../../../../../../../projects/zek/src/lib/modules/modal/modal/modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Output, EventEmitter, Input, inject } from '@angular/core';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { BooleanInput, CoreComponent } from '../../../components';\r\nimport { BootstrapHelper, ComponentType, Convert, handler, RandomHelper } from '../../../utils';\r\nimport { ValidEventArgs } from '../../../models/valid-event-args.model';\r\nimport { ModalSize } from '../../../models';\r\n\r\ndeclare let bootstrap: any;\r\nlet uniqueId = 0;\r\n\r\n@Component({\r\n    selector: 'zek-modal',\r\n    templateUrl: './modal.component.html'\r\n})\r\nexport class ZekModal extends CoreComponent {\r\n    protected readonly translate = inject(TranslateService);\r\n\r\n    constructor() {\r\n        super();\r\n        this.elementId = RandomHelper.randomHex();\r\n    }\r\n    override async destroy() {\r\n        await super.destroy();\r\n        this._modal?.dispose();\r\n        this._modal = null;\r\n\r\n        if (this.hiddenHandler) {\r\n            handler.removeListener(this.hiddenHandler);\r\n        }\r\n        if (this.shownHandler) {\r\n            handler.removeListener(this.shownHandler);\r\n        }\r\n    }\r\n    override init() {\r\n        super.init()\r\n        if (!this.okButtonText) {\r\n            this.translate.get('Action.Ok').subscribe(text => {\r\n                this.okButtonText = text;\r\n            });\r\n        }\r\n\r\n        setTimeout(() => {\r\n            const modalEl = this.getModalElement();\r\n            if (modalEl) {\r\n                this.shownHandler = handler.addListener(modalEl, 'shown.bs.modal', () => {\r\n                    this.onShown.emit();\r\n                });\r\n\r\n                this.hiddenHandler = handler.addListener(modalEl, 'hidden.bs.modal', () => {\r\n                    this.onHidden.emit();\r\n                });\r\n            }\r\n        }, 1);\r\n    }\r\n\r\n    private _uniqueId: string = `zek-modal-${++uniqueId}`;\r\n    /** The unique ID for the radio button. */\r\n    @Input() id: string = this._uniqueId;\r\n    modalId = `${this.id}-modal`;\r\n    lableId = `${this.id}-lable`;\r\n    cancelButtonId = `${this.id}-cancel-button`;\r\n    okButtonId = `${this.id}-ok-button`;\r\n\r\n    shownHandler?: number | null;\r\n    hiddenHandler?: number | null;\r\n\r\n    @Input() model: any;\r\n    readonly elementId: string;\r\n\r\n\r\n    private _showOk = true;\r\n    @Input()\r\n    get showOk(): boolean {\r\n        return this._showOk;\r\n    }\r\n    set showOk(v: BooleanInput) {\r\n        this._showOk = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n    private _disabledOk = false;\r\n    @Input()\r\n    get disabledOk(): boolean {\r\n        return this._disabledOk;\r\n    }\r\n    set disabledOk(v: BooleanInput) {\r\n        this._disabledOk = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n    private _showCancel = true;\r\n    @Input()\r\n    get showCancel(): boolean {\r\n        return this._showCancel;\r\n    }\r\n    set showCancel(v: BooleanInput) {\r\n        this._showCancel = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n\r\n    private _autoHide = true;\r\n    @Input()\r\n    get autoHide(): boolean {\r\n        return this._autoHide;\r\n    }\r\n    set autoHide(v: BooleanInput) {\r\n        this._autoHide = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n\r\n    @Input() title?: string | null;\r\n\r\n    @Input() text?: string | null;\r\n\r\n    @Input() icon?: string | null;\r\n\r\n    @Input() okButtonText?: string | null;\r\n\r\n    @Output() onShown = new EventEmitter<any>();\r\n\r\n    @Output() onHidden = new EventEmitter<any>();\r\n\r\n    @Output() onOk = new EventEmitter<any>();\r\n\r\n    @Input() componentType = ComponentType.Primary;\r\n\r\n\r\n\r\n    private _size: ModalSize = '';\r\n    @Input()\r\n    get size() {\r\n        return this._size;\r\n    }\r\n    set size(v: ModalSize) {\r\n        this._size = v;\r\n    }\r\n\r\n    /**\r\n     * @deprecated Please use size property\r\n     */\r\n    @Input()\r\n    get large(): boolean {\r\n        return this._size === 'lg';\r\n    }\r\n    set large(v: BooleanInput) {\r\n        this._size = Convert.toBooleanProperty(v) ? 'lg' : '';\r\n    }\r\n\r\n    /**\r\n     * @deprecated Please use size property\r\n     */\r\n    @Input()\r\n    get xl(): boolean {\r\n        return this._size === 'xl';\r\n    }\r\n    set xl(v: BooleanInput) {\r\n        this._size = Convert.toBooleanProperty(v) ? 'xl' : '';\r\n    }\r\n\r\n\r\n    private _scrollable = false;\r\n    @Input()\r\n    get scrollable(): boolean {\r\n        return this._scrollable;\r\n    }\r\n    set scrollable(v: BooleanInput) {\r\n        this._scrollable = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n    private _fullscreen = false;\r\n    @Input()\r\n    get fullscreen(): boolean {\r\n        return this._fullscreen;\r\n    }\r\n    set fullscreen(v: BooleanInput) {\r\n        this._fullscreen = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n    private _showHeader = true;\r\n    @Input()\r\n    get showHeader(): boolean {\r\n        return this._showHeader;\r\n    }\r\n    set showHeader(v: BooleanInput) {\r\n        this._showHeader = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n    private _showFooter = true;\r\n    @Input()\r\n    get showFooter(): boolean {\r\n        return this._showFooter;\r\n    }\r\n    set showFooter(v: BooleanInput) {\r\n        this._showFooter = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n\r\n\r\n\r\n    @Output() onValidating = new EventEmitter<ValidEventArgs>(false);\r\n    // @Input() xxl: boolean;\r\n\r\n    private _modal: any;\r\n    // public get modal(): any {\r\n    //     if (!this._modal) {\r\n    //         this.getModal();\r\n    //     }\r\n    //     return this._modal;\r\n    // }\r\n    // public set modal(v: any) {\r\n    //     this._modal = v;\r\n    // }\r\n\r\n    protected getModalElement() {\r\n        return document.getElementById(this.modalId);\r\n    }\r\n    protected getModal() {\r\n        const modalEl = this.getModalElement();\r\n        return new bootstrap.Modal(modalEl, { backdrop: 'static' });\r\n    }\r\n\r\n\r\n\r\n\r\n    cssButton() {\r\n        return BootstrapHelper.cssButton(this.componentType);\r\n    }\r\n\r\n    // private isShown = false;\r\n    show(model?: any) {\r\n        if (!model) model = {};\r\n        this.model = model;\r\n\r\n        // this.modal?.show();\r\n\r\n\r\n        if (!this._modal) {\r\n            this._modal = this.getModal();\r\n        }\r\n        if (this._modal) {\r\n            this._modal.show();\r\n            // this.isShown = true;\r\n        }\r\n    }\r\n\r\n    hide() {\r\n        // this.modal?.hide();\r\n\r\n        // if (this.isShown) {\r\n        //     if (this._modal) {\r\n        //         this._modal.hide();\r\n        //         this.isShown = false;\r\n        //     }\r\n        // } else {\r\n\r\n        // }\r\n\r\n        if (this._modal) {\r\n            this._modal.hide();\r\n        }\r\n        else {\r\n            const btn = document.getElementById(this.cancelButtonId);\r\n            if (btn) {\r\n                btn.click();\r\n            }\r\n        }\r\n    }\r\n\r\n    ok() {\r\n        const event = new ValidEventArgs();\r\n        this.onValidating.emit(event);\r\n        if (!event.valid) return;\r\n\r\n        if (this.autoHide)\r\n            this.hide();\r\n\r\n        this.onOk.emit(this.model);\r\n    }\r\n\r\n    keyDown(e: Event) {\r\n        e.preventDefault();\r\n        this.ok();\r\n    }\r\n}\r\n\r\n/**\r\n * @deprecated Please use ZekModal\r\n */\r\n@Component({\r\n    selector: 'zek-delete-modal',\r\n    templateUrl: './modal.component.html'\r\n})\r\nexport class ZekDeleteModal extends ZekModal {\r\n    constructor() {\r\n        super();\r\n        this.icon = 'fa-solid fa-trash';\r\n        this.translate.get('Action.Delete').subscribe((res: string) => this.title = res);\r\n        this.translate.get('Alert.DeleteQuestion').subscribe((res: string) => this.text = res);\r\n        this.componentType = ComponentType.Delete;\r\n    }\r\n}\r\n\r\n/**\r\n * @deprecated Please use ZekModal\r\n */\r\n@Component({\r\n    selector: 'zek-approve-modal',\r\n    templateUrl: './modal.component.html'\r\n})\r\nexport class ZekApproveModal extends ZekModal {\r\n    constructor() {\r\n        super();\r\n        this.icon = 'fa-solid fa-thumbs-up';\r\n        this.translate.get('Action.Approve').subscribe((res: string) => this.title = res);\r\n        this.translate.get('Alert.ApproveQuestion').subscribe((res: string) => this.text = res);\r\n        this.componentType = ComponentType.Success;\r\n    }\r\n}\r\n\r\n/**\r\n * @deprecated Please use ZekModal\r\n */\r\n@Component({\r\n    selector: 'zek-submit-modal',\r\n    templateUrl: './modal.component.html'\r\n})\r\nexport class ZekSubmitModal extends ZekModal {\r\n    constructor() {\r\n        super();\r\n        this.icon = 'fa-solid fa-thumbs-up';\r\n        this.translate.get('Action.Submit').subscribe((res: string) => this.title = res);\r\n        this.translate.get('Alert.SubmitQuestion').subscribe((res: string) => this.text = res);\r\n        this.componentType = ComponentType.Success;\r\n    }\r\n}\r\n\r\n/**\r\n * @deprecated Please use ZekModal\r\n */\r\n@Component({\r\n    selector: 'zek-disapprove-modal',\r\n    templateUrl: './modal.component.html'\r\n})\r\nexport class ZekDisapproveModal extends ZekModal {\r\n    constructor() {\r\n        super();\r\n        this.icon = 'fa-solid fa-thumbs-down';\r\n        this.translate.get('Action.Disapprove').subscribe((res: string) => this.title = res);\r\n        this.translate.get('Alert.DisapproveQuestion').subscribe((res: string) => this.text = res);\r\n        this.componentType = ComponentType.Delete;\r\n    }\r\n}\r\n\r\n\r\n/**\r\n * @deprecated Please use ZekModal\r\n */\r\n@Component({\r\n    selector: 'zek-restore-modal',\r\n    templateUrl: './modal.component.html'\r\n})\r\nexport class ZekRestoreModal extends ZekModal {\r\n    constructor() {\r\n        super();\r\n        this.icon = 'fa-solid fa-rotate-right';\r\n        this.translate.get('Action.Restore').subscribe((res: string) => this.title = res);\r\n        this.translate.get('Action.RestoreQuestion').subscribe((res: string) => this.text = res);\r\n        this.componentType = ComponentType.Success;\r\n    }\r\n}","<div (keydown.enter)=\"keyDown($event)\" class=\"modal fade\" data-bs-backdrop=\"static\" id=\"{{modalId}}\" tabindex=\"-1\" attr.aria-labelledby=\"{{lableId}}\" aria-hidden=\"true\">\r\n    <div class=\"modal-dialog\" [ngClass]=\"{\r\n        'modal-sm': size === 'sm',\r\n        'modal-lg': size === 'lg', \r\n        'modal-xl': size === 'xl'\r\n    }\" [class.modal-dialog-scrollable]=\"scrollable\" [class.modal-fullscreen]=\"fullscreen\">\r\n        <div class=\"modal-content\">\r\n            <div class=\"modal-header\" *ngIf=\"showHeader\">\r\n                <ng-content select=\"header\"></ng-content>\r\n                <h5 class=\"modal-title\" id=\"{{lableId}}\">{{title}}</h5>\r\n                <button type=\"button\" class=\"btn-close\" data-bs-dismiss=\"modal\" aria-label=\"Close\"></button>\r\n            </div>\r\n            <div class=\"modal-body\">\r\n                {{text}}\r\n                <ng-content></ng-content>\r\n            </div>\r\n            <div class=\"modal-footer\" *ngIf=\"showFooter\">\r\n                <ng-content select=\"footer\"></ng-content>\r\n                <button [class.visually-hidden]=\"!showOk\" [disabled]=\"disabledOk\" type=\"button\" class=\"btn {{cssButton()}}\" id=\"{{okButtonId}}\" (click)=\"ok()\">\r\n                    <i *ngIf=\"icon\" class=\"{{ icon }}\"></i> {{ okButtonText }}\r\n                </button>\r\n                <button [class.visually-hidden]=\"!showCancel\" type=\"button\" class=\"btn btn-secondary\" id=\"{{cancelButtonId}}\" data-bs-dismiss=\"modal\">\r\n                    <i class=\"fa-solid fa-ban\"></i> {{ 'Action.Cancel' | translate }}\r\n                </button>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>"]}
|
|
@@ -6,7 +6,7 @@ export class NumericDirective {
|
|
|
6
6
|
return this._digits;
|
|
7
7
|
}
|
|
8
8
|
set digits(v) {
|
|
9
|
-
|
|
9
|
+
const tmp = MathHelper.clamp(Convert.toNumber(v) || 0, 0, 29);
|
|
10
10
|
this._digits = tmp;
|
|
11
11
|
}
|
|
12
12
|
get negative() {
|
|
@@ -20,7 +20,7 @@ export class NumericDirective {
|
|
|
20
20
|
return String(value).match(new RegExp(/^-?\d+$/));
|
|
21
21
|
}
|
|
22
22
|
else {
|
|
23
|
-
|
|
23
|
+
const regExpString = "^-?\\s*((\\d+(\\.\\d{0," +
|
|
24
24
|
this._digits +
|
|
25
25
|
"})?)|((\\d*(\\.\\d{1," +
|
|
26
26
|
this._digits +
|
|
@@ -33,7 +33,7 @@ export class NumericDirective {
|
|
|
33
33
|
return String(value).match(new RegExp(/^\d+$/));
|
|
34
34
|
}
|
|
35
35
|
else {
|
|
36
|
-
|
|
36
|
+
const regExpString = "^\\s*((\\d+(\\.\\d{0," +
|
|
37
37
|
this._digits +
|
|
38
38
|
"})?)|((\\d*(\\.\\d{1," +
|
|
39
39
|
this._digits +
|
|
@@ -43,8 +43,8 @@ export class NumericDirective {
|
|
|
43
43
|
}
|
|
44
44
|
run(oldValue) {
|
|
45
45
|
setTimeout(() => {
|
|
46
|
-
|
|
47
|
-
|
|
46
|
+
const currentValue = this.el.nativeElement.value;
|
|
47
|
+
const allowNegative = this._negative;
|
|
48
48
|
if (allowNegative) {
|
|
49
49
|
if (!["", "-"].includes(currentValue) &&
|
|
50
50
|
!this.checkAllowNegative(currentValue)) {
|
|
@@ -89,4 +89,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImpor
|
|
|
89
89
|
type: HostListener,
|
|
90
90
|
args: ["paste", ["$event"]]
|
|
91
91
|
}] } });
|
|
92
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
92
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnVtZXJpYy5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy96ZWsvc3JjL2xpYi9tb2R1bGVzL251bWVyaWMvbnVtZXJpYy5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBYyxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTNFLE9BQU8sRUFBRSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sYUFBYSxDQUFDOztBQU1sRCxNQUFNLE9BQU8sZ0JBQWdCO0lBRXpCLElBQUksTUFBTTtRQUNOLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQztJQUN4QixDQUFDO0lBQ0QsSUFDSSxNQUFNLENBQUMsQ0FBYztRQUNyQixNQUFNLEdBQUcsR0FBRyxVQUFVLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUM5RCxJQUFJLENBQUMsT0FBTyxHQUFHLEdBQUcsQ0FBQztJQUN2QixDQUFDO0lBR0QsSUFBSSxRQUFRO1FBQ1IsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDO0lBQzFCLENBQUM7SUFDRCxJQUFhLFFBQVEsQ0FBQyxDQUFlO1FBQ2pDLElBQUksQ0FBQyxTQUFTLEdBQUcsT0FBTyxDQUFDLGlCQUFpQixDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ2xELENBQUM7SUFFTyxrQkFBa0IsQ0FBQyxLQUFhO1FBQ3BDLElBQUksSUFBSSxDQUFDLE9BQU8sSUFBSSxDQUFDLEVBQUUsQ0FBQztZQUNwQixPQUFPLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxLQUFLLENBQUMsSUFBSSxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQztRQUN0RCxDQUFDO2FBQU0sQ0FBQztZQUNKLE1BQU0sWUFBWSxHQUNkLHlCQUF5QjtnQkFDekIsSUFBSSxDQUFDLE9BQU87Z0JBQ1osdUJBQXVCO2dCQUN2QixJQUFJLENBQUMsT0FBTztnQkFDWixZQUFZLENBQUM7WUFDakIsT0FBTyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUMsS0FBSyxDQUFDLElBQUksTUFBTSxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUM7UUFDekQsQ0FBQztJQUNMLENBQUM7SUFFTyxLQUFLLENBQUMsS0FBYTtRQUN2QixJQUFJLElBQUksQ0FBQyxPQUFPLElBQUksQ0FBQyxFQUFFLENBQUM7WUFDcEIsT0FBTyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUMsS0FBSyxDQUFDLElBQUksTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7UUFDcEQsQ0FBQzthQUFNLENBQUM7WUFDSixNQUFNLFlBQVksR0FDZCx1QkFBdUI7Z0JBQ3ZCLElBQUksQ0FBQyxPQUFPO2dCQUNaLHVCQUF1QjtnQkFDdkIsSUFBSSxDQUFDLE9BQU87Z0JBQ1osWUFBWSxDQUFDO1lBQ2pCLE9BQU8sTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDLEtBQUssQ0FBQyxJQUFJLE1BQU0sQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDO1FBQ3pELENBQUM7SUFDTCxDQUFDO0lBRU8sR0FBRyxDQUFDLFFBQWE7UUFDckIsVUFBVSxDQUFDLEdBQUcsRUFBRTtZQUNaLE1BQU0sWUFBWSxHQUFXLElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQztZQUN6RCxNQUFNLGFBQWEsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDO1lBRXJDLElBQUksYUFBYSxFQUFFLENBQUM7Z0JBQ2hCLElBQ0ksQ0FBQyxDQUFDLEVBQUUsRUFBRSxHQUFHLENBQUMsQ0FBQyxRQUFRLENBQUMsWUFBWSxDQUFDO29CQUNqQyxDQUFDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxZQUFZLENBQUMsRUFDeEMsQ0FBQztvQkFDQyxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxLQUFLLEdBQUcsUUFBUSxDQUFDO2dCQUMzQyxDQUFDO1lBQ0wsQ0FBQztpQkFBTSxDQUFDO2dCQUNKLElBQUksWUFBWSxLQUFLLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsWUFBWSxDQUFDLEVBQUUsQ0FBQztvQkFDbkQsSUFBSSxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUMsS0FBSyxHQUFHLFFBQVEsQ0FBQztnQkFDM0MsQ0FBQztZQUNMLENBQUM7UUFDTCxDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7SUFHRCxZQUFvQixFQUFjO1FBQWQsT0FBRSxHQUFGLEVBQUUsQ0FBWTtRQW5FMUIsWUFBTyxHQUFHLENBQUMsQ0FBQztRQVVaLGNBQVMsR0FBRyxLQUFLLENBQUM7SUF5RFksQ0FBQztJQUd2QyxTQUFTLENBQUMsS0FBb0I7UUFDMUIsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUMxQyxDQUFDO0lBR0QsT0FBTyxDQUFDLEtBQXFCO1FBQ3pCLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDMUMsQ0FBQzs4R0E5RVEsZ0JBQWdCO2tHQUFoQixnQkFBZ0I7OzJGQUFoQixnQkFBZ0I7a0JBSjVCLFNBQVM7bUJBQUM7b0JBQ1AsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRSxXQUFXO2lCQUN4QjsrRUFPTyxNQUFNO3NCQURULEtBQUs7Z0JBVU8sUUFBUTtzQkFBcEIsS0FBSztnQkF3RE4sU0FBUztzQkFEUixZQUFZO3VCQUFDLFNBQVMsRUFBRSxDQUFDLFFBQVEsQ0FBQztnQkFNbkMsT0FBTztzQkFETixZQUFZO3VCQUFDLE9BQU8sRUFBRSxDQUFDLFFBQVEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgSG9zdExpc3RlbmVyLCBJbnB1dCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IEJvb2xlYW5JbnB1dCwgTnVtYmVySW5wdXQgfSBmcm9tIFwiLi4vLi4vY29tcG9uZW50c1wiO1xyXG5pbXBvcnQgeyBDb252ZXJ0LCBNYXRoSGVscGVyIH0gZnJvbSBcIi4uLy4uL3V0aWxzXCI7XHJcblxyXG5ARGlyZWN0aXZlKHtcclxuICAgIHN0YW5kYWxvbmU6IHRydWUsXHJcbiAgICBzZWxlY3RvcjogXCJbbnVtZXJpY11cIixcclxufSlcclxuZXhwb3J0IGNsYXNzIE51bWVyaWNEaXJlY3RpdmUge1xyXG4gICAgcHJpdmF0ZSBfZGlnaXRzID0gMDtcclxuICAgIGdldCBkaWdpdHMoKSB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuX2RpZ2l0cztcclxuICAgIH1cclxuICAgIEBJbnB1dCgpXHJcbiAgICBzZXQgZGlnaXRzKHY6IE51bWJlcklucHV0KSB7XHJcbiAgICAgICAgY29uc3QgdG1wID0gTWF0aEhlbHBlci5jbGFtcChDb252ZXJ0LnRvTnVtYmVyKHYpIHx8IDAsIDAsIDI5KTtcclxuICAgICAgICB0aGlzLl9kaWdpdHMgPSB0bXA7XHJcbiAgICB9XHJcblxyXG4gICAgcHJpdmF0ZSBfbmVnYXRpdmUgPSBmYWxzZTtcclxuICAgIGdldCBuZWdhdGl2ZSgpOiBib29sZWFuIHtcclxuICAgICAgICByZXR1cm4gdGhpcy5fbmVnYXRpdmU7XHJcbiAgICB9XHJcbiAgICBASW5wdXQoKSBzZXQgbmVnYXRpdmUodjogQm9vbGVhbklucHV0KSB7XHJcbiAgICAgICAgdGhpcy5fbmVnYXRpdmUgPSBDb252ZXJ0LnRvQm9vbGVhblByb3BlcnR5KHYpO1xyXG4gICAgfVxyXG5cclxuICAgIHByaXZhdGUgY2hlY2tBbGxvd05lZ2F0aXZlKHZhbHVlOiBzdHJpbmcpIHtcclxuICAgICAgICBpZiAodGhpcy5fZGlnaXRzIDw9IDApIHtcclxuICAgICAgICAgICAgcmV0dXJuIFN0cmluZyh2YWx1ZSkubWF0Y2gobmV3IFJlZ0V4cCgvXi0/XFxkKyQvKSk7XHJcbiAgICAgICAgfSBlbHNlIHtcclxuICAgICAgICAgICAgY29uc3QgcmVnRXhwU3RyaW5nID1cclxuICAgICAgICAgICAgICAgIFwiXi0/XFxcXHMqKChcXFxcZCsoXFxcXC5cXFxcZHswLFwiICtcclxuICAgICAgICAgICAgICAgIHRoaXMuX2RpZ2l0cyArXHJcbiAgICAgICAgICAgICAgICBcIn0pPyl8KChcXFxcZCooXFxcXC5cXFxcZHsxLFwiICtcclxuICAgICAgICAgICAgICAgIHRoaXMuX2RpZ2l0cyArXHJcbiAgICAgICAgICAgICAgICBcIn0pKSkpXFxcXHMqJFwiO1xyXG4gICAgICAgICAgICByZXR1cm4gU3RyaW5nKHZhbHVlKS5tYXRjaChuZXcgUmVnRXhwKHJlZ0V4cFN0cmluZykpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICBwcml2YXRlIGNoZWNrKHZhbHVlOiBzdHJpbmcpIHtcclxuICAgICAgICBpZiAodGhpcy5fZGlnaXRzIDw9IDApIHtcclxuICAgICAgICAgICAgcmV0dXJuIFN0cmluZyh2YWx1ZSkubWF0Y2gobmV3IFJlZ0V4cCgvXlxcZCskLykpO1xyXG4gICAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgICAgIGNvbnN0IHJlZ0V4cFN0cmluZyA9XHJcbiAgICAgICAgICAgICAgICBcIl5cXFxccyooKFxcXFxkKyhcXFxcLlxcXFxkezAsXCIgK1xyXG4gICAgICAgICAgICAgICAgdGhpcy5fZGlnaXRzICtcclxuICAgICAgICAgICAgICAgIFwifSk/KXwoKFxcXFxkKihcXFxcLlxcXFxkezEsXCIgK1xyXG4gICAgICAgICAgICAgICAgdGhpcy5fZGlnaXRzICtcclxuICAgICAgICAgICAgICAgIFwifSkpKSlcXFxccyokXCI7XHJcbiAgICAgICAgICAgIHJldHVybiBTdHJpbmcodmFsdWUpLm1hdGNoKG5ldyBSZWdFeHAocmVnRXhwU3RyaW5nKSk7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG5cclxuICAgIHByaXZhdGUgcnVuKG9sZFZhbHVlOiBhbnkpIHtcclxuICAgICAgICBzZXRUaW1lb3V0KCgpID0+IHtcclxuICAgICAgICAgICAgY29uc3QgY3VycmVudFZhbHVlOiBzdHJpbmcgPSB0aGlzLmVsLm5hdGl2ZUVsZW1lbnQudmFsdWU7XHJcbiAgICAgICAgICAgIGNvbnN0IGFsbG93TmVnYXRpdmUgPSB0aGlzLl9uZWdhdGl2ZTtcclxuXHJcbiAgICAgICAgICAgIGlmIChhbGxvd05lZ2F0aXZlKSB7XHJcbiAgICAgICAgICAgICAgICBpZiAoXHJcbiAgICAgICAgICAgICAgICAgICAgIVtcIlwiLCBcIi1cIl0uaW5jbHVkZXMoY3VycmVudFZhbHVlKSAmJlxyXG4gICAgICAgICAgICAgICAgICAgICF0aGlzLmNoZWNrQWxsb3dOZWdhdGl2ZShjdXJyZW50VmFsdWUpXHJcbiAgICAgICAgICAgICAgICApIHtcclxuICAgICAgICAgICAgICAgICAgICB0aGlzLmVsLm5hdGl2ZUVsZW1lbnQudmFsdWUgPSBvbGRWYWx1ZTtcclxuICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgfSBlbHNlIHtcclxuICAgICAgICAgICAgICAgIGlmIChjdXJyZW50VmFsdWUgIT09ICcnICYmICF0aGlzLmNoZWNrKGN1cnJlbnRWYWx1ZSkpIHtcclxuICAgICAgICAgICAgICAgICAgICB0aGlzLmVsLm5hdGl2ZUVsZW1lbnQudmFsdWUgPSBvbGRWYWx1ZTtcclxuICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgfVxyXG4gICAgICAgIH0pO1xyXG4gICAgfVxyXG5cclxuXHJcbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIGVsOiBFbGVtZW50UmVmKSB7IH1cclxuXHJcbiAgICBASG9zdExpc3RlbmVyKFwia2V5ZG93blwiLCBbXCIkZXZlbnRcIl0pXHJcbiAgICBvbktleURvd24oZXZlbnQ6IEtleWJvYXJkRXZlbnQpIHtcclxuICAgICAgICB0aGlzLnJ1bih0aGlzLmVsLm5hdGl2ZUVsZW1lbnQudmFsdWUpO1xyXG4gICAgfVxyXG5cclxuICAgIEBIb3N0TGlzdGVuZXIoXCJwYXN0ZVwiLCBbXCIkZXZlbnRcIl0pXHJcbiAgICBvblBhc3RlKGV2ZW50OiBDbGlwYm9hcmRFdmVudCkge1xyXG4gICAgICAgIHRoaXMucnVuKHRoaXMuZWwubmF0aXZlRWxlbWVudC52YWx1ZSk7XHJcbiAgICB9XHJcbn0iXX0=
|
|
@@ -49,4 +49,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImpor
|
|
|
49
49
|
}], onPageSizeChange: [{
|
|
50
50
|
type: Output
|
|
51
51
|
}] } });
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
52
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pager.js","sourceRoot":"","sources":["../../../../../../../projects/zek/src/lib/modules/pager/pager/pager.ts","../../../../../../../projects/zek/src/lib/modules/pager/pager/pager.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAEvE,OAAO,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAC;AACxC,OAAO,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAC;AACzC,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;;;;AAStD,MAAM,OAAO,QAAQ;IAPrB;QAQa,UAAK,GAAW,IAAI,KAAK,EAAE,CAAC;QAE7B,kBAAa,GAAG,IAAI,CAAC;QASpB,eAAU,GAAG,OAAO,CAAC;QAkBpB,iBAAY,GAAG,IAAI,YAAY,EAAU,CAAC;QAE1C,qBAAgB,GAAG,IAAI,YAAY,EAAU,CAAC;KAC3D;IA7BG,IACI,YAAY;QACZ,OAAO,IAAI,CAAC,aAAa,CAAC;IAC9B,CAAC;IACD,IAAI,YAAY,CAAC,CAAe;QAC5B,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC;IACtD,CAAC;IAKD,OAAO,CAAC,IAAY;QAChB,2BAA2B;QAE3B,IAAI,IAAI,KAAK,IAAI,CAAC,KAAK,CAAC,UAAU;YAC9B,OAAO;QACX,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACjC,CAAC;IACD,WAAW,CAAC,QAAgB;QACxB,2BAA2B;QAE3B,IAAI,QAAQ,KAAK,IAAI,CAAC,KAAK,CAAC,QAAQ;YAChC,OAAO;QACX,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACzC,CAAC;8GA5BQ,QAAQ;kGAAR,QAAQ,0OCdrB,swHAgDM,+EDpCQ,YAAY,6VAAE,eAAe;;2FAE9B,QAAQ;kBAPpB,SAAS;iCACM,IAAI,YACN,WAAW,WAGZ,CAAC,YAAY,EAAE,eAAe,CAAC;8BAG/B,KAAK;sBAAb,KAAK;gBAIF,YAAY;sBADf,KAAK;gBAQG,UAAU;sBAAlB,KAAK;gBAkBI,YAAY;sBAArB,MAAM;gBAEG,gBAAgB;sBAAzB,MAAM","sourcesContent":["import { Component, Input, Output, EventEmitter } from '@angular/core';\r\nimport { BooleanInput } from '../../../components';\r\nimport { Pager } from '../../../models';\r\nimport { Convert } from '../../../utils';\r\nimport { CommonModule } from '@angular/common';\r\nimport { TranslateModule } from '@ngx-translate/core';\r\n\r\n@Component({\r\n    standalone: true,\r\n    selector: 'zek-pager',\r\n    templateUrl: './pager.html',\r\n    styles: [':host { display: block; }'],\r\n    imports: [CommonModule, TranslateModule],\r\n})\r\nexport class ZekPager {\r\n    @Input() pager : Pager = new Pager();\r\n\r\n    private _showPageSize = true;\r\n    @Input()\r\n    get showPageSize(): boolean {\r\n        return this._showPageSize;\r\n    }\r\n    set showPageSize(v: BooleanInput) {\r\n        this._showPageSize = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n    @Input() pagerAlign = 'start';\r\n\r\n\r\n    setPage(page: number) {\r\n        // if (!this.pager) return;\r\n\r\n        if (page === this.pager.pageNumber)\r\n            return;\r\n        this.onPageChange.emit(page);\r\n    }\r\n    setPageSize(pageSize: number) {\r\n        // if (!this.pager) return;\r\n\r\n        if (pageSize === this.pager.pageSize)\r\n            return;\r\n        this.onPageSizeChange.emit(pageSize);\r\n    }\r\n\r\n    @Output() onPageChange = new EventEmitter<number>();\r\n\r\n    @Output() onPageSizeChange = new EventEmitter<number>();\r\n}","<div *ngIf=\"pager\" class=\"row\">\r\n    <div [ngClass]=\"{ 'col-sm-8': showPageSize, 'col-sm-12': !showPageSize}\">\r\n        <nav aria-label=\"Pagination\">\r\n            <ul class=\"pagination\" [ngClass]=\"{ 'justify-content-center': pagerAlign === 'center', 'justify-content-end': pagerAlign === 'end'}\">\r\n                <li [class.disabled]=\"pager.isFirstPage\" class=\"page-item\">\r\n                    <a class=\"page-link\" (click)=\"setPage(1)\" href=\"javascript:void(0)\" [attr.aria-disabled]=\"pager.isFirstPage ? 'true' : null\" aria-label=\"First\">\r\n                        <span aria-hidden=\"true\">&laquo;&laquo;</span>\r\n                    </a>\r\n                </li>\r\n                <li [class.disabled]=\"!pager.hasPreviousPage\" class=\"page-item\">\r\n                    <a class=\"page-link\" (click)=\"setPage(pager.pageNumber - 1)\" href=\"javascript:void(0)\" [attr.aria-disabled]=\"!pager.hasPreviousPage ? 'true' : null\" aria-label=\"Previous\">\r\n                        <span aria-hidden=\"true\">&laquo;</span>\r\n                    </a>\r\n                </li>\r\n                <li *ngFor=\"let page of pager.pages\" [class.active]=\"page === pager.pageNumber\" class=\"page-item\"><a class=\"page-link\" (click)=\"setPage(page)\" href=\"javascript:void(0)\">{{page}}</a></li>\r\n                <li [class.disabled]=\"!pager.hasNextPage\" class=\"page-item\">\r\n                    <a class=\"page-link\" (click)=\"setPage(pager.pageNumber + 1)\" href=\"javascript:void(0)\" [attr.aria-disabled]=\"!pager.hasNextPage ? 'true' : null\" aria-label=\"Next\">\r\n                        <span aria-hidden=\"true\">&raquo;</span>\r\n                    </a>\r\n                </li>\r\n                <li [class.disabled]=\"pager.isLastPage\" class=\"page-item\">\r\n                    <a class=\"page-link\" (click)=\"setPage(pager.pageCount)\" href=\"javascript:void(0)\" [attr.aria-disabled]=\"pager.isLastPage ? 'true' : null\" aria-label=\"Last\">\r\n                        <span aria-hidden=\"true\">&raquo;&raquo;</span>\r\n                    </a>\r\n                </li>\r\n            </ul>\r\n        </nav>\r\n    </div>\r\n    <div class=\"col-sm-4\" *ngIf=\"showPageSize\">\r\n        <div class=\"float-end\">\r\n            <div class=\"dropdown\">\r\n                <button class=\"btn btn-secondary dropdown-toggle\" type=\"button\" id=\"page-size-button\" data-bs-toggle=\"dropdown\" aria-expanded=\"false\">\r\n                    {{pager.pageSize}}\r\n                </button>\r\n                <ul class=\"dropdown-menu dropdown-menu-end\" aria-labelledby=\"page-size-button\">\r\n                    <li><h6 class=\"dropdown-header\">{{ 'Pagination.PageSize' | translate }}</h6></li>\r\n                    <li><a class=\"dropdown-item\" [class.active]=\"pager.pageSize === 10\" (click)=\"setPageSize(10)\" href=\"javascript:void(0)\">10</a></li>\r\n                    <li><a class=\"dropdown-item\" [class.active]=\"pager.pageSize === 20\" (click)=\"setPageSize(20)\" href=\"javascript:void(0)\">20</a></li>\r\n                    <li><a class=\"dropdown-item\" [class.active]=\"pager.pageSize === 50\" (click)=\"setPageSize(50)\" href=\"javascript:void(0)\">50</a></li>\r\n                    <li><a class=\"dropdown-item\" [class.active]=\"pager.pageSize === 100\" (click)=\"setPageSize(100)\" href=\"javascript:void(0)\">100</a></li>\r\n                    <li><a class=\"dropdown-item\" [class.active]=\"pager.pageSize === 500\" (click)=\"setPageSize(500)\" href=\"javascript:void(0)\">500</a></li>\r\n                </ul>\r\n            </div>\r\n        </div>\r\n        <div class=\"float-end mt-2\">\r\n            {{pager.firstItemOnPage}} - {{pager.lastItemOnPage}} of {{pager.totalItemCount}} &nbsp;\r\n        </div>\r\n    </div>\r\n</div>"]}
|
|
@@ -21,7 +21,7 @@ export class ZekProgress {
|
|
|
21
21
|
return this._value;
|
|
22
22
|
}
|
|
23
23
|
set value(v) {
|
|
24
|
-
|
|
24
|
+
const tmp = clamp(Convert.toNumber(v) || 0);
|
|
25
25
|
if (this._value !== tmp) {
|
|
26
26
|
this._value = tmp;
|
|
27
27
|
}
|
|
@@ -63,7 +63,7 @@ export class ZekProgress {
|
|
|
63
63
|
return this._height;
|
|
64
64
|
}
|
|
65
65
|
set height(v) {
|
|
66
|
-
|
|
66
|
+
const tmp = Convert.toNumber(v) || 0;
|
|
67
67
|
this._height = tmp > 0 ? tmp : null;
|
|
68
68
|
}
|
|
69
69
|
get background() {
|
|
@@ -97,4 +97,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImpor
|
|
|
97
97
|
}], background: [{
|
|
98
98
|
type: Input
|
|
99
99
|
}] } });
|
|
100
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZ3Jlc3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy96ZWsvc3JjL2xpYi9tb2R1bGVzL3Byb2dyZXNzL3Byb2dyZXNzLnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvemVrL3NyYy9saWIvbW9kdWxlcy9wcm9ncmVzcy9wcm9ncmVzcy5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRWpELE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDdEMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDOzs7QUFFL0MsU0FBUyxLQUFLLENBQUMsQ0FBUyxFQUFFLEdBQUcsR0FBRyxDQUFDLEVBQUUsR0FBRyxHQUFHLEdBQUc7SUFDeEMsT0FBTyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQzNDLENBQUM7QUFhRCxNQUFNLE9BQU8sV0FBVztJQVR4QjtRQW9CWSxXQUFNLEdBQVcsQ0FBQyxDQUFDO1FBVW5CLGVBQVUsR0FBRyxLQUFLLENBQUM7UUFTbkIsZUFBVSxHQUFHLElBQUksQ0FBQztRQWNsQixhQUFRLEdBQUcsS0FBSyxDQUFDO1FBVWpCLGNBQVMsR0FBRyxLQUFLLENBQUM7UUFTbEIsV0FBTSxHQUFrQixJQUFJLENBQUM7UUFZN0IsWUFBTyxHQUFrQixJQUFJLENBQUM7UUFVOUIsZ0JBQVcsR0FBZSxTQUFTLENBQUM7S0FDL0M7SUFyRkcsSUFDSSxLQUFLO1FBQ0wsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDO0lBQ3ZCLENBQUM7SUFDRCxJQUFJLEtBQUssQ0FBQyxDQUFjO1FBQ3BCLE1BQU0sR0FBRyxHQUFHLEtBQUssQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO1FBQzVDLElBQUksSUFBSSxDQUFDLE1BQU0sS0FBSyxHQUFHLEVBQUUsQ0FBQztZQUN0QixJQUFJLENBQUMsTUFBTSxHQUFHLEdBQUcsQ0FBQztRQUN0QixDQUFDO0lBQ0wsQ0FBQztJQUlELElBQ0ksU0FBUztRQUNULE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQztJQUMzQixDQUFDO0lBQ0QsSUFBSSxTQUFTLENBQUMsQ0FBZTtRQUN6QixJQUFJLENBQUMsVUFBVSxHQUFHLE9BQU8sQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNuRCxDQUFDO0lBR0QsSUFDSSxTQUFTO1FBQ1QsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDO0lBQzNCLENBQUM7SUFDRCxJQUFJLFNBQVMsQ0FBQyxDQUFlO1FBQ3pCLElBQUksQ0FBQyxVQUFVLEdBQUcsT0FBTyxDQUFDLGlCQUFpQixDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ25ELENBQUM7SUFHRCxJQUFJLE1BQU07UUFDTixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDLE1BQU0sSUFBSSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUM7SUFDdkQsQ0FBQztJQUdELElBQ0ksT0FBTztRQUNQLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQztJQUN6QixDQUFDO0lBQ0QsSUFBSSxPQUFPLENBQUMsQ0FBZTtRQUN2QixJQUFJLENBQUMsUUFBUSxHQUFHLE9BQU8sQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNqRCxDQUFDO0lBSUQsSUFDSSxRQUFRO1FBQ1IsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDO0lBQzFCLENBQUM7SUFDRCxJQUFJLFFBQVEsQ0FBQyxDQUFlO1FBQ3hCLElBQUksQ0FBQyxTQUFTLEdBQUcsT0FBTyxDQUFDLGlCQUFpQixDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ2xELENBQUM7SUFHRCxJQUNJLEtBQUs7UUFDTCxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUM7SUFDdkIsQ0FBQztJQUNELElBQUksS0FBSyxDQUFDLENBQTRCO1FBQ2xDLElBQUksQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQztJQUMvQixDQUFDO0lBS0QsSUFDSSxNQUFNO1FBQ04sT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBQ3hCLENBQUM7SUFDRCxJQUFJLE1BQU0sQ0FBQyxDQUFjO1FBQ3JCLE1BQU0sR0FBRyxHQUFHLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3JDLElBQUksQ0FBQyxPQUFPLEdBQUcsR0FBRyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUM7SUFDeEMsQ0FBQztJQUlELElBQ0ksVUFBVTtRQUNWLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQztJQUM1QixDQUFDO0lBQ0QsSUFBSSxVQUFVLENBQUMsQ0FBYTtRQUN4QixJQUFJLENBQUMsV0FBVyxHQUFHLENBQUMsQ0FBQztJQUN6QixDQUFDOzhHQXBGUSxXQUFXO2tHQUFYLFdBQVcsMFBDcEJ4QiwraEJBV00sK0VETUUsWUFBWTs7MkZBR1AsV0FBVztrQkFUdkIsU0FBUztpQ0FDTSxJQUFJLFlBQ04sY0FBYyxXQUdmO3dCQUNMLFlBQVk7cUJBQ2Y7OEJBSUcsS0FBSztzQkFEUixLQUFLO2dCQWNGLFNBQVM7c0JBRFosS0FBSztnQkFVRixTQUFTO3NCQURaLEtBQUs7Z0JBZUYsT0FBTztzQkFEVixLQUFLO2dCQVdGLFFBQVE7c0JBRFgsS0FBSztnQkFVRixLQUFLO3NCQURSLEtBQUs7Z0JBWUYsTUFBTTtzQkFEVCxLQUFLO2dCQVlGLFVBQVU7c0JBRGIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQm9vbGVhbklucHV0LCBOdW1iZXJJbnB1dCB9IGZyb20gJy4uLy4uL2NvbXBvbmVudHMnO1xyXG5pbXBvcnQgeyBDb252ZXJ0IH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5cclxuZnVuY3Rpb24gY2xhbXAodjogbnVtYmVyLCBtaW4gPSAwLCBtYXggPSAxMDApIHtcclxuICAgIHJldHVybiBNYXRoLm1heChtaW4sIE1hdGgubWluKG1heCwgdikpO1xyXG59XHJcblxyXG50eXBlIEJhY2tncm91bmQgPSAncHJpbWFyeScgfCAnc2Vjb25kYXJ5JyB8ICdzdWNjZXNzJyB8ICdkYW5nZXInIHwgJ3dhcm5pbmcnIHwgJ2luZm8nIHwgJ2xpZ2h0JyB8ICdkYXJrJyB8ICdib2R5JyB8ICd3aGl0ZScgfCAndHJhbnNwYXJlbnQnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gICAgc2VsZWN0b3I6ICd6ZWstcHJvZ3Jlc3MnLFxyXG4gICAgdGVtcGxhdGVVcmw6ICcuL3Byb2dyZXNzLmh0bWwnLFxyXG4gICAgc3R5bGVzOiBbJzpob3N0IHsgZGlzcGxheTogYmxvY2s7IH0nXSxcclxuICAgIGltcG9ydHM6IFtcclxuICAgICAgICBDb21tb25Nb2R1bGVcclxuICAgIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIFpla1Byb2dyZXNzIHtcclxuICAgIEBJbnB1dCgpXHJcbiAgICBnZXQgdmFsdWUoKTogbnVtYmVyIHtcclxuICAgICAgICByZXR1cm4gdGhpcy5fdmFsdWU7XHJcbiAgICB9XHJcbiAgICBzZXQgdmFsdWUodjogTnVtYmVySW5wdXQpIHtcclxuICAgICAgICBjb25zdCB0bXAgPSBjbGFtcChDb252ZXJ0LnRvTnVtYmVyKHYpIHx8IDApO1xyXG4gICAgICAgIGlmICh0aGlzLl92YWx1ZSAhPT0gdG1wKSB7XHJcbiAgICAgICAgICAgIHRoaXMuX3ZhbHVlID0gdG1wO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuICAgIHByaXZhdGUgX3ZhbHVlOiBudW1iZXIgPSAwO1xyXG5cclxuXHJcbiAgICBASW5wdXQoKVxyXG4gICAgZ2V0IHNob3dWYWx1ZSgpOiBib29sZWFuIHtcclxuICAgICAgICByZXR1cm4gdGhpcy5fc2hvd1ZhbHVlO1xyXG4gICAgfVxyXG4gICAgc2V0IHNob3dWYWx1ZSh2OiBCb29sZWFuSW5wdXQpIHtcclxuICAgICAgICB0aGlzLl9zaG93VmFsdWUgPSBDb252ZXJ0LnRvQm9vbGVhblByb3BlcnR5KHYpO1xyXG4gICAgfVxyXG4gICAgcHJpdmF0ZSBfc2hvd1ZhbHVlID0gZmFsc2U7XHJcblxyXG4gICAgQElucHV0KClcclxuICAgIGdldCBzaG93VGl0bGUoKTogYm9vbGVhbiB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuX3Nob3dUaXRsZTtcclxuICAgIH1cclxuICAgIHNldCBzaG93VGl0bGUodjogQm9vbGVhbklucHV0KSB7XHJcbiAgICAgICAgdGhpcy5fc2hvd1RpdGxlID0gQ29udmVydC50b0Jvb2xlYW5Qcm9wZXJ0eSh2KTtcclxuICAgIH1cclxuICAgIHByaXZhdGUgX3Nob3dUaXRsZSA9IHRydWU7XHJcblxyXG4gICAgZ2V0IF90aXRsZSgpIHtcclxuICAgICAgICByZXR1cm4gdGhpcy5fc2hvd1RpdGxlID8gYCR7dGhpcy5fdmFsdWV9ICVgIDogbnVsbDtcclxuICAgIH1cclxuXHJcblxyXG4gICAgQElucHV0KClcclxuICAgIGdldCBzdHJpcGVkKCk6IGJvb2xlYW4ge1xyXG4gICAgICAgIHJldHVybiB0aGlzLl9zdHJpcGVkO1xyXG4gICAgfVxyXG4gICAgc2V0IHN0cmlwZWQodjogQm9vbGVhbklucHV0KSB7XHJcbiAgICAgICAgdGhpcy5fc3RyaXBlZCA9IENvbnZlcnQudG9Cb29sZWFuUHJvcGVydHkodik7XHJcbiAgICB9XHJcbiAgICBwcml2YXRlIF9zdHJpcGVkID0gZmFsc2U7XHJcblxyXG5cclxuICAgIEBJbnB1dCgpXHJcbiAgICBnZXQgYW5pbWF0ZWQoKTogYm9vbGVhbiB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuX2FuaW1hdGVkO1xyXG4gICAgfVxyXG4gICAgc2V0IGFuaW1hdGVkKHY6IEJvb2xlYW5JbnB1dCkge1xyXG4gICAgICAgIHRoaXMuX2FuaW1hdGVkID0gQ29udmVydC50b0Jvb2xlYW5Qcm9wZXJ0eSh2KTtcclxuICAgIH1cclxuICAgIHByaXZhdGUgX2FuaW1hdGVkID0gZmFsc2U7XHJcblxyXG4gICAgQElucHV0KClcclxuICAgIGdldCBsYWJlbCgpIHtcclxuICAgICAgICByZXR1cm4gdGhpcy5fbGFiZWw7XHJcbiAgICB9XHJcbiAgICBzZXQgbGFiZWwodjogc3RyaW5nIHwgbnVsbCB8IHVuZGVmaW5lZCkge1xyXG4gICAgICAgIHRoaXMuX2xhYmVsID0gdiA/IHYgOiBudWxsO1xyXG4gICAgfVxyXG4gICAgcHJpdmF0ZSBfbGFiZWw6IHN0cmluZyB8IG51bGwgPSBudWxsO1xyXG5cclxuXHJcblxyXG4gICAgQElucHV0KClcclxuICAgIGdldCBoZWlnaHQoKSB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuX2hlaWdodDtcclxuICAgIH1cclxuICAgIHNldCBoZWlnaHQodjogTnVtYmVySW5wdXQpIHtcclxuICAgICAgICBjb25zdCB0bXAgPSBDb252ZXJ0LnRvTnVtYmVyKHYpIHx8IDA7XHJcbiAgICAgICAgdGhpcy5faGVpZ2h0ID0gdG1wID4gMCA/IHRtcCA6IG51bGw7XHJcbiAgICB9XHJcbiAgICBwcml2YXRlIF9oZWlnaHQ6IG51bWJlciB8IG51bGwgPSBudWxsO1xyXG5cclxuXHJcbiAgICBASW5wdXQoKVxyXG4gICAgZ2V0IGJhY2tncm91bmQoKSB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuX2JhY2tncm91bmQ7XHJcbiAgICB9XHJcbiAgICBzZXQgYmFja2dyb3VuZCh2OiBCYWNrZ3JvdW5kKSB7XHJcbiAgICAgICAgdGhpcy5fYmFja2dyb3VuZCA9IHY7XHJcbiAgICB9XHJcbiAgICBwcml2YXRlIF9iYWNrZ3JvdW5kOiBCYWNrZ3JvdW5kID0gJ3ByaW1hcnknO1xyXG59IiwiPGRpdiBjbGFzcz1cInByb2dyZXNzXCIgW3N0eWxlLmhlaWdodC5weF09XCJoZWlnaHRcIiBbdGl0bGVdPVwiX3RpdGxlXCIgPlxyXG4gICAgPGRpdiBjbGFzcz1cInByb2dyZXNzLWJhciBiZy17e2JhY2tncm91bmR9fVwiIHJvbGU9XCJwcm9ncmVzc2JhclwiXHJcbiAgICAgICAgW2NsYXNzLnByb2dyZXNzLWJhci1zdHJpcGVkXT1cInN0cmlwZWQgfHwgYW5pbWF0ZWRcIlxyXG4gICAgICAgIFtjbGFzcy5wcm9ncmVzcy1iYXItYW5pbWF0ZWRdPVwiYW5pbWF0ZWRcIlxyXG4gICAgICAgIFtzdHlsZS53aWR0aC4lXT1cInZhbHVlXCJcclxuICAgICAgICBbYXR0ci5hcmlhLXZhbHVlbm93XT1cInZhbHVlXCJcclxuICAgICAgICBhcmlhLXZhbHVlbWluPVwiMFwiXHJcbiAgICAgICAgYXJpYS12YWx1ZW1heD1cIjEwMFwiPlxyXG4gICAgICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCJzaG93VmFsdWVcIj57e3ZhbHVlfX0lPC9uZy1jb250YWluZXI+XHJcbiAgICAgICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxyXG4gICAgPC9kaXY+XHJcbjwvZGl2PiJdfQ==
|
|
@@ -28,7 +28,7 @@ export class ZekRadio extends CoreUiComponent {
|
|
|
28
28
|
return this._inline;
|
|
29
29
|
}
|
|
30
30
|
set inline(v) {
|
|
31
|
-
|
|
31
|
+
const newValue = Convert.toBooleanProperty(v);
|
|
32
32
|
if (this._inline !== newValue) {
|
|
33
33
|
this._inline = newValue;
|
|
34
34
|
this.onInlineChanged();
|
|
@@ -131,4 +131,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImpor
|
|
|
131
131
|
}], checked: [{
|
|
132
132
|
type: Input
|
|
133
133
|
}] } });
|
|
134
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio.js","sourceRoot":"","sources":["../../../../../../projects/zek/src/lib/modules/radio/radio.ts","../../../../../../projects/zek/src/lib/modules/radio/radio.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, forwardRef, Input, OnInit, Renderer2, ViewChild, ViewEncapsulation } from '@angular/core';\r\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { BooleanInput } from '../../components';\r\nimport { CoreUiComponent } from '../../components/core-ui.component';\r\nimport { Convert } from '../../utils';\r\n\r\nlet uniqueId = 0;\r\n\r\n/**\r\n * Provider Expression that allows zek-radio to register as a ControlValueAccessor. This\r\n * allows it to support [(ngModel)] and ngControl.\r\n * @docs-private\r\n */\r\nconst ZEK_RADIO_CONTROL_VALUE_ACCESSOR: any = {\r\n    provide: NG_VALUE_ACCESSOR,\r\n    useExisting: forwardRef(() => ZekRadio),\r\n    multi: true,\r\n};\r\n\r\n\r\n@Component({\r\n    standalone: true,\r\n    selector: 'zek-radio',\r\n    templateUrl: './radio.html',\r\n    host: {\r\n        '[attr.id]': 'id',\r\n        '[attr.tabindex]': 'null',\r\n        '[attr.aria-label]': 'null',\r\n        '[attr.aria-labelledby]': 'null',\r\n        '[attr.aria-describedby]': 'null',\r\n        // Note: under normal conditions focus shouldn't land on this element, however it may be\r\n        // programmatically set, for example inside of a focus trap, in this case we want to forward\r\n        // the focus to the native element.\r\n        '(focus)': '_inputElement.nativeElement.focus()',\r\n\r\n    },\r\n    encapsulation: ViewEncapsulation.None,\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [ZEK_RADIO_CONTROL_VALUE_ACCESSOR],\r\n})\r\nexport class ZekRadio extends CoreUiComponent\r\n    implements OnInit {\r\n    constructor(\r\n        private _changeDetector: ChangeDetectorRef,\r\n        _renderer: Renderer2,\r\n        _elementRef: ElementRef) {\r\n        super(_renderer, _elementRef);\r\n    }\r\n\r\n\r\n    private _uniqueId: string = `zek-radio-${++uniqueId}`;\r\n\r\n    /** The unique ID for the radio button. */\r\n    @Input() id: string = this._uniqueId;\r\n\r\n    /** Used to set the 'aria-label' attribute on the underlying input element. */\r\n    @Input('aria-label') ariaLabel?: string | null;\r\n\r\n    /** The 'aria-labelledby' attribute takes precedence as the element's text alternative. */\r\n    @Input('aria-labelledby') ariaLabelledby?: string | null;\r\n\r\n    /** The 'aria-describedby' attribute is read after the element's label and field type. */\r\n    @Input('aria-describedby') ariaDescribedby?: string | null;\r\n\r\n    /** The native `<input type=radio>` element */\r\n    @ViewChild('input') _inputElement?: ElementRef<HTMLInputElement> | null;\r\n\r\n\r\n\r\n    private _inline = false;\r\n    get inline() {\r\n        return this._inline;\r\n    }\r\n    @Input()\r\n    set inline(v: BooleanInput) {\r\n        let newValue = Convert.toBooleanProperty(v);\r\n        if (this._inline !== newValue) {\r\n            this._inline = newValue;\r\n            this.onInlineChanged();\r\n        }\r\n    }\r\n    onInlineChanged() { }\r\n\r\n    get inputId(): string {\r\n        return `${this.id || this._uniqueId}-input`;\r\n    }\r\n\r\n\r\n    /** The value from ngModel. */\r\n    private modelValue: any;\r\n\r\n\r\n    private _checked = false;\r\n    @Input()\r\n    get checked(): boolean {\r\n        return this._checked;\r\n    }\r\n    set checked(value: BooleanInput) {\r\n        const newCheckedState = Convert.toBooleanProperty(value);\r\n        if (this._checked !== newCheckedState) {\r\n            this._checked = newCheckedState;\r\n            this._markForCheck();\r\n        }\r\n    }\r\n\r\n\r\n    override writeValue(value: any): void {\r\n        if (this.modelValue !== value) {\r\n            this.modelValue = value;\r\n            this.checked = this.modelValue === this._value;\r\n        }\r\n\r\n    }\r\n    override onValueChanged() {\r\n        if (!this.checked) {\r\n            // Update checked when the value changed to match the radio group's value\r\n            this.checked = this.modelValue === this._value;\r\n        }\r\n    }\r\n\r\n\r\n    override onRequiredChanged(): void {\r\n        this._markForCheck();\r\n    }\r\n    override onDisabledChanged() {\r\n        this._markForCheck();\r\n    }\r\n\r\n\r\n    /**\r\n     * Marks the radio button as needing checking for change detection.\r\n     * This method is exposed because the parent radio group will directly\r\n     * update bound properties of the radio button.\r\n     */\r\n    private _markForCheck() {\r\n        // When group value changes, the button will not be notified. Use `markForCheck` to explicit\r\n        // update radio button's status\r\n        this._changeDetector.markForCheck();\r\n    }\r\n\r\n\r\n    override init(): void {\r\n        // Determine if it should be checked\r\n        this.checked = this.modelValue === this._value;\r\n    }\r\n\r\n\r\n    /** Triggered when the radio button receives an interaction from the user. */\r\n    override _onInputInteraction(event: Event) {\r\n        // We always have to stop propagation on the change event.\r\n        // Otherwise the change event, from the input element, will bubble up and\r\n        // emit its event object to the `change` output.\r\n        event.stopPropagation();\r\n\r\n        if (!this.checked && !this.disabled) {\r\n            const modelValueChanged = this.value !== this.modelValue;\r\n            this.checked = true;\r\n            this.modelValue = this._value;\r\n            this._emitChangeEvent();\r\n\r\n            if (modelValueChanged) {\r\n                this._onChange(this._value);\r\n            }\r\n        }\r\n    }\r\n}","<div class=\"form-check\" [class.form-check-inline]=\"inline\">\r\n    <input #input class=\"form-check-input\" type=\"radio\"\r\n    [id]=\"inputId\"\r\n    [checked]=\"checked\"\r\n    [disabled]=\"disabled\"\r\n    [attr.name]=\"name\"\r\n    [attr.value]=\"value\"\r\n    [required]=\"required\"\r\n    [attr.aria-label]=\"ariaLabel\"\r\n    [attr.aria-labelledby]=\"ariaLabelledby\"\r\n    [attr.aria-describedby]=\"ariaDescribedby\"\r\n    (change)=\"_onInputInteraction($event)\">\r\n    <label [for]=\"inputId\">\r\n        <ng-content></ng-content>\r\n    </label>\r\n</div>"]}
|
|
134
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio.js","sourceRoot":"","sources":["../../../../../../projects/zek/src/lib/modules/radio/radio.ts","../../../../../../projects/zek/src/lib/modules/radio/radio.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, forwardRef, Input, OnInit, Renderer2, ViewChild, ViewEncapsulation } from '@angular/core';\r\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { BooleanInput } from '../../components';\r\nimport { CoreUiComponent } from '../../components/core-ui.component';\r\nimport { Convert } from '../../utils';\r\n\r\nlet uniqueId = 0;\r\n\r\n/**\r\n * Provider Expression that allows zek-radio to register as a ControlValueAccessor. This\r\n * allows it to support [(ngModel)] and ngControl.\r\n * @docs-private\r\n */\r\nconst ZEK_RADIO_CONTROL_VALUE_ACCESSOR: any = {\r\n    provide: NG_VALUE_ACCESSOR,\r\n    useExisting: forwardRef(() => ZekRadio),\r\n    multi: true,\r\n};\r\n\r\n\r\n@Component({\r\n    standalone: true,\r\n    selector: 'zek-radio',\r\n    templateUrl: './radio.html',\r\n    host: {\r\n        '[attr.id]': 'id',\r\n        '[attr.tabindex]': 'null',\r\n        '[attr.aria-label]': 'null',\r\n        '[attr.aria-labelledby]': 'null',\r\n        '[attr.aria-describedby]': 'null',\r\n        // Note: under normal conditions focus shouldn't land on this element, however it may be\r\n        // programmatically set, for example inside of a focus trap, in this case we want to forward\r\n        // the focus to the native element.\r\n        '(focus)': '_inputElement.nativeElement.focus()',\r\n\r\n    },\r\n    encapsulation: ViewEncapsulation.None,\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [ZEK_RADIO_CONTROL_VALUE_ACCESSOR],\r\n})\r\nexport class ZekRadio extends CoreUiComponent\r\n    implements OnInit {\r\n    constructor(\r\n        private _changeDetector: ChangeDetectorRef,\r\n        _renderer: Renderer2,\r\n        _elementRef: ElementRef) {\r\n        super(_renderer, _elementRef);\r\n    }\r\n\r\n\r\n    private _uniqueId: string = `zek-radio-${++uniqueId}`;\r\n\r\n    /** The unique ID for the radio button. */\r\n    @Input() id: string = this._uniqueId;\r\n\r\n    /** Used to set the 'aria-label' attribute on the underlying input element. */\r\n    @Input('aria-label') ariaLabel?: string | null;\r\n\r\n    /** The 'aria-labelledby' attribute takes precedence as the element's text alternative. */\r\n    @Input('aria-labelledby') ariaLabelledby?: string | null;\r\n\r\n    /** The 'aria-describedby' attribute is read after the element's label and field type. */\r\n    @Input('aria-describedby') ariaDescribedby?: string | null;\r\n\r\n    /** The native `<input type=radio>` element */\r\n    @ViewChild('input') _inputElement?: ElementRef<HTMLInputElement> | null;\r\n\r\n\r\n\r\n    private _inline = false;\r\n    get inline() {\r\n        return this._inline;\r\n    }\r\n    @Input()\r\n    set inline(v: BooleanInput) {\r\n        const newValue = Convert.toBooleanProperty(v);\r\n        if (this._inline !== newValue) {\r\n            this._inline = newValue;\r\n            this.onInlineChanged();\r\n        }\r\n    }\r\n    onInlineChanged() { }\r\n\r\n    get inputId(): string {\r\n        return `${this.id || this._uniqueId}-input`;\r\n    }\r\n\r\n\r\n    /** The value from ngModel. */\r\n    private modelValue: any;\r\n\r\n\r\n    private _checked = false;\r\n    @Input()\r\n    get checked(): boolean {\r\n        return this._checked;\r\n    }\r\n    set checked(value: BooleanInput) {\r\n        const newCheckedState = Convert.toBooleanProperty(value);\r\n        if (this._checked !== newCheckedState) {\r\n            this._checked = newCheckedState;\r\n            this._markForCheck();\r\n        }\r\n    }\r\n\r\n\r\n    override writeValue(value: any): void {\r\n        if (this.modelValue !== value) {\r\n            this.modelValue = value;\r\n            this.checked = this.modelValue === this._value;\r\n        }\r\n\r\n    }\r\n    override onValueChanged() {\r\n        if (!this.checked) {\r\n            // Update checked when the value changed to match the radio group's value\r\n            this.checked = this.modelValue === this._value;\r\n        }\r\n    }\r\n\r\n\r\n    override onRequiredChanged(): void {\r\n        this._markForCheck();\r\n    }\r\n    override onDisabledChanged() {\r\n        this._markForCheck();\r\n    }\r\n\r\n\r\n    /**\r\n     * Marks the radio button as needing checking for change detection.\r\n     * This method is exposed because the parent radio group will directly\r\n     * update bound properties of the radio button.\r\n     */\r\n    private _markForCheck() {\r\n        // When group value changes, the button will not be notified. Use `markForCheck` to explicit\r\n        // update radio button's status\r\n        this._changeDetector.markForCheck();\r\n    }\r\n\r\n\r\n    override init(): void {\r\n        // Determine if it should be checked\r\n        this.checked = this.modelValue === this._value;\r\n    }\r\n\r\n\r\n    /** Triggered when the radio button receives an interaction from the user. */\r\n    override _onInputInteraction(event: Event) {\r\n        // We always have to stop propagation on the change event.\r\n        // Otherwise the change event, from the input element, will bubble up and\r\n        // emit its event object to the `change` output.\r\n        event.stopPropagation();\r\n\r\n        if (!this.checked && !this.disabled) {\r\n            const modelValueChanged = this.value !== this.modelValue;\r\n            this.checked = true;\r\n            this.modelValue = this._value;\r\n            this._emitChangeEvent();\r\n\r\n            if (modelValueChanged) {\r\n                this._onChange(this._value);\r\n            }\r\n        }\r\n    }\r\n}","<div class=\"form-check\" [class.form-check-inline]=\"inline\">\r\n    <input #input class=\"form-check-input\" type=\"radio\"\r\n    [id]=\"inputId\"\r\n    [checked]=\"checked\"\r\n    [disabled]=\"disabled\"\r\n    [attr.name]=\"name\"\r\n    [attr.value]=\"value\"\r\n    [required]=\"required\"\r\n    [attr.aria-label]=\"ariaLabel\"\r\n    [attr.aria-labelledby]=\"ariaLabelledby\"\r\n    [attr.aria-describedby]=\"ariaDescribedby\"\r\n    (change)=\"_onInputInteraction($event)\">\r\n    <label [for]=\"inputId\">\r\n        <ng-content></ng-content>\r\n    </label>\r\n</div>"]}
|
|
@@ -5,9 +5,9 @@ urlParams, url, nonce) {
|
|
|
5
5
|
onLoaded(grecaptcha);
|
|
6
6
|
};
|
|
7
7
|
const baseUrl = url || "https://www.google.com/recaptcha/api.js";
|
|
8
|
-
|
|
9
|
-
|
|
8
|
+
const params = urlParams || '';
|
|
9
|
+
const src = `${baseUrl}?render=${siteKey}&onload=recaptchaloaded${params}`;
|
|
10
10
|
HtmlHelper.loadScript(src, nonce, true, true);
|
|
11
11
|
}
|
|
12
12
|
export const loader = { loadScript };
|
|
13
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
13
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvemVrL3NyYy9saWIvbW9kdWxlcy9yZWNhcHRjaGEvbG9hZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFZekMsU0FBUyxVQUFVLENBQ2YsT0FBNEIsRUFDNUIsUUFBcUQsRUFBQyx1QkFBdUI7QUFDN0UsU0FBa0IsRUFDbEIsR0FBWSxFQUNaLEtBQWM7SUFFZCxNQUFNLENBQUMsZUFBZSxHQUFHLEdBQUcsRUFBRTtRQUMxQixRQUFRLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDekIsQ0FBQyxDQUFDO0lBRUYsTUFBTSxPQUFPLEdBQUcsR0FBRyxJQUFJLHlDQUF5QyxDQUFDO0lBQ2pFLE1BQU0sTUFBTSxHQUFHLFNBQVMsSUFBSSxFQUFFLENBQUM7SUFDL0IsTUFBTSxHQUFHLEdBQUcsR0FBRyxPQUFPLFdBQVcsT0FBTywwQkFBMEIsTUFBTSxFQUFFLENBQUM7SUFFM0UsVUFBVSxDQUFDLFVBQVUsQ0FBQyxHQUFHLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQztBQUNsRCxDQUFDO0FBRUQsTUFBTSxDQUFDLE1BQU0sTUFBTSxHQUFHLEVBQUUsVUFBVSxFQUFFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIdG1sSGVscGVyIH0gZnJvbSBcIi4uLy4uL3V0aWxzXCI7XHJcbmltcG9ydCB7IFJlQ2FwdGNoYVYyIH0gZnJvbSBcIi4vcmVjYXB0Y2hhLm1vZGVsXCI7XHJcblxyXG5kZWNsYXJlIHZhciBncmVjYXB0Y2hhOiBSZUNhcHRjaGFWMi5SZUNhcHRjaGEgJiB7XHJcbiAgICBlbnRlcnByaXNlOiBSZUNhcHRjaGFWMi5SZUNhcHRjaGE7XHJcbn07XHJcblxyXG5kZWNsYXJlIGdsb2JhbCB7XHJcbiAgICBpbnRlcmZhY2UgV2luZG93IHtcclxuICAgICAgICByZWNhcHRjaGFsb2FkZWQ6ICgpID0+IHZvaWQ7XHJcbiAgICB9XHJcbn1cclxuZnVuY3Rpb24gbG9hZFNjcmlwdChcclxuICAgIHNpdGVLZXk6IFwiZXhwbGljaXRcIiB8IHN0cmluZyxcclxuICAgIG9uTG9hZGVkOiAoZ3JlY2FwdGNoYTogUmVDYXB0Y2hhVjIuUmVDYXB0Y2hhKSA9PiB2b2lkLC8vUmVDYXB0Y2hhVjIuUmVDYXB0Y2hhXHJcbiAgICB1cmxQYXJhbXM/OiBzdHJpbmcsXHJcbiAgICB1cmw/OiBzdHJpbmcsXHJcbiAgICBub25jZT86IHN0cmluZ1xyXG4pOiB2b2lkIHtcclxuICAgIHdpbmRvdy5yZWNhcHRjaGFsb2FkZWQgPSAoKSA9PiB7XHJcbiAgICAgICAgb25Mb2FkZWQoZ3JlY2FwdGNoYSk7XHJcbiAgICB9O1xyXG5cclxuICAgIGNvbnN0IGJhc2VVcmwgPSB1cmwgfHwgXCJodHRwczovL3d3dy5nb29nbGUuY29tL3JlY2FwdGNoYS9hcGkuanNcIjtcclxuICAgIGNvbnN0IHBhcmFtcyA9IHVybFBhcmFtcyB8fCAnJztcclxuICAgIGNvbnN0IHNyYyA9IGAke2Jhc2VVcmx9P3JlbmRlcj0ke3NpdGVLZXl9Jm9ubG9hZD1yZWNhcHRjaGFsb2FkZWQke3BhcmFtc31gO1xyXG5cclxuICAgIEh0bWxIZWxwZXIubG9hZFNjcmlwdChzcmMsIG5vbmNlLCB0cnVlLCB0cnVlKTtcclxufVxyXG5cclxuZXhwb3J0IGNvbnN0IGxvYWRlciA9IHsgbG9hZFNjcmlwdCB9OyJdfQ==
|
|
@@ -102,13 +102,13 @@ export class ZekSelectMultiple extends CoreUiComponent {
|
|
|
102
102
|
let notUnique = [];
|
|
103
103
|
if (this.valueField) {
|
|
104
104
|
for (const currentValue of value) {
|
|
105
|
-
|
|
105
|
+
const items = ArrayHelper.filterByKey(currentValue, this.valueField, this._data);
|
|
106
106
|
notUnique = notUnique.concat(items);
|
|
107
107
|
}
|
|
108
108
|
}
|
|
109
109
|
else {
|
|
110
110
|
for (const currentValue of value) {
|
|
111
|
-
|
|
111
|
+
const items = this._data.filter(x => x === currentValue);
|
|
112
112
|
notUnique = notUnique.concat(items);
|
|
113
113
|
}
|
|
114
114
|
}
|
|
@@ -135,7 +135,7 @@ export class ZekSelectMultiple extends CoreUiComponent {
|
|
|
135
135
|
if (!v.checked) {
|
|
136
136
|
v.checked = true;
|
|
137
137
|
if (this.multiple) {
|
|
138
|
-
|
|
138
|
+
const tmp = [];
|
|
139
139
|
for (const item of this.normalized) {
|
|
140
140
|
if (item.checked) {
|
|
141
141
|
tmp.push(item.key);
|
|
@@ -163,7 +163,7 @@ export class ZekSelectMultiple extends CoreUiComponent {
|
|
|
163
163
|
}
|
|
164
164
|
}
|
|
165
165
|
_initText() {
|
|
166
|
-
|
|
166
|
+
const field = this.checkedTextField || this.textField || '';
|
|
167
167
|
if (field) {
|
|
168
168
|
this._text = this._selected.filter(x => x !== undefined && x !== null).map(x => x[field]).join(', ');
|
|
169
169
|
}
|
|
@@ -199,4 +199,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImpor
|
|
|
199
199
|
}], data: [{
|
|
200
200
|
type: Input
|
|
201
201
|
}] } });
|
|
202
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.js","sourceRoot":"","sources":["../../../../../../projects/zek/src/lib/modules/select/select.ts","../../../../../../projects/zek/src/lib/modules/select/select.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, forwardRef, Input, Renderer2 } from '@angular/core';\r\nimport { FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { BooleanInput, CoreUiComponent } from '../../components';\r\nimport { ArrayHelper, Convert } from '../../utils';\r\nimport { KeyPairOption } from './model';\r\nimport { CommonModule } from '@angular/common';\r\n\r\n\r\nlet uniqueId = 0;\r\n\r\n\r\nconst ZEK_SELECT_MULTIPLE_CONTROL_VALUE_ACCESSOR: any = {\r\n    provide: NG_VALUE_ACCESSOR,\r\n    useExisting: forwardRef(() => ZekSelectMultiple),\r\n    multi: true,\r\n};\r\n\r\n@Component({\r\n    standalone: true,\r\n    selector: 'zek-select,[zek-select]',\r\n    templateUrl: './select.html',\r\n    providers: [ZEK_SELECT_MULTIPLE_CONTROL_VALUE_ACCESSOR],\r\n    imports: [\r\n        CommonModule,\r\n        FormsModule\r\n    ],\r\n})\r\n\r\nexport class ZekSelectMultiple extends CoreUiComponent {\r\n    constructor(renderer: Renderer2, elementRef: ElementRef) {\r\n        super(renderer, elementRef);\r\n    }\r\n\r\n    private _uniqueId: string = `zek-select-${++uniqueId}`;\r\n    /** The unique ID for the radio button. */\r\n    @Input() id: string = this._uniqueId;\r\n\r\n    @Input() valueField?: string | null;\r\n    @Input() textField?: string | null;\r\n    @Input() checkedTextField?: string | null;\r\n\r\n    @Input() css: 'primary' | 'secondary' | 'success' | 'danger ' | 'warning' | 'info' | 'light' | 'dark' = 'primary';\r\n\r\n\r\n    @Input()\r\n    get placeholder(): string {\r\n        return this._placeholder;\r\n    }\r\n    set placeholder(value: string | null | undefined) {\r\n        if (value)\r\n            this._placeholder = value;\r\n        else\r\n            this._placeholder = '';\r\n    }\r\n    private _placeholder = '';\r\n\r\n    @Input()\r\n    get label(): string {\r\n        return this._label;\r\n    }\r\n    set label(value: string | null | undefined) {\r\n        if (value)\r\n            this._label = value;\r\n        else\r\n            this._label = '';\r\n    }\r\n    private _label = '';\r\n\r\n\r\n\r\n    @Input()\r\n    get multiple() {\r\n        return this._multiple;\r\n    }\r\n    set multiple(value: BooleanInput) {\r\n        this._multiple = Convert.toBooleanProperty(value);\r\n    }\r\n    private _multiple = true;\r\n\r\n\r\n    private _selected: any[] = [];\r\n\r\n    @Input()\r\n    get data() {\r\n        return this._data;\r\n    }\r\n    set data(value: any[] | null | undefined) {\r\n        if (this._data !== value) {\r\n            this._data = value;\r\n            this.onDataChanged();\r\n        }\r\n    }\r\n    private _data?: any[] | null = [];\r\n    normalized: KeyPairOption[] = [];\r\n    onDataChanged() {\r\n        this._setSelectionByValue(this._value);\r\n        if (this.isInitialized) {\r\n            this._normalizeData();\r\n        }\r\n    }\r\n\r\n    _text = '';\r\n\r\n\r\n\r\n    override onValueChanged() {\r\n        if (Array.isArray(this._data)) {\r\n            this._setSelectionByValue(this._value);\r\n        }\r\n    }\r\n\r\n\r\n    override init(): void {\r\n        this._normalizeData();\r\n    }\r\n\r\n\r\n    private _normalizeData() {\r\n        this.normalized = [];\r\n        if (Array.isArray(this._data)) {\r\n            if (this.valueField && this.textField) {\r\n                for (const item of this._data) {\r\n                    this.normalized.push({ key: item[this.valueField], value: item[this.textField], checked: this._selected.includes(item), item: item });\r\n                }\r\n            } else {\r\n                for (const item of this._data) {\r\n                    this.normalized.push({ key: item, value: item, checked: this._selected.includes(item), item });\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Sets the selected option based on a value. If no option can be\r\n     * found with the designated value, the select trigger is cleared.\r\n     */\r\n    private _setSelectionByValue(value: any | any[]): void {\r\n        this._selected = [];\r\n\r\n        if (this.multiple && value) {\r\n            if (!Array.isArray(value)) {\r\n                throw new Error(\"value is not array\");\r\n            }\r\n\r\n            if (Array.isArray(this._data)) {\r\n                let notUnique: any[] = [];\r\n                if (this.valueField) {\r\n                    for (const currentValue of value) {\r\n                        let items = ArrayHelper.filterByKey(currentValue, this.valueField, this._data);\r\n                        notUnique = notUnique.concat(items);\r\n                    }\r\n                } else {\r\n                    for (const currentValue of value) {\r\n                        let items = this._data.filter(x => x === currentValue);\r\n                        notUnique = notUnique.concat(items);\r\n                    }\r\n                }\r\n\r\n                this._selected = ArrayHelper.distinct(notUnique);\r\n            }\r\n        } else {\r\n            if (Array.isArray(this._data)) {\r\n                if (this.valueField) {\r\n                    this._selected = ArrayHelper.filterByKey(value, this.valueField, this._data);\r\n                } else {\r\n                    this._selected = this._data.filter(x => x === value);\r\n                }\r\n            }\r\n        }\r\n\r\n        for (const norm of this.normalized) {\r\n            norm.checked = this._selected.includes(norm.item);\r\n        }\r\n        this._initText();\r\n    }\r\n\r\n\r\n\r\n\r\n    toggleChecked(v: any) {\r\n        if (v && !this.disabled && !this.readonly) {\r\n            if (!v.checked) {\r\n                v.checked = true;\r\n\r\n                if (this.multiple) {\r\n                    let tmp = [];\r\n                    for (const item of this.normalized) {\r\n                        if (item.checked) {\r\n                            tmp.push(item.key);\r\n                        }\r\n                    }\r\n\r\n                    this.setNgModel(tmp);\r\n                    // this.value = tmp;\r\n                }\r\n                else {\r\n                    //this.value = v.key;\r\n                    this.setNgModel(v.key);\r\n                }\r\n            } else {\r\n                v.checked = false;\r\n                if (this.multiple) {\r\n                    if (Array.isArray(this._value)) {\r\n                        this.setNgModel((this._value as any[]).filter(x => x !== v.key));\r\n                    }\r\n                } else {\r\n                    this.setNgModel(null);\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n\r\n    private _initText() {\r\n        let field = this.checkedTextField || this.textField || '';\r\n        if (field) {\r\n            this._text = this._selected.filter(x => x !== undefined && x !== null).map(x => x[field]).join(', ');\r\n        } else {\r\n            this._text = this._selected.join(', ');\r\n        }\r\n    }\r\n}\r\n","<div class=\"dropdown\" id=\"dropdown-{{id}}\">\r\n    <button class=\"btn btn-{{css}} dropdown-toggle\" type=\"button\" data-bs-toggle=\"dropdown\" aria-expanded=\"false\">\r\n        {{label}} <ng-container *ngIf=\"!_text\">{{placeholder}}</ng-container> {{_text}}\r\n    </button>\r\n    <ul class=\"dropdown-menu\">\r\n        <ng-container *ngIf=\"normalized\">\r\n            <li><a class=\"dropdown-item\" href=\"javascript:void(0)\" *ngFor=\"let item of normalized\" (click)=\"toggleChecked(item)\">\r\n                    <span *ngIf=\"item.checked\"><i class=\"fa-regular fa-square-check\"></i></span>\r\n                    <span *ngIf=\"!item.checked\"><i class=\"fa-regular fa-square\"></i></span>\r\n                    {{item.value}}\r\n                </a></li>\r\n        </ng-container>\r\n    </ul>\r\n</div>"]}
|
|
202
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.js","sourceRoot":"","sources":["../../../../../../projects/zek/src/lib/modules/select/select.ts","../../../../../../projects/zek/src/lib/modules/select/select.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, forwardRef, Input, Renderer2 } from '@angular/core';\r\nimport { FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { BooleanInput, CoreUiComponent } from '../../components';\r\nimport { ArrayHelper, Convert } from '../../utils';\r\nimport { KeyPairOption } from './model';\r\nimport { CommonModule } from '@angular/common';\r\n\r\n\r\nlet uniqueId = 0;\r\n\r\n\r\nconst ZEK_SELECT_MULTIPLE_CONTROL_VALUE_ACCESSOR: any = {\r\n    provide: NG_VALUE_ACCESSOR,\r\n    useExisting: forwardRef(() => ZekSelectMultiple),\r\n    multi: true,\r\n};\r\n\r\n@Component({\r\n    standalone: true,\r\n    selector: 'zek-select,[zek-select]',\r\n    templateUrl: './select.html',\r\n    providers: [ZEK_SELECT_MULTIPLE_CONTROL_VALUE_ACCESSOR],\r\n    imports: [\r\n        CommonModule,\r\n        FormsModule\r\n    ],\r\n})\r\n\r\nexport class ZekSelectMultiple extends CoreUiComponent {\r\n    constructor(renderer: Renderer2, elementRef: ElementRef) {\r\n        super(renderer, elementRef);\r\n    }\r\n\r\n    private _uniqueId: string = `zek-select-${++uniqueId}`;\r\n    /** The unique ID for the radio button. */\r\n    @Input() id: string = this._uniqueId;\r\n\r\n    @Input() valueField?: string | null;\r\n    @Input() textField?: string | null;\r\n    @Input() checkedTextField?: string | null;\r\n\r\n    @Input() css: 'primary' | 'secondary' | 'success' | 'danger ' | 'warning' | 'info' | 'light' | 'dark' = 'primary';\r\n\r\n\r\n    @Input()\r\n    get placeholder(): string {\r\n        return this._placeholder;\r\n    }\r\n    set placeholder(value: string | null | undefined) {\r\n        if (value)\r\n            this._placeholder = value;\r\n        else\r\n            this._placeholder = '';\r\n    }\r\n    private _placeholder = '';\r\n\r\n    @Input()\r\n    get label(): string {\r\n        return this._label;\r\n    }\r\n    set label(value: string | null | undefined) {\r\n        if (value)\r\n            this._label = value;\r\n        else\r\n            this._label = '';\r\n    }\r\n    private _label = '';\r\n\r\n\r\n\r\n    @Input()\r\n    get multiple() {\r\n        return this._multiple;\r\n    }\r\n    set multiple(value: BooleanInput) {\r\n        this._multiple = Convert.toBooleanProperty(value);\r\n    }\r\n    private _multiple = true;\r\n\r\n\r\n    private _selected: any[] = [];\r\n\r\n    @Input()\r\n    get data() {\r\n        return this._data;\r\n    }\r\n    set data(value: any[] | null | undefined) {\r\n        if (this._data !== value) {\r\n            this._data = value;\r\n            this.onDataChanged();\r\n        }\r\n    }\r\n    private _data?: any[] | null = [];\r\n    normalized: KeyPairOption[] = [];\r\n    onDataChanged() {\r\n        this._setSelectionByValue(this._value);\r\n        if (this.isInitialized) {\r\n            this._normalizeData();\r\n        }\r\n    }\r\n\r\n    _text = '';\r\n\r\n\r\n\r\n    override onValueChanged() {\r\n        if (Array.isArray(this._data)) {\r\n            this._setSelectionByValue(this._value);\r\n        }\r\n    }\r\n\r\n\r\n    override init(): void {\r\n        this._normalizeData();\r\n    }\r\n\r\n\r\n    private _normalizeData() {\r\n        this.normalized = [];\r\n        if (Array.isArray(this._data)) {\r\n            if (this.valueField && this.textField) {\r\n                for (const item of this._data) {\r\n                    this.normalized.push({ key: item[this.valueField], value: item[this.textField], checked: this._selected.includes(item), item: item });\r\n                }\r\n            } else {\r\n                for (const item of this._data) {\r\n                    this.normalized.push({ key: item, value: item, checked: this._selected.includes(item), item });\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Sets the selected option based on a value. If no option can be\r\n     * found with the designated value, the select trigger is cleared.\r\n     */\r\n    private _setSelectionByValue(value: any | any[]): void {\r\n        this._selected = [];\r\n\r\n        if (this.multiple && value) {\r\n            if (!Array.isArray(value)) {\r\n                throw new Error(\"value is not array\");\r\n            }\r\n\r\n            if (Array.isArray(this._data)) {\r\n                let notUnique: any[] = [];\r\n                if (this.valueField) {\r\n                    for (const currentValue of value) {\r\n                        const items = ArrayHelper.filterByKey(currentValue, this.valueField, this._data);\r\n                        notUnique = notUnique.concat(items);\r\n                    }\r\n                } else {\r\n                    for (const currentValue of value) {\r\n                        const items = this._data.filter(x => x === currentValue);\r\n                        notUnique = notUnique.concat(items);\r\n                    }\r\n                }\r\n\r\n                this._selected = ArrayHelper.distinct(notUnique);\r\n            }\r\n        } else {\r\n            if (Array.isArray(this._data)) {\r\n                if (this.valueField) {\r\n                    this._selected = ArrayHelper.filterByKey(value, this.valueField, this._data);\r\n                } else {\r\n                    this._selected = this._data.filter(x => x === value);\r\n                }\r\n            }\r\n        }\r\n\r\n        for (const norm of this.normalized) {\r\n            norm.checked = this._selected.includes(norm.item);\r\n        }\r\n        this._initText();\r\n    }\r\n\r\n\r\n\r\n\r\n    toggleChecked(v: any) {\r\n        if (v && !this.disabled && !this.readonly) {\r\n            if (!v.checked) {\r\n                v.checked = true;\r\n\r\n                if (this.multiple) {\r\n                    const tmp = [];\r\n                    for (const item of this.normalized) {\r\n                        if (item.checked) {\r\n                            tmp.push(item.key);\r\n                        }\r\n                    }\r\n\r\n                    this.setNgModel(tmp);\r\n                    // this.value = tmp;\r\n                }\r\n                else {\r\n                    //this.value = v.key;\r\n                    this.setNgModel(v.key);\r\n                }\r\n            } else {\r\n                v.checked = false;\r\n                if (this.multiple) {\r\n                    if (Array.isArray(this._value)) {\r\n                        this.setNgModel((this._value as any[]).filter(x => x !== v.key));\r\n                    }\r\n                } else {\r\n                    this.setNgModel(null);\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n\r\n    private _initText() {\r\n        const field = this.checkedTextField || this.textField || '';\r\n        if (field) {\r\n            this._text = this._selected.filter(x => x !== undefined && x !== null).map(x => x[field]).join(', ');\r\n        } else {\r\n            this._text = this._selected.join(', ');\r\n        }\r\n    }\r\n}\r\n","<div class=\"dropdown\" id=\"dropdown-{{id}}\">\r\n    <button class=\"btn btn-{{css}} dropdown-toggle\" type=\"button\" data-bs-toggle=\"dropdown\" aria-expanded=\"false\">\r\n        {{label}} <ng-container *ngIf=\"!_text\">{{placeholder}}</ng-container> {{_text}}\r\n    </button>\r\n    <ul class=\"dropdown-menu\">\r\n        <ng-container *ngIf=\"normalized\">\r\n            <li><a class=\"dropdown-item\" href=\"javascript:void(0)\" *ngFor=\"let item of normalized\" (click)=\"toggleChecked(item)\">\r\n                    <span *ngIf=\"item.checked\"><i class=\"fa-regular fa-square-check\"></i></span>\r\n                    <span *ngIf=\"!item.checked\"><i class=\"fa-regular fa-square\"></i></span>\r\n                    {{item.value}}\r\n                </a></li>\r\n        </ng-container>\r\n    </ul>\r\n</div>"]}
|