@seniorsistemas/angular-components 17.7.0 → 17.7.1

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 (32) hide show
  1. package/bundles/seniorsistemas-angular-components.umd.js +1287 -1420
  2. package/bundles/seniorsistemas-angular-components.umd.js.map +1 -1
  3. package/bundles/seniorsistemas-angular-components.umd.min.js +2 -2
  4. package/bundles/seniorsistemas-angular-components.umd.min.js.map +1 -1
  5. package/components/file-upload/file-upload.component.d.ts +17 -15
  6. package/components/file-upload/models/index.d.ts +0 -1
  7. package/components/file-upload/models/validate-errors.d.ts +0 -1
  8. package/esm2015/components/file-upload/file-upload.component.js +45 -60
  9. package/esm2015/components/file-upload/file-upload.module.js +6 -16
  10. package/esm2015/components/file-upload/file-upload.service.js +1 -3
  11. package/esm2015/components/file-upload/models/index.js +1 -2
  12. package/esm2015/components/file-upload/models/validate-errors.js +1 -2
  13. package/esm2015/seniorsistemas-angular-components.js +74 -76
  14. package/esm5/components/file-upload/file-upload.component.js +45 -60
  15. package/esm5/components/file-upload/file-upload.module.js +6 -16
  16. package/esm5/components/file-upload/file-upload.service.js +1 -3
  17. package/esm5/components/file-upload/models/index.js +1 -2
  18. package/esm5/components/file-upload/models/validate-errors.js +1 -2
  19. package/esm5/seniorsistemas-angular-components.js +74 -76
  20. package/fesm2015/seniorsistemas-angular-components.js +835 -963
  21. package/fesm2015/seniorsistemas-angular-components.js.map +1 -1
  22. package/fesm5/seniorsistemas-angular-components.js +1202 -1332
  23. package/fesm5/seniorsistemas-angular-components.js.map +1 -1
  24. package/package.json +1 -1
  25. package/seniorsistemas-angular-components.d.ts +73 -75
  26. package/seniorsistemas-angular-components.metadata.json +1 -1
  27. package/components/file-upload/components/file-item/file-item.component.d.ts +0 -26
  28. package/components/file-upload/models/storage-units.d.ts +0 -5
  29. package/esm2015/components/file-upload/components/file-item/file-item.component.js +0 -105
  30. package/esm2015/components/file-upload/models/storage-units.js +0 -6
  31. package/esm5/components/file-upload/components/file-item/file-item.component.js +0 -107
  32. package/esm5/components/file-upload/models/storage-units.js +0 -6
@@ -1,12 +1,12 @@
1
- import { ElementRef, EventEmitter, OnDestroy, OnInit } from "@angular/core";
1
+ import { AfterContentInit, ElementRef, EventEmitter, OnDestroy, OnInit } from "@angular/core";
2
2
  import { FormControl } from "@angular/forms";
3
3
  import { DomSanitizer } from "@angular/platform-browser";
4
4
  import { TranslateService } from "@ngx-translate/core";
5
5
  import { FileUploadService } from "./file-upload.service";
6
6
  import { FileDto } from "./models/file-dto";
7
- import { FileUploadPermissions } from "./models/file-upload-permissions";
8
7
  import { UploadError } from "./models/uploadError";
