@libs-ui/components-inputs-upload 0.2.319-0 → 0.2.321-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.
@@ -6,10 +6,11 @@ export declare class LibsUiComponentsInputsUploadAvatarComponent {
6
6
  readonly showVideoDuration: import("@angular/core").InputSignal<boolean | undefined>;
7
7
  readonly disable: import("@angular/core").InputSignal<boolean | undefined>;
8
8
  readonly size: import("@angular/core").InputSignal<number | undefined>;
9
+ readonly classInclude: import("@angular/core").InputSignalWithTransform<string, string | undefined>;
9
10
  readonly outOpenPreview: import("@angular/core").OutputEmitterRef<IFile>;
10
11
  constructor(linkImageError: string);
11
12
  protected handlerImageError(event: Event): Promise<void>;
12
13
  protected handlerImageClick(event: Event): void;
13
14
  static ɵfac: i0.ɵɵFactoryDeclaration<LibsUiComponentsInputsUploadAvatarComponent, [{ optional: true; }]>;
14
- static ɵcmp: i0.ɵɵComponentDeclaration<LibsUiComponentsInputsUploadAvatarComponent, "libs_ui-components-inputs-upload-avatar", never, { "item": { "alias": "item"; "required": true; "isSignal": true; }; "showVideoDuration": { "alias": "showVideoDuration"; "required": false; "isSignal": true; }; "disable": { "alias": "disable"; "required": false; "isSignal": true; }; "size": { "alias": "size"; "required": false; "isSignal": true; }; }, { "item": "itemChange"; "outOpenPreview": "outOpenPreview"; }, never, never, true, never>;
15
+ static ɵcmp: i0.ɵɵComponentDeclaration<LibsUiComponentsInputsUploadAvatarComponent, "libs_ui-components-inputs-upload-avatar", never, { "item": { "alias": "item"; "required": true; "isSignal": true; }; "showVideoDuration": { "alias": "showVideoDuration"; "required": false; "isSignal": true; }; "disable": { "alias": "disable"; "required": false; "isSignal": true; }; "size": { "alias": "size"; "required": false; "isSignal": true; }; "classInclude": { "alias": "classInclude"; "required": false; "isSignal": true; }; }, { "item": "itemChange"; "outOpenPreview": "outOpenPreview"; }, never, never, true, never>;
15
16
  }
