@smartbit4all/ng-client 4.3.10 → 4.3.12
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.
- package/esm2022/lib/smart-dialog/smartdialog.service.mjs +2 -1
- package/esm2022/lib/smart-form/widgets/components/smart-multi-file-editor/smart-multi-file-editor.component.mjs +3 -3
- package/esm2022/lib/view-context/smart-view-context-dialog.service.mjs +2 -1
- package/fesm2022/smartbit4all-ng-client.mjs +4 -2
- package/fesm2022/smartbit4all-ng-client.mjs.map +1 -1
- package/package.json +1 -1
- package/smartbit4all-ng-client-4.3.12.tgz +0 -0
- package/smartbit4all-ng-client-4.3.10.tgz +0 -0
|
@@ -28,6 +28,7 @@ let SmartdialogService = class SmartdialogService {
|
|
|
28
28
|
else {
|
|
29
29
|
this.dialogRef = this.dialogService.open(component, {
|
|
30
30
|
closable: false,
|
|
31
|
+
closeOnEscape: false,
|
|
31
32
|
showHeader: false,
|
|
32
33
|
data: this.dialogData,
|
|
33
34
|
});
|
|
@@ -90,4 +91,4 @@ SmartdialogService = __decorate([
|
|
|
90
91
|
__param(4, Inject(COMPONENT_LIBRARY))
|
|
91
92
|
], SmartdialogService);
|
|
92
93
|
export { SmartdialogService };
|
|
93
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
94
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smartdialog.service.js","sourceRoot":"","sources":["../../../../../projects/smart-ng-client/src/lib/smart-dialog/smartdialog.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentType } from '@angular/cdk/portal';\r\nimport { MatDialog, MatDialogRef } from '@angular/material/dialog';\r\nimport { Router } from '@angular/router';\r\nimport { SmartDialogData } from './smartdialog.model';\r\nimport { DialogService, DynamicDialogRef } from 'primeng/dynamicdialog';\r\nimport { Inject, Injector } from '@angular/core';\r\nimport { COMPONENT_LIBRARY, ComponentLibrary } from '../view-context/utility/componentLibrary';\r\n\r\nexport abstract class SmartdialogService {\r\n  constructor(\r\n    protected dialog: MatDialog,\r\n    protected router: Router,\r\n    protected dialogService: DialogService,\r\n    protected inject: Injector,\r\n    @Inject(COMPONENT_LIBRARY) public compLib: ComponentLibrary\r\n  ) {}\r\n  componentLibrary = ComponentLibrary;\r\n  dialogRef!: MatDialogRef<any> | DynamicDialogRef;\r\n  dialogData!: SmartDialogData;\r\n\r\n  defaultDialogSizes = {\r\n    maxHeight: 100,\r\n    minHeight: 100,\r\n    maxWidth: 100,\r\n    minWidth: 100,\r\n  };\r\n  createDialog(\r\n    smartDialog: SmartDialogData,\r\n    component: ComponentType<any>\r\n  ): MatDialogRef<any, any> | DynamicDialogRef {\r\n    this.dialogData = smartDialog;\r\n    if (this.compLib === this.componentLibrary.MATERIAL) {\r\n      this.dialogRef = this.dialog.open(component, { data: this.dialogData });\r\n\r\n      this.dialogRef.afterClosed().subscribe((result) => {\r\n        this.closeDialog();\r\n      });\r\n      return this.dialogRef;\r\n    } else {\r\n      this.dialogRef = this.dialogService.open(component, {\r\n        closable: false,\r\n        closeOnEscape: false,\r\n        showHeader: false,\r\n        data: this.dialogData,\r\n      });\r\n      this.dialogRef.onClose.subscribe((result) => {\r\n        this.closeDialog(true);\r\n      });\r\n      return this.dialogRef;\r\n    }\r\n  }\r\n\r\n  createDialogRef(\r\n    smartDialog: SmartDialogData,\r\n    component: ComponentType<any>\r\n  ): MatDialogRef<any, any> | DynamicDialogRef {\r\n    if (this.compLib === this.componentLibrary.MATERIAL) {\r\n      const dialogRef = this.dialog.open(component, { data: smartDialog });\r\n\r\n      dialogRef.afterClosed().subscribe((result) => {\r\n        this.handleAfterClosed(result);\r\n        dialogRef.close();\r\n      });\r\n\r\n      return dialogRef;\r\n    } else {\r\n      const dialogRef = this.dialogService.open(component, {\r\n        closable: false,\r\n        showHeader: false,\r\n        data: smartDialog,\r\n      });\r\n      dialogRef.onClose.subscribe((result) => {\r\n        this.closeDialog(true);\r\n      });\r\n      return dialogRef;\r\n    }\r\n  }\r\n\r\n  openComponentAsDialog(\r\n    component: ComponentType<any>,\r\n    viewName: string\r\n  ): MatDialogRef<any, any> | DynamicDialogRef {\r\n    let smartDialog: SmartDialogData = {\r\n      size: {},\r\n      content: {\r\n        title: viewName,\r\n      },\r\n      customComponent: component,\r\n    };\r\n\r\n    return this.createDialog(smartDialog, component);\r\n  }\r\n\r\n  handleAfterClosed(result: any): void {}\r\n\r\n  openDialog(): void {\r\n    throw new Error('openDialog function is not implemented!');\r\n  }\r\n\r\n  async closeDialog(stopPropagate?: boolean): Promise<void> {\r\n    if (this.dialogData?.outlets) {\r\n      await this.router.navigate([\r\n        {\r\n          outlets: this.dialogData.outlets,\r\n        },\r\n      ]);\r\n    }\r\n\r\n    if (stopPropagate) {\r\n      return;\r\n    }\r\n\r\n    this.dialogRef?.close();\r\n  }\r\n}\r\n"]}
|
|
@@ -141,7 +141,7 @@ export class SmartMultiFileEditorComponent {
|
|
|
141
141
|
useExisting: forwardRef(() => SmartMultiFileEditorComponent),
|
|
142
142
|
multi: true,
|
|
143
143
|
},
|
|
144
|
-
], viewQueries: [{ propertyName: "toolbar", first: true, predicate: ["toolbar"], descendants: true }], ngImport: i0, template: "@if (widgetInstance && widgetInstance.multiFileUploaderProperties) {\r\n <h4\r\n *ngIf=\"widgetInstance.showLabel\"\r\n class=\"labelContainer {{ widgetInstance.cssLabelClass ?? '' }}\"\r\n [ngClass]=\"getLabelNgClass()\"\r\n [ngStyle]=\"getLabelStyle()\"\r\n >\r\n {{ widgetInstance.label }}\r\n </h4>\r\n <smart-ui-action-toolbar\r\n [id]=\"widgetInstance.toolbarId\"\r\n #toolbar\r\n [style]=\"{ display: 'none' }\"\r\n ></smart-ui-action-toolbar>\r\n\r\n <div class=\"fileEditorComponent\">\r\n @if (widgetInstance.value && !isTypeSupported(widgetInstance.value)) {\r\n <div class=\"errorMessage\">\r\n <smart-icon [icon]=\"errorIcon\" [color]=\"'var(--warninig-color)'\"></smart-icon>\r\n <span> Unsupported widgetInstance.value type for this widget.</span>\r\n </div>\r\n } @else {\r\n <smart-upload-widget\r\n class=\"widgetContent {{ widgetInstance.cssClass ?? '' }}\"\r\n [ngClass]=\"getNgClass()\"\r\n [ngStyle]=\"getStyle()\"\r\n [uploadDescriptor]=\"widgetInstance.multiFileUploaderProperties.uploadDescriptor!\"\r\n [isMultiple]=\"true\"\r\n [isDisabled]=\"widgetInstance.isDisabled\"\r\n (uploadFilesEvent)=\"upload($event)\"\r\n />\r\n }\r\n\r\n <div\r\n [ngClass]=\"{ disabledWidget: widgetInstance.isDisabled }\"\r\n class=\"uploadedFileContainer\"\r\n [style.display]=\"\r\n widgetInstance.value && isTypeSupported(widgetInstance.value) ? 'block' : 'none'\r\n \"\r\n >\r\n <div class=\"scrollable\">\r\n <div class=\"uploadedFile\" *ngFor=\"let file of widgetInstance.value; let i = index\">\r\n <smart-icon class=\"uploadedFileIcon\" [icon]=\"fileIcon\"></smart-icon>\r\n\r\n <div class=\"fileData\">\r\n <div class=\"fileDataContainer\">\r\n <span class=\"fileName\">{{ file?.fileName }}</span>\r\n <span class=\"fileSize\">{{ formatSize(file?.size) }}</span>\r\n </div>\r\n </div>\r\n\r\n <div class=\"fileActions\">\r\n @if (toolbarComponent && toolbarComponent.uiActionModels) {\r\n <file-editor-toolbar\r\n [id]=\"widgetInstance.toolbarId\"\r\n [dataUri]=\"file.dataUri\"\r\n [uiActionModels]=\"toolbarComponent.uiActionModels\"\r\n ></file-editor-toolbar>\r\n }\r\n <smart-icon\r\n class=\"downloadIcon\"\r\n icon=\"download\"\r\n (click)=\"downloadFile(file.dataUri)\"\r\n ></smart-icon>\r\n <smart-icon\r\n
|
|
144
|
+
], viewQueries: [{ propertyName: "toolbar", first: true, predicate: ["toolbar"], descendants: true }], ngImport: i0, template: "@if (widgetInstance && widgetInstance.multiFileUploaderProperties) {\r\n <h4\r\n *ngIf=\"widgetInstance.showLabel\"\r\n class=\"labelContainer {{ widgetInstance.cssLabelClass ?? '' }}\"\r\n [ngClass]=\"getLabelNgClass()\"\r\n [ngStyle]=\"getLabelStyle()\"\r\n >\r\n {{ widgetInstance.label }}\r\n </h4>\r\n <smart-ui-action-toolbar\r\n [id]=\"widgetInstance.toolbarId\"\r\n #toolbar\r\n [style]=\"{ display: 'none' }\"\r\n ></smart-ui-action-toolbar>\r\n\r\n <div class=\"fileEditorComponent\">\r\n @if (widgetInstance.value && !isTypeSupported(widgetInstance.value)) {\r\n <div class=\"errorMessage\">\r\n <smart-icon [icon]=\"errorIcon\" [color]=\"'var(--warninig-color)'\"></smart-icon>\r\n <span> Unsupported widgetInstance.value type for this widget.</span>\r\n </div>\r\n } @else {\r\n <smart-upload-widget\r\n class=\"widgetContent {{ widgetInstance.cssClass ?? '' }}\"\r\n [ngClass]=\"getNgClass()\"\r\n [ngStyle]=\"getStyle()\"\r\n [uploadDescriptor]=\"widgetInstance.multiFileUploaderProperties.uploadDescriptor!\"\r\n [isMultiple]=\"true\"\r\n [isDisabled]=\"widgetInstance.isDisabled\"\r\n (uploadFilesEvent)=\"upload($event)\"\r\n />\r\n }\r\n\r\n <div\r\n [ngClass]=\"{ disabledWidget: widgetInstance.isDisabled }\"\r\n class=\"uploadedFileContainer\"\r\n [style.display]=\"\r\n widgetInstance.value && isTypeSupported(widgetInstance.value) ? 'block' : 'none'\r\n \"\r\n >\r\n <div class=\"scrollable\">\r\n <div class=\"uploadedFile\" *ngFor=\"let file of widgetInstance.value; let i = index\">\r\n <smart-icon class=\"uploadedFileIcon\" [icon]=\"fileIcon\"></smart-icon>\r\n\r\n <div class=\"fileData\">\r\n <div class=\"fileDataContainer\">\r\n <span class=\"fileName\">{{ file?.fileName }}</span>\r\n <span class=\"fileSize\">{{ formatSize(file?.size) }}</span>\r\n </div>\r\n </div>\r\n\r\n <div class=\"fileActions\">\r\n @if (toolbarComponent && toolbarComponent.uiActionModels) {\r\n <file-editor-toolbar\r\n [id]=\"widgetInstance.toolbarId\"\r\n [dataUri]=\"file.dataUri\"\r\n [uiActionModels]=\"toolbarComponent.uiActionModels\"\r\n ></file-editor-toolbar>\r\n }\r\n <smart-icon\r\n class=\"downloadIcon\"\r\n icon=\"download\"\r\n (click)=\"downloadFile(file.dataUri)\"\r\n ></smart-icon>\r\n @if (!file.readOnly) {\r\n <smart-icon\r\n class=\"removeIcon\"\r\n [icon]=\"removeIcon\"\r\n (click)=\"!isDisabled && file.readOnly === false && deleteFile(file.dataUri)\"\r\n ></smart-icon>\r\n }\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n}\r\n", styles: [":host{--border-color: #a6aabd60;--warninig-color: #be2d2e;--def-border-radius: .5rem;width:100%}.fileEditorComponent{border:2px dashed var(--border-color);border-radius:var(--def-border-radius);overflow:hidden}.fileEditorComponent ::ng-deep smartfileuploader ::ng-deep .container{border:unset;border-radius:unset}.uploadedFileContainer{display:flex;flex-direction:column;border-top:1px solid #e0e0e0}.uploadedFile{display:flex;flex-direction:row;justify-content:flex-start;align-items:center;padding:1rem;gap:1rem}.scrollable{max-height:30vh;overflow-y:auto}.scrollable>div:not(:last-child){border-bottom:1px solid #e0e0e0}.fileSize{display:flex;flex-direction:row;font-size:smaller}.fileData{flex:1;display:flex;flex-direction:column}.fileDataContainer{display:flex;flex-direction:column;justify-content:flex-end;width:fit-content}.fileActions{display:flex;flex-direction:row;justify-content:flex-end;gap:.5rem}.fileActions ::ng-deep button{border:unset}.fileActions ::ng-deep button:hover{border:unset}.removeIcon ::ng-deep i,.removeIcon ::ng-deep mat-icon{color:var(--warninig-color)}.removeIcon ::ng-deep .pi,.downloadIcon ::ng-deep .pi{font-size:1.5rem!important}.removeIcon ::ng-deep mat-icon,.downloadIcon ::ng-deep mat-icon{font-size:2rem}.removeIcon:hover,.downloadIcon:hover{cursor:pointer}smart-icon{display:flex;align-items:center}smart-icon ::ng-deep mat-icon{font-size:3rem;width:unset;height:unset}.uploadedFileIcon{width:3rem;display:flex;justify-content:center}:host ::ng-deep .p-fileupload-content{border:unset;border-radius:var(--def-border-radius)}smart-icon ::ng-deep .pi{font-size:2rem!important}.fileEditorComponent:has(::ng-deep .errorMessage){border-color:var(--warninig-color)}.errorMessage{padding:1rem;font-size:1.5rem;color:var(--warninig-color);display:flex;flex-direction:row;align-items:center;gap:1rem}:host ::ng-deep .disabledWidget ::ng-deep .changeButton *,:host ::ng-deep .disabledWidget ::ng-deep .removeIcon *{opacity:.4!important;pointer-events:none!important}:host ::ng-deep .disabledWidget ::ng-deep .changeButton:hover,:host ::ng-deep .disabledWidget ::ng-deep .removeIcon:hover{cursor:not-allowed}:host ::ng-deep smartfileuploader ::ng-deep .uploadedFile,:host ::ng-deep .p-fileupload-file{background:repeating-linear-gradient(45deg,#fafafa,#fafafa 6px,#f1f1f1 6px 12px)}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i2.SmartIconComponent, selector: "smart-icon", inputs: ["icon", "color", "imageResource"] }, { kind: "component", type: i3.UiActionToolbarComponent, selector: "smart-ui-action-toolbar", inputs: ["uiActionModels", "uiActionDescriptorService", "id", "scrollOnWrap", "toolbarPropertes"] }, { kind: "component", type: i4.FileEditorToolbarComponent, selector: "file-editor-toolbar", inputs: ["dataUri"], outputs: ["actionEvent"] }, { kind: "component", type: i5.UploadWidgetComponent, selector: "smart-upload-widget", inputs: ["uploadDescriptor", "isMultiple", "isDisabled"], outputs: ["uploadFilesEvent"] }] }); }
|
|
145
145
|
}
|
|
146
146
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SmartMultiFileEditorComponent, decorators: [{
|
|
147
147
|
type: Component,
|
|
@@ -151,7 +151,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
151
151
|
useExisting: forwardRef(() => SmartMultiFileEditorComponent),
|
|
152
152
|
multi: true,
|
|
153
153
|
},
|
|
154
|
-
], template: "@if (widgetInstance && widgetInstance.multiFileUploaderProperties) {\r\n <h4\r\n *ngIf=\"widgetInstance.showLabel\"\r\n class=\"labelContainer {{ widgetInstance.cssLabelClass ?? '' }}\"\r\n [ngClass]=\"getLabelNgClass()\"\r\n [ngStyle]=\"getLabelStyle()\"\r\n >\r\n {{ widgetInstance.label }}\r\n </h4>\r\n <smart-ui-action-toolbar\r\n [id]=\"widgetInstance.toolbarId\"\r\n #toolbar\r\n [style]=\"{ display: 'none' }\"\r\n ></smart-ui-action-toolbar>\r\n\r\n <div class=\"fileEditorComponent\">\r\n @if (widgetInstance.value && !isTypeSupported(widgetInstance.value)) {\r\n <div class=\"errorMessage\">\r\n <smart-icon [icon]=\"errorIcon\" [color]=\"'var(--warninig-color)'\"></smart-icon>\r\n <span> Unsupported widgetInstance.value type for this widget.</span>\r\n </div>\r\n } @else {\r\n <smart-upload-widget\r\n class=\"widgetContent {{ widgetInstance.cssClass ?? '' }}\"\r\n [ngClass]=\"getNgClass()\"\r\n [ngStyle]=\"getStyle()\"\r\n [uploadDescriptor]=\"widgetInstance.multiFileUploaderProperties.uploadDescriptor!\"\r\n [isMultiple]=\"true\"\r\n [isDisabled]=\"widgetInstance.isDisabled\"\r\n (uploadFilesEvent)=\"upload($event)\"\r\n />\r\n }\r\n\r\n <div\r\n [ngClass]=\"{ disabledWidget: widgetInstance.isDisabled }\"\r\n class=\"uploadedFileContainer\"\r\n [style.display]=\"\r\n widgetInstance.value && isTypeSupported(widgetInstance.value) ? 'block' : 'none'\r\n \"\r\n >\r\n <div class=\"scrollable\">\r\n <div class=\"uploadedFile\" *ngFor=\"let file of widgetInstance.value; let i = index\">\r\n <smart-icon class=\"uploadedFileIcon\" [icon]=\"fileIcon\"></smart-icon>\r\n\r\n <div class=\"fileData\">\r\n <div class=\"fileDataContainer\">\r\n <span class=\"fileName\">{{ file?.fileName }}</span>\r\n <span class=\"fileSize\">{{ formatSize(file?.size) }}</span>\r\n </div>\r\n </div>\r\n\r\n <div class=\"fileActions\">\r\n @if (toolbarComponent && toolbarComponent.uiActionModels) {\r\n <file-editor-toolbar\r\n [id]=\"widgetInstance.toolbarId\"\r\n [dataUri]=\"file.dataUri\"\r\n [uiActionModels]=\"toolbarComponent.uiActionModels\"\r\n ></file-editor-toolbar>\r\n }\r\n <smart-icon\r\n class=\"downloadIcon\"\r\n icon=\"download\"\r\n (click)=\"downloadFile(file.dataUri)\"\r\n ></smart-icon>\r\n <smart-icon\r\n
|
|
154
|
+
], template: "@if (widgetInstance && widgetInstance.multiFileUploaderProperties) {\r\n <h4\r\n *ngIf=\"widgetInstance.showLabel\"\r\n class=\"labelContainer {{ widgetInstance.cssLabelClass ?? '' }}\"\r\n [ngClass]=\"getLabelNgClass()\"\r\n [ngStyle]=\"getLabelStyle()\"\r\n >\r\n {{ widgetInstance.label }}\r\n </h4>\r\n <smart-ui-action-toolbar\r\n [id]=\"widgetInstance.toolbarId\"\r\n #toolbar\r\n [style]=\"{ display: 'none' }\"\r\n ></smart-ui-action-toolbar>\r\n\r\n <div class=\"fileEditorComponent\">\r\n @if (widgetInstance.value && !isTypeSupported(widgetInstance.value)) {\r\n <div class=\"errorMessage\">\r\n <smart-icon [icon]=\"errorIcon\" [color]=\"'var(--warninig-color)'\"></smart-icon>\r\n <span> Unsupported widgetInstance.value type for this widget.</span>\r\n </div>\r\n } @else {\r\n <smart-upload-widget\r\n class=\"widgetContent {{ widgetInstance.cssClass ?? '' }}\"\r\n [ngClass]=\"getNgClass()\"\r\n [ngStyle]=\"getStyle()\"\r\n [uploadDescriptor]=\"widgetInstance.multiFileUploaderProperties.uploadDescriptor!\"\r\n [isMultiple]=\"true\"\r\n [isDisabled]=\"widgetInstance.isDisabled\"\r\n (uploadFilesEvent)=\"upload($event)\"\r\n />\r\n }\r\n\r\n <div\r\n [ngClass]=\"{ disabledWidget: widgetInstance.isDisabled }\"\r\n class=\"uploadedFileContainer\"\r\n [style.display]=\"\r\n widgetInstance.value && isTypeSupported(widgetInstance.value) ? 'block' : 'none'\r\n \"\r\n >\r\n <div class=\"scrollable\">\r\n <div class=\"uploadedFile\" *ngFor=\"let file of widgetInstance.value; let i = index\">\r\n <smart-icon class=\"uploadedFileIcon\" [icon]=\"fileIcon\"></smart-icon>\r\n\r\n <div class=\"fileData\">\r\n <div class=\"fileDataContainer\">\r\n <span class=\"fileName\">{{ file?.fileName }}</span>\r\n <span class=\"fileSize\">{{ formatSize(file?.size) }}</span>\r\n </div>\r\n </div>\r\n\r\n <div class=\"fileActions\">\r\n @if (toolbarComponent && toolbarComponent.uiActionModels) {\r\n <file-editor-toolbar\r\n [id]=\"widgetInstance.toolbarId\"\r\n [dataUri]=\"file.dataUri\"\r\n [uiActionModels]=\"toolbarComponent.uiActionModels\"\r\n ></file-editor-toolbar>\r\n }\r\n <smart-icon\r\n class=\"downloadIcon\"\r\n icon=\"download\"\r\n (click)=\"downloadFile(file.dataUri)\"\r\n ></smart-icon>\r\n @if (!file.readOnly) {\r\n <smart-icon\r\n class=\"removeIcon\"\r\n [icon]=\"removeIcon\"\r\n (click)=\"!isDisabled && file.readOnly === false && deleteFile(file.dataUri)\"\r\n ></smart-icon>\r\n }\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n}\r\n", styles: [":host{--border-color: #a6aabd60;--warninig-color: #be2d2e;--def-border-radius: .5rem;width:100%}.fileEditorComponent{border:2px dashed var(--border-color);border-radius:var(--def-border-radius);overflow:hidden}.fileEditorComponent ::ng-deep smartfileuploader ::ng-deep .container{border:unset;border-radius:unset}.uploadedFileContainer{display:flex;flex-direction:column;border-top:1px solid #e0e0e0}.uploadedFile{display:flex;flex-direction:row;justify-content:flex-start;align-items:center;padding:1rem;gap:1rem}.scrollable{max-height:30vh;overflow-y:auto}.scrollable>div:not(:last-child){border-bottom:1px solid #e0e0e0}.fileSize{display:flex;flex-direction:row;font-size:smaller}.fileData{flex:1;display:flex;flex-direction:column}.fileDataContainer{display:flex;flex-direction:column;justify-content:flex-end;width:fit-content}.fileActions{display:flex;flex-direction:row;justify-content:flex-end;gap:.5rem}.fileActions ::ng-deep button{border:unset}.fileActions ::ng-deep button:hover{border:unset}.removeIcon ::ng-deep i,.removeIcon ::ng-deep mat-icon{color:var(--warninig-color)}.removeIcon ::ng-deep .pi,.downloadIcon ::ng-deep .pi{font-size:1.5rem!important}.removeIcon ::ng-deep mat-icon,.downloadIcon ::ng-deep mat-icon{font-size:2rem}.removeIcon:hover,.downloadIcon:hover{cursor:pointer}smart-icon{display:flex;align-items:center}smart-icon ::ng-deep mat-icon{font-size:3rem;width:unset;height:unset}.uploadedFileIcon{width:3rem;display:flex;justify-content:center}:host ::ng-deep .p-fileupload-content{border:unset;border-radius:var(--def-border-radius)}smart-icon ::ng-deep .pi{font-size:2rem!important}.fileEditorComponent:has(::ng-deep .errorMessage){border-color:var(--warninig-color)}.errorMessage{padding:1rem;font-size:1.5rem;color:var(--warninig-color);display:flex;flex-direction:row;align-items:center;gap:1rem}:host ::ng-deep .disabledWidget ::ng-deep .changeButton *,:host ::ng-deep .disabledWidget ::ng-deep .removeIcon *{opacity:.4!important;pointer-events:none!important}:host ::ng-deep .disabledWidget ::ng-deep .changeButton:hover,:host ::ng-deep .disabledWidget ::ng-deep .removeIcon:hover{cursor:not-allowed}:host ::ng-deep smartfileuploader ::ng-deep .uploadedFile,:host ::ng-deep .p-fileupload-file{background:repeating-linear-gradient(45deg,#fafafa,#fafafa 6px,#f1f1f1 6px 12px)}\n"] }]
|
|
155
155
|
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i6.ComponentLibrary, decorators: [{
|
|
156
156
|
type: Inject,
|
|
157
157
|
args: [COMPONENT_LIBRARY]
|
|
@@ -167,4 +167,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
167
167
|
}], fileEvent: [{
|
|
168
168
|
type: Output
|
|
169
169
|
}] } });
|
|
170
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smart-multi-file-editor.component.js","sourceRoot":"","sources":["../../../../../../../../projects/smart-ng-client/src/lib/smart-form/widgets/components/smart-multi-file-editor/smart-multi-file-editor.component.ts","../../../../../../../../projects/smart-ng-client/src/lib/smart-form/widgets/components/smart-multi-file-editor/smart-multi-file-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  forwardRef,\r\n  Inject,\r\n  Input,\r\n  Optional,\r\n  Output,\r\n  QueryList,\r\n  ViewChild,\r\n  ViewChildren,\r\n} from '@angular/core';\r\nimport { SmartMultiFileUploader } from '../../../smartform.form-model';\r\nimport { SmartStyleUtility } from '../../../../view-context/utility/smart-style-utility';\r\nimport {\r\n  IconPosition,\r\n  UiAction,\r\n  UiActionButtonType,\r\n  UiActionDescriptor,\r\n  UiActionUploadDescriptor,\r\n} from '../../../../view-context/api/model/models';\r\nimport {\r\n  COMPONENT_LIBRARY,\r\n  ComponentLibrary,\r\n} from '../../../../view-context/utility/componentLibrary';\r\nimport { UiActionToolbarComponent } from '../../../../view-context/smart-ui-action/ui-action-toolbar.component';\r\nimport { UploadWidgetUtils } from '../../../../view-context/smart-ui-action/components/upload-widget/upload-widget.utils';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\n\r\n@Component({\r\n  selector: 'smart-multi-file-editor',\r\n  templateUrl: './smart-multi-file-editor.component.html',\r\n  styleUrl: './smart-multi-file-editor.component.css',\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => SmartMultiFileEditorComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class SmartMultiFileEditorComponent implements ControlValueAccessor {\r\n  @ViewChild('toolbar') toolbar!: UiActionToolbarComponent;\r\n\r\n  private _widgetInstance!: SmartMultiFileUploader;\r\n\r\n  @Input()\r\n  get widgetInstance(): SmartMultiFileUploader {\r\n    return this._widgetInstance;\r\n  }\r\n  set widgetInstance(value: SmartMultiFileUploader) {\r\n    if (value) {\r\n      this.clone(value);\r\n    }\r\n  }\r\n\r\n  @Output() uploadFilesEvent = new EventEmitter<{\r\n    files: any[];\r\n    uiAction: UiAction;\r\n    uploadDescriptor?: UiActionUploadDescriptor;\r\n  }>();\r\n\r\n  @Output() fileEvent = new EventEmitter<{\r\n    uiAction: UiAction;\r\n    uploadDescriptor?: UiActionUploadDescriptor;\r\n  }>();\r\n\r\n  constructor(\r\n    private cdr: ChangeDetectorRef,\r\n    @Inject(COMPONENT_LIBRARY) @Optional() public compLib?: ComponentLibrary\r\n  ) {}\r\n\r\n  private clone(value: SmartMultiFileUploader) {\r\n    this._widgetInstance =\r\n      typeof structuredClone === 'function'\r\n        ? structuredClone(value)\r\n        : JSON.parse(JSON.stringify(value));\r\n\r\n    this.cdr.markForCheck();\r\n  }\r\n\r\n  upload(event: any): void {\r\n    if (!event.files || event.files.length == 0) {\r\n      return;\r\n    }\r\n\r\n    let props = this._widgetInstance.multiFileUploaderProperties!;\r\n    let uiAction = props.uploadAction!;\r\n\r\n    let params = {\r\n      ...uiAction.params,\r\n      isMultiple: true,\r\n    };\r\n    uiAction.params = params;\r\n\r\n    this.uploadFilesEvent.emit({\r\n      files: event.files,\r\n      uiAction: uiAction,\r\n      uploadDescriptor: event.uploadDescriptor,\r\n    });\r\n\r\n    this.onChange(this._widgetInstance.value);\r\n  }\r\n\r\n  private emitFileAction(actionCode: string | undefined, dataUri: string) {\r\n    const uiAction = {\r\n      code: actionCode,\r\n      model: true,\r\n      path: this._widgetInstance.key,\r\n      params: { _dataUri: dataUri },\r\n    };\r\n\r\n    this.fileEvent.emit({\r\n      uiAction,\r\n      uploadDescriptor: this._widgetInstance.multiFileUploaderProperties?.uploadDescriptor,\r\n    });\r\n\r\n    this.onChange(this._widgetInstance.value);\r\n  }\r\n\r\n  deleteFile(dataUri: string) {\r\n    this.emitFileAction(\r\n      this._widgetInstance.multiFileUploaderProperties?.removeActionCode ?? 'defaultRemove',\r\n      dataUri\r\n    );\r\n  }\r\n\r\n  downloadFile(dataUri: string) {\r\n    this.emitFileAction(\r\n      this._widgetInstance.multiFileUploaderProperties?.downloadActionCode ?? 'defaultDownload',\r\n      dataUri\r\n    );\r\n  }\r\n\r\n  isTypeSupported(value: any): boolean {\r\n    return (\r\n      value == null || (Array.isArray(value) && value.every((item) => item && 'dataUri' in item))\r\n    );\r\n  }\r\n\r\n  formatSize(bytes: number): string {\r\n    return UploadWidgetUtils.formatSize(bytes);\r\n  }\r\n\r\n  // ---- Smart form widget functions ----\r\n  getLabelNgClass(): { [className: string]: boolean } {\r\n    return this._widgetInstance?.labelStyle\r\n      ? SmartStyleUtility.getNgClasses(this._widgetInstance.labelStyle)\r\n      : {};\r\n  }\r\n\r\n  getLabelStyle(): { [key: string]: string | number } {\r\n    return this._widgetInstance?.labelStyle\r\n      ? SmartStyleUtility.getNgStyles(this._widgetInstance.labelStyle)\r\n      : {};\r\n  }\r\n\r\n  getNgClass(): { [className: string]: boolean } {\r\n    return SmartStyleUtility.getNgClasses(this._widgetInstance?.style);\r\n  }\r\n\r\n  getStyle(): { [key: string]: string | number } {\r\n    if (!this._widgetInstance.style) {\r\n      this._widgetInstance.style = {\r\n        classesToAdd: [],\r\n        classesToRemove: [],\r\n        style: {},\r\n      };\r\n    }\r\n\r\n    if (!('width' in this._widgetInstance.style.style) && 'minWidth' in this._widgetInstance) {\r\n      this._widgetInstance.style.style['width'] = `${this._widgetInstance.minWidth}px`;\r\n    }\r\n\r\n    return SmartStyleUtility.getNgStyles(this._widgetInstance.style);\r\n  }\r\n\r\n  // ---- ControlValueAccessor implementation ----\r\n\r\n  onChange = (value: any) => {};\r\n  onTouched = () => {};\r\n  isDisabled = false;\r\n\r\n  writeValue(value: any): void {\r\n    if (value !== undefined && this._widgetInstance) {\r\n      this._widgetInstance.value = value;\r\n      this.cdr.markForCheck();\r\n    }\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  setDisabledState?(isDisabled: boolean): void {\r\n    this.isDisabled = isDisabled;\r\n  }\r\n\r\n  // ---- UI getters ----\r\n\r\n  get removeIcon(): string {\r\n    return this.compLib == ComponentLibrary.PRIMENG ? 'trash' : 'delete';\r\n  }\r\n\r\n  get fileIcon(): string {\r\n    return this.compLib == ComponentLibrary.PRIMENG ? 'file' : 'insert_drive_file';\r\n  }\r\n\r\n  get errorIcon(): string {\r\n    return this.compLib == ComponentLibrary.PRIMENG ? 'exclamation-circle' : 'error';\r\n  }\r\n\r\n  get toolbarComponent(): UiActionToolbarComponent {\r\n    return this.toolbar;\r\n  }\r\n}\r\n","@if (widgetInstance && widgetInstance.multiFileUploaderProperties) {\r\n  <h4\r\n    *ngIf=\"widgetInstance.showLabel\"\r\n    class=\"labelContainer {{ widgetInstance.cssLabelClass ?? '' }}\"\r\n    [ngClass]=\"getLabelNgClass()\"\r\n    [ngStyle]=\"getLabelStyle()\"\r\n  >\r\n    {{ widgetInstance.label }}\r\n  </h4>\r\n  <smart-ui-action-toolbar\r\n    [id]=\"widgetInstance.toolbarId\"\r\n    #toolbar\r\n    [style]=\"{ display: 'none' }\"\r\n  ></smart-ui-action-toolbar>\r\n\r\n  <div class=\"fileEditorComponent\">\r\n    @if (widgetInstance.value && !isTypeSupported(widgetInstance.value)) {\r\n      <div class=\"errorMessage\">\r\n        <smart-icon [icon]=\"errorIcon\" [color]=\"'var(--warninig-color)'\"></smart-icon>\r\n        <span> Unsupported widgetInstance.value type for this widget.</span>\r\n      </div>\r\n    } @else {\r\n      <smart-upload-widget\r\n        class=\"widgetContent {{ widgetInstance.cssClass ?? '' }}\"\r\n        [ngClass]=\"getNgClass()\"\r\n        [ngStyle]=\"getStyle()\"\r\n        [uploadDescriptor]=\"widgetInstance.multiFileUploaderProperties.uploadDescriptor!\"\r\n        [isMultiple]=\"true\"\r\n        [isDisabled]=\"widgetInstance.isDisabled\"\r\n        (uploadFilesEvent)=\"upload($event)\"\r\n      />\r\n    }\r\n\r\n    <div\r\n      [ngClass]=\"{ disabledWidget: widgetInstance.isDisabled }\"\r\n      class=\"uploadedFileContainer\"\r\n      [style.display]=\"\r\n        widgetInstance.value && isTypeSupported(widgetInstance.value) ? 'block' : 'none'\r\n      \"\r\n    >\r\n      <div class=\"scrollable\">\r\n        <div class=\"uploadedFile\" *ngFor=\"let file of widgetInstance.value; let i = index\">\r\n          <smart-icon class=\"uploadedFileIcon\" [icon]=\"fileIcon\"></smart-icon>\r\n\r\n          <div class=\"fileData\">\r\n            <div class=\"fileDataContainer\">\r\n              <span class=\"fileName\">{{ file?.fileName }}</span>\r\n              <span class=\"fileSize\">{{ formatSize(file?.size) }}</span>\r\n            </div>\r\n          </div>\r\n\r\n          <div class=\"fileActions\">\r\n            @if (toolbarComponent && toolbarComponent.uiActionModels) {\r\n              <file-editor-toolbar\r\n                [id]=\"widgetInstance.toolbarId\"\r\n                [dataUri]=\"file.dataUri\"\r\n                [uiActionModels]=\"toolbarComponent.uiActionModels\"\r\n              ></file-editor-toolbar>\r\n            }\r\n            <smart-icon\r\n              class=\"downloadIcon\"\r\n              icon=\"download\"\r\n              (click)=\"downloadFile(file.dataUri)\"\r\n            ></smart-icon>\r\n            <smart-icon\r\n              class=\"removeIcon\"\r\n              [icon]=\"removeIcon\"\r\n              (click)=\"!isDisabled && deleteFile(file.dataUri)\"\r\n            ></smart-icon>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n}\r\n"]}
|
|
170
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smart-multi-file-editor.component.js","sourceRoot":"","sources":["../../../../../../../../projects/smart-ng-client/src/lib/smart-form/widgets/components/smart-multi-file-editor/smart-multi-file-editor.component.ts","../../../../../../../../projects/smart-ng-client/src/lib/smart-form/widgets/components/smart-multi-file-editor/smart-multi-file-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  forwardRef,\r\n  Inject,\r\n  Input,\r\n  Optional,\r\n  Output,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { SmartMultiFileUploader } from '../../../smartform.form-model';\r\nimport { SmartStyleUtility } from '../../../../view-context/utility/smart-style-utility';\r\nimport { UiAction, UiActionUploadDescriptor } from '../../../../view-context/api/model/models';\r\nimport {\r\n  COMPONENT_LIBRARY,\r\n  ComponentLibrary,\r\n} from '../../../../view-context/utility/componentLibrary';\r\nimport { UiActionToolbarComponent } from '../../../../view-context/smart-ui-action/ui-action-toolbar.component';\r\nimport { UploadWidgetUtils } from '../../../../view-context/smart-ui-action/components/upload-widget/upload-widget.utils';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\n\r\n@Component({\r\n  selector: 'smart-multi-file-editor',\r\n  templateUrl: './smart-multi-file-editor.component.html',\r\n  styleUrl: './smart-multi-file-editor.component.css',\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => SmartMultiFileEditorComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class SmartMultiFileEditorComponent implements ControlValueAccessor {\r\n  @ViewChild('toolbar') toolbar!: UiActionToolbarComponent;\r\n\r\n  private _widgetInstance!: SmartMultiFileUploader;\r\n\r\n  @Input()\r\n  get widgetInstance(): SmartMultiFileUploader {\r\n    return this._widgetInstance;\r\n  }\r\n  set widgetInstance(value: SmartMultiFileUploader) {\r\n    if (value) {\r\n      this.clone(value);\r\n    }\r\n  }\r\n\r\n  @Output() uploadFilesEvent = new EventEmitter<{\r\n    files: any[];\r\n    uiAction: UiAction;\r\n    uploadDescriptor?: UiActionUploadDescriptor;\r\n  }>();\r\n\r\n  @Output() fileEvent = new EventEmitter<{\r\n    uiAction: UiAction;\r\n    uploadDescriptor?: UiActionUploadDescriptor;\r\n  }>();\r\n\r\n  constructor(\r\n    private cdr: ChangeDetectorRef,\r\n    @Inject(COMPONENT_LIBRARY) @Optional() public compLib?: ComponentLibrary\r\n  ) {}\r\n\r\n  private clone(value: SmartMultiFileUploader) {\r\n    this._widgetInstance =\r\n      typeof structuredClone === 'function'\r\n        ? structuredClone(value)\r\n        : JSON.parse(JSON.stringify(value));\r\n\r\n    this.cdr.markForCheck();\r\n  }\r\n\r\n  upload(event: any): void {\r\n    if (!event.files || event.files.length == 0) {\r\n      return;\r\n    }\r\n\r\n    let props = this._widgetInstance.multiFileUploaderProperties!;\r\n    let uiAction = props.uploadAction!;\r\n\r\n    let params = {\r\n      ...uiAction.params,\r\n      isMultiple: true,\r\n    };\r\n    uiAction.params = params;\r\n\r\n    this.uploadFilesEvent.emit({\r\n      files: event.files,\r\n      uiAction: uiAction,\r\n      uploadDescriptor: event.uploadDescriptor,\r\n    });\r\n\r\n    this.onChange(this._widgetInstance.value);\r\n  }\r\n\r\n  private emitFileAction(actionCode: string | undefined, dataUri: string) {\r\n    const uiAction = {\r\n      code: actionCode,\r\n      model: true,\r\n      path: this._widgetInstance.key,\r\n      params: { _dataUri: dataUri },\r\n    };\r\n\r\n    this.fileEvent.emit({\r\n      uiAction,\r\n      uploadDescriptor: this._widgetInstance.multiFileUploaderProperties?.uploadDescriptor,\r\n    });\r\n\r\n    this.onChange(this._widgetInstance.value);\r\n  }\r\n\r\n  deleteFile(dataUri: string) {\r\n    this.emitFileAction(\r\n      this._widgetInstance.multiFileUploaderProperties?.removeActionCode ?? 'defaultRemove',\r\n      dataUri\r\n    );\r\n  }\r\n\r\n  downloadFile(dataUri: string) {\r\n    this.emitFileAction(\r\n      this._widgetInstance.multiFileUploaderProperties?.downloadActionCode ?? 'defaultDownload',\r\n      dataUri\r\n    );\r\n  }\r\n\r\n  isTypeSupported(value: any): boolean {\r\n    return (\r\n      value == null || (Array.isArray(value) && value.every((item) => item && 'dataUri' in item))\r\n    );\r\n  }\r\n\r\n  formatSize(bytes: number): string {\r\n    return UploadWidgetUtils.formatSize(bytes);\r\n  }\r\n\r\n  // ---- Smart form widget functions ----\r\n  getLabelNgClass(): { [className: string]: boolean } {\r\n    return this._widgetInstance?.labelStyle\r\n      ? SmartStyleUtility.getNgClasses(this._widgetInstance.labelStyle)\r\n      : {};\r\n  }\r\n\r\n  getLabelStyle(): { [key: string]: string | number } {\r\n    return this._widgetInstance?.labelStyle\r\n      ? SmartStyleUtility.getNgStyles(this._widgetInstance.labelStyle)\r\n      : {};\r\n  }\r\n\r\n  getNgClass(): { [className: string]: boolean } {\r\n    return SmartStyleUtility.getNgClasses(this._widgetInstance?.style);\r\n  }\r\n\r\n  getStyle(): { [key: string]: string | number } {\r\n    if (!this._widgetInstance.style) {\r\n      this._widgetInstance.style = {\r\n        classesToAdd: [],\r\n        classesToRemove: [],\r\n        style: {},\r\n      };\r\n    }\r\n\r\n    if (!('width' in this._widgetInstance.style.style) && 'minWidth' in this._widgetInstance) {\r\n      this._widgetInstance.style.style['width'] = `${this._widgetInstance.minWidth}px`;\r\n    }\r\n\r\n    return SmartStyleUtility.getNgStyles(this._widgetInstance.style);\r\n  }\r\n\r\n  // ---- ControlValueAccessor implementation ----\r\n\r\n  onChange = (value: any) => {};\r\n  onTouched = () => {};\r\n  isDisabled = false;\r\n\r\n  writeValue(value: any): void {\r\n    if (value !== undefined && this._widgetInstance) {\r\n      this._widgetInstance.value = value;\r\n      this.cdr.markForCheck();\r\n    }\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  setDisabledState?(isDisabled: boolean): void {\r\n    this.isDisabled = isDisabled;\r\n  }\r\n\r\n  // ---- UI getters ----\r\n\r\n  get removeIcon(): string {\r\n    return this.compLib == ComponentLibrary.PRIMENG ? 'trash' : 'delete';\r\n  }\r\n\r\n  get fileIcon(): string {\r\n    return this.compLib == ComponentLibrary.PRIMENG ? 'file' : 'insert_drive_file';\r\n  }\r\n\r\n  get errorIcon(): string {\r\n    return this.compLib == ComponentLibrary.PRIMENG ? 'exclamation-circle' : 'error';\r\n  }\r\n\r\n  get toolbarComponent(): UiActionToolbarComponent {\r\n    return this.toolbar;\r\n  }\r\n}\r\n","@if (widgetInstance && widgetInstance.multiFileUploaderProperties) {\r\n  <h4\r\n    *ngIf=\"widgetInstance.showLabel\"\r\n    class=\"labelContainer {{ widgetInstance.cssLabelClass ?? '' }}\"\r\n    [ngClass]=\"getLabelNgClass()\"\r\n    [ngStyle]=\"getLabelStyle()\"\r\n  >\r\n    {{ widgetInstance.label }}\r\n  </h4>\r\n  <smart-ui-action-toolbar\r\n    [id]=\"widgetInstance.toolbarId\"\r\n    #toolbar\r\n    [style]=\"{ display: 'none' }\"\r\n  ></smart-ui-action-toolbar>\r\n\r\n  <div class=\"fileEditorComponent\">\r\n    @if (widgetInstance.value && !isTypeSupported(widgetInstance.value)) {\r\n      <div class=\"errorMessage\">\r\n        <smart-icon [icon]=\"errorIcon\" [color]=\"'var(--warninig-color)'\"></smart-icon>\r\n        <span> Unsupported widgetInstance.value type for this widget.</span>\r\n      </div>\r\n    } @else {\r\n      <smart-upload-widget\r\n        class=\"widgetContent {{ widgetInstance.cssClass ?? '' }}\"\r\n        [ngClass]=\"getNgClass()\"\r\n        [ngStyle]=\"getStyle()\"\r\n        [uploadDescriptor]=\"widgetInstance.multiFileUploaderProperties.uploadDescriptor!\"\r\n        [isMultiple]=\"true\"\r\n        [isDisabled]=\"widgetInstance.isDisabled\"\r\n        (uploadFilesEvent)=\"upload($event)\"\r\n      />\r\n    }\r\n\r\n    <div\r\n      [ngClass]=\"{ disabledWidget: widgetInstance.isDisabled }\"\r\n      class=\"uploadedFileContainer\"\r\n      [style.display]=\"\r\n        widgetInstance.value && isTypeSupported(widgetInstance.value) ? 'block' : 'none'\r\n      \"\r\n    >\r\n      <div class=\"scrollable\">\r\n        <div class=\"uploadedFile\" *ngFor=\"let file of widgetInstance.value; let i = index\">\r\n          <smart-icon class=\"uploadedFileIcon\" [icon]=\"fileIcon\"></smart-icon>\r\n\r\n          <div class=\"fileData\">\r\n            <div class=\"fileDataContainer\">\r\n              <span class=\"fileName\">{{ file?.fileName }}</span>\r\n              <span class=\"fileSize\">{{ formatSize(file?.size) }}</span>\r\n            </div>\r\n          </div>\r\n\r\n          <div class=\"fileActions\">\r\n            @if (toolbarComponent && toolbarComponent.uiActionModels) {\r\n              <file-editor-toolbar\r\n                [id]=\"widgetInstance.toolbarId\"\r\n                [dataUri]=\"file.dataUri\"\r\n                [uiActionModels]=\"toolbarComponent.uiActionModels\"\r\n              ></file-editor-toolbar>\r\n            }\r\n            <smart-icon\r\n              class=\"downloadIcon\"\r\n              icon=\"download\"\r\n              (click)=\"downloadFile(file.dataUri)\"\r\n            ></smart-icon>\r\n            @if (!file.readOnly) {\r\n              <smart-icon\r\n                class=\"removeIcon\"\r\n                [icon]=\"removeIcon\"\r\n                (click)=\"!isDisabled && file.readOnly === false && deleteFile(file.dataUri)\"\r\n              ></smart-icon>\r\n            }\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n}\r\n"]}
|
|
@@ -30,6 +30,7 @@ export class SmartViewContextDialogService {
|
|
|
30
30
|
let dialogRef = this.dialogService.open(component, {
|
|
31
31
|
data: dialogData,
|
|
32
32
|
focusOnShow: false,
|
|
33
|
+
closeOnEscape: false,
|
|
33
34
|
duplicate: true,
|
|
34
35
|
closable: !this.inject.get(DIALOG_DISABLE_CLOSE),
|
|
35
36
|
});
|
|
@@ -81,4 +82,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
81
82
|
type: Inject,
|
|
82
83
|
args: [COMPONENT_LIBRARY]
|
|
83
84
|
}] }] });
|
|
84
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
85
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnQtdmlldy1jb250ZXh0LWRpYWxvZy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc21hcnQtbmctY2xpZW50L3NyYy9saWIvdmlldy1jb250ZXh0L3NtYXJ0LXZpZXctY29udGV4dC1kaWFsb2cuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBWSxNQUFNLGVBQWUsQ0FBQztBQUk3RCxPQUFPLEVBQWlCLGdCQUFnQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDeEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLGdCQUFnQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDakYsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDcEUsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLE1BQU0sQ0FBQzs7Ozs7O0FBSzVCLE1BQU0sT0FBTyw2QkFBNkI7SUFFeEMsWUFDWSxNQUFpQixFQUNqQixNQUFjLEVBQ2QsYUFBNEIsRUFDNUIsTUFBZ0IsRUFDUSxPQUF5QjtRQUpqRCxXQUFNLEdBQU4sTUFBTSxDQUFXO1FBQ2pCLFdBQU0sR0FBTixNQUFNLENBQVE7UUFDZCxrQkFBYSxHQUFiLGFBQWEsQ0FBZTtRQUM1QixXQUFNLEdBQU4sTUFBTSxDQUFVO1FBQ1EsWUFBTyxHQUFQLE9BQU8sQ0FBa0I7UUFON0QscUJBQWdCLEdBQUcsZ0JBQWdCLENBQUM7SUFPakMsQ0FBQztJQUVKLFlBQVksQ0FDVixXQUE0QixFQUM1QixTQUE2QjtRQUU3QixJQUFJLFVBQVUsR0FBRyxXQUFXLENBQUM7UUFDN0IsSUFBSSxJQUFJLENBQUMsT0FBTyxLQUFLLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUNwRCxJQUFJLFNBQVMsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsRUFBRSxJQUFJLEVBQUUsVUFBVSxFQUFFLENBQUMsQ0FBQztZQUVsRSxTQUFTLENBQUMsV0FBVyxFQUFFLENBQUMsU0FBUyxDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUU7Z0JBQzNDLElBQUksQ0FBQyxXQUFXLENBQUMsU0FBUyxFQUFFLFVBQVUsQ0FBQyxDQUFDO1lBQzFDLENBQUMsQ0FBQyxDQUFDO1lBQ0gsT0FBTyxTQUFTLENBQUM7UUFDbkIsQ0FBQzthQUFNLENBQUM7WUFDTixJQUFJLFNBQVMsR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUU7Z0JBQ2pELElBQUksRUFBRSxVQUFVO2dCQUNoQixXQUFXLEVBQUUsS0FBSztnQkFDbEIsYUFBYSxFQUFFLEtBQUs7Z0JBQ3BCLFNBQVMsRUFBRSxJQUFJO2dCQUNmLFFBQVEsRUFBRSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLG9CQUFvQixDQUFDO2FBQ2pELENBQUMsQ0FBQztZQUNILFNBQVMsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLE1BQU0sRUFBRSxFQUFFO2dCQUNuRCxJQUFJLENBQUMsV0FBVyxDQUFDLFNBQVMsRUFBRSxVQUFVLENBQUMsQ0FBQztZQUMxQyxDQUFDLENBQUMsQ0FBQztZQUNILE9BQU8sU0FBUyxDQUFDO1FBQ25CLENBQUM7SUFDSCxDQUFDO0lBRUQsZUFBZSxDQUNiLFdBQTRCLEVBQzVCLFNBQTZCO1FBRTdCLE1BQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxFQUFFLElBQUksRUFBRSxXQUFXLEVBQUUsQ0FBQyxDQUFDO1FBRXJFLFNBQVMsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxTQUFTLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBRTtZQUMzQyxTQUFTLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDcEIsQ0FBQyxDQUFDLENBQUM7UUFFSCxPQUFPLFNBQVMsQ0FBQztJQUNuQixDQUFDO0lBRUQscUJBQXFCLENBQ25CLFNBQTZCLEVBQzdCLFFBQWdCO1FBRWhCLElBQUksV0FBVyxHQUFvQjtZQUNqQyxJQUFJLEVBQUUsRUFBRTtZQUNSLE9BQU8sRUFBRTtnQkFDUCxLQUFLLEVBQUUsUUFBUTthQUNoQjtZQUNELGVBQWUsRUFBRSxTQUFTO1NBQzNCLENBQUM7UUFFRixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsV0FBVyxFQUFFLFNBQVMsQ0FBQyxDQUFDO0lBQ25ELENBQUM7SUFFRCxLQUFLLENBQUMsV0FBVyxDQUNmLFNBQW9ELEVBQ3BELFVBQTJCO1FBRTNCLElBQUksVUFBVSxFQUFFLE9BQU8sRUFBRSxDQUFDO1lBQ3hCLE1BQU0sSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUM7Z0JBQ3pCO29CQUNFLE9BQU8sRUFBRSxVQUFVLENBQUMsT0FBTztpQkFDNUI7YUFDRixDQUFDLENBQUM7UUFDTCxDQUFDO1FBQ0QsU0FBUyxFQUFFLEtBQUssRUFBRSxDQUFDO1FBQ25CLElBQUksU0FBUyxZQUFZLGdCQUFnQixFQUFFLENBQUM7WUFDMUMsU0FBUyxFQUFFLE9BQU8sRUFBRSxDQUFDO1FBQ3ZCLENBQUM7SUFDSCxDQUFDOytHQWhGVSw2QkFBNkIsc0hBTzlCLGlCQUFpQjttSEFQaEIsNkJBQTZCLGNBRjVCLE1BQU07OzRGQUVQLDZCQUE2QjtrQkFIekMsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkI7OzBCQVFJLE1BQU07MkJBQUMsaUJBQWlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50VHlwZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9wb3J0YWwnO1xyXG5pbXBvcnQgeyBJbmplY3QsIEluamVjdGFibGUsIEluamVjdG9yIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE1hdERpYWxvZywgTWF0RGlhbG9nUmVmIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGlhbG9nJztcclxuaW1wb3J0IHsgUm91dGVyIH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcclxuaW1wb3J0IHsgU21hcnREaWFsb2dEYXRhIH0gZnJvbSAnLi4vc21hcnQtZGlhbG9nL3NtYXJ0ZGlhbG9nLm1vZGVsJztcclxuaW1wb3J0IHsgRGlhbG9nU2VydmljZSwgRHluYW1pY0RpYWxvZ1JlZiB9IGZyb20gJ3ByaW1lbmcvZHluYW1pY2RpYWxvZyc7XHJcbmltcG9ydCB7IENPTVBPTkVOVF9MSUJSQVJZLCBDb21wb25lbnRMaWJyYXJ5IH0gZnJvbSAnLi91dGlsaXR5L2NvbXBvbmVudExpYnJhcnknO1xyXG5pbXBvcnQgeyBESUFMT0dfRElTQUJMRV9DTE9TRSB9IGZyb20gJy4vc21hcnQtdmlldy1jb250ZXh0LnNlcnZpY2UnO1xyXG5pbXBvcnQgeyB0YWtlIH0gZnJvbSAncnhqcyc7XHJcblxyXG5ASW5qZWN0YWJsZSh7XHJcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgU21hcnRWaWV3Q29udGV4dERpYWxvZ1NlcnZpY2Uge1xyXG4gIGNvbXBvbmVudExpYnJhcnkgPSBDb21wb25lbnRMaWJyYXJ5O1xyXG4gIHByaXZhdGUgY29uc3RydWN0b3IoXHJcbiAgICBwcm90ZWN0ZWQgZGlhbG9nOiBNYXREaWFsb2csXHJcbiAgICBwcm90ZWN0ZWQgcm91dGVyOiBSb3V0ZXIsXHJcbiAgICBwcm90ZWN0ZWQgZGlhbG9nU2VydmljZTogRGlhbG9nU2VydmljZSxcclxuICAgIHByb3RlY3RlZCBpbmplY3Q6IEluamVjdG9yLFxyXG4gICAgQEluamVjdChDT01QT05FTlRfTElCUkFSWSkgcHVibGljIGNvbXBMaWI6IENvbXBvbmVudExpYnJhcnlcclxuICApIHt9XHJcblxyXG4gIGNyZWF0ZURpYWxvZyhcclxuICAgIHNtYXJ0RGlhbG9nOiBTbWFydERpYWxvZ0RhdGEsXHJcbiAgICBjb21wb25lbnQ6IENvbXBvbmVudFR5cGU8YW55PlxyXG4gICk6IE1hdERpYWxvZ1JlZjxhbnksIGFueT4gfCBEeW5hbWljRGlhbG9nUmVmIHtcclxuICAgIGxldCBkaWFsb2dEYXRhID0gc21hcnREaWFsb2c7XHJcbiAgICBpZiAodGhpcy5jb21wTGliID09PSB0aGlzLmNvbXBvbmVudExpYnJhcnkuTUFURVJJQUwpIHtcclxuICAgICAgbGV0IGRpYWxvZ1JlZiA9IHRoaXMuZGlhbG9nLm9wZW4oY29tcG9uZW50LCB7IGRhdGE6IGRpYWxvZ0RhdGEgfSk7XHJcblxyXG4gICAgICBkaWFsb2dSZWYuYWZ0ZXJDbG9zZWQoKS5zdWJzY3JpYmUoKHJlc3VsdCkgPT4ge1xyXG4gICAgICAgIHRoaXMuY2xvc2VEaWFsb2coZGlhbG9nUmVmLCBkaWFsb2dEYXRhKTtcclxuICAgICAgfSk7XHJcbiAgICAgIHJldHVybiBkaWFsb2dSZWY7XHJcbiAgICB9IGVsc2Uge1xyXG4gICAgICBsZXQgZGlhbG9nUmVmID0gdGhpcy5kaWFsb2dTZXJ2aWNlLm9wZW4oY29tcG9uZW50LCB7XHJcbiAgICAgICAgZGF0YTogZGlhbG9nRGF0YSxcclxuICAgICAgICBmb2N1c09uU2hvdzogZmFsc2UsXHJcbiAgICAgICAgY2xvc2VPbkVzY2FwZTogZmFsc2UsXHJcbiAgICAgICAgZHVwbGljYXRlOiB0cnVlLFxyXG4gICAgICAgIGNsb3NhYmxlOiAhdGhpcy5pbmplY3QuZ2V0KERJQUxPR19ESVNBQkxFX0NMT1NFKSxcclxuICAgICAgfSk7XHJcbiAgICAgIGRpYWxvZ1JlZi5vbkNsb3NlLnBpcGUodGFrZSgxKSkuc3Vic2NyaWJlKChyZXN1bHQpID0+IHtcclxuICAgICAgICB0aGlzLmNsb3NlRGlhbG9nKGRpYWxvZ1JlZiwgZGlhbG9nRGF0YSk7XHJcbiAgICAgIH0pO1xyXG4gICAgICByZXR1cm4gZGlhbG9nUmVmO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgY3JlYXRlRGlhbG9nUmVmKFxyXG4gICAgc21hcnREaWFsb2c6IFNtYXJ0RGlhbG9nRGF0YSxcclxuICAgIGNvbXBvbmVudDogQ29tcG9uZW50VHlwZTxhbnk+XHJcbiAgKTogTWF0RGlhbG9nUmVmPGFueSwgYW55PiB8IER5bmFtaWNEaWFsb2dSZWYge1xyXG4gICAgY29uc3QgZGlhbG9nUmVmID0gdGhpcy5kaWFsb2cub3Blbihjb21wb25lbnQsIHsgZGF0YTogc21hcnREaWFsb2cgfSk7XHJcblxyXG4gICAgZGlhbG9nUmVmLmFmdGVyQ2xvc2VkKCkuc3Vic2NyaWJlKChyZXN1bHQpID0+IHtcclxuICAgICAgZGlhbG9nUmVmLmNsb3NlKCk7XHJcbiAgICB9KTtcclxuXHJcbiAgICByZXR1cm4gZGlhbG9nUmVmO1xyXG4gIH1cclxuXHJcbiAgb3BlbkNvbXBvbmVudEFzRGlhbG9nKFxyXG4gICAgY29tcG9uZW50OiBDb21wb25lbnRUeXBlPGFueT4sXHJcbiAgICB2aWV3TmFtZTogc3RyaW5nXHJcbiAgKTogTWF0RGlhbG9nUmVmPGFueSwgYW55PiB8IER5bmFtaWNEaWFsb2dSZWYge1xyXG4gICAgbGV0IHNtYXJ0RGlhbG9nOiBTbWFydERpYWxvZ0RhdGEgPSB7XHJcbiAgICAgIHNpemU6IHt9LFxyXG4gICAgICBjb250ZW50OiB7XHJcbiAgICAgICAgdGl0bGU6IHZpZXdOYW1lLFxyXG4gICAgICB9LFxyXG4gICAgICBjdXN0b21Db21wb25lbnQ6IGNvbXBvbmVudCxcclxuICAgIH07XHJcblxyXG4gICAgcmV0dXJuIHRoaXMuY3JlYXRlRGlhbG9nKHNtYXJ0RGlhbG9nLCBjb21wb25lbnQpO1xyXG4gIH1cclxuXHJcbiAgYXN5bmMgY2xvc2VEaWFsb2coXHJcbiAgICBkaWFsb2dSZWY6IE1hdERpYWxvZ1JlZjxhbnksIGFueT4gfCBEeW5hbWljRGlhbG9nUmVmLFxyXG4gICAgZGlhbG9nRGF0YTogU21hcnREaWFsb2dEYXRhXHJcbiAgKTogUHJvbWlzZTx2b2lkPiB7XHJcbiAgICBpZiAoZGlhbG9nRGF0YT8ub3V0bGV0cykge1xyXG4gICAgICBhd2FpdCB0aGlzLnJvdXRlci5uYXZpZ2F0ZShbXHJcbiAgICAgICAge1xyXG4gICAgICAgICAgb3V0bGV0czogZGlhbG9nRGF0YS5vdXRsZXRzLFxyXG4gICAgICAgIH0sXHJcbiAgICAgIF0pO1xyXG4gICAgfVxyXG4gICAgZGlhbG9nUmVmPy5jbG9zZSgpO1xyXG4gICAgaWYgKGRpYWxvZ1JlZiBpbnN0YW5jZW9mIER5bmFtaWNEaWFsb2dSZWYpIHtcclxuICAgICAgZGlhbG9nUmVmPy5kZXN0cm95KCk7XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -3371,6 +3371,7 @@ class SmartViewContextDialogService {
|
|
|
3371
3371
|
let dialogRef = this.dialogService.open(component, {
|
|
3372
3372
|
data: dialogData,
|
|
3373
3373
|
focusOnShow: false,
|
|
3374
|
+
closeOnEscape: false,
|
|
3374
3375
|
duplicate: true,
|
|
3375
3376
|
closable: !this.inject.get(DIALOG_DISABLE_CLOSE),
|
|
3376
3377
|
});
|
|
@@ -4313,6 +4314,7 @@ let SmartdialogService = class SmartdialogService {
|
|
|
4313
4314
|
else {
|
|
4314
4315
|
this.dialogRef = this.dialogService.open(component, {
|
|
4315
4316
|
closable: false,
|
|
4317
|
+
closeOnEscape: false,
|
|
4316
4318
|
showHeader: false,
|
|
4317
4319
|
data: this.dialogData,
|
|
4318
4320
|
});
|
|
@@ -7708,7 +7710,7 @@ class SmartMultiFileEditorComponent {
|
|
|
7708
7710
|
useExisting: forwardRef(() => SmartMultiFileEditorComponent),
|
|
7709
7711
|
multi: true,
|
|
7710
7712
|
},
|
|
7711
|
-
], viewQueries: [{ propertyName: "toolbar", first: true, predicate: ["toolbar"], descendants: true }], ngImport: i0, template: "@if (widgetInstance && widgetInstance.multiFileUploaderProperties) {\r\n <h4\r\n *ngIf=\"widgetInstance.showLabel\"\r\n class=\"labelContainer {{ widgetInstance.cssLabelClass ?? '' }}\"\r\n [ngClass]=\"getLabelNgClass()\"\r\n [ngStyle]=\"getLabelStyle()\"\r\n >\r\n {{ widgetInstance.label }}\r\n </h4>\r\n <smart-ui-action-toolbar\r\n [id]=\"widgetInstance.toolbarId\"\r\n #toolbar\r\n [style]=\"{ display: 'none' }\"\r\n ></smart-ui-action-toolbar>\r\n\r\n <div class=\"fileEditorComponent\">\r\n @if (widgetInstance.value && !isTypeSupported(widgetInstance.value)) {\r\n <div class=\"errorMessage\">\r\n <smart-icon [icon]=\"errorIcon\" [color]=\"'var(--warninig-color)'\"></smart-icon>\r\n <span> Unsupported widgetInstance.value type for this widget.</span>\r\n </div>\r\n } @else {\r\n <smart-upload-widget\r\n class=\"widgetContent {{ widgetInstance.cssClass ?? '' }}\"\r\n [ngClass]=\"getNgClass()\"\r\n [ngStyle]=\"getStyle()\"\r\n [uploadDescriptor]=\"widgetInstance.multiFileUploaderProperties.uploadDescriptor!\"\r\n [isMultiple]=\"true\"\r\n [isDisabled]=\"widgetInstance.isDisabled\"\r\n (uploadFilesEvent)=\"upload($event)\"\r\n />\r\n }\r\n\r\n <div\r\n [ngClass]=\"{ disabledWidget: widgetInstance.isDisabled }\"\r\n class=\"uploadedFileContainer\"\r\n [style.display]=\"\r\n widgetInstance.value && isTypeSupported(widgetInstance.value) ? 'block' : 'none'\r\n \"\r\n >\r\n <div class=\"scrollable\">\r\n <div class=\"uploadedFile\" *ngFor=\"let file of widgetInstance.value; let i = index\">\r\n <smart-icon class=\"uploadedFileIcon\" [icon]=\"fileIcon\"></smart-icon>\r\n\r\n <div class=\"fileData\">\r\n <div class=\"fileDataContainer\">\r\n <span class=\"fileName\">{{ file?.fileName }}</span>\r\n <span class=\"fileSize\">{{ formatSize(file?.size) }}</span>\r\n </div>\r\n </div>\r\n\r\n <div class=\"fileActions\">\r\n @if (toolbarComponent && toolbarComponent.uiActionModels) {\r\n <file-editor-toolbar\r\n [id]=\"widgetInstance.toolbarId\"\r\n [dataUri]=\"file.dataUri\"\r\n [uiActionModels]=\"toolbarComponent.uiActionModels\"\r\n ></file-editor-toolbar>\r\n }\r\n <smart-icon\r\n class=\"downloadIcon\"\r\n icon=\"download\"\r\n (click)=\"downloadFile(file.dataUri)\"\r\n ></smart-icon>\r\n <smart-icon\r\n
|
|
7713
|
+
], viewQueries: [{ propertyName: "toolbar", first: true, predicate: ["toolbar"], descendants: true }], ngImport: i0, template: "@if (widgetInstance && widgetInstance.multiFileUploaderProperties) {\r\n <h4\r\n *ngIf=\"widgetInstance.showLabel\"\r\n class=\"labelContainer {{ widgetInstance.cssLabelClass ?? '' }}\"\r\n [ngClass]=\"getLabelNgClass()\"\r\n [ngStyle]=\"getLabelStyle()\"\r\n >\r\n {{ widgetInstance.label }}\r\n </h4>\r\n <smart-ui-action-toolbar\r\n [id]=\"widgetInstance.toolbarId\"\r\n #toolbar\r\n [style]=\"{ display: 'none' }\"\r\n ></smart-ui-action-toolbar>\r\n\r\n <div class=\"fileEditorComponent\">\r\n @if (widgetInstance.value && !isTypeSupported(widgetInstance.value)) {\r\n <div class=\"errorMessage\">\r\n <smart-icon [icon]=\"errorIcon\" [color]=\"'var(--warninig-color)'\"></smart-icon>\r\n <span> Unsupported widgetInstance.value type for this widget.</span>\r\n </div>\r\n } @else {\r\n <smart-upload-widget\r\n class=\"widgetContent {{ widgetInstance.cssClass ?? '' }}\"\r\n [ngClass]=\"getNgClass()\"\r\n [ngStyle]=\"getStyle()\"\r\n [uploadDescriptor]=\"widgetInstance.multiFileUploaderProperties.uploadDescriptor!\"\r\n [isMultiple]=\"true\"\r\n [isDisabled]=\"widgetInstance.isDisabled\"\r\n (uploadFilesEvent)=\"upload($event)\"\r\n />\r\n }\r\n\r\n <div\r\n [ngClass]=\"{ disabledWidget: widgetInstance.isDisabled }\"\r\n class=\"uploadedFileContainer\"\r\n [style.display]=\"\r\n widgetInstance.value && isTypeSupported(widgetInstance.value) ? 'block' : 'none'\r\n \"\r\n >\r\n <div class=\"scrollable\">\r\n <div class=\"uploadedFile\" *ngFor=\"let file of widgetInstance.value; let i = index\">\r\n <smart-icon class=\"uploadedFileIcon\" [icon]=\"fileIcon\"></smart-icon>\r\n\r\n <div class=\"fileData\">\r\n <div class=\"fileDataContainer\">\r\n <span class=\"fileName\">{{ file?.fileName }}</span>\r\n <span class=\"fileSize\">{{ formatSize(file?.size) }}</span>\r\n </div>\r\n </div>\r\n\r\n <div class=\"fileActions\">\r\n @if (toolbarComponent && toolbarComponent.uiActionModels) {\r\n <file-editor-toolbar\r\n [id]=\"widgetInstance.toolbarId\"\r\n [dataUri]=\"file.dataUri\"\r\n [uiActionModels]=\"toolbarComponent.uiActionModels\"\r\n ></file-editor-toolbar>\r\n }\r\n <smart-icon\r\n class=\"downloadIcon\"\r\n icon=\"download\"\r\n (click)=\"downloadFile(file.dataUri)\"\r\n ></smart-icon>\r\n @if (!file.readOnly) {\r\n <smart-icon\r\n class=\"removeIcon\"\r\n [icon]=\"removeIcon\"\r\n (click)=\"!isDisabled && file.readOnly === false && deleteFile(file.dataUri)\"\r\n ></smart-icon>\r\n }\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n}\r\n", styles: [":host{--border-color: #a6aabd60;--warninig-color: #be2d2e;--def-border-radius: .5rem;width:100%}.fileEditorComponent{border:2px dashed var(--border-color);border-radius:var(--def-border-radius);overflow:hidden}.fileEditorComponent ::ng-deep smartfileuploader ::ng-deep .container{border:unset;border-radius:unset}.uploadedFileContainer{display:flex;flex-direction:column;border-top:1px solid #e0e0e0}.uploadedFile{display:flex;flex-direction:row;justify-content:flex-start;align-items:center;padding:1rem;gap:1rem}.scrollable{max-height:30vh;overflow-y:auto}.scrollable>div:not(:last-child){border-bottom:1px solid #e0e0e0}.fileSize{display:flex;flex-direction:row;font-size:smaller}.fileData{flex:1;display:flex;flex-direction:column}.fileDataContainer{display:flex;flex-direction:column;justify-content:flex-end;width:fit-content}.fileActions{display:flex;flex-direction:row;justify-content:flex-end;gap:.5rem}.fileActions ::ng-deep button{border:unset}.fileActions ::ng-deep button:hover{border:unset}.removeIcon ::ng-deep i,.removeIcon ::ng-deep mat-icon{color:var(--warninig-color)}.removeIcon ::ng-deep .pi,.downloadIcon ::ng-deep .pi{font-size:1.5rem!important}.removeIcon ::ng-deep mat-icon,.downloadIcon ::ng-deep mat-icon{font-size:2rem}.removeIcon:hover,.downloadIcon:hover{cursor:pointer}smart-icon{display:flex;align-items:center}smart-icon ::ng-deep mat-icon{font-size:3rem;width:unset;height:unset}.uploadedFileIcon{width:3rem;display:flex;justify-content:center}:host ::ng-deep .p-fileupload-content{border:unset;border-radius:var(--def-border-radius)}smart-icon ::ng-deep .pi{font-size:2rem!important}.fileEditorComponent:has(::ng-deep .errorMessage){border-color:var(--warninig-color)}.errorMessage{padding:1rem;font-size:1.5rem;color:var(--warninig-color);display:flex;flex-direction:row;align-items:center;gap:1rem}:host ::ng-deep .disabledWidget ::ng-deep .changeButton *,:host ::ng-deep .disabledWidget ::ng-deep .removeIcon *{opacity:.4!important;pointer-events:none!important}:host ::ng-deep .disabledWidget ::ng-deep .changeButton:hover,:host ::ng-deep .disabledWidget ::ng-deep .removeIcon:hover{cursor:not-allowed}:host ::ng-deep smartfileuploader ::ng-deep .uploadedFile,:host ::ng-deep .p-fileupload-file{background:repeating-linear-gradient(45deg,#fafafa,#fafafa 6px,#f1f1f1 6px 12px)}\n"], dependencies: [{ kind: "directive", type: i1$2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1$2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1$2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1$2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: SmartIconComponent, selector: "smart-icon", inputs: ["icon", "color", "imageResource"] }, { kind: "component", type: UiActionToolbarComponent, selector: "smart-ui-action-toolbar", inputs: ["uiActionModels", "uiActionDescriptorService", "id", "scrollOnWrap", "toolbarPropertes"] }, { kind: "component", type: FileEditorToolbarComponent, selector: "file-editor-toolbar", inputs: ["dataUri"], outputs: ["actionEvent"] }, { kind: "component", type: UploadWidgetComponent, selector: "smart-upload-widget", inputs: ["uploadDescriptor", "isMultiple", "isDisabled"], outputs: ["uploadFilesEvent"] }] }); }
|
|
7712
7714
|
}
|
|
7713
7715
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SmartMultiFileEditorComponent, decorators: [{
|
|
7714
7716
|
type: Component,
|
|
@@ -7718,7 +7720,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
7718
7720
|
useExisting: forwardRef(() => SmartMultiFileEditorComponent),
|
|
7719
7721
|
multi: true,
|
|
7720
7722
|
},
|
|
7721
|
-
], template: "@if (widgetInstance && widgetInstance.multiFileUploaderProperties) {\r\n <h4\r\n *ngIf=\"widgetInstance.showLabel\"\r\n class=\"labelContainer {{ widgetInstance.cssLabelClass ?? '' }}\"\r\n [ngClass]=\"getLabelNgClass()\"\r\n [ngStyle]=\"getLabelStyle()\"\r\n >\r\n {{ widgetInstance.label }}\r\n </h4>\r\n <smart-ui-action-toolbar\r\n [id]=\"widgetInstance.toolbarId\"\r\n #toolbar\r\n [style]=\"{ display: 'none' }\"\r\n ></smart-ui-action-toolbar>\r\n\r\n <div class=\"fileEditorComponent\">\r\n @if (widgetInstance.value && !isTypeSupported(widgetInstance.value)) {\r\n <div class=\"errorMessage\">\r\n <smart-icon [icon]=\"errorIcon\" [color]=\"'var(--warninig-color)'\"></smart-icon>\r\n <span> Unsupported widgetInstance.value type for this widget.</span>\r\n </div>\r\n } @else {\r\n <smart-upload-widget\r\n class=\"widgetContent {{ widgetInstance.cssClass ?? '' }}\"\r\n [ngClass]=\"getNgClass()\"\r\n [ngStyle]=\"getStyle()\"\r\n [uploadDescriptor]=\"widgetInstance.multiFileUploaderProperties.uploadDescriptor!\"\r\n [isMultiple]=\"true\"\r\n [isDisabled]=\"widgetInstance.isDisabled\"\r\n (uploadFilesEvent)=\"upload($event)\"\r\n />\r\n }\r\n\r\n <div\r\n [ngClass]=\"{ disabledWidget: widgetInstance.isDisabled }\"\r\n class=\"uploadedFileContainer\"\r\n [style.display]=\"\r\n widgetInstance.value && isTypeSupported(widgetInstance.value) ? 'block' : 'none'\r\n \"\r\n >\r\n <div class=\"scrollable\">\r\n <div class=\"uploadedFile\" *ngFor=\"let file of widgetInstance.value; let i = index\">\r\n <smart-icon class=\"uploadedFileIcon\" [icon]=\"fileIcon\"></smart-icon>\r\n\r\n <div class=\"fileData\">\r\n <div class=\"fileDataContainer\">\r\n <span class=\"fileName\">{{ file?.fileName }}</span>\r\n <span class=\"fileSize\">{{ formatSize(file?.size) }}</span>\r\n </div>\r\n </div>\r\n\r\n <div class=\"fileActions\">\r\n @if (toolbarComponent && toolbarComponent.uiActionModels) {\r\n <file-editor-toolbar\r\n [id]=\"widgetInstance.toolbarId\"\r\n [dataUri]=\"file.dataUri\"\r\n [uiActionModels]=\"toolbarComponent.uiActionModels\"\r\n ></file-editor-toolbar>\r\n }\r\n <smart-icon\r\n class=\"downloadIcon\"\r\n icon=\"download\"\r\n (click)=\"downloadFile(file.dataUri)\"\r\n ></smart-icon>\r\n <smart-icon\r\n
|
|
7723
|
+
], template: "@if (widgetInstance && widgetInstance.multiFileUploaderProperties) {\r\n <h4\r\n *ngIf=\"widgetInstance.showLabel\"\r\n class=\"labelContainer {{ widgetInstance.cssLabelClass ?? '' }}\"\r\n [ngClass]=\"getLabelNgClass()\"\r\n [ngStyle]=\"getLabelStyle()\"\r\n >\r\n {{ widgetInstance.label }}\r\n </h4>\r\n <smart-ui-action-toolbar\r\n [id]=\"widgetInstance.toolbarId\"\r\n #toolbar\r\n [style]=\"{ display: 'none' }\"\r\n ></smart-ui-action-toolbar>\r\n\r\n <div class=\"fileEditorComponent\">\r\n @if (widgetInstance.value && !isTypeSupported(widgetInstance.value)) {\r\n <div class=\"errorMessage\">\r\n <smart-icon [icon]=\"errorIcon\" [color]=\"'var(--warninig-color)'\"></smart-icon>\r\n <span> Unsupported widgetInstance.value type for this widget.</span>\r\n </div>\r\n } @else {\r\n <smart-upload-widget\r\n class=\"widgetContent {{ widgetInstance.cssClass ?? '' }}\"\r\n [ngClass]=\"getNgClass()\"\r\n [ngStyle]=\"getStyle()\"\r\n [uploadDescriptor]=\"widgetInstance.multiFileUploaderProperties.uploadDescriptor!\"\r\n [isMultiple]=\"true\"\r\n [isDisabled]=\"widgetInstance.isDisabled\"\r\n (uploadFilesEvent)=\"upload($event)\"\r\n />\r\n }\r\n\r\n <div\r\n [ngClass]=\"{ disabledWidget: widgetInstance.isDisabled }\"\r\n class=\"uploadedFileContainer\"\r\n [style.display]=\"\r\n widgetInstance.value && isTypeSupported(widgetInstance.value) ? 'block' : 'none'\r\n \"\r\n >\r\n <div class=\"scrollable\">\r\n <div class=\"uploadedFile\" *ngFor=\"let file of widgetInstance.value; let i = index\">\r\n <smart-icon class=\"uploadedFileIcon\" [icon]=\"fileIcon\"></smart-icon>\r\n\r\n <div class=\"fileData\">\r\n <div class=\"fileDataContainer\">\r\n <span class=\"fileName\">{{ file?.fileName }}</span>\r\n <span class=\"fileSize\">{{ formatSize(file?.size) }}</span>\r\n </div>\r\n </div>\r\n\r\n <div class=\"fileActions\">\r\n @if (toolbarComponent && toolbarComponent.uiActionModels) {\r\n <file-editor-toolbar\r\n [id]=\"widgetInstance.toolbarId\"\r\n [dataUri]=\"file.dataUri\"\r\n [uiActionModels]=\"toolbarComponent.uiActionModels\"\r\n ></file-editor-toolbar>\r\n }\r\n <smart-icon\r\n class=\"downloadIcon\"\r\n icon=\"download\"\r\n (click)=\"downloadFile(file.dataUri)\"\r\n ></smart-icon>\r\n @if (!file.readOnly) {\r\n <smart-icon\r\n class=\"removeIcon\"\r\n [icon]=\"removeIcon\"\r\n (click)=\"!isDisabled && file.readOnly === false && deleteFile(file.dataUri)\"\r\n ></smart-icon>\r\n }\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n}\r\n", styles: [":host{--border-color: #a6aabd60;--warninig-color: #be2d2e;--def-border-radius: .5rem;width:100%}.fileEditorComponent{border:2px dashed var(--border-color);border-radius:var(--def-border-radius);overflow:hidden}.fileEditorComponent ::ng-deep smartfileuploader ::ng-deep .container{border:unset;border-radius:unset}.uploadedFileContainer{display:flex;flex-direction:column;border-top:1px solid #e0e0e0}.uploadedFile{display:flex;flex-direction:row;justify-content:flex-start;align-items:center;padding:1rem;gap:1rem}.scrollable{max-height:30vh;overflow-y:auto}.scrollable>div:not(:last-child){border-bottom:1px solid #e0e0e0}.fileSize{display:flex;flex-direction:row;font-size:smaller}.fileData{flex:1;display:flex;flex-direction:column}.fileDataContainer{display:flex;flex-direction:column;justify-content:flex-end;width:fit-content}.fileActions{display:flex;flex-direction:row;justify-content:flex-end;gap:.5rem}.fileActions ::ng-deep button{border:unset}.fileActions ::ng-deep button:hover{border:unset}.removeIcon ::ng-deep i,.removeIcon ::ng-deep mat-icon{color:var(--warninig-color)}.removeIcon ::ng-deep .pi,.downloadIcon ::ng-deep .pi{font-size:1.5rem!important}.removeIcon ::ng-deep mat-icon,.downloadIcon ::ng-deep mat-icon{font-size:2rem}.removeIcon:hover,.downloadIcon:hover{cursor:pointer}smart-icon{display:flex;align-items:center}smart-icon ::ng-deep mat-icon{font-size:3rem;width:unset;height:unset}.uploadedFileIcon{width:3rem;display:flex;justify-content:center}:host ::ng-deep .p-fileupload-content{border:unset;border-radius:var(--def-border-radius)}smart-icon ::ng-deep .pi{font-size:2rem!important}.fileEditorComponent:has(::ng-deep .errorMessage){border-color:var(--warninig-color)}.errorMessage{padding:1rem;font-size:1.5rem;color:var(--warninig-color);display:flex;flex-direction:row;align-items:center;gap:1rem}:host ::ng-deep .disabledWidget ::ng-deep .changeButton *,:host ::ng-deep .disabledWidget ::ng-deep .removeIcon *{opacity:.4!important;pointer-events:none!important}:host ::ng-deep .disabledWidget ::ng-deep .changeButton:hover,:host ::ng-deep .disabledWidget ::ng-deep .removeIcon:hover{cursor:not-allowed}:host ::ng-deep smartfileuploader ::ng-deep .uploadedFile,:host ::ng-deep .p-fileupload-file{background:repeating-linear-gradient(45deg,#fafafa,#fafafa 6px,#f1f1f1 6px 12px)}\n"] }]
|
|
7722
7724
|
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: ComponentLibrary, decorators: [{
|
|
7723
7725
|
type: Inject,
|
|
7724
7726
|
args: [COMPONENT_LIBRARY]
|