zek 16.1.14 → 16.1.16

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.
@@ -4,16 +4,18 @@ 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;
7
8
  export class ZekGoogleLoginButton extends CoreComponent {
8
9
  constructor(client_id) {
9
10
  super();
10
11
  this.client_id = client_id;
12
+ this._uniqueId = `zek-google-button-container-${++uniqueId}`;
13
+ this.id = this._uniqueId;
11
14
  this._prompt = true;
12
15
  this._autoSelect = false;
13
16
  this._cancelOnTapOutside = true;
14
17
  this.onLoginResponse = new EventEmitter();
15
18
  this.onLogin = new EventEmitter();
16
- this._buttonContainer = 'google-login-container';
17
19
  this.onLoadComplete = (google) => {
18
20
  this.google = google;
19
21
  this.initialize();
@@ -49,14 +51,6 @@ export class ZekGoogleLoginButton extends CoreComponent {
49
51
  set text(v) {
50
52
  this._text = v;
51
53
  }
52
- get buttonContainer() {
53
- return this._buttonContainer;
54
- }
55
- set buttonContainer(v) {
56
- if (!v)
57
- throw new Error('buttonContainer is required');
58
- this._buttonContainer = v;
59
- }
60
54
  async init() {
61
55
  super.init();
62
56
  // await GoogleLoginButton.loadScript();
@@ -77,8 +71,10 @@ export class ZekGoogleLoginButton extends CoreComponent {
77
71
  auto_select: this._autoSelect,
78
72
  cancel_on_tap_outside: this._cancelOnTapOutside,
79
73
  });
80
- this.renderButton();
81
- this.autoPrompt();
74
+ setTimeout(() => {
75
+ this.renderButton();
76
+ this.autoPrompt();
77
+ });
82
78
  }
83
79
  renderButton() {
84
80
  let options = { theme: "outline", size: "large" };
@@ -86,7 +82,7 @@ export class ZekGoogleLoginButton extends CoreComponent {
86
82
  options.width = this._width;
87
83
  if (this._text)
88
84
  options.text = this._text;
89
- this.google.accounts.id.renderButton(document.getElementById(this._buttonContainer),
85
+ this.google.accounts.id.renderButton(document.getElementById(this.id),
90
86
  // this._elementRef.nativeElement.parentElement,
91
87
  options // customization attributes
92
88
  );
@@ -107,17 +103,22 @@ export class ZekGoogleLoginButton extends CoreComponent {
107
103
  // console.log("Email: " + payload.email);
108
104
  }
109
105
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: ZekGoogleLoginButton, deps: [{ token: GOOGLE_CLIENT_ID }], target: i0.ɵɵFactoryTarget.Directive }); }
110
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.7", type: ZekGoogleLoginButton, selector: "zek-google-login", inputs: { prompt: "prompt", autoSelect: "autoSelect", cancelOnTapOutside: "cancelOnTapOutside", width: "width", text: "text", buttonContainer: "buttonContainer" }, outputs: { onLoginResponse: "onLoginResponse", onLogin: "onLogin" }, usesInheritance: true, ngImport: i0 }); }
106
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.7", type: ZekGoogleLoginButton, selector: "zek-google-login", inputs: { id: "id", prompt: "prompt", autoSelect: "autoSelect", cancelOnTapOutside: "cancelOnTapOutside", width: "width", text: "text" }, outputs: { onLoginResponse: "onLoginResponse", onLogin: "onLogin" }, host: { properties: { "attr.id": "id" } }, usesInheritance: true, ngImport: i0 }); }
111
107
  }
112
108
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: ZekGoogleLoginButton, decorators: [{
113
109
  type: Directive,
114
110
  args: [{
115
111
  selector: 'zek-google-login',
112
+ host: {
113
+ '[attr.id]': 'id',
114
+ }
116
115
  }]
117
116
  }], ctorParameters: function () { return [{ type: undefined, decorators: [{
118
117
  type: Inject,
119
118
  args: [GOOGLE_CLIENT_ID]
120
- }] }]; }, propDecorators: { prompt: [{
119
+ }] }]; }, propDecorators: { id: [{
120
+ type: Input
121
+ }], prompt: [{
121
122
  type: Input
122
123
  }], autoSelect: [{
123
124
  type: Input
@@ -131,7 +132,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImpor
131
132
  type: Output
132
133
  }], onLogin: [{
133
134
  type: Output
134
- }], buttonContainer: [{
135
- type: Input
136
135
  }] } });
