@wizco/fenixds-ngx 17.0.20 → 17.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,5 +1,5 @@
1
- import { Component, EventEmitter, Input, Output, SkipSelf } from '@angular/core';
2
- import { HttpClientModule, HttpEventType } from '@angular/common/http';
1
+ import { Component, EventEmitter, Input, Output, SkipSelf, } from '@angular/core';
2
+ import { HttpClientModule, HttpEventType, } from '@angular/common/http';
3
3
  import { CommonModule } from '@angular/common';
4
4
  import * as i0 from "@angular/core";
5
5
  import * as i1 from "@angular/common/http";
@@ -7,7 +7,7 @@ import * as i2 from "@angular/common";
7
7
  export class UploadComponent {
8
8
  http;
9
9
  /* Texto de descrição do arquivo */
10
- description = "(XX MB de tamanho máximo e é permitido qualquer tipo de arquivos)";
10
+ description = '(XX MB de tamanho máximo e é permitido qualquer tipo de arquivos)';
11
11
  /* config <AngularFileUploaderConfig> configuração do componente principais parâmetros */
12
12
  config = {
13
13
  uploadAPI: {
@@ -18,127 +18,127 @@ export class UploadComponent {
18
18
  },
19
19
  responseType: 'json',
20
20
  withCredentials: false,
21
- }
21
+ },
22
22
  };
23
23
  /*
24
- * Opção de resetar o componente
25
- */
24
+ * Opção de resetar o componente
25
+ */
26
26
  resetUpload = false;
27
27
  /*
28
- * Evento Resposta da requisição sendo sucesso ou erro
29
- */
28
+ * Evento Resposta da requisição sendo sucesso ou erro
29
+ */
30
30
  ApiResponse = new EventEmitter();
31
31
  /*
32
- * Evento javascript puro para retorno do arquivo
33
- */
32
+ * Evento javascript puro para retorno do arquivo
33
+ */
34
34
  fileSelected = new EventEmitter();
35
35
  /**
36
- * @ignore
37
- */
36
+ * @ignore
37
+ */
38
38
  theme = '';
39
39
  /**
40
- * @ignore
41
- */
40
+ * @ignore
41
+ */
42
42
  id = 0;
43
43
  /**
44
- * @ignore
45
- */
44
+ * @ignore
45
+ */
46
46
  hideProgressBar = false;
47
47
  /**
48
- * @ignore
49
- */
48
+ * @ignore
49
+ */
50
50
  maxSize = 20 * 1024000; // mb to bytes.
51
51
  /**
52
- * @ignore
53
- */
52
+ * @ignore
53
+ */
54
54
  uploadAPI = '';
55
55
  /**
56
- * @ignore
57
- */
56
+ * @ignore
57
+ */
58
58
  method = 'POST';
59
59
  /**
60
- * @ignore
61
- */
60
+ * @ignore
61
+ */
62
62
  formatsAllowed = '*';
63
63
  /**
64
- * @ignore
65
- */
64
+ * @ignore
65
+ */
66
66
  formatsAllowedText = '';
67
67
  /**
68
- * @ignore
69
- */
68
+ * @ignore
69
+ */
70
70
  multiple = false;
71
71
  /**
72
- * @ignore
73
- */
72
+ * @ignore
73
+ */
74
74
  headers = {};
75
75
  /**
76
- * @ignore
77
- */
76
+ * @ignore
77
+ */
78
78
  params = {};
79
79
  /**
80
- * @ignore
81
- */
80
+ * @ignore
81
+ */
82
82
  responseType = 'blob';
83
83
  /**
84
- * @ignore
85
- */
84
+ * @ignore
85
+ */
86
86
  hideResetBtn = false;
87
87
  /**
88
- * @ignore
89
- */
88
+ * @ignore
89
+ */
90
90
  hideSelectBtn = false;
91
91
  /**
92
- * @ignore
93
- */
92
+ * @ignore
93
+ */
94
94
  allowedFiles = [];
95
95
  /**
96
- * @ignore
97
- */
96
+ * @ignore
97
+ */
98
98
  notAllowedFiles = [];
99
99
  /**
100
- * @ignore
101
- */
100
+ * @ignore
101
+ */
102
102
  Caption = [];
103
103
  /**
104
- * @ignore
105
- */
104
+ * @ignore
105
+ */
106
106
  isAllowedFileSingle = true;
107
107
  /**
108
- * @ignore
109
- */
108
+ * @ignore
109
+ */
110
110
  progressBarShow = false;
111
111
  /**
112
- * @ignore
113
- */
112
+ * @ignore
113
+ */
114
114
  enableUploadBtn = false;
115
115
  /**
116
- * @ignore
117
- */
116
+ * @ignore
117
+ */
118
118
  uploadMsg = false;
119
119
  /**
120
- * @ignore
121
- */
120
+ * @ignore
121
+ */
122
122
  afterUpload = false;
123
123
  /**
124
- * @ignore
125
- */
124
+ * @ignore
125
+ */
126
126
  uploadStarted = false;
127
127
  /**
128
- * @ignore
129
- */
130
- uploadMsgText = "";
128
+ * @ignore
129
+ */
130
+ uploadMsgText = '';
131
131
  /**
132
- * @ignore
133
- */
132
+ * @ignore
133
+ */
134
134
  uploadMsgClass = 'text-success';
135
135
  /**
136
- * @ignore
137
- */
136
+ * @ignore
137
+ */
138
138
  uploadPercent = 0;
