@posiwise/shared-components 0.0.146 → 0.0.147

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.
Files changed (29) hide show
  1. package/fesm2022/posiwise-shared-components.mjs +128 -96
  2. package/fesm2022/posiwise-shared-components.mjs.map +1 -1
  3. package/lib/pw-tabs/pw-tabs.component.d.ts +1 -0
  4. package/package.json +4 -6
  5. package/esm2022/index.mjs +0 -22
  6. package/esm2022/lib/authenticator/authenticator.component.mjs +0 -39
  7. package/esm2022/lib/clearbit-icon/clearbit-icon.component.mjs +0 -34
  8. package/esm2022/lib/coming-soon/coming-soon.component.mjs +0 -29
  9. package/esm2022/lib/header/header.component.mjs +0 -38
  10. package/esm2022/lib/input-container/input-container.component.mjs +0 -91
  11. package/esm2022/lib/label-management/entity-group/entity-group.component.mjs +0 -154
  12. package/esm2022/lib/label-management/group-definition/group-definition.component.mjs +0 -178
  13. package/esm2022/lib/label-management/groups/groups.component.mjs +0 -236
  14. package/esm2022/lib/landing-page-footer-b/landing-page-footer-b.component.mjs +0 -26
  15. package/esm2022/lib/no-data/no-data.component.mjs +0 -75
  16. package/esm2022/lib/number-picker/number-picker.component.mjs +0 -304
  17. package/esm2022/lib/number-picker/number-picker.config.mjs +0 -2
  18. package/esm2022/lib/password-validation/password-validation.component.mjs +0 -55
  19. package/esm2022/lib/permission-tree/permission-tree.component.mjs +0 -111
  20. package/esm2022/lib/privacy-and-tos/privacy-and-tos.component.mjs +0 -119
  21. package/esm2022/lib/privacy-policy/privacy-policy.component.mjs +0 -23
  22. package/esm2022/lib/pw-tabs/pw-tabs.component.mjs +0 -50
  23. package/esm2022/lib/range-date-picker/date-range-picker.component.mjs +0 -48
  24. package/esm2022/lib/resource-shared-components.module.mjs +0 -99
  25. package/esm2022/lib/shared/shared-component.interface.mjs +0 -2
  26. package/esm2022/lib/shared-components.module.mjs +0 -211
  27. package/esm2022/lib/splash/splash.component.mjs +0 -12
  28. package/esm2022/lib/terms-conditions/terms-conditions.component.mjs +0 -32
  29. package/esm2022/posiwise-shared-components.mjs +0 -5