137
- //# 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, StringInput, NumberInput } from \"../../components\";\r\nimport { Convert } from \"../../utils\";\r\n\r\ndeclare let google: any;\r\n\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})\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 _prompt: boolean = 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: boolean = 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: boolean = 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 _buttonContainer = 'google-login-container';\r\n    @Input() get buttonContainer() {\r\n        return this._buttonContainer;\r\n    }\r\n    set buttonContainer(v: StringInput) {\r\n        if (!v)\r\n            throw new Error('buttonContainer is required');\r\n        this._buttonContainer = v;\r\n    }\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        this.renderButton();\r\n        this.autoPrompt();\r\n    }\r\n    renderButton() {\r\n        let 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._buttonContainer),\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}"]}
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: boolean = 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: boolean = 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: boolean = 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        let 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}"]}
@@ -28,8 +28,9 @@ export * from './select2';
28
28
  export * from './select2-multiple';
29
29
  export * from './sort';
30
30
  export * from './time';
31
+ export * from './tooltip';
31
32
  export * from './validator';
32
33
  export * from './validators';
33
34
  export * from './wizard';
34
35
  // export * from './'
35
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy96ZWsvc3JjL2xpYi9tb2R1bGVzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsT0FBTyxDQUFDO0FBQ3RCLGNBQWMsU0FBUyxDQUFDO0FBQ3hCLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxNQUFNLENBQUM7QUFDckIsY0FBYyxRQUFRLENBQUM7QUFDdkIsY0FBYyxZQUFZLENBQUM7QUFDM0IsY0FBYyxZQUFZLENBQUM7QUFDM0IsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLFFBQVEsQ0FBQztBQUN2QixjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLFdBQVcsQ0FBQztBQUMxQixjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLFdBQVcsQ0FBQztBQUMxQixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxRQUFRLENBQUM7QUFDdkIsY0FBYyxRQUFRLENBQUM7QUFDdkIsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxVQUFVLENBQUM7QUFFekIscUJBQXFCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hZ2UnO1xyXG5leHBvcnQgKiBmcm9tICcuL2FsZXJ0JztcclxuZXhwb3J0ICogZnJvbSAnLi9hdXRvY29tcGxldGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2JiJztcclxuZXhwb3J0ICogZnJvbSAnLi9jYXJkJztcclxuZXhwb3J0ICogZnJvbSAnLi9jYWxsYmFjayc7XHJcbmV4cG9ydCAqIGZyb20gJy4vZGF0ZS1hZ28nO1xyXG5leHBvcnQgKiBmcm9tICcuL2RhdGVwaWNrZXInO1xyXG5leHBvcnQgKiBmcm9tICcuL2VkaXQtdG9vbGJhcic7XHJcbmV4cG9ydCAqIGZyb20gJy4vZmlsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vZmlsZS12aWV3ZXInO1xyXG5leHBvcnQgKiBmcm9tICcuL2dvb2dsZS1sb2dpbi1idXR0b24nO1xyXG5leHBvcnQgKiBmcm9tICcuL2dyaWQtdG9vbGJhcic7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGlzdC10b29sYmFyJztcclxuZXhwb3J0ICogZnJvbSAnLi9sb2FkaW5nJztcclxuZXhwb3J0ICogZnJvbSAnLi9tb2RhbCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbnVtZXJpYyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vcGFnZS10aXRsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vcGFnZXInO1xyXG5leHBvcnQgKiBmcm9tICcuL3Bhc3N3b3JkJztcclxuZXhwb3J0ICogZnJvbSAnLi9wcm9ncmVzcyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vcmFkaW8nO1xyXG5leHBvcnQgKiBmcm9tICcuL3JlYWRvbmx5JztcclxuZXhwb3J0ICogZnJvbSAnLi9yZWNhcHRjaGEvaW5kZXgnO1xyXG5leHBvcnQgKiBmcm9tICcuL3NhZmUnO1xyXG5leHBvcnQgKiBmcm9tICcuL3NlbGVjdCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vc2VsZWN0Mic7XHJcbmV4cG9ydCAqIGZyb20gJy4vc2VsZWN0Mi1tdWx0aXBsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vc29ydCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vdGltZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vdmFsaWRhdG9yJztcclxuZXhwb3J0ICogZnJvbSAnLi92YWxpZGF0b3JzJztcclxuZXhwb3J0ICogZnJvbSAnLi93aXphcmQnO1xyXG5cclxuLy8gZXhwb3J0ICogZnJvbSAnLi8nIl19
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy96ZWsvc3JjL2xpYi9tb2R1bGVzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsT0FBTyxDQUFDO0FBQ3RCLGNBQWMsU0FBUyxDQUFDO0FBQ3hCLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxNQUFNLENBQUM7QUFDckIsY0FBYyxRQUFRLENBQUM7QUFDdkIsY0FBYyxZQUFZLENBQUM7QUFDM0IsY0FBYyxZQUFZLENBQUM7QUFDM0IsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLFFBQVEsQ0FBQztBQUN2QixjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLFdBQVcsQ0FBQztBQUMxQixjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLFdBQVcsQ0FBQztBQUMxQixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsUUFBUSxDQUFDO0FBQ3ZCLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxRQUFRLENBQUM7QUFDdkIsY0FBYyxRQUFRLENBQUM7QUFDdkIsY0FBYyxXQUFXLENBQUM7QUFDMUIsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxVQUFVLENBQUM7QUFFekIscUJBQXFCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hZ2UnO1xyXG5leHBvcnQgKiBmcm9tICcuL2FsZXJ0JztcclxuZXhwb3J0ICogZnJvbSAnLi9hdXRvY29tcGxldGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2JiJztcclxuZXhwb3J0ICogZnJvbSAnLi9jYXJkJztcclxuZXhwb3J0ICogZnJvbSAnLi9jYWxsYmFjayc7XHJcbmV4cG9ydCAqIGZyb20gJy4vZGF0ZS1hZ28nO1xyXG5leHBvcnQgKiBmcm9tICcuL2RhdGVwaWNrZXInO1xyXG5leHBvcnQgKiBmcm9tICcuL2VkaXQtdG9vbGJhcic7XHJcbmV4cG9ydCAqIGZyb20gJy4vZmlsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vZmlsZS12aWV3ZXInO1xyXG5leHBvcnQgKiBmcm9tICcuL2dvb2dsZS1sb2dpbi1idXR0b24nO1xyXG5leHBvcnQgKiBmcm9tICcuL2dyaWQtdG9vbGJhcic7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGlzdC10b29sYmFyJztcclxuZXhwb3J0ICogZnJvbSAnLi9sb2FkaW5nJztcclxuZXhwb3J0ICogZnJvbSAnLi9tb2RhbCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbnVtZXJpYyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vcGFnZS10aXRsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vcGFnZXInO1xyXG5leHBvcnQgKiBmcm9tICcuL3Bhc3N3b3JkJztcclxuZXhwb3J0ICogZnJvbSAnLi9wcm9ncmVzcyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vcmFkaW8nO1xyXG5leHBvcnQgKiBmcm9tICcuL3JlYWRvbmx5JztcclxuZXhwb3J0ICogZnJvbSAnLi9yZWNhcHRjaGEvaW5kZXgnO1xyXG5leHBvcnQgKiBmcm9tICcuL3NhZmUnO1xyXG5leHBvcnQgKiBmcm9tICcuL3NlbGVjdCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vc2VsZWN0Mic7XHJcbmV4cG9ydCAqIGZyb20gJy4vc2VsZWN0Mi1tdWx0aXBsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vc29ydCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vdGltZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vdG9vbHRpcCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vdmFsaWRhdG9yJztcclxuZXhwb3J0ICogZnJvbSAnLi92YWxpZGF0b3JzJztcclxuZXhwb3J0ICogZnJvbSAnLi93aXphcmQnO1xyXG5cclxuLy8gZXhwb3J0ICogZnJvbSAnLi8nIl19
@@ -0,0 +1,2 @@
1
+ export * from './tooltip';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy96ZWsvc3JjL2xpYi9tb2R1bGVzL3Rvb2x0aXAvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxXQUFXLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3Rvb2x0aXAnOyJdfQ==
@@ -0,0 +1,27 @@
1
+ import { Directive } from "@angular/core";
2
+ import { CoreComponent } from "../../components";
3
+ import * as i0 from "@angular/core";
4
+ export class ZekTooltip extends CoreComponent {
5
+ constructor(el) {
6
+ super();
7
+ this.el = el;
8
+ }
9
+ destroy() {
10
+ this._tooltip?.dispose();
11
+ this._tooltip = undefined;
12
+ return super.destroy();
13
+ }
14
+ ngAfterViewInit() {
15
+ this._tooltip = new bootstrap.Tooltip(this.el.nativeElement);
16
+ }
17
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: ZekTooltip, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
18
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.7", type: ZekTooltip, isStandalone: true, selector: "[zek-toltip]", usesInheritance: true, ngImport: i0 }); }
19
+ }
20
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: ZekTooltip, decorators: [{
21
+ type: Directive,
22
+ args: [{
23
+ standalone: true,
24
+ selector: '[zek-toltip]'
25
+ }]
26
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }]; } });
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3play9zcmMvbGliL21vZHVsZXMvdG9vbHRpcC90b29sdGlwLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBaUIsU0FBUyxFQUFjLE1BQU0sZUFBZSxDQUFDO0FBQ3JFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQzs7QUFRakQsTUFBTSxPQUFPLFVBQVcsU0FBUSxhQUFhO0lBRXpDLFlBQW9CLEVBQWM7UUFDOUIsS0FBSyxFQUFFLENBQUM7UUFEUSxPQUFFLEdBQUYsRUFBRSxDQUFZO0lBRWxDLENBQUM7SUFFUSxPQUFPO1FBQ1osSUFBSSxDQUFDLFFBQVEsRUFBRSxPQUFPLEVBQUUsQ0FBQztRQUN6QixJQUFJLENBQUMsUUFBUSxHQUFHLFNBQVMsQ0FBQztRQUMxQixPQUFPLEtBQUssQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUMzQixDQUFDO0lBRUQsZUFBZTtRQUNYLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxTQUFTLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDLENBQUM7SUFDakUsQ0FBQzs4R0FkUSxVQUFVO2tHQUFWLFVBQVU7OzJGQUFWLFVBQVU7a0JBSnRCLFNBQVM7bUJBQUM7b0JBQ1AsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRSxjQUFjO2lCQUMzQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFmdGVyVmlld0luaXQsIERpcmVjdGl2ZSwgRWxlbWVudFJlZiB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IENvcmVDb21wb25lbnQgfSBmcm9tIFwiLi4vLi4vY29tcG9uZW50c1wiO1xyXG5cclxuZGVjbGFyZSBsZXQgYm9vdHN0cmFwOiBhbnk7XHJcblxyXG5ARGlyZWN0aXZlKHtcclxuICAgIHN0YW5kYWxvbmU6IHRydWUsXHJcbiAgICBzZWxlY3RvcjogJ1t6ZWstdG9sdGlwXSdcclxufSlcclxuZXhwb3J0IGNsYXNzIFpla1Rvb2x0aXAgZXh0ZW5kcyBDb3JlQ29tcG9uZW50IGltcGxlbWVudHMgQWZ0ZXJWaWV3SW5pdCB7XHJcbiAgICBwcml2YXRlIF90b29sdGlwOiBhbnk7XHJcbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIGVsOiBFbGVtZW50UmVmKSB7XHJcbiAgICAgICAgc3VwZXIoKTtcclxuICAgIH1cclxuXHJcbiAgICBvdmVycmlkZSBkZXN0cm95KCkge1xyXG4gICAgICAgIHRoaXMuX3Rvb2x0aXA/LmRpc3Bvc2UoKTtcclxuICAgICAgICB0aGlzLl90b29sdGlwID0gdW5kZWZpbmVkO1xyXG4gICAgICAgIHJldHVybiBzdXBlci5kZXN0cm95KCk7XHJcbiAgICB9XHJcblxyXG4gICAgbmdBZnRlclZpZXdJbml0KCkge1xyXG4gICAgICAgIHRoaXMuX3Rvb2x0aXAgPSBuZXcgYm9vdHN0cmFwLlRvb2x0aXAodGhpcy5lbC5uYXRpdmVFbGVtZW50KTtcclxuICAgIH1cclxuXHJcbn0iXX0=
package/fesm2022/zek.mjs CHANGED
@@ -1926,7 +1926,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImpor
1926
1926
  type: Input