139
139
  /**
140
- * @ignore
141
- */
140
+ * @ignore
141
+ */
142
142
  replaceTexts = {
143
143
  selectFileBtn: 'Selecionar Arquivo',
144
144
  resetBtn: 'Resetar',
@@ -150,31 +150,31 @@ export class UploadComponent {
150
150
  sizeLimit: 'Tamanho máximo',
151
151
  };
152
152
  /**
153
- * @ignore
154
- */
153
+ * @ignore
154
+ */
155
155
  currentUploads = [];
156
156
  /**
157
- * @ignore
158
- */
157
+ * @ignore
158
+ */
159
159
  fileNameIndex = true;
160
160
  /**
161
- * @ignore
162
- */
161
+ * @ignore
162
+ */
163
163
  withCredentials = false;
164
164
  /**
165
- * @ignore
166
- */
165
+ * @ignore
166
+ */
167
167
  autoUpload = true;
168
168
  /**
169
- * @ignore
170
- */
169
+ * @ignore
170
+ */
171
171
  idDate = +new Date();
172
172
  constructor(http) {
173
173
  this.http = http;
174
174
  }
175
175
  /**
176
- * @ignore
177
- */
176
+ * @ignore
177
+ */
178
178
  ngOnChanges(changes) {
179
179
  // Track changes in Configuration and see if user has even provided Configuration.
180
180
  if (changes.config && this.config) {
@@ -198,7 +198,8 @@ export class UploadComponent {
198
198
  this.responseType = this.config.uploadAPI.responseType || 'json';
199
199
  this.withCredentials = this.config.uploadAPI.withCredentials || false;
200
200
  }
201
- this.formatsAllowedText = this.formatsAllowed === '*' ? '' : '(' + this.formatsAllowed + ')';
201
+ this.formatsAllowedText =
202
+ this.formatsAllowed === '*' ? '' : '(' + this.formatsAllowed + ')';
202
203
  this.fileNameIndex = this.config.fileNameIndex === false ? false : true;
203
204
  this.autoUpload = this.config.autoUpload || false;
204
205
  if (this.config.replaceTexts) {
@@ -244,7 +245,9 @@ export class UploadComponent {
244
245
  // tslint:disable-next-line: for-of
245
246
  for (let i = 0; i < fileList.length; i++) {
246
247
  const _currentFileExt = fileExtRegExp.exec(fileList[i].name);
247
- const currentFileExt = typeof _currentFileExt[1] === 'string' ? _currentFileExt[1].toLowerCase() : '';
248
+ const currentFileExt = typeof _currentFileExt[1] === 'string'
249
+ ? _currentFileExt[1].toLowerCase()
250
+ : '';
248
251
  const isFormatValid = this.formatsAllowed.includes('*')
249
252
  ? true
250
253
  : this.formatsAllowed.includes(currentFileExt);
@@ -314,7 +317,9 @@ export class UploadComponent {
314
317
  this.uploadMsg = true;
315
318
  this.afterUpload = true;
316
319
  if (!isError) {
317
- this.uploadMsgText = this.replaceTexts.afterUploadMsg_success || 'Successfully Uploaded !';
320
+ this.uploadMsgText =
321
+ this.replaceTexts.afterUploadMsg_success ||
322
+ 'Successfully Uploaded !';
318
323
  this.uploadMsgClass = 'text-success lead';
319
324
  }
320
325
  }
@@ -340,7 +345,8 @@ export class UploadComponent {
340
345
  this.enableUploadBtn = false;
341
346
  this.uploadMsg = true;
342
347
  this.afterUpload = true;
343
- this.uploadMsgText = this.replaceTexts.afterUploadMsg_error || 'Error in uploading files';
348
+ this.uploadMsgText =
349
+ this.replaceTexts.afterUploadMsg_error || 'Error in uploading files';
344
350
  this.uploadMsgClass = 'text-danger lead';
345
351
  }
346
352
  removeFile(i, sf_na) {
@@ -377,11 +383,11 @@ export class UploadComponent {
377
383
  event.dataTransfer.dropEffect = 'copy';
378
384
  }
379
385
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: UploadComponent, deps: [{ token: i1.HttpClient, skipSelf: true }], target: i0.ɵɵFactoryTarget.Component });
380
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: UploadComponent, isStandalone: true, selector: "wco-file-upload", inputs: { description: "description", config: "config", resetUpload: "resetUpload" }, outputs: { ApiResponse: "apiResponse", fileSelected: "fileSelected" }, usesOnChanges: true, ngImport: i0, template: "<label for=\"sel{{id}}\" class=\"wco-file-upload\" (drop)=\"drop($event)\" (dragover)=\"allowDrop($event)\">\n <div class=\"upload__drop-info\">\n <span>Arraste-os aqui ou</span>\n <div class=\"upload__button\">\n <span class=\"material-icons\">cloud_upload</span>\n <span>{{replaceTexts.selectFileBtn}}</span>\n </div>\n </div>\n <span class=\"upload__info\" *ngIf=\"!allowedFiles.length\" >{{description}}</span>\n <ng-container *ngIf=\"allowedFiles.length\">\n <span class=\"upload__info\" *ngFor=\"let sf of allowedFiles;let i=index\">\n {{sf.name}} <small>({{convertSize(sf.size)}})</small>\n </span>\n </ng-container>\n <input class=\"upload__file\" type=\"file\" id=\"sel{{id}}\" (change)=\"onChange($event)\" style=\"display: none\" title=\"Select file\"\n name=\"files[]\" [accept]=\"formatsAllowed\" [attr.multiple]=\"multiple ? '' : null\" />\n</label>\n", styles: [".wco-file-upload{--color-button: var(--wco-color-primary-600);--color-button-hover: var(--wco-color-primary-700);border:2px dashed #c1c3c5;border-radius:10px;padding:10px;display:flex;flex-direction:column;align-items:center;gap:12px;cursor:pointer}.wco-file-upload .upload__drop-info{display:inherit;justify-content:center;align-items:center;gap:16px}.wco-file-upload .upload__button{display:inherit;justify-content:center;gap:8px;padding:10px 0}.wco-file-upload .upload__button span,.wco-file-upload .upload__button label{color:var(--color-button);cursor:pointer}.wco-file-upload .upload__file{display:none}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: HttpClientModule }] });
386
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: UploadComponent, isStandalone: true, selector: "wco-file-upload", inputs: { description: "description", config: "config", resetUpload: "resetUpload" }, outputs: { ApiResponse: "apiResponse", fileSelected: "fileSelected" }, usesOnChanges: true, ngImport: i0, template: "<label for=\"sel{{id}}\" class=\"wco-form-upload\" (drop)=\"drop($event)\" (dragover)=\"allowDrop($event)\">\n <div class=\"wco-form-upload__info\">\n <span>Arraste-os aqui ou</span>\n <span>\n <span class=\"material-icons\">cloud_upload</span>\n <span>{{replaceTexts.selectFileBtn}}</span>\n </span>\n </div>\n <span class=\"upload__info\" *ngIf=\"!allowedFiles.length\" >{{description}}</span>\n <ng-container *ngIf=\"allowedFiles.length\">\n <span class=\"upload__info\" *ngFor=\"let sf of allowedFiles;let i=index\">\n {{sf.name}} <small>({{convertSize(sf.size)}})</small>\n </span>\n </ng-container>\n <input type=\"file\" id=\"sel{{id}}\" (change)=\"onChange($event)\" style=\"display: none\" title=\"Select file\"\n name=\"files[]\" [accept]=\"formatsAllowed\" [attr.multiple]=\"multiple ? '' : null\" />\n</label>", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: HttpClientModule }] });
381
387
  }
382
388
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: UploadComponent, decorators: [{
383
389
  type: Component,
384
- args: [{ selector: "wco-file-upload", standalone: true, imports: [CommonModule, HttpClientModule], template: "<label for=\"sel{{id}}\" class=\"wco-file-upload\" (drop)=\"drop($event)\" (dragover)=\"allowDrop($event)\">\n <div class=\"upload__drop-info\">\n <span>Arraste-os aqui ou</span>\n <div class=\"upload__button\">\n <span class=\"material-icons\">cloud_upload</span>\n <span>{{replaceTexts.selectFileBtn}}</span>\n </div>\n </div>\n <span class=\"upload__info\" *ngIf=\"!allowedFiles.length\" >{{description}}</span>\n <ng-container *ngIf=\"allowedFiles.length\">\n <span class=\"upload__info\" *ngFor=\"let sf of allowedFiles;let i=index\">\n {{sf.name}} <small>({{convertSize(sf.size)}})</small>\n </span>\n </ng-container>\n <input class=\"upload__file\" type=\"file\" id=\"sel{{id}}\" (change)=\"onChange($event)\" style=\"display: none\" title=\"Select file\"\n name=\"files[]\" [accept]=\"formatsAllowed\" [attr.multiple]=\"multiple ? '' : null\" />\n</label>\n", styles: [".wco-file-upload{--color-button: var(--wco-color-primary-600);--color-button-hover: var(--wco-color-primary-700);border:2px dashed #c1c3c5;border-radius:10px;padding:10px;display:flex;flex-direction:column;align-items:center;gap:12px;cursor:pointer}.wco-file-upload .upload__drop-info{display:inherit;justify-content:center;align-items:center;gap:16px}.wco-file-upload .upload__button{display:inherit;justify-content:center;gap:8px;padding:10px 0}.wco-file-upload .upload__button span,.wco-file-upload .upload__button label{color:var(--color-button);cursor:pointer}.wco-file-upload .upload__file{display:none}\n"] }]
390
+ args: [{ selector: 'wco-file-upload', standalone: true, imports: [CommonModule, HttpClientModule], template: "<label for=\"sel{{id}}\" class=\"wco-form-upload\" (drop)=\"drop($event)\" (dragover)=\"allowDrop($event)\">\n <div class=\"wco-form-upload__info\">\n <span>Arraste-os aqui ou</span>\n <span>\n <span class=\"material-icons\">cloud_upload</span>\n <span>{{replaceTexts.selectFileBtn}}</span>\n </span>\n </div>\n <span class=\"upload__info\" *ngIf=\"!allowedFiles.length\" >{{description}}</span>\n <ng-container *ngIf=\"allowedFiles.length\">\n <span class=\"upload__info\" *ngFor=\"let sf of allowedFiles;let i=index\">\n {{sf.name}} <small>({{convertSize(sf.size)}})</small>\n </span>\n </ng-container>\n <input type=\"file\" id=\"sel{{id}}\" (change)=\"onChange($event)\" style=\"display: none\" title=\"Select file\"\n name=\"files[]\" [accept]=\"formatsAllowed\" [attr.multiple]=\"multiple ? '' : null\" />\n</label>" }]
385
391
  }], ctorParameters: function () { return [{ type: i1.HttpClient, decorators: [{
386
392
  type: SkipSelf
387
393
  }] }]; }, propDecorators: { description: [{
@@ -396,4 +402,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
396
402
  }], fileSelected: [{
397
403
  type: Output
398
404
  }] } });
