@posiwise/shared-components 0.0.109 → 0.0.110
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/ab-test/ab-test-container/ab-test-container.component.mjs +1 -1
- package/esm2022/lib/autheticator/authenticator.component.mjs +1 -2
- package/esm2022/lib/custom-uploader/custom-uploader.component.mjs +4 -4
- package/esm2022/lib/geo-template/geo-template.component.mjs +1 -1
- package/esm2022/lib/header/header.component.mjs +4 -4
- package/esm2022/lib/image-cropper/image-cropper.component.mjs +3 -3
- package/esm2022/lib/input-container/input-container.component.mjs +5 -5
- package/esm2022/lib/label-management/entity-group/entity-group.component.mjs +5 -7
- package/esm2022/lib/label-management/group-definition/group-definition.component.mjs +4 -6
- package/esm2022/lib/label-management/groups/groups.component.mjs +4 -6
- package/esm2022/lib/landing-page-footer-b/landing-page-footer-b.component.mjs +3 -3
- package/esm2022/lib/no-data/no-data.component.mjs +4 -4
- package/esm2022/lib/number-picker/number-picker.component.mjs +24 -27
- package/esm2022/lib/password-validation/password-validation.component.mjs +1 -1
- package/esm2022/lib/permission-tree/permission-tree.component.mjs +4 -6
- package/esm2022/lib/privacy-and-tos/privacy-and-tos.component.mjs +27 -18
- package/esm2022/lib/privacy-policy/privacy-policy.component.mjs +2 -2
- package/esm2022/lib/splash/splash.component.mjs +1 -1
- package/esm2022/lib/terms-conditions/terms-conditions.component.mjs +3 -3
- package/fesm2022/posiwise-shared-components.mjs +80 -77
- package/fesm2022/posiwise-shared-components.mjs.map +1 -1
- package/lib/ab-test/ab-test-container/ab-test-container.component.d.ts +1 -1
- package/lib/autheticator/authenticator.component.d.ts +1 -1
- package/lib/custom-uploader/custom-uploader.component.d.ts +2 -2
- package/lib/geo-template/geo-template.component.d.ts +1 -1
- package/lib/header/header.component.d.ts +1 -1
- package/lib/image-cropper/image-cropper.component.d.ts +1 -1
- package/lib/input-container/input-container.component.d.ts +1 -1
- package/lib/label-management/entity-group/entity-group.component.d.ts +5 -7
- package/lib/label-management/group-definition/group-definition.component.d.ts +6 -8
- package/lib/label-management/groups/groups.component.d.ts +6 -9
- package/lib/landing-page-footer-b/landing-page-footer-b.component.d.ts +1 -1
- package/lib/number-picker/number-picker.component.d.ts +1 -2
- package/lib/password-validation/password-validation.component.d.ts +1 -1
- package/lib/permission-tree/permission-tree.component.d.ts +1 -1
- package/lib/privacy-and-tos/privacy-and-tos.component.d.ts +5 -3
- package/lib/terms-conditions/terms-conditions.component.d.ts +1 -1
- package/package.json +1 -1
|
@@ -87,7 +87,7 @@ export class NumberPickerComponent {
|
|
|
87
87
|
onDecrease(event) {
|
|
88
88
|
event.preventDefault();
|
|
89
89
|
if (this.canDecrease()) {
|
|
90
|
-
this.value = this.round(this.value > this.min ?
|
|
90
|
+
this.value = this.round(this.value > this.min ? this.value - this.step : this.value);
|
|
91
91
|
this.valueChange.emit(this.value);
|
|
92
92
|
}
|
|
93
93
|
else {
|
|
@@ -98,7 +98,7 @@ export class NumberPickerComponent {
|
|
|
98
98
|
onIncrease(event) {
|
|
99
99
|
event.preventDefault();
|
|
100
100
|
if (this.canIncrease()) {
|
|
101
|
-
this.value = this.round(this.value < this.max ?
|
|
101
|
+
this.value = this.round(this.value < this.max ? this.value + this.step : this.value);
|
|
102
102
|
this.valueChange.emit(this.value);
|
|
103
103
|
}
|
|
104
104
|
else {
|
|
@@ -109,11 +109,11 @@ export class NumberPickerComponent {
|
|
|
109
109
|
onMouseDown(event, increase = true) {
|
|
110
110
|
this.afterMouseDown(increase, event);
|
|
111
111
|
}
|
|
112
|
-
isArrowUpDown(
|
|
113
|
-
return
|
|
112
|
+
isArrowUpDown(key) {
|
|
113
|
+
return key === 'ArrowUp' || key === 'ArrowDown';
|
|
114
114
|
}
|
|
115
|
-
isArowUp(
|
|
116
|
-
return
|
|
115
|
+
isArowUp(key) {
|
|
116
|
+
return key === 'ArrowUp';
|
|
117
117
|
}
|
|
118
118
|
loopPick(increase, event) {
|
|
119
119
|
this.onPickStarted(increase);
|
|
@@ -132,24 +132,24 @@ export class NumberPickerComponent {
|
|
|
132
132
|
this.afterMouseUp(increase, event);
|
|
133
133
|
}
|
|
134
134
|
onKeyDown(event) {
|
|
135
|
-
if (this.isArrowUpDown(event.
|
|
135
|
+
if (this.isArrowUpDown(event.key)) {
|
|
136
136
|
event.preventDefault();
|
|
137
137
|
if (!this.eventHolder) {
|
|
138
|
-
this.loopPick(this.isArowUp(event.
|
|
138
|
+
this.loopPick(this.isArowUp(event.key), event);
|
|
139
139
|
}
|
|
140
140
|
}
|
|
141
141
|
event.stopPropagation();
|
|
142
142
|
}
|
|
143
143
|
onKeyUp(event) {
|
|
144
|
-
if (this.isArrowUpDown(event.
|
|
144
|
+
if (this.isArrowUpDown(event.key)) {
|
|
145
145
|
event.preventDefault();
|
|
146
|
-
this.afterPick(this.isArowUp(event.
|
|
146
|
+
this.afterPick(this.isArowUp(event.key));
|
|
147
147
|
}
|
|
148
148
|
event.stopPropagation();
|
|
149
149
|
}
|
|
150
150
|
afterMouseDown(up, event) {
|
|
151
151
|
event.preventDefault();
|
|
152
|
-
if (this.isLeftClick(event
|
|
152
|
+
if (this.isLeftClick(event)) {
|
|
153
153
|
this.loopPick(up, event);
|
|
154
154
|
}
|
|
155
155
|
event.stopPropagation();
|
|
@@ -169,14 +169,6 @@ export class NumberPickerComponent {
|
|
|
169
169
|
this.eventHolder = null;
|
|
170
170
|
this.countInterval = null;
|
|
171
171
|
}
|
|
172
|
-
afterArrowKeysPressed(up, event, start) {
|
|
173
|
-
if (start) {
|
|
174
|
-
this.loopPick(up, event);
|
|
175
|
-
}
|
|
176
|
-
else {
|
|
177
|
-
this.afterPick(up);
|
|
178
|
-
}
|
|
179
|
-
}
|
|
180
172
|
parseVal(value) {
|
|
181
173
|
if (typeof value === 'number') {
|
|
182
174
|
return value;
|
|
@@ -205,8 +197,11 @@ export class NumberPickerComponent {
|
|
|
205
197
|
return canDecrease;
|
|
206
198
|
}
|
|
207
199
|
onPickStarted(increase) {
|
|
208
|
-
|
|
200
|
+
const isIncrease = increase;
|
|
201
|
+
if (isIncrease) {
|
|
202
|
+
// NOSONAR
|
|
209
203
|
if (this.canIncrease()) {
|
|
204
|
+
console.log('In this');
|
|
210
205
|
this.pickStarted.emit(true);
|
|
211
206
|
this.pickUpStarted.emit(true);
|
|
212
207
|
}
|
|
@@ -217,7 +212,9 @@ export class NumberPickerComponent {
|
|
|
217
212
|
}
|
|
218
213
|
}
|
|
219
214
|
onpickStopped(increase) {
|
|
220
|
-
|
|
215
|
+
const isIncrease = increase;
|
|
216
|
+
if (isIncrease) {
|
|
217
|
+
// NOSONAR
|
|
221
218
|
if (this.canIncrease()) {
|
|
222
219
|
this.pickUpStopped.emit(true);
|
|
223
220
|
this.pickStopped.emit(true);
|
|
@@ -228,8 +225,8 @@ export class NumberPickerComponent {
|
|
|
228
225
|
this.pickStopped.emit(true);
|
|
229
226
|
}
|
|
230
227
|
}
|
|
231
|
-
isLeftClick(
|
|
232
|
-
return
|
|
228
|
+
isLeftClick(event) {
|
|
229
|
+
return event.button === 0;
|
|
233
230
|
}
|
|
234
231
|
initPicker() {
|
|
235
232
|
this.min = this.parseVal(this.min) || this.numberPickerService.min;
|
|
@@ -241,14 +238,14 @@ export class NumberPickerComponent {
|
|
|
241
238
|
this.pickTimer = this.parseVal(this.pickTimer) || this.numberPickerService.pickTimer;
|
|
242
239
|
this.precision = this.getPrecision(this.step) || this.numberPickerService.precision;
|
|
243
240
|
this.value = this.round(this.value);
|
|
244
|
-
this.placeholder = this.placeholder
|
|
241
|
+
this.placeholder = this.placeholder ?? '';
|
|
245
242
|
}
|
|
246
243
|
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 }); }
|
|
247
|
-
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 (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)=\"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 (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 (mouseup)=\"onMouseUp($event)\"\n (mousedown)=\"onMouseDown($event)\">+</span>\n <span *ngIf=\"showDownButton\"\n class=\"{{ customClass.down }}\"\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"] }] }); }
|
|
244
|
+
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"] }] }); }
|
|
248
245
|
}
|
|
249
246
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: NumberPickerComponent, decorators: [{
|
|
250
247
|
type: Component,
|
|
251
|
-
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 (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)=\"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 (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 (mouseup)=\"onMouseUp($event)\"\n (mousedown)=\"onMouseDown($event)\">+</span>\n <span *ngIf=\"showDownButton\"\n class=\"{{ customClass.down }}\"\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"] }]
|
|
248
|
+
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"] }]
|
|
252
249
|
}], ctorParameters: () => [{ type: i1.NumberPickerService }], propDecorators: { min: [{
|
|
253
250
|
type: Input
|
|
254
251
|
}], showTooltip: [{
|
|
@@ -306,4 +303,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
306
303
|
}], pickDownStopped: [{
|
|
307
304
|
type: Output
|
|
308
305
|
}] } });
|
|
309
|
-
//# 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 { CustomClasses, buttonsOrientationType, sizeType } from './number-picker.config';\nimport { NumberPickerService } from '@posiwise/common-services';\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 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        console.log(event, 'abc');\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(keyCode: number): boolean {\n        return keyCode === 38 || keyCode === 40;\n    }\n\n    private isArowUp(keyCode: number): boolean {\n        return keyCode === 38;\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.keyCode)) {\n            event.preventDefault();\n            if (!this.eventHolder) {\n                this.loopPick(this.isArowUp(event.keyCode), event);\n            }\n        }\n        event.stopPropagation();\n    }\n\n    onKeyUp(event: KeyboardEvent) {\n        if (this.isArrowUpDown(event.keyCode)) {\n            event.preventDefault();\n            this.afterPick(this.isArowUp(event.keyCode));\n        }\n        event.stopPropagation();\n    }\n\n    private afterMouseDown(up: boolean, event: MouseEvent) {\n        event.preventDefault();\n        if (this.isLeftClick(event.which)) {\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 afterArrowKeysPressed(up: boolean, event: KeyboardEvent, start: boolean) {\n        if (start) {\n            this.loopPick(up, event);\n        } else {\n            this.afterPick(up);\n        }\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        if (increase) {\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        if (increase) {\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(witch: number): boolean {\n        return witch === 1;\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 !== undefined ? 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    (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)=\"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    (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      (mouseup)=\"onMouseUp($event)\"\n      (mousedown)=\"onMouseDown($event)\">+</span>\n    <span *ngIf=\"showDownButton\"\n      class=\"{{ customClass.down }}\"\n      (click)=\"onDecrease($event)\"\n      (mouseup)=\"onMouseUp($event, false)\"\n      (mousedown)=\"onMouseDown($event, false)\">-</span>\n  </span>\n</div>\n"]}
|
|
306
|
+
//# 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 { CustomClasses, buttonsOrientationType, sizeType } from './number-picker.config';\nimport { NumberPickerService } from '@posiwise/common-services';\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        console.log(event, 'abc');\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 isArowUp(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.isArowUp(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.isArowUp(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                console.log('In this');\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"]}
|
|
@@ -49,4 +49,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
49
49
|
}], successEvent: [{
|
|
50
50
|
type: Output
|
|
51
51
|
}] } });
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
52
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFzc3dvcmQtdmFsaWRhdGlvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3NoYXJlZC1jb21wb25lbnRzL3NyYy9saWIvcGFzc3dvcmQtdmFsaWRhdGlvbi9wYXNzd29yZC12YWxpZGF0aW9uLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvc2hhcmVkLWNvbXBvbmVudHMvc3JjL2xpYi9wYXNzd29yZC12YWxpZGF0aW9uL3Bhc3N3b3JkLXZhbGlkYXRpb24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxXQUFXLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2xHLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFFaEQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sOEJBQThCLENBQUM7Ozs7OztBQU9oRSxNQUFNLE9BQU8sMkJBQTRCLFNBQVEsZ0JBQWdCO0lBVTdELFlBQ0ksUUFBa0IsRUFDRCxLQUFlO1FBRWhDLEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUZDLFVBQUssR0FBTCxLQUFLLENBQVU7UUFScEMsaUJBQVksR0FBMEIsSUFBSSxZQUFZLEVBQUUsQ0FBQztJQVd6RCxDQUFDO0lBRUQsSUFBSTtRQUNBLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLFdBQVcsRUFBRSxjQUFjLEVBQUUsQ0FBQyxDQUFDO0lBQ25GLENBQUM7SUFFRCxnQkFBZ0I7UUFDWixJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUNoQixJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQztZQUN2QixJQUFJLENBQUMsV0FBVztpQkFDWCxhQUFhLENBQUMsRUFBRSxRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDO2lCQUMxQyxTQUFTLENBQUMsSUFBSSxDQUFDLEVBQUU7Z0JBQ2QsSUFBSSxJQUFJLElBQUksSUFBSSxFQUFFLE1BQU0sS0FBSyxXQUFXLENBQUMsRUFBRSxFQUFFLENBQUM7b0JBQzFDLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO29CQUM3QixJQUFJLENBQUMsS0FBSyxDQUFDLFVBQVUsRUFBRSxDQUFDO29CQUN4QixJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQztnQkFDekIsQ0FBQztxQkFBTSxDQUFDO29CQUNKLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO29CQUM5QixJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQztnQkFDekIsQ0FBQztZQUNMLENBQUMsQ0FBQztpQkFDRCxHQUFHLENBQUMsR0FBRyxFQUFFO2dCQUNOLElBQUksQ0FBQyxVQUFVLEdBQUcsS0FBSyxDQUFDO1lBQzVCLENBQUMsQ0FBQyxDQUFDO1FBQ1gsQ0FBQztJQUNMLENBQUM7K0dBeENRLDJCQUEyQjttR0FBM0IsMkJBQTJCLGtQQ1h4QyxpaENBb0NBOzs0RkR6QmEsMkJBQTJCO2tCQUp2QyxTQUFTOytCQUNJLHdCQUF3QjtvR0FJTSxPQUFPO3NCQUE5QyxTQUFTO3VCQUFDLFNBQVMsRUFBRSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUU7Z0JBR3RDLFlBQVk7c0JBRFgsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbmplY3RvciwgT3V0cHV0LCBUZW1wbGF0ZVJlZiwgVmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOZ2JNb2RhbCB9IGZyb20gJ0BuZy1ib290c3RyYXAvbmctYm9vdHN0cmFwJztcbmltcG9ydCB7IFN0YXR1c0NvZGVzIH0gZnJvbSAnaHR0cC1zdGF0dXMtY29kZXMnO1xuXG5pbXBvcnQgeyBBcHBCYXNlQ29tcG9uZW50IH0gZnJvbSAnQHBvc2l3aXNlL2FwcC1iYXNlLWNvbXBvbmVudCc7XG5pbXBvcnQgeyBTaGFyZWRNb2RhbENvbnRleHQgfSBmcm9tICcuLi9zaGFyZWQvc2hhcmVkLWNvbXBvbmVudC5pbnRlcmZhY2UnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3B3LXBhc3N3b3JkLXZhbGlkYXRpb24nLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9wYXNzd29yZC12YWxpZGF0aW9uLmNvbXBvbmVudC5odG1sJ1xufSlcbmV4cG9ydCBjbGFzcyBQYXNzd29yZFZhbGlkYXRpb25Db21wb25lbnQgZXh0ZW5kcyBBcHBCYXNlQ29tcG9uZW50IHtcbiAgICBAVmlld0NoaWxkKCdjb250ZW50JywgeyBzdGF0aWM6IHRydWUgfSkgY29udGVudDogVGVtcGxhdGVSZWY8U2hhcmVkTW9kYWxDb250ZXh0PjtcblxuICAgIEBPdXRwdXQoKVxuICAgIHN1Y2Nlc3NFdmVudDogRXZlbnRFbWl0dGVyPGJvb2xlYW4+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuXG4gICAgcGFzc3dvcmQ6IHN0cmluZztcblxuICAgIGJ1dHRvbkJ1c3k6IGJvb2xlYW47XG5cbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgaW5qZWN0b3I6IEluamVjdG9yLFxuICAgICAgICBwcml2YXRlIHJlYWRvbmx5IG1vZGFsOiBOZ2JNb2RhbFxuICAgICkge1xuICAgICAgICBzdXBlcihpbmplY3Rvcik7XG4gICAgfVxuXG4gICAgb3BlbigpIHtcbiAgICAgICAgdGhpcy5tb2RhbC5vcGVuKHRoaXMuY29udGVudCwgeyBjZW50ZXJlZDogdHJ1ZSwgd2luZG93Q2xhc3M6ICdtb2RhbC1ob2xkZXInIH0pO1xuICAgIH1cblxuICAgIHZhbGlkYXRlUGFzc3dvcmQoKSB7XG4gICAgICAgIGlmICh0aGlzLnBhc3N3b3JkKSB7XG4gICAgICAgICAgICB0aGlzLmJ1dHRvbkJ1c3kgPSB0cnVlO1xuICAgICAgICAgICAgdGhpcy51c2VyU2VydmljZVxuICAgICAgICAgICAgICAgIC5jaGVja1Bhc3N3b3JkKHsgcGFzc3dvcmQ6IHRoaXMucGFzc3dvcmQgfSlcbiAgICAgICAgICAgICAgICAuc3Vic2NyaWJlKGRhdGEgPT4ge1xuICAgICAgICAgICAgICAgICAgICBpZiAoZGF0YSAmJiBkYXRhPy5zdGF0dXMgPT09IFN0YXR1c0NvZGVzLk9LKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICB0aGlzLnN1Y2Nlc3NFdmVudC5lbWl0KHRydWUpO1xuICAgICAgICAgICAgICAgICAgICAgICAgdGhpcy5tb2RhbC5kaXNtaXNzQWxsKCk7XG4gICAgICAgICAgICAgICAgICAgICAgICB0aGlzLnBhc3N3b3JkID0gbnVsbDtcbiAgICAgICAgICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHRoaXMuc3VjY2Vzc0V2ZW50LmVtaXQoZmFsc2UpO1xuICAgICAgICAgICAgICAgICAgICAgICAgdGhpcy5wYXNzd29yZCA9IG51bGw7XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICB9KVxuICAgICAgICAgICAgICAgIC5hZGQoKCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICB0aGlzLmJ1dHRvbkJ1c3kgPSBmYWxzZTtcbiAgICAgICAgICAgICAgICB9KTtcbiAgICAgICAgfVxuICAgIH1cbn1cbiIsIjxuZy10ZW1wbGF0ZSAjY29udGVudFxuICBsZXQtbW9kYWw+XG4gIDxkaXYgY2xhc3M9XCJtb2RhbC1oZWFkZXJcIj5cbiAgICA8aDUgY2xhc3M9XCJtb2RhbC10aXRsZVwiPkNvbmZpcm08L2g1PlxuICAgIDxidXR0b24gdHlwZT1cImJ1dHRvblwiXG4gICAgICBjbGFzcz1cImJ0bi1jbG9zZSBmbG9hdC1lbmRcIlxuICAgICAgYXJpYS1sYWJlbD1cIkNsb3NlXCJcbiAgICAgIChjbGljayk9XCJtb2RhbC5kaXNtaXNzKClcIj5cbiAgICA8L2J1dHRvbj5cbiAgPC9kaXY+XG4gIDxkaXYgY2xhc3M9XCJtb2RhbC1ib2R5XCI+XG4gICAgPHN0cm9uZyBjbGFzcz1cInAzXCI+e3sgJ1VzZXIuQWNjb3VudC5NZXNzYWdlLkVudGVyUGFzc3dvcmQnIHwgdHJhbnNsb2NvIH19PC9zdHJvbmc+XG4gICAgPGRpdj5cbiAgICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiAgICA8L2Rpdj5cbiAgICA8ZGl2IGNsYXNzPVwicm93XCI+XG4gICAgICA8ZGl2IGNsYXNzPVwiY29sLTEyXCI+XG4gICAgICAgIDxpbnB1dCB0eXBlPVwicGFzc3dvcmRcIlxuICAgICAgICAgICNwYXNzd29yZFJlZlxuICAgICAgICAgIFsobmdNb2RlbCldPVwicGFzc3dvcmRcIlxuICAgICAgICAgIGNsYXNzPVwiZm9ybS1jb250cm9sXCJcbiAgICAgICAgICBwbGFjZWhvbGRlcj1cIkN1cnJlbnQgUGFzc3dvcmRcIiAvPlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gICAgPGRpdiBjbGFzcz1cInJvdyBtdC0yXCI+XG4gICAgICA8ZGl2IGNsYXNzPVwiY29sLTEyXCI+XG4gICAgICAgIDxidXR0b24gW2J1dHRvbkJ1c3ldPVwiYnV0dG9uQnVzeVwiXG4gICAgICAgICAgY2xhc3M9XCJidG4gYnRuLXByaW1hcnkgZmxvYXQtZW5kXCJcbiAgICAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgICAgICAoY2xpY2spPVwidmFsaWRhdGVQYXNzd29yZCgpXCI+XG4gICAgICAgICAge3sgJ0J1dHRvbi5Db25maXJtJyB8IHRyYW5zbG9jbyB9fVxuICAgICAgICA8L2J1dHRvbj5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICA8L2Rpdj5cbjwvbmctdGVtcGxhdGU+XG4iXX0=
|
|
@@ -6,9 +6,7 @@ export class PermissionTreeComponent {
|
|
|
6
6
|
this._element = _element;
|
|
7
7
|
}
|
|
8
8
|
ngOnChanges(simple) {
|
|
9
|
-
if (simple['data']
|
|
10
|
-
simple['data'].currentValue &&
|
|
11
|
-
simple['data'].currentValue.grantedPermissionNames) {
|
|
9
|
+
if (simple['data']?.currentValue?.grantedPermissionNames) {
|
|
12
10
|
this.refreshTree();
|
|
13
11
|
}
|
|
14
12
|
}
|
|
@@ -22,8 +20,8 @@ export class PermissionTreeComponent {
|
|
|
22
20
|
}
|
|
23
21
|
const permissionNames = [];
|
|
24
22
|
const selectedPermissions = this._$tree.jstree('get_selected', true);
|
|
25
|
-
for (
|
|
26
|
-
permissionNames.push(
|
|
23
|
+
for (const permission of selectedPermissions) {
|
|
24
|
+
permissionNames.push(permission.original.id);
|
|
27
25
|
}
|
|
28
26
|
return permissionNames;
|
|
29
27
|
}
|
|
@@ -110,4 +108,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
110
108
|
}], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { data: [{
|
|
111
109
|
type: Input
|
|
112
110
|
}] } });
|
|
113
|
-
//# 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';\nimport map from 'lodash/map';\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 _element: ElementRef) {}\n\n    ngOnChanges(simple: SimpleChanges) {\n        if (\n            simple['data'] &&\n            simple['data'].currentValue &&\n            simple['data'].currentValue.grantedPermissionNames\n        ) {\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 (let i = 0; i < selectedPermissions.length; i++) {\n            permissionNames.push(selectedPermissions[i].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 ? 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"]}
|
|
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';\nimport map from 'lodash/map';\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 ? 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"]}
|