@@ -14,6 +14,7 @@ export class LibsUiComponentsInputsUploadAvatarComponent {
14
14
  showVideoDuration = input();
15
15
  disable = input();
16
16
  size = input();
17
+ classInclude = input('', { transform: (value) => value ?? '' });
17
18
  outOpenPreview = output();
18
19
  constructor(linkImageError) {
19
20
  this.linkImageError = linkImageError;
@@ -29,15 +30,15 @@ export class LibsUiComponentsInputsUploadAvatarComponent {
29
30
  this.outOpenPreview.emit(this.item());
30
31
  }
31
32
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsInputsUploadAvatarComponent, deps: [{ token: LINK_IMAGE_ERROR_TOKEN_INJECT, optional: true }], target: i0.ɵɵFactoryTarget.Component });
32
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: LibsUiComponentsInputsUploadAvatarComponent, isStandalone: true, selector: "libs_ui-components-inputs-upload-avatar", inputs: { item: { classPropertyName: "item", publicName: "item", isSignal: true, isRequired: true, transformFunction: null }, showVideoDuration: { classPropertyName: "showVideoDuration", publicName: "showVideoDuration", isSignal: true, isRequired: false, transformFunction: null }, disable: { classPropertyName: "disable", publicName: "disable", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { item: "itemChange", outOpenPreview: "outOpenPreview" }, ngImport: i0, template: "<div\n class=\"flex mr-[12px] bg-[#ffffff] rounded-[4px]\"\n [class.libs-ui-disable]=\"disable() || item().isUploading || item().error\">\n @if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'image') {\n <div\n [style.width.px]=\"size() || 32\"\n [style.height.px]=\"size() || 32\"\n class=\"relative\">\n @if (item().url || item().origin_url; as url) {\n <img\n [src]=\"url\"\n [style.width.px]=\"size() || 32\"\n [style.height.px]=\"size() || 32\"\n class=\"rounded-[4px] cursor-pointer\"\n alt\n (error)=\"handlerImageError($event)\"\n (click)=\"handlerImageClick($event)\" />\n } @else {\n <libs_ui-components-spinner [size]=\"'medium'\" />\n }\n </div>\n } @else if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'video') {\n <div\n class=\"relative\"\n [style.width.px]=\"size() || 32\"\n [style.height.px]=\"size() || 32\">\n @if (item().url || item().origin_url) {\n <video\n #videoRef\n [style.width.px]=\"size || 32\"\n [style.height.px]=\"size || 32\"\n class=\"rounded-[4px]\"\n preload=\"metadata\"\n [src]=\"item().url || item().origin_url || '' | LibsUiPipesSecurityTrustPipe: 'resourceUrl'\"></video>\n <div class=\"absolute w-full h-full top-0 bg-[#001433] opacity-40 rounded-[4px]\"></div>\n <div class=\"absolute w-full h-full flex items-center justify-center top-0\">\n <i class=\"text-[#ffffff] libs-ui-icon-play-solid before:!text-[10px]\"></i>\n </div>\n @if (showVideoDuration()) {\n <div class=\"flex text-[5px] absolute bottom-0 right-0 py-[2px] px-[4px] rounded-[4px] bg-[#000000] text-[#ffffff]\">\n {{ videoRef.duration | LibsUiPipesInputsUploadCalcDurationVideoPipe }}\n </div>\n }\n } @else {\n <libs_ui-components-spinner [size]=\"'medium'\" />\n }\n </div>\n } @else if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'pdf') {\n <ng-container *ngComponentOutlet=\"'pdf' | LibsUiIconsGetIconComponentPipe | async\" />\n } @else if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'word') {\n <ng-container *ngComponentOutlet=\"'word' | LibsUiIconsGetIconComponentPipe | async\" />\n } @else if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'pptx') {\n <ng-container *ngComponentOutlet=\"'pptx' | LibsUiIconsGetIconComponentPipe | async\" />\n } @else if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'xlsx') {\n <ng-container *ngComponentOutlet=\"'xlsx' | LibsUiIconsGetIconComponentPipe | async\" />\n } @else {\n <div\n [style.width.px]=\"size() || 32\"\n [style.height.px]=\"size() || 32\"\n class=\"flex items-center justify-center\">\n <i\n class=\"libs-ui-icon-file before:!text-[19px]\"\n [class.text-[#6a7383]]=\"!item().isUploading && !item().error\"\n [class.text-[#071631]]=\"disable() || item().isUploading || item().error\"></i>\n </div>\n }\n</div>\n", dependencies: [{ kind: "directive", type: NgComponentOutlet, selector: "[ngComponentOutlet]", inputs: ["ngComponentOutlet", "ngComponentOutletInputs", "ngComponentOutletInjector", "ngComponentOutletContent", "ngComponentOutletNgModule", "ngComponentOutletNgModuleFactory"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "ngmodule", type: TranslateModule }, { kind: "component", type: LibsUiComponentsSpinnerComponent, selector: "libs_ui-components-spinner", inputs: ["type", "size"] }, { kind: "pipe", type: LibsUiPipesSecurityTrustPipe, name: "LibsUiPipesSecurityTrustPipe" }, { kind: "pipe", type: LibsUiPipesInputsUploadCalcDurationVideoPipe, name: "LibsUiPipesInputsUploadCalcDurationVideoPipe" }, { kind: "pipe", type: LibsUiPipesInputsUploadCheckFileExtensionPipe, name: "LibsUiPipesInputsUploadCheckFileExtensionPipe" }, { kind: "pipe", type: LibsUiIconsGetIconComponentPipe, name: "LibsUiIconsGetIconComponentPipe" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
33
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: LibsUiComponentsInputsUploadAvatarComponent, isStandalone: true, selector: "libs_ui-components-inputs-upload-avatar", inputs: { item: { classPropertyName: "item", publicName: "item", isSignal: true, isRequired: true, transformFunction: null }, showVideoDuration: { classPropertyName: "showVideoDuration", publicName: "showVideoDuration", isSignal: true, isRequired: false, transformFunction: null }, disable: { classPropertyName: "disable", publicName: "disable", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, classInclude: { classPropertyName: "classInclude", publicName: "classInclude", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { item: "itemChange", outOpenPreview: "outOpenPreview" }, ngImport: i0, template: "<div\n class=\"flex mr-[12px] bg-[#ffffff] rounded-[4px] {{ classInclude() }}\"\n [class.libs-ui-disable]=\"disable() || item().isUploading || item().error\">\n @if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'image') {\n <div\n [style.width.px]=\"size() || 32\"\n [style.height.px]=\"size() || 32\"\n class=\"relative\">\n @if (item().url || item().origin_url; as url) {\n <img\n [src]=\"url\"\n [style.width.px]=\"size() || 32\"\n [style.height.px]=\"size() || 32\"\n class=\"rounded-[4px] cursor-pointer\"\n alt\n (error)=\"handlerImageError($event)\"\n (click)=\"handlerImageClick($event)\" />\n } @else {\n <libs_ui-components-spinner [size]=\"'medium'\" />\n }\n </div>\n } @else if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'video') {\n <div\n class=\"relative\"\n [style.width.px]=\"size() || 32\"\n [style.height.px]=\"size() || 32\">\n @if (item().url || item().origin_url) {\n @let constHtmlSrc = item().url || item().origin_url || '';\n <video\n #videoRef\n [style.width.px]=\"size || 32\"\n [style.height.px]=\"size || 32\"\n class=\"rounded-[4px]\"\n preload=\"metadata\"\n [src]=\"constHtmlSrc | LibsUiPipesSecurityTrustPipe: 'resourceUrl'\"></video>\n <div class=\"absolute w-full h-full top-0 bg-[#001433] opacity-40 rounded-[4px]\"></div>\n <div class=\"absolute w-full h-full flex items-center justify-center top-0\">\n <i class=\"text-[#ffffff] libs-ui-icon-play-solid before:!text-[10px]\"></i>\n </div>\n @if (showVideoDuration()) {\n <div class=\"flex text-[5px] absolute bottom-0 right-0 py-[2px] px-[4px] rounded-[4px] bg-[#000000] text-[#ffffff]\">\n {{ videoRef.duration | LibsUiPipesInputsUploadCalcDurationVideoPipe }}\n </div>\n }\n } @else {\n <libs_ui-components-spinner [size]=\"'medium'\" />\n }\n </div>\n } @else if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'pdf') {\n <ng-container *ngComponentOutlet=\"'pdf' | LibsUiIconsGetIconComponentPipe | async; inputs: { size: size() || 32 }\" />\n } @else if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'word') {\n <ng-container *ngComponentOutlet=\"'word' | LibsUiIconsGetIconComponentPipe | async; inputs: { size: size() || 32 }\" />\n } @else if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'pptx') {\n <ng-container *ngComponentOutlet=\"'pptx' | LibsUiIconsGetIconComponentPipe | async; inputs: { size: size() || 32 }\" />\n } @else if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'xlsx') {\n <ng-container *ngComponentOutlet=\"'xlsx' | LibsUiIconsGetIconComponentPipe | async; inputs: { size: size() || 32 }\" />\n } @else {\n <div\n [style.width.px]=\"size() || 32\"\n [style.height.px]=\"size() || 32\"\n class=\"flex items-center justify-center\">\n <i\n class=\"libs-ui-icon-file before:!text-[19px]\"\n [class.text-[#6a7383]]=\"!item().isUploading && !item().error\"\n [class.text-[#071631]]=\"disable() || item().isUploading || item().error\"></i>\n </div>\n }\n</div>\n", dependencies: [{ kind: "directive", type: NgComponentOutlet, selector: "[ngComponentOutlet]", inputs: ["ngComponentOutlet", "ngComponentOutletInputs", "ngComponentOutletInjector", "ngComponentOutletContent", "ngComponentOutletNgModule", "ngComponentOutletNgModuleFactory"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "ngmodule", type: TranslateModule }, { kind: "component", type: LibsUiComponentsSpinnerComponent, selector: "libs_ui-components-spinner", inputs: ["type", "size"] }, { kind: "pipe", type: LibsUiPipesSecurityTrustPipe, name: "LibsUiPipesSecurityTrustPipe" }, { kind: "pipe", type: LibsUiPipesInputsUploadCalcDurationVideoPipe, name: "LibsUiPipesInputsUploadCalcDurationVideoPipe" }, { kind: "pipe", type: LibsUiPipesInputsUploadCheckFileExtensionPipe, name: "LibsUiPipesInputsUploadCheckFileExtensionPipe" }, { kind: "pipe", type: LibsUiIconsGetIconComponentPipe, name: "LibsUiIconsGetIconComponentPipe" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
33
34
  }
34
35
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsInputsUploadAvatarComponent, decorators: [{
35
36
  type: Component,
36
- args: [{ selector: 'libs_ui-components-inputs-upload-avatar', standalone: true, imports: [NgComponentOutlet, AsyncPipe, TranslateModule, LibsUiComponentsSpinnerComponent, LibsUiPipesSecurityTrustPipe, LibsUiPipesInputsUploadCalcDurationVideoPipe, LibsUiPipesInputsUploadCheckFileExtensionPipe, LibsUiIconsGetIconComponentPipe], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n class=\"flex mr-[12px] bg-[#ffffff] rounded-[4px]\"\n [class.libs-ui-disable]=\"disable() || item().isUploading || item().error\">\n @if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'image') {\n <div\n [style.width.px]=\"size() || 32\"\n [style.height.px]=\"size() || 32\"\n class=\"relative\">\n @if (item().url || item().origin_url; as url) {\n <img\n [src]=\"url\"\n [style.width.px]=\"size() || 32\"\n [style.height.px]=\"size() || 32\"\n class=\"rounded-[4px] cursor-pointer\"\n alt\n (error)=\"handlerImageError($event)\"\n (click)=\"handlerImageClick($event)\" />\n } @else {\n <libs_ui-components-spinner [size]=\"'medium'\" />\n }\n </div>\n } @else if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'video') {\n <div\n class=\"relative\"\n [style.width.px]=\"size() || 32\"\n [style.height.px]=\"size() || 32\">\n @if (item().url || item().origin_url) {\n <video\n #videoRef\n [style.width.px]=\"size || 32\"\n [style.height.px]=\"size || 32\"\n class=\"rounded-[4px]\"\n preload=\"metadata\"\n [src]=\"item().url || item().origin_url || '' | LibsUiPipesSecurityTrustPipe: 'resourceUrl'\"></video>\n <div class=\"absolute w-full h-full top-0 bg-[#001433] opacity-40 rounded-[4px]\"></div>\n <div class=\"absolute w-full h-full flex items-center justify-center top-0\">\n <i class=\"text-[#ffffff] libs-ui-icon-play-solid before:!text-[10px]\"></i>\n </div>\n @if (showVideoDuration()) {\n <div class=\"flex text-[5px] absolute bottom-0 right-0 py-[2px] px-[4px] rounded-[4px] bg-[#000000] text-[#ffffff]\">\n {{ videoRef.duration | LibsUiPipesInputsUploadCalcDurationVideoPipe }}\n </div>\n }\n } @else {\n <libs_ui-components-spinner [size]=\"'medium'\" />\n }\n </div>\n } @else if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'pdf') {\n <ng-container *ngComponentOutlet=\"'pdf' | LibsUiIconsGetIconComponentPipe | async\" />\n } @else if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'word') {\n <ng-container *ngComponentOutlet=\"'word' | LibsUiIconsGetIconComponentPipe | async\" />\n } @else if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'pptx') {\n <ng-container *ngComponentOutlet=\"'pptx' | LibsUiIconsGetIconComponentPipe | async\" />\n } @else if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'xlsx') {\n <ng-container *ngComponentOutlet=\"'xlsx' | LibsUiIconsGetIconComponentPipe | async\" />\n } @else {\n <div\n [style.width.px]=\"size() || 32\"\n [style.height.px]=\"size() || 32\"\n class=\"flex items-center justify-center\">\n <i\n class=\"libs-ui-icon-file before:!text-[19px]\"\n [class.text-[#6a7383]]=\"!item().isUploading && !item().error\"\n [class.text-[#071631]]=\"disable() || item().isUploading || item().error\"></i>\n </div>\n }\n</div>\n" }]
37
+ args: [{ selector: 'libs_ui-components-inputs-upload-avatar', standalone: true, imports: [NgComponentOutlet, AsyncPipe, TranslateModule, LibsUiComponentsSpinnerComponent, LibsUiPipesSecurityTrustPipe, LibsUiPipesInputsUploadCalcDurationVideoPipe, LibsUiPipesInputsUploadCheckFileExtensionPipe, LibsUiIconsGetIconComponentPipe], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n class=\"flex mr-[12px] bg-[#ffffff] rounded-[4px] {{ classInclude() }}\"\n [class.libs-ui-disable]=\"disable() || item().isUploading || item().error\">\n @if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'image') {\n <div\n [style.width.px]=\"size() || 32\"\n [style.height.px]=\"size() || 32\"\n class=\"relative\">\n @if (item().url || item().origin_url; as url) {\n <img\n [src]=\"url\"\n [style.width.px]=\"size() || 32\"\n [style.height.px]=\"size() || 32\"\n class=\"rounded-[4px] cursor-pointer\"\n alt\n (error)=\"handlerImageError($event)\"\n (click)=\"handlerImageClick($event)\" />\n } @else {\n <libs_ui-components-spinner [size]=\"'medium'\" />\n }\n </div>\n } @else if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'video') {\n <div\n class=\"relative\"\n [style.width.px]=\"size() || 32\"\n [style.height.px]=\"size() || 32\">\n @if (item().url || item().origin_url) {\n @let constHtmlSrc = item().url || item().origin_url || '';\n <video\n #videoRef\n [style.width.px]=\"size || 32\"\n [style.height.px]=\"size || 32\"\n class=\"rounded-[4px]\"\n preload=\"metadata\"\n [src]=\"constHtmlSrc | LibsUiPipesSecurityTrustPipe: 'resourceUrl'\"></video>\n <div class=\"absolute w-full h-full top-0 bg-[#001433] opacity-40 rounded-[4px]\"></div>\n <div class=\"absolute w-full h-full flex items-center justify-center top-0\">\n <i class=\"text-[#ffffff] libs-ui-icon-play-solid before:!text-[10px]\"></i>\n </div>\n @if (showVideoDuration()) {\n <div class=\"flex text-[5px] absolute bottom-0 right-0 py-[2px] px-[4px] rounded-[4px] bg-[#000000] text-[#ffffff]\">\n {{ videoRef.duration | LibsUiPipesInputsUploadCalcDurationVideoPipe }}\n </div>\n }\n } @else {\n <libs_ui-components-spinner [size]=\"'medium'\" />\n }\n </div>\n } @else if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'pdf') {\n <ng-container *ngComponentOutlet=\"'pdf' | LibsUiIconsGetIconComponentPipe | async; inputs: { size: size() || 32 }\" />\n } @else if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'word') {\n <ng-container *ngComponentOutlet=\"'word' | LibsUiIconsGetIconComponentPipe | async; inputs: { size: size() || 32 }\" />\n } @else if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'pptx') {\n <ng-container *ngComponentOutlet=\"'pptx' | LibsUiIconsGetIconComponentPipe | async; inputs: { size: size() || 32 }\" />\n } @else if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'xlsx') {\n <ng-container *ngComponentOutlet=\"'xlsx' | LibsUiIconsGetIconComponentPipe | async; inputs: { size: size() || 32 }\" />\n } @else {\n <div\n [style.width.px]=\"size() || 32\"\n [style.height.px]=\"size() || 32\"\n class=\"flex items-center justify-center\">\n <i\n class=\"libs-ui-icon-file before:!text-[19px]\"\n [class.text-[#6a7383]]=\"!item().isUploading && !item().error\"\n [class.text-[#071631]]=\"disable() || item().isUploading || item().error\"></i>\n </div>\n }\n</div>\n" }]
37
38
  }], ctorParameters: () => [{ type: undefined, decorators: [{
38
39
  type: Optional
39
40
  }, {
40
41
  type: Inject,
41
42
  args: [LINK_IMAGE_ERROR_TOKEN_INJECT]
42
43
  }] }] });
43
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"avatar.component.js","sourceRoot":"","sources":["../../../../../../../libs-ui/components/inputs/upload/src/avatar/avatar.component.ts","../../../../../../../libs-ui/components/inputs/upload/src/avatar/avatar.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AAC/D,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAC3G,OAAO,EAAE,gCAAgC,EAAE,MAAM,6BAA6B,CAAC;AAC/E,OAAO,EAAE,+BAA+B,EAAE,MAAM,gBAAgB,CAAC;AAEjE,OAAO,EAAE,4BAA4B,EAAE,MAAM,+BAA+B,CAAC;AAC7E,OAAO,EAAE,6BAA6B,EAAE,MAAM,gBAAgB,CAAC;AAC/D,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,4CAA4C,EAAE,MAAM,mCAAmC,CAAC;AACjG,OAAO,EAAE,6CAA6C,EAAE,MAAM,oCAAoC,CAAC;;AAUnG,MAAM,OAAO,2CAA2C;IAOiB;IAN9D,IAAI,GAAG,KAAK,CAAC,QAAQ,EAAS,CAAC;IAC/B,iBAAiB,GAAG,KAAK,EAAW,CAAC;IACrC,OAAO,GAAG,KAAK,EAAW,CAAC;IAC3B,IAAI,GAAG,KAAK,EAAU,CAAC;IACvB,cAAc,GAAG,MAAM,EAAS,CAAC;IAE1C,YAAuE,cAAsB;QAAtB,mBAAc,GAAd,cAAc,CAAQ;IAAG,CAAC;IAEvF,KAAK,CAAC,iBAAiB,CAAC,KAAY;QAC5C,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC;YACzB,OAAO;QACT,CAAC;QACA,KAAgB,CAAC,MAAM,CAAC,GAAG,GAAG,IAAI,CAAC,cAAc,CAAC;IACrD,CAAC;IAES,iBAAiB,CAAC,KAAY;QACtC,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;IACxC,CAAC;wGAnBU,2CAA2C,kBAOtB,6BAA6B;4FAPlD,2CAA2C,qrBCnBxD,4iGAmEA,4CDnDY,iBAAiB,+OAAE,SAAS,6CAAE,eAAe,+BAAE,gCAAgC,4FAAE,4BAA4B,gEAAE,4CAA4C,gFAAE,6CAA6C,iFAAE,+BAA+B;;4FAG1O,2CAA2C;kBARvD,SAAS;+BAEE,yCAAyC,cAEvC,IAAI,WACP,CAAC,iBAAiB,EAAE,SAAS,EAAE,eAAe,EAAE,gCAAgC,EAAE,4BAA4B,EAAE,4CAA4C,EAAE,6CAA6C,EAAE,+BAA+B,CAAC,mBACrO,uBAAuB,CAAC,MAAM;;0BASlC,QAAQ;;0BAAI,MAAM;2BAAC,6BAA6B","sourcesContent":["import { AsyncPipe, NgComponentOutlet } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, Inject, input, model, Optional, output } from '@angular/core';\nimport { LibsUiComponentsSpinnerComponent } from '@libs-ui/components-spinner';\nimport { LibsUiIconsGetIconComponentPipe } from '@libs-ui/icons';\nimport { IEvent, IFile } from '@libs-ui/interfaces-types';\nimport { LibsUiPipesSecurityTrustPipe } from '@libs-ui/pipes-security-trust';\nimport { LINK_IMAGE_ERROR_TOKEN_INJECT } from '@libs-ui/utils';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { LibsUiPipesInputsUploadCalcDurationVideoPipe } from '../pipes/calc-duration-video.pipe';\nimport { LibsUiPipesInputsUploadCheckFileExtensionPipe } from '../pipes/check-file-extension.pipe';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'libs_ui-components-inputs-upload-avatar',\n  templateUrl: './avatar.component.html',\n  standalone: true,\n  imports: [NgComponentOutlet, AsyncPipe, TranslateModule, LibsUiComponentsSpinnerComponent, LibsUiPipesSecurityTrustPipe, LibsUiPipesInputsUploadCalcDurationVideoPipe, LibsUiPipesInputsUploadCheckFileExtensionPipe, LibsUiIconsGetIconComponentPipe],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class LibsUiComponentsInputsUploadAvatarComponent {\n  readonly item = model.required<IFile>();\n  readonly showVideoDuration = input<boolean>();\n  readonly disable = input<boolean>();\n  readonly size = input<number>();\n  readonly outOpenPreview = output<IFile>();\n\n  constructor(@Optional() @Inject(LINK_IMAGE_ERROR_TOKEN_INJECT) private linkImageError: string) {}\n\n  protected async handlerImageError(event: Event) {\n    if (!this.linkImageError) {\n      return;\n    }\n    (event as IEvent).target.src = this.linkImageError;\n  }\n\n  protected handlerImageClick(event: Event) {\n    event.stopPropagation();\n    this.outOpenPreview.emit(this.item());\n  }\n}\n","<div\n  class=\"flex mr-[12px] bg-[#ffffff] rounded-[4px]\"\n  [class.libs-ui-disable]=\"disable() || item().isUploading || item().error\">\n  @if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'image') {\n    <div\n      [style.width.px]=\"size() || 32\"\n      [style.height.px]=\"size() || 32\"\n      class=\"relative\">\n      @if (item().url || item().origin_url; as url) {\n        <img\n          [src]=\"url\"\n          [style.width.px]=\"size() || 32\"\n          [style.height.px]=\"size() || 32\"\n          class=\"rounded-[4px] cursor-pointer\"\n          alt\n          (error)=\"handlerImageError($event)\"\n          (click)=\"handlerImageClick($event)\" />\n      } @else {\n        <libs_ui-components-spinner [size]=\"'medium'\" />\n      }\n    </div>\n  } @else if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'video') {\n    <div\n      class=\"relative\"\n      [style.width.px]=\"size() || 32\"\n      [style.height.px]=\"size() || 32\">\n      @if (item().url || item().origin_url) {\n        <video\n          #videoRef\n          [style.width.px]=\"size || 32\"\n          [style.height.px]=\"size || 32\"\n          class=\"rounded-[4px]\"\n          preload=\"metadata\"\n          [src]=\"item().url || item().origin_url || '' | LibsUiPipesSecurityTrustPipe: 'resourceUrl'\"></video>\n        <div class=\"absolute w-full h-full top-0 bg-[#001433] opacity-40 rounded-[4px]\"></div>\n        <div class=\"absolute w-full h-full flex items-center justify-center top-0\">\n          <i class=\"text-[#ffffff] libs-ui-icon-play-solid before:!text-[10px]\"></i>\n        </div>\n        @if (showVideoDuration()) {\n          <div class=\"flex text-[5px] absolute bottom-0 right-0 py-[2px] px-[4px] rounded-[4px] bg-[#000000] text-[#ffffff]\">\n            {{ videoRef.duration | LibsUiPipesInputsUploadCalcDurationVideoPipe }}\n          </div>\n        }\n      } @else {\n        <libs_ui-components-spinner [size]=\"'medium'\" />\n      }\n    </div>\n  } @else if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'pdf') {\n    <ng-container *ngComponentOutlet=\"'pdf' | LibsUiIconsGetIconComponentPipe | async\" />\n  } @else if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'word') {\n    <ng-container *ngComponentOutlet=\"'word' | LibsUiIconsGetIconComponentPipe | async\" />\n  } @else if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'pptx') {\n    <ng-container *ngComponentOutlet=\"'pptx' | LibsUiIconsGetIconComponentPipe | async\" />\n  } @else if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'xlsx') {\n    <ng-container *ngComponentOutlet=\"'xlsx' | LibsUiIconsGetIconComponentPipe | async\" />\n  } @else {\n    <div\n      [style.width.px]=\"size() || 32\"\n      [style.height.px]=\"size() || 32\"\n      class=\"flex items-center justify-center\">\n      <i\n        class=\"libs-ui-icon-file before:!text-[19px]\"\n        [class.text-[#6a7383]]=\"!item().isUploading && !item().error\"\n        [class.text-[#071631]]=\"disable() || item().isUploading || item().error\"></i>\n    </div>\n  }\n</div>\n"]}
44
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"avatar.component.js","sourceRoot":"","sources":["../../../../../../../libs-ui/components/inputs/upload/src/avatar/avatar.component.ts","../../../../../../../libs-ui/components/inputs/upload/src/avatar/avatar.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AAC/D,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAC3G,OAAO,EAAE,gCAAgC,EAAE,MAAM,6BAA6B,CAAC;AAC/E,OAAO,EAAE,+BAA+B,EAAE,MAAM,gBAAgB,CAAC;AAEjE,OAAO,EAAE,4BAA4B,EAAE,MAAM,+BAA+B,CAAC;AAC7E,OAAO,EAAE,6BAA6B,EAAE,MAAM,gBAAgB,CAAC;AAC/D,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,4CAA4C,EAAE,MAAM,mCAAmC,CAAC;AACjG,OAAO,EAAE,6CAA6C,EAAE,MAAM,oCAAoC,CAAC;;AAUnG,MAAM,OAAO,2CAA2C;IASiB;IAR9D,IAAI,GAAG,KAAK,CAAC,QAAQ,EAAS,CAAC;IAC/B,iBAAiB,GAAG,KAAK,EAAW,CAAC;IACrC,OAAO,GAAG,KAAK,EAAW,CAAC;IAC3B,IAAI,GAAG,KAAK,EAAU,CAAC;IACvB,YAAY,GAAG,KAAK,CAA6B,EAAE,EAAE,EAAE,SAAS,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,IAAI,EAAE,EAAE,CAAC,CAAC;IAE5F,cAAc,GAAG,MAAM,EAAS,CAAC;IAE1C,YAAuE,cAAsB;QAAtB,mBAAc,GAAd,cAAc,CAAQ;IAAG,CAAC;IAEvF,KAAK,CAAC,iBAAiB,CAAC,KAAY;QAC5C,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC;YACzB,OAAO;QACT,CAAC;QACA,KAAgB,CAAC,MAAM,CAAC,GAAG,GAAG,IAAI,CAAC,cAAc,CAAC;IACrD,CAAC;IAES,iBAAiB,CAAC,KAAY;QACtC,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;IACxC,CAAC;wGArBU,2CAA2C,kBAStB,6BAA6B;4FATlD,2CAA2C,k0BCnBxD,4uGAoEA,4CDpDY,iBAAiB,+OAAE,SAAS,6CAAE,eAAe,+BAAE,gCAAgC,4FAAE,4BAA4B,gEAAE,4CAA4C,gFAAE,6CAA6C,iFAAE,+BAA+B;;4FAG1O,2CAA2C;kBARvD,SAAS;+BAEE,yCAAyC,cAEvC,IAAI,WACP,CAAC,iBAAiB,EAAE,SAAS,EAAE,eAAe,EAAE,gCAAgC,EAAE,4BAA4B,EAAE,4CAA4C,EAAE,6CAA6C,EAAE,+BAA+B,CAAC,mBACrO,uBAAuB,CAAC,MAAM;;0BAWlC,QAAQ;;0BAAI,MAAM;2BAAC,6BAA6B","sourcesContent":["import { AsyncPipe, NgComponentOutlet } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, Inject, input, model, Optional, output } from '@angular/core';\nimport { LibsUiComponentsSpinnerComponent } from '@libs-ui/components-spinner';\nimport { LibsUiIconsGetIconComponentPipe } from '@libs-ui/icons';\nimport { IEvent, IFile } from '@libs-ui/interfaces-types';\nimport { LibsUiPipesSecurityTrustPipe } from '@libs-ui/pipes-security-trust';\nimport { LINK_IMAGE_ERROR_TOKEN_INJECT } from '@libs-ui/utils';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { LibsUiPipesInputsUploadCalcDurationVideoPipe } from '../pipes/calc-duration-video.pipe';\nimport { LibsUiPipesInputsUploadCheckFileExtensionPipe } from '../pipes/check-file-extension.pipe';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'libs_ui-components-inputs-upload-avatar',\n  templateUrl: './avatar.component.html',\n  standalone: true,\n  imports: [NgComponentOutlet, AsyncPipe, TranslateModule, LibsUiComponentsSpinnerComponent, LibsUiPipesSecurityTrustPipe, LibsUiPipesInputsUploadCalcDurationVideoPipe, LibsUiPipesInputsUploadCheckFileExtensionPipe, LibsUiIconsGetIconComponentPipe],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class LibsUiComponentsInputsUploadAvatarComponent {\n  readonly item = model.required<IFile>();\n  readonly showVideoDuration = input<boolean>();\n  readonly disable = input<boolean>();\n  readonly size = input<number>();\n  readonly classInclude = input<string, string | undefined>('', { transform: (value) => value ?? '' });\n\n  readonly outOpenPreview = output<IFile>();\n\n  constructor(@Optional() @Inject(LINK_IMAGE_ERROR_TOKEN_INJECT) private linkImageError: string) {}\n\n  protected async handlerImageError(event: Event) {\n    if (!this.linkImageError) {\n      return;\n    }\n    (event as IEvent).target.src = this.linkImageError;\n  }\n\n  protected handlerImageClick(event: Event) {\n    event.stopPropagation();\n    this.outOpenPreview.emit(this.item());\n  }\n}\n","<div\n  class=\"flex mr-[12px] bg-[#ffffff] rounded-[4px] {{ classInclude() }}\"\n  [class.libs-ui-disable]=\"disable() || item().isUploading || item().error\">\n  @if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'image') {\n    <div\n      [style.width.px]=\"size() || 32\"\n      [style.height.px]=\"size() || 32\"\n      class=\"relative\">\n      @if (item().url || item().origin_url; as url) {\n        <img\n          [src]=\"url\"\n          [style.width.px]=\"size() || 32\"\n          [style.height.px]=\"size() || 32\"\n          class=\"rounded-[4px] cursor-pointer\"\n          alt\n          (error)=\"handlerImageError($event)\"\n          (click)=\"handlerImageClick($event)\" />\n      } @else {\n        <libs_ui-components-spinner [size]=\"'medium'\" />\n      }\n    </div>\n  } @else if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'video') {\n    <div\n      class=\"relative\"\n      [style.width.px]=\"size() || 32\"\n      [style.height.px]=\"size() || 32\">\n      @if (item().url || item().origin_url) {\n        @let constHtmlSrc = item().url || item().origin_url || '';\n        <video\n          #videoRef\n          [style.width.px]=\"size || 32\"\n          [style.height.px]=\"size || 32\"\n          class=\"rounded-[4px]\"\n          preload=\"metadata\"\n          [src]=\"constHtmlSrc | LibsUiPipesSecurityTrustPipe: 'resourceUrl'\"></video>\n        <div class=\"absolute w-full h-full top-0 bg-[#001433] opacity-40 rounded-[4px]\"></div>\n        <div class=\"absolute w-full h-full flex items-center justify-center top-0\">\n          <i class=\"text-[#ffffff] libs-ui-icon-play-solid before:!text-[10px]\"></i>\n        </div>\n        @if (showVideoDuration()) {\n          <div class=\"flex text-[5px] absolute bottom-0 right-0 py-[2px] px-[4px] rounded-[4px] bg-[#000000] text-[#ffffff]\">\n            {{ videoRef.duration | LibsUiPipesInputsUploadCalcDurationVideoPipe }}\n          </div>\n        }\n      } @else {\n        <libs_ui-components-spinner [size]=\"'medium'\" />\n      }\n    </div>\n  } @else if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'pdf') {\n    <ng-container *ngComponentOutlet=\"'pdf' | LibsUiIconsGetIconComponentPipe | async; inputs: { size: size() || 32 }\" />\n  } @else if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'word') {\n    <ng-container *ngComponentOutlet=\"'word' | LibsUiIconsGetIconComponentPipe | async; inputs: { size: size() || 32 }\" />\n  } @else if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'pptx') {\n    <ng-container *ngComponentOutlet=\"'pptx' | LibsUiIconsGetIconComponentPipe | async; inputs: { size: size() || 32 }\" />\n  } @else if (item() | LibsUiPipesInputsUploadCheckFileExtensionPipe: 'xlsx') {\n    <ng-container *ngComponentOutlet=\"'xlsx' | LibsUiIconsGetIconComponentPipe | async; inputs: { size: size() || 32 }\" />\n  } @else {\n    <div\n      [style.width.px]=\"size() || 32\"\n      [style.height.px]=\"size() || 32\"\n      class=\"flex items-center justify-center\">\n      <i\n        class=\"libs-ui-icon-file before:!text-[19px]\"\n        [class.text-[#6a7383]]=\"!item().isUploading && !item().error\"\n        [class.text-[#071631]]=\"disable() || item().isUploading || item().error\"></i>\n    </div>\n  }\n</div>\n"]}
@@ -15,7 +15,7 @@ export class LibsUiPipesInputsUploadCheckFileExtensionPipe {
15
15
  case 'word':
16
16
  return ['doc', 'docx', 'application/msword', 'application/vnd.openxmlformats-officedocument.wordprocessingml.document'].includes(fileExtension);
17
17
  case 'xlsx':
18
- return ['xls', 'xlsx', 'application/vnd.ms-excel', 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'].includes(fileExtension);
18
+ return ['xls', 'xlsx', 'application/vnd.ms-excel', 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet', 'gsheet'].includes(fileExtension);
19
19
  case 'pdf':
20
20
  return ['pdf', 'application/pdf'].includes(fileExtension);
21
21
  case 'pptx':
@@ -34,4 +34,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
34
34
  standalone: true,
35
35
  }]
36
36
  }] });
37
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2stZmlsZS1leHRlbnNpb24ucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMtdWkvY29tcG9uZW50cy9pbnB1dHMvdXBsb2FkL3NyYy9waXBlcy9jaGVjay1maWxlLWV4dGVuc2lvbi5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDO0FBRXBELE9BQU8sRUFBRSxlQUFlLEVBQUUsZ0JBQWdCLEVBQUUsWUFBWSxFQUFFLFlBQVksRUFBRSxNQUFNLGdCQUFnQixDQUFDOztBQU0vRixNQUFNLE9BQU8sNkNBQTZDO0lBQ3hELFNBQVMsQ0FBQyxJQUFXLEVBQUUsSUFBb0U7UUFDekYsTUFBTSxhQUFhLEdBQUcsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLENBQUM7UUFFN0MsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO1lBQ25CLE9BQU8sS0FBSyxDQUFDO1FBQ2YsQ0FBQztRQUNELFFBQVEsSUFBSSxFQUFFLENBQUM7WUFDYixLQUFLLE9BQU87Z0JBQ1YsT0FBTyxZQUFZLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1lBRTlDLEtBQUssT0FBTztnQkFDVixPQUFPLFlBQVksQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDLENBQUM7WUFFOUMsS0FBSyxNQUFNO2dCQUNULE9BQU8sQ0FBQyxLQUFLLEVBQUUsTUFBTSxFQUFFLG9CQUFvQixFQUFFLHlFQUF5RSxDQUFDLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1lBRWxKLEtBQUssTUFBTTtnQkFDVCxPQUFPLENBQUMsS0FBSyxFQUFFLE1BQU0sRUFBRSwwQkFBMEIsRUFBRSxtRUFBbUUsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsQ0FBQztZQUVsSixLQUFLLEtBQUs7Z0JBQ1IsT0FBTyxDQUFDLEtBQUssRUFBRSxpQkFBaUIsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsQ0FBQztZQUU1RCxLQUFLLE1BQU07Z0JBQ1QsT0FBTyxDQUFDLEtBQUssRUFBRSxNQUFNLEVBQUUsK0JBQStCLEVBQUUsMkVBQTJFLENBQUMsQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDLENBQUM7WUFFL0osS0FBSyxPQUFPO2dCQUNWLE9BQU8sQ0FBQyxDQUFDLEdBQUcsWUFBWSxFQUFFLEdBQUcsWUFBWSxFQUFFLEdBQUcsZUFBZSxDQUFDLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQzNGLENBQUM7SUFDSCxDQUFDO3dHQTdCVSw2Q0FBNkM7c0dBQTdDLDZDQUE2Qzs7NEZBQTdDLDZDQUE2QztrQkFKekQsSUFBSTttQkFBQztvQkFDSixJQUFJLEVBQUUsK0NBQStDO29CQUNyRCxVQUFVLEVBQUUsSUFBSTtpQkFDakIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBJRmlsZSB9IGZyb20gJ0BsaWJzLXVpL2ludGVyZmFjZXMtdHlwZXMnO1xuaW1wb3J0IHsgRG9jdW1lbnRFeHRMaXN0LCBnZXRGaWxlRXh0ZW5zaW9uLCBJbWFnZUV4dExpc3QsIFZpZGVvRXh0TGlzdCB9IGZyb20gJ0BsaWJzLXVpL3V0aWxzJztcblxuQFBpcGUoe1xuICBuYW1lOiAnTGlic1VpUGlwZXNJbnB1dHNVcGxvYWRDaGVja0ZpbGVFeHRlbnNpb25QaXBlJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbn0pXG5leHBvcnQgY2xhc3MgTGlic1VpUGlwZXNJbnB1dHNVcGxvYWRDaGVja0ZpbGVFeHRlbnNpb25QaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XG4gIHRyYW5zZm9ybShmaWxlOiBJRmlsZSwgdHlwZTogJ2ltYWdlJyB8ICd2aWRlbycgfCAnd29yZCcgfCAneGxzeCcgfCAncGRmJyB8ICdwcHR4JyB8ICdvdGhlcicpIHtcbiAgICBjb25zdCBmaWxlRXh0ZW5zaW9uID0gZ2V0RmlsZUV4dGVuc2lvbihmaWxlKTtcblxuICAgIGlmICghZmlsZUV4dGVuc2lvbikge1xuICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbiAgICBzd2l0Y2ggKHR5cGUpIHtcbiAgICAgIGNhc2UgJ2ltYWdlJzpcbiAgICAgICAgcmV0dXJuIEltYWdlRXh0TGlzdC5pbmNsdWRlcyhmaWxlRXh0ZW5zaW9uKTtcblxuICAgICAgY2FzZSAndmlkZW8nOlxuICAgICAgICByZXR1cm4gVmlkZW9FeHRMaXN0LmluY2x1ZGVzKGZpbGVFeHRlbnNpb24pO1xuXG4gICAgICBjYXNlICd3b3JkJzpcbiAgICAgICAgcmV0dXJuIFsnZG9jJywgJ2RvY3gnLCAnYXBwbGljYXRpb24vbXN3b3JkJywgJ2FwcGxpY2F0aW9uL3ZuZC5vcGVueG1sZm9ybWF0cy1vZmZpY2Vkb2N1bWVudC53b3JkcHJvY2Vzc2luZ21sLmRvY3VtZW50J10uaW5jbHVkZXMoZmlsZUV4dGVuc2lvbik7XG5cbiAgICAgIGNhc2UgJ3hsc3gnOlxuICAgICAgICByZXR1cm4gWyd4bHMnLCAneGxzeCcsICdhcHBsaWNhdGlvbi92bmQubXMtZXhjZWwnLCAnYXBwbGljYXRpb24vdm5kLm9wZW54bWxmb3JtYXRzLW9mZmljZWRvY3VtZW50LnNwcmVhZHNoZWV0bWwuc2hlZXQnXS5pbmNsdWRlcyhmaWxlRXh0ZW5zaW9uKTtcblxuICAgICAgY2FzZSAncGRmJzpcbiAgICAgICAgcmV0dXJuIFsncGRmJywgJ2FwcGxpY2F0aW9uL3BkZiddLmluY2x1ZGVzKGZpbGVFeHRlbnNpb24pO1xuXG4gICAgICBjYXNlICdwcHR4JzpcbiAgICAgICAgcmV0dXJuIFsncHB0JywgJ3BwdHgnLCAnYXBwbGljYXRpb24vdm5kLm1zLXBvd2VycG9pbnQnLCAnYXBwbGljYXRpb24vdm5kLm9wZW54bWxmb3JtYXRzLW9mZmljZWRvY3VtZW50LnByZXNlbnRhdGlvbm1sLnByZXNlbnRhdGlvbiddLmluY2x1ZGVzKGZpbGVFeHRlbnNpb24pO1xuXG4gICAgICBjYXNlICdvdGhlcic6XG4gICAgICAgIHJldHVybiAhWy4uLkltYWdlRXh0TGlzdCwgLi4uVmlkZW9FeHRMaXN0LCAuLi5Eb2N1bWVudEV4dExpc3RdLmluY2x1ZGVzKGZpbGVFeHRlbnNpb24pO1xuICAgIH1cbiAgfVxufVxuIl19
37
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2stZmlsZS1leHRlbnNpb24ucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMtdWkvY29tcG9uZW50cy9pbnB1dHMvdXBsb2FkL3NyYy9waXBlcy9jaGVjay1maWxlLWV4dGVuc2lvbi5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDO0FBRXBELE9BQU8sRUFBRSxlQUFlLEVBQUUsZ0JBQWdCLEVBQUUsWUFBWSxFQUFFLFlBQVksRUFBRSxNQUFNLGdCQUFnQixDQUFDOztBQU0vRixNQUFNLE9BQU8sNkNBQTZDO0lBQ3hELFNBQVMsQ0FBQyxJQUFXLEVBQUUsSUFBb0U7UUFDekYsTUFBTSxhQUFhLEdBQUcsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLENBQUM7UUFFN0MsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO1lBQ25CLE9BQU8sS0FBSyxDQUFDO1FBQ2YsQ0FBQztRQUNELFFBQVEsSUFBSSxFQUFFLENBQUM7WUFDYixLQUFLLE9BQU87Z0JBQ1YsT0FBTyxZQUFZLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1lBRTlDLEtBQUssT0FBTztnQkFDVixPQUFPLFlBQVksQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDLENBQUM7WUFFOUMsS0FBSyxNQUFNO2dCQUNULE9BQU8sQ0FBQyxLQUFLLEVBQUUsTUFBTSxFQUFFLG9CQUFvQixFQUFFLHlFQUF5RSxDQUFDLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1lBRWxKLEtBQUssTUFBTTtnQkFDVCxPQUFPLENBQUMsS0FBSyxFQUFFLE1BQU0sRUFBRSwwQkFBMEIsRUFBRSxtRUFBbUUsRUFBRSxRQUFRLENBQUMsQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDLENBQUM7WUFFNUosS0FBSyxLQUFLO2dCQUNSLE9BQU8sQ0FBQyxLQUFLLEVBQUUsaUJBQWlCLENBQUMsQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDLENBQUM7WUFFNUQsS0FBSyxNQUFNO2dCQUNULE9BQU8sQ0FBQyxLQUFLLEVBQUUsTUFBTSxFQUFFLCtCQUErQixFQUFFLDJFQUEyRSxDQUFDLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1lBRS9KLEtBQUssT0FBTztnQkFDVixPQUFPLENBQUMsQ0FBQyxHQUFHLFlBQVksRUFBRSxHQUFHLFlBQVksRUFBRSxHQUFHLGVBQWUsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUMzRixDQUFDO0lBQ0gsQ0FBQzt3R0E3QlUsNkNBQTZDO3NHQUE3Qyw2Q0FBNkM7OzRGQUE3Qyw2Q0FBNkM7a0JBSnpELElBQUk7bUJBQUM7b0JBQ0osSUFBSSxFQUFFLCtDQUErQztvQkFDckQsVUFBVSxFQUFFLElBQUk7aUJBQ2pCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSUZpbGUgfSBmcm9tICdAbGlicy11aS9pbnRlcmZhY2VzLXR5cGVzJztcbmltcG9ydCB7IERvY3VtZW50RXh0TGlzdCwgZ2V0RmlsZUV4dGVuc2lvbiwgSW1hZ2VFeHRMaXN0LCBWaWRlb0V4dExpc3QgfSBmcm9tICdAbGlicy11aS91dGlscyc7XG5cbkBQaXBlKHtcbiAgbmFtZTogJ0xpYnNVaVBpcGVzSW5wdXRzVXBsb2FkQ2hlY2tGaWxlRXh0ZW5zaW9uUGlwZScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIExpYnNVaVBpcGVzSW5wdXRzVXBsb2FkQ2hlY2tGaWxlRXh0ZW5zaW9uUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuICB0cmFuc2Zvcm0oZmlsZTogSUZpbGUsIHR5cGU6ICdpbWFnZScgfCAndmlkZW8nIHwgJ3dvcmQnIHwgJ3hsc3gnIHwgJ3BkZicgfCAncHB0eCcgfCAnb3RoZXInKSB7XG4gICAgY29uc3QgZmlsZUV4dGVuc2lvbiA9IGdldEZpbGVFeHRlbnNpb24oZmlsZSk7XG5cbiAgICBpZiAoIWZpbGVFeHRlbnNpb24pIHtcbiAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG4gICAgc3dpdGNoICh0eXBlKSB7XG4gICAgICBjYXNlICdpbWFnZSc6XG4gICAgICAgIHJldHVybiBJbWFnZUV4dExpc3QuaW5jbHVkZXMoZmlsZUV4dGVuc2lvbik7XG5cbiAgICAgIGNhc2UgJ3ZpZGVvJzpcbiAgICAgICAgcmV0dXJuIFZpZGVvRXh0TGlzdC5pbmNsdWRlcyhmaWxlRXh0ZW5zaW9uKTtcblxuICAgICAgY2FzZSAnd29yZCc6XG4gICAgICAgIHJldHVybiBbJ2RvYycsICdkb2N4JywgJ2FwcGxpY2F0aW9uL21zd29yZCcsICdhcHBsaWNhdGlvbi92bmQub3BlbnhtbGZvcm1hdHMtb2ZmaWNlZG9jdW1lbnQud29yZHByb2Nlc3NpbmdtbC5kb2N1bWVudCddLmluY2x1ZGVzKGZpbGVFeHRlbnNpb24pO1xuXG4gICAgICBjYXNlICd4bHN4JzpcbiAgICAgICAgcmV0dXJuIFsneGxzJywgJ3hsc3gnLCAnYXBwbGljYXRpb24vdm5kLm1zLWV4Y2VsJywgJ2FwcGxpY2F0aW9uL3ZuZC5vcGVueG1sZm9ybWF0cy1vZmZpY2Vkb2N1bWVudC5zcHJlYWRzaGVldG1sLnNoZWV0JywgJ2dzaGVldCddLmluY2x1ZGVzKGZpbGVFeHRlbnNpb24pO1xuXG4gICAgICBjYXNlICdwZGYnOlxuICAgICAgICByZXR1cm4gWydwZGYnLCAnYXBwbGljYXRpb24vcGRmJ10uaW5jbHVkZXMoZmlsZUV4dGVuc2lvbik7XG5cbiAgICAgIGNhc2UgJ3BwdHgnOlxuICAgICAgICByZXR1cm4gWydwcHQnLCAncHB0eCcsICdhcHBsaWNhdGlvbi92bmQubXMtcG93ZXJwb2ludCcsICdhcHBsaWNhdGlvbi92bmQub3BlbnhtbGZvcm1hdHMtb2ZmaWNlZG9jdW1lbnQucHJlc2VudGF0aW9ubWwucHJlc2VudGF0aW9uJ10uaW5jbHVkZXMoZmlsZUV4dGVuc2lvbik7XG5cbiAgICAgIGNhc2UgJ290aGVyJzpcbiAgICAgICAgcmV0dXJuICFbLi4uSW1hZ2VFeHRMaXN0LCAuLi5WaWRlb0V4dExpc3QsIC4uLkRvY3VtZW50RXh0TGlzdF0uaW5jbHVkZXMoZmlsZUV4dGVuc2lvbik7XG4gICAgfVxuICB9XG59XG4iXX0=