1927
1927
  }] } });
1928
1928
 
1929
- let uniqueId$3 = 0;
1929
+ let uniqueId$4 = 0;
1930
1930
  class CoreUiComponent extends CoreComponent {
1931
1931
  constructor(_renderer, _elementRef
1932
1932
  //private _changeDetector: ChangeDetectorRef
@@ -1943,7 +1943,7 @@ class CoreUiComponent extends CoreComponent {
1943
1943
  this._onTouched = () => { };
1944
1944
  this.change = new EventEmitter();
1945
1945
  this.changing = new EventEmitter();
1946
- this._name = `zek-${++uniqueId$3}`;
1946
+ this._name = `zek-${++uniqueId$4}`;
1947
1947
  this._isInitialized = false;
1948
1948
  this._value = null;
1949
1949
  this._readonly = false;
@@ -2971,7 +2971,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImpor
2971
2971
  }]
2972
2972
  }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.Router }]; } });
2973
2973
 
2974
- let uniqueId$2 = 0;
2974
+ let uniqueId$3 = 0;
2975
2975
  /**
2976
2976
  * Provider Expression that allows bb to register as a ControlValueAccessor. This
2977
2977
  * allows it to support [(ngModel)] and ngControl.
@@ -2985,7 +2985,7 @@ const ZEK_BB_CONTROL_VALUE_ACCESSOR = {
2985
2985
  class ZekButtonBrowse extends CoreUiComponent {
2986
2986
  constructor() {
2987
2987
  super(...arguments);
2988
- this._uniqueId = `zek-bb-${++uniqueId$2}`;
2988
+ this._uniqueId = `zek-bb-${++uniqueId$3}`;
2989
2989
  /** The unique ID for the bb. */
