turbogui-angular 11.0.2 → 12.1.0
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/main/controller/browser.service.mjs +48 -48
- package/esm2022/main/controller/dialog.service.mjs +327 -324
- package/esm2022/main/controller/globalerror.service.mjs +68 -68
- package/esm2022/main/controller/http.service.mjs +70 -70
- package/esm2022/main/controller/httpservice/HTTPServiceGetRequest.mjs +14 -14
- package/esm2022/main/controller/httpservice/HTTPServicePostRequest.mjs +14 -14
- package/esm2022/main/controller/localization.service.mjs +22 -22
- package/esm2022/main/controller/notification.service.mjs +56 -56
- package/esm2022/main/controller/user.service.mjs +124 -124
- package/esm2022/main/controller/views.service.mjs +113 -113
- package/esm2022/main/managers/DelayedMethodCallManager.mjs +69 -69
- package/esm2022/main/model/classes/GUINotification.mjs +31 -31
- package/esm2022/main/model/classes/View.mjs +33 -33
- package/esm2022/main/model/classes/ViewModel.mjs +13 -13
- package/esm2022/main/model/classes/ViewService.mjs +27 -27
- package/esm2022/main/model/modules/turbogui-angular.module.mjs +140 -140
- package/esm2022/main/view/animations/fade.animation.mjs +35 -35
- package/esm2022/main/view/components/busy-state-base/busy-state-base.component.mjs +38 -38
- package/esm2022/main/view/components/button-base/button-base.component.mjs +180 -180
- package/esm2022/main/view/components/button-container/button-container.component.mjs +34 -34
- package/esm2022/main/view/components/button-image/button-image.component.mjs +47 -47
- package/esm2022/main/view/components/dialog-base/dialog-base.component.mjs +13 -13
- package/esm2022/main/view/components/dialog-error/dialog-error.component.mjs +41 -41
- package/esm2022/main/view/components/dialog-multiple-option/dialog-multiple-option.component.mjs +38 -38
- package/esm2022/main/view/components/dialog-options-base/dialog-options-base.component.mjs +14 -14
- package/esm2022/main/view/components/dialog-single-option/dialog-single-option.component.mjs +41 -41
- package/esm2022/main/view/components/dialog-single-selection-list/dialog-single-selection-list.component.mjs +112 -112
- package/esm2022/main/view/components/dialog-two-option/dialog-two-option.component.mjs +42 -42
- package/esm2022/main/view/components/views-container/views-container.component.mjs +70 -70
- package/esm2022/main/view/directives/AutoFocusOnDisplayDirective.mjs +39 -39
- package/esm2022/main/view/directives/AutoSelectTextOnFocusDirective.mjs +39 -39
- package/esm2022/main/view/directives/ElementCreatedDirective.mjs +42 -42
- package/esm2022/main/view/directives/ElementDestroyedDirective.mjs +42 -42
- package/esm2022/public_api.mjs +43 -43
- package/esm2022/turbogui-angular.mjs +4 -4
- package/fesm2022/turbogui-angular.mjs +1865 -1862
- package/fesm2022/turbogui-angular.mjs.map +1 -1
- package/index.d.ts +5 -5
- package/main/controller/browser.service.d.ts +29 -29
- package/main/controller/dialog.service.d.ts +186 -184
- package/main/controller/dialog.service.d.ts.map +1 -1
- package/main/controller/globalerror.service.d.ts +54 -54
- package/main/controller/http.service.d.ts +37 -37
- package/main/controller/httpservice/HTTPServiceGetRequest.d.ts +14 -14
- package/main/controller/httpservice/HTTPServicePostRequest.d.ts +14 -14
- package/main/controller/localization.service.d.ts +9 -9
- package/main/controller/notification.service.d.ts +36 -36
- package/main/controller/user.service.d.ts +57 -57
- package/main/controller/views.service.d.ts +71 -71
- package/main/managers/DelayedMethodCallManager.d.ts +51 -51
- package/main/model/classes/GUINotification.d.ts +27 -27
- package/main/model/classes/View.d.ts +39 -39
- package/main/model/classes/ViewModel.d.ts +13 -13
- package/main/model/classes/ViewService.d.ts +26 -26
- package/main/model/modules/turbogui-angular.module.d.ts +28 -28
- package/main/view/animations/fade.animation.d.ts +16 -16
- package/main/view/components/busy-state-base/busy-state-base.component.d.ts +18 -18
- package/main/view/components/button-base/button-base.component.d.ts +94 -94
- package/main/view/components/button-container/button-container.component.d.ts +13 -13
- package/main/view/components/button-image/button-image.component.d.ts +31 -31
- package/main/view/components/dialog-base/dialog-base.component.d.ts +13 -13
- package/main/view/components/dialog-error/dialog-error.component.d.ts +13 -13
- package/main/view/components/dialog-multiple-option/dialog-multiple-option.component.d.ts +13 -13
- package/main/view/components/dialog-options-base/dialog-options-base.component.d.ts +14 -14
- package/main/view/components/dialog-single-option/dialog-single-option.component.d.ts +13 -13
- package/main/view/components/dialog-single-selection-list/dialog-single-selection-list.component.d.ts +62 -62
- package/main/view/components/dialog-two-option/dialog-two-option.component.d.ts +14 -14
- package/main/view/components/views-container/views-container.component.d.ts +45 -45
- package/main/view/directives/AutoFocusOnDisplayDirective.d.ts +20 -20
- package/main/view/directives/AutoSelectTextOnFocusDirective.d.ts +19 -19
- package/main/view/directives/ElementCreatedDirective.d.ts +23 -23
- package/main/view/directives/ElementDestroyedDirective.d.ts +23 -23
- package/package.json +6 -6
- package/public_api.d.ts +40 -40
|
@@ -1,180 +1,180 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* TurboGUI is A library that helps with the most common and generic UI elements and functionalities
|
|
3
|
-
*
|
|
4
|
-
* Website : -> http://www.turbogui.org
|
|
5
|
-
* License : -> Licensed under the Apache License, Version 2.0. You may not use this file except in compliance with the License.
|
|
6
|
-
* License Url : -> http://www.apache.org/licenses/LICENSE-2.0
|
|
7
|
-
* CopyRight : -> Copyright 2018 Edertone Advanded Solutions. https://www.edertone.com
|
|
8
|
-
*/
|
|
9
|
-
import { HostBinding, HostListener, Input, Directive } from '@angular/core';
|
|
10
|
-
import * as i0 from "@angular/core";
|
|
11
|
-
/**
|
|
12
|
-
* This is the base class for all button components
|
|
13
|
-
*/
|
|
14
|
-
export class ButtonBaseComponent {
|
|
15
|
-
constructor() {
|
|
16
|
-
/**
|
|
17
|
-
* Defines the actual opacity that is binded on the html part
|
|
18
|
-
*/
|
|
19
|
-
this.currentOpacity = .7;
|
|
20
|
-
/**
|
|
21
|
-
* Defines the actual scale that is binded on the html part
|
|
22
|
-
*/
|
|
23
|
-
this.currentScale = 'scale(1)';
|
|
24
|
-
/**
|
|
25
|
-
* Defines if the button can be clicked or not
|
|
26
|
-
*/
|
|
27
|
-
this.pointerEvents = 'initial';
|
|
28
|
-
/**
|
|
29
|
-
* Specifies if the button animations must rollback when the user releases the mouse or pointer after pressing it
|
|
30
|
-
*/
|
|
31
|
-
this.releaseOnMouseUp = true;
|
|
32
|
-
/**
|
|
33
|
-
* Specifies the amount of milliseconds that the button will vibrate when it gets clicked (only on compatible devices and browsers)
|
|
34
|
-
* Set it to 0 to disable click vibration
|
|
35
|
-
*/
|
|
36
|
-
this.vibrateOnClick = 25;
|
|
37
|
-
/**
|
|
38
|
-
* Defines the button opacity when it is not clicked
|
|
39
|
-
*/
|
|
40
|
-
this.defaultOpacity = .7;
|
|
41
|
-
/**
|
|
42
|
-
* Defines the image scale when it is not clicked
|
|
43
|
-
*/
|
|
44
|
-
this.defaultScale = 1;
|
|
45
|
-
/**
|
|
46
|
-
* Defines the button opacity when it is hovered
|
|
47
|
-
*/
|
|
48
|
-
this.hoverOpacity = .8;
|
|
49
|
-
/**
|
|
50
|
-
* Defines the image scale when it is hovered
|
|
51
|
-
*/
|
|
52
|
-
this.hoverScale = 1;
|
|
53
|
-
/**
|
|
54
|
-
* Defines the button opacity when it is clicked
|
|
55
|
-
*/
|
|
56
|
-
this.clickOpacity = 1;
|
|
57
|
-
/**
|
|
58
|
-
* Defines the image scale when it is clicked
|
|
59
|
-
*/
|
|
60
|
-
this.clickScale = 1;
|
|
61
|
-
/**
|
|
62
|
-
* Defines the button opacity when it is disabled
|
|
63
|
-
*/
|
|
64
|
-
this.disabledOpacity = .2;
|
|
65
|
-
/**
|
|
66
|
-
* Stores the value that tells if the button is enabled or disabled
|
|
67
|
-
*/
|
|
68
|
-
this._enabled = true;
|
|
69
|
-
}
|
|
70
|
-
/**
|
|
71
|
-
* Specifies if the button is enabled or disabled
|
|
72
|
-
*/
|
|
73
|
-
set enabled(v) {
|
|
74
|
-
this._enabled = v;
|
|
75
|
-
this.currentOpacity = v ? this.defaultOpacity : this.disabledOpacity;
|
|
76
|
-
this.pointerEvents = v ? 'initial' : 'none';
|
|
77
|
-
}
|
|
78
|
-
;
|
|
79
|
-
/**
|
|
80
|
-
* Set button default values
|
|
81
|
-
*/
|
|
82
|
-
ngOnInit() {
|
|
83
|
-
this.currentOpacity = this._enabled ? this.defaultOpacity : this.disabledOpacity;
|
|
84
|
-
this.currentScale = 'scale(1)';
|
|
85
|
-
}
|
|
86
|
-
/**
|
|
87
|
-
* Listens for the mouse over the button component
|
|
88
|
-
*/
|
|
89
|
-
onMouseOver() {
|
|
90
|
-
if (this._enabled) {
|
|
91
|
-
this.currentOpacity = this.hoverOpacity;
|
|
92
|
-
this.currentScale = 'scale(' + this.hoverScale + ')';
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
/**
|
|
96
|
-
* Listens for the mouse out of the button component
|
|
97
|
-
*/
|
|
98
|
-
onMouseOut() {
|
|
99
|
-
if (this._enabled) {
|
|
100
|
-
this.currentOpacity = this.defaultOpacity;
|
|
101
|
-
this.currentScale = 'scale(' + this.defaultScale + ')';
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
/**
|
|
105
|
-
* Listens for the mouse down on the button component
|
|
106
|
-
*/
|
|
107
|
-
onMouseDown() {
|
|
108
|
-
if (this._enabled) {
|
|
109
|
-
this.currentOpacity = this.clickOpacity;
|
|
110
|
-
this.currentScale = 'scale(' + this.clickScale + ')';
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
/**
|
|
114
|
-
* Listens for the mouse up of the button component
|
|
115
|
-
*/
|
|
116
|
-
onMouseUp() {
|
|
117
|
-
if (this._enabled) {
|
|
118
|
-
if (this.vibrateOnClick > 0 && window.navigator && window.navigator.vibrate) {
|
|
119
|
-
window.navigator.vibrate(this.vibrateOnClick);
|
|
120
|
-
}
|
|
121
|
-
if (this.releaseOnMouseUp) {
|
|
122
|
-
this.currentOpacity = this.defaultOpacity;
|
|
123
|
-
this.currentScale = 'scale(' + this.defaultScale + ')';
|
|
124
|
-
}
|
|
125
|
-
}
|
|
126
|
-
}
|
|
127
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
128
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "
|
|
129
|
-
}
|
|
130
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
131
|
-
type: Directive
|
|
132
|
-
}], propDecorators: { currentOpacity: [{
|
|
133
|
-
type: HostBinding,
|
|
134
|
-
args: ['style.opacity']
|
|
135
|
-
}], currentScale: [{
|
|
136
|
-
type: HostBinding,
|
|
137
|
-
args: ['style.transform']
|
|
138
|
-
}], pointerEvents: [{
|
|
139
|
-
type: HostBinding,
|
|
140
|
-
args: ['style.pointer-events']
|
|
141
|
-
}], releaseOnMouseUp: [{
|
|
142
|
-
type: Input
|
|
143
|
-
}], vibrateOnClick: [{
|
|
144
|
-
type: Input
|
|
145
|
-
}], defaultOpacity: [{
|
|
146
|
-
type: Input
|
|
147
|
-
}], defaultScale: [{
|
|
148
|
-
type: Input
|
|
149
|
-
}], hoverOpacity: [{
|
|
150
|
-
type: Input
|
|
151
|
-
}], hoverScale: [{
|
|
152
|
-
type: Input
|
|
153
|
-
}], clickOpacity: [{
|
|
154
|
-
type: Input
|
|
155
|
-
}], clickScale: [{
|
|
156
|
-
type: Input
|
|
157
|
-
}], disabledOpacity: [{
|
|
158
|
-
type: Input
|
|
159
|
-
}], enabled: [{
|
|
160
|
-
type: Input
|
|
161
|
-
}], onMouseOver: [{
|
|
162
|
-
type: HostListener,
|
|
163
|
-
args: ['mouseover']
|
|
164
|
-
}], onMouseOut: [{
|
|
165
|
-
type: HostListener,
|
|
166
|
-
args: ['mouseout']
|
|
167
|
-
}, {
|
|
168
|
-
type: HostListener,
|
|
169
|
-
args: ['pointerout']
|
|
170
|
-
}, {
|
|
171
|
-
type: HostListener,
|
|
172
|
-
args: ['pointerleave']
|
|
173
|
-
}], onMouseDown: [{
|
|
174
|
-
type: HostListener,
|
|
175
|
-
args: ['pointerdown']
|
|
176
|
-
}], onMouseUp: [{
|
|
177
|
-
type: HostListener,
|
|
178
|
-
args: ['pointerup']
|
|
179
|
-
}] } });
|
|
180
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button-base.component.js","sourceRoot":"","sources":["../../../../../../../projects/turbogui-angular/src/main/view/components/button-base/button-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * TurboGUI is A library that helps with the most common and generic UI elements and functionalities\r\n *\r\n * Website : -> http://www.turbogui.org\r\n * License : -> Licensed under the Apache License, Version 2.0. You may not use this file except in compliance with the License.\r\n * License Url : -> http://www.apache.org/licenses/LICENSE-2.0\r\n * CopyRight : -> Copyright 2018 Edertone Advanded Solutions. https://www.edertone.com\r\n */\r\n\r\nimport { HostBinding, HostListener, Input, OnInit, Directive } from '@angular/core';\r\n\r\n\r\n/**\r\n * This is the base class for all button components\r\n */\r\n@Directive()\nexport abstract class ButtonBaseComponent implements OnInit {\r\n\r\n\r\n    /**\r\n     * Defines the actual opacity that is binded on the html part\r\n     */\r\n    @HostBinding('style.opacity') currentOpacity = .7;\r\n\r\n\r\n    /**\r\n     * Defines the actual scale that is binded on the html part\r\n     */\r\n    @HostBinding('style.transform') currentScale = 'scale(1)';\r\n    \r\n    \r\n    /**\r\n     * Defines if the button can be clicked or not\r\n     */\r\n    @HostBinding('style.pointer-events') pointerEvents = 'initial';\r\n\r\n\r\n    /**\r\n     * Specifies if the button animations must rollback when the user releases the mouse or pointer after pressing it\r\n     */\r\n    @Input() releaseOnMouseUp = true;\r\n    \r\n    \r\n    /**\r\n     * Specifies the amount of milliseconds that the button will vibrate when it gets clicked (only on compatible devices and browsers)\r\n     * Set it to 0 to disable click vibration\r\n     */\r\n    @Input() vibrateOnClick = 25;\r\n\r\n\r\n    /**\r\n     * Defines the button opacity when it is not clicked\r\n     */\r\n    @Input() defaultOpacity = .7;\r\n\r\n\r\n    /**\r\n     * Defines the image scale when it is not clicked\r\n     */\r\n    @Input() defaultScale = 1;\r\n\r\n\r\n    /**\r\n     * Defines the button opacity when it is hovered\r\n     */\r\n    @Input() hoverOpacity = .8;\r\n\r\n\r\n    /**\r\n     * Defines the image scale when it is hovered\r\n     */\r\n    @Input() hoverScale = 1;\r\n\r\n\r\n    /**\r\n     * Defines the button opacity when it is clicked\r\n     */\r\n    @Input() clickOpacity = 1;\r\n\r\n\r\n    /**\r\n     * Defines the image scale when it is clicked\r\n     */\r\n    @Input() clickScale = 1;\r\n    \r\n    \r\n    /**\r\n     * Defines the button opacity when it is disabled\r\n     */\r\n    @Input() disabledOpacity = .2;\r\n\r\n\r\n    /**\r\n     * Stores the value that tells if the button is enabled or disabled\r\n     */\r\n    private _enabled = true;\r\n    \r\n\r\n    /**\r\n     * Specifies if the button is enabled or disabled\r\n     */\r\n    @Input() set enabled(v:boolean){\r\n        \r\n        this._enabled = v;\r\n        \r\n        this.currentOpacity = v ? this.defaultOpacity : this.disabledOpacity;\r\n        \r\n        this.pointerEvents = v ? 'initial' : 'none'; \r\n    };\r\n\r\n\r\n    /**\r\n     * Set button default values\r\n     */\r\n    ngOnInit() {\r\n\r\n        this.currentOpacity = this._enabled ? this.defaultOpacity : this.disabledOpacity;\r\n        this.currentScale = 'scale(1)';\r\n    }\r\n\r\n\r\n    /**\r\n     * Listens for the mouse over the button component\r\n     */\r\n    @HostListener('mouseover')\r\n    onMouseOver() {\r\n\r\n        if(this._enabled){\r\n            \r\n            this.currentOpacity = this.hoverOpacity;\r\n            this.currentScale = 'scale(' + (this.hoverScale as any as string) + ')';\r\n        }\r\n    }\r\n\r\n\r\n    /**\r\n     * Listens for the mouse out of the button component\r\n     */\r\n    @HostListener('mouseout')\r\n    @HostListener('pointerout')\r\n    @HostListener('pointerleave')\r\n    onMouseOut() {\r\n\r\n        if(this._enabled){\r\n            \r\n            this.currentOpacity = this.defaultOpacity;\r\n            this.currentScale = 'scale(' + (this.defaultScale as any as string) + ')';\r\n        }\r\n    }\r\n\r\n\r\n    /**\r\n     * Listens for the mouse down on the button component\r\n     */\r\n    @HostListener('pointerdown')\r\n    onMouseDown() {\r\n\r\n        if(this._enabled){\r\n            \r\n            this.currentOpacity = this.clickOpacity;\r\n            this.currentScale = 'scale(' + (this.clickScale as any as string) + ')'; \r\n        }\r\n    }\r\n\r\n\r\n    /**\r\n     * Listens for the mouse up of the button component\r\n     */\r\n    @HostListener('pointerup')\r\n    onMouseUp() {\r\n\r\n        if (this._enabled) {\r\n            \r\n            if (this.vibrateOnClick > 0 && window.navigator && window.navigator.vibrate) {\r\n                \r\n                window.navigator.vibrate(this.vibrateOnClick);\r\n            }\r\n            \r\n            if(this.releaseOnMouseUp){\r\n                \r\n                this.currentOpacity = this.defaultOpacity;\r\n                this.currentScale = 'scale(' + (this.defaultScale as any as string) + ')';\r\n            }\r\n        }\r\n    }\r\n}\r\n"]}
|
|
1
|
+
/**
|
|
2
|
+
* TurboGUI is A library that helps with the most common and generic UI elements and functionalities
|
|
3
|
+
*
|
|
4
|
+
* Website : -> http://www.turbogui.org
|
|
5
|
+
* License : -> Licensed under the Apache License, Version 2.0. You may not use this file except in compliance with the License.
|
|
6
|
+
* License Url : -> http://www.apache.org/licenses/LICENSE-2.0
|
|
7
|
+
* CopyRight : -> Copyright 2018 Edertone Advanded Solutions. https://www.edertone.com
|
|
8
|
+
*/
|
|
9
|
+
import { HostBinding, HostListener, Input, Directive } from '@angular/core';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
/**
|
|
12
|
+
* This is the base class for all button components
|
|
13
|
+
*/
|
|
14
|
+
export class ButtonBaseComponent {
|
|
15
|
+
constructor() {
|
|
16
|
+
/**
|
|
17
|
+
* Defines the actual opacity that is binded on the html part
|
|
18
|
+
*/
|
|
19
|
+
this.currentOpacity = .7;
|
|
20
|
+
/**
|
|
21
|
+
* Defines the actual scale that is binded on the html part
|
|
22
|
+
*/
|
|
23
|
+
this.currentScale = 'scale(1)';
|
|
24
|
+
/**
|
|
25
|
+
* Defines if the button can be clicked or not
|
|
26
|
+
*/
|
|
27
|
+
this.pointerEvents = 'initial';
|
|
28
|
+
/**
|
|
29
|
+
* Specifies if the button animations must rollback when the user releases the mouse or pointer after pressing it
|
|
30
|
+
*/
|
|
31
|
+
this.releaseOnMouseUp = true;
|
|
32
|
+
/**
|
|
33
|
+
* Specifies the amount of milliseconds that the button will vibrate when it gets clicked (only on compatible devices and browsers)
|
|
34
|
+
* Set it to 0 to disable click vibration
|
|
35
|
+
*/
|
|
36
|
+
this.vibrateOnClick = 25;
|
|
37
|
+
/**
|
|
38
|
+
* Defines the button opacity when it is not clicked
|
|
39
|
+
*/
|
|
40
|
+
this.defaultOpacity = .7;
|
|
41
|
+
/**
|
|
42
|
+
* Defines the image scale when it is not clicked
|
|
43
|
+
*/
|
|
44
|
+
this.defaultScale = 1;
|
|
45
|
+
/**
|
|
46
|
+
* Defines the button opacity when it is hovered
|
|
47
|
+
*/
|
|
48
|
+
this.hoverOpacity = .8;
|
|
49
|
+
/**
|
|
50
|
+
* Defines the image scale when it is hovered
|
|
51
|
+
*/
|
|
52
|
+
this.hoverScale = 1;
|
|
53
|
+
/**
|
|
54
|
+
* Defines the button opacity when it is clicked
|
|
55
|
+
*/
|
|
56
|
+
this.clickOpacity = 1;
|
|
57
|
+
/**
|
|
58
|
+
* Defines the image scale when it is clicked
|
|
59
|
+
*/
|
|
60
|
+
this.clickScale = 1;
|
|
61
|
+
/**
|
|
62
|
+
* Defines the button opacity when it is disabled
|
|
63
|
+
*/
|
|
64
|
+
this.disabledOpacity = .2;
|
|
65
|
+
/**
|
|
66
|
+
* Stores the value that tells if the button is enabled or disabled
|
|
67
|
+
*/
|
|
68
|
+
this._enabled = true;
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* Specifies if the button is enabled or disabled
|
|
72
|
+
*/
|
|
73
|
+
set enabled(v) {
|
|
74
|
+
this._enabled = v;
|
|
75
|
+
this.currentOpacity = v ? this.defaultOpacity : this.disabledOpacity;
|
|
76
|
+
this.pointerEvents = v ? 'initial' : 'none';
|
|
77
|
+
}
|
|
78
|
+
;
|
|
79
|
+
/**
|
|
80
|
+
* Set button default values
|
|
81
|
+
*/
|
|
82
|
+
ngOnInit() {
|
|
83
|
+
this.currentOpacity = this._enabled ? this.defaultOpacity : this.disabledOpacity;
|
|
84
|
+
this.currentScale = 'scale(1)';
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* Listens for the mouse over the button component
|
|
88
|
+
*/
|
|
89
|
+
onMouseOver() {
|
|
90
|
+
if (this._enabled) {
|
|
91
|
+
this.currentOpacity = this.hoverOpacity;
|
|
92
|
+
this.currentScale = 'scale(' + this.hoverScale + ')';
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
/**
|
|
96
|
+
* Listens for the mouse out of the button component
|
|
97
|
+
*/
|
|
98
|
+
onMouseOut() {
|
|
99
|
+
if (this._enabled) {
|
|
100
|
+
this.currentOpacity = this.defaultOpacity;
|
|
101
|
+
this.currentScale = 'scale(' + this.defaultScale + ')';
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
/**
|
|
105
|
+
* Listens for the mouse down on the button component
|
|
106
|
+
*/
|
|
107
|
+
onMouseDown() {
|
|
108
|
+
if (this._enabled) {
|
|
109
|
+
this.currentOpacity = this.clickOpacity;
|
|
110
|
+
this.currentScale = 'scale(' + this.clickScale + ')';
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
/**
|
|
114
|
+
* Listens for the mouse up of the button component
|
|
115
|
+
*/
|
|
116
|
+
onMouseUp() {
|
|
117
|
+
if (this._enabled) {
|
|
118
|
+
if (this.vibrateOnClick > 0 && window.navigator && window.navigator.vibrate) {
|
|
119
|
+
window.navigator.vibrate(this.vibrateOnClick);
|
|
120
|
+
}
|
|
121
|
+
if (this.releaseOnMouseUp) {
|
|
122
|
+
this.currentOpacity = this.defaultOpacity;
|
|
123
|
+
this.currentScale = 'scale(' + this.defaultScale + ')';
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: ButtonBaseComponent, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
128
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.8", type: ButtonBaseComponent, inputs: { releaseOnMouseUp: "releaseOnMouseUp", vibrateOnClick: "vibrateOnClick", defaultOpacity: "defaultOpacity", defaultScale: "defaultScale", hoverOpacity: "hoverOpacity", hoverScale: "hoverScale", clickOpacity: "clickOpacity", clickScale: "clickScale", disabledOpacity: "disabledOpacity", enabled: "enabled" }, host: { listeners: { "mouseover": "onMouseOver()", "mouseout": "onMouseOut()", "pointerout": "onMouseOut()", "pointerleave": "onMouseOut()", "pointerdown": "onMouseDown()", "pointerup": "onMouseUp()" }, properties: { "style.opacity": "this.currentOpacity", "style.transform": "this.currentScale", "style.pointer-events": "this.pointerEvents" } }, ngImport: i0 }); }
|
|
129
|
+
}
|
|
130
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: ButtonBaseComponent, decorators: [{
|
|
131
|
+
type: Directive
|
|
132
|
+
}], propDecorators: { currentOpacity: [{
|
|
133
|
+
type: HostBinding,
|
|
134
|
+
args: ['style.opacity']
|
|
135
|
+
}], currentScale: [{
|
|
136
|
+
type: HostBinding,
|
|
137
|
+
args: ['style.transform']
|
|
138
|
+
}], pointerEvents: [{
|
|
139
|
+
type: HostBinding,
|
|
140
|
+
args: ['style.pointer-events']
|
|
141
|
+
}], releaseOnMouseUp: [{
|
|
142
|
+
type: Input
|
|
143
|
+
}], vibrateOnClick: [{
|
|
144
|
+
type: Input
|
|
145
|
+
}], defaultOpacity: [{
|
|
146
|
+
type: Input
|
|
147
|
+
}], defaultScale: [{
|
|
148
|
+
type: Input
|
|
149
|
+
}], hoverOpacity: [{
|
|
150
|
+
type: Input
|
|
151
|
+
}], hoverScale: [{
|
|
152
|
+
type: Input
|
|
153
|
+
}], clickOpacity: [{
|
|
154
|
+
type: Input
|
|
155
|
+
}], clickScale: [{
|
|
156
|
+
type: Input
|
|
157
|
+
}], disabledOpacity: [{
|
|
158
|
+
type: Input
|
|
159
|
+
}], enabled: [{
|
|
160
|
+
type: Input
|
|
161
|
+
}], onMouseOver: [{
|
|
162
|
+
type: HostListener,
|
|
163
|
+
args: ['mouseover']
|
|
164
|
+
}], onMouseOut: [{
|
|
165
|
+
type: HostListener,
|
|
166
|
+
args: ['mouseout']
|
|
167
|
+
}, {
|
|
168
|
+
type: HostListener,
|
|
169
|
+
args: ['pointerout']
|
|
170
|
+
}, {
|
|
171
|
+
type: HostListener,
|
|
172
|
+
args: ['pointerleave']
|
|
173
|
+
}], onMouseDown: [{
|
|
174
|
+
type: HostListener,
|
|
175
|
+
args: ['pointerdown']
|
|
176
|
+
}], onMouseUp: [{
|
|
177
|
+
type: HostListener,
|
|
178
|
+
args: ['pointerup']
|
|
179
|
+
}] } });
|
|
180
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button-base.component.js","sourceRoot":"","sources":["../../../../../../../projects/turbogui-angular/src/main/view/components/button-base/button-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * TurboGUI is A library that helps with the most common and generic UI elements and functionalities\r\n *\r\n * Website : -> http://www.turbogui.org\r\n * License : -> Licensed under the Apache License, Version 2.0. You may not use this file except in compliance with the License.\r\n * License Url : -> http://www.apache.org/licenses/LICENSE-2.0\r\n * CopyRight : -> Copyright 2018 Edertone Advanded Solutions. https://www.edertone.com\r\n */\r\n\r\nimport { HostBinding, HostListener, Input, OnInit, Directive } from '@angular/core';\r\n\r\n\r\n/**\r\n * This is the base class for all button components\r\n */\r\n@Directive()\nexport abstract class ButtonBaseComponent implements OnInit {\r\n\r\n\r\n    /**\r\n     * Defines the actual opacity that is binded on the html part\r\n     */\r\n    @HostBinding('style.opacity') currentOpacity = .7;\r\n\r\n\r\n    /**\r\n     * Defines the actual scale that is binded on the html part\r\n     */\r\n    @HostBinding('style.transform') currentScale = 'scale(1)';\r\n    \r\n    \r\n    /**\r\n     * Defines if the button can be clicked or not\r\n     */\r\n    @HostBinding('style.pointer-events') pointerEvents = 'initial';\r\n\r\n\r\n    /**\r\n     * Specifies if the button animations must rollback when the user releases the mouse or pointer after pressing it\r\n     */\r\n    @Input() releaseOnMouseUp = true;\r\n    \r\n    \r\n    /**\r\n     * Specifies the amount of milliseconds that the button will vibrate when it gets clicked (only on compatible devices and browsers)\r\n     * Set it to 0 to disable click vibration\r\n     */\r\n    @Input() vibrateOnClick = 25;\r\n\r\n\r\n    /**\r\n     * Defines the button opacity when it is not clicked\r\n     */\r\n    @Input() defaultOpacity = .7;\r\n\r\n\r\n    /**\r\n     * Defines the image scale when it is not clicked\r\n     */\r\n    @Input() defaultScale = 1;\r\n\r\n\r\n    /**\r\n     * Defines the button opacity when it is hovered\r\n     */\r\n    @Input() hoverOpacity = .8;\r\n\r\n\r\n    /**\r\n     * Defines the image scale when it is hovered\r\n     */\r\n    @Input() hoverScale = 1;\r\n\r\n\r\n    /**\r\n     * Defines the button opacity when it is clicked\r\n     */\r\n    @Input() clickOpacity = 1;\r\n\r\n\r\n    /**\r\n     * Defines the image scale when it is clicked\r\n     */\r\n    @Input() clickScale = 1;\r\n    \r\n    \r\n    /**\r\n     * Defines the button opacity when it is disabled\r\n     */\r\n    @Input() disabledOpacity = .2;\r\n\r\n\r\n    /**\r\n     * Stores the value that tells if the button is enabled or disabled\r\n     */\r\n    private _enabled = true;\r\n    \r\n\r\n    /**\r\n     * Specifies if the button is enabled or disabled\r\n     */\r\n    @Input() set enabled(v:boolean){\r\n        \r\n        this._enabled = v;\r\n        \r\n        this.currentOpacity = v ? this.defaultOpacity : this.disabledOpacity;\r\n        \r\n        this.pointerEvents = v ? 'initial' : 'none'; \r\n    };\r\n\r\n\r\n    /**\r\n     * Set button default values\r\n     */\r\n    ngOnInit() {\r\n\r\n        this.currentOpacity = this._enabled ? this.defaultOpacity : this.disabledOpacity;\r\n        this.currentScale = 'scale(1)';\r\n    }\r\n\r\n\r\n    /**\r\n     * Listens for the mouse over the button component\r\n     */\r\n    @HostListener('mouseover')\r\n    onMouseOver() {\r\n\r\n        if(this._enabled){\r\n            \r\n            this.currentOpacity = this.hoverOpacity;\r\n            this.currentScale = 'scale(' + (this.hoverScale as any as string) + ')';\r\n        }\r\n    }\r\n\r\n\r\n    /**\r\n     * Listens for the mouse out of the button component\r\n     */\r\n    @HostListener('mouseout')\r\n    @HostListener('pointerout')\r\n    @HostListener('pointerleave')\r\n    onMouseOut() {\r\n\r\n        if(this._enabled){\r\n            \r\n            this.currentOpacity = this.defaultOpacity;\r\n            this.currentScale = 'scale(' + (this.defaultScale as any as string) + ')';\r\n        }\r\n    }\r\n\r\n\r\n    /**\r\n     * Listens for the mouse down on the button component\r\n     */\r\n    @HostListener('pointerdown')\r\n    onMouseDown() {\r\n\r\n        if(this._enabled){\r\n            \r\n            this.currentOpacity = this.clickOpacity;\r\n            this.currentScale = 'scale(' + (this.clickScale as any as string) + ')'; \r\n        }\r\n    }\r\n\r\n\r\n    /**\r\n     * Listens for the mouse up of the button component\r\n     */\r\n    @HostListener('pointerup')\r\n    onMouseUp() {\r\n\r\n        if (this._enabled) {\r\n            \r\n            if (this.vibrateOnClick > 0 && window.navigator && window.navigator.vibrate) {\r\n                \r\n                window.navigator.vibrate(this.vibrateOnClick);\r\n            }\r\n            \r\n            if(this.releaseOnMouseUp){\r\n                \r\n                this.currentOpacity = this.defaultOpacity;\r\n                this.currentScale = 'scale(' + (this.defaultScale as any as string) + ')';\r\n            }\r\n        }\r\n    }\r\n}\r\n"]}
|
|
@@ -1,34 +1,34 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* TurboGUI is A library that helps with the most common and generic UI elements and functionalities
|
|
3
|
-
*
|
|
4
|
-
* Website : -> http://www.turbogui.org
|
|
5
|
-
* License : -> Licensed under the Apache License, Version 2.0. You may not use this file except in compliance with the License.
|
|
6
|
-
* License Url : -> http://www.apache.org/licenses/LICENSE-2.0
|
|
7
|
-
* CopyRight : -> Copyright 2018 Edertone Advanded Solutions. https://www.edertone.com
|
|
8
|
-
*/
|
|
9
|
-
import { Component, HostBinding } from '@angular/core';
|
|
10
|
-
import { FadeAnimationClass } from '../../animations/fade.animation';
|
|
11
|
-
import { ButtonBaseComponent } from '../../../view/components/button-base/button-base.component';
|
|
12
|
-
import * as i0 from "@angular/core";
|
|
13
|
-
/**
|
|
14
|
-
* This component is a basic button without visual appearance, that is used as a container to load any content.
|
|
15
|
-
*/
|
|
16
|
-
export class ButtonContainerComponent extends ButtonBaseComponent {
|
|
17
|
-
constructor() {
|
|
18
|
-
super(...arguments);
|
|
19
|
-
/**
|
|
20
|
-
* This is used to attach the fade animation directly to this component so it fades in and out when created and removed from the app
|
|
21
|
-
*/
|
|
22
|
-
this.buttonFade = true;
|
|
23
|
-
}
|
|
24
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
25
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
26
|
-
}
|
|
27
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
28
|
-
type: Component,
|
|
29
|
-
args: [{ selector: 'tg-button-container', animations: [FadeAnimationClass.getTrigger('buttonFade', '300ms ease', '300ms ease')], template: "<ng-content></ng-content>", styles: [":host{-webkit-user-select:none;-moz-user-select:none;user-select:none;overflow:hidden;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:opacity .3s ease,transform .2s cubic-bezier(.04,.62,.58,1);display:flex;justify-content:center;align-items:center}\n"] }]
|
|
30
|
-
}], propDecorators: { buttonFade: [{
|
|
31
|
-
type: HostBinding,
|
|
32
|
-
args: ['@buttonFade']
|
|
33
|
-
}] } });
|
|
34
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
/**
|
|
2
|
+
* TurboGUI is A library that helps with the most common and generic UI elements and functionalities
|
|
3
|
+
*
|
|
4
|
+
* Website : -> http://www.turbogui.org
|
|
5
|
+
* License : -> Licensed under the Apache License, Version 2.0. You may not use this file except in compliance with the License.
|
|
6
|
+
* License Url : -> http://www.apache.org/licenses/LICENSE-2.0
|
|
7
|
+
* CopyRight : -> Copyright 2018 Edertone Advanded Solutions. https://www.edertone.com
|
|
8
|
+
*/
|
|
9
|
+
import { Component, HostBinding } from '@angular/core';
|
|
10
|
+
import { FadeAnimationClass } from '../../animations/fade.animation';
|
|
11
|
+
import { ButtonBaseComponent } from '../../../view/components/button-base/button-base.component';
|
|
12
|
+
import * as i0 from "@angular/core";
|
|
13
|
+
/**
|
|
14
|
+
* This component is a basic button without visual appearance, that is used as a container to load any content.
|
|
15
|
+
*/
|
|
16
|
+
export class ButtonContainerComponent extends ButtonBaseComponent {
|
|
17
|
+
constructor() {
|
|
18
|
+
super(...arguments);
|
|
19
|
+
/**
|
|
20
|
+
* This is used to attach the fade animation directly to this component so it fades in and out when created and removed from the app
|
|
21
|
+
*/
|
|
22
|
+
this.buttonFade = true;
|
|
23
|
+
}
|
|
24
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: ButtonContainerComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
25
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: ButtonContainerComponent, selector: "tg-button-container", host: { properties: { "@buttonFade": "this.buttonFade" } }, usesInheritance: true, ngImport: i0, template: "<ng-content></ng-content>", styles: [":host{-webkit-user-select:none;-moz-user-select:none;user-select:none;overflow:hidden;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:opacity .3s ease,transform .2s cubic-bezier(.04,.62,.58,1);display:flex;justify-content:center;align-items:center}\n"], animations: [FadeAnimationClass.getTrigger('buttonFade', '300ms ease', '300ms ease')] }); }
|
|
26
|
+
}
|
|
27
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: ButtonContainerComponent, decorators: [{
|
|
28
|
+
type: Component,
|
|
29
|
+
args: [{ selector: 'tg-button-container', animations: [FadeAnimationClass.getTrigger('buttonFade', '300ms ease', '300ms ease')], template: "<ng-content></ng-content>", styles: [":host{-webkit-user-select:none;-moz-user-select:none;user-select:none;overflow:hidden;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:opacity .3s ease,transform .2s cubic-bezier(.04,.62,.58,1);display:flex;justify-content:center;align-items:center}\n"] }]
|
|
30
|
+
}], propDecorators: { buttonFade: [{
|
|
31
|
+
type: HostBinding,
|
|
32
|
+
args: ['@buttonFade']
|
|
33
|
+
}] } });
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLWNvbnRhaW5lci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90dXJib2d1aS1hbmd1bGFyL3NyYy9tYWluL3ZpZXcvY29tcG9uZW50cy9idXR0b24tY29udGFpbmVyL2J1dHRvbi1jb250YWluZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHVyYm9ndWktYW5ndWxhci9zcmMvbWFpbi92aWV3L2NvbXBvbmVudHMvYnV0dG9uLWNvbnRhaW5lci9idXR0b24tY29udGFpbmVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7O0dBT0c7QUFFSCxPQUFPLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN2RCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUNyRSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSw0REFBNEQsQ0FBQzs7QUFHakc7O0dBRUc7QUFTSCxNQUFNLE9BQU8sd0JBQXlCLFNBQVEsbUJBQW1CO0lBUmpFOztRQVdJOztXQUVHO1FBQ3lCLGVBQVUsR0FBRyxJQUFJLENBQUM7S0FDakQ7OEdBUFksd0JBQXdCO2tHQUF4Qix3QkFBd0IsOElDekJyQywyQkFBeUIsd1NEb0JYLENBQUMsa0JBQWtCLENBQUMsVUFBVSxDQUFDLFlBQVksRUFBRSxZQUFZLEVBQUUsWUFBWSxDQUFDLENBQUM7OzJGQUsxRSx3QkFBd0I7a0JBUnBDLFNBQVM7K0JBQ0UscUJBQXFCLGNBRW5CLENBQUMsa0JBQWtCLENBQUMsVUFBVSxDQUFDLFlBQVksRUFBRSxZQUFZLEVBQUUsWUFBWSxDQUFDLENBQUM7OEJBV3ZELFVBQVU7c0JBQXJDLFdBQVc7dUJBQUMsYUFBYSIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxyXG4gKiBUdXJib0dVSSBpcyBBIGxpYnJhcnkgdGhhdCBoZWxwcyB3aXRoIHRoZSBtb3N0IGNvbW1vbiBhbmQgZ2VuZXJpYyBVSSBlbGVtZW50cyBhbmQgZnVuY3Rpb25hbGl0aWVzXHJcbiAqXHJcbiAqIFdlYnNpdGUgOiAtPiBodHRwOi8vd3d3LnR1cmJvZ3VpLm9yZ1xyXG4gKiBMaWNlbnNlIDogLT4gTGljZW5zZWQgdW5kZXIgdGhlIEFwYWNoZSBMaWNlbnNlLCBWZXJzaW9uIDIuMC4gWW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZSB3aXRoIHRoZSBMaWNlbnNlLlxyXG4gKiBMaWNlbnNlIFVybCA6IC0+IGh0dHA6Ly93d3cuYXBhY2hlLm9yZy9saWNlbnNlcy9MSUNFTlNFLTIuMFxyXG4gKiBDb3B5UmlnaHQgOiAtPiBDb3B5cmlnaHQgMjAxOCBFZGVydG9uZSBBZHZhbmRlZCBTb2x1dGlvbnMuIGh0dHBzOi8vd3d3LmVkZXJ0b25lLmNvbVxyXG4gKi9cclxuXHJcbmltcG9ydCB7IENvbXBvbmVudCwgSG9zdEJpbmRpbmcgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgRmFkZUFuaW1hdGlvbkNsYXNzIH0gZnJvbSAnLi4vLi4vYW5pbWF0aW9ucy9mYWRlLmFuaW1hdGlvbic7XHJcbmltcG9ydCB7IEJ1dHRvbkJhc2VDb21wb25lbnQgfSBmcm9tICcuLi8uLi8uLi92aWV3L2NvbXBvbmVudHMvYnV0dG9uLWJhc2UvYnV0dG9uLWJhc2UuY29tcG9uZW50JztcclxuXHJcblxyXG4vKipcclxuICogVGhpcyBjb21wb25lbnQgaXMgYSBiYXNpYyBidXR0b24gd2l0aG91dCB2aXN1YWwgYXBwZWFyYW5jZSwgdGhhdCBpcyB1c2VkIGFzIGEgY29udGFpbmVyIHRvIGxvYWQgYW55IGNvbnRlbnQuXHJcbiAqL1xyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ3RnLWJ1dHRvbi1jb250YWluZXInLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9idXR0b24tY29udGFpbmVyLmNvbXBvbmVudC5odG1sJyxcclxuICBhbmltYXRpb25zOiBbRmFkZUFuaW1hdGlvbkNsYXNzLmdldFRyaWdnZXIoJ2J1dHRvbkZhZGUnLCAnMzAwbXMgZWFzZScsICczMDBtcyBlYXNlJyldLFxyXG4gIHN0eWxlVXJsczogWycuL2J1dHRvbi1jb250YWluZXIuY29tcG9uZW50LnNjc3MnXVxyXG59KVxyXG5cclxuXHJcbmV4cG9ydCBjbGFzcyBCdXR0b25Db250YWluZXJDb21wb25lbnQgZXh0ZW5kcyBCdXR0b25CYXNlQ29tcG9uZW50IHtcclxuXHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBUaGlzIGlzIHVzZWQgdG8gYXR0YWNoIHRoZSBmYWRlIGFuaW1hdGlvbiBkaXJlY3RseSB0byB0aGlzIGNvbXBvbmVudCBzbyBpdCBmYWRlcyBpbiBhbmQgb3V0IHdoZW4gY3JlYXRlZCBhbmQgcmVtb3ZlZCBmcm9tIHRoZSBhcHBcclxuICAgICAqL1xyXG4gICAgQEhvc3RCaW5kaW5nKCdAYnV0dG9uRmFkZScpIGJ1dHRvbkZhZGUgPSB0cnVlO1xyXG59XHJcbiIsIjxuZy1jb250ZW50PjwvbmctY29udGVudD4iXX0=
|
|
@@ -1,47 +1,47 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* TurboGUI is A library that helps with the most common and generic UI elements and functionalities
|
|
3
|
-
*
|
|
4
|
-
* Website : -> http://www.turbogui.org
|
|
5
|
-
* License : -> Licensed under the Apache License, Version 2.0. You may not use this file except in compliance with the License.
|
|
6
|
-
* License Url : -> http://www.apache.org/licenses/LICENSE-2.0
|
|
7
|
-
* CopyRight : -> Copyright 2018 Edertone Advanded Solutions. https://www.edertone.com
|
|
8
|
-
*/
|
|
9
|
-
import { Component, HostBinding, Input } from '@angular/core';
|
|
10
|
-
import { FadeAnimationClass } from '../../animations/fade.animation';
|
|
11
|
-
import { ButtonBaseComponent } from '../../../view/components/button-base/button-base.component';
|
|
12
|
-
import * as i0 from "@angular/core";
|
|
13
|
-
/**
|
|
14
|
-
* This component is a basic button that uses an image as its visual appearance
|
|
15
|
-
*/
|
|
16
|
-
export class ButtonImageComponent extends ButtonBaseComponent {
|
|
17
|
-
constructor() {
|
|
18
|
-
super(...arguments);
|
|
19
|
-
/**
|
|
20
|
-
* This is used to attach the fade animation directly to this component so it fades in and out when created and removed from the app
|
|
21
|
-
*/
|
|
22
|
-
this.buttonFade = true;
|
|
23
|
-
/**
|
|
24
|
-
* Defines the path to the image that is shown by this button
|
|
25
|
-
*/
|
|
26
|
-
this.src = '';
|
|
27
|
-
/**
|
|
28
|
-
* Defines the percentual size of the image based on the button size. 100 means the image will fill the whole button,
|
|
29
|
-
* 50 only half, etc..
|
|
30
|
-
*/
|
|
31
|
-
this.percentSize = 100;
|
|
32
|
-
}
|
|
33
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
34
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
35
|
-
}
|
|
36
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
37
|
-
type: Component,
|
|
38
|
-
args: [{ selector: 'tg-button-image', animations: [FadeAnimationClass.getTrigger('buttonFade', '300ms ease', '300ms ease')], template: "<img src=\"{{src}}\"\r\n [style.width]=\"percentSize + '%'\"\r\n [style.height]=\"percentSize + '%'\" />", styles: [":host{-webkit-user-select:none;-moz-user-select:none;user-select:none;overflow:hidden;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:opacity .3s ease,transform .2s cubic-bezier(.04,.62,.58,1);display:flex;justify-content:center;align-items:center}img{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}\n"] }]
|
|
39
|
-
}], propDecorators: { buttonFade: [{
|
|
40
|
-
type: HostBinding,
|
|
41
|
-
args: ['@buttonFade']
|
|
42
|
-
}], src: [{
|
|
43
|
-
type: Input
|
|
44
|
-
}], percentSize: [{
|
|
45
|
-
type: Input
|
|
46
|
-
}] } });
|
|
47
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
/**
|
|
2
|
+
* TurboGUI is A library that helps with the most common and generic UI elements and functionalities
|
|
3
|
+
*
|
|
4
|
+
* Website : -> http://www.turbogui.org
|
|
5
|
+
* License : -> Licensed under the Apache License, Version 2.0. You may not use this file except in compliance with the License.
|
|
6
|
+
* License Url : -> http://www.apache.org/licenses/LICENSE-2.0
|
|
7
|
+
* CopyRight : -> Copyright 2018 Edertone Advanded Solutions. https://www.edertone.com
|
|
8
|
+
*/
|
|
9
|
+
import { Component, HostBinding, Input } from '@angular/core';
|
|
10
|
+
import { FadeAnimationClass } from '../../animations/fade.animation';
|
|
11
|
+
import { ButtonBaseComponent } from '../../../view/components/button-base/button-base.component';
|
|
12
|
+
import * as i0 from "@angular/core";
|
|
13
|
+
/**
|
|
14
|
+
* This component is a basic button that uses an image as its visual appearance
|
|
15
|
+
*/
|
|
16
|
+
export class ButtonImageComponent extends ButtonBaseComponent {
|
|
17
|
+
constructor() {
|
|
18
|
+
super(...arguments);
|
|
19
|
+
/**
|
|
20
|
+
* This is used to attach the fade animation directly to this component so it fades in and out when created and removed from the app
|
|
21
|
+
*/
|
|
22
|
+
this.buttonFade = true;
|
|
23
|
+
/**
|
|
24
|
+
* Defines the path to the image that is shown by this button
|
|
25
|
+
*/
|
|
26
|
+
this.src = '';
|
|
27
|
+
/**
|
|
28
|
+
* Defines the percentual size of the image based on the button size. 100 means the image will fill the whole button,
|
|
29
|
+
* 50 only half, etc..
|
|
30
|
+
*/
|
|
31
|
+
this.percentSize = 100;
|
|
32
|
+
}
|
|
33
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: ButtonImageComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
34
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: ButtonImageComponent, selector: "tg-button-image", inputs: { src: "src", percentSize: "percentSize" }, host: { properties: { "@buttonFade": "this.buttonFade" } }, usesInheritance: true, ngImport: i0, template: "<img src=\"{{src}}\"\r\n [style.width]=\"percentSize + '%'\"\r\n [style.height]=\"percentSize + '%'\" />", styles: [":host{-webkit-user-select:none;-moz-user-select:none;user-select:none;overflow:hidden;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:opacity .3s ease,transform .2s cubic-bezier(.04,.62,.58,1);display:flex;justify-content:center;align-items:center}img{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}\n"], animations: [FadeAnimationClass.getTrigger('buttonFade', '300ms ease', '300ms ease')] }); }
|
|
35
|
+
}
|
|
36
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: ButtonImageComponent, decorators: [{
|
|
37
|
+
type: Component,
|
|
38
|
+
args: [{ selector: 'tg-button-image', animations: [FadeAnimationClass.getTrigger('buttonFade', '300ms ease', '300ms ease')], template: "<img src=\"{{src}}\"\r\n [style.width]=\"percentSize + '%'\"\r\n [style.height]=\"percentSize + '%'\" />", styles: [":host{-webkit-user-select:none;-moz-user-select:none;user-select:none;overflow:hidden;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:opacity .3s ease,transform .2s cubic-bezier(.04,.62,.58,1);display:flex;justify-content:center;align-items:center}img{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}\n"] }]
|
|
39
|
+
}], propDecorators: { buttonFade: [{
|
|
40
|
+
type: HostBinding,
|
|
41
|
+
args: ['@buttonFade']
|
|
42
|
+
}], src: [{
|
|
43
|
+
type: Input
|
|
44
|
+
}], percentSize: [{
|
|
45
|
+
type: Input
|
|
46
|
+
}] } });
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLWltYWdlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3R1cmJvZ3VpLWFuZ3VsYXIvc3JjL21haW4vdmlldy9jb21wb25lbnRzL2J1dHRvbi1pbWFnZS9idXR0b24taW1hZ2UuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHVyYm9ndWktYW5ndWxhci9zcmMvbWFpbi92aWV3L2NvbXBvbmVudHMvYnV0dG9uLWltYWdlL2J1dHRvbi1pbWFnZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7OztHQU9HO0FBRUgsT0FBTyxFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBQ3RFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQ3JFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDREQUE0RCxDQUFDOztBQUdqRzs7R0FFRztBQVNILE1BQU0sT0FBTyxvQkFBcUIsU0FBUSxtQkFBbUI7SUFSN0Q7O1FBV0k7O1dBRUc7UUFDeUIsZUFBVSxHQUFHLElBQUksQ0FBQztRQUc5Qzs7V0FFRztRQUNNLFFBQUcsR0FBRyxFQUFFLENBQUM7UUFHbEI7OztXQUdHO1FBQ00sZ0JBQVcsR0FBRyxHQUFHLENBQUM7S0FDOUI7OEdBcEJZLG9CQUFvQjtrR0FBcEIsb0JBQW9CLDhMQ3pCakMsZ0hBRXlDLHdhRGtCM0IsQ0FBQyxrQkFBa0IsQ0FBQyxVQUFVLENBQUMsWUFBWSxFQUFFLFlBQVksRUFBRSxZQUFZLENBQUMsQ0FBQzs7MkZBSzFFLG9CQUFvQjtrQkFSaEMsU0FBUzsrQkFDRSxpQkFBaUIsY0FFZixDQUFDLGtCQUFrQixDQUFDLFVBQVUsQ0FBQyxZQUFZLEVBQUUsWUFBWSxFQUFFLFlBQVksQ0FBQyxDQUFDOzhCQVd2RCxVQUFVO3NCQUFyQyxXQUFXO3VCQUFDLGFBQWE7Z0JBTWpCLEdBQUc7c0JBQVgsS0FBSztnQkFPRyxXQUFXO3NCQUFuQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXHJcbiAqIFR1cmJvR1VJIGlzIEEgbGlicmFyeSB0aGF0IGhlbHBzIHdpdGggdGhlIG1vc3QgY29tbW9uIGFuZCBnZW5lcmljIFVJIGVsZW1lbnRzIGFuZCBmdW5jdGlvbmFsaXRpZXNcclxuICpcclxuICogV2Vic2l0ZSA6IC0+IGh0dHA6Ly93d3cudHVyYm9ndWkub3JnXHJcbiAqIExpY2Vuc2UgOiAtPiBMaWNlbnNlZCB1bmRlciB0aGUgQXBhY2hlIExpY2Vuc2UsIFZlcnNpb24gMi4wLiBZb3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlIHdpdGggdGhlIExpY2Vuc2UuXHJcbiAqIExpY2Vuc2UgVXJsIDogLT4gaHR0cDovL3d3dy5hcGFjaGUub3JnL2xpY2Vuc2VzL0xJQ0VOU0UtMi4wXHJcbiAqIENvcHlSaWdodCA6IC0+IENvcHlyaWdodCAyMDE4IEVkZXJ0b25lIEFkdmFuZGVkIFNvbHV0aW9ucy4gaHR0cHM6Ly93d3cuZWRlcnRvbmUuY29tXHJcbiAqL1xyXG5cclxuaW1wb3J0IHsgQ29tcG9uZW50LCBIb3N0QmluZGluZywgSW5wdXQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBGYWRlQW5pbWF0aW9uQ2xhc3MgfSBmcm9tICcuLi8uLi9hbmltYXRpb25zL2ZhZGUuYW5pbWF0aW9uJztcclxuaW1wb3J0IHsgQnV0dG9uQmFzZUNvbXBvbmVudCB9IGZyb20gJy4uLy4uLy4uL3ZpZXcvY29tcG9uZW50cy9idXR0b24tYmFzZS9idXR0b24tYmFzZS5jb21wb25lbnQnO1xyXG5cclxuXHJcbi8qKlxyXG4gKiBUaGlzIGNvbXBvbmVudCBpcyBhIGJhc2ljIGJ1dHRvbiB0aGF0IHVzZXMgYW4gaW1hZ2UgYXMgaXRzIHZpc3VhbCBhcHBlYXJhbmNlXHJcbiAqL1xyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ3RnLWJ1dHRvbi1pbWFnZScsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2J1dHRvbi1pbWFnZS5jb21wb25lbnQuaHRtbCcsXHJcbiAgYW5pbWF0aW9uczogW0ZhZGVBbmltYXRpb25DbGFzcy5nZXRUcmlnZ2VyKCdidXR0b25GYWRlJywgJzMwMG1zIGVhc2UnLCAnMzAwbXMgZWFzZScpXSxcclxuICBzdHlsZVVybHM6IFsnLi9idXR0b24taW1hZ2UuY29tcG9uZW50LnNjc3MnXVxyXG59KVxyXG5cclxuXHJcbmV4cG9ydCBjbGFzcyBCdXR0b25JbWFnZUNvbXBvbmVudCBleHRlbmRzIEJ1dHRvbkJhc2VDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG5cclxuXHJcbiAgICAvKipcclxuICAgICAqIFRoaXMgaXMgdXNlZCB0byBhdHRhY2ggdGhlIGZhZGUgYW5pbWF0aW9uIGRpcmVjdGx5IHRvIHRoaXMgY29tcG9uZW50IHNvIGl0IGZhZGVzIGluIGFuZCBvdXQgd2hlbiBjcmVhdGVkIGFuZCByZW1vdmVkIGZyb20gdGhlIGFwcFxyXG4gICAgICovXHJcbiAgICBASG9zdEJpbmRpbmcoJ0BidXR0b25GYWRlJykgYnV0dG9uRmFkZSA9IHRydWU7XHJcblxyXG5cclxuICAgIC8qKlxyXG4gICAgICogRGVmaW5lcyB0aGUgcGF0aCB0byB0aGUgaW1hZ2UgdGhhdCBpcyBzaG93biBieSB0aGlzIGJ1dHRvblxyXG4gICAgICovXHJcbiAgICBASW5wdXQoKSBzcmMgPSAnJztcclxuXHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBEZWZpbmVzIHRoZSBwZXJjZW50dWFsIHNpemUgb2YgdGhlIGltYWdlIGJhc2VkIG9uIHRoZSBidXR0b24gc2l6ZS4gMTAwIG1lYW5zIHRoZSBpbWFnZSB3aWxsIGZpbGwgdGhlIHdob2xlIGJ1dHRvbixcclxuICAgICAqIDUwIG9ubHkgaGFsZiwgZXRjLi5cclxuICAgICAqL1xyXG4gICAgQElucHV0KCkgcGVyY2VudFNpemUgPSAxMDA7XHJcbn1cclxuIiwiPGltZyBzcmM9XCJ7e3NyY319XCJcclxuICAgIFtzdHlsZS53aWR0aF09XCJwZXJjZW50U2l6ZSArICclJ1wiXHJcbiAgICBbc3R5bGUuaGVpZ2h0XT1cInBlcmNlbnRTaXplICsgJyUnXCIgLz4iXX0=
|