lib-portal-angular 0.0.36 → 0.0.38
Sign up to get free protection for your applications and to get access to all the features.
- package/esm2022/lib/components/button/button.component.mjs +31 -15
- package/esm2022/lib/components/components.module.mjs +8 -3
- package/esm2022/lib/components/confirmation/confirmation.component.mjs +7 -4
- package/esm2022/lib/components/confirmation/confirmation.service.mjs +16 -7
- package/esm2022/lib/components/custom-pagination/custom-pagination.component.mjs +7 -1
- package/esm2022/lib/components/imput/input.component.mjs +34 -29
- package/esm2022/lib/components/search-input/search-input.component.mjs +122 -0
- package/esm2022/lib/components/tables/data-paginate.service.mjs +37 -0
- package/esm2022/lib/components/tables/data-table.component.mjs +81 -45
- package/esm2022/lib/lib-portal-angular.module.mjs +6 -3
- package/esm2022/lib/service/auth-service.service.mjs +34 -0
- package/esm2022/public-api.mjs +3 -1
- package/fesm2022/lib-portal-angular.mjs +355 -97
- package/fesm2022/lib-portal-angular.mjs.map +1 -1
- package/lib/components/button/button.component.d.ts +9 -5
- package/lib/components/components.module.d.ts +5 -4
- package/lib/components/confirmation/confirmation.component.d.ts +3 -1
- package/lib/components/confirmation/confirmation.service.d.ts +4 -1
- package/lib/components/custom-pagination/custom-pagination.component.d.ts +4 -2
- package/lib/components/imput/input.component.d.ts +8 -7
- package/lib/components/search-input/search-input.component.d.ts +44 -0
- package/lib/components/tables/data-paginate.service.d.ts +21 -0
- package/lib/components/tables/data-table.component.d.ts +22 -14
- package/lib/service/auth-service.service.d.ts +9 -0
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
@@ -1,10 +1,12 @@
|
|
1
|
-
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, Input, Output } from '@angular/core';
|
2
2
|
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
3
3
|
import * as i0 from "@angular/core";
|
4
|
-
import * as i1 from "
|
5
|
-
import * as i2 from "@angular/
|
4
|
+
import * as i1 from "../../service/auth-service.service";
|
5
|
+
import * as i2 from "@angular/common";
|
6
|
+
import * as i3 from "@angular/forms";
|
6
7
|
export class InputComponent {
|
7
|
-
constructor() {
|
8
|
+
constructor(authService) {
|
9
|
+
this.authService = authService;
|
8
10
|
this.label = 'Default Label';
|
9
11
|
this.placeholder = '';
|
10
12
|
this.id = 'inputId';
|
@@ -22,7 +24,6 @@ export class InputComponent {
|
|
22
24
|
this.marginRight = 0;
|
23
25
|
this.labelFontWeight = 400;
|
24
26
|
this.permissions = [];
|
25
|
-
this.permissionChecker = null;
|
26
27
|
this.inputEvent = new EventEmitter();
|
27
28
|
this.changeEvent = new EventEmitter();
|
28
29
|
this.focusEvent = new EventEmitter();
|
@@ -33,6 +34,7 @@ export class InputComponent {
|
|
33
34
|
this.onChangeCallback = () => { };
|
34
35
|
this.onTouchedCallback = () => { };
|
35
36
|
this.value = '';
|
37
|
+
this.subscriptions = [];
|
36
38
|
}
|
37
39
|
onInput(event) {
|
38
40
|
const inputElement = event.target;
|
@@ -50,15 +52,6 @@ export class InputComponent {
|
|
50
52
|
this.onTouchedCallback();
|
51
53
|
this.blurEvent.emit(event);
|
52
54
|
}
|
53
|
-
onKeyup(event) {
|
54
|
-
this.keyupEvent.emit(event);
|
55
|
-
}
|
56
|
-
onKeydown(event) {
|
57
|
-
this.keydownEvent.emit(event);
|
58
|
-
}
|
59
|
-
onKeypress(event) {
|
60
|
-
this.keypressEvent.emit(event);
|
61
|
-
}
|
62
55
|
writeValue(value) {
|
63
56
|
this.value = value;
|
64
57
|
}
|
@@ -72,10 +65,21 @@ export class InputComponent {
|
|
72
65
|
this.disabled = isDisabled;
|
73
66
|
}
|
74
67
|
hasPermission() {
|
75
|
-
if (
|
68
|
+
if (this.permissions.length === 0) {
|
69
|
+
return true;
|
70
|
+
}
|
71
|
+
try {
|
72
|
+
return this.authService.hasPermission(this.permissions);
|
73
|
+
}
|
74
|
+
catch (error) {
|
75
|
+
if (error instanceof Error) {
|
76
|
+
console.error('Permission error:', error.message);
|
77
|
+
}
|
78
|
+
else {
|
79
|
+
console.error('Unknown error occurred during permission check');
|
80
|
+
}
|
76
81
|
return true;
|
77
82
|
}
|
78
|
-
return this.permissionChecker(this.permissions);
|
79
83
|
}
|
80
84
|
getLabelStyles() {
|
81
85
|
return {
|
@@ -92,8 +96,11 @@ export class InputComponent {
|
|
92
96
|
'text-align': 'left'
|
93
97
|
};
|
94
98
|
}
|
95
|
-
|
96
|
-
|
99
|
+
ngOnDestroy() {
|
100
|
+
this.subscriptions.forEach(sub => sub.unsubscribe());
|
101
|
+
}
|
102
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: InputComponent, deps: [{ token: i1.AuthService }], target: i0.ɵɵFactoryTarget.Component }); }
|
103
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: InputComponent, selector: "sim-app-input", inputs: { label: "label", placeholder: "placeholder", id: "id", type: "type", disabled: "disabled", readonly: "readonly", maxlength: "maxlength", minlength: "minlength", required: "required", pattern: "pattern", autofocus: "autofocus", marginTop: "marginTop", marginBottom: "marginBottom", marginLeft: "marginLeft", marginRight: "marginRight", labelFontWeight: "labelFontWeight", permissions: "permissions" }, outputs: { inputEvent: "inputEvent", changeEvent: "changeEvent", focusEvent: "focusEvent", blurEvent: "blurEvent", keyupEvent: "keyupEvent", keydownEvent: "keydownEvent", keypressEvent: "keypressEvent" }, providers: [
|
97
104
|
{
|
98
105
|
provide: NG_VALUE_ACCESSOR,
|
99
106
|
useExisting: forwardRef(() => InputComponent),
|
@@ -116,9 +123,9 @@ export class InputComponent {
|
|
116
123
|
(change)="onChange($event)"
|
117
124
|
(focus)="onFocus($event)"
|
118
125
|
(blur)="onBlur($event)"
|
119
|
-
(keyup)="
|
120
|
-
(keydown)="
|
121
|
-
(keypress)="
|
126
|
+
(keyup)="keyupEvent.emit($event)"
|
127
|
+
(keydown)="keydownEvent.emit($event)"
|
128
|
+
(keypress)="keypressEvent.emit($event)"
|
122
129
|
[disabled]="disabled"
|
123
130
|
[readonly]="readonly"
|
124
131
|
[attr.maxlength]="maxlength"
|
@@ -127,7 +134,7 @@ export class InputComponent {
|
|
127
134
|
[attr.pattern]="pattern"
|
128
135
|
[autofocus]="autofocus">
|
129
136
|
</div>
|
130
|
-
`, isInline: true, styles: [".form-group{font-family:Inter;font-size:1rem;font-weight:700}.form-check-input{font-family:Inter;color:#333;font-size:.9rem}.form-check-label{width:623px;height:19px;top:1608px;left:133px;gap:0px;opacity:0px;font-family:Inter;font-size:16px;line-height:19.36px;text-align:left}\n"], dependencies: [{ kind: "directive", type:
|
137
|
+
`, isInline: true, styles: [".form-group{font-family:Inter;font-size:1rem;font-weight:700}.form-check-input{font-family:Inter;color:#333;font-size:.9rem}.form-check-label{width:623px;height:19px;top:1608px;left:133px;gap:0px;opacity:0px;font-family:Inter;font-size:16px;line-height:19.36px;text-align:left}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i3.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: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
131
138
|
}
|
132
139
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: InputComponent, decorators: [{
|
133
140
|
type: Component,
|
@@ -148,9 +155,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
148
155
|
(change)="onChange($event)"
|
149
156
|
(focus)="onFocus($event)"
|
150
157
|
(blur)="onBlur($event)"
|
151
|
-
(keyup)="
|
152
|
-
(keydown)="
|
153
|
-
(keypress)="
|
158
|
+
(keyup)="keyupEvent.emit($event)"
|
159
|
+
(keydown)="keydownEvent.emit($event)"
|
160
|
+
(keypress)="keypressEvent.emit($event)"
|
154
161
|
[disabled]="disabled"
|
155
162
|
[readonly]="readonly"
|
156
163
|
[attr.maxlength]="maxlength"
|
@@ -166,7 +173,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
166
173
|
multi: true
|
167
174
|
}
|
168
175
|
], changeDetection: ChangeDetectionStrategy.OnPush, styles: [".form-group{font-family:Inter;font-size:1rem;font-weight:700}.form-check-input{font-family:Inter;color:#333;font-size:.9rem}.form-check-label{width:623px;height:19px;top:1608px;left:133px;gap:0px;opacity:0px;font-family:Inter;font-size:16px;line-height:19.36px;text-align:left}\n"] }]
|
169
|
-
}], propDecorators: { label: [{
|
176
|
+
}], ctorParameters: function () { return [{ type: i1.AuthService }]; }, propDecorators: { label: [{
|
170
177
|
type: Input
|
171
178
|
}], placeholder: [{
|
172
179
|
type: Input
|
@@ -200,8 +207,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
200
207
|
type: Input
|
201
208
|
}], permissions: [{
|
202
209
|
type: Input
|
203
|
-
}], permissionChecker: [{
|
204
|
-
type: Input
|
205
210
|
}], inputEvent: [{
|
206
211
|
type: Output
|
207
212
|
}], changeEvent: [{
|
@@ -217,4 +222,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
217
222
|
}], keypressEvent: [{
|
218
223
|
type: Output
|
219
224
|
}] } });
|
220
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../../projects/lib-portal-angular/src/lib/components/imput/input.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, forwardRef } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\n@Component({\n  selector: 'sim-app-input',\n  template: `\n    <div *ngIf=\"hasPermission()\" class=\"form-group\" [ngStyle]=\"{\n      'margin-top': marginTop + 'rem',\n      'margin-bottom': marginBottom + 'rem',\n      'margin-left': marginLeft + 'rem',\n      'margin-right': marginRight + 'rem'\n    }\">\n      <label [for]=\"id\" [ngStyle]=\"getLabelStyles()\">{{ label }}</label>\n      <input [type]=\"type\"\n             class=\"form-control custom-input\"\n             [id]=\"id\"\n             [placeholder]=\"placeholder\"\n             [(ngModel)]=\"value\"\n             (input)=\"onInput($event)\"\n             (change)=\"onChange($event)\"\n             (focus)=\"onFocus($event)\"\n             (blur)=\"onBlur($event)\"\n             (keyup)=\"onKeyup($event)\"\n             (keydown)=\"onKeydown($event)\"\n             (keypress)=\"onKeypress($event)\"\n             [disabled]=\"disabled\"\n             [readonly]=\"readonly\"\n             [attr.maxlength]=\"maxlength\"\n             [attr.minlength]=\"minlength\"\n             [required]=\"required\"\n             [attr.pattern]=\"pattern\"\n             [autofocus]=\"autofocus\">\n    </div>\n  `,\n  styles: [`\n    .form-group {\n      font-family: Inter;\n      font-size: 1rem;\n      font-weight: bold;\n    }\n    .form-check-input {\n      font-family: Inter;\n      color: #333;\n      font-size: 0.9rem;\n    }\n    .form-check-label {\n      width: 623px;\n      height: 19px;\n      top: 1608px;\n      left: 133px;\n      gap: 0px;\n      opacity: 0px;\n      font-family: Inter;\n      font-size: 16px;\n      line-height: 19.36px;\n      text-align: left;\n    }\n  `],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => InputComponent),\n      multi: true\n    }\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class InputComponent implements ControlValueAccessor {\n  @Input() label: string = 'Default Label';\n  @Input() placeholder: string = '';\n  @Input() id: string = 'inputId';\n  @Input() type: string = 'text';\n  @Input() disabled: boolean = false;\n  @Input() readonly: boolean = false;\n  @Input() maxlength: number | null = null;\n  @Input() minlength: number | null = null;\n  @Input() required: boolean = false;\n  @Input() pattern: string | null = null;\n  @Input() autofocus: boolean = false;\n\n  @Input() marginTop: number = 0;\n  @Input() marginBottom: number = 0;\n  @Input() marginLeft: number = 0;\n  @Input() marginRight: number = 0;\n  @Input() labelFontWeight: number = 400;\n\n  @Input() permissions: string[] = [];\n  @Input() permissionChecker: ((permissions: string[]) => boolean) | null = null;\n\n  @Output() inputEvent: EventEmitter<Event> = new EventEmitter<Event>();\n  @Output() changeEvent: EventEmitter<Event> = new EventEmitter<Event>();\n  @Output() focusEvent: EventEmitter<FocusEvent> = new EventEmitter<FocusEvent>();\n  @Output() blurEvent: EventEmitter<FocusEvent> = new EventEmitter<FocusEvent>();\n  @Output() keyupEvent: EventEmitter<KeyboardEvent> = new EventEmitter<KeyboardEvent>();\n  @Output() keydownEvent: EventEmitter<KeyboardEvent> = new EventEmitter<KeyboardEvent>();\n  @Output() keypressEvent: EventEmitter<KeyboardEvent> = new EventEmitter<KeyboardEvent>();\n\n  private onChangeCallback: (_: any) => void = () => { };\n  private onTouchedCallback: () => void = () => { };\n\n  value: string = '';\n\n  onInput(event: Event) {\n    const inputElement = event.target as HTMLInputElement;\n    this.value = inputElement.value;\n    this.onChangeCallback(this.value);\n    this.inputEvent.emit(event);\n  }\n\n  onChange(event: Event) {\n    this.changeEvent.emit(event);\n  }\n\n  onFocus(event: FocusEvent) {\n    this.focusEvent.emit(event);\n  }\n\n  onBlur(event: FocusEvent) {\n    this.onTouchedCallback();\n    this.blurEvent.emit(event);\n  }\n\n  onKeyup(event: KeyboardEvent) {\n    this.keyupEvent.emit(event);\n  }\n\n  onKeydown(event: KeyboardEvent) {\n    this.keydownEvent.emit(event);\n  }\n\n  onKeypress(event: KeyboardEvent) {\n    this.keypressEvent.emit(event);\n  }\n\n  writeValue(value: any): void {\n    this.value = value;\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChangeCallback = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouchedCallback = fn;\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  hasPermission(): boolean {\n    if (!this.permissionChecker || this.permissions.length === 0) {\n      return true;\n    }\n    return this.permissionChecker(this.permissions);\n  }\n\n  getLabelStyles() {\n    return {\n      'font-weight': this.labelFontWeight,\n      'width': '623px',\n      'height': '19px',\n      'top': '1608px',\n      'left': '133px',\n      'gap': '0px',\n      'opacity': '0px',\n      'font-family': 'Inter',\n      'font-size': '16px',\n      'line-height': '19.36px',\n      'text-align': 'left'\n    };\n  }\n}\n"]}
|
225
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../../projects/lib-portal-angular/src/lib/components/imput/input.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAAE,UAAU,EAAE,KAAK,EAAa,MAAM,EAAE,MAAM,eAAe,CAAC;AACvH,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;;;;;AAoEzE,MAAM,OAAO,cAAc;IAoCzB,YAAoB,WAAwB;QAAxB,gBAAW,GAAX,WAAW,CAAa;QAnCnC,UAAK,GAAW,eAAe,CAAC;QAChC,gBAAW,GAAW,EAAE,CAAC;QACzB,OAAE,GAAW,SAAS,CAAC;QACvB,SAAI,GAAW,MAAM,CAAC;QACtB,aAAQ,GAAY,KAAK,CAAC;QAC1B,aAAQ,GAAY,KAAK,CAAC;QAC1B,cAAS,GAAkB,IAAI,CAAC;QAChC,cAAS,GAAkB,IAAI,CAAC;QAChC,aAAQ,GAAY,KAAK,CAAC;QAC1B,YAAO,GAAkB,IAAI,CAAC;QAC9B,cAAS,GAAY,KAAK,CAAC;QAE3B,cAAS,GAAW,CAAC,CAAC;QACtB,iBAAY,GAAW,CAAC,CAAC;QACzB,eAAU,GAAW,CAAC,CAAC;QACvB,gBAAW,GAAW,CAAC,CAAC;QACxB,oBAAe,GAAW,GAAG,CAAC;QAE9B,gBAAW,GAAa,EAAE,CAAC;QAE1B,eAAU,GAAwB,IAAI,YAAY,EAAS,CAAC;QAC5D,gBAAW,GAAwB,IAAI,YAAY,EAAS,CAAC;QAC7D,eAAU,GAA6B,IAAI,YAAY,EAAc,CAAC;QACtE,cAAS,GAA6B,IAAI,YAAY,EAAc,CAAC;QACrE,eAAU,GAAgC,IAAI,YAAY,EAAiB,CAAC;QAC5E,iBAAY,GAAgC,IAAI,YAAY,EAAiB,CAAC;QAC9E,kBAAa,GAAgC,IAAI,YAAY,EAAiB,CAAC;QAEjF,qBAAgB,GAAqB,GAAG,EAAE,GAAG,CAAC,CAAC;QAC/C,sBAAiB,GAAe,GAAG,EAAE,GAAG,CAAC,CAAC;QAElD,UAAK,GAAW,EAAE,CAAC;QAEX,kBAAa,GAAmB,EAAE,CAAC;IAEK,CAAC;IAEjD,OAAO,CAAC,KAAY;QAClB,MAAM,YAAY,GAAG,KAAK,CAAC,MAA0B,CAAC;QACtD,IAAI,CAAC,KAAK,GAAG,YAAY,CAAC,KAAK,CAAC;QAChC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAClC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC;IAED,QAAQ,CAAC,KAAY;QACnB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;IAED,OAAO,CAAC,KAAiB;QACvB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC;IAED,MAAM,CAAC,KAAiB;QACtB,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC7B,CAAC;IAED,UAAU,CAAC,KAAU;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IAED,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;IAC7B,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAC;IAC9B,CAAC;IAED,gBAAgB,CAAE,UAAmB;QACnC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;IAC7B,CAAC;IAED,aAAa;QACX,IAAI,IAAI,CAAC,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE;YACjC,OAAO,IAAI,CAAC;SACb;QAED,IAAI;YACF,OAAO,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;SACzD;QAAC,OAAO,KAAc,EAAE;YACvB,IAAI,KAAK,YAAY,KAAK,EAAE;gBAC1B,OAAO,CAAC,KAAK,CAAC,mBAAmB,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC;aACnD;iBAAM;gBACL,OAAO,CAAC,KAAK,CAAC,gDAAgD,CAAC,CAAC;aACjE;YACD,OAAO,IAAI,CAAC;SACb;IACH,CAAC;IAED,cAAc;QACZ,OAAO;YACL,aAAa,EAAE,IAAI,CAAC,eAAe;YACnC,OAAO,EAAE,OAAO;YAChB,QAAQ,EAAE,MAAM;YAChB,KAAK,EAAE,QAAQ;YACf,MAAM,EAAE,OAAO;YACf,KAAK,EAAE,KAAK;YACZ,SAAS,EAAE,KAAK;YAChB,aAAa,EAAE,OAAO;YACtB,WAAW,EAAE,MAAM;YACnB,aAAa,EAAE,SAAS;YACxB,YAAY,EAAE,MAAM;SACrB,CAAC;IACJ,CAAC;IAED,WAAW;QACT,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC,CAAC;IACvD,CAAC;+GA7GU,cAAc;mGAAd,cAAc,+oBATd;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,cAAc,CAAC;gBAC7C,KAAK,EAAE,IAAI;aACZ;SACF,0BA3DS;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4BT;;4FAkCU,cAAc;kBAhE1B,SAAS;+BACE,eAAe,YACf;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4BT,aAyBU;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,eAAe,CAAC;4BAC7C,KAAK,EAAE,IAAI;yBACZ;qBACF,mBACgB,uBAAuB,CAAC,MAAM;kGAGtC,KAAK;sBAAb,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,EAAE;sBAAV,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBAEG,SAAS;sBAAjB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBAEG,WAAW;sBAAnB,KAAK;gBAEI,UAAU;sBAAnB,MAAM;gBACG,WAAW;sBAApB,MAAM;gBACG,UAAU;sBAAnB,MAAM;gBACG,SAAS;sBAAlB,MAAM;gBACG,UAAU;sBAAnB,MAAM;gBACG,YAAY;sBAArB,MAAM;gBACG,aAAa;sBAAtB,MAAM","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, Input, OnDestroy, Output } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { AuthService } from '../../service/auth-service.service';\n\n@Component({\n  selector: 'sim-app-input',\n  template: `\n    <div *ngIf=\"hasPermission()\" class=\"form-group\" [ngStyle]=\"{\n      'margin-top': marginTop + 'rem',\n      'margin-bottom': marginBottom + 'rem',\n      'margin-left': marginLeft + 'rem',\n      'margin-right': marginRight + 'rem'\n    }\">\n      <label [for]=\"id\" [ngStyle]=\"getLabelStyles()\">{{ label }}</label>\n      <input [type]=\"type\"\n             class=\"form-control custom-input\"\n             [id]=\"id\"\n             [placeholder]=\"placeholder\"\n             [(ngModel)]=\"value\"\n             (input)=\"onInput($event)\"\n             (change)=\"onChange($event)\"\n             (focus)=\"onFocus($event)\"\n             (blur)=\"onBlur($event)\"\n             (keyup)=\"keyupEvent.emit($event)\"\n             (keydown)=\"keydownEvent.emit($event)\"\n             (keypress)=\"keypressEvent.emit($event)\"\n             [disabled]=\"disabled\"\n             [readonly]=\"readonly\"\n             [attr.maxlength]=\"maxlength\"\n             [attr.minlength]=\"minlength\"\n             [required]=\"required\"\n             [attr.pattern]=\"pattern\"\n             [autofocus]=\"autofocus\">\n    </div>\n  `,\n  styles: [`\n    .form-group {\n      font-family: Inter;\n      font-size: 1rem;\n      font-weight: bold;\n    }\n    .form-check-input {\n      font-family: Inter;\n      color: #333;\n      font-size: 0.9rem;\n    }\n    .form-check-label {\n      width: 623px;\n      height: 19px;\n      top: 1608px;\n      left: 133px;\n      gap: 0px;\n      opacity: 0px;\n      font-family: Inter;\n      font-size: 16px;\n      line-height: 19.36px;\n      text-align: left;\n    }\n  `],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => InputComponent),\n      multi: true\n    }\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class InputComponent implements ControlValueAccessor, OnDestroy {\n  @Input() label: string = 'Default Label';\n  @Input() placeholder: string = '';\n  @Input() id: string = 'inputId';\n  @Input() type: string = 'text';\n  @Input() disabled: boolean = false;\n  @Input() readonly: boolean = false;\n  @Input() maxlength: number | null = null;\n  @Input() minlength: number | null = null;\n  @Input() required: boolean = false;\n  @Input() pattern: string | null = null;\n  @Input() autofocus: boolean = false;\n\n  @Input() marginTop: number = 0;\n  @Input() marginBottom: number = 0;\n  @Input() marginLeft: number = 0;\n  @Input() marginRight: number = 0;\n  @Input() labelFontWeight: number = 400;\n\n  @Input() permissions: string[] = [];\n\n  @Output() inputEvent: EventEmitter<Event> = new EventEmitter<Event>();\n  @Output() changeEvent: EventEmitter<Event> = new EventEmitter<Event>();\n  @Output() focusEvent: EventEmitter<FocusEvent> = new EventEmitter<FocusEvent>();\n  @Output() blurEvent: EventEmitter<FocusEvent> = new EventEmitter<FocusEvent>();\n  @Output() keyupEvent: EventEmitter<KeyboardEvent> = new EventEmitter<KeyboardEvent>();\n  @Output() keydownEvent: EventEmitter<KeyboardEvent> = new EventEmitter<KeyboardEvent>();\n  @Output() keypressEvent: EventEmitter<KeyboardEvent> = new EventEmitter<KeyboardEvent>();\n\n  private onChangeCallback: (_: any) => void = () => { };\n  private onTouchedCallback: () => void = () => { };\n\n  value: string = '';\n\n  private subscriptions: Subscription[] = [];\n\n  constructor(private authService: AuthService) { }\n\n  onInput(event: Event) {\n    const inputElement = event.target as HTMLInputElement;\n    this.value = inputElement.value;\n    this.onChangeCallback(this.value);\n    this.inputEvent.emit(event);\n  }\n\n  onChange(event: Event) {\n    this.changeEvent.emit(event);\n  }\n\n  onFocus(event: FocusEvent) {\n    this.focusEvent.emit(event);\n  }\n\n  onBlur(event: FocusEvent) {\n    this.onTouchedCallback();\n    this.blurEvent.emit(event);\n  }\n\n  writeValue(value: any): void {\n    this.value = value;\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChangeCallback = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouchedCallback = fn;\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  hasPermission(): boolean {\n    if (this.permissions.length === 0) {\n      return true;\n    }\n\n    try {\n      return this.authService.hasPermission(this.permissions);\n    } catch (error: unknown) {\n      if (error instanceof Error) {\n        console.error('Permission error:', error.message);\n      } else {\n        console.error('Unknown error occurred during permission check');\n      }\n      return true;\n    }\n  }\n\n  getLabelStyles() {\n    return {\n      'font-weight': this.labelFontWeight,\n      'width': '623px',\n      'height': '19px',\n      'top': '1608px',\n      'left': '133px',\n      'gap': '0px',\n      'opacity': '0px',\n      'font-family': 'Inter',\n      'font-size': '16px',\n      'line-height': '19.36px',\n      'text-align': 'left'\n    };\n  }\n\n  ngOnDestroy(): void {\n    this.subscriptions.forEach(sub => sub.unsubscribe());\n  }\n}\n"]}
|
@@ -0,0 +1,122 @@
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
2
|
+
import { Subject, Subscription } from 'rxjs';
|
3
|
+
import { debounceTime } from 'rxjs/operators';
|
4
|
+
import * as i0 from "@angular/core";
|
5
|
+
import * as i1 from "@angular/common";
|
6
|
+
import * as i2 from "@angular/forms";
|
7
|
+
export class SearchInputComponent {
|
8
|
+
constructor() {
|
9
|
+
this.id = '';
|
10
|
+
this.label = 'Search';
|
11
|
+
this.type = 'text';
|
12
|
+
this.placeholder = 'Type to search...';
|
13
|
+
this.value = '';
|
14
|
+
this.disabled = false;
|
15
|
+
this.readonly = false;
|
16
|
+
this.autofocus = false;
|
17
|
+
this.maxlength = null;
|
18
|
+
this.minlength = null;
|
19
|
+
this.required = false;
|
20
|
+
this.pattern = null;
|
21
|
+
this.debounceTime = 700; // Valor padrão
|
22
|
+
this.search = new EventEmitter();
|
23
|
+
this.inputChange = new EventEmitter();
|
24
|
+
this.change = new EventEmitter();
|
25
|
+
this.focus = new EventEmitter();
|
26
|
+
this.blur = new EventEmitter();
|
27
|
+
this.keyup = new EventEmitter();
|
28
|
+
this.keydown = new EventEmitter();
|
29
|
+
this.keypress = new EventEmitter();
|
30
|
+
this.searchSubject = new Subject();
|
31
|
+
this.searchSubscription = new Subscription();
|
32
|
+
}
|
33
|
+
ngOnInit() {
|
34
|
+
this.searchSubscription = this.searchSubject.pipe(debounceTime(this.debounceTime)).subscribe((searchText) => {
|
35
|
+
this.search.emit(searchText);
|
36
|
+
});
|
37
|
+
}
|
38
|
+
onInput(event) {
|
39
|
+
const inputElement = event.target;
|
40
|
+
const value = inputElement.value;
|
41
|
+
this.value = value;
|
42
|
+
this.inputChange.emit(value); // Emite o valor de input imediatamente
|
43
|
+
this.searchSubject.next(value);
|
44
|
+
}
|
45
|
+
onChange(event) {
|
46
|
+
this.change.emit(event);
|
47
|
+
}
|
48
|
+
onFocus(event) {
|
49
|
+
this.focus.emit(event);
|
50
|
+
}
|
51
|
+
onBlur(event) {
|
52
|
+
this.blur.emit(event);
|
53
|
+
}
|
54
|
+
onKeyup(event) {
|
55
|
+
this.keyup.emit(event);
|
56
|
+
}
|
57
|
+
onKeydown(event) {
|
58
|
+
this.keydown.emit(event);
|
59
|
+
}
|
60
|
+
onKeypress(event) {
|
61
|
+
this.keypress.emit(event);
|
62
|
+
}
|
63
|
+
ngOnDestroy() {
|
64
|
+
this.searchSubscription.unsubscribe();
|
65
|
+
}
|
66
|
+
getLabelStyles() {
|
67
|
+
return {
|
68
|
+
fontFamily: 'Inter',
|
69
|
+
fontSize: '16px',
|
70
|
+
lineHeight: '19.36px',
|
71
|
+
};
|
72
|
+
}
|
73
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SearchInputComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
74
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: SearchInputComponent, selector: "sim-search-input", inputs: { id: "id", label: "label", type: "type", placeholder: "placeholder", value: "value", disabled: "disabled", readonly: "readonly", autofocus: "autofocus", maxlength: "maxlength", minlength: "minlength", required: "required", pattern: "pattern", debounceTime: "debounceTime" }, outputs: { search: "search", inputChange: "inputChange", change: "change", focus: "focus", blur: "blur", keyup: "keyup", keydown: "keydown", keypress: "keypress" }, ngImport: i0, template: "<div class=\"form-group\">\n <label [for]=\"id\" [ngStyle]=\"getLabelStyles()\">{{ label }}</label>\n <input [type]=\"type\"\n class=\"form-control custom-input\"\n [id]=\"id\"\n [placeholder]=\"placeholder\"\n [(ngModel)]=\"value\"\n (input)=\"onInput($event)\"\n (change)=\"onChange($event)\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n (keyup)=\"onKeyup($event)\"\n (keydown)=\"onKeydown($event)\"\n (keypress)=\"onKeypress($event)\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [attr.maxlength]=\"maxlength\"\n [attr.minlength]=\"minlength\"\n [required]=\"required\"\n [attr.pattern]=\"pattern\"\n [autofocus]=\"autofocus\">\n</div>\n", styles: [".form-group{font-family:Inter;font-size:1rem;font-weight:700}.custom-input{font-family:Inter;color:#333;font-size:.9rem}label{font-family:Inter;font-size:16px;line-height:19.36px;text-align:left}\n"], dependencies: [{ kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { 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.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); }
|
75
|
+
}
|
76
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SearchInputComponent, decorators: [{
|
77
|
+
type: Component,
|
78
|
+
args: [{ selector: 'sim-search-input', template: "<div class=\"form-group\">\n <label [for]=\"id\" [ngStyle]=\"getLabelStyles()\">{{ label }}</label>\n <input [type]=\"type\"\n class=\"form-control custom-input\"\n [id]=\"id\"\n [placeholder]=\"placeholder\"\n [(ngModel)]=\"value\"\n (input)=\"onInput($event)\"\n (change)=\"onChange($event)\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n (keyup)=\"onKeyup($event)\"\n (keydown)=\"onKeydown($event)\"\n (keypress)=\"onKeypress($event)\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [attr.maxlength]=\"maxlength\"\n [attr.minlength]=\"minlength\"\n [required]=\"required\"\n [attr.pattern]=\"pattern\"\n [autofocus]=\"autofocus\">\n</div>\n", styles: [".form-group{font-family:Inter;font-size:1rem;font-weight:700}.custom-input{font-family:Inter;color:#333;font-size:.9rem}label{font-family:Inter;font-size:16px;line-height:19.36px;text-align:left}\n"] }]
|
79
|
+
}], ctorParameters: function () { return []; }, propDecorators: { id: [{
|
80
|
+
type: Input
|
81
|
+
}], label: [{
|
82
|
+
type: Input
|
83
|
+
}], type: [{
|
84
|
+
type: Input
|
85
|
+
}], placeholder: [{
|
86
|
+
type: Input
|
87
|
+
}], value: [{
|
88
|
+
type: Input
|
89
|
+
}], disabled: [{
|
90
|
+
type: Input
|
91
|
+
}], readonly: [{
|
92
|
+
type: Input
|
93
|
+
}], autofocus: [{
|
94
|
+
type: Input
|
95
|
+
}], maxlength: [{
|
96
|
+
type: Input
|
97
|
+
}], minlength: [{
|
98
|
+
type: Input
|
99
|
+
}], required: [{
|
100
|
+
type: Input
|
101
|
+
}], pattern: [{
|
102
|
+
type: Input
|
103
|
+
}], debounceTime: [{
|
104
|
+
type: Input
|
105
|
+
}], search: [{
|
106
|
+
type: Output
|
107
|
+
}], inputChange: [{
|
108
|
+
type: Output
|
109
|
+
}], change: [{
|
110
|
+
type: Output
|
111
|
+
}], focus: [{
|
112
|
+
type: Output
|
113
|
+
}], blur: [{
|
114
|
+
type: Output
|
115
|
+
}], keyup: [{
|
116
|
+
type: Output
|
117
|
+
}], keydown: [{
|
118
|
+
type: Output
|
119
|
+
}], keypress: [{
|
120
|
+
type: Output
|
121
|
+
}] } });
|
122
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-input.component.js","sourceRoot":"","sources":["../../../../../../projects/lib-portal-angular/src/lib/components/search-input/search-input.component.ts","../../../../../../projects/lib-portal-angular/src/lib/components/search-input/search-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output } from '@angular/core';\nimport { Subject, Subscription } from 'rxjs';\nimport { debounceTime } from 'rxjs/operators';\n\n@Component({\n    selector: 'sim-search-input',\n    templateUrl: './search-input.component.html',\n    styleUrls: ['./search-input.component.scss']\n})\nexport class SearchInputComponent implements OnInit, OnDestroy {\n    @Input() id: string = '';\n    @Input() label: string = 'Search';\n    @Input() type: string = 'text';\n    @Input() placeholder: string = 'Type to search...';\n    @Input() value: string = '';\n    @Input() disabled: boolean = false;\n    @Input() readonly: boolean = false;\n    @Input() autofocus: boolean = false;\n    @Input() maxlength: number | null = null;\n    @Input() minlength: number | null = null;\n    @Input() required: boolean = false;\n    @Input() pattern: string | null = null;\n    @Input() debounceTime: number = 700; // Valor padrão\n\n    @Output() search = new EventEmitter<string>();\n    @Output() inputChange = new EventEmitter<string>();\n    @Output() change = new EventEmitter<Event>();\n    @Output() focus = new EventEmitter<Event>();\n    @Output() blur = new EventEmitter<Event>();\n    @Output() keyup = new EventEmitter<KeyboardEvent>();\n    @Output() keydown = new EventEmitter<KeyboardEvent>();\n    @Output() keypress = new EventEmitter<KeyboardEvent>();\n\n    private searchSubject: Subject<string> = new Subject<string>();\n    private searchSubscription: Subscription = new Subscription();\n\n    constructor() { }\n\n    ngOnInit(): void {\n        this.searchSubscription = this.searchSubject.pipe(\n            debounceTime(this.debounceTime)\n        ).subscribe((searchText) => {\n            this.search.emit(searchText);\n        });\n    }\n\n    onInput(event: Event): void {\n        const inputElement = event.target as HTMLInputElement;\n        const value = inputElement.value;\n        this.value = value;\n        this.inputChange.emit(value); // Emite o valor de input imediatamente\n        this.searchSubject.next(value);\n    }\n\n    onChange(event: Event): void {\n        this.change.emit(event);\n    }\n\n    onFocus(event: Event): void {\n        this.focus.emit(event);\n    }\n\n    onBlur(event: Event): void {\n        this.blur.emit(event);\n    }\n\n    onKeyup(event: KeyboardEvent): void {\n        this.keyup.emit(event);\n    }\n\n    onKeydown(event: KeyboardEvent): void {\n        this.keydown.emit(event);\n    }\n\n    onKeypress(event: KeyboardEvent): void {\n        this.keypress.emit(event);\n    }\n\n    ngOnDestroy(): void {\n        this.searchSubscription.unsubscribe();\n    }\n\n    getLabelStyles() {\n        return {\n            fontFamily: 'Inter',\n            fontSize: '16px',\n            lineHeight: '19.36px',\n        };\n    }\n}\n","<div class=\"form-group\">\n  <label [for]=\"id\" [ngStyle]=\"getLabelStyles()\">{{ label }}</label>\n  <input [type]=\"type\"\n         class=\"form-control custom-input\"\n         [id]=\"id\"\n         [placeholder]=\"placeholder\"\n         [(ngModel)]=\"value\"\n         (input)=\"onInput($event)\"\n         (change)=\"onChange($event)\"\n         (focus)=\"onFocus($event)\"\n         (blur)=\"onBlur($event)\"\n         (keyup)=\"onKeyup($event)\"\n         (keydown)=\"onKeydown($event)\"\n         (keypress)=\"onKeypress($event)\"\n         [disabled]=\"disabled\"\n         [readonly]=\"readonly\"\n         [attr.maxlength]=\"maxlength\"\n         [attr.minlength]=\"minlength\"\n         [required]=\"required\"\n         [attr.pattern]=\"pattern\"\n         [autofocus]=\"autofocus\">\n</div>\n"]}
|
@@ -0,0 +1,37 @@
|
|
1
|
+
import { Injectable } from '@angular/core';
|
2
|
+
import { HttpParams } from '@angular/common/http';
|
3
|
+
import { map } from 'rxjs/operators';
|
4
|
+
import * as i0 from "@angular/core";
|
5
|
+
import * as i1 from "@angular/common/http";
|
6
|
+
export class DataPaginateService {
|
7
|
+
constructor(http) {
|
8
|
+
this.http = http;
|
9
|
+
}
|
10
|
+
fetchData(url, params) {
|
11
|
+
let httpParams = new HttpParams()
|
12
|
+
.set('page', params.pageNumber.toString())
|
13
|
+
.set('limit', params.pageSize.toString())
|
14
|
+
.set('sort', params.sortColumn)
|
15
|
+
.set('order', params.sortDirection);
|
16
|
+
if (params.filterDescription) {
|
17
|
+
httpParams = httpParams.set('description', params.filterDescription);
|
18
|
+
}
|
19
|
+
return this.http.get(url, { params: httpParams }).pipe(map(response => {
|
20
|
+
const items = response.data || [];
|
21
|
+
const totalItems = response.meta.total || 0;
|
22
|
+
return {
|
23
|
+
items,
|
24
|
+
totalItems
|
25
|
+
};
|
26
|
+
}));
|
27
|
+
}
|
28
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DataPaginateService, deps: [{ token: i1.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
29
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DataPaginateService, providedIn: 'root' }); }
|
30
|
+
}
|
31
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DataPaginateService, decorators: [{
|
32
|
+
type: Injectable,
|
33
|
+
args: [{
|
34
|
+
providedIn: 'root'
|
35
|
+
}]
|
36
|
+
}], ctorParameters: function () { return [{ type: i1.HttpClient }]; } });
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS1wYWdpbmF0ZS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbGliLXBvcnRhbC1hbmd1bGFyL3NyYy9saWIvY29tcG9uZW50cy90YWJsZXMvZGF0YS1wYWdpbmF0ZS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFjLFVBQVUsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBRTlELE9BQU8sRUFBRSxHQUFHLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7O0FBa0JyQyxNQUFNLE9BQU8sbUJBQW1CO0lBQzVCLFlBQW9CLElBQWdCO1FBQWhCLFNBQUksR0FBSixJQUFJLENBQVk7SUFBSSxDQUFDO0lBRXpDLFNBQVMsQ0FBSSxHQUFXLEVBQUUsTUFBMEI7UUFDaEQsSUFBSSxVQUFVLEdBQUcsSUFBSSxVQUFVLEVBQUU7YUFDNUIsR0FBRyxDQUFDLE1BQU0sRUFBRSxNQUFNLENBQUMsVUFBVSxDQUFDLFFBQVEsRUFBRSxDQUFDO2FBQ3pDLEdBQUcsQ0FBQyxPQUFPLEVBQUUsTUFBTSxDQUFDLFFBQVEsQ0FBQyxRQUFRLEVBQUUsQ0FBQzthQUN4QyxHQUFHLENBQUMsTUFBTSxFQUFFLE1BQU0sQ0FBQyxVQUFVLENBQUM7YUFDOUIsR0FBRyxDQUFDLE9BQU8sRUFBRSxNQUFNLENBQUMsYUFBYSxDQUFDLENBQUM7UUFFeEMsSUFBSSxNQUFNLENBQUMsaUJBQWlCLEVBQUU7WUFDMUIsVUFBVSxHQUFHLFVBQVUsQ0FBQyxHQUFHLENBQUMsYUFBYSxFQUFFLE1BQU0sQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO1NBQ3hFO1FBRUQsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBeUMsR0FBRyxFQUFFLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUMxRixHQUFHLENBQUMsUUFBUSxDQUFDLEVBQUU7WUFDWCxNQUFNLEtBQUssR0FBRyxRQUFRLENBQUMsSUFBSSxJQUFJLEVBQUUsQ0FBQztZQUNsQyxNQUFNLFVBQVUsR0FBRyxRQUFRLENBQUMsSUFBSSxDQUFDLEtBQUssSUFBSSxDQUFDLENBQUM7WUFDNUMsT0FBTztnQkFDSCxLQUFLO2dCQUNMLFVBQVU7YUFDYixDQUFDO1FBQ04sQ0FBQyxDQUFDLENBQ0wsQ0FBQztJQUNOLENBQUM7K0dBeEJRLG1CQUFtQjttSEFBbkIsbUJBQW1CLGNBRmhCLE1BQU07OzRGQUVULG1CQUFtQjtrQkFIL0IsVUFBVTttQkFBQztvQkFDUixVQUFVLEVBQUUsTUFBTTtpQkFDckIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBIdHRwQ2xpZW50LCBIdHRwUGFyYW1zIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgbWFwIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIElEYXRhSW5kZXhQYWdpbmF0ZSB7XG4gICAgZmlsdGVyRGVzY3JpcHRpb24/OiBzdHJpbmc7XG4gICAgcGFnZU51bWJlcjogbnVtYmVyO1xuICAgIHBhZ2VTaXplOiBudW1iZXI7XG4gICAgc29ydENvbHVtbjogc3RyaW5nO1xuICAgIHNvcnREaXJlY3Rpb246ICdhc2MnIHwgJ2Rlc2MnO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIElQYWdpbmF0ZVJlc3VsdDxUPiB7XG4gICAgaXRlbXM6IFRbXTtcbiAgICB0b3RhbEl0ZW1zOiBudW1iZXI7XG59XG5cbkBJbmplY3RhYmxlKHtcbiAgICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgRGF0YVBhZ2luYXRlU2VydmljZSB7XG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBodHRwOiBIdHRwQ2xpZW50KSB7IH1cblxuICAgIGZldGNoRGF0YTxUPih1cmw6IHN0cmluZywgcGFyYW1zOiBJRGF0YUluZGV4UGFnaW5hdGUpOiBPYnNlcnZhYmxlPElQYWdpbmF0ZVJlc3VsdDxUPj4ge1xuICAgICAgICBsZXQgaHR0cFBhcmFtcyA9IG5ldyBIdHRwUGFyYW1zKClcbiAgICAgICAgICAgIC5zZXQoJ3BhZ2UnLCBwYXJhbXMucGFnZU51bWJlci50b1N0cmluZygpKVxuICAgICAgICAgICAgLnNldCgnbGltaXQnLCBwYXJhbXMucGFnZVNpemUudG9TdHJpbmcoKSlcbiAgICAgICAgICAgIC5zZXQoJ3NvcnQnLCBwYXJhbXMuc29ydENvbHVtbilcbiAgICAgICAgICAgIC5zZXQoJ29yZGVyJywgcGFyYW1zLnNvcnREaXJlY3Rpb24pO1xuXG4gICAgICAgIGlmIChwYXJhbXMuZmlsdGVyRGVzY3JpcHRpb24pIHtcbiAgICAgICAgICAgIGh0dHBQYXJhbXMgPSBodHRwUGFyYW1zLnNldCgnZGVzY3JpcHRpb24nLCBwYXJhbXMuZmlsdGVyRGVzY3JpcHRpb24pO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIHRoaXMuaHR0cC5nZXQ8eyBtZXRhOiB7IHRvdGFsOiBudW1iZXIgfSwgZGF0YTogVFtdIH0+KHVybCwgeyBwYXJhbXM6IGh0dHBQYXJhbXMgfSkucGlwZShcbiAgICAgICAgICAgIG1hcChyZXNwb25zZSA9PiB7XG4gICAgICAgICAgICAgICAgY29uc3QgaXRlbXMgPSByZXNwb25zZS5kYXRhIHx8IFtdO1xuICAgICAgICAgICAgICAgIGNvbnN0IHRvdGFsSXRlbXMgPSByZXNwb25zZS5tZXRhLnRvdGFsIHx8IDA7XG4gICAgICAgICAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgICAgICAgICAgaXRlbXMsXG4gICAgICAgICAgICAgICAgICAgIHRvdGFsSXRlbXNcbiAgICAgICAgICAgICAgICB9O1xuICAgICAgICAgICAgfSlcbiAgICAgICAgKTtcbiAgICB9XG59XG4iXX0=
|