2990
2990
  this.id = this._uniqueId;
2991
2991
  this.filter = {};
@@ -4213,16 +4213,18 @@ function loadScript$1(onLoaded, url, nonce) {
4213
4213
  }
4214
4214
  const loader$1 = { loadScript: loadScript$1 };
4215
4215
 
4216
+ let uniqueId$2 = 0;
4216
4217
  class ZekGoogleLoginButton extends CoreComponent {
4217
4218
  constructor(client_id) {
4218
4219
  super();
4219
4220
  this.client_id = client_id;
4221
+ this._uniqueId = `zek-google-button-container-${++uniqueId$2}`;
4222
+ this.id = this._uniqueId;
4220
4223
  this._prompt = true;
4221
4224
  this._autoSelect = false;
4222
4225
  this._cancelOnTapOutside = true;
4223
4226
  this.onLoginResponse = new EventEmitter();
4224
4227
  this.onLogin = new EventEmitter();
4225
- this._buttonContainer = 'google-login-container';
4226
4228
  this.onLoadComplete = (google) => {
4227
4229
  this.google = google;
4228
4230
  this.initialize();
@@ -4258,14 +4260,6 @@ class ZekGoogleLoginButton extends CoreComponent {
4258
4260
  set text(v) {
4259
4261
  this._text = v;
4260
4262
  }
4261
- get buttonContainer() {
4262
- return this._buttonContainer;
4263
- }
4264
- set buttonContainer(v) {
4265
- if (!v)
4266
- throw new Error('buttonContainer is required');
4267
- this._buttonContainer = v;
4268
- }
4269
4263
  async init() {
4270
4264
  super.init();
4271
4265
  // await GoogleLoginButton.loadScript();
@@ -4286,8 +4280,10 @@ class ZekGoogleLoginButton extends CoreComponent {
4286
4280
  auto_select: this._autoSelect,
4287
4281
  cancel_on_tap_outside: this._cancelOnTapOutside,
4288
4282
  });
4289
- this.renderButton();
4290
- this.autoPrompt();
4283
+ setTimeout(() => {
4284
+ this.renderButton();
4285
+ this.autoPrompt();
4286
+ });
4291
4287
  }
4292
4288
  renderButton() {
4293
4289
  let options = { theme: "outline", size: "large" };
@@ -4295,7 +4291,7 @@ class ZekGoogleLoginButton extends CoreComponent {
4295
4291
  options.width = this._width;
4296
4292
  if (this._text)
4297
4293
  options.text = this._text;
4298
- this.google.accounts.id.renderButton(document.getElementById(this._buttonContainer),
4294
+ this.google.accounts.id.renderButton(document.getElementById(this.id),
4299
4295
  // this._elementRef.nativeElement.parentElement,
4300
4296
  options // customization attributes
4301
4297
  );
@@ -4316,17 +4312,22 @@ class ZekGoogleLoginButton extends CoreComponent {
4316
4312
  // console.log("Email: " + payload.email);
4317
4313
  }
4318
4314
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: ZekGoogleLoginButton, deps: [{ token: GOOGLE_CLIENT_ID }], target: i0.ɵɵFactoryTarget.Directive }); }
4319
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.7", type: ZekGoogleLoginButton, selector: "zek-google-login", inputs: { prompt: "prompt", autoSelect: "autoSelect", cancelOnTapOutside: "cancelOnTapOutside", width: "width", text: "text", buttonContainer: "buttonContainer" }, outputs: { onLoginResponse: "onLoginResponse", onLogin: "onLogin" }, usesInheritance: true, ngImport: i0 }); }
4315
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.7", type: ZekGoogleLoginButton, selector: "zek-google-login", inputs: { id: "id", prompt: "prompt", autoSelect: "autoSelect", cancelOnTapOutside: "cancelOnTapOutside", width: "width", text: "text" }, outputs: { onLoginResponse: "onLoginResponse", onLogin: "onLogin" }, host: { properties: { "attr.id": "id" } }, usesInheritance: true, ngImport: i0 }); }
4320
4316
  }
4321
4317
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: ZekGoogleLoginButton, decorators: [{
4322
4318
  type: Directive,
4323
4319
  args: [{
4324
4320
  selector: 'zek-google-login',
4321
+ host: {
4322
+ '[attr.id]': 'id',
4323
+ }
4325
4324
  }]
4326
4325
  }], ctorParameters: function () { return [{ type: undefined, decorators: [{
4327
4326
  type: Inject,
4328
4327
  args: [GOOGLE_CLIENT_ID]
4329
- }] }]; }, propDecorators: { prompt: [{
4328
+ }] }]; }, propDecorators: { id: [{
4329
+ type: Input
4330
+ }], prompt: [{
4330
4331
  type: Input
4331
4332
  }], autoSelect: [{
4332
4333
  type: Input
@@ -4340,8 +4341,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImpor
4340
4341
  type: Output
4341
4342
  }], onLogin: [{
4342
4343
  type: Output
4343
- }], buttonContainer: [{
4344
- type: Input
4345
4344
  }] } });
