@rlucan/ui 18.2.3 → 19.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (41) hide show
  1. package/fesm2022/rlucan-ui.mjs +144 -140
  2. package/fesm2022/rlucan-ui.mjs.map +1 -1
  3. package/package.json +11 -13
  4. package/esm2022/lib/action-button/action-button.component.mjs +0 -99
  5. package/esm2022/lib/action-icon/action-icon.component.mjs +0 -37
  6. package/esm2022/lib/auto-complete/auto-complete.component.mjs +0 -405
  7. package/esm2022/lib/autocomplete/autocomplete.component.mjs +0 -391
  8. package/esm2022/lib/avatar/avatar.component.mjs +0 -34
  9. package/esm2022/lib/button/button.component.mjs +0 -57
  10. package/esm2022/lib/checkbox/checkbox.component.mjs +0 -39
  11. package/esm2022/lib/checkbox-group/checkbox-group.component.mjs +0 -91
  12. package/esm2022/lib/currency/currency.component.mjs +0 -151
  13. package/esm2022/lib/date/date.component.mjs +0 -68
  14. package/esm2022/lib/dialog/dialog.component.mjs +0 -37
  15. package/esm2022/lib/directives/force-visibility/force-visibility.directive.mjs +0 -104
  16. package/esm2022/lib/editor/editor.component.mjs +0 -119
  17. package/esm2022/lib/elements/burger/burger.component.mjs +0 -21
  18. package/esm2022/lib/elements/expander/expander.component.mjs +0 -28
  19. package/esm2022/lib/elements/validation-message/validation-message.component.mjs +0 -47
  20. package/esm2022/lib/file/file.component.mjs +0 -177
  21. package/esm2022/lib/file-uploader/ui-file-uploader.component.mjs +0 -424
  22. package/esm2022/lib/input/input.component.mjs +0 -265
  23. package/esm2022/lib/input-autocomplete/input-autocomplete.component.mjs +0 -277
  24. package/esm2022/lib/layouts/base/ui-base-layout.component.mjs +0 -22
  25. package/esm2022/lib/layouts/base/ui-base.component.mjs +0 -74
  26. package/esm2022/lib/layouts/simple/ui-simple-layout.component.mjs +0 -18
  27. package/esm2022/lib/layouts/simple/ui-simple.component.mjs +0 -166
  28. package/esm2022/lib/radio/radio.component.mjs +0 -21
  29. package/esm2022/lib/radio-group/radio-group.component.mjs +0 -58
  30. package/esm2022/lib/select/select.component.mjs +0 -126
  31. package/esm2022/lib/services/message-box.service.mjs +0 -149
  32. package/esm2022/lib/services/toast.service.mjs +0 -23
  33. package/esm2022/lib/services/ui-file.service.mjs +0 -72
  34. package/esm2022/lib/services/ui-translate.service.mjs +0 -32
  35. package/esm2022/lib/submit-button/submit-button.component.mjs +0 -72
  36. package/esm2022/lib/table/table.component.mjs +0 -97
  37. package/esm2022/lib/text-area/text-area.component.mjs +0 -46
  38. package/esm2022/lib/ui.model.mjs +0 -2
  39. package/esm2022/lib/ui.module.mjs +0 -274
  40. package/esm2022/public-api.mjs +0 -36
  41. package/esm2022/rlucan-ui.mjs +0 -5
