zek 16.1.0 → 16.1.2

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/README.md CHANGED
@@ -1,24 +1,24 @@
1
- # Zek
2
-
3
- This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 16.1.0.
4
-
5
- ## Code scaffolding
6
-
7
- Run `ng generate component component-name --project zek` to generate a new component. You can also use `ng generate directive|pipe|service|class|guard|interface|enum|module --project zek`.
8
- > Note: Don't forget to add `--project zek` or else it will be added to the default project in your `angular.json` file.
9
-
10
- ## Build
11
-
12
- Run `ng build zek` to build the project. The build artifacts will be stored in the `dist/` directory.
13
-
14
- ## Publishing
15
-
16
- After building your library with `ng build zek`, go to the dist folder `cd dist/zek` and run `npm publish`.
17
-
18
- ## Running unit tests
19
-
20
- Run `ng test zek` to execute the unit tests via [Karma](https://karma-runner.github.io).
21
-
22
- ## Further help
23
-
24
- To get more help on the Angular CLI use `ng help` or go check out the [Angular CLI Overview and Command Reference](https://angular.io/cli) page.
1
+ # Zek
2
+
3
+ This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 16.1.0.
4
+
5
+ ## Code scaffolding
6
+
7
+ Run `ng generate component component-name --project zek` to generate a new component. You can also use `ng generate directive|pipe|service|class|guard|interface|enum|module --project zek`.
8
+ > Note: Don't forget to add `--project zek` or else it will be added to the default project in your `angular.json` file.
9
+
10
+ ## Build
11
+
12
+ Run `ng build zek` to build the project. The build artifacts will be stored in the `dist/` directory.
13
+
14
+ ## Publishing
15
+
16
+ After building your library with `ng build zek`, go to the dist folder `cd dist/zek` and run `npm publish`.
17
+
18
+ ## Running unit tests
19
+
20
+ Run `ng test zek` to execute the unit tests via [Karma](https://karma-runner.github.io).
21
+
22
+ ## Further help
23
+
24
+ To get more help on the Angular CLI use `ng help` or go check out the [Angular CLI Overview and Command Reference](https://angular.io/cli) page.
@@ -9,6 +9,8 @@ export class ZekGoogleLoginButton extends CoreComponent {
9
9
  super();
10
10
  this.client_id = client_id;
11
11
  this._prompt = true;
12
+ this._autoSelect = false;
13
+ this._cancelOnTapOutside = true;
12
14
  this.onLoginResponse = new EventEmitter();
13
15
  this.onLogin = new EventEmitter();
14
16
  this._buttonContainer = 'google-login-container';
@@ -23,6 +25,30 @@ export class ZekGoogleLoginButton extends CoreComponent {
23
25
  set prompt(v) {
24
26
  this._prompt = Convert.toBooleanProperty(v);
25
27
  }
28
+ get autoSelect() {
29
+ return this._autoSelect;
30
+ }
31
+ set autoSelect(v) {
32
+ this._autoSelect = Convert.toBooleanProperty(v);
33
+ }
34
+ get cancelOnTapOutside() {
35
+ return this._cancelOnTapOutside;
36
+ }
37
+ set cancelOnTapOutside(v) {
38
+ this._cancelOnTapOutside = Convert.toBooleanProperty(v);
39
+ }
40
+ get width() {
41
+ return this._width;
42
+ }
43
+ set width(v) {
44
+ this._width = v;
45
+ }
46
+ get text() {
47
+ return this._text;
48
+ }
49
+ set text(v) {
50
+ this._text = v;
51
+ }
26
52
  get buttonContainer() {
27
53
  return this._buttonContainer;
28
54
  }
@@ -47,15 +73,22 @@ export class ZekGoogleLoginButton extends CoreComponent {
47
73
  client_id: this.client_id,
48
74
  callback: (response) => {
49
75
  this.handleCredentialResponse(response);
50
- }
76
+ },
77
+ auto_select: this._autoSelect,
78
+ cancel_on_tap_outside: this._cancelOnTapOutside,
51
79
  });
52
80
  this.renderButton();
53
81
  this.autoPrompt();
54
82
  }
55
83
  renderButton() {
84
+ let options = { theme: "outline", size: "large" };
85
+ if (this._width)
86
+ options.width = this._width;
87
+ if (this._text)
88
+ options.text = this._text;
56
89
  this.google.accounts.id.renderButton(document.getElementById(this._buttonContainer),
57
90
  // this._elementRef.nativeElement.parentElement,
58
- { theme: "outline", size: "large" } // customization attributes
91
+ options // customization attributes
59
92
  );
60
93
  }
61
94
  autoPrompt() {
@@ -74,7 +107,7 @@ export class ZekGoogleLoginButton extends CoreComponent {
74
107
  // console.log("Email: " + payload.email);
75
108
  }
76
109
  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 }); }
77
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.7", type: ZekGoogleLoginButton, selector: "zek-google-login", inputs: { prompt: "prompt", buttonContainer: "buttonContainer" }, outputs: { onLoginResponse: "onLoginResponse", onLogin: "onLogin" }, usesInheritance: true, ngImport: i0 }); }
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 }); }
78
111
  }