399
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upload.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-components/src/lib/upload/upload.component.ts","../../../../../projects/ngx-components/src/lib/upload/upload.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input, OnChanges, Output, SkipSelf\n} from '@angular/core';\n\nimport {\n  HttpClient,\n  HttpClientModule,\n  HttpEventType, HttpHeaders,\n  HttpParams\n} from '@angular/common/http';\n\n\n\nimport { CommonModule } from '@angular/common';\nimport { AngularFileUploaderConfig, ReplaceTexts, UploadInfoTypes } from \"./upload.types\";\n\n@Component({\n  selector: \"wco-file-upload\",\n  standalone: true,\n  imports: [CommonModule, HttpClientModule],\n  templateUrl: \"./upload.component.html\",\n  styleUrls: [\"./upload.component.scss\"],\n})\n\nexport class UploadComponent implements OnChanges {\n  /* Texto de descrição do arquivo */\n  @Input() description: string = \"(XX MB de tamanho máximo e é permitido qualquer tipo de arquivos)\"\n  /* config <AngularFileUploaderConfig> configuração do componente principais parâmetros */\n  @Input() config: AngularFileUploaderConfig = {\n    uploadAPI: {\n      url: '',\n      method: 'POST',\n      headers: {\n        'Content-Type': 'text/plain;charset=UTF-8',\n      },\n      responseType: 'json',\n      withCredentials: false,\n    }\n  };\n\n\n  /*\n  * Opção de resetar o componente\n  */\n  @Input() resetUpload = false;\n\n  /*\n  * Evento Resposta da requisição sendo sucesso ou erro\n  */\n  @Output('apiResponse') ApiResponse = new EventEmitter();\n  /*\n  * Evento javascript puro para retorno do arquivo\n  */\n  @Output() fileSelected: EventEmitter<UploadInfoTypes[]> = new EventEmitter<UploadInfoTypes[]>();\n\n  /**\n  * @ignore\n  */\n  theme: string = '';\n  /**\n  * @ignore\n  */\n  id: number = 0;\n  /**\n  * @ignore\n  */\n  hideProgressBar: boolean = false;\n  /**\n  * @ignore\n  */\n  maxSize: number = 20 * 1024000; // mb to bytes.\n  /**\n  * @ignore\n  */\n  uploadAPI: string = '';\n  /**\n  * @ignore\n  */\n  method: string = 'POST';\n  /**\n  * @ignore\n  */\n  formatsAllowed: string = '*';\n  /**\n  * @ignore\n  */\n  formatsAllowedText: string = '';\n  /**\n  * @ignore\n  */\n  multiple: boolean = false;\n  /**\n  * @ignore\n  */\n  headers: HttpHeaders | { [header: string]: string | string[] } = {}\n  /**\n  * @ignore\n  */\n  params: HttpParams | { [param: string]: string | string[] } = {}\n  /**\n  * @ignore\n  */\n  responseType: 'json' | 'arraybuffer' | 'blob' | 'text' = 'blob';\n  /**\n  * @ignore\n  */\n  hideResetBtn: boolean = false;\n  /**\n  * @ignore\n  */\n  hideSelectBtn: boolean = false;\n  /**\n  * @ignore\n  */\n  allowedFiles: File[] = [];\n  /**\n  * @ignore\n  */\n  notAllowedFiles: {\n    fileName: string;\n    fileSize: string;\n    errorMsg: string;\n  }[] = [];\n  /**\n  * @ignore\n  */\n  Caption: string[] = [];\n  /**\n  * @ignore\n  */\n  isAllowedFileSingle = true;\n  /**\n  * @ignore\n  */\n  progressBarShow = false;\n  /**\n  * @ignore\n  */\n  enableUploadBtn = false;\n  /**\n  * @ignore\n  */\n  uploadMsg = false;\n  /**\n  * @ignore\n  */\n  afterUpload = false;\n  /**\n  * @ignore\n  */\n  uploadStarted = false;\n  /**\n  * @ignore\n  */\n  uploadMsgText: string = \"\"\n  /**\n  * @ignore\n  */\n  uploadMsgClass: string = 'text-success';\n  /**\n  * @ignore\n  */\n  uploadPercent: number = 0;\n  /**\n  * @ignore\n  */\n  replaceTexts: ReplaceTexts = {\n    selectFileBtn: 'Selecionar Arquivo',\n    resetBtn: 'Resetar',\n    uploadBtn: 'Enviar',\n    dragNDropBox: 'Arraste e solte',\n    attachPinBtn: 'Anexar Arquivo...',\n    afterUploadMsg_success: 'Enviado com sucesso !',\n    afterUploadMsg_error: 'Falha no envio !',\n    sizeLimit: 'Tamanho máximo',\n  }\n  /**\n  * @ignore\n  */\n  currentUploads: any[] = [];\n  /**\n  * @ignore\n  */\n  fileNameIndex = true;\n  /**\n  * @ignore\n  */\n  withCredentials = false;\n  /**\n  * @ignore\n  */\n  autoUpload = true;\n  /**\n  * @ignore\n  */\n  private idDate: number = +new Date();\n\n  constructor(@SkipSelf() private http: HttpClient) {}\n\n  /**\n  * @ignore\n  */\n  ngOnChanges(changes: any) {\n    // Track changes in Configuration and see if user has even provided Configuration.\n    if (changes.config && this.config) {\n      // Assign User Configurations to Library Properties.\n      this.theme = this.config.theme || '';\n      this.id =\n        this.config.id ||\n        parseInt((this.idDate / 10000).toString().split('.')[1], 10) +\n          Math.floor(Math.random() * 20) * 10000;\n      this.hideProgressBar = this.config.hideProgressBar || false;\n      this.hideResetBtn = this.config.hideResetBtn || false;\n      this.hideSelectBtn = this.config.hideSelectBtn || false;\n      this.maxSize = (this.config.maxSize || 20) * 1024000; // mb to bytes.\n      if(this.config.uploadAPI) {\n        this.uploadAPI = this.config.uploadAPI.url ;\n        this.method = this.config.uploadAPI.method || 'POST';\n        this.formatsAllowed = this.config.formatsAllowed || '*';\n        this.multiple = this.config.multiple || false;\n        this.headers = this.config.uploadAPI.headers || {};\n        this.params = this.config.uploadAPI.params || {};\n        this.responseType = this.config.uploadAPI.responseType || 'json';\n        this.withCredentials = this.config.uploadAPI.withCredentials || false;\n      }\n      this.formatsAllowedText = this.formatsAllowed === '*' ? '' : '(' + this.formatsAllowed + ')';\n      this.fileNameIndex = this.config.fileNameIndex === false ? false : true;\n      this.autoUpload = this.config.autoUpload || false;\n      if (this.config.replaceTexts) {\n        this.replaceTexts = {\n          ...this.replaceTexts,\n          ...this.config.replaceTexts,\n        };\n      }\n    }\n\n    // Reset when resetUpload value changes from false to true.\n    if (changes.resetUpload) {\n      if (changes.resetUpload.currentValue === true) {\n        this.resetFileUpload();\n      }\n    }\n  }\n\n  /* Função resetar componente */\n  resetFileUpload() {\n    this.allowedFiles = [];\n    this.Caption = [];\n    this.notAllowedFiles = [];\n    this.uploadMsg = false;\n    this.enableUploadBtn = false;\n  }\n\n  /* Detectar mudança  */\n  onChange(event: any) {\n    this.fileSelected.emit(event);\n    this.notAllowedFiles = [];\n    const fileExtRegExp: RegExp = /(?:\\.([^.]+))?$/;\n    let fileList: FileList;\n\n    if (this.afterUpload || !this.multiple) {\n      this.allowedFiles = [];\n      this.Caption = [];\n      this.afterUpload = false;\n    }\n\n    if (event.type === 'drop') {\n      fileList = event.dataTransfer.files;\n    } else {\n      fileList = event.target.files || event.srcElement.files;\n    }\n\n    // 'forEach' does not exist on 'filelist' that's why this good old 'for' is used.\n    // tslint:disable-next-line: for-of\n    for (let i = 0; i < fileList.length; i++) {\n      const _currentFileExt: any = fileExtRegExp.exec(fileList[i].name);\n      const currentFileExt = typeof _currentFileExt[1] === 'string' ? _currentFileExt[1].toLowerCase() : '';\n      const isFormatValid = this.formatsAllowed.includes('*')\n        ? true\n        : this.formatsAllowed.includes(currentFileExt);\n\n      const isSizeValid = fileList[i].size <= this.maxSize;\n\n      // Check whether current file format and size is correct as specified in the configurations.\n      if (isFormatValid && isSizeValid) {\n        this.allowedFiles.push(fileList[i]);\n      } else {\n        this.notAllowedFiles.push({\n          fileName: fileList[i].name,\n          fileSize: this.convertSize(fileList[i].size),\n          errorMsg: !isFormatValid ? 'Invalid format' : 'Invalid size',\n        });\n      }\n    }\n\n\n    // If there's any allowedFiles.\n    if (this.allowedFiles.length > 0) {\n      this.enableUploadBtn = true;\n      // Upload the files directly if theme is attach pin (as upload btn is not there for this theme) or autoUpload is true.\n      if (this.theme === 'attachPin' || this.autoUpload) {\n        this.uploadFiles();\n      }\n    } else {\n      this.enableUploadBtn = false;\n    }\n\n    this.uploadMsg = false;\n    this.uploadStarted = false;\n    this.uploadPercent = 0;\n    event.target.value = null;\n  }\n\n  /* Função para enviar arquivo para servidor */\n  uploadFiles() {\n    this.progressBarShow = true;\n    this.uploadStarted = true;\n    this.notAllowedFiles = [];\n    let isError = false;\n    this.isAllowedFileSingle = this.allowedFiles.length <= 1;\n    const formData = new FormData();\n\n    // Add data to be sent in this request\n    this.allowedFiles.forEach((file, i) => {\n      formData.append(\n        this.Caption[i] || 'file' + (this.fileNameIndex ? i : ''),\n        this.allowedFiles[i]\n      );\n    });\n\n\n    this.http\n      .request(this.method.toUpperCase(), this.uploadAPI, {\n        body: formData,\n        reportProgress: true,\n        observe: 'events',\n        headers: this.headers,\n        params: this.params,\n        responseType: this.responseType,\n        withCredentials: this.withCredentials,\n      })\n      .subscribe(\n        (event) => {\n          // Upload Progress\n          if (event.type === HttpEventType.UploadProgress) {\n            this.enableUploadBtn = false; // button should be disabled if process uploading\n            const currentDone = event.loaded / event.total;\n            this.uploadPercent = Math.round((event.loaded / event.total) * 100);\n          } else if (event.type === HttpEventType.Response) {\n            if (event.status === 200 || event.status === 201) {\n              // Success\n              this.progressBarShow = false;\n              this.enableUploadBtn = false;\n              this.uploadMsg = true;\n              this.afterUpload = true;\n              if (!isError) {\n                this.uploadMsgText = this.replaceTexts.afterUploadMsg_success || 'Successfully Uploaded !';\n                this.uploadMsgClass = 'text-success lead';\n              }\n            } else {\n              // Failure\n              isError = true;\n              this.handleErrors();\n            }\n            this.ApiResponse.emit(event);\n          } else {\n            //console.log('Event Other: ', event);\n          }\n        },\n        (error) => {\n          // Failure\n          isError = true;\n          this.handleErrors();\n          this.ApiResponse.emit(error);\n        }\n      );\n  }\n\n  handleErrors() {\n    this.progressBarShow = false;\n    this.enableUploadBtn = false;\n    this.uploadMsg = true;\n    this.afterUpload = true;\n    this.uploadMsgText = this.replaceTexts.afterUploadMsg_error || 'Error in uploading files';\n    this.uploadMsgClass = 'text-danger lead';\n  }\n\n  removeFile(i: any, sf_na: any) {\n    if (sf_na === 'sf') {\n      this.allowedFiles.splice(i, 1);\n      this.Caption.splice(i, 1);\n    } else {\n      this.notAllowedFiles.splice(i, 1);\n    }\n\n    if (this.allowedFiles.length === 0) {\n      this.enableUploadBtn = false;\n    }\n  }\n\n  convertSize(fileSize: number): string {\n    return fileSize < 1024000\n      ? (fileSize / 1024).toFixed(2) + ' KB'\n      : (fileSize / 1024000).toFixed(2) + ' MB';\n  }\n\n  attachpinOnclick() {\n    const element = document.getElementById('sel' + this.id);\n    if (element !== null) {\n      element.click();\n    }\n  }\n\n  drop(event: any) {\n    event.stopPropagation();\n    event.preventDefault();\n    this.onChange(event);\n  }\n\n  allowDrop(event: any) {\n    event.stopPropagation();\n    event.preventDefault();\n    event.dataTransfer.dropEffect = 'copy';\n  }\n}\n","<label for=\"sel{{id}}\" class=\"wco-file-upload\" (drop)=\"drop($event)\" (dragover)=\"allowDrop($event)\">\n  <div class=\"upload__drop-info\">\n    <span>Arraste-os aqui ou</span>\n    <div class=\"upload__button\">\n      <span class=\"material-icons\">cloud_upload</span>\n      <span>{{replaceTexts.selectFileBtn}}</span>\n    </div>\n  </div>\n  <span class=\"upload__info\" *ngIf=\"!allowedFiles.length\" >{{description}}</span>\n  <ng-container *ngIf=\"allowedFiles.length\">\n    <span class=\"upload__info\" *ngFor=\"let sf of allowedFiles;let i=index\">\n      {{sf.name}} <small>({{convertSize(sf.size)}})</small>\n    </span>\n  </ng-container>\n  <input class=\"upload__file\" type=\"file\" id=\"sel{{id}}\" (change)=\"onChange($event)\" style=\"display: none\" title=\"Select file\"\n  name=\"files[]\" [accept]=\"formatsAllowed\" [attr.multiple]=\"multiple ? '' : null\" />\n</label>\n"]}
405
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upload.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-components/src/lib/upload/upload.component.ts","../../../../../projects/ngx-components/src/lib/upload/upload.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  Output,\n  SkipSelf,\n} from '@angular/core';\n\nimport {\n  HttpClient,\n  HttpClientModule,\n  HttpEventType,\n  HttpHeaders,\n  HttpParams,\n} from '@angular/common/http';\n\nimport { CommonModule } from '@angular/common';\nimport {\n  AngularFileUploaderConfig,\n  ReplaceTexts,\n  UploadInfoTypes,\n} from './upload.types';\n\n@Component({\n  selector: 'wco-file-upload',\n  standalone: true,\n  imports: [CommonModule, HttpClientModule],\n  templateUrl: './upload.component.html',\n  styleUrls: ['./upload.component.scss'],\n})\nexport class UploadComponent implements OnChanges {\n  /* Texto de descrição do arquivo */\n  @Input() description: string =\n    '(XX MB de tamanho máximo e é permitido qualquer tipo de arquivos)';\n  /* config <AngularFileUploaderConfig> configuração do componente principais parâmetros */\n  @Input() config: AngularFileUploaderConfig = {\n    uploadAPI: {\n      url: '',\n      method: 'POST',\n      headers: {\n        'Content-Type': 'text/plain;charset=UTF-8',\n      },\n      responseType: 'json',\n      withCredentials: false,\n    },\n  };\n\n  /*\n   * Opção de resetar o componente\n   */\n  @Input() resetUpload = false;\n\n  /*\n   * Evento Resposta da requisição sendo sucesso ou erro\n   */\n  @Output('apiResponse') ApiResponse = new EventEmitter();\n  /*\n   * Evento javascript puro para retorno do arquivo\n   */\n  @Output() fileSelected: EventEmitter<UploadInfoTypes[]> = new EventEmitter<\n    UploadInfoTypes[]\n  >();\n\n  /**\n   * @ignore\n   */\n  theme: string = '';\n  /**\n   * @ignore\n   */\n  id: number = 0;\n  /**\n   * @ignore\n   */\n  hideProgressBar: boolean = false;\n  /**\n   * @ignore\n   */\n  maxSize: number = 20 * 1024000; // mb to bytes.\n  /**\n   * @ignore\n   */\n  uploadAPI: string = '';\n  /**\n   * @ignore\n   */\n  method: string = 'POST';\n  /**\n   * @ignore\n   */\n  formatsAllowed: string = '*';\n  /**\n   * @ignore\n   */\n  formatsAllowedText: string = '';\n  /**\n   * @ignore\n   */\n  multiple: boolean = false;\n  /**\n   * @ignore\n   */\n  headers: HttpHeaders | { [header: string]: string | string[] } = {};\n  /**\n   * @ignore\n   */\n  params: HttpParams | { [param: string]: string | string[] } = {};\n  /**\n   * @ignore\n   */\n  responseType: 'json' | 'arraybuffer' | 'blob' | 'text' = 'blob';\n  /**\n   * @ignore\n   */\n  hideResetBtn: boolean = false;\n  /**\n   * @ignore\n   */\n  hideSelectBtn: boolean = false;\n  /**\n   * @ignore\n   */\n  allowedFiles: File[] = [];\n  /**\n   * @ignore\n   */\n  notAllowedFiles: {\n    fileName: string;\n    fileSize: string;\n    errorMsg: string;\n  }[] = [];\n  /**\n   * @ignore\n   */\n  Caption: string[] = [];\n  /**\n   * @ignore\n   */\n  isAllowedFileSingle = true;\n  /**\n   * @ignore\n   */\n  progressBarShow = false;\n  /**\n   * @ignore\n   */\n  enableUploadBtn = false;\n  /**\n   * @ignore\n   */\n  uploadMsg = false;\n  /**\n   * @ignore\n   */\n  afterUpload = false;\n  /**\n   * @ignore\n   */\n  uploadStarted = false;\n  /**\n   * @ignore\n   */\n  uploadMsgText: string = '';\n  /**\n   * @ignore\n   */\n  uploadMsgClass: string = 'text-success';\n  /**\n   * @ignore\n   */\n  uploadPercent: number = 0;\n  /**\n   * @ignore\n   */\n  replaceTexts: ReplaceTexts = {\n    selectFileBtn: 'Selecionar Arquivo',\n    resetBtn: 'Resetar',\n    uploadBtn: 'Enviar',\n    dragNDropBox: 'Arraste e solte',\n    attachPinBtn: 'Anexar Arquivo...',\n    afterUploadMsg_success: 'Enviado com sucesso !',\n    afterUploadMsg_error: 'Falha no envio !',\n    sizeLimit: 'Tamanho máximo',\n  };\n  /**\n   * @ignore\n   */\n  currentUploads: any[] = [];\n  /**\n   * @ignore\n   */\n  fileNameIndex = true;\n  /**\n   * @ignore\n   */\n  withCredentials = false;\n  /**\n   * @ignore\n   */\n  autoUpload = true;\n  /**\n   * @ignore\n   */\n  private idDate: number = +new Date();\n\n  constructor(@SkipSelf() private http: HttpClient) {}\n\n  /**\n   * @ignore\n   */\n  ngOnChanges(changes: any) {\n    // Track changes in Configuration and see if user has even provided Configuration.\n    if (changes.config && this.config) {\n      // Assign User Configurations to Library Properties.\n      this.theme = this.config.theme || '';\n      this.id =\n        this.config.id ||\n        parseInt((this.idDate / 10000).toString().split('.')[1], 10) +\n          Math.floor(Math.random() * 20) * 10000;\n      this.hideProgressBar = this.config.hideProgressBar || false;\n      this.hideResetBtn = this.config.hideResetBtn || false;\n      this.hideSelectBtn = this.config.hideSelectBtn || false;\n      this.maxSize = (this.config.maxSize || 20) * 1024000; // mb to bytes.\n      if (this.config.uploadAPI) {\n        this.uploadAPI = this.config.uploadAPI.url;\n        this.method = this.config.uploadAPI.method || 'POST';\n        this.formatsAllowed = this.config.formatsAllowed || '*';\n        this.multiple = this.config.multiple || false;\n        this.headers = this.config.uploadAPI.headers || {};\n        this.params = this.config.uploadAPI.params || {};\n        this.responseType = this.config.uploadAPI.responseType || 'json';\n        this.withCredentials = this.config.uploadAPI.withCredentials || false;\n      }\n      this.formatsAllowedText =\n        this.formatsAllowed === '*' ? '' : '(' + this.formatsAllowed + ')';\n      this.fileNameIndex = this.config.fileNameIndex === false ? false : true;\n      this.autoUpload = this.config.autoUpload || false;\n      if (this.config.replaceTexts) {\n        this.replaceTexts = {\n          ...this.replaceTexts,\n          ...this.config.replaceTexts,\n        };\n      }\n    }\n\n    // Reset when resetUpload value changes from false to true.\n    if (changes.resetUpload) {\n      if (changes.resetUpload.currentValue === true) {\n        this.resetFileUpload();\n      }\n    }\n  }\n\n  /* Função resetar componente */\n  resetFileUpload() {\n    this.allowedFiles = [];\n    this.Caption = [];\n    this.notAllowedFiles = [];\n    this.uploadMsg = false;\n    this.enableUploadBtn = false;\n  }\n\n  /* Detectar mudança  */\n  onChange(event: any) {\n    this.fileSelected.emit(event);\n    this.notAllowedFiles = [];\n    const fileExtRegExp: RegExp = /(?:\\.([^.]+))?$/;\n    let fileList: FileList;\n\n    if (this.afterUpload || !this.multiple) {\n      this.allowedFiles = [];\n      this.Caption = [];\n      this.afterUpload = false;\n    }\n\n    if (event.type === 'drop') {\n      fileList = event.dataTransfer.files;\n    } else {\n      fileList = event.target.files || event.srcElement.files;\n    }\n\n    // 'forEach' does not exist on 'filelist' that's why this good old 'for' is used.\n    // tslint:disable-next-line: for-of\n    for (let i = 0; i < fileList.length; i++) {\n      const _currentFileExt: any = fileExtRegExp.exec(fileList[i].name);\n      const currentFileExt =\n        typeof _currentFileExt[1] === 'string'\n          ? _currentFileExt[1].toLowerCase()\n          : '';\n      const isFormatValid = this.formatsAllowed.includes('*')\n        ? true\n        : this.formatsAllowed.includes(currentFileExt);\n\n      const isSizeValid = fileList[i].size <= this.maxSize;\n\n      // Check whether current file format and size is correct as specified in the configurations.\n      if (isFormatValid && isSizeValid) {\n        this.allowedFiles.push(fileList[i]);\n      } else {\n        this.notAllowedFiles.push({\n          fileName: fileList[i].name,\n          fileSize: this.convertSize(fileList[i].size),\n          errorMsg: !isFormatValid ? 'Invalid format' : 'Invalid size',\n        });\n      }\n    }\n\n    // If there's any allowedFiles.\n    if (this.allowedFiles.length > 0) {\n      this.enableUploadBtn = true;\n      // Upload the files directly if theme is attach pin (as upload btn is not there for this theme) or autoUpload is true.\n      if (this.theme === 'attachPin' || this.autoUpload) {\n        this.uploadFiles();\n      }\n    } else {\n      this.enableUploadBtn = false;\n    }\n\n    this.uploadMsg = false;\n    this.uploadStarted = false;\n    this.uploadPercent = 0;\n    event.target.value = null;\n  }\n\n  /* Função para enviar arquivo para servidor */\n  uploadFiles() {\n    this.progressBarShow = true;\n    this.uploadStarted = true;\n    this.notAllowedFiles = [];\n    let isError = false;\n    this.isAllowedFileSingle = this.allowedFiles.length <= 1;\n    const formData = new FormData();\n\n    // Add data to be sent in this request\n    this.allowedFiles.forEach((file, i) => {\n      formData.append(\n        this.Caption[i] || 'file' + (this.fileNameIndex ? i : ''),\n        this.allowedFiles[i]\n      );\n    });\n\n    this.http\n      .request(this.method.toUpperCase(), this.uploadAPI, {\n        body: formData,\n        reportProgress: true,\n        observe: 'events',\n        headers: this.headers,\n        params: this.params,\n        responseType: this.responseType,\n        withCredentials: this.withCredentials,\n      })\n      .subscribe(\n        (event) => {\n          // Upload Progress\n          if (event.type === HttpEventType.UploadProgress) {\n            this.enableUploadBtn = false; // button should be disabled if process uploading\n            const currentDone = event.loaded / event.total;\n            this.uploadPercent = Math.round((event.loaded / event.total) * 100);\n          } else if (event.type === HttpEventType.Response) {\n            if (event.status === 200 || event.status === 201) {\n              // Success\n              this.progressBarShow = false;\n              this.enableUploadBtn = false;\n              this.uploadMsg = true;\n              this.afterUpload = true;\n              if (!isError) {\n                this.uploadMsgText =\n                  this.replaceTexts.afterUploadMsg_success ||\n                  'Successfully Uploaded !';\n                this.uploadMsgClass = 'text-success lead';\n              }\n            } else {\n              // Failure\n              isError = true;\n              this.handleErrors();\n            }\n            this.ApiResponse.emit(event);\n          } else {\n            //console.log('Event Other: ', event);\n          }\n        },\n        (error) => {\n          // Failure\n          isError = true;\n          this.handleErrors();\n          this.ApiResponse.emit(error);\n        }\n      );\n  }\n\n  handleErrors() {\n    this.progressBarShow = false;\n    this.enableUploadBtn = false;\n    this.uploadMsg = true;\n    this.afterUpload = true;\n    this.uploadMsgText =\n      this.replaceTexts.afterUploadMsg_error || 'Error in uploading files';\n    this.uploadMsgClass = 'text-danger lead';\n  }\n\n  removeFile(i: any, sf_na: any) {\n    if (sf_na === 'sf') {\n      this.allowedFiles.splice(i, 1);\n      this.Caption.splice(i, 1);\n    } else {\n      this.notAllowedFiles.splice(i, 1);\n    }\n\n    if (this.allowedFiles.length === 0) {\n      this.enableUploadBtn = false;\n    }\n  }\n\n  convertSize(fileSize: number): string {\n    return fileSize < 1024000\n      ? (fileSize / 1024).toFixed(2) + ' KB'\n      : (fileSize / 1024000).toFixed(2) + ' MB';\n  }\n\n  attachpinOnclick() {\n    const element = document.getElementById('sel' + this.id);\n    if (element !== null) {\n      element.click();\n    }\n  }\n\n  drop(event: any) {\n    event.stopPropagation();\n    event.preventDefault();\n    this.onChange(event);\n  }\n\n  allowDrop(event: any) {\n    event.stopPropagation();\n    event.preventDefault();\n    event.dataTransfer.dropEffect = 'copy';\n  }\n}\n","<label for=\"sel{{id}}\" class=\"wco-form-upload\" (drop)=\"drop($event)\" (dragover)=\"allowDrop($event)\">\n  <div class=\"wco-form-upload__info\">\n    <span>Arraste-os aqui ou</span>\n    <span>\n      <span class=\"material-icons\">cloud_upload</span>\n      <span>{{replaceTexts.selectFileBtn}}</span>\n    </span>\n  </div>\n  <span class=\"upload__info\" *ngIf=\"!allowedFiles.length\" >{{description}}</span>\n  <ng-container *ngIf=\"allowedFiles.length\">\n    <span class=\"upload__info\" *ngFor=\"let sf of allowedFiles;let i=index\">\n      {{sf.name}} <small>({{convertSize(sf.size)}})</small>\n    </span>\n  </ng-container>\n  <input type=\"file\" id=\"sel{{id}}\" (change)=\"onChange($event)\" style=\"display: none\" title=\"Select file\"\n  name=\"files[]\" [accept]=\"formatsAllowed\" [attr.multiple]=\"multiple ? '' : null\" />\n</label>"]}
@@ -35,11 +35,11 @@ export class UserAvatarComponent {
35
35
  this.userNameLetters = capitalizeLetters.toUpperCase();
36
36
  }
37
37
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: UserAvatarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
38
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: UserAvatarComponent, isStandalone: true, selector: "wco-avatar", inputs: { userName: ["name", "userName"], userAvatar: ["image", "userAvatar"], size: "size", theme: "theme", solid: "solid" }, usesOnChanges: true, ngImport: i0, template: "<div\r\n [class]=\"\r\n 'wco-user-avatar wco-user-avatar__size--' + size + ' wco-user-avatar__theme--' + theme + ' ' + (solid ? 'wco-user-solid' : '') \"\r\n [title]=\"userName\" >\r\n <span>{{userNameLetters}}</span>\r\n <img *ngIf=\"userAvatar\" [src]=\"userAvatar\" [alt]=\"userName\" />\r\n</div>\r\n", styles: [".wco-user-avatar{--wco-user-avatar-bg: var(--wco-color-secondary-50);--wco-user-avatar-color: var(--wco-color-secondary-500);overflow:hidden;position:relative;border-radius:50%;background:var(--wco-user-avatar-bg);display:flex;align-items:center;justify-content:center;border:1px solid var(--wco-user-avatar-color, #576ff7);width:var(--wco-size-xy-user-photo, 48px);height:var(--wco-size-xy-user-photo, 48px)}.wco-user-avatar.wco-user-avatar__size--xs{--wco-size-xy-user-photo: 24px;--wco-size-user-photo: 11px}.wco-user-avatar.wco-user-avatar__size--sm{--wco-size-xy-user-photo: 32px;--wco-size-user-photo: 14px}.wco-user-avatar.wco-user-avatar__size--md{--wco-size-xy-user-photo: 48px;--wco-size-user-photo: 16px}.wco-user-avatar.wco-user-avatar__size--lg{--wco-size-xy-user-photo: 56px;--wco-size-user-photo: 18px}.wco-user-avatar.wco-user-avatar__size--xl{--wco-size-xy-user-photo: 90px;--wco-size-user-photo: 20px}.wco-user-avatar .wco-user-avatar__theme--primary{--wco-user-avatar-color: var(--wco-color-primary-500);--wco-user-avatar-bg: var(--wco-color-primary-50)}.wco-user-avatar .wco-user-avatar__theme--secondary{--wco-user-avatar-color: var(--wco-color-secondary-500);--wco-user-avatar-bg: var(--wco-color-secondary-50)}.wco-user-avatar .wco-user-avatar__theme--light{--wco-user-avatar-color: var(--wco-color-neutral-100);--wco-user-avatar-bg: var(--wco-color-neutral-900)}.wco-user-avatar .wco-user-avatar__theme--dark{--wco-user-avatar-color: var(--wco-color-neutral-700);--wco-user-avatar-bg: var(--wco-color-neutral-50)}.wco-user-avatar.wco-user-solid.wco-user-avatar__theme--primary{--wco-user-avatar-bg: var(--wco-color-primary-500);--wco-user-avatar-color: var(--wco-color-primary-50)}.wco-user-avatar.wco-user-solid.wco-user-avatar__theme--secondary{--wco-user-avatar-bg: var(--wco-color-secondary-500);--wco-user-avatar-color: var(--wco-color-secondary-50)}.wco-user-avatar.wco-user-solid.wco-user-avatar__theme--light{--wco-user-avatar-bg: var(--wco-color-neutral-100);--wco-user-avatar-color: var(--wco-color-neutral-900)}.wco-user-avatar.wco-user-solid.wco-user-avatar__theme--dark{--wco-user-avatar-bg: var(--wco-color-neutral-700);--wco-user-avatar-color: var(--wco-color-neutral-50)}.wco-user-avatar span,.wco-user-avatar img{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);padding:0;margin:0;display:block}.wco-user-avatar img{width:var(--wco-size-xy-user-photo);height:var(--wco-size-xy-user-photo);object-fit:cover}.wco-user-avatar span{font-family:var(--wco-font-family, \"Roboto\", sans-serif);width:var(--wco-size-xy-user-photo);text-align:center;font-weight:700;font-size:var(--wco-size-user-photo, 18px);color:var(--wco-user-avatar-color, #ffffff);letter-spacing:.4px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], encapsulation: i0.ViewEncapsulation.None });
38
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: UserAvatarComponent, isStandalone: true, selector: "wco-avatar", inputs: { userName: ["name", "userName"], userAvatar: ["image", "userAvatar"], size: "size", theme: "theme", solid: "solid" }, usesOnChanges: true, ngImport: i0, template: "<div\r\n [class]=\"\r\n 'wco-user-avatar wco-user-avatar__size--' + size + ' wco-user-avatar__theme--' + theme + ' ' + (solid ? 'wco-user-solid' : '') \"\r\n [title]=\"userName\" >\r\n <span>{{userNameLetters}}</span>\r\n <img *ngIf=\"userAvatar\" [src]=\"userAvatar\" [alt]=\"userName\" />\r\n</div>\r\n", styles: [".wco-user-avatar{--wco-user-avatar-bg: var(--wco-color-secondary-50);--wco-user-avatar-color: var(--wco-color-secondary-500);overflow:hidden;position:relative;border-radius:50%;background:var(--wco-user-avatar-bg);display:flex;align-items:center;justify-content:center;border:1px solid var(--wco-user-avatar-color, #576ff7);width:var(--wco-size-xy-user-photo, 48px);height:var(--wco-size-xy-user-photo, 48px)}.wco-user-avatar.wco-user-avatar__size--xs{--wco-size-xy-user-photo: 24px;--wco-size-user-photo: 11px}.wco-user-avatar.wco-user-avatar__size--sm{--wco-size-xy-user-photo: 32px;--wco-size-user-photo: 14px}.wco-user-avatar.wco-user-avatar__size--md{--wco-size-xy-user-photo: 48px;--wco-size-user-photo: 16px}.wco-user-avatar.wco-user-avatar__size--lg{--wco-size-xy-user-photo: 56px;--wco-size-user-photo: 18px}.wco-user-avatar.wco-user-avatar__size--xl{--wco-size-xy-user-photo: 90px;--wco-size-user-photo: 20px}.wco-user-avatar.wco-user-avatar__theme--primary{--wco-user-avatar-color: var(--wco-color-primary-500);--wco-user-avatar-bg: var(--wco-color-primary-50)}.wco-user-avatar.wco-user-avatar__theme--secondary{--wco-user-avatar-color: var(--wco-color-secondary-500);--wco-user-avatar-bg: var(--wco-color-secondary-50)}.wco-user-avatar.wco-user-avatar__theme--light{--wco-user-avatar-color: var(--wco-color-neutral-100);--wco-user-avatar-bg: var(--wco-color-neutral-900)}.wco-user-avatar.wco-user-avatar__theme--dark{--wco-user-avatar-color: var(--wco-color-neutral-700);--wco-user-avatar-bg: var(--wco-color-neutral-50)}.wco-user-avatar.wco-user-solid.wco-user-avatar__theme--primary{--wco-user-avatar-bg: var(--wco-color-primary-500);--wco-user-avatar-color: var(--wco-color-primary-50)}.wco-user-avatar.wco-user-solid.wco-user-avatar__theme--secondary{--wco-user-avatar-bg: var(--wco-color-secondary-500);--wco-user-avatar-color: var(--wco-color-secondary-50)}.wco-user-avatar.wco-user-solid.wco-user-avatar__theme--light{--wco-user-avatar-bg: var(--wco-color-neutral-100);--wco-user-avatar-color: var(--wco-color-neutral-900)}.wco-user-avatar.wco-user-solid.wco-user-avatar__theme--dark{--wco-user-avatar-bg: var(--wco-color-neutral-700);--wco-user-avatar-color: var(--wco-color-neutral-50)}.wco-user-avatar span,.wco-user-avatar img{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);padding:0;margin:0;display:block}.wco-user-avatar img{width:var(--wco-size-xy-user-photo);height:var(--wco-size-xy-user-photo);object-fit:cover}.wco-user-avatar span{font-family:var(--wco-font-family, \"Roboto\", sans-serif);width:var(--wco-size-xy-user-photo);text-align:center;font-weight:700;font-size:var(--wco-size-user-photo, 18px);color:var(--wco-user-avatar-color, #ffffff);letter-spacing:.4px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], encapsulation: i0.ViewEncapsulation.None });
39
39
  }
40
40
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: UserAvatarComponent, decorators: [{
41
41
  type: Component,
42
- args: [{ selector: 'wco-avatar', standalone: true, encapsulation: ViewEncapsulation.None, imports: [CommonModule], template: "<div\r\n [class]=\"\r\n 'wco-user-avatar wco-user-avatar__size--' + size + ' wco-user-avatar__theme--' + theme + ' ' + (solid ? 'wco-user-solid' : '') \"\r\n [title]=\"userName\" >\r\n <span>{{userNameLetters}}</span>\r\n <img *ngIf=\"userAvatar\" [src]=\"userAvatar\" [alt]=\"userName\" />\r\n</div>\r\n", styles: [".wco-user-avatar{--wco-user-avatar-bg: var(--wco-color-secondary-50);--wco-user-avatar-color: var(--wco-color-secondary-500);overflow:hidden;position:relative;border-radius:50%;background:var(--wco-user-avatar-bg);display:flex;align-items:center;justify-content:center;border:1px solid var(--wco-user-avatar-color, #576ff7);width:var(--wco-size-xy-user-photo, 48px);height:var(--wco-size-xy-user-photo, 48px)}.wco-user-avatar.wco-user-avatar__size--xs{--wco-size-xy-user-photo: 24px;--wco-size-user-photo: 11px}.wco-user-avatar.wco-user-avatar__size--sm{--wco-size-xy-user-photo: 32px;--wco-size-user-photo: 14px}.wco-user-avatar.wco-user-avatar__size--md{--wco-size-xy-user-photo: 48px;--wco-size-user-photo: 16px}.wco-user-avatar.wco-user-avatar__size--lg{--wco-size-xy-user-photo: 56px;--wco-size-user-photo: 18px}.wco-user-avatar.wco-user-avatar__size--xl{--wco-size-xy-user-photo: 90px;--wco-size-user-photo: 20px}.wco-user-avatar .wco-user-avatar__theme--primary{--wco-user-avatar-color: var(--wco-color-primary-500);--wco-user-avatar-bg: var(--wco-color-primary-50)}.wco-user-avatar .wco-user-avatar__theme--secondary{--wco-user-avatar-color: var(--wco-color-secondary-500);--wco-user-avatar-bg: var(--wco-color-secondary-50)}.wco-user-avatar .wco-user-avatar__theme--light{--wco-user-avatar-color: var(--wco-color-neutral-100);--wco-user-avatar-bg: var(--wco-color-neutral-900)}.wco-user-avatar .wco-user-avatar__theme--dark{--wco-user-avatar-color: var(--wco-color-neutral-700);--wco-user-avatar-bg: var(--wco-color-neutral-50)}.wco-user-avatar.wco-user-solid.wco-user-avatar__theme--primary{--wco-user-avatar-bg: var(--wco-color-primary-500);--wco-user-avatar-color: var(--wco-color-primary-50)}.wco-user-avatar.wco-user-solid.wco-user-avatar__theme--secondary{--wco-user-avatar-bg: var(--wco-color-secondary-500);--wco-user-avatar-color: var(--wco-color-secondary-50)}.wco-user-avatar.wco-user-solid.wco-user-avatar__theme--light{--wco-user-avatar-bg: var(--wco-color-neutral-100);--wco-user-avatar-color: var(--wco-color-neutral-900)}.wco-user-avatar.wco-user-solid.wco-user-avatar__theme--dark{--wco-user-avatar-bg: var(--wco-color-neutral-700);--wco-user-avatar-color: var(--wco-color-neutral-50)}.wco-user-avatar span,.wco-user-avatar img{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);padding:0;margin:0;display:block}.wco-user-avatar img{width:var(--wco-size-xy-user-photo);height:var(--wco-size-xy-user-photo);object-fit:cover}.wco-user-avatar span{font-family:var(--wco-font-family, \"Roboto\", sans-serif);width:var(--wco-size-xy-user-photo);text-align:center;font-weight:700;font-size:var(--wco-size-user-photo, 18px);color:var(--wco-user-avatar-color, #ffffff);letter-spacing:.4px}\n"] }]
42
+ args: [{ selector: 'wco-avatar', standalone: true, encapsulation: ViewEncapsulation.None, imports: [CommonModule], template: "<div\r\n [class]=\"\r\n 'wco-user-avatar wco-user-avatar__size--' + size + ' wco-user-avatar__theme--' + theme + ' ' + (solid ? 'wco-user-solid' : '') \"\r\n [title]=\"userName\" >\r\n <span>{{userNameLetters}}</span>\r\n <img *ngIf=\"userAvatar\" [src]=\"userAvatar\" [alt]=\"userName\" />\r\n</div>\r\n", styles: [".wco-user-avatar{--wco-user-avatar-bg: var(--wco-color-secondary-50);--wco-user-avatar-color: var(--wco-color-secondary-500);overflow:hidden;position:relative;border-radius:50%;background:var(--wco-user-avatar-bg);display:flex;align-items:center;justify-content:center;border:1px solid var(--wco-user-avatar-color, #576ff7);width:var(--wco-size-xy-user-photo, 48px);height:var(--wco-size-xy-user-photo, 48px)}.wco-user-avatar.wco-user-avatar__size--xs{--wco-size-xy-user-photo: 24px;--wco-size-user-photo: 11px}.wco-user-avatar.wco-user-avatar__size--sm{--wco-size-xy-user-photo: 32px;--wco-size-user-photo: 14px}.wco-user-avatar.wco-user-avatar__size--md{--wco-size-xy-user-photo: 48px;--wco-size-user-photo: 16px}.wco-user-avatar.wco-user-avatar__size--lg{--wco-size-xy-user-photo: 56px;--wco-size-user-photo: 18px}.wco-user-avatar.wco-user-avatar__size--xl{--wco-size-xy-user-photo: 90px;--wco-size-user-photo: 20px}.wco-user-avatar.wco-user-avatar__theme--primary{--wco-user-avatar-color: var(--wco-color-primary-500);--wco-user-avatar-bg: var(--wco-color-primary-50)}.wco-user-avatar.wco-user-avatar__theme--secondary{--wco-user-avatar-color: var(--wco-color-secondary-500);--wco-user-avatar-bg: var(--wco-color-secondary-50)}.wco-user-avatar.wco-user-avatar__theme--light{--wco-user-avatar-color: var(--wco-color-neutral-100);--wco-user-avatar-bg: var(--wco-color-neutral-900)}.wco-user-avatar.wco-user-avatar__theme--dark{--wco-user-avatar-color: var(--wco-color-neutral-700);--wco-user-avatar-bg: var(--wco-color-neutral-50)}.wco-user-avatar.wco-user-solid.wco-user-avatar__theme--primary{--wco-user-avatar-bg: var(--wco-color-primary-500);--wco-user-avatar-color: var(--wco-color-primary-50)}.wco-user-avatar.wco-user-solid.wco-user-avatar__theme--secondary{--wco-user-avatar-bg: var(--wco-color-secondary-500);--wco-user-avatar-color: var(--wco-color-secondary-50)}.wco-user-avatar.wco-user-solid.wco-user-avatar__theme--light{--wco-user-avatar-bg: var(--wco-color-neutral-100);--wco-user-avatar-color: var(--wco-color-neutral-900)}.wco-user-avatar.wco-user-solid.wco-user-avatar__theme--dark{--wco-user-avatar-bg: var(--wco-color-neutral-700);--wco-user-avatar-color: var(--wco-color-neutral-50)}.wco-user-avatar span,.wco-user-avatar img{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);padding:0;margin:0;display:block}.wco-user-avatar img{width:var(--wco-size-xy-user-photo);height:var(--wco-size-xy-user-photo);object-fit:cover}.wco-user-avatar span{font-family:var(--wco-font-family, \"Roboto\", sans-serif);width:var(--wco-size-xy-user-photo);text-align:center;font-weight:700;font-size:var(--wco-size-user-photo, 18px);color:var(--wco-user-avatar-color, #ffffff);letter-spacing:.4px}\n"] }]
43
43
  }], ctorParameters: function () { return []; }, propDecorators: { userName: [{
44
44
  type: Input,
45
45
  args: ['name']
@@ -56,4 +56,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
56
56
  type: Input,
57
57
  args: ['solid']
58
58
  }] } });