@@ -1,304 +0,0 @@
1
- import { Component, EventEmitter, Input, Output } from '@angular/core';
2
- import { NumberPickerService } from '@posiwise/common-services';
3
- import * as i0 from "@angular/core";
4
- import * as i1 from "@posiwise/common-services";
5
- import * as i2 from "@angular/forms";
6
- import * as i3 from "primeng/tooltip";
7
- import * as i4 from "@angular/common";
8
- export class NumberPickerComponent {
9
- constructor(numberPickerService) {
10
- this.numberPickerService = numberPickerService;
11
- this.eventHolder = null;
12
- this.countInterval = null;
13
- this.isInputFocused = false;
14
- this.size = 'md';
15
- this.customClass = {};
16
- this.mouseWheel = false;
17
- this.arrowKeys = true;
18
- this.inputReadOnly = false;
19
- this.showUpButton = true;
20
- this.showDownButton = true;
21
- this.valueChange = new EventEmitter();
22
- this.minReached = new EventEmitter();
23
- this.maxReached = new EventEmitter();
24
- this.pickStarted = new EventEmitter();
25
- this.pickStopped = new EventEmitter();
26
- this.pickUpStarted = new EventEmitter();
27
- this.pickUpStopped = new EventEmitter();
28
- this.pickDownStarted = new EventEmitter();
29
- this.pickDownStopped = new EventEmitter();
30
- }
31
- ngOnInit() {
32
- this.initPicker();
33
- }
34
- isHorizontal() {
35
- return this.buttonsOrientation !== 'v' && this.buttonsOrientation !== 'vertical';
36
- }
37
- onFocus(event) {
38
- event.preventDefault();
39
- event.stopPropagation();
40
- this.isInputFocused = true;
41
- }
42
- onBlur(event) {
43
- event.preventDefault();
44
- event.stopPropagation();
45
- this.isInputFocused = false;
46
- }
47
- onMouseWheel(event) {
48
- if (this.isInputFocused) {
49
- event.preventDefault();
50
- let wheelUp = null;
51
- let delta = null;
52
- if (event.deltaY) {
53
- delta = event.deltaY / 60;
54
- }
55
- if (event.detail) {
56
- delta = -event.detail / 2;
57
- }
58
- if (delta !== null) {
59
- wheelUp = delta > 0;
60
- }
61
- this.afterMouseWheels(wheelUp, event);
62
- event.stopPropagation();
63
- }
64
- }
65
- afterMouseWheels(wheelUp, event) {
66
- this.onPickStarted(wheelUp);
67
- if (wheelUp) {
68
- this.onIncrease(event);
69
- }
70
- else {
71
- this.onDecrease(event);
72
- }
73
- this.onPickStopped(wheelUp);
74
- }
75
- onValueChange(_event) {
76
- if (this.value > this.max) {
77
- this.value = this.max;
78
- }
79
- else if (this.value < this.min) {
80
- this.value = this.min;
81
- }
82
- if (this.parseVal(this.value) === 0 || this.parseVal(this.value)) {
83
- this.valueChange.emit(this.value);
84
- }
85
- }
86
- onDecrease(event) {
87
- event.preventDefault();
88
- if (this.canDecrease()) {
89
- this.value = this.round(this.value > this.min ? this.value - this.step : this.value);
90
- this.valueChange.emit(this.value);
91
- }
92
- else {
93
- this.minReached.emit(true);
94
- }
95
- event.stopPropagation();
96
- }
97
- onIncrease(event) {
98
- event.preventDefault();
99
- if (this.canIncrease()) {
100
- this.value = this.round(this.value < this.max ? this.value + this.step : this.value);
101
- this.valueChange.emit(this.value);
102
- }
103
- else {
104
- this.maxReached.emit(true);
105
- }
106
- event.stopPropagation();
107
- }
108
- onMouseDown(event, increase = true) {
109
- this.afterMouseDown(increase, event);
110
- }
111
- isArrowUpDown(key) {
112
- return key === 'ArrowUp' || key === 'ArrowDown';
113
- }
114
- isArrowUp(key) {
115
- return key === 'ArrowUp';
116
- }
117
- loopPick(increase, event) {
118
- this.onPickStarted(increase);
119
- this.eventHolder = setTimeout(() => {
120
- this.countInterval = setInterval(() => {
121
- if (increase) {
122
- this.onIncrease(event);
123
- }
124
- else {
125
- this.onDecrease(event);
126
- }
127
- }, this.pickTimer);
128
- }, this.pickStartAfter);
129
- }
130
- onMouseUp(event, increase = true) {
131
- this.afterMouseUp(increase, event);
132
- }
133
- onKeyDown(event) {
134
- if (this.isArrowUpDown(event.key)) {
135
- event.preventDefault();
136
- if (!this.eventHolder) {
137
- this.loopPick(this.isArrowUp(event.key), event);
138
- }
139
- }
140
- event.stopPropagation();
141
- }
142
- onKeyUp(event) {
143
- if (this.isArrowUpDown(event.key)) {
144
- event.preventDefault();
145
- this.afterPick(this.isArrowUp(event.key));
146
- }
147
- event.stopPropagation();
148
- }
149
- afterMouseDown(up, event) {
150
- event.preventDefault();
151
- if (this.isLeftClick(event)) {
152
- this.loopPick(up, event);
153
- }
154
- event.stopPropagation();
155
- }
156
- afterMouseUp(up, event) {
157
- event.preventDefault();
158
- this.afterPick(up);
159
- event.stopPropagation();
160
- }
161
- afterPick(up) {
162
- this.onPickStopped(up);
163
- this.clearTimers();
164
- }
165
- clearTimers() {
166
- clearTimeout(this.eventHolder);
167
- clearInterval(this.countInterval);
168
- this.eventHolder = null;
169
- this.countInterval = null;
170
- }
171
- parseVal(value) {
172
- if (typeof value === 'number') {
173
- return value;
174
- }
175
- return Number.parseFloat(value);
176
- }
177
- getPrecision(step) {
178
- return /^\d*$/.exec(String(step))[0].length;
179
- }
180
- round(value) {
181
- // eslint-disable-next-line no-restricted-properties
182
- return Math.round(value * 10 ** this.precision) / 10 ** this.precision;
183
- }
184
- canIncrease() {
185
- const canIncrease = this.value <= this.max - this.step;
186
- if (!canIncrease) {
187
- this.value = this.max;
188
- }
189
- return canIncrease;
190
- }
191
- canDecrease() {
192
- const canDecrease = this.value >= this.min + this.step;
193
- if (!canDecrease) {
194
- this.value = this.min;
195
- }
196
- return canDecrease;
197
- }
198
- onPickStarted(increase) {
199
- const isIncrease = increase;
200
- if (isIncrease) {
201
- // NOSONAR
202
- if (this.canIncrease()) {
203
- this.pickStarted.emit(true);
204
- this.pickUpStarted.emit(true);
205
- }
206
- }
207
- else if (this.canDecrease()) {
208
- this.pickStarted.emit(true);
209
- this.pickDownStarted.emit(true);
210
- }
211
- }
212
- onPickStopped(increase) {
213
- const isIncrease = increase;
214
- if (isIncrease) {
215
- // NOSONAR
216
- if (this.canIncrease()) {
217
- this.pickUpStopped.emit(true);
218
- this.pickStopped.emit(true);
219
- }
220
- }
221
- else if (this.canDecrease()) {
222
- this.pickDownStopped.emit(true);
223
- this.pickStopped.emit(true);
224
- }
225
- }
226
- isLeftClick(event) {
227
- return event.button === 0;
228
- }
229
- initPicker() {
230
- this.min = this.parseVal(this.min) || this.numberPickerService.min;
231
- this.max = this.parseVal(this.max) || this.numberPickerService.max;
232
- this.step = this.parseVal(this.step) || this.numberPickerService.step;
233
- this.value = this.parseVal(this.value) || this.numberPickerService.value;
234
- this.pickStartAfter =
235
- this.parseVal(this.pickStartAfter) || this.numberPickerService.pickStartAfter;
236
- this.pickTimer = this.parseVal(this.pickTimer) || this.numberPickerService.pickTimer;
237
- this.precision = this.getPrecision(this.step) || this.numberPickerService.precision;
238
- this.value = this.round(this.value);
239
- this.placeholder = this.placeholder ?? '';
240
- }
241
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: NumberPickerComponent, deps: [{ token: i1.NumberPickerService }], target: i0.ɵɵFactoryTarget.Component }); }
242
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: NumberPickerComponent, selector: "pw-number-picker", inputs: { min: "min", showTooltip: "showTooltip", tooltipText: "tooltipText", max: "max", step: "step", value: "value", pickStartAfter: "pickStartAfter", pickTimer: "pickTimer", prefix: "prefix", postfix: "postfix", placeholder: "placeholder", buttonsOrientation: "buttonsOrientation", size: "size", customClass: "customClass", mouseWheel: "mouseWheel", arrowKeys: "arrowKeys", inputReadOnly: "inputReadOnly", showUpButton: "showUpButton", showDownButton: "showDownButton" }, outputs: { valueChange: "valueChange", minReached: "minReached", maxReached: "maxReached", pickStarted: "pickStarted", pickStopped: "pickStopped", pickUpStarted: "pickUpStarted", pickUpStopped: "pickUpStopped", pickDownStarted: "pickDownStarted", pickDownStopped: "pickDownStopped" }, ngImport: i0, template: "<div class=\"input-group mb-3 input-{{ size }} {{ customClass.container }}\">\n <!-- Horizontal decrease button orientation -->\n <span *ngIf=\"isHorizontal() && showDownButton\"\n class=\"input-group-text decrease {{ customClass.down }}\"\n (click)=\"onDecrease($event)\"\n (keydown.enter)=\"onDecrease($event)\"\n (mouseup)=\"onMouseUp($event, false)\"\n (mousedown)=\"onMouseDown($event, false)\">-</span>\n <!-- Input prefix -->\n <span *ngIf=\"prefix\"\n class=\"input-group-text {{ customClass.prefix }}\">{{ prefix }}\n </span>\n <input type=\"number\"\n class=\"form-control\"\n name=\"input-spin-val\"\n [(ngModel)]=\"value\"\n [readOnly]=\"inputReadOnly\"\n (blur)=\"onBlur($event)\"\n (focus)=\"onFocus($event)\"\n (wheel)=\"mouseWheel && onMouseWheel($event)\"\n (keyup)=\"arrowKeys && onKeyUp($event)\"\n (keydown.enter)=\"arrowKeys && onKeyDown($event)\"\n (keydown.arrowup)=\"arrowKeys && onIncrease($event)\"\n (keydown.arrowdown)=\"arrowKeys && onDecrease($event)\"\n (change)=\"onValueChange($event)\"\n [placeholder]=\"placeholder\" />\n <!-- Input postfix -->\n\n <span *ngIf=\"postfix\"\n class=\"input-group-text {{ customClass.postfix }}\"\n [style.borderLeft]=\"'0'\">{{postfix}}\n <span class=\"tooltip-wrap ms-1\"\n *ngIf=\"showTooltip && tooltipText\"\n [pTooltip]=\"tooltipText\"\n [appendTo]=\"'body'\"\n [tooltipPosition]=\"tooltipPosition || 'top'\">\n <i class=\"fas fa-info-circle\"></i>\n </span>\n </span>\n\n <!-- Horizontal increase button orientation -->\n <span *ngIf=\"isHorizontal() && showUpButton\"\n class=\"input-group-text increase {{ customClass.up }}\"\n [style.borderLeft]=\"!postfix ? '0' : ''\"\n (click)=\"onIncrease($event)\"\n (keydown.enter)=\"onIncrease($event)\"\n (mouseup)=\"onMouseUp($event)\"\n (mousedown)=\"onMouseDown($event)\">+</span>\n <!-- Vertical buttons orientation -->\n <span *ngIf=\"!isHorizontal()\"\n class=\"input-group-text vertical p-0\">\n <span *ngIf=\"showUpButton\"\n class=\"{{ customClass.up }}\"\n (click)=\"onIncrease($event)\"\n (keydown.enter)=\"onIncrease($event)\"\n (mouseup)=\"onMouseUp($event)\"\n (mousedown)=\"onMouseDown($event)\">+</span>\n <span *ngIf=\"showDownButton\"\n class=\"{{ customClass.down }}\"\n (keydown.enter)=\"onDecrease($event)\"\n (click)=\"onDecrease($event)\"\n (mouseup)=\"onMouseUp($event, false)\"\n (mousedown)=\"onMouseDown($event, false)\">-</span>\n </span>\n</div>\n", styles: ["input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{appearance:none;margin:0}.increase:hover,.decrease:hover{-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;cursor:pointer;background-color:#d8d8d8}.increase{border-top-right-radius:3px!important;border-bottom-right-radius:3px!important}.vertical{display:flex;justify-content:center;flex-direction:column;text-align:center;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;cursor:pointer}.vertical span{line-height:15px}.input-md .vertical span,.input-sm .vertical span{padding:2px 10px}.input-lg .vertical span{padding:4px 10px}.input-xlg .vertical span{padding:7px 10px}.input-md,.input-medium{height:45px}.input-lg,.input-large{height:50px}.input-xlg,.input-xlarge{height:75px}.input-md input,.input-medium input,.input-md span,.input-medium span{font-size:22px}.input-lg input,.input-large input,.input-lg span,.input-large span{font-size:25px}.input-xlg input,.input-xlarge input,.input-xlg span,.input-xlarge span{font-size:38px}\n"], dependencies: [{ kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
243
- }
244
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: NumberPickerComponent, decorators: [{
245
- type: Component,
246
- args: [{ selector: 'pw-number-picker', template: "<div class=\"input-group mb-3 input-{{ size }} {{ customClass.container }}\">\n <!-- Horizontal decrease button orientation -->\n <span *ngIf=\"isHorizontal() && showDownButton\"\n class=\"input-group-text decrease {{ customClass.down }}\"\n (click)=\"onDecrease($event)\"\n (keydown.enter)=\"onDecrease($event)\"\n (mouseup)=\"onMouseUp($event, false)\"\n (mousedown)=\"onMouseDown($event, false)\">-</span>\n <!-- Input prefix -->\n <span *ngIf=\"prefix\"\n class=\"input-group-text {{ customClass.prefix }}\">{{ prefix }}\n </span>\n <input type=\"number\"\n class=\"form-control\"\n name=\"input-spin-val\"\n [(ngModel)]=\"value\"\n [readOnly]=\"inputReadOnly\"\n (blur)=\"onBlur($event)\"\n (focus)=\"onFocus($event)\"\n (wheel)=\"mouseWheel && onMouseWheel($event)\"\n (keyup)=\"arrowKeys && onKeyUp($event)\"\n (keydown.enter)=\"arrowKeys && onKeyDown($event)\"\n (keydown.arrowup)=\"arrowKeys && onIncrease($event)\"\n (keydown.arrowdown)=\"arrowKeys && onDecrease($event)\"\n (change)=\"onValueChange($event)\"\n [placeholder]=\"placeholder\" />\n <!-- Input postfix -->\n\n <span *ngIf=\"postfix\"\n class=\"input-group-text {{ customClass.postfix }}\"\n [style.borderLeft]=\"'0'\">{{postfix}}\n <span class=\"tooltip-wrap ms-1\"\n *ngIf=\"showTooltip && tooltipText\"\n [pTooltip]=\"tooltipText\"\n [appendTo]=\"'body'\"\n [tooltipPosition]=\"tooltipPosition || 'top'\">\n <i class=\"fas fa-info-circle\"></i>\n </span>\n </span>\n\n <!-- Horizontal increase button orientation -->\n <span *ngIf=\"isHorizontal() && showUpButton\"\n class=\"input-group-text increase {{ customClass.up }}\"\n [style.borderLeft]=\"!postfix ? '0' : ''\"\n (click)=\"onIncrease($event)\"\n (keydown.enter)=\"onIncrease($event)\"\n (mouseup)=\"onMouseUp($event)\"\n (mousedown)=\"onMouseDown($event)\">+</span>\n <!-- Vertical buttons orientation -->\n <span *ngIf=\"!isHorizontal()\"\n class=\"input-group-text vertical p-0\">\n <span *ngIf=\"showUpButton\"\n class=\"{{ customClass.up }}\"\n (click)=\"onIncrease($event)\"\n (keydown.enter)=\"onIncrease($event)\"\n (mouseup)=\"onMouseUp($event)\"\n (mousedown)=\"onMouseDown($event)\">+</span>\n <span *ngIf=\"showDownButton\"\n class=\"{{ customClass.down }}\"\n (keydown.enter)=\"onDecrease($event)\"\n (click)=\"onDecrease($event)\"\n (mouseup)=\"onMouseUp($event, false)\"\n (mousedown)=\"onMouseDown($event, false)\">-</span>\n </span>\n</div>\n", styles: ["input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{appearance:none;margin:0}.increase:hover,.decrease:hover{-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;cursor:pointer;background-color:#d8d8d8}.increase{border-top-right-radius:3px!important;border-bottom-right-radius:3px!important}.vertical{display:flex;justify-content:center;flex-direction:column;text-align:center;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;cursor:pointer}.vertical span{line-height:15px}.input-md .vertical span,.input-sm .vertical span{padding:2px 10px}.input-lg .vertical span{padding:4px 10px}.input-xlg .vertical span{padding:7px 10px}.input-md,.input-medium{height:45px}.input-lg,.input-large{height:50px}.input-xlg,.input-xlarge{height:75px}.input-md input,.input-medium input,.input-md span,.input-medium span{font-size:22px}.input-lg input,.input-large input,.input-lg span,.input-large span{font-size:25px}.input-xlg input,.input-xlarge input,.input-xlg span,.input-xlarge span{font-size:38px}\n"] }]
247
- }], ctorParameters: () => [{ type: i1.NumberPickerService }], propDecorators: { min: [{
248
- type: Input
249
- }], showTooltip: [{
250
- type: Input
251
- }], tooltipText: [{
252
- type: Input
253
- }], max: [{
254
- type: Input
255
- }], step: [{
256
- type: Input
257
- }], value: [{
258
- type: Input
259
- }], pickStartAfter: [{
260
- type: Input
261
- }], pickTimer: [{
262
- type: Input
263
- }], prefix: [{
264
- type: Input
265
- }], postfix: [{
266
- type: Input
267
- }], placeholder: [{
268
- type: Input
269
- }], buttonsOrientation: [{
270
- type: Input
271
- }], size: [{
272
- type: Input
273
- }], customClass: [{
274
- type: Input
275
- }], mouseWheel: [{
276
- type: Input
277
- }], arrowKeys: [{
278
- type: Input
279
- }], inputReadOnly: [{
280
- type: Input
281
- }], showUpButton: [{
282
- type: Input
283
- }], showDownButton: [{
284
- type: Input
285
- }], valueChange: [{
286
- type: Output
287
- }], minReached: [{
288
- type: Output
289
- }], maxReached: [{
290
- type: Output
291
- }], pickStarted: [{
292
- type: Output
293
- }], pickStopped: [{
294
- type: Output
295
- }], pickUpStarted: [{
296
- type: Output
297
- }], pickUpStopped: [{
298
- type: Output
299
- }], pickDownStarted: [{
300
- type: Output
301
- }], pickDownStopped: [{
302
- type: Output
303
- }] } });
304
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"number-picker.component.js","sourceRoot":"","sources":["../../../../../../libs/shared-components/src/lib/number-picker/number-picker.component.ts","../../../../../../libs/shared-components/src/lib/number-picker/number-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\n\nimport { NumberPickerService } from '@posiwise/common-services';\n\nimport { buttonsOrientationType, CustomClasses, sizeType } from './number-picker.config';\n\n@Component({\n    selector: 'pw-number-picker',\n    templateUrl: './number-picker.component.html',\n    styleUrls: ['./number-picker.component.scss']\n})\nexport class NumberPickerComponent implements OnInit {\n    private precision: number;\n\n    private eventHolder = null;\n\n    private countInterval = null;\n\n    private isInputFocused = false;\n\n    @Input() min: number;\n\n    @Input() showTooltip: boolean;\n\n    @Input() tooltipText: string;\n\n    @Input() max: number;\n\n    @Input() step: number;\n\n    @Input() value: number;\n\n    @Input() pickStartAfter: number;\n\n    @Input() pickTimer: number;\n\n    @Input() prefix: string;\n\n    @Input() postfix: string;\n\n    @Input() placeholder: string;\n\n    @Input() buttonsOrientation: buttonsOrientationType;\n\n    @Input() size: sizeType = 'md';\n\n    @Input() customClass: CustomClasses = {};\n\n    @Input() mouseWheel = false;\n\n    @Input() arrowKeys = true;\n\n    @Input() inputReadOnly = false;\n\n    @Input() showUpButton = true;\n\n    @Input() showDownButton = true;\n\n    @Output() valueChange: EventEmitter<number> = new EventEmitter();\n\n    @Output() minReached: EventEmitter<boolean> = new EventEmitter();\n\n    @Output() maxReached: EventEmitter<boolean> = new EventEmitter();\n\n    @Output() pickStarted: EventEmitter<boolean> = new EventEmitter();\n\n    @Output() pickStopped: EventEmitter<boolean> = new EventEmitter();\n\n    @Output() pickUpStarted: EventEmitter<boolean> = new EventEmitter();\n\n    @Output() pickUpStopped: EventEmitter<boolean> = new EventEmitter();\n\n    @Output() pickDownStarted: EventEmitter<boolean> = new EventEmitter();\n\n    @Output() pickDownStopped: EventEmitter<boolean> = new EventEmitter();\n\n    constructor(private readonly numberPickerService: NumberPickerService) {}\n\n    ngOnInit() {\n        this.initPicker();\n    }\n\n    isHorizontal(): boolean {\n        return this.buttonsOrientation !== 'v' && this.buttonsOrientation !== 'vertical';\n    }\n\n    onFocus(event: FocusEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n        this.isInputFocused = true;\n    }\n\n    onBlur(event: Event) {\n        event.preventDefault();\n        event.stopPropagation();\n        this.isInputFocused = false;\n    }\n\n    onMouseWheel(event: WheelEvent) {\n        if (this.isInputFocused) {\n            event.preventDefault();\n            let wheelUp = null;\n            let delta = null;\n\n            if (event.deltaY) {\n                delta = event.deltaY / 60;\n            }\n            if (event.detail) {\n                delta = -event.detail / 2;\n            }\n            if (delta !== null) {\n                wheelUp = delta > 0;\n            }\n\n            this.afterMouseWheels(wheelUp, event);\n            event.stopPropagation();\n        }\n    }\n\n    private afterMouseWheels(wheelUp: boolean, event: WheelEvent) {\n        this.onPickStarted(wheelUp);\n        if (wheelUp) {\n            this.onIncrease(event);\n        } else {\n            this.onDecrease(event);\n        }\n        this.onPickStopped(wheelUp);\n    }\n\n    onValueChange(_event: Event) {\n        if (this.value > this.max) {\n            this.value = this.max;\n        } else if (this.value < this.min) {\n            this.value = this.min;\n        }\n        if (this.parseVal(this.value) === 0 || this.parseVal(this.value)) {\n            this.valueChange.emit(this.value);\n        }\n    }\n\n    onDecrease(event: MouseEvent | WheelEvent | KeyboardEvent) {\n        event.preventDefault();\n        if (this.canDecrease()) {\n            this.value = this.round(this.value > this.min ? this.value - this.step : this.value);\n            this.valueChange.emit(this.value);\n        } else {\n            this.minReached.emit(true);\n        }\n        event.stopPropagation();\n    }\n\n    onIncrease(event: MouseEvent | WheelEvent | KeyboardEvent) {\n        event.preventDefault();\n        if (this.canIncrease()) {\n            this.value = this.round(this.value < this.max ? this.value + this.step : this.value);\n            this.valueChange.emit(this.value);\n        } else {\n            this.maxReached.emit(true);\n        }\n        event.stopPropagation();\n    }\n\n    onMouseDown(event: MouseEvent, increase = true) {\n        this.afterMouseDown(increase, event);\n    }\n\n    private isArrowUpDown(key: string): boolean {\n        return key === 'ArrowUp' || key === 'ArrowDown';\n    }\n\n    private isArrowUp(key: string): boolean {\n        return key === 'ArrowUp';\n    }\n\n    private loopPick(increase: boolean, event: MouseEvent | KeyboardEvent) {\n        this.onPickStarted(increase);\n        this.eventHolder = setTimeout(() => {\n            this.countInterval = setInterval(() => {\n                if (increase) {\n                    this.onIncrease(event);\n                } else {\n                    this.onDecrease(event);\n                }\n            }, this.pickTimer);\n        }, this.pickStartAfter);\n    }\n\n    onMouseUp(event: MouseEvent, increase = true) {\n        this.afterMouseUp(increase, event);\n    }\n\n    onKeyDown(event: KeyboardEvent) {\n        if (this.isArrowUpDown(event.key)) {\n            event.preventDefault();\n            if (!this.eventHolder) {\n                this.loopPick(this.isArrowUp(event.key), event);\n            }\n        }\n        event.stopPropagation();\n    }\n\n    onKeyUp(event: KeyboardEvent) {\n        if (this.isArrowUpDown(event.key)) {\n            event.preventDefault();\n            this.afterPick(this.isArrowUp(event.key));\n        }\n        event.stopPropagation();\n    }\n\n    private afterMouseDown(up: boolean, event: MouseEvent) {\n        event.preventDefault();\n        if (this.isLeftClick(event)) {\n            this.loopPick(up, event);\n        }\n        event.stopPropagation();\n    }\n\n    private afterMouseUp(up: boolean, event: MouseEvent) {\n        event.preventDefault();\n        this.afterPick(up);\n        event.stopPropagation();\n    }\n\n    private afterPick(up: boolean) {\n        this.onPickStopped(up);\n        this.clearTimers();\n    }\n\n    private clearTimers() {\n        clearTimeout(this.eventHolder);\n        clearInterval(this.countInterval);\n        this.eventHolder = null;\n        this.countInterval = null;\n    }\n\n    private parseVal(value: string | number) {\n        if (typeof value === 'number') {\n            return value;\n        }\n\n        return Number.parseFloat(value);\n    }\n\n    private getPrecision(step: number): number {\n        return /^\\d*$/.exec(String(step))[0].length;\n    }\n\n    private round(value: number): number {\n        // eslint-disable-next-line no-restricted-properties\n        return Math.round(value * 10 ** this.precision) / 10 ** this.precision;\n    }\n\n    private canIncrease(): boolean {\n        const canIncrease = this.value <= this.max - this.step;\n        if (!canIncrease) {\n            this.value = this.max;\n        }\n\n        return canIncrease;\n    }\n\n    private canDecrease(): boolean {\n        const canDecrease = this.value >= this.min + this.step;\n        if (!canDecrease) {\n            this.value = this.min;\n        }\n\n        return canDecrease;\n    }\n\n    private onPickStarted(increase: boolean) {\n        const isIncrease = increase;\n        if (isIncrease) {\n            // NOSONAR\n            if (this.canIncrease()) {\n                this.pickStarted.emit(true);\n                this.pickUpStarted.emit(true);\n            }\n        } else if (this.canDecrease()) {\n            this.pickStarted.emit(true);\n            this.pickDownStarted.emit(true);\n        }\n    }\n\n    private onPickStopped(increase: boolean) {\n        const isIncrease = increase;\n        if (isIncrease) {\n            // NOSONAR\n            if (this.canIncrease()) {\n                this.pickUpStopped.emit(true);\n                this.pickStopped.emit(true);\n            }\n        } else if (this.canDecrease()) {\n            this.pickDownStopped.emit(true);\n            this.pickStopped.emit(true);\n        }\n    }\n\n    private isLeftClick(event): boolean {\n        return event.button === 0;\n    }\n\n    private initPicker(): void {\n        this.min = this.parseVal(this.min) || this.numberPickerService.min;\n        this.max = this.parseVal(this.max) || this.numberPickerService.max;\n        this.step = this.parseVal(this.step) || this.numberPickerService.step;\n        this.value = this.parseVal(this.value) || this.numberPickerService.value;\n        this.pickStartAfter =\n            this.parseVal(this.pickStartAfter) || this.numberPickerService.pickStartAfter;\n        this.pickTimer = this.parseVal(this.pickTimer) || this.numberPickerService.pickTimer;\n        this.precision = this.getPrecision(this.step) || this.numberPickerService.precision;\n        this.value = this.round(this.value);\n        this.placeholder = this.placeholder ?? '';\n    }\n}\n","<div class=\"input-group mb-3 input-{{ size }} {{ customClass.container }}\">\n  <!-- Horizontal decrease button orientation -->\n  <span *ngIf=\"isHorizontal() && showDownButton\"\n    class=\"input-group-text decrease {{ customClass.down }}\"\n    (click)=\"onDecrease($event)\"\n    (keydown.enter)=\"onDecrease($event)\"\n    (mouseup)=\"onMouseUp($event, false)\"\n    (mousedown)=\"onMouseDown($event, false)\">-</span>\n  <!-- Input prefix -->\n  <span *ngIf=\"prefix\"\n    class=\"input-group-text {{ customClass.prefix }}\">{{ prefix }}\n  </span>\n  <input type=\"number\"\n    class=\"form-control\"\n    name=\"input-spin-val\"\n    [(ngModel)]=\"value\"\n    [readOnly]=\"inputReadOnly\"\n    (blur)=\"onBlur($event)\"\n    (focus)=\"onFocus($event)\"\n    (wheel)=\"mouseWheel && onMouseWheel($event)\"\n    (keyup)=\"arrowKeys && onKeyUp($event)\"\n    (keydown.enter)=\"arrowKeys && onKeyDown($event)\"\n    (keydown.arrowup)=\"arrowKeys && onIncrease($event)\"\n    (keydown.arrowdown)=\"arrowKeys && onDecrease($event)\"\n    (change)=\"onValueChange($event)\"\n    [placeholder]=\"placeholder\" />\n  <!-- Input postfix -->\n\n  <span *ngIf=\"postfix\"\n    class=\"input-group-text {{ customClass.postfix }}\"\n    [style.borderLeft]=\"'0'\">{{postfix}}\n    <span class=\"tooltip-wrap ms-1\"\n      *ngIf=\"showTooltip && tooltipText\"\n      [pTooltip]=\"tooltipText\"\n      [appendTo]=\"'body'\"\n      [tooltipPosition]=\"tooltipPosition || 'top'\">\n      <i class=\"fas fa-info-circle\"></i>\n    </span>\n  </span>\n\n  <!-- Horizontal increase button orientation -->\n  <span *ngIf=\"isHorizontal() && showUpButton\"\n    class=\"input-group-text increase {{ customClass.up }}\"\n    [style.borderLeft]=\"!postfix ? '0' : ''\"\n    (click)=\"onIncrease($event)\"\n    (keydown.enter)=\"onIncrease($event)\"\n    (mouseup)=\"onMouseUp($event)\"\n    (mousedown)=\"onMouseDown($event)\">+</span>\n  <!-- Vertical buttons orientation -->\n  <span *ngIf=\"!isHorizontal()\"\n    class=\"input-group-text vertical p-0\">\n    <span *ngIf=\"showUpButton\"\n      class=\"{{ customClass.up }}\"\n      (click)=\"onIncrease($event)\"\n      (keydown.enter)=\"onIncrease($event)\"\n      (mouseup)=\"onMouseUp($event)\"\n      (mousedown)=\"onMouseDown($event)\">+</span>\n    <span *ngIf=\"showDownButton\"\n      class=\"{{ customClass.down }}\"\n      (keydown.enter)=\"onDecrease($event)\"\n      (click)=\"onDecrease($event)\"\n      (mouseup)=\"onMouseUp($event, false)\"\n      (mousedown)=\"onMouseDown($event, false)\">-</span>\n  </span>\n</div>\n"]}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnVtYmVyLXBpY2tlci5jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3NoYXJlZC1jb21wb25lbnRzL3NyYy9saWIvbnVtYmVyLXBpY2tlci9udW1iZXItcGlja2VyLmNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgYnV0dG9uc09yaWVudGF0aW9uVHlwZSA9ICdob3Jpem9udGFsJyB8ICd2ZXJ0aWNhbCcgfCAnaCcgfCAndic7XG5leHBvcnQgdHlwZSBzaXplVHlwZSA9ICdtZWRpdW0nIHwgJ2xhcmdlJyB8ICdzbWFsbCcgfCAneGxhcmdlJyB8ICdtZCcgfCAnbGcnIHwgJ3NtJyB8ICd4bGcnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEN1c3RvbUNsYXNzZXMge1xuICAgIGNvbnRhaW5lcj86IHN0cmluZzsgLy8gY3VzdG9tIGNsYXNzIGZvciB0aGUgY29tcG9uZW50IGNvbnRhaW5lclxuICAgIHVwPzogc3RyaW5nOyAvLyBjdXN0b20gY2xhc3MgZm9yIHRoZSB1cHdhcmRzIGJ1dHRvbnNcbiAgICBkb3duPzogc3RyaW5nOyAvLyBjdXN0b20gY2xhc3MgZm9yIHRoZSBkb3dud2FyZHMgYnV0dG9uc1xuICAgIHBvc3RmaXg/OiBzdHJpbmc7IC8vIGN1c3RvbSBjbGFzcyBmb3IgdGhlIHRleHQgYWZ0ZXIgdGhlIGlucHV0XG4gICAgcHJlZml4Pzogc3RyaW5nOyAvLyBjdXN0b20gY2xhc3MgZm9yIHRoZSB0ZXh0IGJlZm9yZSB0aGUgaW5wdXRcbiAgICBzdWNjZXNzPzogc3RyaW5nOyAvLyBUT0RPOlxuICAgIGVycm9yPzogc3RyaW5nOyAvLyBUT0RPOlxufVxuIl19
@@ -1,55 +0,0 @@
1
- import { Component, EventEmitter, Injector, Input, Output, TemplateRef, ViewChild } from '@angular/core';
2
- import { AppBaseComponent } from '@posiwise/app-base-component';
3
- import { StatusCodes } from 'http-status-codes';
4
- import { NgbModal } from '@ng-bootstrap/ng-bootstrap';
5
- import * as i0 from "@angular/core";
6
- import * as i1 from "@ng-bootstrap/ng-bootstrap";
7
- import * as i2 from "@angular/forms";
8
- import * as i3 from "@posiwise/directives";
9
- import * as i4 from "@jsverse/transloco";
10
- export class PasswordValidationComponent extends AppBaseComponent {
11
- constructor(injector, modal) {
12
- super(injector);
13
- this.modal = modal;
14
- this.confirmMessage = 'User.Account.Message.EnterPassword';
15
- this.successEvent = new EventEmitter();
16
- }
17
- open() {
18
- this.modal.open(this.content, { centered: true, windowClass: 'modal-holder' });
19
- }
20
- validatePassword() {
21
- if (this.password) {
22
- this.buttonBusy = true;
23
- this.userService
24
- .checkPassword({ password: this.password })
25
- .subscribe(data => {
26
- if (data && data?.status === StatusCodes.OK) {
27
- this.successEvent.emit(true);
28
- this.modal.dismissAll();
29
- this.password = null;
30
- }
31
- else {
32
- this.successEvent.emit(false);
33
- this.password = null;
34
- }
35
- })
36
- .add(() => {
37
- this.buttonBusy = false;
38
- });
39
- }
40
- }
41
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PasswordValidationComponent, deps: [{ token: i0.Injector }, { token: i1.NgbModal }], target: i0.ɵɵFactoryTarget.Component }); }
42
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PasswordValidationComponent, selector: "pw-password-validation", inputs: { confirmMessage: "confirmMessage" }, outputs: { successEvent: "successEvent" }, viewQueries: [{ propertyName: "content", first: true, predicate: ["content"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<ng-template #content\n let-modal>\n <div class=\"modal-header\">\n <h5 class=\"modal-title\">Confirm</h5>\n <button type=\"button\"\n class=\"btn-close float-end\"\n aria-label=\"Close\"\n (click)=\"modal.dismiss()\">\n </button>\n </div>\n <div class=\"modal-body\">\n <strong class=\"p3\">{{ confirmMessage | transloco }}</strong>\n <div>\n <ng-content></ng-content>\n </div>\n <div class=\"row\">\n <div class=\"col-12\">\n <input type=\"password\"\n #passwordRef\n [(ngModel)]=\"password\"\n class=\"form-control\"\n placeholder=\"Current Password\" />\n </div>\n </div>\n <div class=\"row mt-2\">\n <div class=\"col-12\">\n <button [buttonBusy]=\"buttonBusy\"\n class=\"btn btn-primary float-end\"\n type=\"button\"\n (click)=\"validatePassword()\">\n {{ 'Button.Confirm' | transloco }}\n </button>\n </div>\n </div>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.ButtonBusyDirective, selector: "[buttonBusy]", inputs: ["buttonBusy", "busyText"] }, { kind: "pipe", type: i4.TranslocoPipe, name: "transloco" }] }); }
43
- }
44
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PasswordValidationComponent, decorators: [{
45
- type: Component,
46
- args: [{ selector: 'pw-password-validation', template: "<ng-template #content\n let-modal>\n <div class=\"modal-header\">\n <h5 class=\"modal-title\">Confirm</h5>\n <button type=\"button\"\n class=\"btn-close float-end\"\n aria-label=\"Close\"\n (click)=\"modal.dismiss()\">\n </button>\n </div>\n <div class=\"modal-body\">\n <strong class=\"p3\">{{ confirmMessage | transloco }}</strong>\n <div>\n <ng-content></ng-content>\n </div>\n <div class=\"row\">\n <div class=\"col-12\">\n <input type=\"password\"\n #passwordRef\n [(ngModel)]=\"password\"\n class=\"form-control\"\n placeholder=\"Current Password\" />\n </div>\n </div>\n <div class=\"row mt-2\">\n <div class=\"col-12\">\n <button [buttonBusy]=\"buttonBusy\"\n class=\"btn btn-primary float-end\"\n type=\"button\"\n (click)=\"validatePassword()\">\n {{ 'Button.Confirm' | transloco }}\n </button>\n </div>\n </div>\n </div>\n</ng-template>\n" }]
47
- }], ctorParameters: () => [{ type: i0.Injector }, { type: i1.NgbModal }], propDecorators: { content: [{
48
- type: ViewChild,
49
- args: ['content', { static: true }]
50
- }], confirmMessage: [{
51
- type: Input
52
- }], successEvent: [{
53
- type: Output
54
- }] } });
55
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFzc3dvcmQtdmFsaWRhdGlvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3NoYXJlZC1jb21wb25lbnRzL3NyYy9saWIvcGFzc3dvcmQtdmFsaWRhdGlvbi9wYXNzd29yZC12YWxpZGF0aW9uLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvc2hhcmVkLWNvbXBvbmVudHMvc3JjL2xpYi9wYXNzd29yZC12YWxpZGF0aW9uL3Bhc3N3b3JkLXZhbGlkYXRpb24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNILFNBQVMsRUFDVCxZQUFZLEVBQ1osUUFBUSxFQUNSLEtBQUssRUFDTCxNQUFNLEVBQ04sV0FBVyxFQUNYLFNBQVMsRUFDWixNQUFNLGVBQWUsQ0FBQztBQUV2QixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUVoRSxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFFaEQsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLDRCQUE0QixDQUFDOzs7Ozs7QUFRdEQsTUFBTSxPQUFPLDJCQUE0QixTQUFRLGdCQUFnQjtJQVc3RCxZQUNJLFFBQWtCLEVBQ0QsS0FBZTtRQUVoQyxLQUFLLENBQUMsUUFBUSxDQUFDLENBQUM7UUFGQyxVQUFLLEdBQUwsS0FBSyxDQUFVO1FBWDNCLG1CQUFjLEdBQUcsb0NBQW9DLENBQUM7UUFHL0QsaUJBQVksR0FBMEIsSUFBSSxZQUFZLEVBQUUsQ0FBQztJQVd6RCxDQUFDO0lBRUQsSUFBSTtRQUNBLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLFdBQVcsRUFBRSxjQUFjLEVBQUUsQ0FBQyxDQUFDO0lBQ25GLENBQUM7SUFFRCxnQkFBZ0I7UUFDWixJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUNoQixJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQztZQUN2QixJQUFJLENBQUMsV0FBVztpQkFDWCxhQUFhLENBQUMsRUFBRSxRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDO2lCQUMxQyxTQUFTLENBQUMsSUFBSSxDQUFDLEVBQUU7Z0JBQ2QsSUFBSSxJQUFJLElBQUksSUFBSSxFQUFFLE1BQU0sS0FBSyxXQUFXLENBQUMsRUFBRSxFQUFFLENBQUM7b0JBQzFDLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO29CQUM3QixJQUFJLENBQUMsS0FBSyxDQUFDLFVBQVUsRUFBRSxDQUFDO29CQUN4QixJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQztnQkFDekIsQ0FBQztxQkFBTSxDQUFDO29CQUNKLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO29CQUM5QixJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQztnQkFDekIsQ0FBQztZQUNMLENBQUMsQ0FBQztpQkFDRCxHQUFHLENBQUMsR0FBRyxFQUFFO2dCQUNOLElBQUksQ0FBQyxVQUFVLEdBQUcsS0FBSyxDQUFDO1lBQzVCLENBQUMsQ0FBQyxDQUFDO1FBQ1gsQ0FBQztJQUNMLENBQUM7K0dBekNRLDJCQUEyQjttR0FBM0IsMkJBQTJCLGdTQ3RCeEMsMi9CQW9DQTs7NEZEZGEsMkJBQTJCO2tCQUp2QyxTQUFTOytCQUNJLHdCQUF3QjtvR0FJTSxPQUFPO3NCQUE5QyxTQUFTO3VCQUFDLFNBQVMsRUFBRSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUU7Z0JBQzdCLGNBQWM7c0JBQXRCLEtBQUs7Z0JBR04sWUFBWTtzQkFEWCxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgICBDb21wb25lbnQsXG4gICAgRXZlbnRFbWl0dGVyLFxuICAgIEluamVjdG9yLFxuICAgIElucHV0LFxuICAgIE91dHB1dCxcbiAgICBUZW1wbGF0ZVJlZixcbiAgICBWaWV3Q2hpbGRcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IEFwcEJhc2VDb21wb25lbnQgfSBmcm9tICdAcG9zaXdpc2UvYXBwLWJhc2UtY29tcG9uZW50JztcblxuaW1wb3J0IHsgU3RhdHVzQ29kZXMgfSBmcm9tICdodHRwLXN0YXR1cy1jb2Rlcyc7XG5cbmltcG9ydCB7IE5nYk1vZGFsIH0gZnJvbSAnQG5nLWJvb3RzdHJhcC9uZy1ib290c3RyYXAnO1xuXG5pbXBvcnQgeyBTaGFyZWRNb2RhbENvbnRleHQgfSBmcm9tICcuLi9zaGFyZWQvc2hhcmVkLWNvbXBvbmVudC5pbnRlcmZhY2UnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3B3LXBhc3N3b3JkLXZhbGlkYXRpb24nLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9wYXNzd29yZC12YWxpZGF0aW9uLmNvbXBvbmVudC5odG1sJ1xufSlcbmV4cG9ydCBjbGFzcyBQYXNzd29yZFZhbGlkYXRpb25Db21wb25lbnQgZXh0ZW5kcyBBcHBCYXNlQ29tcG9uZW50IHtcbiAgICBAVmlld0NoaWxkKCdjb250ZW50JywgeyBzdGF0aWM6IHRydWUgfSkgY29udGVudDogVGVtcGxhdGVSZWY8U2hhcmVkTW9kYWxDb250ZXh0PjtcbiAgICBASW5wdXQoKSBjb25maXJtTWVzc2FnZSA9ICdVc2VyLkFjY291bnQuTWVzc2FnZS5FbnRlclBhc3N3b3JkJztcblxuICAgIEBPdXRwdXQoKVxuICAgIHN1Y2Nlc3NFdmVudDogRXZlbnRFbWl0dGVyPGJvb2xlYW4+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuXG4gICAgcGFzc3dvcmQ6IHN0cmluZztcblxuICAgIGJ1dHRvbkJ1c3k6IGJvb2xlYW47XG5cbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgaW5qZWN0b3I6IEluamVjdG9yLFxuICAgICAgICBwcml2YXRlIHJlYWRvbmx5IG1vZGFsOiBOZ2JNb2RhbFxuICAgICkge1xuICAgICAgICBzdXBlcihpbmplY3Rvcik7XG4gICAgfVxuXG4gICAgb3BlbigpIHtcbiAgICAgICAgdGhpcy5tb2RhbC5vcGVuKHRoaXMuY29udGVudCwgeyBjZW50ZXJlZDogdHJ1ZSwgd2luZG93Q2xhc3M6ICdtb2RhbC1ob2xkZXInIH0pO1xuICAgIH1cblxuICAgIHZhbGlkYXRlUGFzc3dvcmQoKSB7XG4gICAgICAgIGlmICh0aGlzLnBhc3N3b3JkKSB7XG4gICAgICAgICAgICB0aGlzLmJ1dHRvbkJ1c3kgPSB0cnVlO1xuICAgICAgICAgICAgdGhpcy51c2VyU2VydmljZVxuICAgICAgICAgICAgICAgIC5jaGVja1Bhc3N3b3JkKHsgcGFzc3dvcmQ6IHRoaXMucGFzc3dvcmQgfSlcbiAgICAgICAgICAgICAgICAuc3Vic2NyaWJlKGRhdGEgPT4ge1xuICAgICAgICAgICAgICAgICAgICBpZiAoZGF0YSAmJiBkYXRhPy5zdGF0dXMgPT09IFN0YXR1c0NvZGVzLk9LKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICB0aGlzLnN1Y2Nlc3NFdmVudC5lbWl0KHRydWUpO1xuICAgICAgICAgICAgICAgICAgICAgICAgdGhpcy5tb2RhbC5kaXNtaXNzQWxsKCk7XG4gICAgICAgICAgICAgICAgICAgICAgICB0aGlzLnBhc3N3b3JkID0gbnVsbDtcbiAgICAgICAgICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHRoaXMuc3VjY2Vzc0V2ZW50LmVtaXQoZmFsc2UpO1xuICAgICAgICAgICAgICAgICAgICAgICAgdGhpcy5wYXNzd29yZCA9IG51bGw7XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICB9KVxuICAgICAgICAgICAgICAgIC5hZGQoKCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICB0aGlzLmJ1dHRvbkJ1c3kgPSBmYWxzZTtcbiAgICAgICAgICAgICAgICB9KTtcbiAgICAgICAgfVxuICAgIH1cbn1cbiIsIjxuZy10ZW1wbGF0ZSAjY29udGVudFxuICBsZXQtbW9kYWw+XG4gIDxkaXYgY2xhc3M9XCJtb2RhbC1oZWFkZXJcIj5cbiAgICA8aDUgY2xhc3M9XCJtb2RhbC10aXRsZVwiPkNvbmZpcm08L2g1PlxuICAgIDxidXR0b24gdHlwZT1cImJ1dHRvblwiXG4gICAgICBjbGFzcz1cImJ0bi1jbG9zZSBmbG9hdC1lbmRcIlxuICAgICAgYXJpYS1sYWJlbD1cIkNsb3NlXCJcbiAgICAgIChjbGljayk9XCJtb2RhbC5kaXNtaXNzKClcIj5cbiAgICA8L2J1dHRvbj5cbiAgPC9kaXY+XG4gIDxkaXYgY2xhc3M9XCJtb2RhbC1ib2R5XCI+XG4gICAgPHN0cm9uZyBjbGFzcz1cInAzXCI+e3sgY29uZmlybU1lc3NhZ2UgfCB0cmFuc2xvY28gfX08L3N0cm9uZz5cbiAgICA8ZGl2PlxuICAgICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICAgIDwvZGl2PlxuICAgIDxkaXYgY2xhc3M9XCJyb3dcIj5cbiAgICAgIDxkaXYgY2xhc3M9XCJjb2wtMTJcIj5cbiAgICAgICAgPGlucHV0IHR5cGU9XCJwYXNzd29yZFwiXG4gICAgICAgICAgI3Bhc3N3b3JkUmVmXG4gICAgICAgICAgWyhuZ01vZGVsKV09XCJwYXNzd29yZFwiXG4gICAgICAgICAgY2xhc3M9XCJmb3JtLWNvbnRyb2xcIlxuICAgICAgICAgIHBsYWNlaG9sZGVyPVwiQ3VycmVudCBQYXNzd29yZFwiIC8+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgICA8ZGl2IGNsYXNzPVwicm93IG10LTJcIj5cbiAgICAgIDxkaXYgY2xhc3M9XCJjb2wtMTJcIj5cbiAgICAgICAgPGJ1dHRvbiBbYnV0dG9uQnVzeV09XCJidXR0b25CdXN5XCJcbiAgICAgICAgICBjbGFzcz1cImJ0biBidG4tcHJpbWFyeSBmbG9hdC1lbmRcIlxuICAgICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICAgIChjbGljayk9XCJ2YWxpZGF0ZVBhc3N3b3JkKClcIj5cbiAgICAgICAgICB7eyAnQnV0dG9uLkNvbmZpcm0nIHwgdHJhbnNsb2NvIH19XG4gICAgICAgIDwvYnV0dG9uPlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gIDwvZGl2PlxuPC9uZy10ZW1wbGF0ZT5cbiJdfQ==
@@ -1,111 +0,0 @@
1
- import { Component, ElementRef, Input } from '@angular/core';
2
- import map from 'lodash/map';
3
- import * as i0 from "@angular/core";
4
- export class PermissionTreeComponent {
5
- constructor(_element) {
6
- this._element = _element;
7
- }
8
- ngOnChanges(simple) {
9
- if (simple['data']?.currentValue?.grantedPermissionNames) {
10
- this.refreshTree();
11
- }
12
- }
13
- ngAfterViewInit() {
14
- this._$tree = $(this._element.nativeElement);
15
- this.refreshTree();
16
- }
17
- getGrantedPermissionNames() {
18
- if (!this._$tree || !this._createdTreeBefore) {
19
- return [];
20
- }
21
- const permissionNames = [];
22
- const selectedPermissions = this._$tree.jstree('get_selected', true);
23
- for (const permission of selectedPermissions) {
24
- permissionNames.push(permission.original.id);
25
- }
26
- return permissionNames;
27
- }
28
- refreshTree() {
29
- if (this._createdTreeBefore) {
30
- this._$tree.jstree('destroy');
31
- }
32
- this._createdTreeBefore = false;
33
- if (!this.data || !this._$tree) {
34
- return;
35
- }
36
- const treeData = map(this.data.permissions, item => {
37
- return {
38
- id: item.name,
39
- parent: item.parentName ?? '#',
40
- text: item.displayName,
41
- state: {
42
- opened: true,
43
- selected: this.data.grantedPermissionNames.includes(item.name)
44
- }
45
- };
46
- });
47
- this._$tree.jstree({
48
- core: {
49
- data: treeData
50
- },
51
- types: {
52
- default: {
53
- icon: 'fa fa-folder-open tree-item-icon-color icon-lg'
54
- },
55
- file: {
56
- icon: 'fa fa-file tree-item-icon-color icon-lg'
57
- }
58
- },
59
- checkbox: {
60
- keep_selected_style: false,
61
- three_state: false,
62
- cascade: ''
63
- },
64
- plugins: ['checkbox', 'types']
65
- });
66
- this._createdTreeBefore = true;
67
- let inTreeChangeEvent = false;
68
- const selectNodeAndAllParents = node => {
69
- this._$tree.jstree('select_node', node, true);
70
- const parent = this._$tree.jstree('get_parent', node);
71
- if (parent) {
72
- selectNodeAndAllParents(parent);
73
- }
74
- };
75
- this._$tree.on('changed.jstree', (_e, data) => {
76
- if (!data.node) {
77
- return;
78
- }
79
- const wasInTreeChangeEvent = inTreeChangeEvent;
80
- if (!wasInTreeChangeEvent) {
81
- inTreeChangeEvent = true;
82
- }
83
- let childrenNodes;
84
- if (data.node.state.selected) {
85
- selectNodeAndAllParents(this._$tree.jstree('get_parent', data.node));
86
- childrenNodes = $.makeArray(this._$tree.jstree('get_children_dom', data.node));
87
- this._$tree.jstree('select_node', childrenNodes);
88
- }
89
- else {
90
- childrenNodes = $.makeArray(this._$tree.jstree('get_children_dom', data.node));
91
- this._$tree.jstree('deselect_node', childrenNodes);
92
- }
93
- if (!wasInTreeChangeEvent) {
94
- inTreeChangeEvent = false;
95
- }
96
- });
97
- }
98
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PermissionTreeComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
99
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PermissionTreeComponent, selector: "permission-tree", inputs: { data: "data" }, usesOnChanges: true, ngImport: i0, template: ` <div class="permission-tree"></div> `, isInline: true }); }
100
- }
101
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PermissionTreeComponent, decorators: [{
102
- type: Component,
103
- args: [{
104
- // eslint-disable-next-line @angular-eslint/component-selector
105
- selector: 'permission-tree',
106
- template: ` <div class="permission-tree"></div> `
107
- }]
108
- }], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { data: [{
109
- type: Input
110
- }] } });
111
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"permission-tree.component.js","sourceRoot":"","sources":["../../../../../../libs/shared-components/src/lib/permission-tree/permission-tree.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    Component,\n    ElementRef,\n    Input,\n    OnChanges,\n    SimpleChanges\n} from '@angular/core';\n\nimport map from 'lodash/map';\n\nimport { PermissionTreeData } from '../shared/shared-component.interface';\n\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: 'permission-tree',\n    template: ` <div class=\"permission-tree\"></div> `\n})\nexport class PermissionTreeComponent implements AfterViewInit, OnChanges {\n    @Input() data: PermissionTreeData;\n\n    private _$tree;\n    private _createdTreeBefore: boolean;\n    constructor(private readonly _element: ElementRef) {}\n\n    ngOnChanges(simple: SimpleChanges) {\n        if (simple['data']?.currentValue?.grantedPermissionNames) {\n            this.refreshTree();\n        }\n    }\n\n    ngAfterViewInit(): void {\n        this._$tree = $(this._element.nativeElement);\n\n        this.refreshTree();\n    }\n\n    getGrantedPermissionNames(): string[] {\n        if (!this._$tree || !this._createdTreeBefore) {\n            return [];\n        }\n\n        const permissionNames = [];\n\n        const selectedPermissions = this._$tree.jstree('get_selected', true);\n        for (const permission of selectedPermissions) {\n            permissionNames.push(permission.original.id);\n        }\n\n        return permissionNames;\n    }\n\n    private refreshTree(): void {\n        if (this._createdTreeBefore) {\n            this._$tree.jstree('destroy');\n        }\n\n        this._createdTreeBefore = false;\n\n        if (!this.data || !this._$tree) {\n            return;\n        }\n\n        const treeData = map(this.data.permissions, item => {\n            return {\n                id: item.name,\n                parent: item.parentName ?? '#',\n                text: item.displayName,\n                state: {\n                    opened: true,\n                    selected: this.data.grantedPermissionNames.includes(item.name)\n                }\n            };\n        });\n\n        this._$tree.jstree({\n            core: {\n                data: treeData\n            },\n            types: {\n                default: {\n                    icon: 'fa fa-folder-open tree-item-icon-color icon-lg'\n                },\n                file: {\n                    icon: 'fa fa-file tree-item-icon-color icon-lg'\n                }\n            },\n            checkbox: {\n                keep_selected_style: false,\n                three_state: false,\n                cascade: ''\n            },\n            plugins: ['checkbox', 'types']\n        });\n\n        this._createdTreeBefore = true;\n\n        let inTreeChangeEvent = false;\n\n        const selectNodeAndAllParents = node => {\n            this._$tree.jstree('select_node', node, true);\n            const parent = this._$tree.jstree('get_parent', node);\n            if (parent) {\n                selectNodeAndAllParents(parent);\n            }\n        };\n\n        this._$tree.on('changed.jstree', (_e, data) => {\n            if (!data.node) {\n                return;\n            }\n\n            const wasInTreeChangeEvent = inTreeChangeEvent;\n            if (!wasInTreeChangeEvent) {\n                inTreeChangeEvent = true;\n            }\n\n            let childrenNodes;\n\n            if (data.node.state.selected) {\n                selectNodeAndAllParents(this._$tree.jstree('get_parent', data.node));\n\n                childrenNodes = $.makeArray(this._$tree.jstree('get_children_dom', data.node));\n                this._$tree.jstree('select_node', childrenNodes);\n            } else {\n                childrenNodes = $.makeArray(this._$tree.jstree('get_children_dom', data.node));\n                this._$tree.jstree('deselect_node', childrenNodes);\n            }\n\n            if (!wasInTreeChangeEvent) {\n                inTreeChangeEvent = false;\n            }\n        });\n    }\n}\n"]}