79
112
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: ZekGoogleLoginButton, decorators: [{
80
113
  type: Directive,
@@ -86,6 +119,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImpor
86
119
  args: [GOOGLE_CLIENT_ID]
87
120
  }] }]; }, propDecorators: { prompt: [{
88
121
  type: Input
122
+ }], autoSelect: [{
123
+ type: Input
124
+ }], cancelOnTapOutside: [{
125
+ type: Input
126
+ }], width: [{
127
+ type: Input
128
+ }], text: [{
129
+ type: Input
89
130
  }], onLoginResponse: [{
90
131
  type: Output
91
132
  }], onLogin: [{
@@ -93,4 +134,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImpor
93
134
  }], buttonContainer: [{
94
135
  type: Input
95
136
  }] } });
96
- //# 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 } 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\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    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\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        });\r\n\r\n        this.renderButton();\r\n        this.autoPrompt();\r\n    }\r\n    renderButton() {\r\n        this.google.accounts.id.renderButton(\r\n            document.getElementById(this._buttonContainer),\r\n            // this._elementRef.nativeElement.parentElement,\r\n            { theme: \"outline\", size: \"large\" }  // 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}"]}
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}"]}
@@ -3,5 +3,8 @@ export class MathHelper {
3
3
  return Math.round(Number(value) * Math.pow(10, decimals)) / (Math.pow(10, decimals));
4
4
  }
5
5
  ;
6
+ static clamp(v, min, max) {
7
+ return Math.max(min, Math.min(max, v));
8
+ }
6
9
  }
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWF0aC1oZWxwZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy96ZWsvc3JjL2xpYi91dGlscy9tYXRoLWhlbHBlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLE9BQU8sVUFBVTtJQUNuQixNQUFNLENBQUMsS0FBSyxDQUFDLEtBQWEsRUFBRSxXQUFtQixDQUFDO1FBQzVDLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLEVBQUUsUUFBUSxDQUFDLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxFQUFFLFFBQVEsQ0FBQyxDQUFDLENBQUM7SUFDekYsQ0FBQztJQUFBLENBQUM7Q0FDTCIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBNYXRoSGVscGVyIHtcclxuICAgIHN0YXRpYyByb3VuZCh2YWx1ZTogbnVtYmVyLCBkZWNpbWFsczogbnVtYmVyID0gMCk6IG51bWJlciB7XHJcbiAgICAgICAgcmV0dXJuIE1hdGgucm91bmQoTnVtYmVyKHZhbHVlKSAqIE1hdGgucG93KDEwLCBkZWNpbWFscykpIC8gKE1hdGgucG93KDEwLCBkZWNpbWFscykpO1xyXG4gICAgfTtcclxufSJdfQ==
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWF0aC1oZWxwZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy96ZWsvc3JjL2xpYi91dGlscy9tYXRoLWhlbHBlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLE9BQU8sVUFBVTtJQUNuQixNQUFNLENBQUMsS0FBSyxDQUFDLEtBQWEsRUFBRSxXQUFtQixDQUFDO1FBQzVDLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLEVBQUUsUUFBUSxDQUFDLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxFQUFFLFFBQVEsQ0FBQyxDQUFDLENBQUM7SUFDekYsQ0FBQztJQUFBLENBQUM7SUFHRixNQUFNLENBQUMsS0FBSyxDQUFDLENBQVMsRUFBRSxHQUFXLEVBQUUsR0FBVztRQUM1QyxPQUFPLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxFQUFFLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDM0MsQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNsYXNzIE1hdGhIZWxwZXIge1xyXG4gICAgc3RhdGljIHJvdW5kKHZhbHVlOiBudW1iZXIsIGRlY2ltYWxzOiBudW1iZXIgPSAwKTogbnVtYmVyIHtcclxuICAgICAgICByZXR1cm4gTWF0aC5yb3VuZChOdW1iZXIodmFsdWUpICogTWF0aC5wb3coMTAsIGRlY2ltYWxzKSkgLyAoTWF0aC5wb3coMTAsIGRlY2ltYWxzKSk7XHJcbiAgICB9O1xyXG5cclxuXHJcbiAgICBzdGF0aWMgY2xhbXAodjogbnVtYmVyLCBtaW46IG51bWJlciwgbWF4OiBudW1iZXIpIHtcclxuICAgICAgICByZXR1cm4gTWF0aC5tYXgobWluLCBNYXRoLm1pbihtYXgsIHYpKTtcclxuICAgIH1cclxufSJdfQ==
package/fesm2022/zek.mjs CHANGED
@@ -920,6 +920,9 @@ class MathHelper {
920
920
  return Math.round(Number(value) * Math.pow(10, decimals)) / (Math.pow(10, decimals));
921
921
  }