4346
4345
 
4347
4346
  class ZekGoogleLoginModule {
@@ -6246,6 +6245,30 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImpor
6246
6245
  type: Input
6247
6246
  }] } });
6248
6247
 
6248
+ class ZekTooltip extends CoreComponent {
6249
+ constructor(el) {
6250
+ super();
6251
+ this.el = el;
6252
+ }
6253
+ destroy() {
6254
+ this._tooltip?.dispose();
6255
+ this._tooltip = undefined;
6256
+ return super.destroy();
6257
+ }
6258
+ ngAfterViewInit() {
6259
+ this._tooltip = new bootstrap.Tooltip(this.el.nativeElement);
6260
+ }
6261
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: ZekTooltip, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
6262
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.7", type: ZekTooltip, isStandalone: true, selector: "[zek-toltip]", usesInheritance: true, ngImport: i0 }); }
6263
+ }
6264
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: ZekTooltip, decorators: [{
6265
+ type: Directive,
6266
+ args: [{
6267
+ standalone: true,
6268
+ selector: '[zek-toltip]'
6269
+ }]
6270
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }]; } });
6271
+
6249
6272
  // export const range = (range?: Array<number> | null): ValidatorFn => {
6250
6273
  // return (control: AbstractControl): { [key: string]: any } | null => {
