zek 17.3.83 → 17.3.86
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/models/nav.model.mjs +1 -1
- package/esm2022/lib/modules/bb/bb.component.mjs +2 -3
- package/esm2022/lib/modules/file-input/file-input.mjs +2 -3
- package/esm2022/lib/modules/google-login-button/google-login-button.mjs +2 -3
- package/esm2022/lib/modules/modal/modal/modal.component.mjs +10 -7
- package/esm2022/lib/modules/radio/radio.mjs +2 -3
- package/esm2022/lib/modules/select/select.mjs +2 -3
- package/esm2022/lib/modules/tag/tag.mjs +2 -3
- package/esm2022/lib/services/file.service.mjs +10 -1
- package/fesm2022/zek.mjs +25 -19
- package/fesm2022/zek.mjs.map +1 -1
- package/lib/models/nav.model.d.ts +2 -6
- package/lib/modules/modal/modal/modal.component.d.ts +5 -1
- package/lib/services/file.service.d.ts +2 -0
- package/package.json +1 -1
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2Lm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvemVrL3NyYy9saWIvbW9kZWxzL25hdi5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBJTmF2SXRlbSB7XHJcbiAgICBpZD86IHN0cmluZyB8IG51bGw7XHJcbiAgICBuYW1lPzogc3RyaW5nIHwgbnVsbDtcclxuICAgIHRvcD86IGJvb2xlYW4gfCBudWxsO1xyXG4gICAgaWNvbj86IHN0cmluZyB8IG51bGw7XHJcbiAgICBiYWRnZT86IHN0cmluZyB8IG51bGw7XHJcbiAgICBwYXRoPzogc3RyaW5nIHwgbnVsbDtcclxuICAgIGRhdGE/OiB7XHJcbiAgICAgICAgcm9sZXM/OiBbXSB8IG51bGwsXHJcbiAgICAgICAgcGVybWlzc2lvbj86IHsga2V5OiBudW1iZXIgfSB8IG51bGxcclxuICAgIH0gfCBudWxsO1xyXG5cclxuICAgIGNoaWxkcmVuPzogSU5hdkl0ZW1bXSB8IG51bGxcclxufSJdfQ==
|
|
@@ -6,7 +6,6 @@ import { Convert, ObjectHelper } from '../../utils';
|
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
import * as i1 from "@angular/common";
|
|
8
8
|
import * as i2 from "@ngx-translate/core";
|
|
9
|
-
let uniqueId = 0;
|
|
10
9
|
/**
|
|
11
10
|
* Provider Expression that allows bb to register as a ControlValueAccessor. This
|
|
12
11
|
* allows it to support [(ngModel)] and ngControl.
|
|
@@ -20,7 +19,7 @@ const ZEK_BB_CONTROL_VALUE_ACCESSOR = {
|
|
|
20
19
|
export class ZekButtonBrowse extends CoreUiComponent {
|
|
21
20
|
constructor() {
|
|
22
21
|
super(...arguments);
|
|
23
|
-
this._uniqueId = `zek-bb-${
|
|
22
|
+
this._uniqueId = `zek-bb-${this.uniqueId}`;
|
|
24
23
|
/** The unique ID for the bb. */
|
|
25
24
|
this.id = this._uniqueId;
|
|
26
25
|
this.filter = {};
|
|
@@ -205,4 +204,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImpor
|
|
|
205
204
|
}], showHeader: [{
|
|
206
205
|
type: Input
|
|
207
206
|
}] } });
|
|
208
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bb.component.js","sourceRoot":"","sources":["../../../../../../projects/zek/src/lib/modules/bb/bb.component.ts","../../../../../../projects/zek/src/lib/modules/bb/bb.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, forwardRef } 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 { KeyPair, ModalSize, PagedList } from '../../models';\r\nimport { Convert, ObjectHelper } from '../../utils';\r\ndeclare let bootstrap: any;\r\nlet uniqueId = 0;\r\n\r\n/**\r\n * Provider Expression that allows bb to register as a ControlValueAccessor. This\r\n * allows it to support [(ngModel)] and ngControl.\r\n * @docs-private\r\n */\r\nconst ZEK_BB_CONTROL_VALUE_ACCESSOR: any = {\r\n    provide: NG_VALUE_ACCESSOR,\r\n    useExisting: forwardRef(() => ZekButtonBrowse),\r\n    multi: true,\r\n};\r\n\r\n@Component({\r\n    selector: 'zek-bb',\r\n    templateUrl: './bb.component.html',\r\n    providers: [ZEK_BB_CONTROL_VALUE_ACCESSOR],\r\n})\r\nexport class ZekButtonBrowse extends CoreUiComponent {\r\n    override destroy() {\r\n        this._modal?.dispose();\r\n        this._modal = null;\r\n        return super.destroy();\r\n    }\r\n\r\n    private _uniqueId: string = `zek-bb-${++uniqueId}`;\r\n    /** The unique ID for the bb. */\r\n    @Input() id: string = this._uniqueId;\r\n    get modalId(): string {\r\n        return `${this.id || this._uniqueId}-modal`;\r\n    }\r\n    filter: any = {};\r\n    data: PagedList = new PagedList();\r\n\r\n\r\n    private _type?: string | null;\r\n    @Input()\r\n    get type() {\r\n        return this._type;\r\n    }\r\n    set type(v: string | null | undefined) {\r\n        if (this._type !== v) {\r\n            this._type = v;\r\n            this.onValueChanged();//get and set input text\r\n        }\r\n    }\r\n\r\n    private _text: string | null = null;\r\n    @Input()\r\n    get text(): string | null {\r\n        return this._text;\r\n    }\r\n    set text(v: string | null) {\r\n        if (this._text !== v) {\r\n            this._text = v\r\n            this.onTextChanged();\r\n        }\r\n    }\r\n    onTextChanged() {\r\n        this.onKeyPairChange.emit(new KeyPair({ key: this._value, value: this._text }))\r\n    }\r\n\r\n\r\n\r\n    private _readOnly = false;\r\n    @Input()\r\n    get readOnly(): boolean {\r\n        return this._readOnly;\r\n    }\r\n    set readOnly(v: BooleanInput) {\r\n        this._readOnly = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n\r\n\r\n    private _hide = false;\r\n    @Input()\r\n    get hide(): boolean {\r\n        return this._hide;\r\n    }\r\n    set hide(v: BooleanInput) {\r\n        this._hide = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n    private _showInput = true;\r\n    @Input()\r\n    get showInput(): boolean {\r\n        return this._showInput;\r\n    }\r\n    set showInput(v: BooleanInput) {\r\n        this._showInput = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n    private _multiSelect = false;\r\n    @Input()\r\n    get multiSelect(): boolean {\r\n        return this._multiSelect;\r\n    }\r\n    set multiSelect(v: BooleanInput) {\r\n        this._multiSelect = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n\r\n    @Output() onShowModal = new EventEmitter();\r\n    @Output() onChooseAll = new EventEmitter();\r\n    @Output() onKeyPairChange = new EventEmitter<KeyPair>();\r\n    @Output() onBindText = new EventEmitter();\r\n\r\n    private _modal: any;\r\n    get modal(): any {\r\n        if (!this._modal) {\r\n            const modalEl = document.getElementById(this.modalId);\r\n            this._modal = new bootstrap.Modal(modalEl, { backdrop: false });\r\n        }\r\n        return this._modal;\r\n    }\r\n    set modal(v: any) {\r\n        this._modal = v;\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    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\r\n    showModal() {\r\n        if (!this.disabled && !this.readOnly) {\r\n            this.onShowModal.emit(this.filter);\r\n\r\n            this.data = new PagedList();\r\n            if (this.modal)\r\n                this.modal.show();\r\n        }\r\n    }\r\n    close() {\r\n        this._modal?.hide();\r\n    }\r\n\r\n\r\n\r\n    choose(value: any) {\r\n        if (!this.disabled && !this.readOnly) {\r\n            this.setNgModel(value);\r\n            this.close();\r\n        }\r\n    }\r\n    chooseAll(filter: any) {\r\n        this.onChooseAll.emit(filter);\r\n        this.close();\r\n    }\r\n\r\n    delete() {\r\n        if (!this.readOnly) {//!this.disabled && \r\n            this.setNgModel(null);\r\n        }\r\n    }\r\n\r\n    _onKey(event: KeyboardEvent) {\r\n        if (event.key === 'Delete') {\r\n            this.delete();\r\n        }\r\n    }\r\n\r\n\r\n\r\n\r\n    override onValueChanged() {\r\n        if (ObjectHelper.isDefined(this._value) && ObjectHelper.isDefined(this._type)) {\r\n            this.bindText();\r\n        } else {\r\n            this.text = null;\r\n        }\r\n    }\r\n    bindText() {\r\n        this.onBindText.emit();\r\n    }\r\n}","<div *ngIf=\"!hide && showInput\" class=\"input-group\">\r\n    <input type=\"text\" class=\"form-control\" [ngClass]=\"{ 'ng-valid required': !required || value, 'ng-invalid': required && !value }\" (keyup)=\"_onKey($event)\" title=\"ID = {{value}}\" [value]=\"text\" [attr.readonly]=\"true\">\r\n    <button type=\"button\" [disabled]=\"disabled || readOnly\" class=\"btn btn-outline-secondary\" (click)=\"showModal()\">\r\n        <i class=\"fa-solid fa-ellipsis\"></i>\r\n    </button>\r\n    <button type=\"button\" [disabled]=\"disabled || readOnly\" class=\"btn btn-outline-secondary dropdown-toggle dropdown-toggle-split\" data-bs-toggle=\"dropdown\" aria-expanded=\"false\">\r\n        <span class=\"visually-hidden\">Toggle Dropdown</span>\r\n    </button>\r\n    <ul class=\"dropdown-menu\">\r\n        <li><a class=\"dropdown-item\" (click)=\"delete()\" href=\"javascript:void(0)\"> <i class=\"fa-solid fa-trash\"></i> Delete <kbd>delete</kbd> </a></li>\r\n    </ul>\r\n</div>\r\n<div *ngIf=\"!hide || disabled || readOnly\" class=\"modal fade\" [id]=\"modalId\" tabindex=\"-1\" aria-labelledby=\"bb-modal-label\" 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                <h5 class=\"modal-title\" id=\"{{modalId}}-label\">{{'Action.Choose' | translate }}</h5>\r\n                <button type=\"button\" (click)=\"close()\" class=\"btn-close\" data-bs-dismiss2=\"modal\" aria-label=\"Close\"></button>\r\n            </div>\r\n            <div class=\"modal-body\">\r\n                <ng-content></ng-content>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>"]}
|
|
207
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bb.component.js","sourceRoot":"","sources":["../../../../../../projects/zek/src/lib/modules/bb/bb.component.ts","../../../../../../projects/zek/src/lib/modules/bb/bb.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, forwardRef } 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 { KeyPair, ModalSize, PagedList } from '../../models';\r\nimport { Convert, ObjectHelper } from '../../utils';\r\ndeclare let bootstrap: any;\r\n\r\n/**\r\n * Provider Expression that allows bb to register as a ControlValueAccessor. This\r\n * allows it to support [(ngModel)] and ngControl.\r\n * @docs-private\r\n */\r\nconst ZEK_BB_CONTROL_VALUE_ACCESSOR: any = {\r\n    provide: NG_VALUE_ACCESSOR,\r\n    useExisting: forwardRef(() => ZekButtonBrowse),\r\n    multi: true,\r\n};\r\n\r\n@Component({\r\n    selector: 'zek-bb',\r\n    templateUrl: './bb.component.html',\r\n    providers: [ZEK_BB_CONTROL_VALUE_ACCESSOR],\r\n})\r\nexport class ZekButtonBrowse extends CoreUiComponent {\r\n    override destroy() {\r\n        this._modal?.dispose();\r\n        this._modal = null;\r\n        return super.destroy();\r\n    }\r\n\r\n    private _uniqueId: string = `zek-bb-${this.uniqueId}`;\r\n    /** The unique ID for the bb. */\r\n    @Input() id: string = this._uniqueId;\r\n    get modalId(): string {\r\n        return `${this.id || this._uniqueId}-modal`;\r\n    }\r\n    filter: any = {};\r\n    data: PagedList = new PagedList();\r\n\r\n\r\n    private _type?: string | null;\r\n    @Input()\r\n    get type() {\r\n        return this._type;\r\n    }\r\n    set type(v: string | null | undefined) {\r\n        if (this._type !== v) {\r\n            this._type = v;\r\n            this.onValueChanged();//get and set input text\r\n        }\r\n    }\r\n\r\n    private _text: string | null = null;\r\n    @Input()\r\n    get text(): string | null {\r\n        return this._text;\r\n    }\r\n    set text(v: string | null) {\r\n        if (this._text !== v) {\r\n            this._text = v\r\n            this.onTextChanged();\r\n        }\r\n    }\r\n    onTextChanged() {\r\n        this.onKeyPairChange.emit(new KeyPair({ key: this._value, value: this._text }))\r\n    }\r\n\r\n\r\n\r\n    private _readOnly = false;\r\n    @Input()\r\n    get readOnly(): boolean {\r\n        return this._readOnly;\r\n    }\r\n    set readOnly(v: BooleanInput) {\r\n        this._readOnly = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n\r\n\r\n    private _hide = false;\r\n    @Input()\r\n    get hide(): boolean {\r\n        return this._hide;\r\n    }\r\n    set hide(v: BooleanInput) {\r\n        this._hide = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n    private _showInput = true;\r\n    @Input()\r\n    get showInput(): boolean {\r\n        return this._showInput;\r\n    }\r\n    set showInput(v: BooleanInput) {\r\n        this._showInput = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n    private _multiSelect = false;\r\n    @Input()\r\n    get multiSelect(): boolean {\r\n        return this._multiSelect;\r\n    }\r\n    set multiSelect(v: BooleanInput) {\r\n        this._multiSelect = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n\r\n    @Output() onShowModal = new EventEmitter();\r\n    @Output() onChooseAll = new EventEmitter();\r\n    @Output() onKeyPairChange = new EventEmitter<KeyPair>();\r\n    @Output() onBindText = new EventEmitter();\r\n\r\n    private _modal: any;\r\n    get modal(): any {\r\n        if (!this._modal) {\r\n            const modalEl = document.getElementById(this.modalId);\r\n            this._modal = new bootstrap.Modal(modalEl, { backdrop: false });\r\n        }\r\n        return this._modal;\r\n    }\r\n    set modal(v: any) {\r\n        this._modal = v;\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    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\r\n    showModal() {\r\n        if (!this.disabled && !this.readOnly) {\r\n            this.onShowModal.emit(this.filter);\r\n\r\n            this.data = new PagedList();\r\n            if (this.modal)\r\n                this.modal.show();\r\n        }\r\n    }\r\n    close() {\r\n        this._modal?.hide();\r\n    }\r\n\r\n\r\n\r\n    choose(value: any) {\r\n        if (!this.disabled && !this.readOnly) {\r\n            this.setNgModel(value);\r\n            this.close();\r\n        }\r\n    }\r\n    chooseAll(filter: any) {\r\n        this.onChooseAll.emit(filter);\r\n        this.close();\r\n    }\r\n\r\n    delete() {\r\n        if (!this.readOnly) {//!this.disabled && \r\n            this.setNgModel(null);\r\n        }\r\n    }\r\n\r\n    _onKey(event: KeyboardEvent) {\r\n        if (event.key === 'Delete') {\r\n            this.delete();\r\n        }\r\n    }\r\n\r\n\r\n\r\n\r\n    override onValueChanged() {\r\n        if (ObjectHelper.isDefined(this._value) && ObjectHelper.isDefined(this._type)) {\r\n            this.bindText();\r\n        } else {\r\n            this.text = null;\r\n        }\r\n    }\r\n    bindText() {\r\n        this.onBindText.emit();\r\n    }\r\n}","<div *ngIf=\"!hide && showInput\" class=\"input-group\">\r\n    <input type=\"text\" class=\"form-control\" [ngClass]=\"{ 'ng-valid required': !required || value, 'ng-invalid': required && !value }\" (keyup)=\"_onKey($event)\" title=\"ID = {{value}}\" [value]=\"text\" [attr.readonly]=\"true\">\r\n    <button type=\"button\" [disabled]=\"disabled || readOnly\" class=\"btn btn-outline-secondary\" (click)=\"showModal()\">\r\n        <i class=\"fa-solid fa-ellipsis\"></i>\r\n    </button>\r\n    <button type=\"button\" [disabled]=\"disabled || readOnly\" class=\"btn btn-outline-secondary dropdown-toggle dropdown-toggle-split\" data-bs-toggle=\"dropdown\" aria-expanded=\"false\">\r\n        <span class=\"visually-hidden\">Toggle Dropdown</span>\r\n    </button>\r\n    <ul class=\"dropdown-menu\">\r\n        <li><a class=\"dropdown-item\" (click)=\"delete()\" href=\"javascript:void(0)\"> <i class=\"fa-solid fa-trash\"></i> Delete <kbd>delete</kbd> </a></li>\r\n    </ul>\r\n</div>\r\n<div *ngIf=\"!hide || disabled || readOnly\" class=\"modal fade\" [id]=\"modalId\" tabindex=\"-1\" aria-labelledby=\"bb-modal-label\" 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                <h5 class=\"modal-title\" id=\"{{modalId}}-label\">{{'Action.Choose' | translate }}</h5>\r\n                <button type=\"button\" (click)=\"close()\" class=\"btn-close\" data-bs-dismiss2=\"modal\" aria-label=\"Close\"></button>\r\n            </div>\r\n            <div class=\"modal-body\">\r\n                <ng-content></ng-content>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>"]}
|
|
@@ -5,14 +5,13 @@ import { FileService } from '../../services/file.service';
|
|
|
5
5
|
import { CoreUiComponent } from '../../components/core-ui.component';
|
|
6
6
|
import { Convert } from '../../utils/convert';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
|
-
let uniqueId = 0;
|
|
9
8
|
export class ZekFileInput extends CoreUiComponent {
|
|
10
9
|
constructor() {
|
|
11
10
|
super(...arguments);
|
|
12
11
|
// @Input() model!: string[] | null;
|
|
13
12
|
this.onUpload = new EventEmitter();
|
|
14
13
|
this.fileService = inject(FileService);
|
|
15
|
-
this._uniqueId = `zek-file-input-${
|
|
14
|
+
this._uniqueId = `zek-file-input-${this.uniqueId}`;
|
|
16
15
|
/** The unique ID for the tag. */
|
|
17
16
|
this.id = this._uniqueId;
|
|
18
17
|
this._accept = '*';
|
|
@@ -77,4 +76,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImpor
|
|
|
77
76
|
}], multiple: [{
|
|
78
77
|
type: Input
|
|
79
78
|
}] } });
|
|
80
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1pbnB1dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3play9zcmMvbGliL21vZHVsZXMvZmlsZS1pbnB1dC9maWxlLWlucHV0LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvemVrL3NyYy9saWIvbW9kdWxlcy9maWxlLWlucHV0L2ZpbGUtaW5wdXQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDL0UsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFFckUsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLHFCQUFxQixDQUFDOztBQWE5QyxNQUFNLE9BQU8sWUFBYSxTQUFRLGVBQWU7SUFYakQ7O1FBWUksb0NBQW9DO1FBQ2pCLGFBQVEsR0FBRyxJQUFJLFlBQVksRUFBYyxDQUFDO1FBRTVDLGdCQUFXLEdBQUcsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBRTNDLGNBQVMsR0FBVyxrQkFBa0IsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQzlELGlDQUFpQztRQUN4QixPQUFFLEdBQVcsSUFBSSxDQUFDLFNBQVMsQ0FBQztRQU03QixZQUFPLEdBQUcsR0FBRyxDQUFDO1FBYWQsY0FBUyxHQUFHLEtBQUssQ0FBQztLQW9DN0I7SUFyREcsSUFBSSxPQUFPO1FBQ1AsT0FBTyxHQUFHLElBQUksQ0FBQyxFQUFFLElBQUksSUFBSSxDQUFDLFNBQVMsUUFBUSxDQUFDO0lBQ2hELENBQUM7SUFHRCxJQUFXLE1BQU07UUFDYixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUM7SUFDeEIsQ0FBQztJQUNELElBQ0ksTUFBTSxDQUFDLENBQTRCO1FBQ25DLElBQUksQ0FBQyxDQUFDO1lBQ0YsSUFBSSxDQUFDLE9BQU8sR0FBRyxHQUFHLENBQUM7O1lBRW5CLElBQUksQ0FBQyxPQUFPLEdBQUcsQ0FBQyxDQUFDO0lBQ3pCLENBQUM7SUFJRCxJQUNJLFFBQVE7UUFDUixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUM7SUFDMUIsQ0FBQztJQUNELElBQUksUUFBUSxDQUFDLENBQWU7UUFDeEIsSUFBSSxDQUFDLFNBQVMsR0FBRyxPQUFPLENBQUMsaUJBQWlCLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDbEQsQ0FBQztJQUVELCtCQUErQjtJQUUvQixVQUFVO1FBQ04sTUFBTSxFQUFFLEdBQUcsUUFBUSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDakQsSUFBSSxFQUFFLEVBQUUsQ0FBQztZQUNMLEVBQUUsQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUNmLENBQUM7SUFDTCxDQUFDO0lBRUQsS0FBSyxDQUFDLGlCQUFpQixDQUFDLEtBQVU7UUFDOUIsS0FBSyxDQUFDLGNBQWMsRUFBRSxDQUFDO1FBQ3ZCLEtBQUssQ0FBQyxlQUFlLEVBQUUsQ0FBQztRQUV4QixNQUFNLEtBQUssR0FBRyxLQUFLLEVBQUUsTUFBTSxFQUFFLEtBQUssQ0FBQztRQUNuQyxJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxLQUFLLENBQUM7WUFBRSxPQUFPO1FBRWxDLE1BQU0sUUFBUSxHQUFHLElBQUksUUFBUSxFQUFFLENBQUM7UUFDaEMsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLEtBQUssQ0FBQyxNQUFNLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQztZQUNwQyxNQUFNLElBQUksR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDdEIsUUFBUSxDQUFDLE1BQU0sQ0FBQyxPQUFPLEVBQUUsSUFBSSxFQUFFLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUM5QyxDQUFDO1FBQ0QsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxFQUFFO1lBQzdDLElBQUksSUFBSSxFQUFFLE9BQU8sRUFBRSxDQUFDO2dCQUNoQixJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDbkMsQ0FBQztRQUNMLENBQUMsQ0FBQyxDQUFBO0lBQ04sQ0FBQzs4R0E5RFEsWUFBWTtrR0FBWixZQUFZLHlNQUxWLENBQUMsV0FBVyxDQUFDLGlEQ2Q1Qix5UUFLMkMsK0ZESzdCLFlBQVksOEJBQUUsV0FBVzs7MkZBUzFCLFlBQVk7a0JBWHhCLFNBQVM7aUNBQ00sSUFBSSxXQUNQLENBQUMsWUFBWSxFQUFFLFdBQVcsQ0FBQyxZQUMxQixnQkFBZ0IsYUFHZixDQUFDLFdBQVcsQ0FBQyxRQUNsQjt3QkFDRixXQUFXLEVBQUUsSUFBSTtxQkFDcEI7OEJBSWtCLFFBQVE7c0JBQTFCLE1BQU07Z0JBTUUsRUFBRTtzQkFBVixLQUFLO2dCQVdGLE1BQU07c0JBRFQsS0FBSztnQkFXRixRQUFRO3NCQURYLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgaW5qZWN0LCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBGaWxlU2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL2ZpbGUuc2VydmljZSc7XHJcbmltcG9ydCB7IENvcmVVaUNvbXBvbmVudCB9IGZyb20gJy4uLy4uL2NvbXBvbmVudHMvY29yZS11aS5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBCb29sZWFuSW5wdXQgfSBmcm9tICcuLi8uLi9jb21wb25lbnRzL3R5cGVzJztcclxuaW1wb3J0IHsgQ29udmVydCB9IGZyb20gJy4uLy4uL3V0aWxzL2NvbnZlcnQnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gICAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgRm9ybXNNb2R1bGVdLFxyXG4gICAgc2VsZWN0b3I6ICd6ZWstZmlsZS1pbnB1dCcsXHJcbiAgICB0ZW1wbGF0ZVVybDogJ2ZpbGUtaW5wdXQuaHRtbCcsXHJcbiAgICBzdHlsZVVybDogJ2ZpbGUtaW5wdXQuc2NzcycsXHJcbiAgICBwcm92aWRlcnM6IFtGaWxlU2VydmljZV0sXHJcbiAgICBob3N0OiB7XHJcbiAgICAgICAgJ1thdHRyLmlkXSc6ICdpZCcsXHJcbiAgICB9XHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBaZWtGaWxlSW5wdXQgZXh0ZW5kcyBDb3JlVWlDb21wb25lbnQge1xyXG4gICAgLy8gQElucHV0KCkgbW9kZWwhOiBzdHJpbmdbXSB8IG51bGw7XHJcbiAgICBAT3V0cHV0KCkgcmVhZG9ubHkgb25VcGxvYWQgPSBuZXcgRXZlbnRFbWl0dGVyPEFycmF5PGFueT4+KCk7XHJcblxyXG4gICAgcHJpdmF0ZSByZWFkb25seSBmaWxlU2VydmljZSA9IGluamVjdChGaWxlU2VydmljZSk7XHJcblxyXG4gICAgcHJpdmF0ZSBfdW5pcXVlSWQ6IHN0cmluZyA9IGB6ZWstZmlsZS1pbnB1dC0ke3RoaXMudW5pcXVlSWR9YDtcclxuICAgIC8qKiBUaGUgdW5pcXVlIElEIGZvciB0aGUgdGFnLiAqL1xyXG4gICAgQElucHV0KCkgaWQ6IHN0cmluZyA9IHRoaXMuX3VuaXF1ZUlkO1xyXG5cclxuICAgIGdldCBpbnB1dElkKCk6IHN0cmluZyB7XHJcbiAgICAgICAgcmV0dXJuIGAke3RoaXMuaWQgfHwgdGhpcy5fdW5pcXVlSWR9LWlucHV0YDtcclxuICAgIH1cclxuXHJcbiAgICBwcml2YXRlIF9hY2NlcHQgPSAnKic7XHJcbiAgICBwdWJsaWMgZ2V0IGFjY2VwdCgpOiBzdHJpbmcge1xyXG4gICAgICAgIHJldHVybiB0aGlzLl9hY2NlcHQ7XHJcbiAgICB9XHJcbiAgICBASW5wdXQoKVxyXG4gICAgc2V0IGFjY2VwdCh2OiBzdHJpbmcgfCBudWxsIHwgdW5kZWZpbmVkKSB7XHJcbiAgICAgICAgaWYgKCF2KVxyXG4gICAgICAgICAgICB0aGlzLl9hY2NlcHQgPSAnKic7XHJcbiAgICAgICAgZWxzZVxyXG4gICAgICAgICAgICB0aGlzLl9hY2NlcHQgPSB2O1xyXG4gICAgfVxyXG5cclxuXHJcbiAgICBwcml2YXRlIF9tdWx0aXBsZSA9IGZhbHNlO1xyXG4gICAgQElucHV0KClcclxuICAgIGdldCBtdWx0aXBsZSgpOiBib29sZWFuIHtcclxuICAgICAgICByZXR1cm4gdGhpcy5fbXVsdGlwbGU7XHJcbiAgICB9XHJcbiAgICBzZXQgbXVsdGlwbGUodjogQm9vbGVhbklucHV0KSB7XHJcbiAgICAgICAgdGhpcy5fbXVsdGlwbGUgPSBDb252ZXJ0LnRvQm9vbGVhblByb3BlcnR5KHYpO1xyXG4gICAgfVxyXG5cclxuICAgIC8vIGZpbGVzOiBGaWxlW10gfCBudWxsID0gbnVsbDtcclxuXHJcbiAgICBjbGlja0lucHV0KCkge1xyXG4gICAgICAgIGNvbnN0IGVsID0gZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQodGhpcy5pbnB1dElkKTtcclxuICAgICAgICBpZiAoZWwpIHtcclxuICAgICAgICAgICAgZWwuY2xpY2soKTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG4gICAgYXN5bmMgb25GaWxlSW5wdXRDaGFuZ2UoZXZlbnQ6IGFueSkge1xyXG4gICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XHJcbiAgICAgICAgZXZlbnQuc3RvcFByb3BhZ2F0aW9uKCk7XHJcblxyXG4gICAgICAgIGNvbnN0IGZpbGVzID0gZXZlbnQ/LnRhcmdldD8uZmlsZXM7XHJcbiAgICAgICAgaWYgKEFycmF5LmlzQXJyYXkoIWZpbGVzKSkgcmV0dXJuO1xyXG5cclxuICAgICAgICBjb25zdCBmb3JtRGF0YSA9IG5ldyBGb3JtRGF0YSgpO1xyXG4gICAgICAgIGZvciAobGV0IGkgPSAwOyBpIDwgZmlsZXMubGVuZ3RoOyBpKyspIHtcclxuICAgICAgICAgICAgY29uc3QgZmlsZSA9IGZpbGVzW2ldO1xyXG4gICAgICAgICAgICBmb3JtRGF0YS5hcHBlbmQoJ2ZpbGVzJywgZmlsZSwgZmlsZS5uYW1lKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgdGhpcy5maWxlU2VydmljZS5zYXZlKGZvcm1EYXRhKS5zdWJzY3JpYmUoZGF0YSA9PiB7XHJcbiAgICAgICAgICAgIGlmIChkYXRhPy5zdWNjZXNzKSB7XHJcbiAgICAgICAgICAgICAgICB0aGlzLm9uVXBsb2FkLmVtaXQoZGF0YS52YWx1ZSk7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9KVxyXG4gICAgfVxyXG59IiwiPGlucHV0IHR5cGU9XCJmaWxlXCIgY2xhc3M9XCJmb3JtLWNvbnRyb2xcIlxyXG4gICAgbmFtZT1cInt7aW5wdXRJZH19XCJcclxuICAgIGlkPVwie3tpbnB1dElkfX1cIlxyXG4gICAgW211bHRpcGxlXT1cIm11bHRpcGxlXCIgW2FjY2VwdF09XCJhY2NlcHRcIiBbcmVxdWlyZWRdPVwicmVxdWlyZWRcIiBbZGlzYWJsZWRdPVwicmVhZG9ubHlcIlxyXG4gICAgI2ZpbGVJbnB1dFxyXG4gICAgKGNoYW5nZSk9XCJvbkZpbGVJbnB1dENoYW5nZSgkZXZlbnQpXCIgLz4iXX0=
|
|
@@ -4,12 +4,11 @@ import { GOOGLE_CLIENT_ID } from "../../tokens";
|
|
|
4
4
|
import { CoreComponent } from "../../components";
|
|
5
5
|
import { Convert } from "../../utils";
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
|
-
let uniqueId = 0;
|
|
8
7
|
export class ZekGoogleLoginButton extends CoreComponent {
|
|
9
8
|
constructor(client_id) {
|
|
10
9
|
super();
|
|
11
10
|
this.client_id = client_id;
|
|
12
|
-
this._uniqueId = `zek-google-button-container-${
|
|
11
|
+
this._uniqueId = `zek-google-button-container-${this.uniqueId}`;
|
|
13
12
|
this.id = this._uniqueId;
|
|
14
13
|
this._prompt = true;
|
|
15
14
|
this._autoSelect = false;
|
|
@@ -133,4 +132,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImpor
|
|
|
133
132
|
}], onLogin: [{
|
|
134
133
|
type: Output
|
|
135
134
|
}] } });
|
|
136
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"google-login-button.js","sourceRoot":"","sources":["../../../../../../projects/zek/src/lib/modules/google-login-button/google-login-button.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Directive, EventEmitter, Inject, Input, Output } from \"@angular/core\";\r\nimport { loader } from './loader';\r\nimport { GOOGLE_CLIENT_ID } from \"../../tokens\";\r\nimport { CoreComponent, BooleanInput, NumberInput } from \"../../components\";\r\nimport { Convert } from \"../../utils\";\r\n\r\ndeclare let google: any;\r\nlet uniqueId = 0;\r\n\r\nexport interface GoogleLoginConfig {\r\n    client_id: string;\r\n}\r\nexport type GoogleLoginButtonTextInput =\r\n    'signin_with' | 'signup_with' | 'continue_with' | 'signin' | null | undefined;\r\n\r\n\r\n@Directive({\r\n    selector: 'zek-google-login',\r\n    host: {\r\n        '[attr.id]': 'id',\r\n    }\r\n})\r\nexport class ZekGoogleLoginButton extends CoreComponent {\r\n    constructor(@Inject(GOOGLE_CLIENT_ID) private readonly client_id: string) {\r\n        super();\r\n    }\r\n\r\n    private _uniqueId: string = `zek-google-button-container-${++uniqueId}`;\r\n    @Input() id: string = this._uniqueId;\r\n\r\n    private _prompt = true;\r\n    @Input() get prompt() {\r\n        return this._prompt;\r\n    }\r\n    set prompt(v: BooleanInput) {\r\n        this._prompt = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n    private _autoSelect = false;\r\n    @Input() get autoSelect() {\r\n        return this._autoSelect;\r\n    }\r\n    set autoSelect(v: BooleanInput) {\r\n        this._autoSelect = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n\r\n    private _cancelOnTapOutside = true;\r\n    @Input() get cancelOnTapOutside() {\r\n        return this._cancelOnTapOutside;\r\n    }\r\n    set cancelOnTapOutside(v: BooleanInput) {\r\n        this._cancelOnTapOutside = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n\r\n    private _width: NumberInput;\r\n    @Input() get width() {\r\n        return this._width;\r\n    }\r\n    set width(v: NumberInput) {\r\n        this._width = v;\r\n    }\r\n\r\n\r\n    private _text: GoogleLoginButtonTextInput;\r\n    @Input() get text() {\r\n        return this._text;\r\n    }\r\n    set text(v: GoogleLoginButtonTextInput) {\r\n        this._text = v;\r\n    }\r\n\r\n\r\n\r\n    @Output() onLoginResponse = new EventEmitter();\r\n    @Output() onLogin = new EventEmitter();\r\n\r\n    // private _type: 'standard' | 'icon';\r\n    // public get type(): '' {\r\n    //     return this._type;\r\n    // }\r\n    // public set type(v: 'standard' | 'icon') {\r\n    //     this._type = v;\r\n    // }\r\n\r\n\r\n\r\n\r\n    // private static _loaded = false;\r\n    // static async loadScript() {\r\n    //     if (this._loaded) return;\r\n    //     await HtmlHelper.loadScripts('https://accounts.google.com/gsi/client');\r\n    //     this._loaded = true;\r\n    // }\r\n\r\n\r\n    private google?: any;\r\n    override async init() {\r\n        super.init();\r\n        // await GoogleLoginButton.loadScript();\r\n\r\n        if (\"google\" in window) {\r\n            this.google = google;\r\n            this.initialize();\r\n        } else {\r\n            loader.loadScript(this.onLoadComplete);\r\n        }\r\n    }\r\n    private onLoadComplete = (google: any) => {\r\n        this.google = google;\r\n        this.initialize();\r\n    }\r\n\r\n    initialize() {\r\n        this.google.accounts.id.initialize({\r\n            client_id: this.client_id,\r\n            callback: (response: any) => {\r\n                this.handleCredentialResponse(response);\r\n            },\r\n            auto_select: this._autoSelect,\r\n            cancel_on_tap_outside: this._cancelOnTapOutside,\r\n        });\r\n\r\n        setTimeout(() => {\r\n            this.renderButton();\r\n            this.autoPrompt();\r\n        },);\r\n    }\r\n    renderButton() {\r\n        const options: any = { theme: \"outline\", size: \"large\" };\r\n        if (this._width)\r\n            options.width = this._width;\r\n        if (this._text)\r\n            options.text = this._text\r\n\r\n        this.google.accounts.id.renderButton(\r\n            document.getElementById(this.id),\r\n            // this._elementRef.nativeElement.parentElement,\r\n            options  // customization attributes\r\n        );\r\n    }\r\n    autoPrompt() {\r\n        if (this._prompt)\r\n            this.google.accounts.id.prompt(); // also display the One Tap dialog\r\n    }\r\n\r\n\r\n    handleCredentialResponse(response: any) {\r\n        this.onLoginResponse?.emit(response);\r\n        this.onLogin?.emit(response.credential);\r\n\r\n        // let payload = JwtHelper.decode(response.credential);\r\n        // console.log(\"ID: \" + payload.sub);\r\n        // console.log('Full Name: ' + payload.name);\r\n        // console.log('Given Name: ' + payload.given_name);\r\n        // console.log('Family Name: ' + payload.family_name);\r\n        // console.log(\"Image URL: \" + payload.picture);\r\n        // console.log(\"Email: \" + payload.email);\r\n    }\r\n}"]}
|
|
135
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"google-login-button.js","sourceRoot":"","sources":["../../../../../../projects/zek/src/lib/modules/google-login-button/google-login-button.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, EventEmitter, Inject, Input, Output } from \"@angular/core\";\r\nimport { loader } from './loader';\r\nimport { GOOGLE_CLIENT_ID } from \"../../tokens\";\r\nimport { CoreComponent, BooleanInput, NumberInput } from \"../../components\";\r\nimport { Convert } from \"../../utils\";\r\n\r\ndeclare let google: any;\r\n\r\nexport interface GoogleLoginConfig {\r\n    client_id: string;\r\n}\r\nexport type GoogleLoginButtonTextInput =\r\n    'signin_with' | 'signup_with' | 'continue_with' | 'signin' | null | undefined;\r\n\r\n\r\n@Directive({\r\n    selector: 'zek-google-login',\r\n    host: {\r\n        '[attr.id]': 'id',\r\n    }\r\n})\r\nexport class ZekGoogleLoginButton extends CoreComponent {\r\n    constructor(@Inject(GOOGLE_CLIENT_ID) private readonly client_id: string) {\r\n        super();\r\n    }\r\n\r\n    private _uniqueId: string = `zek-google-button-container-${this.uniqueId}`;\r\n    @Input() id: string = this._uniqueId;\r\n\r\n    private _prompt = true;\r\n    @Input() get prompt() {\r\n        return this._prompt;\r\n    }\r\n    set prompt(v: BooleanInput) {\r\n        this._prompt = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n    private _autoSelect = false;\r\n    @Input() get autoSelect() {\r\n        return this._autoSelect;\r\n    }\r\n    set autoSelect(v: BooleanInput) {\r\n        this._autoSelect = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n\r\n    private _cancelOnTapOutside = true;\r\n    @Input() get cancelOnTapOutside() {\r\n        return this._cancelOnTapOutside;\r\n    }\r\n    set cancelOnTapOutside(v: BooleanInput) {\r\n        this._cancelOnTapOutside = Convert.toBooleanProperty(v);\r\n    }\r\n\r\n\r\n    private _width: NumberInput;\r\n    @Input() get width() {\r\n        return this._width;\r\n    }\r\n    set width(v: NumberInput) {\r\n        this._width = v;\r\n    }\r\n\r\n\r\n    private _text: GoogleLoginButtonTextInput;\r\n    @Input() get text() {\r\n        return this._text;\r\n    }\r\n    set text(v: GoogleLoginButtonTextInput) {\r\n        this._text = v;\r\n    }\r\n\r\n\r\n\r\n    @Output() onLoginResponse = new EventEmitter();\r\n    @Output() onLogin = new EventEmitter();\r\n\r\n    // private _type: 'standard' | 'icon';\r\n    // public get type(): '' {\r\n    //     return this._type;\r\n    // }\r\n    // public set type(v: 'standard' | 'icon') {\r\n    //     this._type = v;\r\n    // }\r\n\r\n\r\n\r\n\r\n    // private static _loaded = false;\r\n    // static async loadScript() {\r\n    //     if (this._loaded) return;\r\n    //     await HtmlHelper.loadScripts('https://accounts.google.com/gsi/client');\r\n    //     this._loaded = true;\r\n    // }\r\n\r\n\r\n    private google?: any;\r\n    override async init() {\r\n        super.init();\r\n        // await GoogleLoginButton.loadScript();\r\n\r\n        if (\"google\" in window) {\r\n            this.google = google;\r\n            this.initialize();\r\n        } else {\r\n            loader.loadScript(this.onLoadComplete);\r\n        }\r\n    }\r\n    private onLoadComplete = (google: any) => {\r\n        this.google = google;\r\n        this.initialize();\r\n    }\r\n\r\n    initialize() {\r\n        this.google.accounts.id.initialize({\r\n            client_id: this.client_id,\r\n            callback: (response: any) => {\r\n                this.handleCredentialResponse(response);\r\n            },\r\n            auto_select: this._autoSelect,\r\n            cancel_on_tap_outside: this._cancelOnTapOutside,\r\n        });\r\n\r\n        setTimeout(() => {\r\n            this.renderButton();\r\n            this.autoPrompt();\r\n        },);\r\n    }\r\n    renderButton() {\r\n        const options: any = { theme: \"outline\", size: \"large\" };\r\n        if (this._width)\r\n            options.width = this._width;\r\n        if (this._text)\r\n            options.text = this._text\r\n\r\n        this.google.accounts.id.renderButton(\r\n            document.getElementById(this.id),\r\n            // this._elementRef.nativeElement.parentElement,\r\n            options  // customization attributes\r\n        );\r\n    }\r\n    autoPrompt() {\r\n        if (this._prompt)\r\n            this.google.accounts.id.prompt(); // also display the One Tap dialog\r\n    }\r\n\r\n\r\n    handleCredentialResponse(response: any) {\r\n        this.onLoginResponse?.emit(response);\r\n        this.onLogin?.emit(response.credential);\r\n\r\n        // let payload = JwtHelper.decode(response.credential);\r\n        // console.log(\"ID: \" + payload.sub);\r\n        // console.log('Full Name: ' + payload.name);\r\n        // console.log('Given Name: ' + payload.given_name);\r\n        // console.log('Family Name: ' + payload.family_name);\r\n        // console.log(\"Image URL: \" + payload.picture);\r\n        // console.log(\"Email: \" + payload.email);\r\n    }\r\n}"]}
|
|
@@ -1,17 +1,16 @@
|
|
|
1
1
|
import { Component, Output, EventEmitter, Input, inject } from '@angular/core';
|
|
2
2
|
import { TranslateService } from '@ngx-translate/core';
|
|
3
3
|
import { CoreComponent } from '../../../components';
|
|
4
|
-
import { BootstrapHelper, ComponentType, Convert, handler, RandomHelper } from '../../../utils';
|
|
4
|
+
import { BootstrapHelper, ComponentType, Convert, handler, ObjectHelper, RandomHelper } from '../../../utils';
|
|
5
5
|
import { ValidEventArgs } from '../../../models/valid-event-args.model';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
import * as i1 from "@angular/common";
|
|
8
8
|
import * as i2 from "@ngx-translate/core";
|
|
9
|
-
let uniqueId = 0;
|
|
10
9
|
export class ZekModal extends CoreComponent {
|
|
11
10
|
constructor() {
|
|
12
11
|
super(...arguments);
|
|
13
12
|
this.translate = inject(TranslateService);
|
|
14
|
-
this._uniqueId = `zek-modal-${
|
|
13
|
+
this._uniqueId = `zek-modal-${this.uniqueId}`;
|
|
15
14
|
/** The unique ID for the radio button. */
|
|
16
15
|
this.id = this._uniqueId;
|
|
17
16
|
this.modalId = `${this.id}-modal`;
|
|
@@ -149,7 +148,11 @@ export class ZekModal extends CoreComponent {
|
|
|
149
148
|
getModalElement() {
|
|
150
149
|
return document.getElementById(this.modalId);
|
|
151
150
|
}
|
|
152
|
-
|
|
151
|
+
/**
|
|
152
|
+
* Creates with method new bootstrap.Modal(modalId, { backdrop: 'static' });
|
|
153
|
+
* @returns boostrap modal
|
|
154
|
+
*/
|
|
155
|
+
createModal() {
|
|
153
156
|
const modalEl = this.getModalElement();
|
|
154
157
|
return new bootstrap.Modal(modalEl, { backdrop: 'static' });
|
|
155
158
|
}
|
|
@@ -158,12 +161,12 @@ export class ZekModal extends CoreComponent {
|
|
|
158
161
|
}
|
|
159
162
|
// private isShown = false;
|
|
160
163
|
show(model) {
|
|
161
|
-
if (!model)
|
|
164
|
+
if (!ObjectHelper.isDefined(model))
|
|
162
165
|
model = {};
|
|
163
166
|
this.model = model;
|
|
164
167
|
// this.modal?.show();
|
|
165
168
|
if (!this._modal) {
|
|
166
|
-
this._modal = this.
|
|
169
|
+
this._modal = this.createModal();
|
|
167
170
|
}
|
|
168
171
|
if (this._modal) {
|
|
169
172
|
this._modal.show();
|
|
@@ -349,4 +352,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImpor
|
|
|
349
352
|
type: Component,
|
|
350
353
|
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\" (click)=\"cancel()\" 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}}\"\r\n (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\"\r\n (click)=\"cancel()\">\r\n <i class=\"fa-solid fa-ban\"></i> {{ 'Action.Cancel' | translate }}\r\n </button>\r\n <button type=\"button\" class=\"d-none\" id=\"{{cancelButtonId}}\" data-bs-dismiss=\"modal\"></button>\r\n </div>\r\n </div>\r\n </div>\r\n</div>" }]
|
|
351
354
|
}], ctorParameters: () => [] });
|
|
352
|
-
//# 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    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 = RandomHelper.randomHex();\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    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    @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<void>();\r\n\r\n    @Output() onHidden = new EventEmitter<void>();\r\n\r\n    @Output() onOk = new EventEmitter<any>();\r\n    @Output() onCancel = new EventEmitter<void>();\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\r\n    cancel(){\r\n        this.onCancel.emit();\r\n        this.hide();\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\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\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\" (click)=\"cancel()\" 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}}\"\r\n                    (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\"\r\n                    (click)=\"cancel()\">\r\n                    <i class=\"fa-solid fa-ban\"></i> {{ 'Action.Cancel' | translate }}\r\n                </button>\r\n                <button type=\"button\" class=\"d-none\" id=\"{{cancelButtonId}}\" data-bs-dismiss=\"modal\"></button>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>"]}
|
|
355
|
+
//# 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, ObjectHelper, 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\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    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-${this.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 = RandomHelper.randomHex();\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    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    @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<void>();\r\n\r\n    @Output() onHidden = new EventEmitter<void>();\r\n\r\n    @Output() onOk = new EventEmitter<any>();\r\n    @Output() onCancel = new EventEmitter<void>();\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    /**\r\n     * Creates  with method new bootstrap.Modal(modalId, { backdrop: 'static' });\r\n     * @returns boostrap modal\r\n     */\r\n    protected createModal() {\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 (!ObjectHelper.isDefined(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.createModal();\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\r\n    cancel() {\r\n        this.onCancel.emit();\r\n        this.hide();\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\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\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\" (click)=\"cancel()\" 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}}\"\r\n                    (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\"\r\n                    (click)=\"cancel()\">\r\n                    <i class=\"fa-solid fa-ban\"></i> {{ 'Action.Cancel' | translate }}\r\n                </button>\r\n                <button type=\"button\" class=\"d-none\" id=\"{{cancelButtonId}}\" data-bs-dismiss=\"modal\"></button>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>"]}
|
|
@@ -3,7 +3,6 @@ import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
|
3
3
|
import { CoreUiComponent } from '../../components/core-ui.component';
|
|
4
4
|
import { Convert } from '../../utils';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
|
-
let uniqueId = 0;
|
|
7
6
|
/**
|
|
8
7
|
* Provider Expression that allows zek-radio to register as a ControlValueAccessor. This
|
|
9
8
|
* allows it to support [(ngModel)] and ngControl.
|
|
@@ -18,7 +17,7 @@ export class ZekRadio extends CoreUiComponent {
|
|
|
18
17
|
constructor(_changeDetector, _renderer, _elementRef) {
|
|
19
18
|
super(_renderer, _elementRef);
|
|
20
19
|
this._changeDetector = _changeDetector;
|
|
21
|
-
this._uniqueId = `zek-radio-${
|
|
20
|
+
this._uniqueId = `zek-radio-${this.uniqueId}`;
|
|
22
21
|
/** The unique ID for the radio button. */
|
|
23
22
|
this.id = this._uniqueId;
|
|
24
23
|
this._inline = false;
|
|
@@ -131,4 +130,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImpor
|
|
|
131
130
|
}], checked: [{
|
|
132
131
|
type: Input
|
|
133
132
|
}] } });
|
|
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>"]}
|
|
133
|
+
//# 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\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-${this.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>"]}
|