59
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNlci1hdmF0YXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWNvbXBvbmVudHMvc3JjL2xpYi91c2VyLWF2YXRhci91c2VyLWF2YXRhci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tcG9uZW50cy9zcmMvbGliL3VzZXItYXZhdGFyL3VzZXItYXZhdGFyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBYSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7O0FBVS9FLE1BQU0sT0FBTyxtQkFBbUI7SUFFOUIsc0JBQXNCO0lBQ1AsUUFBUSxHQUFXLEVBQUUsQ0FBQztJQUNyQyw2QkFBNkI7SUFDYixVQUFVLEdBQVcsRUFBRSxDQUFDO0lBQ3hDLDZCQUE2QjtJQUNkLElBQUksR0FBcUMsSUFBSSxDQUFDO0lBQzdELDRDQUE0QztJQUM1QixLQUFLLEdBQStDLFdBQVcsQ0FBQztJQUVoRixxQ0FBcUM7SUFDckIsS0FBSyxHQUFZLEtBQUssQ0FBQztJQUV2Qzs7TUFFRTtJQUNLLGVBQWUsR0FBVyxFQUFFLENBQUM7SUFFcEMsZ0JBQWdCLENBQUM7SUFHakIsc0NBQXNDO0lBQ3RDLFdBQVc7UUFDVCxJQUFJLENBQUMsbUJBQW1CLEVBQUUsQ0FBQztJQUM3QixDQUFDO0lBRUQsK0JBQStCO0lBQ3ZCLG1CQUFtQjtRQUN6QixJQUFJLGlCQUFpQixHQUFXLEVBQUUsQ0FBQztRQUNuQyxJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUc7WUFDbEIsaUJBQWlCLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDNUMsSUFBSSxZQUFZLEdBQWEsSUFBSSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7WUFDdEQsSUFBSSxZQUFZLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRTtnQkFDM0IsaUJBQWlCLElBQUksWUFBWSxDQUFDLFlBQVksQ0FBQyxNQUFNLEdBQUUsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDO2FBQ3JFO1NBQ0Y7UUFDRCxJQUFJLENBQUMsZUFBZSxHQUFHLGlCQUFpQixDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQ3pELENBQUM7d0dBdENVLG1CQUFtQjs0RkFBbkIsbUJBQW1CLDBOQ1hoQyx5VEFPQSw2dEZEQ1ksWUFBWTs7NEZBR1gsbUJBQW1CO2tCQVIvQixTQUFTOytCQUNFLFlBQVksY0FDVixJQUFJLGlCQUVELGlCQUFpQixDQUFDLElBQUksV0FDNUIsQ0FBQyxZQUFZLENBQUM7MEVBTVIsUUFBUTtzQkFBdEIsS0FBSzt1QkFBQyxNQUFNO2dCQUVHLFVBQVU7c0JBQXpCLEtBQUs7dUJBQUMsT0FBTztnQkFFQyxJQUFJO3NCQUFsQixLQUFLO3VCQUFDLE1BQU07Z0JBRUcsS0FBSztzQkFBcEIsS0FBSzt1QkFBQyxPQUFPO2dCQUdFLEtBQUs7c0JBQXBCLEtBQUs7dUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uQ2hhbmdlcywgVmlld0VuY2Fwc3VsYXRpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnd2NvLWF2YXRhcicsXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICB0ZW1wbGF0ZVVybDogJy4vdXNlci1hdmF0YXIuY29tcG9uZW50Lmh0bWwnLFxyXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXHJcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXHJcbiAgc3R5bGVVcmxzOiBbJy4vdXNlci1hdmF0YXIuY29tcG9uZW50LnNjc3MnXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgVXNlckF2YXRhckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uQ2hhbmdlcyB7XHJcblxyXG4gIC8qKiBOb21lIGRvIHVzdcOhcmlvICovXHJcbiAgQElucHV0KCduYW1lJykgdXNlck5hbWU6IHN0cmluZyA9IFwiXCI7XHJcbiAgLyoqIFVybCBkYSBpbWFnZW0gb3BjaW9uYWwgKi9cclxuICBASW5wdXQoJ2ltYWdlJykgdXNlckF2YXRhcjogc3RyaW5nID0gXCJcIjtcclxuICAvKiogVGFtYW5obyBkbyBjb21wb25lbnRlICAqL1xyXG4gIEBJbnB1dCgnc2l6ZScpIHNpemU6ICd4cycgfCAnc20nIHwgJ21kJyB8ICdsZycgfCAneGwnID0gJ21kJztcclxuICAvKiogVGhlbWUgbXVkYW7Dp2EgZGUgY29yZXMgZG8gY29tcG9uZW50ZSAgKi9cclxuICBASW5wdXQoJ3RoZW1lJykgdGhlbWU6ICdwcmltYXJ5JyB8ICdzZWNvbmRhcnknIHwgJ2xpZ2h0JyB8ICdkYXJrJyA9ICdzZWNvbmRhcnknO1xyXG5cclxuICAvKiogc29saWQgdGlwbyBjb20gYmcgcHJlZG9taW5hbnQgICovXHJcbiAgQElucHV0KCdzb2xpZCcpIHNvbGlkOiBib29sZWFuID0gZmFsc2U7XHJcblxyXG4gIC8qKlxyXG4gICogQGlnbm9yZVxyXG4gICovXHJcbiAgcHVibGljIHVzZXJOYW1lTGV0dGVyczogc3RyaW5nID0gXCJcIjtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7IH1cclxuXHJcblxyXG4gIC8qKiBNdWRhbsOnYSBkZSBwYXLDom1ldHJvcyBkaW7Dom1pY29zICovXHJcbiAgbmdPbkNoYW5nZXMoKSB7XHJcbiAgICB0aGlzLl9wcmVwYXJlTmFtZUxldHRlcnMoKTtcclxuICB9XHJcblxyXG4gIC8qKiBSZXRvcm5lIG8gbm9tZSBhYnJldmlhZG8gKi9cclxuICBwcml2YXRlIF9wcmVwYXJlTmFtZUxldHRlcnMoKTogdm9pZCB7XHJcbiAgICBsZXQgY2FwaXRhbGl6ZUxldHRlcnM6IHN0cmluZyA9IFwiXCI7XHJcbiAgICBpZiggdGhpcy51c2VyTmFtZSApIHtcclxuICAgICAgY2FwaXRhbGl6ZUxldHRlcnMgPSB0aGlzLnVzZXJOYW1lLmNoYXJBdCgwKTtcclxuICAgICAgbGV0IF9hcnJVc2VyTmFtZTogc3RyaW5nW10gPSB0aGlzLnVzZXJOYW1lLnNwbGl0KCcgJyk7XHJcbiAgICAgIGlmIChfYXJyVXNlck5hbWUubGVuZ3RoID4gMSkge1xyXG4gICAgICAgIGNhcGl0YWxpemVMZXR0ZXJzICs9IF9hcnJVc2VyTmFtZVtfYXJyVXNlck5hbWUubGVuZ3RoIC0xXS5jaGFyQXQoMCk7XHJcbiAgICAgIH1cclxuICAgIH1cclxuICAgIHRoaXMudXNlck5hbWVMZXR0ZXJzID0gY2FwaXRhbGl6ZUxldHRlcnMudG9VcHBlckNhc2UoKTtcclxuICB9XHJcblxyXG59XHJcbiIsIjxkaXZcclxuICBbY2xhc3NdPVwiXHJcbiAgICAnd2NvLXVzZXItYXZhdGFyIHdjby11c2VyLWF2YXRhcl9fc2l6ZS0tJyArIHNpemUgKyAnIHdjby11c2VyLWF2YXRhcl9fdGhlbWUtLScgKyB0aGVtZSArICcgJyArIChzb2xpZCA/ICd3Y28tdXNlci1zb2xpZCcgOiAnJykgXCJcclxuICBbdGl0bGVdPVwidXNlck5hbWVcIiA+XHJcbiAgPHNwYW4+e3t1c2VyTmFtZUxldHRlcnN9fTwvc3Bhbj5cclxuICA8aW1nICpuZ0lmPVwidXNlckF2YXRhclwiIFtzcmNdPVwidXNlckF2YXRhclwiIFthbHRdPVwidXNlck5hbWVcIiAvPlxyXG48L2Rpdj5cclxuIl19
59
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNlci1hdmF0YXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWNvbXBvbmVudHMvc3JjL2xpYi91c2VyLWF2YXRhci91c2VyLWF2YXRhci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tcG9uZW50cy9zcmMvbGliL3VzZXItYXZhdGFyL3VzZXItYXZhdGFyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBYSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7O0FBVS9FLE1BQU0sT0FBTyxtQkFBbUI7SUFFOUIsc0JBQXNCO0lBQ1AsUUFBUSxHQUFXLEVBQUUsQ0FBQztJQUNyQyw2QkFBNkI7SUFDYixVQUFVLEdBQVcsRUFBRSxDQUFDO0lBQ3hDLDZCQUE2QjtJQUNkLElBQUksR0FBcUMsSUFBSSxDQUFDO0lBQzdELDRDQUE0QztJQUM1QixLQUFLLEdBQStDLFdBQVcsQ0FBQztJQUVoRixxQ0FBcUM7SUFDckIsS0FBSyxHQUFZLEtBQUssQ0FBQztJQUV2Qzs7TUFFRTtJQUNLLGVBQWUsR0FBVyxFQUFFLENBQUM7SUFFcEMsZ0JBQWdCLENBQUM7SUFHakIsc0NBQXNDO0lBQ3RDLFdBQVc7UUFDVCxJQUFJLENBQUMsbUJBQW1CLEVBQUUsQ0FBQztJQUM3QixDQUFDO0lBRUQsK0JBQStCO0lBQ3ZCLG1CQUFtQjtRQUN6QixJQUFJLGlCQUFpQixHQUFXLEVBQUUsQ0FBQztRQUNuQyxJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUc7WUFDbEIsaUJBQWlCLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDNUMsSUFBSSxZQUFZLEdBQWEsSUFBSSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7WUFDdEQsSUFBSSxZQUFZLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRTtnQkFDM0IsaUJBQWlCLElBQUksWUFBWSxDQUFDLFlBQVksQ0FBQyxNQUFNLEdBQUUsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDO2FBQ3JFO1NBQ0Y7UUFDRCxJQUFJLENBQUMsZUFBZSxHQUFHLGlCQUFpQixDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQ3pELENBQUM7d0dBdENVLG1CQUFtQjs0RkFBbkIsbUJBQW1CLDBOQ1hoQyx5VEFPQSx5dEZEQ1ksWUFBWTs7NEZBR1gsbUJBQW1CO2tCQVIvQixTQUFTOytCQUNFLFlBQVksY0FDVixJQUFJLGlCQUVELGlCQUFpQixDQUFDLElBQUksV0FDNUIsQ0FBQyxZQUFZLENBQUM7MEVBTVIsUUFBUTtzQkFBdEIsS0FBSzt1QkFBQyxNQUFNO2dCQUVHLFVBQVU7c0JBQXpCLEtBQUs7dUJBQUMsT0FBTztnQkFFQyxJQUFJO3NCQUFsQixLQUFLO3VCQUFDLE1BQU07Z0JBRUcsS0FBSztzQkFBcEIsS0FBSzt1QkFBQyxPQUFPO2dCQUdFLEtBQUs7c0JBQXBCLEtBQUs7dUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uQ2hhbmdlcywgVmlld0VuY2Fwc3VsYXRpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnd2NvLWF2YXRhcicsXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICB0ZW1wbGF0ZVVybDogJy4vdXNlci1hdmF0YXIuY29tcG9uZW50Lmh0bWwnLFxyXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXHJcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXHJcbiAgc3R5bGVVcmxzOiBbJy4vdXNlci1hdmF0YXIuY29tcG9uZW50LnNjc3MnXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgVXNlckF2YXRhckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uQ2hhbmdlcyB7XHJcblxyXG4gIC8qKiBOb21lIGRvIHVzdcOhcmlvICovXHJcbiAgQElucHV0KCduYW1lJykgdXNlck5hbWU6IHN0cmluZyA9IFwiXCI7XHJcbiAgLyoqIFVybCBkYSBpbWFnZW0gb3BjaW9uYWwgKi9cclxuICBASW5wdXQoJ2ltYWdlJykgdXNlckF2YXRhcjogc3RyaW5nID0gXCJcIjtcclxuICAvKiogVGFtYW5obyBkbyBjb21wb25lbnRlICAqL1xyXG4gIEBJbnB1dCgnc2l6ZScpIHNpemU6ICd4cycgfCAnc20nIHwgJ21kJyB8ICdsZycgfCAneGwnID0gJ21kJztcclxuICAvKiogVGhlbWUgbXVkYW7Dp2EgZGUgY29yZXMgZG8gY29tcG9uZW50ZSAgKi9cclxuICBASW5wdXQoJ3RoZW1lJykgdGhlbWU6ICdwcmltYXJ5JyB8ICdzZWNvbmRhcnknIHwgJ2xpZ2h0JyB8ICdkYXJrJyA9ICdzZWNvbmRhcnknO1xyXG5cclxuICAvKiogc29saWQgdGlwbyBjb20gYmcgcHJlZG9taW5hbnQgICovXHJcbiAgQElucHV0KCdzb2xpZCcpIHNvbGlkOiBib29sZWFuID0gZmFsc2U7XHJcblxyXG4gIC8qKlxyXG4gICogQGlnbm9yZVxyXG4gICovXHJcbiAgcHVibGljIHVzZXJOYW1lTGV0dGVyczogc3RyaW5nID0gXCJcIjtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7IH1cclxuXHJcblxyXG4gIC8qKiBNdWRhbsOnYSBkZSBwYXLDom1ldHJvcyBkaW7Dom1pY29zICovXHJcbiAgbmdPbkNoYW5nZXMoKSB7XHJcbiAgICB0aGlzLl9wcmVwYXJlTmFtZUxldHRlcnMoKTtcclxuICB9XHJcblxyXG4gIC8qKiBSZXRvcm5lIG8gbm9tZSBhYnJldmlhZG8gKi9cclxuICBwcml2YXRlIF9wcmVwYXJlTmFtZUxldHRlcnMoKTogdm9pZCB7XHJcbiAgICBsZXQgY2FwaXRhbGl6ZUxldHRlcnM6IHN0cmluZyA9IFwiXCI7XHJcbiAgICBpZiggdGhpcy51c2VyTmFtZSApIHtcclxuICAgICAgY2FwaXRhbGl6ZUxldHRlcnMgPSB0aGlzLnVzZXJOYW1lLmNoYXJBdCgwKTtcclxuICAgICAgbGV0IF9hcnJVc2VyTmFtZTogc3RyaW5nW10gPSB0aGlzLnVzZXJOYW1lLnNwbGl0KCcgJyk7XHJcbiAgICAgIGlmIChfYXJyVXNlck5hbWUubGVuZ3RoID4gMSkge1xyXG4gICAgICAgIGNhcGl0YWxpemVMZXR0ZXJzICs9IF9hcnJVc2VyTmFtZVtfYXJyVXNlck5hbWUubGVuZ3RoIC0xXS5jaGFyQXQoMCk7XHJcbiAgICAgIH1cclxuICAgIH1cclxuICAgIHRoaXMudXNlck5hbWVMZXR0ZXJzID0gY2FwaXRhbGl6ZUxldHRlcnMudG9VcHBlckNhc2UoKTtcclxuICB9XHJcblxyXG59XHJcbiIsIjxkaXZcclxuICBbY2xhc3NdPVwiXHJcbiAgICAnd2NvLXVzZXItYXZhdGFyIHdjby11c2VyLWF2YXRhcl9fc2l6ZS0tJyArIHNpemUgKyAnIHdjby11c2VyLWF2YXRhcl9fdGhlbWUtLScgKyB0aGVtZSArICcgJyArIChzb2xpZCA/ICd3Y28tdXNlci1zb2xpZCcgOiAnJykgXCJcclxuICBbdGl0bGVdPVwidXNlck5hbWVcIiA+XHJcbiAgPHNwYW4+e3t1c2VyTmFtZUxldHRlcnN9fTwvc3Bhbj5cclxuICA8aW1nICpuZ0lmPVwidXNlckF2YXRhclwiIFtzcmNdPVwidXNlckF2YXRhclwiIFthbHRdPVwidXNlck5hbWVcIiAvPlxyXG48L2Rpdj5cclxuIl19