6251
6274
  // if (!range) return null;
@@ -6572,5 +6595,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImpor
6572
6595
  * Generated bundle index. Do not edit.
6573
6596
  */
6574
6597
 
6575
- export { API_BASE_URL, AgePipe, Alert, AlertService, AppBaseModule, ArrayHelper, AuthGuardService, AuthService, Base64Helper, BaseAlert, BaseComponent, BaseService, BitwiseHelper, BootstrapHelper, ButtonBrowseModalBaseComponent, ButtonBrowseModule, Color, ComponentType, Convert, CoreComponent, CoreUiComponent, CrudService, CssHelper, CustomHttpParamEncoder, DATE_FORMAT, DateAgoPipe, DateHelper, DateValueAccessor, DatepickerModule, EditBase, EditBaseComponent, EditComponent, EditFormComponent, FileBase, FileBytes, FileHelper, FileString, FilterBase, FilterHelper, GOOGLE_CLIENT_ID, Gender, HtmlHelper, HttpErrorHandler, JwtHelper, KeyPair, KeyPairChecked, KeyPairEx, KeyPairRequired, LANGUAGE, ListBase, ListBaseComponent, MATCH_VALIDATOR, MatchValidator, MathHelper, Month, NumericDirective, ObjectHelper, OverlapHelper, PagedList, PagedListBase, Pager, PagerBase, PagerHelper, PeriodRelation, PrintType, RANGE_VALIDATOR, RECAPTCHA_SITE_KEY, RandomHelper, RangeValidator, ReCaptchaService, RecaptchaModule, Select2Module, StorageHelper, StringHelper, TimeHelper, TimeModule, TimePipe, TimerService, TmpHelper, Toast, Tree, UrlHelper, ValidEventArgs, ValidationHelper, Validators, ValidatorsModule, WebApiClient, WebApiModule, ZekAlert, ZekApproveModal, ZekAutoComplete, ZekButtonBrowse, ZekButtonBrowseModalToolbar, ZekCallbackPipe, ZekCard, ZekDeleteModal, ZekDisapproveModal, ZekEditToolbar, ZekFieldValidator, ZekFileSizePipe, ZekFileViewer, ZekFilterModal, ZekGoogleLoginButton, ZekGoogleLoginModule, ZekGridToolbar, ZekGridToolbarBar, ZekListToolbar, ZekLoading, ZekLoadingModule, ZekModal, ZekModalModule, ZekPageTitle, ZekPager, ZekPassword, ZekProgress, ZekRadio, ZekReadOnlyDirective, ZekRestoreModal, ZekSafePipe, ZekSelect2, ZekSelect2Multiple, ZekSelectModule, ZekSelectMultiple, ZekSort, ZekSortButtonGroup, ZekSubmitModal, ZekSumModal, ZekToast, ZekValidation, ZekWizard, ZekWizard2, firstBy, handler, matchValidator, nullValidator, rangeValidator };
6598
+ export { API_BASE_URL, AgePipe, Alert, AlertService, AppBaseModule, ArrayHelper, AuthGuardService, AuthService, Base64Helper, BaseAlert, BaseComponent, BaseService, BitwiseHelper, BootstrapHelper, ButtonBrowseModalBaseComponent, ButtonBrowseModule, Color, ComponentType, Convert, CoreComponent, CoreUiComponent, CrudService, CssHelper, CustomHttpParamEncoder, DATE_FORMAT, DateAgoPipe, DateHelper, DateValueAccessor, DatepickerModule, EditBase, EditBaseComponent, EditComponent, EditFormComponent, FileBase, FileBytes, FileHelper, FileString, FilterBase, FilterHelper, GOOGLE_CLIENT_ID, Gender, HtmlHelper, HttpErrorHandler, JwtHelper, KeyPair, KeyPairChecked, KeyPairEx, KeyPairRequired, LANGUAGE, ListBase, ListBaseComponent, MATCH_VALIDATOR, MatchValidator, MathHelper, Month, NumericDirective, ObjectHelper, OverlapHelper, PagedList, PagedListBase, Pager, PagerBase, PagerHelper, PeriodRelation, PrintType, RANGE_VALIDATOR, RECAPTCHA_SITE_KEY, RandomHelper, RangeValidator, ReCaptchaService, RecaptchaModule, Select2Module, StorageHelper, StringHelper, TimeHelper, TimeModule, TimePipe, TimerService, TmpHelper, Toast, Tree, UrlHelper, ValidEventArgs, ValidationHelper, Validators, ValidatorsModule, WebApiClient, WebApiModule, ZekAlert, ZekApproveModal, ZekAutoComplete, ZekButtonBrowse, ZekButtonBrowseModalToolbar, ZekCallbackPipe, ZekCard, ZekDeleteModal, ZekDisapproveModal, ZekEditToolbar, ZekFieldValidator, ZekFileSizePipe, ZekFileViewer, ZekFilterModal, ZekGoogleLoginButton, ZekGoogleLoginModule, ZekGridToolbar, ZekGridToolbarBar, ZekListToolbar, ZekLoading, ZekLoadingModule, ZekModal, ZekModalModule, ZekPageTitle, ZekPager, ZekPassword, ZekProgress, ZekRadio, ZekReadOnlyDirective, ZekRestoreModal, ZekSafePipe, ZekSelect2, ZekSelect2Multiple, ZekSelectModule, ZekSelectMultiple, ZekSort, ZekSortButtonGroup, ZekSubmitModal, ZekSumModal, ZekToast, ZekTooltip, ZekValidation, ZekWizard, ZekWizard2, firstBy, handler, matchValidator, nullValidator, rangeValidator };
6576
6599
  //# sourceMappingURL=zek.mjs.map