@@ -1,149 +0,0 @@
1
- import { Component, Inject, Injectable } from '@angular/core';
2
- import { MAT_DIALOG_DATA, MatDialogConfig } from '@angular/material/dialog';
3
- import { UI_TRANSLATESERVICE } from './ui-translate.service';
4
- import * as i0 from "@angular/core";
5
- import * as i1 from "@angular/material/dialog";
6
- import * as i2 from "@angular/platform-browser";
7
- import * as i3 from "@angular/common";
8
- import * as i4 from "../button/button.component";
9
- import * as i5 from "../dialog/dialog.component";
10
- export class MessageBoxModalComponent {
11
- constructor(dialogRef, sanitizer, data) {
12
- this.dialogRef = dialogRef;
13
- this.sanitizer = sanitizer;
14
- this.data = data;
15
- this.buttons = [];
16
- this.hideCloseButton = false;
17
- this.processing = null;
18
- if (data.message) {
19
- this.message = this.sanitizer.bypassSecurityTrustHtml(data.message);
20
- }
21
- if (this.data.options.template) {
22
- this.template = this.data.options.template;
23
- }
24
- if (this.data.options.errorMessage) {
25
- this.errorMessage = this.sanitizer.bypassSecurityTrustHtml(data.options.errorMessage);
26
- }
27
- if (this.data.options.errorDetail) {
28
- this.errorDetail = this.sanitizer.bypassSecurityTrustHtml(data.options.errorDetail);
29
- }
30
- if (this.data.options.hideCloseButton !== undefined) {
31
- this.hideCloseButton = this.data.options.hideCloseButton;
32
- }
33
- this.buttons = data.options.buttons ? data.options.buttons : [{ id: 'close', text: 'Close' }];
34
- this.title = data.options.title;
35
- }
36
- close(result) {
37
- this.dialogRef.close(result);
38
- }
39
- buttonClick(b) {
40
- if (b.process) {
41
- this.processing = b;
42
- b.process().then(r => {
43
- this.close(r);
44
- }).catch(e => {
45
- this.processing = null;
46
- });
47
- }
48
- else {
49
- this.close(b.id);
50
- }
51
- }
52
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: MessageBoxModalComponent, deps: [{ token: i1.MatDialogRef }, { token: i2.DomSanitizer }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component }); }
53
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.1", type: MessageBoxModalComponent, selector: "ui-message-box-modal", ngImport: i0, template: `
54
- <ui-dialog [title]="title" [hideCloseButton]="hideCloseButton">
55
- <div mat-dialog-content *ngIf="message" style="padding: 7px 16px 12px 16px;">
56
- <div [innerHTML]="message" style="line-height: 24px;"></div>
57
- <pre *ngIf="errorMessage" [innerHTML]="errorMessage"></pre>
58
- <pre *ngIf="errorDetail" [innerHTML]="errorDetail"></pre>
59
- </div>
60
-
61
- <div mat-dialog-content *ngIf="template" style="padding: 7px 16px 12px 16px;">
62
- <ng-template [ngTemplateOutlet]="template"></ng-template>
63
- </div>
64
-
65
- <div mat-dialog-actions>
66
- <div class="buttons">
67
- <ui-button *ngFor="let b of buttons" [color]="b.color || 'primary'" [tabIndex]="-1"
68
- [kind]="b.kind || 'stroked'" [busy]="processing === b" [disabled]="!!processing || (b.disabled && b.disabled())" (click)="buttonClick(b)" [label]="b.text"></ui-button>
69
- </div>
70
- </div>
71
- </ui-dialog>
72
- `, isInline: true, dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "component", type: i4.ButtonComponent, selector: "ui-button", inputs: ["type", "matIconPrefix", "label", "disabled", "busy", "kind", "color", "size", "formInvalid"] }, { kind: "component", type: i5.DialogComponent, selector: "ui-dialog", inputs: ["title", "draggable", "hideCloseButton", "close"] }] }); }
73
- }
74
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: MessageBoxModalComponent, decorators: [{
75
- type: Component,
76
- args: [{
77
- selector: 'ui-message-box-modal',
78
- template: `
79
- <ui-dialog [title]="title" [hideCloseButton]="hideCloseButton">
80
- <div mat-dialog-content *ngIf="message" style="padding: 7px 16px 12px 16px;">
81
- <div [innerHTML]="message" style="line-height: 24px;"></div>
82
- <pre *ngIf="errorMessage" [innerHTML]="errorMessage"></pre>
83
- <pre *ngIf="errorDetail" [innerHTML]="errorDetail"></pre>
84
- </div>
85
-
86
- <div mat-dialog-content *ngIf="template" style="padding: 7px 16px 12px 16px;">
87
- <ng-template [ngTemplateOutlet]="template"></ng-template>
88
- </div>
89
-
90
- <div mat-dialog-actions>
91
- <div class="buttons">
92
- <ui-button *ngFor="let b of buttons" [color]="b.color || 'primary'" [tabIndex]="-1"
93
- [kind]="b.kind || 'stroked'" [busy]="processing === b" [disabled]="!!processing || (b.disabled && b.disabled())" (click)="buttonClick(b)" [label]="b.text"></ui-button>
94
- </div>
95
- </div>
96
- </ui-dialog>
97
- `
98
- }]
99
- }], ctorParameters: () => [{ type: i1.MatDialogRef }, { type: i2.DomSanitizer }, { type: undefined, decorators: [{
100
- type: Inject,
101
- args: [MAT_DIALOG_DATA]
102
- }] }] });
103
- export class MessageBoxService {
104
- constructor(dialog, translateService) {
105
- this.dialog = dialog;
106
- this.translateService = translateService;
107
- }
108
- confirm(message, options = {}) {
109
- const config = new MatDialogConfig();
110
- config.disableClose = false;
111
- config.minWidth = '340px';
112
- config.maxWidth = options.maxWidth || '600px';
113
- config.width = '40vw';
114
- config.data = { message, options };
115
- return this.dialog.open(MessageBoxModalComponent, config).afterClosed();
116
- }
117
- open(options = {}) {
118
- const config = new MatDialogConfig();
119
- config.disableClose = true;
120
- config.minWidth = '340px';
121
- config.maxWidth = options.maxWidth || '600px';
122
- config.width = '40vw';
123
- config.data = { message: options.message, options };
124
- return this.dialog.open(MessageBoxModalComponent, config).afterClosed();
125
- }
126
- confirmDelete(title, message) {
127
- const options = {
128
- title,
129
- buttons: [
130
- { id: 'cancel', text: this.translateService.instant('ui.messagebox.button.cancel') },
131
- { id: 'delete', text: this.translateService.instant('ui.messagebox.button.delete'), color: 'warn', kind: 'flat' }
132
- ]
133
- };
134
- // @ts-ignore
135
- return this.confirm(message, options);
136
- }
137
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: MessageBoxService, deps: [{ token: i1.MatDialog }, { token: UI_TRANSLATESERVICE }], target: i0.ɵɵFactoryTarget.Injectable }); }
138
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: MessageBoxService, providedIn: 'root' }); }
139
- }
140
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: MessageBoxService, decorators: [{
141
- type: Injectable,
142
- args: [{
143
- providedIn: 'root'
144
- }]
145
- }], ctorParameters: () => [{ type: i1.MatDialog }, { type: undefined, decorators: [{
146
- type: Inject,
147
- args: [UI_TRANSLATESERVICE]
148
- }] }] });
149
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"message-box.service.js","sourceRoot":"","sources":["../../../../../projects/ui/src/lib/services/message-box.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject, Injectable, TemplateRef } from '@angular/core';\r\nimport {DomSanitizer} from '@angular/platform-browser';\r\nimport { MAT_DIALOG_DATA, MatDialog, MatDialogConfig, MatDialogRef } from '@angular/material/dialog';\r\nimport { Observable } from 'rxjs';\r\nimport { IUiTranslateService, UI_TRANSLATESERVICE } from './ui-translate.service';\r\n\r\nexport interface MessageBoxButton {\r\n  id: string;\r\n  text: string;\r\n  kind?: 'basic' | 'flat' | 'stroked';\r\n  color?: 'primary' | 'accent' | 'warn';\r\n  process?: () => Promise<any>;\r\n  disabled?: () => boolean;\r\n}\r\n\r\n@Component({\r\n  selector: 'ui-message-box-modal',\r\n  template: `\r\n    <ui-dialog [title]=\"title\" [hideCloseButton]=\"hideCloseButton\">\r\n      <div mat-dialog-content *ngIf=\"message\" style=\"padding: 7px 16px 12px 16px;\">\r\n        <div [innerHTML]=\"message\" style=\"line-height: 24px;\"></div>\r\n        <pre *ngIf=\"errorMessage\" [innerHTML]=\"errorMessage\"></pre>\r\n        <pre *ngIf=\"errorDetail\" [innerHTML]=\"errorDetail\"></pre>\r\n      </div>\r\n      \r\n      <div mat-dialog-content *ngIf=\"template\" style=\"padding: 7px 16px 12px 16px;\">\r\n        <ng-template [ngTemplateOutlet]=\"template\"></ng-template>\r\n      </div>\r\n\r\n      <div mat-dialog-actions>\r\n        <div class=\"buttons\">\r\n          <ui-button *ngFor=\"let b of buttons\" [color]=\"b.color || 'primary'\" [tabIndex]=\"-1\"\r\n                      [kind]=\"b.kind || 'stroked'\" [busy]=\"processing === b\" [disabled]=\"!!processing || (b.disabled && b.disabled())\" (click)=\"buttonClick(b)\" [label]=\"b.text\"></ui-button>\r\n        </div>\r\n      </div>\r\n    </ui-dialog>\r\n  `\r\n})\r\nexport class MessageBoxModalComponent {\r\n\r\n  message;\r\n  errorMessage;\r\n  errorDetail;\r\n  buttons: MessageBoxButton[] = [];\r\n  title: string;\r\n  template: any;\r\n  hideCloseButton = false;\r\n  processing: MessageBoxButton = null;\r\n\r\n  constructor(public dialogRef: MatDialogRef<MessageBoxModalComponent>,\r\n              public sanitizer: DomSanitizer,\r\n              @Inject(MAT_DIALOG_DATA) private data: any) {\r\n\r\n    if (data.message) {\r\n      this.message = this.sanitizer.bypassSecurityTrustHtml(data.message);\r\n    }\r\n\r\n    if (this.data.options.template) {\r\n      this.template = this.data.options.template;\r\n    }\r\n\r\n    if (this.data.options.errorMessage) {\r\n      this.errorMessage = this.sanitizer.bypassSecurityTrustHtml(data.options.errorMessage);\r\n    }\r\n    if (this.data.options.errorDetail) {\r\n      this.errorDetail = this.sanitizer.bypassSecurityTrustHtml(data.options.errorDetail);\r\n    }\r\n    if (this.data.options.hideCloseButton !== undefined) {\r\n      this.hideCloseButton = this.data.options.hideCloseButton;\r\n    }\r\n\r\n    this.buttons = data.options.buttons ? data.options.buttons : [{id: 'close', text: 'Close'}];\r\n    this.title = data.options.title;\r\n  }\r\n\r\n  close(result: any): void {\r\n    this.dialogRef.close(result);\r\n  }\r\n\r\n  buttonClick(b: MessageBoxButton) {\r\n    if (b.process) {\r\n      this.processing = b;\r\n      b.process().then(r => {\r\n        this.close(r);\r\n      }).catch(e => {\r\n        this.processing = null;\r\n      })\r\n    } else {\r\n      this.close(b.id);\r\n    }\r\n  }\r\n}\r\n\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class MessageBoxService {\r\n\r\n  constructor(private dialog: MatDialog,\r\n              @Inject(UI_TRANSLATESERVICE) public translateService: IUiTranslateService) {\r\n  }\r\n\r\n  confirm(message: string, options: {\r\n    buttons?: MessageBoxButton[],\r\n    title?: string,\r\n    errorMessage?: string,\r\n    errorDetail?: string,\r\n    hideCloseButton?: boolean,\r\n    maxWidth?: string\r\n  } = {}): Observable<any> {\r\n    const config = new MatDialogConfig();\r\n    config.disableClose = false;\r\n    config.minWidth = '340px';\r\n    config.maxWidth = options.maxWidth || '600px';\r\n    config.width = '40vw';\r\n    config.data = {message, options};\r\n\r\n    return this.dialog.open(MessageBoxModalComponent, config).afterClosed();\r\n  }\r\n\r\n  open(options: {\r\n    buttons?: MessageBoxButton[],\r\n    title?: string,\r\n    errorMessage?: string,\r\n    errorDetail?: string,\r\n    hideCloseButton?: boolean,\r\n    maxWidth?: string,\r\n    message?: string,\r\n    template?: TemplateRef<any>\r\n  } = {}): Observable<any> {\r\n    const config = new MatDialogConfig();\r\n    config.disableClose = true;\r\n    config.minWidth = '340px';\r\n    config.maxWidth = options.maxWidth || '600px';\r\n    config.width = '40vw';\r\n    config.data = {message: options.message, options};\r\n\r\n    return this.dialog.open(MessageBoxModalComponent, config).afterClosed();\r\n  }\r\n\r\n  confirmDelete(title: string, message: string): Observable<any> {\r\n    const options = {\r\n      title,\r\n      buttons: [\r\n        { id: 'cancel', text: this.translateService.instant('ui.messagebox.button.cancel') },\r\n        { id: 'delete', text: this.translateService.instant('ui.messagebox.button.delete'), color: 'warn', kind: 'flat' }\r\n      ]\r\n    };\r\n    // @ts-ignore\r\n    return this.confirm(message, options);\r\n  }\r\n\r\n\r\n}\r\n"]}
@@ -1,23 +0,0 @@
1
- import { Injectable } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- import * as i1 from "@angular/material/snack-bar";
4
- export class ToastService {
5
- constructor(snackService) {
6
- this.snackService = snackService;
7
- }
8
- open(message, options = { duration: 2500, type: 'info' }) {
9
- this.snackService.open(message, null, {
10
- duration: options.duration || 2500,
11
- panelClass: [options.type || 'message']
12
- });
13
- }
14
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: ToastService, deps: [{ token: i1.MatSnackBar }], target: i0.ɵɵFactoryTarget.Injectable }); }
15
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: ToastService, providedIn: 'root' }); }
16
- }
17
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: ToastService, decorators: [{
18
- type: Injectable,
19
- args: [{
20
- providedIn: 'root'
21
- }]
22
- }], ctorParameters: () => [{ type: i1.MatSnackBar }] });
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9hc3Quc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpL3NyYy9saWIvc2VydmljZXMvdG9hc3Quc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFRM0MsTUFBTSxPQUFPLFlBQVk7SUFFdkIsWUFBb0IsWUFBeUI7UUFBekIsaUJBQVksR0FBWixZQUFZLENBQWE7SUFBSSxDQUFDO0lBRTNDLElBQUksQ0FBQyxPQUFlLEVBQUUsVUFBbUQsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUM7UUFDN0csSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLElBQUksRUFBRTtZQUNwQyxRQUFRLEVBQUUsT0FBTyxDQUFDLFFBQVEsSUFBSSxJQUFJO1lBQ2xDLFVBQVUsRUFBRSxDQUFFLE9BQU8sQ0FBQyxJQUFJLElBQUksU0FBUyxDQUFDO1NBQ3pDLENBQUMsQ0FBQztJQUNMLENBQUM7OEdBVFUsWUFBWTtrSEFBWixZQUFZLGNBRlgsTUFBTTs7MkZBRVAsWUFBWTtrQkFIeEIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE1hdFNuYWNrQmFyIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc25hY2stYmFyJztcclxuXHJcbmV4cG9ydCB0eXBlIFRvYXN0VHlwZSA9ICdpbmZvJyB8ICdzdWNjZXNzJyB8ICd3YXJuaW5nJyB8ICdmYWlsJztcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICBwcm92aWRlZEluOiAncm9vdCdcclxufSlcclxuZXhwb3J0IGNsYXNzIFRvYXN0U2VydmljZSB7XHJcblxyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgc25hY2tTZXJ2aWNlOiBNYXRTbmFja0JhcikgeyB9XHJcblxyXG4gIHB1YmxpYyBvcGVuKG1lc3NhZ2U6IHN0cmluZywgb3B0aW9uczogeyBkdXJhdGlvbj86IG51bWJlciwgdHlwZT86IFRvYXN0VHlwZSB9ID0geyBkdXJhdGlvbjogMjUwMCwgdHlwZTogJ2luZm8nfSkge1xyXG4gICAgdGhpcy5zbmFja1NlcnZpY2Uub3BlbihtZXNzYWdlLCBudWxsLCB7XHJcbiAgICAgIGR1cmF0aW9uOiBvcHRpb25zLmR1cmF0aW9uIHx8IDI1MDAsXHJcbiAgICAgIHBhbmVsQ2xhc3M6IFsgb3B0aW9ucy50eXBlIHx8ICdtZXNzYWdlJ11cclxuICAgIH0pO1xyXG4gIH1cclxufVxyXG4iXX0=
@@ -1,72 +0,0 @@
1
- import { EventEmitter, Inject, Injectable, InjectionToken, Optional } from '@angular/core';
2
- import { Subject } from 'rxjs';
3
- import * as i0 from "@angular/core";
4
- export const UI_FILESERVICE = new InjectionToken('IUiFileService');
5
- // export const FileServiceConfigService = new InjectionToken<FileServiceConfig>('FileServiceConfig');
6
- export class UiFileService {
7
- constructor(fileServiceConfig) {
8
- this.fileServiceConfig = fileServiceConfig;
9
- this.uploadInput = new EventEmitter();
10
- this.uploadSubscription = new Subject();
11
- this.filesToRemove = [];
12
- this.controls = new Set();
13
- this.uploadSubscription.subscribe((v) => {
14
- switch (v.action) {
15
- case 'register':
16
- this.controls.add(v.data);
17
- return;
18
- case 'destroy':
19
- this.controls.delete(v.data);
20
- return;
21
- case 'uploadStarted':
22
- let cnt = 0;
23
- this.controls.forEach(c => cnt += c.hasFilesToUpload ? 1 : 0);
24
- if (cnt === 0) {
25
- this.uploadSubscription.next({ action: 'uploadSuccess' });
26
- }
27
- break;
28
- case 'uploadControlFailed':
29
- case 'uploadControlSuccess':
30
- let cnt2 = 0;
31
- this.controls.forEach(c => cnt2 += c.hasFilesToUpload ? 1 : 0);
32
- if (cnt2 === 0) {
33
- this.uploadSubscription.next({ action: v.action === 'uploadControlFailed' ? 'uploadFailed' : 'uploadSuccess' });
34
- }
35
- break;
36
- }
37
- });
38
- }
39
- upload() {
40
- const promises = [];
41
- this.controls.forEach(c => promises.push(c.beforeSave()));
42
- return new Promise((res) => {
43
- this.uploadSubscription.subscribe((v) => {
44
- if (v.action === 'uploadSuccess' || v.action === 'uploadFailed') {
45
- res(v.action);
46
- }
47
- });
48
- this.uploadSubscription.next({ action: 'uploadStarted' });
49
- Promise.all(promises).then((r) => {
50
- console.log(r);
51
- const event = {
52
- type: 'uploadAll',
53
- url: this.fileServiceConfig.uploadUrl(),
54
- method: 'POST',
55
- headers: this.fileServiceConfig.getAuthHeader()
56
- };
57
- this.uploadInput.emit(event);
58
- });
59
- });
60
- }
61
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: UiFileService, deps: [{ token: UI_FILESERVICE, optional: true }], target: i0.ɵɵFactoryTarget.Injectable }); }
62
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: UiFileService }); }
63
- }
64
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: UiFileService, decorators: [{
65
- type: Injectable
66
- }], ctorParameters: () => [{ type: undefined, decorators: [{
67
- type: Optional
68
- }, {
69
- type: Inject,
70
- args: [UI_FILESERVICE]
71
- }] }] });
72
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-file.service.js","sourceRoot":"","sources":["../../../../../projects/ui/src/lib/services/ui-file.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter, Inject, Injectable, InjectionToken, Optional } from '@angular/core';\r\nimport { UploadFile, UploadInput } from 'ngx-uploader';\r\nimport { Subject } from 'rxjs';\r\n// import { UiFileUploaderComponent } from '../file-uploader/ui-file-uploader.component';\r\n\r\n// export interface IGetAuthHeader {\r\n//   getAuthHeader: () => { [key: string]: string };\r\n// }\r\n\r\nexport interface IUiFileSize {\r\n  name: string,\r\n  width: number,\r\n  height: number,\r\n  limit?: 'fit' | 'maxWidth' | 'maxHeight'\r\n}\r\n\r\nexport type IUiFileServiceMessages = 'cropInvalidFileType' | 'extensionNotAllowed' | 'fileAdded' | 'fileRemoved';\r\n\r\nexport interface IUiFileService {\r\n  getAuthHeader: () => { [ key: string ]: string },\r\n  uploadUrl: (size?: IUiFileSize) => string;\r\n  // // upload64Url: string;\r\n  getMediaSrc: (size: IUiFileSize, data: any, options: any) => string,\r\n  getPreviewUrl: (size: IUiFileSize, data: any) => string,\r\n  addFileImgSrc: (size: IUiFileSize) => string,\r\n  getMimeType: (data: any) => string;\r\n  imageSizes: IUiFileSize[];\r\n  concurrentUploads: number,\r\n  useRetinaSrc: boolean,\r\n\r\n  fileValidation?: (size: IUiFileSize, file: UploadFile) => Promise<boolean>\r\n}\r\n\r\nexport const UI_FILESERVICE = new InjectionToken<IUiFileService>('IUiFileService');\r\n\r\n// export const FileServiceConfigService = new InjectionToken<FileServiceConfig>('FileServiceConfig');\r\n\r\n@Injectable()\r\nexport class UiFileService {\r\n\r\n  uploadInput: EventEmitter<UploadInput> = new EventEmitter<UploadInput>();\r\n\r\n  uploadSubscription = new Subject();\r\n\r\n  filesToRemove: string[] = [];\r\n  controls = new Set<any>();\r\n\r\n  constructor(@Optional() @Inject(UI_FILESERVICE) public fileServiceConfig: IUiFileService) {\r\n    this.uploadSubscription.subscribe((v: any) => {\r\n      switch (v.action) {\r\n        case 'register': this.controls.add(v.data); return;\r\n        case 'destroy': this.controls.delete(v.data); return;\r\n\r\n        case 'uploadStarted':\r\n          let cnt = 0;\r\n          this.controls.forEach(c => cnt += c.hasFilesToUpload ? 1 : 0);\r\n          if (cnt === 0) {\r\n            this.uploadSubscription.next({action: 'uploadSuccess'});\r\n          }\r\n          break;\r\n\r\n        case 'uploadControlFailed':\r\n        case 'uploadControlSuccess':\r\n          let cnt2 = 0;\r\n          this.controls.forEach(c => cnt2 += c.hasFilesToUpload ? 1 : 0);\r\n          if (cnt2 === 0) {\r\n            this.uploadSubscription.next({action: v.action === 'uploadControlFailed' ? 'uploadFailed' : 'uploadSuccess'});\r\n          }\r\n          break;\r\n      }\r\n    });\r\n  }\r\n\r\n  public upload(): Promise<'uploadSuccess' | 'uploadFailed'> {\r\n    const promises = [];\r\n    this.controls.forEach(c => promises.push(c.beforeSave()));\r\n\r\n    return new Promise<'uploadSuccess' | 'uploadFailed'>((res) => {\r\n\r\n      this.uploadSubscription.subscribe((v: any) => {\r\n        if (v.action === 'uploadSuccess' || v.action === 'uploadFailed') {\r\n          res(v.action);\r\n        }\r\n      });\r\n\r\n      this.uploadSubscription.next({action: 'uploadStarted'});\r\n\r\n      Promise.all(promises).then((r) => {\r\n        console.log(r);\r\n\r\n        const event: UploadInput = {\r\n          type: 'uploadAll',\r\n          url: this.fileServiceConfig.uploadUrl(),\r\n          method: 'POST',\r\n          headers: this.fileServiceConfig.getAuthHeader()\r\n        };\r\n\r\n        this.uploadInput.emit(event);\r\n\r\n      })\r\n    });\r\n  }\r\n}\r\n"]}
@@ -1,32 +0,0 @@
1
- import { Injectable, InjectionToken } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- export const UI_TRANSLATESERVICE = new InjectionToken('IUiTranslateServiceToken');
4
- export class UiTranslateService {
5
- instant(code, data) {
6
- switch (code) {
7
- case 'ui.controls.ui-file-uploader.menu.change': return 'Změnit';
8
- case 'ui.controls.ui-file-uploader.menu.delete': return 'Smazat';
9
- case 'ui.controls.ui-file-uploader.uploadError': return 'Chyba při ukládání souboru';
10
- case 'ui.controls.validation.required': return 'Povinná položka';
11
- case 'ui.controls.validation.email': return 'Neplatný email';
12
- case 'ui.controls.validation.matDatepickerParse': return 'Neplatné datum';
13
- case 'ui.controls.validation.maxlength': return 'Zadej maximálně ' + data.requiredLength + ' znaků';
14
- case 'ui.controls.validation.minlength': return 'Zadej minimálně ' + data.requiredLength + ' znaků';
15
- case 'ui.controls.validation.invalidNumber': return 'Neplatné číslo';
16
- case 'ui.controls.validation.positive': return 'Musí být větší než 0';
17
- case 'ui.controls.validation.cbGroupRequired': return 'Zaškrtni alespoň jednu položku';
18
- case 'ui.controls.ui-select.clear-selection': return 'Zrušit výběr';
19
- case 'ui.controls.ui-select.all': return 'Vše';
20
- case 'ui.controls.ui-select.apply-selection': return 'Použít výběr';
21
- case 'ui.messagebox.button.cancel': return 'Zrušit';
22
- case 'ui.messagebox.button.delete': return 'Smazat';
23
- default: return code;
24
- }
25
- }
26
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: UiTranslateService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
27
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: UiTranslateService }); }
28
- }
29
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: UiTranslateService, decorators: [{
30
- type: Injectable
31
- }] });
32
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWktdHJhbnNsYXRlLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL3NlcnZpY2VzL3VpLXRyYW5zbGF0ZS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsY0FBYyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQU0zRCxNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBRyxJQUFJLGNBQWMsQ0FBc0IsMEJBQTBCLENBQUMsQ0FBQztBQUd2RyxNQUFNLE9BQU8sa0JBQWtCO0lBQzdCLE9BQU8sQ0FBQyxJQUFZLEVBQUUsSUFBUztRQUM3QixRQUFRLElBQUksRUFBRSxDQUFDO1lBQ2IsS0FBSywwQ0FBMEMsQ0FBQyxDQUFDLE9BQU8sUUFBUSxDQUFDO1lBQ2pFLEtBQUssMENBQTBDLENBQUMsQ0FBQyxPQUFPLFFBQVEsQ0FBQztZQUNqRSxLQUFLLDBDQUEwQyxDQUFDLENBQUMsT0FBTyw0QkFBNEIsQ0FBQztZQUNyRixLQUFLLGlDQUFpQyxDQUFDLENBQUMsT0FBTyxpQkFBaUIsQ0FBQztZQUNqRSxLQUFLLDhCQUE4QixDQUFDLENBQUMsT0FBTyxnQkFBZ0IsQ0FBQztZQUM3RCxLQUFLLDJDQUEyQyxDQUFDLENBQUMsT0FBTyxnQkFBZ0IsQ0FBQztZQUMxRSxLQUFLLGtDQUFrQyxDQUFDLENBQUMsT0FBTyxrQkFBa0IsR0FBRyxJQUFJLENBQUMsY0FBYyxHQUFHLFFBQVEsQ0FBQztZQUNwRyxLQUFLLGtDQUFrQyxDQUFDLENBQUMsT0FBTyxrQkFBa0IsR0FBRyxJQUFJLENBQUMsY0FBYyxHQUFHLFFBQVEsQ0FBQztZQUNwRyxLQUFLLHNDQUFzQyxDQUFDLENBQUMsT0FBTyxnQkFBZ0IsQ0FBQztZQUNyRSxLQUFLLGlDQUFpQyxDQUFDLENBQUMsT0FBTyxzQkFBc0IsQ0FBQztZQUN0RSxLQUFLLHdDQUF3QyxDQUFDLENBQUMsT0FBTyxnQ0FBZ0MsQ0FBQztZQUN2RixLQUFLLHVDQUF1QyxDQUFDLENBQUMsT0FBTyxjQUFjLENBQUM7WUFDcEUsS0FBSywyQkFBMkIsQ0FBQyxDQUFDLE9BQU8sS0FBSyxDQUFDO1lBQy9DLEtBQUssdUNBQXVDLENBQUMsQ0FBQyxPQUFPLGNBQWMsQ0FBQztZQUNwRSxLQUFLLDZCQUE2QixDQUFDLENBQUMsT0FBTyxRQUFRLENBQUM7WUFDcEQsS0FBSyw2QkFBNkIsQ0FBQyxDQUFDLE9BQU8sUUFBUSxDQUFDO1lBQ3BELE9BQU8sQ0FBQyxDQUFDLE9BQU8sSUFBSSxDQUFDO1FBQ3ZCLENBQUM7SUFDSCxDQUFDOzhHQXJCVSxrQkFBa0I7a0hBQWxCLGtCQUFrQjs7MkZBQWxCLGtCQUFrQjtrQkFEOUIsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUsIEluamVjdGlvblRva2VuIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIElVaVRyYW5zbGF0ZVNlcnZpY2Uge1xyXG4gIGluc3RhbnQ6IChjb2RlOiBzdHJpbmcsIGRhdGE/OiBhbnkpID0+IHN0cmluZztcclxufVxyXG5cclxuZXhwb3J0IGNvbnN0IFVJX1RSQU5TTEFURVNFUlZJQ0UgPSBuZXcgSW5qZWN0aW9uVG9rZW48SVVpVHJhbnNsYXRlU2VydmljZT4oJ0lVaVRyYW5zbGF0ZVNlcnZpY2VUb2tlbicpO1xyXG5cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgVWlUcmFuc2xhdGVTZXJ2aWNlIGltcGxlbWVudHMgSVVpVHJhbnNsYXRlU2VydmljZSB7XHJcbiAgaW5zdGFudChjb2RlOiBzdHJpbmcsIGRhdGE6IGFueSk6IHN0cmluZyB7XHJcbiAgICBzd2l0Y2ggKGNvZGUpIHtcclxuICAgICAgY2FzZSAndWkuY29udHJvbHMudWktZmlsZS11cGxvYWRlci5tZW51LmNoYW5nZSc6IHJldHVybiAnWm3Em25pdCc7XHJcbiAgICAgIGNhc2UgJ3VpLmNvbnRyb2xzLnVpLWZpbGUtdXBsb2FkZXIubWVudS5kZWxldGUnOiByZXR1cm4gJ1NtYXphdCc7XHJcbiAgICAgIGNhc2UgJ3VpLmNvbnRyb2xzLnVpLWZpbGUtdXBsb2FkZXIudXBsb2FkRXJyb3InOiByZXR1cm4gJ0NoeWJhIHDFmWkgdWtsw6Fkw6Fuw60gc291Ym9ydSc7XHJcbiAgICAgIGNhc2UgJ3VpLmNvbnRyb2xzLnZhbGlkYXRpb24ucmVxdWlyZWQnOiByZXR1cm4gJ1BvdmlubsOhIHBvbG/FvmthJztcclxuICAgICAgY2FzZSAndWkuY29udHJvbHMudmFsaWRhdGlvbi5lbWFpbCc6IHJldHVybiAnTmVwbGF0bsO9IGVtYWlsJztcclxuICAgICAgY2FzZSAndWkuY29udHJvbHMudmFsaWRhdGlvbi5tYXREYXRlcGlja2VyUGFyc2UnOiByZXR1cm4gJ05lcGxhdG7DqSBkYXR1bSc7XHJcbiAgICAgIGNhc2UgJ3VpLmNvbnRyb2xzLnZhbGlkYXRpb24ubWF4bGVuZ3RoJzogcmV0dXJuICdaYWRlaiBtYXhpbcOhbG7EmyAnICsgZGF0YS5yZXF1aXJlZExlbmd0aCArICcgem5ha8WvJztcclxuICAgICAgY2FzZSAndWkuY29udHJvbHMudmFsaWRhdGlvbi5taW5sZW5ndGgnOiByZXR1cm4gJ1phZGVqIG1pbmltw6FsbsSbICcgKyBkYXRhLnJlcXVpcmVkTGVuZ3RoICsgJyB6bmFrxa8nO1xyXG4gICAgICBjYXNlICd1aS5jb250cm9scy52YWxpZGF0aW9uLmludmFsaWROdW1iZXInOiByZXR1cm4gJ05lcGxhdG7DqSDEjcOtc2xvJztcclxuICAgICAgY2FzZSAndWkuY29udHJvbHMudmFsaWRhdGlvbi5wb3NpdGl2ZSc6IHJldHVybiAnTXVzw60gYsO9dCB2xJt0xaHDrSBuZcW+IDAnO1xyXG4gICAgICBjYXNlICd1aS5jb250cm9scy52YWxpZGF0aW9uLmNiR3JvdXBSZXF1aXJlZCc6IHJldHVybiAnWmHFoWtydG5pIGFsZXNwb8WIIGplZG51IHBvbG/Fvmt1JztcclxuICAgICAgY2FzZSAndWkuY29udHJvbHMudWktc2VsZWN0LmNsZWFyLXNlbGVjdGlvbic6IHJldHVybiAnWnJ1xaFpdCB2w71ixJtyJztcclxuICAgICAgY2FzZSAndWkuY29udHJvbHMudWktc2VsZWN0LmFsbCc6IHJldHVybiAnVsWhZSc7XHJcbiAgICAgIGNhc2UgJ3VpLmNvbnRyb2xzLnVpLXNlbGVjdC5hcHBseS1zZWxlY3Rpb24nOiByZXR1cm4gJ1BvdcW+w610IHbDvWLEm3InO1xyXG4gICAgICBjYXNlICd1aS5tZXNzYWdlYm94LmJ1dHRvbi5jYW5jZWwnOiByZXR1cm4gJ1pydcWhaXQnO1xyXG4gICAgICBjYXNlICd1aS5tZXNzYWdlYm94LmJ1dHRvbi5kZWxldGUnOiByZXR1cm4gJ1NtYXphdCc7XHJcbiAgICAgIGRlZmF1bHQ6IHJldHVybiBjb2RlO1xyXG4gICAgfVxyXG4gIH1cclxufVxyXG4iXX0=
@@ -1,72 +0,0 @@
1
- import { Component, Host, HostBinding, Input, Optional, SkipSelf } from '@angular/core';
2
- import { UntypedFormGroup } from '@angular/forms';
3
- import * as i0 from "@angular/core";
4
- import * as i1 from "@angular/material/dialog";
5
- import * as i2 from "@angular/forms";
6
- import * as i3 from "@angular/common";
7
- import * as i4 from "../button/button.component";
8
- export class SubmitButtonComponent {
9
- constructor(dialogRef, controlContainer) {
10
- this.dialogRef = dialogRef;
11
- this.controlContainer = controlContainer;
12
- this.busy = false;
13
- this.disabled = false;
14
- this.formGroups = [];
15
- this.label = 'Save';
16
- this.prependCloseButton = true;
17
- }
18
- ngOnInit() {
19
- if (this.formInvalid === undefined) {
20
- if (this.formGroups === undefined && this.controlContainer && this.controlContainer.control instanceof UntypedFormGroup) {
21
- this.formGroups = this.controlContainer.control;
22
- }
23
- if (!Array.isArray(this.formGroups)) {
24
- this.formGroups = [this.formGroups];
25
- }
26
- }
27
- }
28
- get formsValid() {
29
- if (this.formInvalid !== undefined) {
30
- return !this.formInvalid;
31
- }
32
- else {
33
- return !this.formGroups.find(f => f.invalid);
34
- }
35
- }
36
- doSubmit() {
37
- this.formGroups.forEach(f => f.markAllAsTouched());
38
- if (this.formsValid && this.submit) {
39
- this.submit();
40
- }
41
- }
42
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: SubmitButtonComponent, deps: [{ token: i1.MatDialogRef }, { token: i2.ControlContainer, host: true, optional: true, skipSelf: true }], target: i0.ɵɵFactoryTarget.Component }); }
43
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.1", type: SubmitButtonComponent, selector: "ui-submit-button", inputs: { busy: "busy", disabled: "disabled", formGroups: "formGroups", label: "label", submit: "submit", formInvalid: "formInvalid", prependCloseButton: "prependCloseButton" }, host: { properties: { "class.with-close": "this.prependCloseButton" } }, ngImport: i0, template: "<ui-button *ngIf=\"prependCloseButton\" [label]=\"'Close'\" (click)=\"dialogRef.close()\"></ui-button>\r\n\r\n<ui-button [busy]=\"busy\"\r\n [disabled]=\"disabled || busy\" [type]=\"'submit'\"\r\n [formInvalid]=\"!formsValid\"\r\n [label]=\"label\" (click)=\"doSubmit()\"></ui-button>\r\n", styles: [":host.with-close{display:flex;justify-content:flex-end;width:100%;margin-left:0!important}:host.with-close ui-button{margin-left:12px}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.ButtonComponent, selector: "ui-button", inputs: ["type", "matIconPrefix", "label", "disabled", "busy", "kind", "color", "size", "formInvalid"] }] }); }
44
- }
45
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: SubmitButtonComponent, decorators: [{
46
- type: Component,
47
- args: [{ selector: 'ui-submit-button', template: "<ui-button *ngIf=\"prependCloseButton\" [label]=\"'Close'\" (click)=\"dialogRef.close()\"></ui-button>\r\n\r\n<ui-button [busy]=\"busy\"\r\n [disabled]=\"disabled || busy\" [type]=\"'submit'\"\r\n [formInvalid]=\"!formsValid\"\r\n [label]=\"label\" (click)=\"doSubmit()\"></ui-button>\r\n", styles: [":host.with-close{display:flex;justify-content:flex-end;width:100%;margin-left:0!important}:host.with-close ui-button{margin-left:12px}\n"] }]
48
- }], ctorParameters: () => [{ type: i1.MatDialogRef }, { type: i2.ControlContainer, decorators: [{
49
- type: Optional
50
- }, {
51
- type: Host
52
- }, {
53
- type: SkipSelf
54
- }] }], propDecorators: { busy: [{
55
- type: Input
56
- }], disabled: [{
57
- type: Input
58
- }], formGroups: [{
59
- type: Input
60
- }], label: [{
61
- type: Input
62
- }], submit: [{
63
- type: Input
64
- }], formInvalid: [{
65
- type: Input
66
- }], prependCloseButton: [{
67
- type: HostBinding,
68
- args: ['class.with-close']
69
- }, {
70
- type: Input
71
- }] } });
72
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3VibWl0LWJ1dHRvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL3N1Ym1pdC1idXR0b24vc3VibWl0LWJ1dHRvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL3N1Ym1pdC1idXR0b24vc3VibWl0LWJ1dHRvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLElBQUksRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFVLFFBQVEsRUFBRSxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDOUYsT0FBTyxFQUFtQixnQkFBZ0IsRUFBQyxNQUFNLGdCQUFnQixDQUFDOzs7Ozs7QUFRbEUsTUFBTSxPQUFPLHFCQUFxQjtJQVloQyxZQUFtQixTQUE0QixFQUV6QixnQkFBa0M7UUFGckMsY0FBUyxHQUFULFNBQVMsQ0FBbUI7UUFFekIscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFrQjtRQVovQyxTQUFJLEdBQUcsS0FBSyxDQUFDO1FBQ2IsYUFBUSxHQUFHLEtBQUssQ0FBQztRQUNqQixlQUFVLEdBQTBDLEVBQUUsQ0FBQztRQUN2RCxVQUFLLEdBQUcsTUFBTSxDQUFDO1FBS2YsdUJBQWtCLEdBQUcsSUFBSSxDQUFDO0lBSXlCLENBQUM7SUFFN0QsUUFBUTtRQUNOLElBQUksSUFBSSxDQUFDLFdBQVcsS0FBSyxTQUFTLEVBQUUsQ0FBQztZQUNuQyxJQUFJLElBQUksQ0FBQyxVQUFVLEtBQUssU0FBUyxJQUFJLElBQUksQ0FBQyxnQkFBZ0IsSUFBSSxJQUFJLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxZQUFZLGdCQUFnQixFQUFFLENBQUM7Z0JBQ3hILElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE9BQU8sQ0FBQztZQUNsRCxDQUFDO1lBQ0QsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxFQUFFLENBQUM7Z0JBQ3BDLElBQUksQ0FBQyxVQUFVLEdBQUcsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7WUFDdEMsQ0FBQztRQUNILENBQUM7SUFDSCxDQUFDO0lBRUQsSUFBSSxVQUFVO1FBQ1osSUFBSSxJQUFJLENBQUMsV0FBVyxLQUFLLFNBQVMsRUFBRSxDQUFDO1lBQ25DLE9BQU8sQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDO1FBQzNCLENBQUM7YUFBTSxDQUFDO1lBQ04sT0FBTyxDQUFFLElBQUksQ0FBQyxVQUFpQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUN2RSxDQUFDO0lBQ0gsQ0FBQztJQUVELFFBQVE7UUFDTCxJQUFJLENBQUMsVUFBaUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxDQUFDO1FBQzNFLElBQUksSUFBSSxDQUFDLFVBQVUsSUFBSSxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDbkMsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ2hCLENBQUM7SUFDSCxDQUFDOzhHQXhDVSxxQkFBcUI7a0dBQXJCLHFCQUFxQixtVENUbEMsbVVBTUE7OzJGREdhLHFCQUFxQjtrQkFMakMsU0FBUzsrQkFDRSxrQkFBa0I7OzBCQWlCZixRQUFROzswQkFBSSxJQUFJOzswQkFBSSxRQUFRO3lDQVhoQyxJQUFJO3NCQUFaLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxVQUFVO3NCQUFsQixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxNQUFNO3NCQUFkLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFHRyxrQkFBa0I7c0JBRDFCLFdBQVc7dUJBQUMsa0JBQWtCOztzQkFDOUIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBIb3N0LCBIb3N0QmluZGluZywgSW5wdXQsIE9uSW5pdCwgT3B0aW9uYWwsIFNraXBTZWxmfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHtDb250cm9sQ29udGFpbmVyLCBVbnR5cGVkRm9ybUdyb3VwfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IE1hdERpYWxvZ1JlZiB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ3VpLXN1Ym1pdC1idXR0b24nLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9zdWJtaXQtYnV0dG9uLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsgJy4vc3VibWl0LWJ1dHRvbi5jb21wb25lbnQuc2NzcycgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgU3VibWl0QnV0dG9uQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcclxuXHJcbiAgQElucHV0KCkgYnVzeSA9IGZhbHNlO1xyXG4gIEBJbnB1dCgpIGRpc2FibGVkID0gZmFsc2U7XHJcbiAgQElucHV0KCkgZm9ybUdyb3VwczogVW50eXBlZEZvcm1Hcm91cCB8IFVudHlwZWRGb3JtR3JvdXBbXSA9IFtdO1xyXG4gIEBJbnB1dCgpIGxhYmVsID0gJ1NhdmUnO1xyXG4gIEBJbnB1dCgpIHN1Ym1pdDogKCgpID0+IHZvaWQpIHwgdW5kZWZpbmVkO1xyXG4gIEBJbnB1dCgpIGZvcm1JbnZhbGlkOiBib29sZWFuIHwgdW5kZWZpbmVkO1xyXG5cclxuICBASG9zdEJpbmRpbmcoJ2NsYXNzLndpdGgtY2xvc2UnKVxyXG4gIEBJbnB1dCgpIHByZXBlbmRDbG9zZUJ1dHRvbiA9IHRydWU7XHJcblxyXG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBkaWFsb2dSZWY6IE1hdERpYWxvZ1JlZjxhbnk+LFxyXG4gICAgICAgICAgICAgIEBPcHRpb25hbCgpIEBIb3N0KCkgQFNraXBTZWxmKClcclxuICAgICAgICAgICAgICBwcm90ZWN0ZWQgY29udHJvbENvbnRhaW5lcjogQ29udHJvbENvbnRhaW5lcikgeyB9XHJcblxyXG4gIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgaWYgKHRoaXMuZm9ybUludmFsaWQgPT09IHVuZGVmaW5lZCkge1xyXG4gICAgICBpZiAodGhpcy5mb3JtR3JvdXBzID09PSB1bmRlZmluZWQgJiYgdGhpcy5jb250cm9sQ29udGFpbmVyICYmIHRoaXMuY29udHJvbENvbnRhaW5lci5jb250cm9sIGluc3RhbmNlb2YgVW50eXBlZEZvcm1Hcm91cCkge1xyXG4gICAgICAgIHRoaXMuZm9ybUdyb3VwcyA9IHRoaXMuY29udHJvbENvbnRhaW5lci5jb250cm9sO1xyXG4gICAgICB9XHJcbiAgICAgIGlmICghQXJyYXkuaXNBcnJheSh0aGlzLmZvcm1Hcm91cHMpKSB7XHJcbiAgICAgICAgdGhpcy5mb3JtR3JvdXBzID0gW3RoaXMuZm9ybUdyb3Vwc107XHJcbiAgICAgIH1cclxuICAgIH1cclxuICB9XHJcblxyXG4gIGdldCBmb3Jtc1ZhbGlkKCk6IGJvb2xlYW4ge1xyXG4gICAgaWYgKHRoaXMuZm9ybUludmFsaWQgIT09IHVuZGVmaW5lZCkge1xyXG4gICAgICByZXR1cm4gIXRoaXMuZm9ybUludmFsaWQ7XHJcbiAgICB9IGVsc2Uge1xyXG4gICAgICByZXR1cm4gISh0aGlzLmZvcm1Hcm91cHMgYXMgVW50eXBlZEZvcm1Hcm91cFtdKS5maW5kKGYgPT4gZi5pbnZhbGlkKTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIGRvU3VibWl0KCk6IHZvaWQge1xyXG4gICAgKHRoaXMuZm9ybUdyb3VwcyBhcyBVbnR5cGVkRm9ybUdyb3VwW10pLmZvckVhY2goZiA9PiBmLm1hcmtBbGxBc1RvdWNoZWQoKSk7XHJcbiAgICBpZiAodGhpcy5mb3Jtc1ZhbGlkICYmIHRoaXMuc3VibWl0KSB7XHJcbiAgICAgIHRoaXMuc3VibWl0KCk7XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiIsIjx1aS1idXR0b24gKm5nSWY9XCJwcmVwZW5kQ2xvc2VCdXR0b25cIiBbbGFiZWxdPVwiJ0Nsb3NlJ1wiIChjbGljayk9XCJkaWFsb2dSZWYuY2xvc2UoKVwiPjwvdWktYnV0dG9uPlxyXG5cclxuPHVpLWJ1dHRvbiBbYnVzeV09XCJidXN5XCJcclxuICAgICAgICAgICAgW2Rpc2FibGVkXT1cImRpc2FibGVkIHx8IGJ1c3lcIiBbdHlwZV09XCInc3VibWl0J1wiXHJcbiAgICAgICAgICAgIFtmb3JtSW52YWxpZF09XCIhZm9ybXNWYWxpZFwiXHJcbiAgICAgICAgICAgIFtsYWJlbF09XCJsYWJlbFwiIChjbGljayk9XCJkb1N1Ym1pdCgpXCI+PC91aS1idXR0b24+XHJcbiJdfQ==
@@ -1,97 +0,0 @@
1
- import { Component, Input, ViewChild } from '@angular/core';
2
- import { MatSort } from '@angular/material/sort';
3
- import * as i0 from "@angular/core";
4
- import * as i1 from "@angular/platform-browser";
5
- import * as i2 from "@angular/common";
6
- import * as i3 from "@angular/material/table";
7
- import * as i4 from "@angular/material/sort";
8
- export class TableComponent {
9
- get columnList() {
10
- return this.columns.map(c => c.name);
11
- }
12
- constructor(/*private persistService: PersistService, */ domSanitizer) {
13
- this.domSanitizer = domSanitizer;
14
- this.columns = [];
15
- this.rowTemplates = {};
16
- this.headerTemplates = {};
17
- this.stateStoreKey = '';
18
- }
19
- ngOnInit() {
20
- this.options = { ...{ sticky: false }, ...this.options };
21
- if (this.dataSource) {
22
- // if (this.stateStoreKey !== '') {
23
- // const storeKey = this.stateStoreKey + '.sort';
24
- // const ms = this.persistService.get(storeKey, { active: '', direction: ''});
25
- // this.matSort.active = ms.active;
26
- // this.matSort.direction = ms.direction;
27
- // this.matSort.sortChange.subscribe(sc => {
28
- // this.persistService.set(storeKey, sc.direction === '' ? { active: '', direction: ''} : sc);
29
- // });
30
- // }
31
- if (this.columns.find(c => c.sortable !== undefined)) {
32
- this.dataSource.sortData = (rows, sort) => {
33
- if (sort.direction) {
34
- const sortColumn = this.columns.find(c => c.name === sort.active);
35
- if (sortColumn) {
36
- const res = sort.direction === 'asc' ? 1 : -1;
37
- return rows.sort((r1, r2) => {
38
- if (sortColumn.sortable === true) {
39
- return r1[sortColumn.name] < r2[sortColumn.name] ? -res : res;
40
- }
41
- if (typeof sortColumn.sortable === 'function') {
42
- return sortColumn.sortable(r1, sort.direction) < sortColumn.sortable(r2, sort.direction) ? -res : res;
43
- }
44
- return 0;
45
- });
46
- }
47
- }
48
- return rows;
49
- };
50
- }
51
- }
52
- }
53
- ngAfterViewInit() {
54
- this.dataSource.sort = this.matSort;
55
- }
56
- display(row, col) {
57
- if (col.formatter) {
58
- return this.domSanitizer.bypassSecurityTrustHtml(col.formatter(row));
59
- }
60
- else {
61
- return row[col.name];
62
- }
63
- }
64
- rowClicked(row) {
65
- if (this.rowAction) {
66
- this.rowAction(row);
67
- }
68
- }
69
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: TableComponent, deps: [{ token: i1.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component }); }
70
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.1", type: TableComponent, selector: "ui-table", inputs: { columns: "columns", dataSource: "dataSource", options: "options", rowTemplates: "rowTemplates", headerTemplates: "headerTemplates", stateStoreKey: "stateStoreKey", rowAction: "rowAction", matSortActive: "matSortActive", matSortDirection: "matSortDirection" }, viewQueries: [{ propertyName: "matSort", first: true, predicate: MatSort, descendants: true }], ngImport: i0, template: "<table mat-table matSort [dataSource]=\"dataSource\" style=\"width: 100%\" [matSortActive]=\"matSortActive\" [matSortDirection]=\"matSortDirection\">\r\n\r\n <ng-container *ngFor=\"let c of columns\" [matColumnDef]=\"c.name\">\r\n\r\n <ng-container *ngIf=\"c.sortable\">\r\n <th mat-header-cell *matHeaderCellDef mat-sort-header>{{c.label}}</th>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!c.sortable\">\r\n <ng-container *ngIf=\"!headerTemplates[c.name]\">\r\n <th mat-header-cell *matHeaderCellDef>{{c.label}}</th>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"headerTemplates[c.name]\">\r\n <th mat-header-cell *matHeaderCellDef>\r\n <ng-template [ngTemplateOutlet]=\"headerTemplates[c.name]\"></ng-template>\r\n </th>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <td mat-cell *matCellDef=\"let element\" [colSpan]=\"c.colSpan ? c.colSpan(element) : 1\" [class]=\"c.cellClass ? c.cellClass(element) : ''\">\r\n <ng-container *ngIf=\"!c.colSpan || c.colSpan(element) > 0\">\r\n <ng-container *ngIf=\"rowTemplates[c.name]\">\r\n <ng-template [ngTemplateOutlet]=\"rowTemplates[c.name]\" [ngTemplateOutletContext]=\"{row:element}\" ></ng-template>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!rowTemplates[c.name]\">\r\n <span [innerHTML]=\"display(element, c)\"></span>\r\n </ng-container>\r\n </ng-container>\r\n </td>\r\n </ng-container>\r\n\r\n <tr mat-header-row *matHeaderRowDef=\"columnList; sticky: options?.sticky\"></tr>\r\n <tr mat-row *matRowDef=\"let row; columns: columnList;\" (click)=\"rowClicked(row)\"></tr>\r\n</table>\r\n", styles: [":host table{width:100%}:host td[colspan=\"0\"]{display:none}:host .mat-header-cell{font-weight:400;font-size:14px}:host.inverse .mat-header-row{background-color:#fff}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i3.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i3.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i3.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i3.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { kind: "directive", type: i3.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i3.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i3.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i3.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i3.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i3.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "directive", type: i4.MatSort, selector: "[matSort]", inputs: ["matSortActive", "matSortStart", "matSortDirection", "matSortDisableClear", "matSortDisabled"], outputs: ["matSortChange"], exportAs: ["matSort"] }, { kind: "component", type: i4.MatSortHeader, selector: "[mat-sort-header]", inputs: ["mat-sort-header", "arrowPosition", "start", "disabled", "sortActionDescription", "disableClear"], exportAs: ["matSortHeader"] }] }); }
71
- }
72
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: TableComponent, decorators: [{
73
- type: Component,
74
- args: [{ selector: 'ui-table', template: "<table mat-table matSort [dataSource]=\"dataSource\" style=\"width: 100%\" [matSortActive]=\"matSortActive\" [matSortDirection]=\"matSortDirection\">\r\n\r\n <ng-container *ngFor=\"let c of columns\" [matColumnDef]=\"c.name\">\r\n\r\n <ng-container *ngIf=\"c.sortable\">\r\n <th mat-header-cell *matHeaderCellDef mat-sort-header>{{c.label}}</th>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!c.sortable\">\r\n <ng-container *ngIf=\"!headerTemplates[c.name]\">\r\n <th mat-header-cell *matHeaderCellDef>{{c.label}}</th>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"headerTemplates[c.name]\">\r\n <th mat-header-cell *matHeaderCellDef>\r\n <ng-template [ngTemplateOutlet]=\"headerTemplates[c.name]\"></ng-template>\r\n </th>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <td mat-cell *matCellDef=\"let element\" [colSpan]=\"c.colSpan ? c.colSpan(element) : 1\" [class]=\"c.cellClass ? c.cellClass(element) : ''\">\r\n <ng-container *ngIf=\"!c.colSpan || c.colSpan(element) > 0\">\r\n <ng-container *ngIf=\"rowTemplates[c.name]\">\r\n <ng-template [ngTemplateOutlet]=\"rowTemplates[c.name]\" [ngTemplateOutletContext]=\"{row:element}\" ></ng-template>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!rowTemplates[c.name]\">\r\n <span [innerHTML]=\"display(element, c)\"></span>\r\n </ng-container>\r\n </ng-container>\r\n </td>\r\n </ng-container>\r\n\r\n <tr mat-header-row *matHeaderRowDef=\"columnList; sticky: options?.sticky\"></tr>\r\n <tr mat-row *matRowDef=\"let row; columns: columnList;\" (click)=\"rowClicked(row)\"></tr>\r\n</table>\r\n", styles: [":host table{width:100%}:host td[colspan=\"0\"]{display:none}:host .mat-header-cell{font-weight:400;font-size:14px}:host.inverse .mat-header-row{background-color:#fff}\n"] }]
75
- }], ctorParameters: () => [{ type: i1.DomSanitizer }], propDecorators: { columns: [{
76
- type: Input
77
- }], dataSource: [{
78
- type: Input
79
- }], options: [{
80
- type: Input
81
- }], rowTemplates: [{
82
- type: Input
83
- }], headerTemplates: [{
84
- type: Input
85
- }], stateStoreKey: [{
86
- type: Input
87
- }], rowAction: [{
88
- type: Input
89
- }], matSortActive: [{
90
- type: Input
91
- }], matSortDirection: [{
92
- type: Input
93
- }], matSort: [{
94
- type: ViewChild,
95
- args: [MatSort]
96
- }] } });
97
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../projects/ui/src/lib/table/table.component.ts","../../../../../projects/ui/src/lib/table/table.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAiB,SAAS,EAAE,KAAK,EAAU,SAAS,EAAE,MAAM,eAAe,CAAC;AACnF,OAAO,EAAC,OAAO,EAAgB,MAAM,wBAAwB,CAAC;;;;;;AAqB9D,MAAM,OAAO,cAAc;IAezB,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;IACvC,CAAC;IAED,YAAY,4CAA4C,CAAQ,YAA0B;QAA1B,iBAAY,GAAZ,YAAY,CAAc;QAjBjF,YAAO,GAAkB,EAAE,CAAC;QAG5B,iBAAY,GAAQ,EAAE,CAAC;QACvB,oBAAe,GAAQ,EAAE,CAAC;QAC1B,kBAAa,GAAG,EAAE,CAAC;IAYkE,CAAC;IAE/F,QAAQ;QACN,IAAI,CAAC,OAAO,GAAG,EAAC,GAAG,EAAC,MAAM,EAAE,KAAK,EAAC,EAAE,GAAG,IAAI,CAAC,OAAO,EAAC,CAAC;QACrD,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,mCAAmC;YACnC,mDAAmD;YACnD,gFAAgF;YAChF,qCAAqC;YACrC,2CAA2C;YAC3C,8CAA8C;YAC9C,kGAAkG;YAClG,QAAQ;YACR,IAAI;YACJ,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,SAAS,CAAC,EAAE,CAAC;gBACrD,IAAI,CAAC,UAAU,CAAC,QAAQ,GAAG,CAAC,IAAW,EAAE,IAAa,EAAE,EAAE;oBACxD,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;wBACnB,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,MAAM,CAAC,CAAC;wBAClE,IAAI,UAAU,EAAE,CAAC;4BACf,MAAM,GAAG,GAAG,IAAI,CAAC,SAAS,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;4BAC9C,OAAO,IAAI,CAAC,IAAI,CAAC,CAAC,EAAO,EAAE,EAAO,EAAE,EAAE;gCACpC,IAAI,UAAU,CAAC,QAAQ,KAAK,IAAI,EAAE,CAAC;oCACjC,OAAO,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;gCAChE,CAAC;gCACD,IAAI,OAAO,UAAU,CAAC,QAAQ,KAAK,UAAU,EAAE,CAAC;oCAC9C,OAAO,UAAU,CAAC,QAAQ,CAAC,EAAE,EAAE,IAAI,CAAC,SAAS,CAAC,GAAG,UAAU,CAAC,QAAQ,CAAC,EAAE,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;gCACxG,CAAC;gCACD,OAAO,CAAC,CAAC;4BACX,CAAC,CAAC,CAAC;wBACL,CAAC;oBACH,CAAC;oBACD,OAAO,IAAI,CAAC;gBACd,CAAC,CAAC;YACJ,CAAC;QACH,CAAC;IACH,CAAC;IAED,eAAe;QACb,IAAI,CAAC,UAAU,CAAC,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC;IACtC,CAAC;IAED,OAAO,CAAC,GAAQ,EAAE,GAAgB;QAChC,IAAI,GAAG,CAAC,SAAS,EAAE,CAAC;YAClB,OAAO,IAAI,CAAC,YAAY,CAAC,uBAAuB,CAAC,GAAG,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC;QACvE,CAAC;aAAM,CAAC;YACN,OAAO,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACvB,CAAC;IACH,CAAC;IAED,UAAU,CAAC,GAAG;QACZ,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,IAAI,CAAC,SAAS,CAAE,GAAG,CAAC,CAAC;QACvB,CAAC;IACH,CAAC;8GAxEU,cAAc;kGAAd,cAAc,uWAad,OAAO,gDCnCpB,+pDAoCA;;2FDda,cAAc;kBAL1B,SAAS;+BACE,UAAU;iFAMX,OAAO;sBAAf,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBAEG,aAAa;sBAArB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBAEc,OAAO;sBAA1B,SAAS;uBAAC,OAAO","sourcesContent":["import { AfterViewInit, Component, Input, OnInit, ViewChild } from '@angular/core';\r\nimport {MatSort, SortDirection} from '@angular/material/sort';\r\n// import {PersistService} from '../../services/persist.service';\r\nimport {DomSanitizer} from '@angular/platform-browser';\r\n\r\nexport interface TableColumn {\r\n  name: string;\r\n  sortable?: boolean | ((row: any, direction?: SortDirection) => number | string);\r\n  label?: string;\r\n  colSpan?: (row: any) => number;\r\n  formatter?: (row: any) => string;\r\n  cellClass?: (row: any) => string;\r\n}\r\n\r\nexport interface TableOptions {\r\n  sticky?: boolean;\r\n}\r\n@Component({\r\n  selector: 'ui-table',\r\n  templateUrl: './table.component.html',\r\n  styleUrls: ['./table.component.scss']\r\n})\r\nexport class TableComponent implements OnInit, AfterViewInit {\r\n\r\n  @Input() columns: TableColumn[] = [];\r\n  @Input() dataSource: any;\r\n  @Input() options: TableOptions | undefined;\r\n  @Input() rowTemplates: any = {};\r\n  @Input() headerTemplates: any = {};\r\n  @Input() stateStoreKey = '';\r\n  @Input() rowAction: (row: any) => void;\r\n\r\n  @Input() matSortActive;\r\n  @Input() matSortDirection;\r\n\r\n  @ViewChild(MatSort) matSort: MatSort | undefined;\r\n\r\n  get columnList(): string[] {\r\n    return this.columns.map(c => c.name);\r\n  }\r\n\r\n  constructor(/*private persistService: PersistService, */private domSanitizer: DomSanitizer) { }\r\n\r\n  ngOnInit(): void {\r\n    this.options = {...{sticky: false}, ...this.options};\r\n    if (this.dataSource) {\r\n      // if (this.stateStoreKey !== '') {\r\n      //   const storeKey = this.stateStoreKey + '.sort';\r\n      //   const ms = this.persistService.get(storeKey, { active: '', direction: ''});\r\n      //   this.matSort.active = ms.active;\r\n      //   this.matSort.direction = ms.direction;\r\n      //   this.matSort.sortChange.subscribe(sc => {\r\n      //     this.persistService.set(storeKey, sc.direction === '' ? { active: '', direction: ''} : sc);\r\n      //   });\r\n      // }\r\n      if (this.columns.find(c => c.sortable !== undefined)) {\r\n        this.dataSource.sortData = (rows: any[], sort: MatSort) => {\r\n          if (sort.direction) {\r\n            const sortColumn = this.columns.find(c => c.name === sort.active);\r\n            if (sortColumn) {\r\n              const res = sort.direction === 'asc' ? 1 : -1;\r\n              return rows.sort((r1: any, r2: any) => {\r\n                if (sortColumn.sortable === true) {\r\n                  return r1[sortColumn.name] < r2[sortColumn.name] ? -res : res;\r\n                }\r\n                if (typeof sortColumn.sortable === 'function') {\r\n                  return sortColumn.sortable(r1, sort.direction) < sortColumn.sortable(r2, sort.direction) ? -res : res;\r\n                }\r\n                return 0;\r\n              });\r\n            }\r\n          }\r\n          return rows;\r\n        };\r\n      }\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.dataSource.sort = this.matSort;\r\n  }\r\n\r\n  display(row: any, col: TableColumn): any {\r\n    if (col.formatter) {\r\n      return this.domSanitizer.bypassSecurityTrustHtml(col.formatter(row));\r\n    } else {\r\n      return row[col.name];\r\n    }\r\n  }\r\n\r\n  rowClicked(row) {\r\n    if (this.rowAction) {\r\n      this.rowAction( row);\r\n    }\r\n  }\r\n}\r\n","<table mat-table matSort [dataSource]=\"dataSource\" style=\"width: 100%\" [matSortActive]=\"matSortActive\" [matSortDirection]=\"matSortDirection\">\r\n\r\n  <ng-container *ngFor=\"let c of columns\" [matColumnDef]=\"c.name\">\r\n\r\n    <ng-container *ngIf=\"c.sortable\">\r\n      <th mat-header-cell *matHeaderCellDef mat-sort-header>{{c.label}}</th>\r\n    </ng-container>\r\n\r\n    <ng-container *ngIf=\"!c.sortable\">\r\n      <ng-container *ngIf=\"!headerTemplates[c.name]\">\r\n        <th mat-header-cell *matHeaderCellDef>{{c.label}}</th>\r\n      </ng-container>\r\n\r\n      <ng-container *ngIf=\"headerTemplates[c.name]\">\r\n        <th mat-header-cell *matHeaderCellDef>\r\n          <ng-template [ngTemplateOutlet]=\"headerTemplates[c.name]\"></ng-template>\r\n        </th>\r\n      </ng-container>\r\n    </ng-container>\r\n\r\n    <td mat-cell *matCellDef=\"let element\" [colSpan]=\"c.colSpan ? c.colSpan(element) : 1\" [class]=\"c.cellClass ? c.cellClass(element) : ''\">\r\n      <ng-container *ngIf=\"!c.colSpan || c.colSpan(element) > 0\">\r\n        <ng-container *ngIf=\"rowTemplates[c.name]\">\r\n          <ng-template [ngTemplateOutlet]=\"rowTemplates[c.name]\" [ngTemplateOutletContext]=\"{row:element}\" ></ng-template>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"!rowTemplates[c.name]\">\r\n          <span [innerHTML]=\"display(element, c)\"></span>\r\n        </ng-container>\r\n      </ng-container>\r\n    </td>\r\n  </ng-container>\r\n\r\n  <tr mat-header-row *matHeaderRowDef=\"columnList; sticky: options?.sticky\"></tr>\r\n  <tr mat-row *matRowDef=\"let row; columns: columnList;\" (click)=\"rowClicked(row)\"></tr>\r\n</table>\r\n"]}
@@ -1,46 +0,0 @@
1
- import { Component, EventEmitter, Input, Optional, Output, Self, ViewChild } from '@angular/core';
2
- import { UiSimpleComponent } from '../layouts/simple/ui-simple.component';
3
- import * as i0 from "@angular/core";
4
- import * as i1 from "@angular/forms";
5
- import * as i2 from "@angular/common";
6
- import * as i3 from "@angular/material/input";
7
- import * as i4 from "@angular/cdk/text-field";
8
- import * as i5 from "../layouts/simple/ui-simple-layout.component";
9
- export class TextAreaComponent extends UiSimpleComponent {
10
- constructor(ngControl /*, private _ngZone: NgZone, private cdr: ChangeDetectorRef*/) {
11
- super(ngControl);
12
- this.ngControl = ngControl;
13
- this.rows = 5;
14
- this.autoResize = false;
15
- this.lastClientHeight = -1;
16
- this.focusChanged = new EventEmitter();
17
- }
18
- focus() {
19
- this.textarea.nativeElement.focus();
20
- }
21
- setDisabledState(isDisabled) {
22
- }
23
- onFocus(focus) {
24
- this.focusChanged.emit(focus);
25
- }
26
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: TextAreaComponent, deps: [{ token: i1.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component }); }
27
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.1", type: TextAreaComponent, selector: "ui-text-area", inputs: { rows: "rows", autoResize: "autoResize" }, outputs: { focusChanged: "focusChanged" }, viewQueries: [{ propertyName: "textarea", first: true, predicate: ["textarea"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<ui-simple-layout [ctx]=\"this\">\r\n\r\n<div class=\"input-wrapper\">\r\n <ng-container *ngIf=\"componentFormControl\">\r\n <textarea *ngIf=\"autoResize \"#textarea matInput\r\n cdkTextareaAutosize cdkAutosizeMinRows=\"rows\"\r\n class=\"autoresize\"\r\n [formControl]=\"componentFormControl\" [placeholder]=\"placeholder\" [rows]=\"rows\" (focus)=\"onFocus(true)\" (blur)=\"onFocus(false)\"></textarea>\r\n <textarea *ngIf=\"!autoResize \"#textarea matInput\r\n [formControl]=\"componentFormControl\" [placeholder]=\"placeholder\" [rows]=\"rows\" (focus)=\"onFocus(true)\" (blur)=\"onFocus(false)\"></textarea>\r\n </ng-container>\r\n</div>\r\n\r\n</ui-simple-layout>\r\n", styles: [":host{display:flex;flex-direction:column;width:100%}:host .control-container{width:100%;position:relative}:host .control-container.has-prefix ::ng-deep input,:host .control-container.has-prefix ::ng-deep textarea,:host .control-container.has-prefix ::ng-deep .mat-mdc-select-trigger{padding-left:1.8em}:host .control-container.has-suffix:not(.has-clear-icon) ::ng-deep input,:host .control-container.has-suffix:not(.has-clear-icon) ::ng-deep textarea,:host .control-container.has-suffix:not(.has-clear-icon) ::ng-deep .mat-mdc-select-trigger{padding-right:1.8em}:host .control-container.has-clear-icon:not(.has-suffix) ::ng-deep input,:host .control-container.has-clear-icon:not(.has-suffix) ::ng-deep textarea,:host .control-container.has-clear-icon:not(.has-suffix) ::ng-deep .mat-mdc-select-trigger{padding-right:1.8em}:host .control-container.has-suffix.has-clear-icon ::ng-deep input,:host .control-container.has-suffix.has-clear-icon ::ng-deep textarea,:host .control-container.has-suffix.has-clear-icon ::ng-deep .mat-mdc-select-trigger{padding-right:3.6em}:host .control-container.has-suffix.has-clear-icon ::ng-deep .clear-icon{right:1.4em!important}:host ::ng-deep [slot=suffix],:host ::ng-deep .clear-icon,:host ::ng-deep .suffix-icon{position:absolute;-webkit-user-select:none;user-select:none;transition:color .25s;top:calc(50% - .5em);right:.2em;width:1em;height:1em;font-size:1.5em}:host ::ng-deep [slot=suffix]:not(.disabled),:host ::ng-deep .clear-icon:not(.disabled),:host ::ng-deep .suffix-icon:not(.disabled){cursor:pointer}:host ::ng-deep [slot=prefix],:host ::ng-deep .prefix-icon{position:absolute;-webkit-user-select:none;user-select:none;transition:color .25s;top:calc(50% - .5em);left:.2em;width:1em;height:1em;font-size:1.5em}:host ::ng-deep [slot=prefix]:not(.disabled),:host ::ng-deep .prefix-icon:not(.disabled){cursor:pointer}:host ::ng-deep input,:host ::ng-deep textarea,:host ::ng-deep .mat-mdc-select-trigger,:host ::ng-deep .editor-wrapper{resize:none;width:100%;line-height:1.2em;font-size:1em;outline:none;border-style:solid;transition:border-color 333ms}:host ::ng-deep textarea.autoresize{box-sizing:content-box;width:calc(100% - 1.4em)}:host ::ng-deep ::ng-deep .mat-select-trigger,:host ::ng-deep ::ng-deep .mat-mdc-select-trigger{height:100%}:host ::ng-deep ::ng-deep .mat-select-value,:host ::ng-deep ::ng-deep .mat-mdc-select-value{vertical-align:middle}::ng-deep ui-input{display:block}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.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: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: i4.CdkTextareaAutosize, selector: "textarea[cdkTextareaAutosize]", inputs: ["cdkAutosizeMinRows", "cdkAutosizeMaxRows", "cdkTextareaAutosize", "placeholder"], exportAs: ["cdkTextareaAutosize"] }, { kind: "component", type: i5.UiSimpleLayoutComponent, selector: "ui-simple-layout", inputs: ["ctx"] }] }); }
28
- }
29
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: TextAreaComponent, decorators: [{
30
- type: Component,
31
- args: [{ selector: 'ui-text-area', template: "<ui-simple-layout [ctx]=\"this\">\r\n\r\n<div class=\"input-wrapper\">\r\n <ng-container *ngIf=\"componentFormControl\">\r\n <textarea *ngIf=\"autoResize \"#textarea matInput\r\n cdkTextareaAutosize cdkAutosizeMinRows=\"rows\"\r\n class=\"autoresize\"\r\n [formControl]=\"componentFormControl\" [placeholder]=\"placeholder\" [rows]=\"rows\" (focus)=\"onFocus(true)\" (blur)=\"onFocus(false)\"></textarea>\r\n <textarea *ngIf=\"!autoResize \"#textarea matInput\r\n [formControl]=\"componentFormControl\" [placeholder]=\"placeholder\" [rows]=\"rows\" (focus)=\"onFocus(true)\" (blur)=\"onFocus(false)\"></textarea>\r\n </ng-container>\r\n</div>\r\n\r\n</ui-simple-layout>\r\n", styles: [":host{display:flex;flex-direction:column;width:100%}:host .control-container{width:100%;position:relative}:host .control-container.has-prefix ::ng-deep input,:host .control-container.has-prefix ::ng-deep textarea,:host .control-container.has-prefix ::ng-deep .mat-mdc-select-trigger{padding-left:1.8em}:host .control-container.has-suffix:not(.has-clear-icon) ::ng-deep input,:host .control-container.has-suffix:not(.has-clear-icon) ::ng-deep textarea,:host .control-container.has-suffix:not(.has-clear-icon) ::ng-deep .mat-mdc-select-trigger{padding-right:1.8em}:host .control-container.has-clear-icon:not(.has-suffix) ::ng-deep input,:host .control-container.has-clear-icon:not(.has-suffix) ::ng-deep textarea,:host .control-container.has-clear-icon:not(.has-suffix) ::ng-deep .mat-mdc-select-trigger{padding-right:1.8em}:host .control-container.has-suffix.has-clear-icon ::ng-deep input,:host .control-container.has-suffix.has-clear-icon ::ng-deep textarea,:host .control-container.has-suffix.has-clear-icon ::ng-deep .mat-mdc-select-trigger{padding-right:3.6em}:host .control-container.has-suffix.has-clear-icon ::ng-deep .clear-icon{right:1.4em!important}:host ::ng-deep [slot=suffix],:host ::ng-deep .clear-icon,:host ::ng-deep .suffix-icon{position:absolute;-webkit-user-select:none;user-select:none;transition:color .25s;top:calc(50% - .5em);right:.2em;width:1em;height:1em;font-size:1.5em}:host ::ng-deep [slot=suffix]:not(.disabled),:host ::ng-deep .clear-icon:not(.disabled),:host ::ng-deep .suffix-icon:not(.disabled){cursor:pointer}:host ::ng-deep [slot=prefix],:host ::ng-deep .prefix-icon{position:absolute;-webkit-user-select:none;user-select:none;transition:color .25s;top:calc(50% - .5em);left:.2em;width:1em;height:1em;font-size:1.5em}:host ::ng-deep [slot=prefix]:not(.disabled),:host ::ng-deep .prefix-icon:not(.disabled){cursor:pointer}:host ::ng-deep input,:host ::ng-deep textarea,:host ::ng-deep .mat-mdc-select-trigger,:host ::ng-deep .editor-wrapper{resize:none;width:100%;line-height:1.2em;font-size:1em;outline:none;border-style:solid;transition:border-color 333ms}:host ::ng-deep textarea.autoresize{box-sizing:content-box;width:calc(100% - 1.4em)}:host ::ng-deep ::ng-deep .mat-select-trigger,:host ::ng-deep ::ng-deep .mat-mdc-select-trigger{height:100%}:host ::ng-deep ::ng-deep .mat-select-value,:host ::ng-deep ::ng-deep .mat-mdc-select-value{vertical-align:middle}::ng-deep ui-input{display:block}\n"] }]
32
- }], ctorParameters: () => [{ type: i1.NgControl, decorators: [{
33
- type: Optional
34
- }, {
35
- type: Self
36
- }] }], propDecorators: { rows: [{
37
- type: Input
38
- }], autoResize: [{
39
- type: Input
40
- }], textarea: [{
41
- type: ViewChild,
42
- args: ['textarea']
43
- }], focusChanged: [{
44
- type: Output
45
- }] } });
46
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC1hcmVhLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpL3NyYy9saWIvdGV4dC1hcmVhL3RleHQtYXJlYS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9zcmMvbGliL3RleHQtYXJlYS90ZXh0LWFyZWEuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUVMLFNBQVMsRUFFVCxZQUFZLEVBRVosS0FBSyxFQUVMLFFBQVEsRUFDUixNQUFNLEVBQ04sSUFBSSxFQUNKLFNBQVMsRUFDVixNQUFNLGVBQWUsQ0FBQztBQUV2QixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQzs7Ozs7OztBQWUxRSxNQUFNLE9BQU8saUJBQWtCLFNBQVEsaUJBQWlCO0lBZXRELFlBQXVDLFNBQW9CLENBQUEsNkRBQTZEO1FBQ3RILEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQztRQURvQixjQUFTLEdBQVQsU0FBUyxDQUFXO1FBYmxELFNBQUksR0FBRyxDQUFDLENBQUM7UUFFVCxlQUFVLEdBQUcsS0FBSyxDQUFDO1FBRTVCLHFCQUFnQixHQUFHLENBQUMsQ0FBQyxDQUFDO1FBTVosaUJBQVksR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFDO0lBS3JELENBQUM7SUFFRCxLQUFLO1FBQ0gsSUFBSSxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDdEMsQ0FBQztJQUVELGdCQUFnQixDQUFDLFVBQW1CO0lBQ3BDLENBQUM7SUFFRCxPQUFPLENBQUMsS0FBYztRQUNwQixJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNoQyxDQUFDOzhHQTVCVSxpQkFBaUI7a0dBQWpCLGlCQUFpQixnUkM3QjlCLG10QkFjQTs7MkZEZWEsaUJBQWlCO2tCQVY3QixTQUFTOytCQUNFLGNBQWM7OzBCQXdCWCxRQUFROzswQkFBSSxJQUFJO3lDQWJwQixJQUFJO3NCQUFaLEtBQUs7Z0JBRUcsVUFBVTtzQkFBbEIsS0FBSztnQkFNaUIsUUFBUTtzQkFBOUIsU0FBUzt1QkFBQyxVQUFVO2dCQUVYLFlBQVk7c0JBQXJCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIENoYW5nZURldGVjdG9yUmVmLFxyXG4gIENvbXBvbmVudCxcclxuICBFbGVtZW50UmVmLFxyXG4gIEV2ZW50RW1pdHRlcixcclxuICBIb3N0QmluZGluZyxcclxuICBJbnB1dCxcclxuICBOZ1pvbmUsXHJcbiAgT3B0aW9uYWwsXHJcbiAgT3V0cHV0LFxyXG4gIFNlbGYsXHJcbiAgVmlld0NoaWxkXHJcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE5nQ29udHJvbCB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgVWlTaW1wbGVDb21wb25lbnQgfSBmcm9tICcuLi9sYXlvdXRzL3NpbXBsZS91aS1zaW1wbGUuY29tcG9uZW50JztcclxuaW1wb3J0IHsgQ2RrVGV4dGFyZWFBdXRvc2l6ZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay90ZXh0LWZpZWxkJztcclxuaW1wb3J0IHsgdGFrZSB9IGZyb20gJ3J4anMnO1xyXG5cclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAndWktdGV4dC1hcmVhJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vdGV4dC1hcmVhLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsgJy4uL2xheW91dHMvc2ltcGxlL3VpLXNpbXBsZS1sYXlvdXQuY29tcG9uZW50LnNjc3MnXSxcclxuICAvLyBwcm92aWRlcnM6IFt7XHJcbiAgLy8gICBwcm92aWRlOiBOR19WQUxVRV9BQ0NFU1NPUixcclxuICAvLyAgIG11bHRpOiB0cnVlLFxyXG4gIC8vICAgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gVGV4dEFyZWFDb21wb25lbnQpLFxyXG4gIC8vIH1dXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBUZXh0QXJlYUNvbXBvbmVudCBleHRlbmRzIFVpU2ltcGxlQ29tcG9uZW50IHtcclxuXHJcbiAgQElucHV0KCkgcm93cyA9IDU7XHJcblxyXG4gIEBJbnB1dCgpIGF1dG9SZXNpemUgPSBmYWxzZTtcclxuXHJcbiAgbGFzdENsaWVudEhlaWdodCA9IC0xO1xyXG4gIC8vIGhlaWdodCA9IC0xO1xyXG5cclxuXHJcbiAgQFZpZXdDaGlsZCgndGV4dGFyZWEnKSB0ZXh0YXJlYTogRWxlbWVudFJlZjtcclxuXHJcbiAgQE91dHB1dCgpIGZvY3VzQ2hhbmdlZCA9IG5ldyBFdmVudEVtaXR0ZXI8Ym9vbGVhbj4oKTtcclxuXHJcblxyXG4gIGNvbnN0cnVjdG9yKEBPcHRpb25hbCgpIEBTZWxmKCkgcHVibGljIG5nQ29udHJvbDogTmdDb250cm9sLyosIHByaXZhdGUgX25nWm9uZTogTmdab25lLCBwcml2YXRlIGNkcjogQ2hhbmdlRGV0ZWN0b3JSZWYqLykge1xyXG4gICAgc3VwZXIobmdDb250cm9sKTtcclxuICB9XHJcblxyXG4gIGZvY3VzKCk6IHZvaWQge1xyXG4gICAgdGhpcy50ZXh0YXJlYS5uYXRpdmVFbGVtZW50LmZvY3VzKCk7XHJcbiAgfVxyXG5cclxuICBzZXREaXNhYmxlZFN0YXRlKGlzRGlzYWJsZWQ6IGJvb2xlYW4pOiB2b2lkIHtcclxuICB9XHJcblxyXG4gIG9uRm9jdXMoZm9jdXM6IGJvb2xlYW4pOiB2b2lkIHtcclxuICAgIHRoaXMuZm9jdXNDaGFuZ2VkLmVtaXQoZm9jdXMpO1xyXG4gIH1cclxuXHJcblxyXG4gIC8vIG9uS2V5ZG93bigpIHtcclxuICAvLyAgIC8vIHNldFRpbWVvdXQoKCkgPT4ge1xyXG4gIC8vICAgICBjb25zb2xlLmxvZygnb25rZXlkb3duJyk7XHJcbiAgLy8gICAgIC8vIGlmICh0aGlzLmxhc3RDbGllbnRIZWlnaHQgIT09IHRoaXMudGV4dGFyZWEubmF0aXZlRWxlbWVudC5jbGllbnRIZWlnaHQgKyAyMCkge1xyXG4gIC8vICAgICAgIHRoaXMuaGVpZ2h0ID0gdGhpcy50ZXh0YXJlYS5uYXRpdmVFbGVtZW50LmNsaWVudEhlaWdodCArIDIwO1xyXG4gIC8vICAgICAgIC8vIHRoaXMudGV4dGFyZWEubmF0aXZlRWxlbWVudC5zZXRBdHRyaWJ1dGUoJ3N0eWxlJywgJ2NvbG9yOiB3aGl0ZTsgYmFja2dyb3VuZDogcmVkOyBoZWlnaHQ6ICcgKyB0aGlzLmhlaWdodCArICdweDsnKTtcclxuICAvLyAgICAgICAvLyB0aGlzLmNkci5kZXRlY3RDaGFuZ2VzKCk7XHJcbiAgLy8gICAgICAgdGhpcy5sYXN0Q2xpZW50SGVpZ2h0ID0gdGhpcy5oZWlnaHQ7XHJcbiAgLy8gICAgICAgY29uc29sZS5sb2codGhpcy5oZWlnaHQpO1xyXG4gIC8vICAgICAvLyB9XHJcbiAgLy8gICAvLyB9KTtcclxuICAvLyB9XHJcblxyXG4gIC8vIEBWaWV3Q2hpbGQoJ2F1dG9zaXplJykgYXV0b3NpemU6IENka1RleHRhcmVhQXV0b3NpemU7XHJcbiAgLy9cclxuICAvLyB0cmlnZ2VyUmVzaXplKCkge1xyXG4gIC8vICAgLy8gV2FpdCBmb3IgY2hhbmdlcyB0byBiZSBhcHBsaWVkLCB0aGVuIHRyaWdnZXIgdGV4dGFyZWEgcmVzaXplLlxyXG4gIC8vICAgdGhpcy5fbmdab25lLm9uU3RhYmxlLnBpcGUodGFrZSgxKSkuc3Vic2NyaWJlKCgpID0+IHtcclxuICAvLyAgICAgY29uc29sZS5sb2coJ3h4eCcpO1xyXG4gIC8vICAgICB0aGlzLmF1dG9zaXplLnJlc2l6ZVRvRml0Q29udGVudCh0cnVlKVxyXG4gIC8vICAgfSk7XHJcbiAgLy8gfVxyXG59XHJcbiIsIjx1aS1zaW1wbGUtbGF5b3V0IFtjdHhdPVwidGhpc1wiPlxyXG5cclxuPGRpdiBjbGFzcz1cImlucHV0LXdyYXBwZXJcIj5cclxuICA8bmctY29udGFpbmVyICpuZ0lmPVwiY29tcG9uZW50Rm9ybUNvbnRyb2xcIj5cclxuICA8dGV4dGFyZWEgKm5nSWY9XCJhdXRvUmVzaXplIFwiI3RleHRhcmVhIG1hdElucHV0XHJcbiAgICAgICAgICAgIGNka1RleHRhcmVhQXV0b3NpemUgY2RrQXV0b3NpemVNaW5Sb3dzPVwicm93c1wiXHJcbiAgICAgICAgICAgIGNsYXNzPVwiYXV0b3Jlc2l6ZVwiXHJcbiAgICAgICAgICAgIFtmb3JtQ29udHJvbF09XCJjb21wb25lbnRGb3JtQ29udHJvbFwiIFtwbGFjZWhvbGRlcl09XCJwbGFjZWhvbGRlclwiIFtyb3dzXT1cInJvd3NcIiAoZm9jdXMpPVwib25Gb2N1cyh0cnVlKVwiIChibHVyKT1cIm9uRm9jdXMoZmFsc2UpXCI+PC90ZXh0YXJlYT5cclxuICA8dGV4dGFyZWEgKm5nSWY9XCIhYXV0b1Jlc2l6ZSBcIiN0ZXh0YXJlYSBtYXRJbnB1dFxyXG4gICAgICAgICAgICBbZm9ybUNvbnRyb2xdPVwiY29tcG9uZW50Rm9ybUNvbnRyb2xcIiBbcGxhY2Vob2xkZXJdPVwicGxhY2Vob2xkZXJcIiBbcm93c109XCJyb3dzXCIgKGZvY3VzKT1cIm9uRm9jdXModHJ1ZSlcIiAoYmx1cik9XCJvbkZvY3VzKGZhbHNlKVwiPjwvdGV4dGFyZWE+XHJcbiAgPC9uZy1jb250YWluZXI+XHJcbjwvZGl2PlxyXG5cclxuPC91aS1zaW1wbGUtbGF5b3V0PlxyXG4iXX0=