922
922
  ;
923
+ static clamp(v, min, max) {
924
+ return Math.max(min, Math.min(max, v));
925
+ }
923
926
  }
924
927
 
925
928
  class PagerHelper {
@@ -4371,6 +4374,8 @@ class ZekGoogleLoginButton extends CoreComponent {
4371
4374
  super();
4372
4375
  this.client_id = client_id;
4373
4376
  this._prompt = true;
4377
+ this._autoSelect = false;
4378
+ this._cancelOnTapOutside = true;
4374
4379
  this.onLoginResponse = new EventEmitter();
4375
4380
  this.onLogin = new EventEmitter();
4376
4381
  this._buttonContainer = 'google-login-container';
@@ -4385,6 +4390,30 @@ class ZekGoogleLoginButton extends CoreComponent {
4385
4390
  set prompt(v) {
4386
4391
  this._prompt = Convert.toBooleanProperty(v);
4387
4392
  }
4393
+ get autoSelect() {
4394
+ return this._autoSelect;
4395
+ }
4396
+ set autoSelect(v) {
4397
+ this._autoSelect = Convert.toBooleanProperty(v);
4398
+ }
4399
+ get cancelOnTapOutside() {
4400
+ return this._cancelOnTapOutside;
4401
+ }
4402
+ set cancelOnTapOutside(v) {
4403
+ this._cancelOnTapOutside = Convert.toBooleanProperty(v);
4404
+ }
4405
+ get width() {
4406
+ return this._width;
4407
+ }
4408
+ set width(v) {
4409
+ this._width = v;
4410
+ }
4411
+ get text() {
4412
+ return this._text;
4413
+ }
4414
+ set text(v) {
4415
+ this._text = v;
4416
+ }
4388
4417
  get buttonContainer() {
4389
4418
  return this._buttonContainer;
4390
4419
  }
@@ -4409,15 +4438,22 @@ class ZekGoogleLoginButton extends CoreComponent {
4409
4438
  client_id: this.client_id,
4410
4439
  callback: (response) => {
4411
4440
  this.handleCredentialResponse(response);
4412
- }
4441
+ },
4442
+ auto_select: this._autoSelect,
4443
+ cancel_on_tap_outside: this._cancelOnTapOutside,
4413
4444
  });
4414
4445
  this.renderButton();
4415
4446
  this.autoPrompt();
4416
4447
  }
4417
4448
  renderButton() {
4449
+ let options = { theme: "outline", size: "large" };
4450
+ if (this._width)
4451
+ options.width = this._width;
4452
+ if (this._text)
4453
+ options.text = this._text;
4418
4454
  this.google.accounts.id.renderButton(document.getElementById(this._buttonContainer),
4419
4455
  // this._elementRef.nativeElement.parentElement,
4420
- { theme: "outline", size: "large" } // customization attributes
4456
+ options // customization attributes
4421
4457
  );
4422
4458
  }
4423
4459
  autoPrompt() {
@@ -4436,7 +4472,7 @@ class ZekGoogleLoginButton extends CoreComponent {
4436
4472
  // console.log("Email: " + payload.email);
4437
4473
  }
4438
4474
  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 }); }
4439
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.7", type: ZekGoogleLoginButton, selector: "zek-google-login", inputs: { prompt: "prompt", buttonContainer: "buttonContainer" }, outputs: { onLoginResponse: "onLoginResponse", onLogin: "onLogin" }, usesInheritance: true, ngImport: i0 }); }
4475
+ 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 }); }
4440
4476
  }
4441
4477
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: ZekGoogleLoginButton, decorators: [{
4442
4478
  type: Directive,
@@ -4448,6 +4484,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImpor
4448
4484
  args: [GOOGLE_CLIENT_ID]
4449
4485
  }] }]; }, propDecorators: { prompt: [{
4450
4486
  type: Input
4487
+ }], autoSelect: [{
4488
+ type: Input
4489
+ }], cancelOnTapOutside: [{
4490
+ type: Input
4491
+ }], width: [{
4492
+ type: Input
4493
+ }], text: [{
4494
+ type: Input
4451
4495
  }], onLoginResponse: [{
4452
4496
  type: Output
4453
4497
  }], onLogin: [{