9
- export declare class FileUploadComponent implements OnInit, OnDestroy {
8
+ import { FileUploadPermissions } from "./models/file-upload-permissions";
9
+ export declare class FileUploadComponent implements OnInit, OnDestroy, AfterContentInit {
10
10
  private readonly sanitizer;
11
11
  private readonly fileUploadService;
12
12
  private readonly translate;
@@ -26,7 +26,6 @@ export declare class FileUploadComponent implements OnInit, OnDestroy {
26
26
  supportedExtensions: string[];
27
27
  ariaLabelFileName: string;
28
28
  maxFileSize: number;
29
- maxCombinedFileSize: number;
30
29
  fileLimit: number;
31
30
  ariaLabelProgress: string;
32
31
  ariaLabelSuccess: string;
@@ -49,24 +48,27 @@ export declare class FileUploadComponent implements OnInit, OnDestroy {
49
48
  anchor: ElementRef;
50
49
  }>;
51
50
  validateErrors: EventEmitter<UploadError>;
52
- inputValue: string;
53
- modifiedDate: string;
54
51
  private _files;
55
52
  private readonly ngUsubscribe;
53
+ isSmallDevice: boolean;
54
+ inputValue: string;
55
+ modifiedDate: string;
56
56
  constructor(sanitizer: DomSanitizer, fileUploadService: FileUploadService, translate: TranslateService);
57
57
  ngOnInit(): void;
58
58
  ngOnDestroy(): void;
59
+ ngAfterContentInit(): void;
60
+ onResize(): void;
59
61
  onFileSelect(files: FileDto[]): void;
60
62
  onRemoveFile(file: FileDto): void;
61
- onCancelUpload(file: FileDto): void;
63
+ onCancelUpload(index: number): void;
62
64
  onDowloadFile(index: number): void;
63
65
  get files(): FileDto[];
64
- private _isImage;
65
- private _isFileLimitExceeded;
66
- private _isFileCombinedSizeExceeded;
67
- private _isFileSizeExceeded;
68
- private _isUnsupportedFileExtension;
69
- private _clearFileInput;
70
- private _getUploadDate;
71
- private _setModifiedDate;
66
+ private update;
67
+ private isImage;
68
+ private isFileLimitExceeded;
69
+ private isFileSizeExceeded;
70
+ private isUnsupportedFileExtension;
71
+ private clearFileInput;
72
+ private getUploadDate;
73
+ private setModifiedDate;
72
74
  }
@@ -2,4 +2,3 @@ export { FileDto } from "./file-dto";
2
2
  export { ValidateErrors } from "./validate-errors";
3
3
  export { UploadError } from "./uploadError";
4
4
  export { FileUploadPermissions } from "./file-upload-permissions";
5
- export { StorageUnits } from "./storage-units";
@@ -1,6 +1,5 @@
1
1
  export declare enum ValidateErrors {
2
2
  MAX_FILE_SIZE = "MAX_FILE_SIZE",
3
- MAX_COMBINED_FILE_SIZE = "MAX_COMBINED_FILE_SIZE",
4
3
  MAX_FILE_LIMIT = "MAX_FILE_LIMIT",
5
4
  UNSUPPORTED_EXTENSION = "UNSUPPORTED_EXTENSION"
6
5
  }
@@ -1,13 +1,14 @@
1
1
  var FileUploadComponent_1;
2
2
  import { __decorate } from "tslib";
3
- import { Component, EventEmitter, Input, Output, ViewChild } from "@angular/core";
3
+ import { Component, EventEmitter, HostListener, Input, Output, ViewChild, } from "@angular/core";
4
4
  import { DomSanitizer } from "@angular/platform-browser";
5
5
  import { TranslateService } from "@ngx-translate/core";
6
6
  import { Subject } from "rxjs";
7
7
  import * as moment_ from "moment";
8
+ import { Breakpoints } from "../utils";
8
9
  import { FileUploadService } from "./file-upload.service";
9
- import { ALL_PERMISSIONS, FileUploadPermissions } from "./models/file-upload-permissions";
10
10
  import { ValidateErrors } from "./models/validate-errors";
11
+ import { FileUploadPermissions, ALL_PERMISSIONS } from "./models/file-upload-permissions";
11
12
  const moment = moment_;
12
13
  let FileUploadComponent = FileUploadComponent_1 = class FileUploadComponent {
13
14
  constructor(sanitizer, fileUploadService, translate) {
@@ -27,59 +28,58 @@ let FileUploadComponent = FileUploadComponent_1 = class FileUploadComponent {
27
28
  this.cancelUpload = new EventEmitter();
28
29
  this.downloadFile = new EventEmitter();
29
30
  this.validateErrors = new EventEmitter();
30
- this.inputValue = "";
31
31
  this._files = [];
32
32
  this.ngUsubscribe = new Subject();
33
+ this.inputValue = "";
33
34
  }
34
35
  set files(files) {
35
36
  var _a;
36
37
  if (this.showFileUploadDate && ((_a = files[0]) === null || _a === void 0 ? void 0 : _a.objectId)) {
37
- this._getUploadDate(files);
38
+ this.getUploadDate(files);
38
39
  }
39
- this._files = files.map((file) => {
40
- if (this._isImage(file)) {
40
+ this._files = files.map(file => {
41
+ if (this.isImage(file)) {
41
42
  file.objectURL = this.sanitizer.bypassSecurityTrustUrl(window.URL.createObjectURL(file));
42
43
  }
43
44
  return file;
44
45
  });
45
46
  }
46
47
  ngOnInit() {
47
- this.supportedExtensions = this.supportedExtensions.map((extension) => extension.replace(".", "").toLowerCase());
48
+ this.supportedExtensions = this.supportedExtensions
49
+ .map(extension => extension.replace(".", "").toLowerCase());
48
50
  }
49
51
  ngOnDestroy() {
50
52
  this.ngUsubscribe.next();
51
53
  this.ngUsubscribe.complete();
52
54
  }
55
+ ngAfterContentInit() {
56
+ this.update();
57
+ }
58
+ onResize() {
59
+ this.update();
60
+ }
53
61
  onFileSelect(files) {
54
62
  const newFiles = [];
55
63
  if (!this.multiple) {
56
64
  this.files = [];
57
65
  }
58
- if (this._isFileLimitExceeded(files)) {
66
+ if (this.isFileLimitExceeded(files)) {
59
67
  this.validateErrors.emit({
60
68
  files,
61
69
  validation: ValidateErrors.MAX_FILE_LIMIT,
62
70
  });
63
- this._clearFileInput();
64
- return;
65
- }
66
- if (this._isFileCombinedSizeExceeded(files)) {
67
- this.validateErrors.emit({
68
- files,
69
- validation: ValidateErrors.MAX_COMBINED_FILE_SIZE,
70
- });
71
- this._clearFileInput();
71
+ this.clearFileInput();
72
72
  return;
73
73
  }
74
74
  for (const file of files) {
75
- if (this._isUnsupportedFileExtension(file)) {
75
+ if (this.isUnsupportedFileExtension(file)) {
76
76
  this.validateErrors.emit({
77
77
  files: [file],
78
78
  validation: ValidateErrors.UNSUPPORTED_EXTENSION,
79
79
  });
80
80
  continue;
81
81
  }
82
- if (this._isFileSizeExceeded(file)) {
82
+ if (this.isFileSizeExceeded(file)) {
83
83
  this.validateErrors.emit({
84
84
  files: [file],
85
85
  validation: ValidateErrors.MAX_FILE_SIZE,
@@ -94,7 +94,7 @@ let FileUploadComponent = FileUploadComponent_1 = class FileUploadComponent {
94
94
  files: newFiles,
95
95
  });
96
96
  }
97
- this._clearFileInput();
97
+ this.clearFileInput();
98
98
  }
99
99
  onRemoveFile(file) {
100
100
  const fileIndex = this.files.indexOf(file);
@@ -103,13 +103,12 @@ let FileUploadComponent = FileUploadComponent_1 = class FileUploadComponent {
103
103
  this.removeFile.emit({ file });
104
104
  }
105
105
  }
106
- onCancelUpload(file) {
107
- const index = this.files.indexOf(file);
108
- if (index != -1) {
109
- this.files.splice(index, 1);
106
+ onCancelUpload(index) {
107
+ const removedFiles = this.files.splice(index, 1);
108
+ if (removedFiles.length) {
110
109
  this.cancelUpload.emit(index);
111
110
  }
112
- this._clearFileInput();
111
+ this.clearFileInput();
113
112
  }
114
113
  onDowloadFile(index) {
115
114
  this.downloadFile.emit({
@@ -120,64 +119,50 @@ let FileUploadComponent = FileUploadComponent_1 = class FileUploadComponent {
120
119
  get files() {
121
120
  return this._files;
122
121
  }
123
- _isImage(file) {
122
+ update() {
123
+ const windowWidth = window.innerWidth;
124
+ this.isSmallDevice = windowWidth <= Breakpoints.SM_MAX;
125
+ }
126
+ isImage(file) {
124
127
  return /^image\//.test(file.type);
125
128
  }
126
- _isFileLimitExceeded(files) {
129
+ isFileLimitExceeded(files) {
127
130
  if (!this.fileLimit) {
128
131
  return false;
129
132
  }
130
133
  return this.files.length + files.length > this.fileLimit;
131
134
  }
132
- _isFileCombinedSizeExceeded(files) {
133
- if (!this.maxCombinedFileSize) {
134
- return false;
135
- }
136
- const filesList = [...files, ...this.files];
137
- const combinedSize = filesList.reduce((combinedSize, file) => combinedSize + file.size, 0);
138
- return combinedSize > this.maxCombinedFileSize;
139
- }
140
- _isFileSizeExceeded(file) {
135
+ isFileSizeExceeded(file) {
141
136
  if (!this.maxFileSize) {
142
137
  return false;
143
138
  }
144
139
  return file.size > this.maxFileSize;
145
140
  }
146
- _isUnsupportedFileExtension(file) {
141
+ isUnsupportedFileExtension(file) {
147
142
  var _a;
148
143
  if ((_a = this.supportedExtensions) === null || _a === void 0 ? void 0 : _a.length) {
149
- const extension = file.name
150
- .split(".")
151
- .pop()
152
- .toLowerCase();
144
+ const extension = file.name.split(".").pop().toLowerCase();
153
145
  return !this.supportedExtensions.includes(extension);
154
146
  }
155
147
  return false;
156
148
  }
157
- _clearFileInput() {
149
+ clearFileInput() {
158
150
  this.inputUpload.nativeElement.value = null;
159
151
  }
160
- _getUploadDate(blobFile) {
152
+ getUploadDate(blobFile) {
161
153
  if (!blobFile) {
162
154
  return;
163
155
  }
164
- this.fileUploadService
165
- .getMetadataCustomField({ objectId: blobFile[0].objectId })
166
- .then((metadata) => this._setModifiedDate(metadata));
156
+ this.fileUploadService.getMetadataCustomField({ objectId: blobFile[0].objectId })
157
+ .then(metadata => this.setModifiedDate(metadata));
167
158
  }
168
- _setModifiedDate(metadata) {
159
+ setModifiedDate(metadata) {
169
160
  const hour = moment(metadata.modified).format("HH");
170
161
  const minutes = moment(metadata.modified).format("mm");
171
162
  const day = moment(metadata.modified).format("DD");
172
163
  const month = moment(metadata.modified).format("MM");
173
164
  const fullYear = moment(metadata.modified).format("YYYY");
174
- this.modifiedDate = this.translate.instant("platform.angular_components.date_modified_custom_blob", {
175
- hour,
176
- minutes,
177
- day,
178
- month,
179
- fullYear,
180
- });
165
+ this.modifiedDate = this.translate.instant("platform.angular_components.date_modified_custom_blob", { hour, minutes, day, month, fullYear });
181
166
  }
182
167
  };
183
168
  FileUploadComponent.nextId = 0;
@@ -222,9 +207,6 @@ __decorate([
222
207
  __decorate([
223
208
  Input()
224
209
  ], FileUploadComponent.prototype, "maxFileSize", void 0);
225
- __decorate([
226
- Input()
227
- ], FileUploadComponent.prototype, "maxCombinedFileSize", void 0);
228
210
  __decorate([
229
211
  Input()
230
212
  ], FileUploadComponent.prototype, "fileLimit", void 0);
@@ -270,12 +252,15 @@ __decorate([
270
252
  __decorate([
271
253
  Output()
272
254
  ], FileUploadComponent.prototype, "validateErrors", void 0);
255
+ __decorate([
256
+ HostListener("window:resize")
257
+ ], FileUploadComponent.prototype, "onResize", null);
273
258
  FileUploadComponent = FileUploadComponent_1 = __decorate([
274
259
  Component({
275
260
  selector: "s-file-upload",
276
- template: "<div [id]=\"id\" class=\"fileupload\">\n <div class=\"fileupload-choose\">\n <input\n #inputUpload\n type=\"file\"\n name=\"file\"\n [accept]=\"accept\"\n [multiple]=\"multiple\"\n (change)=\"onFileSelect($event.dataTransfer ? $event.dataTransfer.files : $event.target.files)\"\n />\n <s-button\n *ngIf=\"permissions.includes(ADD_PERMISSION)\"\n [label]=\"chooseLabel || 'platform.angular_components.attach_files' | translate\"\n (onClick)=\"inputUpload.click()\"\n priority=\"primary\"\n [disabled]=\"disabled || !!formGroup?.disabled\"\n [auxiliary]=\"false\"\n >\n </s-button>\n </div>\n <ul\n *ngIf=\"files.length\"\n class=\"file-list\"\n role=\"grid\">\n <li *ngFor=\"let file of files; let i = index\" class=\"file-list-item\">\n <s-file-item\n [id]=\"'file-' + i\"\n [file]=\"file\"\n [canReadFiles]=\"permissions.includes(READ_PERMISSION) && file.savedFile || file.progress === 100\"\n [canRemoveFiles]=\"permissions.includes(REMOVE_PERMISSION) && !(disabled || !!formGroup?.disabled)\"\n [cancelLabel]=\"cancelLabel\"\n [removeLabel]=\"removeLabel\"\n [ariaLabelProgress]=\"ariaLabelProgress\"\n [successTooltip]=\"successTooltip\"\n [ariaLabelSuccess]=\"ariaLabelSuccess\"\n (cancelUpload)=\"onCancelUpload($event)\"\n (removeFile)=\"onRemoveFile($event)\"\n >\n </s-file-item>\n </li>\n </ul>\n</div>\n",
277
- styles: [".fileupload .fileupload-choose{position:relative;margin:15px 0;width:-webkit-max-content;width:max-content}.fileupload input[type=file]{display:none}.fileupload .file-list{border:1px solid #c1c1cc;border-radius:4px;padding:0}.fileupload .file-list .file-list-item{list-style-type:none}.fileupload .file-list .file-list-item:not(:first-child){border-top:1px solid #ccc}"]
261
+ template: "<div\n [id]=\"id\"\n class=\"s-fileupload\">\n <div class=\"s-fileupload-choose\">\n <input\n #inputUpload\n [id]=\"id+'input-upload'\"\n type=\"file\"\n name=\"file\"\n [accept]=\"accept\"\n [multiple]=\"multiple\"\n (change)=\"onFileSelect($event.dataTransfer\n ? $event.dataTransfer.files\n : $event.target.files)\"> \n <s-button\n *ngIf=\"permissions.includes(ADD_PERMISSION)\"\n [id]=\"id + 'upload-button'\"\n [label]=\"chooseLabel || 'platform.angular_components.attach_files' | translate\"\n (onClick)=\"inputUpload.click()\"\n priority=\"primary\"\n [disabled]=\"disabled || !!formGroup?.disabled\"\n [auxiliary]=\"false\">\n </s-button>\n </div>\n\n <section\n *ngIf=\"files.length\" \n [id]=\"id + 'fileupload-list'\"\n class=\"s-fileupload-list\"\n role=\"grid\">\n <ng-container *ngFor=\"let file of files; let i = index\">\n <div\n class=\"s-fileupload-list-file\"\n role=\"row\">\n <div\n [id]=\"id + '-file-' + i + '-name'\"\n class=\"s-fileupload-list-file-name\"\n role=\"gridcell\">\n <ng-container *ngTemplateOutlet=\"permissions.includes(READ_PERMISSION) && file.savedFile || file.progress === 100\n ? descriptionUrl\n : description; context: {\n $implicit: file,\n index: i\n }\">\n </ng-container>\n <span *ngIf=\"modifiedDate\" class=\"s-fileupload-list-file-name-date\">{{ modifiedDate }}</span>\n </div>\n <div\n class=\"s-fileupload-list-file-status\"\n role=\"gridcell\">\n <p-progressBar\n *ngIf=\"file.isUploading && !isSmallDevice\"\n [style]=\"{ 'width': '250px', 'background-color': '#d8d8d8', 'border-radius': '0px', 'height': '14px'}\"\n [value]=\"file.progress\"\n [showValue]=\"false\"\n role=\"alert\"\n [attr.aria-label]=\"ariaLabelProgress || 'platform.angular_components.loading_file' | translate\">\n </p-progressBar>\n <span\n *ngIf=\"file.isUploading && isSmallDevice\" \n [id]=\"id + '-file-' + i + '-spin'\"\n class=\"fas fa-circle-notch fa-spin\"\n [attr.aria-label]=\"ariaLabelProgress || 'platform.angular_components.loading_file' | translate\">\n </span>\n <span\n *ngIf=\"!file.isUploading && !file.error && file.progress === 100\"\n [id]=\"id + '-file-' + i + '-check'\"\n class=\"fas fa-check\"\n role=\"alert\"\n [attr.aria-label]=\"ariaLabelSuccess || successTooltip || 'platform.angular_components.file_attached_successfully' | translate\"\n [pTooltip]=\"successTooltip || 'platform.angular_components.file_attached_successfully' | translate\"\n tooltipPosition=\"top\"\n showDelay=\"500\"\n [appendTo]=\"'body'\">\n </span>\n <span\n *ngIf=\"file.error?.message\" \n [id]=\"id + '-file-' + i + '-error'\"\n class=\"fas fa-times\"\n role=\"alert\"\n [pTooltip]=\"file.error?.message\"\n tooltipPosition=\"top\"\n showDelay=\"500\"\n [appendTo]=\"'body'\">\n </span>\n </div>\n <div\n class=\"s-fileupload-list-file-actions\"\n role=\"gridcell\">\n <a\n *ngIf=\"file.isUploading\"\n [id]=\"id + '-file-' + i + '-cancel'\"\n class=\"s-fileupload-list-file-actions-action\"\n (click)=\"onCancelUpload(i)\">\n {{ cancelLabel || 'platform.angular_components.cancel' | translate }}\n </a>\n <a\n *ngIf=\"permissions.includes(REMOVE_PERMISSION) && !file.isUploading && !(disabled || !!formGroup?.disabled)\"\n role=\"button\"\n tabindex=\"0\"\n [id]=\"id + '-file-' + i + '-remove'\"\n class=\"s-fileupload-list-file-actions-action\"\n (click)=\"onRemoveFile(file)\"\n [attr.aria-label]=\"ariaLabelRemove || removeLabel || 'platform.angular_components.remove' | translate\">\n {{ removeLabel || 'platform.angular_components.remove' | translate }}\n </a>\n </div>\n </div>\n </ng-container>\n </section>\n</div>\n\n<ng-template\n #descriptionUrl\n let-file\n let-i = index>\n <a\n [id]=\"id + '-file-' + i + '-name-link'\"\n tabindex=\"0\"\n (click)=\"onDowloadFile(i)\"\n [attr.aria-label]=\"ariaLabelFileName || file.name\">{{file.name}}\n </a>\n <a\n style=\"display: none;\"\n [href]=\"file.objectURL\"\n target=\"_blank\"\n download\n #anchor>\n </a>\n</ng-template>\n\n<ng-template\n #description\n let-file>\n <span\n tabindex=\"0\"\n [attr.aria-label]=\"ariaLabelFileName || file.name\">\n {{file.name}}\n </span>\n</ng-template>\n",
262
+ styles: [".s-fileupload .s-fileupload-choose{position:relative;margin:15px 0;width:-webkit-max-content;width:max-content}.s-fileupload input[type=file]{display:none}.s-fileupload-list{border:1px solid #ccc}.s-fileupload-list-file:not(:first-child){border-top:1px solid #ccc}.s-fileupload-list .s-fileupload-list-file{display:-ms-flexbox;display:flex;-ms-flex-direction:row;flex-direction:row;-ms-flex-wrap:wrap;flex-wrap:wrap;-ms-flex-pack:justify;justify-content:space-between;padding:15px}.s-fileupload-list .s-fileupload-list-file .s-fileupload-list-file-name{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;-ms-flex-item-align:center;align-self:center;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.s-fileupload-list .s-fileupload-list-file .s-fileupload-list-file-name .s-fileupload-list-file-name-date{font-size:.75rem;color:#999}.s-fileupload-list .s-fileupload-list-file .s-fileupload-list-file-name>a{cursor:pointer;text-decoration:none}.s-fileupload-list .s-fileupload-list-file .s-fileupload-list-file-status{-ms-flex-item-align:center;-ms-grid-row-align:center;align-self:center}.s-fileupload-list .s-fileupload-list-file .fas.fa-circle-notch{color:#d8d8d8;font-size:12px}.s-fileupload-list .s-fileupload-list-file .fas.fa-check{color:#0c9348;font-size:12px}.s-fileupload-list .s-fileupload-list-file .fas.fa-times{color:#c13018;font-size:12px}.s-fileupload-list .s-fileupload-list-file .s-fileupload-list-file-actions{margin-top:15px;-ms-flex-item-align:center;-ms-grid-row-align:center;align-self:center;width:100%}.s-fileupload-list .s-fileupload-list-file .s-fileupload-list-file-actions a.s-fileupload-list-file-actions-action{text-decoration:none;color:#428bca}.s-fileupload-list .s-fileupload-list-file .s-fileupload-list-file-actions a.s-fileupload-list-file-actions-action :focus,.s-fileupload-list .s-fileupload-list-file .s-fileupload-list-file-actions a.s-fileupload-list-file-actions-action :visited,.s-fileupload-list .s-fileupload-list-file .s-fileupload-list-file-actions a.s-fileupload-list-file-actions-action:hover{text-decoration:none}@media (min-width:768px){.s-fileupload-list .s-fileupload-list-file{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.s-fileupload-list .s-fileupload-list-file .s-fileupload-list-file-name{width:auto;-ms-flex-positive:2;flex-grow:2}.s-fileupload-list .s-fileupload-list-file .s-fileupload-list-file-status{margin:0 15px}.s-fileupload-list .s-fileupload-list-file .s-fileupload-list-file-actions{margin:0;width:auto}}"]
278
263
  })
279
264
  ], FileUploadComponent);
280
265
  export { FileUploadComponent };
281
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-upload.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/file-upload/file-upload.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, OnDestroy, OnInit, Output, ViewChild } from \"@angular/core\";\nimport { FormControl } from \"@angular/forms\";\nimport { DomSanitizer } from \"@angular/platform-browser\";\n\nimport { TranslateService } from \"@ngx-translate/core\";\nimport { Subject } from \"rxjs\";\nimport * as moment_ from \"moment\";\n\nimport { Breakpoints } from \"../utils\";\nimport { FileUploadService } from \"./file-upload.service\";\nimport { FileDto } from \"./models/file-dto\";\nimport { ALL_PERMISSIONS, FileUploadPermissions } from \"./models/file-upload-permissions\";\nimport { UploadError } from \"./models/uploadError\";\nimport { ValidateErrors } from \"./models/validate-errors\";\nimport { ListBlobMetadataResponse } from \"./models/list-blob-metadata\";\n\nconst moment = moment_;\n\n@Component({\n    selector: \"s-file-upload\",\n    templateUrl: \"./file-upload.component.html\",\n    styleUrls: [\"./file-upload.component.scss\"],\n})\nexport class FileUploadComponent implements OnInit, OnDestroy {\n    public static nextId = 0;\n\n    public ADD_PERMISSION = FileUploadPermissions.Add;\n    public READ_PERMISSION = FileUploadPermissions.Read;\n    public REMOVE_PERMISSION = FileUploadPermissions.Remove;\n\n    @ViewChild(\"inputUpload\", { static: false })\n    private readonly inputUpload: ElementRef;\n\n    @ViewChild(\"anchor\", { static: false })\n    private readonly anchor: ElementRef;\n\n    @Input()\n    public id = `s-file-upload-${FileUploadComponent.nextId++}`;\n\n    @Input()\n    public chooseLabel: string;\n\n    @Input()\n    public removeLabel: string;\n\n    @Input()\n    public cancelLabel: string;\n\n    @Input()\n    public successTooltip: string;\n\n    @Input()\n    public multiple: boolean;\n\n    @Input()\n    public accept: string;\n\n    @Input()\n    public supportedExtensions: string[] = [];\n\n    @Input()\n    public ariaLabelFileName: string;\n\n    @Input()\n    public maxFileSize: number;\n\n    @Input()\n    public maxCombinedFileSize: number;\n\n    @Input()\n    public fileLimit: number;\n\n    @Input()\n    public ariaLabelProgress: string;\n\n    @Input()\n    public ariaLabelSuccess: string;\n\n    @Input()\n    public ariaLabelError: string;\n\n    @Input()\n    public ariaLabelRemove: string;\n\n    @Input()\n    public formGroup: FormControl;\n\n    @Input()\n    public disabled = false;\n\n    @Input()\n    public showFileUploadDate: boolean = false;\n\n    @Input()\n    public permissions: FileUploadPermissions[] = ALL_PERMISSIONS;\n\n    @Input()\n    public set files(files: FileDto[]) {\n        if (this.showFileUploadDate && files[0]?.objectId) {\n            this._getUploadDate(files);\n        }\n        this._files = files.map((file) => {\n            if (this._isImage(file)) {\n                file.objectURL = this.sanitizer.bypassSecurityTrustUrl(window.URL.createObjectURL(file));\n            }\n            return file;\n        });\n    }\n\n    @Output()\n    public uploadHandler: EventEmitter<{ files: FileDto[] }> = new EventEmitter();\n\n    @Output()\n    public removeFile: EventEmitter<{ file: File }> = new EventEmitter();\n\n    @Output()\n    public cancelUpload: EventEmitter<number> = new EventEmitter();\n\n    @Output()\n    public downloadFile: EventEmitter<{ index: number; anchor: ElementRef }> = new EventEmitter();\n\n    @Output()\n    public validateErrors: EventEmitter<UploadError> = new EventEmitter();\n\n    public inputValue = \"\";\n    public modifiedDate: string;\n\n    private _files: FileDto[] = [];\n    private readonly ngUsubscribe: Subject<void> = new Subject();\n\n    constructor(\n        private readonly sanitizer: DomSanitizer,\n        private readonly fileUploadService: FileUploadService,\n        private readonly translate: TranslateService\n    ) {}\n\n    public ngOnInit(): void {\n        this.supportedExtensions = this.supportedExtensions.map((extension) => extension.replace(\".\", \"\").toLowerCase());\n    }\n\n    public ngOnDestroy(): void {\n        this.ngUsubscribe.next();\n        this.ngUsubscribe.complete();\n    }\n\n    public onFileSelect(files: FileDto[]): void {\n        const newFiles: FileDto[] = [];\n\n        if (!this.multiple) {\n            this.files = [];\n        }\n\n        if (this._isFileLimitExceeded(files)) {\n            this.validateErrors.emit({\n                files,\n                validation: ValidateErrors.MAX_FILE_LIMIT,\n            });\n            this._clearFileInput();\n            return;\n        }\n\n        if (this._isFileCombinedSizeExceeded(files)) {\n            this.validateErrors.emit({\n                files,\n                validation: ValidateErrors.MAX_COMBINED_FILE_SIZE,\n            });\n            this._clearFileInput();\n            return;\n        }\n\n        for (const file of files) {\n            if (this._isUnsupportedFileExtension(file)) {\n                this.validateErrors.emit({\n                    files: [file],\n                    validation: ValidateErrors.UNSUPPORTED_EXTENSION,\n                });\n                continue;\n            }\n\n            if (this._isFileSizeExceeded(file)) {\n                this.validateErrors.emit({\n                    files: [file],\n                    validation: ValidateErrors.MAX_FILE_SIZE,\n                });\n                continue;\n            }\n\n            newFiles.push(file);\n        }\n\n        if (newFiles.length) {\n            this.files = this.files.concat(newFiles);\n            this.uploadHandler.emit({\n                files: newFiles,\n            });\n        }\n\n        this._clearFileInput();\n    }\n\n    public onRemoveFile(file: FileDto): void {\n        const fileIndex = this.files.indexOf(file);\n        const removedFiles = this.files.splice(fileIndex, 1);\n\n        if (removedFiles.length) {\n            this.removeFile.emit({ file });\n        }\n    }\n\n    public onCancelUpload(file: FileDto): void {\n        const index = this.files.indexOf(file);\n\n        if (index != -1) {\n            this.files.splice(index, 1);\n            this.cancelUpload.emit(index);\n        }\n\n        this._clearFileInput();\n    }\n\n    public onDowloadFile(index: number): void {\n        this.downloadFile.emit({\n            index,\n            anchor: this.anchor,\n        });\n    }\n\n    public get files(): FileDto[] {\n        return this._files;\n    }\n\n    private _isImage(file: File): boolean {\n        return /^image\\//.test(file.type);\n    }\n\n    private _isFileLimitExceeded(files: FileDto[]): boolean {\n        if (!this.fileLimit) {\n            return false;\n        }\n        return this.files.length + files.length > this.fileLimit;\n    }\n\n    private _isFileCombinedSizeExceeded(files: FileDto[]): boolean {\n        if (!this.maxCombinedFileSize) {\n            return false;\n        }\n\n        const filesList = [...files, ...this.files];\n\n        const combinedSize = filesList.reduce((combinedSize, file) => combinedSize + file.size, 0);\n\n        return combinedSize > this.maxCombinedFileSize;\n    }\n\n    private _isFileSizeExceeded(file: File): boolean {\n        if (!this.maxFileSize) {\n            return false;\n        }\n        return file.size > this.maxFileSize;\n    }\n\n    private _isUnsupportedFileExtension(file: File): boolean {\n        if (this.supportedExtensions?.length) {\n            const extension = file.name\n                .split(\".\")\n                .pop()\n                .toLowerCase();\n            return !this.supportedExtensions.includes(extension);\n        }\n        return false;\n    }\n\n    private _clearFileInput(): void {\n        this.inputUpload.nativeElement.value = null;\n    }\n\n    private _getUploadDate(blobFile: FileDto[]): void {\n        if (!blobFile) {\n            return;\n        }\n\n        this.fileUploadService\n            .getMetadataCustomField({ objectId: blobFile[0].objectId })\n            .then((metadata) => this._setModifiedDate(metadata));\n    }\n\n    private _setModifiedDate(metadata: ListBlobMetadataResponse): void {\n        const hour = moment(metadata.modified).format(\"HH\");\n        const minutes = moment(metadata.modified).format(\"mm\");\n        const day = moment(metadata.modified).format(\"DD\");\n        const month = moment(metadata.modified).format(\"MM\");\n        const fullYear = moment(metadata.modified).format(\"YYYY\");\n\n        this.modifiedDate = this.translate.instant(\"platform.angular_components.date_modified_custom_blob\", {\n            hour,\n            minutes,\n            day,\n            month,\n            fullYear,\n        });\n    }\n}\n"]}
266
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-upload.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/file-upload/file-upload.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterContentInit,\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostListener,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    ViewChild,\n} from \"@angular/core\";\nimport { FormControl } from \"@angular/forms\";\nimport { DomSanitizer } from \"@angular/platform-browser\";\n\nimport { TranslateService } from \"@ngx-translate/core\";\nimport { Subject } from \"rxjs\";\nimport * as moment_ from \"moment\";\n\nimport { Breakpoints } from \"../utils\";\nimport { FileUploadService } from \"./file-upload.service\";\nimport { ListBlobMetadataResponse } from \"./models/list-blob-metadata\";\nimport { FileDto } from \"./models/file-dto\";\nimport { UploadError } from \"./models/uploadError\";\nimport { ValidateErrors } from \"./models/validate-errors\";\nimport { FileUploadPermissions, ALL_PERMISSIONS } from \"./models/file-upload-permissions\";\n\nconst moment = moment_;\n\n@Component({\n    selector: \"s-file-upload\",\n    templateUrl: \"./file-upload.component.html\",\n    styleUrls: [\"./file-upload.component.scss\"],\n})\nexport class FileUploadComponent implements OnInit, OnDestroy, AfterContentInit {\n    public static nextId = 0;\n\n    public ADD_PERMISSION = FileUploadPermissions.Add;\n    public READ_PERMISSION = FileUploadPermissions.Read;\n    public REMOVE_PERMISSION = FileUploadPermissions.Remove;\n\n    @ViewChild(\"inputUpload\", { static: false })\n    private readonly inputUpload: ElementRef;\n\n    @ViewChild(\"anchor\", { static: false })\n    private readonly anchor: ElementRef;\n\n    @Input()\n    public id = `s-file-upload-${FileUploadComponent.nextId++}`;\n\n    @Input()\n    public chooseLabel: string;\n\n    @Input()\n    public removeLabel: string;\n\n    @Input()\n    public cancelLabel: string;\n\n    @Input()\n    public successTooltip: string;\n\n    @Input()\n    public multiple: boolean;\n\n    @Input()\n    public accept: string;\n\n    @Input()\n    public supportedExtensions: string[] = [];\n\n    @Input()\n    public ariaLabelFileName: string;\n\n    @Input()\n    public maxFileSize: number;\n\n    @Input()\n    public fileLimit: number;\n\n    @Input()\n    public ariaLabelProgress: string;\n\n    @Input()\n    public ariaLabelSuccess: string;\n\n    @Input()\n    public ariaLabelError: string;\n\n    @Input()\n    public ariaLabelRemove: string;\n\n    @Input()\n    public formGroup: FormControl;\n\n    @Input()\n    public disabled = false;\n\n    @Input()\n    public showFileUploadDate: boolean = false;\n\n    @Input()\n    public permissions: FileUploadPermissions[] = ALL_PERMISSIONS;\n\n    @Input()\n    public set files(files: FileDto[]) {\n        if (this.showFileUploadDate && files[0]?.objectId) {\n            this.getUploadDate(files);\n        }\n        this._files = files.map(file => {\n            if (this.isImage(file)) {\n                file.objectURL = this.sanitizer.bypassSecurityTrustUrl(window.URL.createObjectURL(file));\n            }\n            return file;\n        });\n    }\n\n    @Output()\n    public uploadHandler: EventEmitter<{ files: FileDto[] }> = new EventEmitter();\n\n    @Output()\n    public removeFile: EventEmitter<{ file: File }> = new EventEmitter();\n\n    @Output()\n    public cancelUpload: EventEmitter<number> = new EventEmitter();\n\n    @Output()\n    public downloadFile: EventEmitter<{ index: number; anchor: ElementRef }> = new EventEmitter();\n\n    @Output()\n    public validateErrors: EventEmitter<UploadError> = new EventEmitter();\n\n    private _files: FileDto[] = [];\n    private readonly ngUsubscribe: Subject<void> = new Subject();\n    public isSmallDevice: boolean;\n    public inputValue = \"\";\n    public modifiedDate: string;\n\n    constructor(private readonly sanitizer: DomSanitizer,\n        private readonly fileUploadService: FileUploadService,\n        private readonly translate: TranslateService) { }\n\n    public ngOnInit(): void {\n        this.supportedExtensions = this.supportedExtensions\n            .map(extension => extension.replace(\".\", \"\").toLowerCase());\n    }\n\n    public ngOnDestroy() {\n        this.ngUsubscribe.next();\n        this.ngUsubscribe.complete();\n    }\n\n    public ngAfterContentInit() {\n        this.update();\n    }\n\n    @HostListener(\"window:resize\")\n    public onResize() {\n        this.update();\n    }\n\n    public onFileSelect(files: FileDto[]): void {\n        const newFiles: FileDto[] = [];\n\n        if (!this.multiple) {\n            this.files = [];\n        }\n\n        if (this.isFileLimitExceeded(files)) {\n            this.validateErrors.emit({\n                files,\n                validation: ValidateErrors.MAX_FILE_LIMIT,\n            });\n            this.clearFileInput();\n            return;\n        }\n\n        for (const file of files) {\n            if (this.isUnsupportedFileExtension(file)) {\n                this.validateErrors.emit({\n                    files: [file],\n                    validation: ValidateErrors.UNSUPPORTED_EXTENSION,\n                });\n                continue;\n            }\n\n            if (this.isFileSizeExceeded(file)) {\n                this.validateErrors.emit({\n                    files: [file],\n                    validation: ValidateErrors.MAX_FILE_SIZE,\n                });\n                continue;\n            }\n\n            newFiles.push(file);\n        }\n\n        if (newFiles.length) {\n            this.files = this.files.concat(newFiles);\n            this.uploadHandler.emit({\n                files: newFiles,\n            });\n        }\n\n        this.clearFileInput();\n    }\n\n    public onRemoveFile(file: FileDto): void {\n        const fileIndex = this.files.indexOf(file);\n        const removedFiles = this.files.splice(fileIndex, 1);\n\n        if (removedFiles.length) {\n            this.removeFile.emit({ file });\n        }\n    }\n\n    public onCancelUpload(index: number) {\n        const removedFiles = this.files.splice(index, 1);\n\n        if (removedFiles.length) {\n            this.cancelUpload.emit(index);\n        }\n\n        this.clearFileInput();\n    }\n\n    public onDowloadFile(index: number) {\n        this.downloadFile.emit({\n            index,\n            anchor: this.anchor,\n        });\n    }\n\n    public get files(): FileDto[] {\n        return this._files;\n    }\n\n    private update() {\n        const windowWidth = window.innerWidth;\n        this.isSmallDevice = windowWidth <= Breakpoints.SM_MAX;\n    }\n\n    private isImage(file: File): boolean {\n        return /^image\\//.test(file.type);\n    }\n\n    private isFileLimitExceeded(files: FileDto[]) {\n        if (!this.fileLimit) {\n            return false;\n        }\n        return this.files.length + files.length > this.fileLimit;\n    }\n\n    private isFileSizeExceeded(file: File): boolean {\n        if (!this.maxFileSize) {\n            return false;\n        }\n        return file.size > this.maxFileSize;\n    }\n\n    private isUnsupportedFileExtension(file: File) {\n        if (this.supportedExtensions?.length) {\n            const extension = file.name.split(\".\").pop().toLowerCase();\n            return !this.supportedExtensions.includes(extension);\n        }\n        return false;\n    }\n\n    private clearFileInput() {\n        this.inputUpload.nativeElement.value = null;\n    }\n\n    private getUploadDate(blobFile: FileDto[]): void {\n        if (!blobFile) {\n            return;\n        }\n\n        this.fileUploadService.getMetadataCustomField({ objectId: blobFile[0].objectId })\n            .then(metadata => this.setModifiedDate(metadata));\n    }\n\n    private setModifiedDate(metadata: ListBlobMetadataResponse): void {\n        const hour = moment(metadata.modified).format(\"HH\");\n        const minutes = moment(metadata.modified).format(\"mm\");\n        const day = moment(metadata.modified).format(\"DD\");\n        const month = moment(metadata.modified).format(\"MM\");\n        const fullYear = moment(metadata.modified).format(\"YYYY\");\n\n        this.modifiedDate = this.translate.instant(\"platform.angular_components.date_modified_custom_blob\", { hour, minutes, day, month, fullYear });\n    }\n}\n"]}
@@ -1,37 +1,27 @@
1
1
  import { __decorate } from "tslib";
2
2
  import { CommonModule } from "@angular/common";
3
- import { HttpClientModule } from '@angular/common/http';
4
3
  import { NgModule } from "@angular/core";
5
4
  import { TranslateModule } from "@ngx-translate/core";
5
+ import { ProgressBarModule } from "primeng/progressbar";
6
+ import { TooltipModule } from "primeng/tooltip";
6
7
  import { ButtonModule } from "../button/button.module";
7
- import { LocaleService } from "../locale/locale.service";
8
- import { ProgressBarModule } from "../progressbar/progressbar.module";
9
- import { TooltipModule } from "../tooltip/tooltip.module";
10
- import { FileItemComponent } from "./components/file-item/file-item.component";
11
- import { FileUploadComponent } from "./file-upload.component";
12
8
  import { FileUploadService } from "./file-upload.service";
9
+ import { FileUploadComponent } from "./file-upload.component";
13
10
  let FileUploadModule = class FileUploadModule {
14
11
  };
15
12
  FileUploadModule = __decorate([
16
13
  NgModule({
14
+ declarations: [FileUploadComponent],
17
15
  imports: [
18
16
  CommonModule,
19
- HttpClientModule,
20
17
  ButtonModule,
21
18
  TooltipModule,
22
19
  ProgressBarModule,
23
20
  TranslateModule,
24
21
  ],
25
- declarations: [
26
- FileUploadComponent,
27
- FileItemComponent,
28
- ],
29
- providers: [
30
- FileUploadService,
31
- LocaleService,
32
- ],
22
+ providers: [FileUploadService],
33
23
  exports: [FileUploadComponent],
34
24
  })
35
25
  ], FileUploadModule);
36
26
  export { FileUploadModule };
37
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQHNlbmlvcnNpc3RlbWFzL2FuZ3VsYXItY29tcG9uZW50cy8iLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvZmlsZS11cGxvYWQvZmlsZS11cGxvYWQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDeEQsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV6QyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFFdEQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUN0RSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDMUQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sNENBQTRDLENBQUM7QUFDL0UsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDOUQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFxQjFELElBQWEsZ0JBQWdCLEdBQTdCLE1BQWEsZ0JBQWdCO0NBQUcsQ0FBQTtBQUFuQixnQkFBZ0I7SUFuQjVCLFFBQVEsQ0FBQztRQUNOLE9BQU8sRUFBRTtZQUNMLFlBQVk7WUFDWixnQkFBZ0I7WUFDaEIsWUFBWTtZQUNaLGFBQWE7WUFDYixpQkFBaUI7WUFDakIsZUFBZTtTQUNsQjtRQUNELFlBQVksRUFBRTtZQUNWLG1CQUFtQjtZQUNuQixpQkFBaUI7U0FDcEI7UUFDRCxTQUFTLEVBQUU7WUFDUCxpQkFBaUI7WUFDakIsYUFBYTtTQUNoQjtRQUNELE9BQU8sRUFBRSxDQUFDLG1CQUFtQixDQUFDO0tBQ2pDLENBQUM7R0FDVyxnQkFBZ0IsQ0FBRztTQUFuQixnQkFBZ0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XG5pbXBvcnQgeyBIdHRwQ2xpZW50TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuXG5pbXBvcnQgeyBUcmFuc2xhdGVNb2R1bGUgfSBmcm9tIFwiQG5neC10cmFuc2xhdGUvY29yZVwiO1xuXG5pbXBvcnQgeyBCdXR0b25Nb2R1bGUgfSBmcm9tIFwiLi4vYnV0dG9uL2J1dHRvbi5tb2R1bGVcIjtcbmltcG9ydCB7IExvY2FsZVNlcnZpY2UgfSBmcm9tIFwiLi4vbG9jYWxlL2xvY2FsZS5zZXJ2aWNlXCI7XG5pbXBvcnQgeyBQcm9ncmVzc0Jhck1vZHVsZSB9IGZyb20gXCIuLi9wcm9ncmVzc2Jhci9wcm9ncmVzc2Jhci5tb2R1bGVcIjtcbmltcG9ydCB7IFRvb2x0aXBNb2R1bGUgfSBmcm9tIFwiLi4vdG9vbHRpcC90b29sdGlwLm1vZHVsZVwiO1xuaW1wb3J0IHsgRmlsZUl0ZW1Db21wb25lbnQgfSBmcm9tIFwiLi9jb21wb25lbnRzL2ZpbGUtaXRlbS9maWxlLWl0ZW0uY29tcG9uZW50XCI7XG5pbXBvcnQgeyBGaWxlVXBsb2FkQ29tcG9uZW50IH0gZnJvbSBcIi4vZmlsZS11cGxvYWQuY29tcG9uZW50XCI7XG5pbXBvcnQgeyBGaWxlVXBsb2FkU2VydmljZSB9IGZyb20gXCIuL2ZpbGUtdXBsb2FkLnNlcnZpY2VcIjtcblxuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBbXG4gICAgICAgIENvbW1vbk1vZHVsZSxcbiAgICAgICAgSHR0cENsaWVudE1vZHVsZSxcbiAgICAgICAgQnV0dG9uTW9kdWxlLFxuICAgICAgICBUb29sdGlwTW9kdWxlLFxuICAgICAgICBQcm9ncmVzc0Jhck1vZHVsZSxcbiAgICAgICAgVHJhbnNsYXRlTW9kdWxlLFxuICAgIF0sXG4gICAgZGVjbGFyYXRpb25zOiBbXG4gICAgICAgIEZpbGVVcGxvYWRDb21wb25lbnQsXG4gICAgICAgIEZpbGVJdGVtQ29tcG9uZW50LFxuICAgIF0sXG4gICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIEZpbGVVcGxvYWRTZXJ2aWNlLFxuICAgICAgICBMb2NhbGVTZXJ2aWNlLFxuICAgIF0sXG4gICAgZXhwb3J0czogW0ZpbGVVcGxvYWRDb21wb25lbnRdLFxufSlcbmV4cG9ydCBjbGFzcyBGaWxlVXBsb2FkTW9kdWxlIHt9XG4iXX0=
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQHNlbmlvcnNpc3RlbWFzL2FuZ3VsYXItY29tcG9uZW50cy8iLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvZmlsZS11cGxvYWQvZmlsZS11cGxvYWQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV6QyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDdEQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDeEQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBRWhELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN2RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQWM5RCxJQUFhLGdCQUFnQixHQUE3QixNQUFhLGdCQUFnQjtDQUFHLENBQUE7QUFBbkIsZ0JBQWdCO0lBWjVCLFFBQVEsQ0FBQztRQUNOLFlBQVksRUFBRSxDQUFDLG1CQUFtQixDQUFDO1FBQ25DLE9BQU8sRUFBRTtZQUNMLFlBQVk7WUFDWixZQUFZO1lBQ1osYUFBYTtZQUNiLGlCQUFpQjtZQUNqQixlQUFlO1NBQ2xCO1FBQ0QsU0FBUyxFQUFFLENBQUMsaUJBQWlCLENBQUM7UUFDOUIsT0FBTyxFQUFFLENBQUMsbUJBQW1CLENBQUM7S0FDakMsQ0FBQztHQUNXLGdCQUFnQixDQUFHO1NBQW5CLGdCQUFnQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcblxuaW1wb3J0IHsgVHJhbnNsYXRlTW9kdWxlIH0gZnJvbSBcIkBuZ3gtdHJhbnNsYXRlL2NvcmVcIjtcbmltcG9ydCB7IFByb2dyZXNzQmFyTW9kdWxlIH0gZnJvbSBcInByaW1lbmcvcHJvZ3Jlc3NiYXJcIjtcbmltcG9ydCB7IFRvb2x0aXBNb2R1bGUgfSBmcm9tIFwicHJpbWVuZy90b29sdGlwXCI7XG5cbmltcG9ydCB7IEJ1dHRvbk1vZHVsZSB9IGZyb20gXCIuLi9idXR0b24vYnV0dG9uLm1vZHVsZVwiO1xuaW1wb3J0IHsgRmlsZVVwbG9hZFNlcnZpY2UgfSBmcm9tIFwiLi9maWxlLXVwbG9hZC5zZXJ2aWNlXCI7XG5pbXBvcnQgeyBGaWxlVXBsb2FkQ29tcG9uZW50IH0gZnJvbSBcIi4vZmlsZS11cGxvYWQuY29tcG9uZW50XCI7XG5cbkBOZ01vZHVsZSh7XG4gICAgZGVjbGFyYXRpb25zOiBbRmlsZVVwbG9hZENvbXBvbmVudF0sXG4gICAgaW1wb3J0czogW1xuICAgICAgICBDb21tb25Nb2R1bGUsXG4gICAgICAgIEJ1dHRvbk1vZHVsZSxcbiAgICAgICAgVG9vbHRpcE1vZHVsZSxcbiAgICAgICAgUHJvZ3Jlc3NCYXJNb2R1bGUsXG4gICAgICAgIFRyYW5zbGF0ZU1vZHVsZSxcbiAgICBdLFxuICAgIHByb3ZpZGVyczogW0ZpbGVVcGxvYWRTZXJ2aWNlXSxcbiAgICBleHBvcnRzOiBbRmlsZVVwbG9hZENvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIEZpbGVVcGxvYWRNb2R1bGUge31cbiJdfQ==
@@ -1,8 +1,6 @@
1
1
  import { __awaiter, __decorate } from "tslib";
2
2
  import { Injectable } from "@angular/core";
3
- import * as moment_ from "moment";
4
3
  import { CustomHttpClient } from "../code-editor/infra/utils";
5
- const moment = moment_;
6
4
  let FileUploadService = class FileUploadService {
7
5
  constructor() {
8
6
  this.BASE_URL_FIELD_CUSTOMIZATION = "platform/field_customization";
@@ -18,4 +16,4 @@ FileUploadService = __decorate([
18
16
  Injectable()
19
17
  ], FileUploadService);
20
18
  export { FileUploadService };
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWQuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BzZW5pb3JzaXN0ZW1hcy9hbmd1bGFyLWNvbXBvbmVudHMvIiwic291cmNlcyI6WyJjb21wb25lbnRzL2ZpbGUtdXBsb2FkL2ZpbGUtdXBsb2FkLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFM0MsT0FBTyxLQUFLLE9BQU8sTUFBTSxRQUFRLENBQUM7QUFFbEMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFNOUQsTUFBTSxNQUFNLEdBQUcsT0FBTyxDQUFDO0FBR3ZCLElBQWEsaUJBQWlCLEdBQTlCLE1BQWEsaUJBQWlCO0lBQTlCO1FBQ1ksaUNBQTRCLEdBQUcsOEJBQThCLENBQUM7UUFDOUQsVUFBSyxHQUFHLElBQUksZUFBZSxFQUFFLENBQUM7SUFTMUMsQ0FBQztJQVBnQixzQkFBc0IsQ0FBSSxPQUFnQzs7WUFDbkUsT0FBTyxnQkFBZ0IsQ0FBQyxJQUFJLENBQ3hCLEdBQUcsSUFBSSxDQUFDLDRCQUE0QiwwQkFBMEIsRUFDOUQsT0FBTyxFQUNQLEVBQUUsTUFBTSxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxFQUFFLENBQ2hDLENBQUM7UUFDTixDQUFDO0tBQUE7Q0FDSixDQUFBO0FBWFksaUJBQWlCO0lBRDdCLFVBQVUsRUFBRTtHQUNBLGlCQUFpQixDQVc3QjtTQVhZLGlCQUFpQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuXG5pbXBvcnQgKiBhcyBtb21lbnRfIGZyb20gXCJtb21lbnRcIjtcblxuaW1wb3J0IHsgQ3VzdG9tSHR0cENsaWVudCB9IGZyb20gXCIuLi9jb2RlLWVkaXRvci9pbmZyYS91dGlsc1wiO1xuaW1wb3J0IHtcbiAgICBMaXN0QmxvYk1ldGFkYXRhUmVxdWVzdCxcbiAgICBMaXN0QmxvYk1ldGFkYXRhUmVzcG9uc2Vcbn0gZnJvbSBcIi4vbW9kZWxzL2xpc3QtYmxvYi1tZXRhZGF0YVwiO1xuXG5jb25zdCBtb21lbnQgPSBtb21lbnRfO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgRmlsZVVwbG9hZFNlcnZpY2Uge1xuICAgIHByaXZhdGUgQkFTRV9VUkxfRklFTERfQ1VTVE9NSVpBVElPTiA9IFwicGxhdGZvcm0vZmllbGRfY3VzdG9taXphdGlvblwiO1xuICAgIHByaXZhdGUgVE9LRU4gPSBuZXcgQWJvcnRDb250cm9sbGVyKCk7XG5cbiAgICBwdWJsaWMgYXN5bmMgZ2V0TWV0YWRhdGFDdXN0b21GaWVsZDxUPihyZXF1ZXN0OiBMaXN0QmxvYk1ldGFkYXRhUmVxdWVzdCk6IFByb21pc2U8TGlzdEJsb2JNZXRhZGF0YVJlc3BvbnNlPiB7XG4gICAgICAgIHJldHVybiBDdXN0b21IdHRwQ2xpZW50LlBPU1QoXG4gICAgICAgICAgICBgJHt0aGlzLkJBU0VfVVJMX0ZJRUxEX0NVU1RPTUlaQVRJT059L3F1ZXJpZXMvZ2V0RmlsZU1ldGFkYXRhYCxcbiAgICAgICAgICAgIHJlcXVlc3QsXG4gICAgICAgICAgICB7IHNpZ25hbDogdGhpcy5UT0tFTi5zaWduYWwgfVxuICAgICAgICApO1xuICAgIH1cbn1cbiJdfQ==
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWQuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BzZW5pb3JzaXN0ZW1hcy9hbmd1bGFyLWNvbXBvbmVudHMvIiwic291cmNlcyI6WyJjb21wb25lbnRzL2ZpbGUtdXBsb2FkL2ZpbGUtdXBsb2FkLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFPOUQsSUFBYSxpQkFBaUIsR0FBOUIsTUFBYSxpQkFBaUI7SUFBOUI7UUFDWSxpQ0FBNEIsR0FBRyw4QkFBOEIsQ0FBQztRQUM5RCxVQUFLLEdBQUcsSUFBSSxlQUFlLEVBQUUsQ0FBQztJQVMxQyxDQUFDO0lBUGdCLHNCQUFzQixDQUFJLE9BQWdDOztZQUNuRSxPQUFPLGdCQUFnQixDQUFDLElBQUksQ0FDeEIsR0FBRyxJQUFJLENBQUMsNEJBQTRCLDBCQUEwQixFQUM5RCxPQUFPLEVBQ1AsRUFBRSxNQUFNLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLEVBQUUsQ0FDaEMsQ0FBQztRQUNOLENBQUM7S0FBQTtDQUNKLENBQUE7QUFYWSxpQkFBaUI7SUFEN0IsVUFBVSxFQUFFO0dBQ0EsaUJBQWlCLENBVzdCO1NBWFksaUJBQWlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBDdXN0b21IdHRwQ2xpZW50IH0gZnJvbSBcIi4uL2NvZGUtZWRpdG9yL2luZnJhL3V0aWxzXCI7XG5pbXBvcnQge1xuICAgIExpc3RCbG9iTWV0YWRhdGFSZXF1ZXN0LFxuICAgIExpc3RCbG9iTWV0YWRhdGFSZXNwb25zZVxufSBmcm9tIFwiLi9tb2RlbHMvbGlzdC1ibG9iLW1ldGFkYXRhXCJcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIEZpbGVVcGxvYWRTZXJ2aWNlIHtcbiAgICBwcml2YXRlIEJBU0VfVVJMX0ZJRUxEX0NVU1RPTUlaQVRJT04gPSBcInBsYXRmb3JtL2ZpZWxkX2N1c3RvbWl6YXRpb25cIjtcbiAgICBwcml2YXRlIFRPS0VOID0gbmV3IEFib3J0Q29udHJvbGxlcigpO1xuXG4gICAgcHVibGljIGFzeW5jIGdldE1ldGFkYXRhQ3VzdG9tRmllbGQ8VD4ocmVxdWVzdDogTGlzdEJsb2JNZXRhZGF0YVJlcXVlc3QpOiBQcm9taXNlPExpc3RCbG9iTWV0YWRhdGFSZXNwb25zZT4ge1xuICAgICAgICByZXR1cm4gQ3VzdG9tSHR0cENsaWVudC5QT1NUKFxuICAgICAgICAgICAgYCR7dGhpcy5CQVNFX1VSTF9GSUVMRF9DVVNUT01JWkFUSU9OfS9xdWVyaWVzL2dldEZpbGVNZXRhZGF0YWAsXG4gICAgICAgICAgICByZXF1ZXN0LFxuICAgICAgICAgICAgeyBzaWduYWw6IHRoaXMuVE9LRU4uc2lnbmFsIH1cbiAgICAgICAgKTtcbiAgICB9XG59XG4iXX0=
@@ -1,4 +1,3 @@
1
1
  export { ValidateErrors } from "./validate-errors";
2
2
  export { FileUploadPermissions } from "./file-upload-permissions";
3
- export { StorageUnits } from "./storage-units";
4
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yc2lzdGVtYXMvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy9maWxlLXVwbG9hZC9tb2RlbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBRW5ELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IEZpbGVEdG8gfSBmcm9tIFwiLi9maWxlLWR0b1wiO1xuZXhwb3J0IHsgVmFsaWRhdGVFcnJvcnMgfSBmcm9tIFwiLi92YWxpZGF0ZS1lcnJvcnNcIjtcbmV4cG9ydCB7IFVwbG9hZEVycm9yIH0gZnJvbSBcIi4vdXBsb2FkRXJyb3JcIjtcbmV4cG9ydCB7IEZpbGVVcGxvYWRQZXJtaXNzaW9ucyB9IGZyb20gXCIuL2ZpbGUtdXBsb2FkLXBlcm1pc3Npb25zXCI7XG5leHBvcnQgeyBTdG9yYWdlVW5pdHMgfSBmcm9tIFwiLi9zdG9yYWdlLXVuaXRzXCI7XG4iXX0=
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yc2lzdGVtYXMvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy9maWxlLXVwbG9hZC9tb2RlbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBRW5ELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDJCQUEyQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgRmlsZUR0byB9IGZyb20gXCIuL2ZpbGUtZHRvXCI7XG5leHBvcnQgeyBWYWxpZGF0ZUVycm9ycyB9IGZyb20gXCIuL3ZhbGlkYXRlLWVycm9yc1wiO1xuZXhwb3J0IHsgVXBsb2FkRXJyb3IgfSBmcm9tIFwiLi91cGxvYWRFcnJvclwiO1xuZXhwb3J0IHsgRmlsZVVwbG9hZFBlcm1pc3Npb25zIH0gZnJvbSBcIi4vZmlsZS11cGxvYWQtcGVybWlzc2lvbnNcIjtcbiJdfQ==
@@ -1,8 +1,7 @@
1
1
  export var ValidateErrors;
2
2
  (function (ValidateErrors) {
3
3
  ValidateErrors["MAX_FILE_SIZE"] = "MAX_FILE_SIZE";
4
- ValidateErrors["MAX_COMBINED_FILE_SIZE"] = "MAX_COMBINED_FILE_SIZE";
5
4
  ValidateErrors["MAX_FILE_LIMIT"] = "MAX_FILE_LIMIT";
6
5
  ValidateErrors["UNSUPPORTED_EXTENSION"] = "UNSUPPORTED_EXTENSION";
7
6
  })(ValidateErrors || (ValidateErrors = {}));
8
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdGUtZXJyb3JzLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQHNlbmlvcnNpc3RlbWFzL2FuZ3VsYXItY29tcG9uZW50cy8iLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvZmlsZS11cGxvYWQvbW9kZWxzL3ZhbGlkYXRlLWVycm9ycy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQU4sSUFBWSxjQUtYO0FBTEQsV0FBWSxjQUFjO0lBQ3ZCLGlEQUErQixDQUFBO0lBQy9CLG1FQUFpRCxDQUFBO0lBQ2pELG1EQUFpQyxDQUFBO0lBQ2pDLGlFQUErQyxDQUFBO0FBQ2xELENBQUMsRUFMVyxjQUFjLEtBQWQsY0FBYyxRQUt6QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIFZhbGlkYXRlRXJyb3JzIHtcbiAgIE1BWF9GSUxFX1NJWkUgPSBcIk1BWF9GSUxFX1NJWkVcIixcbiAgIE1BWF9DT01CSU5FRF9GSUxFX1NJWkUgPSBcIk1BWF9DT01CSU5FRF9GSUxFX1NJWkVcIixcbiAgIE1BWF9GSUxFX0xJTUlUID0gXCJNQVhfRklMRV9MSU1JVFwiLFxuICAgVU5TVVBQT1JURURfRVhURU5TSU9OID0gXCJVTlNVUFBPUlRFRF9FWFRFTlNJT05cIixcbn1cbiJdfQ==
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdGUtZXJyb3JzLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQHNlbmlvcnNpc3RlbWFzL2FuZ3VsYXItY29tcG9uZW50cy8iLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvZmlsZS11cGxvYWQvbW9kZWxzL3ZhbGlkYXRlLWVycm9ycy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQU4sSUFBWSxjQUlYO0FBSkQsV0FBWSxjQUFjO0lBQ3ZCLGlEQUErQixDQUFBO0lBQy9CLG1EQUFpQyxDQUFBO0lBQ2pDLGlFQUErQyxDQUFBO0FBQ2xELENBQUMsRUFKVyxjQUFjLEtBQWQsY0FBYyxRQUl6QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIFZhbGlkYXRlRXJyb3JzIHtcbiAgIE1BWF9GSUxFX1NJWkUgPSBcIk1BWF9GSUxFX1NJWkVcIixcbiAgIE1BWF9GSUxFX0xJTUlUID0gXCJNQVhfRklMRV9MSU1JVFwiLFxuICAgVU5TVVBQT1JURURfRVhURU5TSU9OID0gXCJVTlNVUFBPUlRFRF9FWFRFTlNJT05cIixcbn1cbiJdfQ==