@smartbit4all/ng-client 4.2.126 → 4.2.128

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (39) hide show
  1. package/esm2022/lib/smart-client/smart-component-api-client.mjs +39 -36
  2. package/esm2022/lib/smart-form/api/api/api.mjs +1 -1
  3. package/esm2022/lib/smart-form/api/api/default.service.mjs +1 -1
  4. package/esm2022/lib/smart-form/api/api.module.mjs +1 -1
  5. package/esm2022/lib/smart-form/api/configuration.mjs +1 -1
  6. package/esm2022/lib/smart-form/api/encoder.mjs +1 -1
  7. package/esm2022/lib/smart-form/api/index.mjs +1 -1
  8. package/esm2022/lib/smart-form/api/model/fileUploaderProperties.mjs +1 -1
  9. package/esm2022/lib/smart-form/api/model/imageProperties.mjs +1 -1
  10. package/esm2022/lib/smart-form/api/model/models.mjs +1 -1
  11. package/esm2022/lib/smart-form/api/model/propertyMapping.mjs +1 -1
  12. package/esm2022/lib/smart-form/api/model/selectionDefinition.mjs +1 -1
  13. package/esm2022/lib/smart-form/api/model/smartFormInputMode.mjs +1 -1
  14. package/esm2022/lib/smart-form/api/model/smartFormWidgetDirection.mjs +1 -1
  15. package/esm2022/lib/smart-form/api/model/smartFormWidgetType.mjs +1 -1
  16. package/esm2022/lib/smart-form/api/model/smartLayoutDefinition.mjs +1 -1
  17. package/esm2022/lib/smart-form/api/model/smartMatrixModel.mjs +1 -1
  18. package/esm2022/lib/smart-form/api/model/smartWidgetDefinition.mjs +1 -1
  19. package/esm2022/lib/smart-form/api/model/smartWidgetHint.mjs +1 -1
  20. package/esm2022/lib/smart-form/api/model/sortDefinition.mjs +1 -1
  21. package/esm2022/lib/smart-form/api/model/textFieldProperties.mjs +1 -1
  22. package/esm2022/lib/smart-form/api/model/valueChangeMode.mjs +2 -1
  23. package/esm2022/lib/smart-form/api/param.mjs +1 -1
  24. package/esm2022/lib/smart-form/api/variables.mjs +1 -1
  25. package/esm2022/lib/smart-form/smartfileuploader/smartfileuploader.component.mjs +3 -2
  26. package/esm2022/lib/smart-form/smartform.component.mjs +6 -5
  27. package/esm2022/lib/smart-form/widgets/components/smart-file-editor/smart-file-editor.component.mjs +96 -66
  28. package/esm2022/lib/smart-form/widgets/smartformwidget/smartformwidget.component.mjs +36 -21
  29. package/esm2022/lib/view-context/smart-ui-action/components/upload-widget/prime-file-uploader/prime-file-uploader.component.mjs +4 -4
  30. package/fesm2022/smartbit4all-ng-client.mjs +167 -117
  31. package/fesm2022/smartbit4all-ng-client.mjs.map +1 -1
  32. package/lib/smart-client/smart-component-api-client.d.ts +9 -7
  33. package/lib/smart-form/api/model/valueChangeMode.d.ts +2 -1
  34. package/lib/smart-form/smartform.component.d.ts +3 -2
  35. package/lib/smart-form/widgets/components/smart-file-editor/smart-file-editor.component.d.ts +19 -10
  36. package/lib/smart-form/widgets/smartformwidget/smartformwidget.component.d.ts +9 -12
  37. package/package.json +1 -1
  38. package/smartbit4all-ng-client-4.2.128.tgz +0 -0
  39. package/smartbit4all-ng-client-4.2.126.tgz +0 -0
@@ -1,10 +1,10 @@
1
1
  import { Component, Inject, Input, ViewChildren, } from '@angular/core';
2
2
  import { Subject, takeUntil } from 'rxjs';
3
+ import { SmartSubject } from '../smart-subject/projects';
3
4
  import { SmartFormWidgetDirection, SmartFormWidgetType } from './api';
4
5
  import { SmartFormService } from './services/smartform.service';
5
- import { SmartSubject } from '../smart-subject/projects';
6
- import { SmartformwidgetComponent } from './widgets/smartformwidget/smartformwidget.component';
7
6
  import { COMPONENT_LIBRARY } from '../view-context/utility/componentLibrary';
7
+ import { SmartformwidgetComponent } from './widgets/smartformwidget/smartformwidget.component';
8
8
  import * as i0 from "@angular/core";
9
9
  import * as i1 from "./services/smartform.service";
10
10
  import * as i2 from "@angular/common";
@@ -18,6 +18,7 @@ export class SmartformComponent {
18
18
  this._destroy$ = new Subject();
19
19
  this.originalWidgets = [];
20
20
  this.sophisticatedValueChange = new SmartSubject(this._destroy$);
21
+ this.blurSophisticatedValueChange = new SmartSubject(this._destroy$);
21
22
  this.direction = SmartFormWidgetDirection;
22
23
  }
23
24
  ngOnChanges(changes) {
@@ -168,11 +169,11 @@ export class SmartformComponent {
168
169
  return [];
169
170
  }
170
171
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SmartformComponent, deps: [{ token: i1.SmartFormService }, { token: COMPONENT_LIBRARY }], target: i0.ɵɵFactoryTarget.Component }); }
171
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: SmartformComponent, selector: "smartform", inputs: { smartForm: "smartForm" }, providers: [SmartFormService], viewQueries: [{ propertyName: "smartWidgetsQL", predicate: SmartformwidgetComponent, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<form *ngIf=\"smartForm\" (keydown)=\"keyDownFunction($event)\" [formGroup]=\"form\" class=\"flex form\">\r\n <h2 *ngIf=\"smartForm.name\">\r\n {{ smartForm.name }}\r\n </h2>\r\n <div [ngClass]=\"smartForm.direction === direction.ROW ? 'row' : 'col'\">\r\n <div *ngFor=\"let widget of smartForm.widgets\" class=\"item\">\r\n <smartformwidget\r\n *ngIf=\"widget.isVisible === undefined ? true : widget.isVisible\"\r\n [widgetInstance]=\"widget\"\r\n [form]=\"form\"\r\n class=\"grid-item\"\r\n [onBlur]=\"onBlurSubject\"\r\n [onValueChange]=\"onValueChangeSubject\"\r\n [sophisticatedValueChange]=\"sophisticatedValueChange\"\r\n class=\"{{ widget.key }}\"\r\n [labelColor]=\"smartForm.labelTheme\"\r\n (valueCleared)=\"submitForm(true)\"\r\n ></smartformwidget>\r\n </div>\r\n </div>\r\n</form>\r\n", styles: [".col{display:flex;flex-direction:column;gap:.25em}.row{display:flex;flex-wrap:wrap;gap:.25em}.grid-item{text-align:left}.item{flex:1}.item ::ng-deep .p-inputtext{width:100%!important;min-height:45px}.item ::ng-deep p-inputnumber,.item ::ng-deep .p-inputnumber{width:100%!important;height:45px!important}.item ::ng-deep .p-dropdown,.item ::ng-deep .p-multiselect{width:100%!important}.item ::ng-deep p-overlay{z-index:1002}.item ::ng-deep .p-chips{width:100%!important;height:45px!important}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i4.SmartformwidgetComponent, selector: "smartformwidget", inputs: ["form", "widgetInstance", "onBlur", "onValueChange", "labelColor", "sophisticatedValueChange"], outputs: ["valueCleared"] }] }); }
172
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: SmartformComponent, selector: "smartform", inputs: { smartForm: "smartForm" }, providers: [SmartFormService], viewQueries: [{ propertyName: "smartWidgetsQL", predicate: SmartformwidgetComponent, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<form *ngIf=\"smartForm\" (keydown)=\"keyDownFunction($event)\" [formGroup]=\"form\" class=\"flex form\">\r\n <h2 *ngIf=\"smartForm.name\">\r\n {{ smartForm.name }}\r\n </h2>\r\n <div [ngClass]=\"smartForm.direction === direction.ROW ? 'row' : 'col'\">\r\n <div *ngFor=\"let widget of smartForm.widgets\" class=\"item\">\r\n <smartformwidget\r\n *ngIf=\"widget.isVisible === undefined ? true : widget.isVisible\"\r\n [widgetInstance]=\"widget\"\r\n [form]=\"form\"\r\n class=\"grid-item\"\r\n [onBlur]=\"onBlurSubject\"\r\n [onValueChange]=\"onValueChangeSubject\"\r\n [blurSophisticatedValueChange]=\"blurSophisticatedValueChange\"\r\n [sophisticatedValueChange]=\"sophisticatedValueChange\"\r\n class=\"{{ widget.key }}\"\r\n [labelColor]=\"smartForm.labelTheme\"\r\n (valueCleared)=\"submitForm(true)\"\r\n ></smartformwidget>\r\n </div>\r\n </div>\r\n</form>\r\n", styles: [".col{display:flex;flex-direction:column;gap:.25em}.row{display:flex;flex-wrap:wrap;gap:.25em}.grid-item{text-align:left}.item{flex:1}.item ::ng-deep .p-inputtext{width:100%!important;min-height:45px}.item ::ng-deep p-inputnumber,.item ::ng-deep .p-inputnumber{width:100%!important;height:45px!important}.item ::ng-deep .p-dropdown,.item ::ng-deep .p-multiselect{width:100%!important}.item ::ng-deep p-overlay{z-index:1002}.item ::ng-deep .p-chips{width:100%!important;height:45px!important}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i4.SmartformwidgetComponent, selector: "smartformwidget", inputs: ["form", "widgetInstance", "onBlur", "onValueChange", "labelColor", "sophisticatedValueChange", "blurSophisticatedValueChange"], outputs: ["valueCleared"] }] }); }
172
173
  }
173
174
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SmartformComponent, decorators: [{
174
175
  type: Component,
175
- args: [{ selector: 'smartform', providers: [SmartFormService], template: "<form *ngIf=\"smartForm\" (keydown)=\"keyDownFunction($event)\" [formGroup]=\"form\" class=\"flex form\">\r\n <h2 *ngIf=\"smartForm.name\">\r\n {{ smartForm.name }}\r\n </h2>\r\n <div [ngClass]=\"smartForm.direction === direction.ROW ? 'row' : 'col'\">\r\n <div *ngFor=\"let widget of smartForm.widgets\" class=\"item\">\r\n <smartformwidget\r\n *ngIf=\"widget.isVisible === undefined ? true : widget.isVisible\"\r\n [widgetInstance]=\"widget\"\r\n [form]=\"form\"\r\n class=\"grid-item\"\r\n [onBlur]=\"onBlurSubject\"\r\n [onValueChange]=\"onValueChangeSubject\"\r\n [sophisticatedValueChange]=\"sophisticatedValueChange\"\r\n class=\"{{ widget.key }}\"\r\n [labelColor]=\"smartForm.labelTheme\"\r\n (valueCleared)=\"submitForm(true)\"\r\n ></smartformwidget>\r\n </div>\r\n </div>\r\n</form>\r\n", styles: [".col{display:flex;flex-direction:column;gap:.25em}.row{display:flex;flex-wrap:wrap;gap:.25em}.grid-item{text-align:left}.item{flex:1}.item ::ng-deep .p-inputtext{width:100%!important;min-height:45px}.item ::ng-deep p-inputnumber,.item ::ng-deep .p-inputnumber{width:100%!important;height:45px!important}.item ::ng-deep .p-dropdown,.item ::ng-deep .p-multiselect{width:100%!important}.item ::ng-deep p-overlay{z-index:1002}.item ::ng-deep .p-chips{width:100%!important;height:45px!important}\n"] }]
176
+ args: [{ selector: 'smartform', providers: [SmartFormService], template: "<form *ngIf=\"smartForm\" (keydown)=\"keyDownFunction($event)\" [formGroup]=\"form\" class=\"flex form\">\r\n <h2 *ngIf=\"smartForm.name\">\r\n {{ smartForm.name }}\r\n </h2>\r\n <div [ngClass]=\"smartForm.direction === direction.ROW ? 'row' : 'col'\">\r\n <div *ngFor=\"let widget of smartForm.widgets\" class=\"item\">\r\n <smartformwidget\r\n *ngIf=\"widget.isVisible === undefined ? true : widget.isVisible\"\r\n [widgetInstance]=\"widget\"\r\n [form]=\"form\"\r\n class=\"grid-item\"\r\n [onBlur]=\"onBlurSubject\"\r\n [onValueChange]=\"onValueChangeSubject\"\r\n [blurSophisticatedValueChange]=\"blurSophisticatedValueChange\"\r\n [sophisticatedValueChange]=\"sophisticatedValueChange\"\r\n class=\"{{ widget.key }}\"\r\n [labelColor]=\"smartForm.labelTheme\"\r\n (valueCleared)=\"submitForm(true)\"\r\n ></smartformwidget>\r\n </div>\r\n </div>\r\n</form>\r\n", styles: [".col{display:flex;flex-direction:column;gap:.25em}.row{display:flex;flex-wrap:wrap;gap:.25em}.grid-item{text-align:left}.item{flex:1}.item ::ng-deep .p-inputtext{width:100%!important;min-height:45px}.item ::ng-deep p-inputnumber,.item ::ng-deep .p-inputnumber{width:100%!important;height:45px!important}.item ::ng-deep .p-dropdown,.item ::ng-deep .p-multiselect{width:100%!important}.item ::ng-deep p-overlay{z-index:1002}.item ::ng-deep .p-chips{width:100%!important;height:45px!important}\n"] }]
176
177
  }], ctorParameters: () => [{ type: i1.SmartFormService }, { type: i5.ComponentLibrary, decorators: [{
177
178
  type: Inject,
178
179
  args: [COMPONENT_LIBRARY]
@@ -182,4 +183,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
182
183
  type: ViewChildren,
183
184
  args: [SmartformwidgetComponent]
184
185
  }] } });
185
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smartform.component.js","sourceRoot":"","sources":["../../../../../projects/smart-ng-client/src/lib/smart-form/smartform.component.ts","../../../../../projects/smart-ng-client/src/lib/smart-form/smartform.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  Inject,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  QueryList,\r\n  SimpleChanges,\r\n  ViewChildren,\r\n} from '@angular/core';\r\nimport { UntypedFormGroup } from '@angular/forms';\r\nimport { Subject, takeUntil } from 'rxjs';\r\nimport { SmartFormWidgetDirection, SmartFormWidgetType } from './api';\r\nimport { SmartFormService } from './services/smartform.service';\r\nimport { SmartForm, SmartFormInvalidFields, SophisticatedValueChange } from './smartform.model';\r\nimport { SmartSubject } from '../smart-subject/projects';\r\n// import { UiActionToolbarComponent } from '../view-context/smart-ui-action/ui-action-toolbar.component';\r\nimport { SmartFormWidget } from './smartform.form-model';\r\nimport { SmartformwidgetComponent } from './widgets/smartformwidget/smartformwidget.component';\r\nimport { UiActionToolbarComponent } from '../view-context/smart-ui-action/ui-action-toolbar.component';\r\nimport { COMPONENT_LIBRARY, ComponentLibrary } from '../view-context/utility/componentLibrary';\r\n\r\n@Component({\r\n  selector: 'smartform',\r\n  templateUrl: './smartform.component.html',\r\n  styleUrls: ['./smartform.component.css'],\r\n  providers: [SmartFormService],\r\n})\r\nexport class SmartformComponent implements OnInit, OnDestroy, OnChanges {\r\n  private _destroy$: Subject<void> = new Subject();\r\n\r\n  @Input() smartForm?: SmartForm;\r\n  onBlurSubject?: Subject<any>;\r\n  onValueChangeSubject?: Subject<any>;\r\n  originalWidgets: SmartFormWidget<any>[] = [];\r\n\r\n  sophisticatedValueChange: Subject<SophisticatedValueChange> = new SmartSubject(this._destroy$);\r\n\r\n  form!: UntypedFormGroup;\r\n\r\n  direction = SmartFormWidgetDirection;\r\n\r\n  @ViewChildren(SmartformwidgetComponent)\r\n  smartWidgetsQL?: QueryList<SmartformwidgetComponent>;\r\n\r\n  constructor(\r\n    private service: SmartFormService,\r\n    @Inject(COMPONENT_LIBRARY) public compLib: ComponentLibrary\r\n  ) {}\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    this.smartForm = changes['smartForm'].currentValue;\r\n    this.originalWidgets = [];\r\n    if (this.smartForm) {\r\n      this.constructForm();\r\n    }\r\n  }\r\n  ngOnInit(): void {\r\n    if (this.smartForm) {\r\n      this.constructForm();\r\n    }\r\n    this.onBlurSubject = new SmartSubject(this._destroy$);\r\n  }\r\n\r\n  // ngAfterViewInit(): void {\r\n  //   if (this.smartWidgetsQL) {\r\n  //     this.handleQueryList(this.smartWidgetsQL, (widget) => {\r\n  //       // ???\r\n  //     });\r\n  //   }\r\n  // }\r\n\r\n  // // TODO this is a duplicate from SmartFormApiClient -> move it to a utility\r\n  // protected handleQueryList<T>(ql: QueryList<T>, handler: (el: T) => void) {\r\n  //   ql.forEach((el) => handler(el));\r\n  //   ql.changes\r\n  //     .pipe(takeUntil(this._destroy$))\r\n  //     .subscribe((list) => (list as QueryList<T>).forEach((el) => handler(el)));\r\n  // }\r\n\r\n  refresh(): void {\r\n    this.service.setValuesFromModel();\r\n  }\r\n\r\n  constructForm(): void {\r\n    if (!this.smartForm) {\r\n      throw new Error('Smartform has not been defined!');\r\n    }\r\n\r\n    if (this.smartForm.useOnValueChangeEvent && !this.onValueChangeSubject) {\r\n      this.onValueChangeSubject = new SmartSubject(this._destroy$);\r\n    }\r\n\r\n    this.service.smartForm = this.smartForm;\r\n    if (!this.originalWidgets || this.originalWidgets.length === 0) {\r\n      this.originalWidgets = this.smartForm.widgets;\r\n    }\r\n    this.service.setValuesFromModel(this.originalWidgets, this.compLib);\r\n    this.service.applyConstraints(this.originalWidgets);\r\n    this.smartForm.widgets = this.service.filterWidgetsByVisibility(this.originalWidgets);\r\n    this.form = this.service.toFormGroup(this.compLib);\r\n\r\n    if (this.smartForm.translateService) {\r\n      this.smartForm.translateService.onLangChange.pipe(takeUntil(this._destroy$)).subscribe(() => {\r\n        this.translateWidgets(this.smartForm!.widgets);\r\n      });\r\n      this.translateWidgets(this.smartForm.widgets);\r\n    }\r\n  }\r\n\r\n  private async translateWidgets(widgets: SmartFormWidget<any>[]): Promise<void> {\r\n    await this.service.translateWidgets(this.smartForm!.widgets);\r\n    this.markAllWidgetsForChangeDetection();\r\n  }\r\n\r\n  public markAllWidgetsForChangeDetection() {\r\n    this.getAllSmartWidgets().forEach((widget) => widget.changeDetector.markForCheck());\r\n  }\r\n  private getAllSmartWidgets(): SmartformwidgetComponent[] {\r\n    const result: SmartformwidgetComponent[] = [];\r\n    this.smartWidgetsQL?.forEach((widget) => {\r\n      result.push(...this.getChildWidgets(widget));\r\n    });\r\n    return result;\r\n  }\r\n\r\n  private getChildWidgets(widget: SmartformwidgetComponent): SmartformwidgetComponent[] {\r\n    if (widget.widgetInstance.type == SmartFormWidgetType.CONTAINER) {\r\n      const result: SmartformwidgetComponent[] = [];\r\n      widget.childrenWidgetsQL?.forEach((child) => result.push(...this.getChildWidgets(child)));\r\n      return result;\r\n    } else {\r\n      return [widget];\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._destroy$.next();\r\n    this._destroy$.complete();\r\n  }\r\n\r\n  getForm(): UntypedFormGroup {\r\n    return this.form;\r\n  }\r\n\r\n  getInvalidFields(): SmartFormInvalidFields {\r\n    let invalidFields: SmartFormInvalidFields = {\r\n      invalidFieldKeys: [],\r\n      invalidFieldNames: [],\r\n    };\r\n    if (this.form) {\r\n      for (const control of Object.keys(this.form.controls)) {\r\n        if (!this.form.controls[control].valid) {\r\n          let widget = this.service.getSmartFormWidgetByKey(control);\r\n          if (\r\n            widget &&\r\n            widget.type !== SmartFormWidgetType.CONTAINER &&\r\n            widget.type !== SmartFormWidgetType.INDICATOR &&\r\n            widget.type !== SmartFormWidgetType.LABEL &&\r\n            widget.type !== SmartFormWidgetType.FILE_UPLOADER &&\r\n            widget.type !== SmartFormWidgetType.IMAGE &&\r\n            widget.type !== SmartFormWidgetType.SVG &&\r\n            widget.type !== SmartFormWidgetType.DIVIDER &&\r\n            widget.type !== SmartFormWidgetType.BUTTON &&\r\n            widget.type !== SmartFormWidgetType.COMPONENT &&\r\n            widget.type !== SmartFormWidgetType.YOUTUBE_PLAYER &&\r\n            !widget.isDisabled\r\n          ) {\r\n            invalidFields.invalidFieldNames.push(widget.label);\r\n            invalidFields.invalidFieldKeys.push(widget.key);\r\n          }\r\n        }\r\n      }\r\n    }\r\n    return invalidFields;\r\n  }\r\n\r\n  submitForm(validate = true): SmartForm {\r\n    if (validate) {\r\n      this.smartForm!.invalidFields = undefined;\r\n\r\n      if (this.form && this.form.invalid) {\r\n        for (const control of Object.keys(this.form.controls)) {\r\n          this.form.controls[control].markAsTouched();\r\n          this.form.controls[control].markAsDirty();\r\n          // this.form.controls[control].setValue(value);\r\n        }\r\n\r\n        this.smartForm!.invalidFields = this.getInvalidFields();\r\n        this.markAllWidgetsForChangeDetection();\r\n        return this.smartForm!;\r\n      }\r\n    }\r\n    return this.service.toSmartForm(this.form);\r\n  }\r\n\r\n  keyDownFunction(event: any): void {\r\n    if (event.keyCode === 13 && this.smartForm!.submitOnEnter) {\r\n      this.smartForm!.submitOnEnter();\r\n    }\r\n  }\r\n\r\n  getModel(): any {\r\n    return this.service.getModel(this.form);\r\n  }\r\n\r\n  getToolbars(): UiActionToolbarComponent[] {\r\n    if (this.smartWidgetsQL) {\r\n      let toolbars = this.smartWidgetsQL\r\n        .filter((widget) => widget.toolbar !== undefined && widget.toolbar !== null)\r\n        .map((widget) => widget.toolbar!);\r\n      if (toolbars) {\r\n        return toolbars;\r\n      }\r\n    }\r\n    return [];\r\n  }\r\n}\r\n","<form *ngIf=\"smartForm\" (keydown)=\"keyDownFunction($event)\" [formGroup]=\"form\" class=\"flex form\">\r\n  <h2 *ngIf=\"smartForm.name\">\r\n    {{ smartForm.name }}\r\n  </h2>\r\n  <div [ngClass]=\"smartForm.direction === direction.ROW ? 'row' : 'col'\">\r\n    <div *ngFor=\"let widget of smartForm.widgets\" class=\"item\">\r\n      <smartformwidget\r\n        *ngIf=\"widget.isVisible === undefined ? true : widget.isVisible\"\r\n        [widgetInstance]=\"widget\"\r\n        [form]=\"form\"\r\n        class=\"grid-item\"\r\n        [onBlur]=\"onBlurSubject\"\r\n        [onValueChange]=\"onValueChangeSubject\"\r\n        [sophisticatedValueChange]=\"sophisticatedValueChange\"\r\n        class=\"{{ widget.key }}\"\r\n        [labelColor]=\"smartForm.labelTheme\"\r\n        (valueCleared)=\"submitForm(true)\"\r\n      ></smartformwidget>\r\n    </div>\r\n  </div>\r\n</form>\r\n"]}
186
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smartform.component.js","sourceRoot":"","sources":["../../../../../projects/smart-ng-client/src/lib/smart-form/smartform.component.ts","../../../../../projects/smart-ng-client/src/lib/smart-form/smartform.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  Inject,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  QueryList,\r\n  SimpleChanges,\r\n  ViewChildren,\r\n} from '@angular/core';\r\nimport { UntypedFormGroup } from '@angular/forms';\r\nimport { Subject, takeUntil } from 'rxjs';\r\nimport { SmartSubject } from '../smart-subject/projects';\r\nimport { SmartFormWidgetDirection, SmartFormWidgetType } from './api';\r\nimport { SmartFormService } from './services/smartform.service';\r\nimport { SmartForm, SmartFormInvalidFields, SophisticatedValueChange } from './smartform.model';\r\n// import { UiActionToolbarComponent } from '../view-context/smart-ui-action/ui-action-toolbar.component';\r\nimport { UiActionToolbarComponent } from '../view-context/smart-ui-action/ui-action-toolbar.component';\r\nimport { COMPONENT_LIBRARY, ComponentLibrary } from '../view-context/utility/componentLibrary';\r\nimport { SmartFormWidget } from './smartform.form-model';\r\nimport { SmartformwidgetComponent } from './widgets/smartformwidget/smartformwidget.component';\r\n\r\n@Component({\r\n  selector: 'smartform',\r\n  templateUrl: './smartform.component.html',\r\n  styleUrls: ['./smartform.component.css'],\r\n  providers: [SmartFormService],\r\n})\r\nexport class SmartformComponent implements OnInit, OnDestroy, OnChanges {\r\n  private _destroy$: Subject<void> = new Subject();\r\n\r\n  @Input() smartForm?: SmartForm;\r\n  onBlurSubject?: Subject<any>;\r\n  onValueChangeSubject?: Subject<any>;\r\n  originalWidgets: SmartFormWidget<any>[] = [];\r\n\r\n  sophisticatedValueChange: Subject<SophisticatedValueChange> = new SmartSubject(this._destroy$);\r\n  blurSophisticatedValueChange: Subject<SophisticatedValueChange> = new SmartSubject(\r\n    this._destroy$\r\n  );\r\n\r\n  form!: UntypedFormGroup;\r\n\r\n  direction = SmartFormWidgetDirection;\r\n\r\n  @ViewChildren(SmartformwidgetComponent)\r\n  smartWidgetsQL?: QueryList<SmartformwidgetComponent>;\r\n\r\n  constructor(\r\n    private service: SmartFormService,\r\n    @Inject(COMPONENT_LIBRARY) public compLib: ComponentLibrary\r\n  ) {}\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    this.smartForm = changes['smartForm'].currentValue;\r\n    this.originalWidgets = [];\r\n    if (this.smartForm) {\r\n      this.constructForm();\r\n    }\r\n  }\r\n  ngOnInit(): void {\r\n    if (this.smartForm) {\r\n      this.constructForm();\r\n    }\r\n    this.onBlurSubject = new SmartSubject(this._destroy$);\r\n  }\r\n\r\n  // ngAfterViewInit(): void {\r\n  //   if (this.smartWidgetsQL) {\r\n  //     this.handleQueryList(this.smartWidgetsQL, (widget) => {\r\n  //       // ???\r\n  //     });\r\n  //   }\r\n  // }\r\n\r\n  // // TODO this is a duplicate from SmartFormApiClient -> move it to a utility\r\n  // protected handleQueryList<T>(ql: QueryList<T>, handler: (el: T) => void) {\r\n  //   ql.forEach((el) => handler(el));\r\n  //   ql.changes\r\n  //     .pipe(takeUntil(this._destroy$))\r\n  //     .subscribe((list) => (list as QueryList<T>).forEach((el) => handler(el)));\r\n  // }\r\n\r\n  refresh(): void {\r\n    this.service.setValuesFromModel();\r\n  }\r\n\r\n  constructForm(): void {\r\n    if (!this.smartForm) {\r\n      throw new Error('Smartform has not been defined!');\r\n    }\r\n\r\n    if (this.smartForm.useOnValueChangeEvent && !this.onValueChangeSubject) {\r\n      this.onValueChangeSubject = new SmartSubject(this._destroy$);\r\n    }\r\n\r\n    this.service.smartForm = this.smartForm;\r\n    if (!this.originalWidgets || this.originalWidgets.length === 0) {\r\n      this.originalWidgets = this.smartForm.widgets;\r\n    }\r\n    this.service.setValuesFromModel(this.originalWidgets, this.compLib);\r\n    this.service.applyConstraints(this.originalWidgets);\r\n    this.smartForm.widgets = this.service.filterWidgetsByVisibility(this.originalWidgets);\r\n    this.form = this.service.toFormGroup(this.compLib);\r\n\r\n    if (this.smartForm.translateService) {\r\n      this.smartForm.translateService.onLangChange.pipe(takeUntil(this._destroy$)).subscribe(() => {\r\n        this.translateWidgets(this.smartForm!.widgets);\r\n      });\r\n      this.translateWidgets(this.smartForm.widgets);\r\n    }\r\n  }\r\n\r\n  private async translateWidgets(widgets: SmartFormWidget<any>[]): Promise<void> {\r\n    await this.service.translateWidgets(this.smartForm!.widgets);\r\n    this.markAllWidgetsForChangeDetection();\r\n  }\r\n\r\n  public markAllWidgetsForChangeDetection() {\r\n    this.getAllSmartWidgets().forEach((widget) => widget.changeDetector.markForCheck());\r\n  }\r\n  private getAllSmartWidgets(): SmartformwidgetComponent[] {\r\n    const result: SmartformwidgetComponent[] = [];\r\n    this.smartWidgetsQL?.forEach((widget) => {\r\n      result.push(...this.getChildWidgets(widget));\r\n    });\r\n    return result;\r\n  }\r\n\r\n  private getChildWidgets(widget: SmartformwidgetComponent): SmartformwidgetComponent[] {\r\n    if (widget.widgetInstance.type == SmartFormWidgetType.CONTAINER) {\r\n      const result: SmartformwidgetComponent[] = [];\r\n      widget.childrenWidgetsQL?.forEach((child) => result.push(...this.getChildWidgets(child)));\r\n      return result;\r\n    } else {\r\n      return [widget];\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._destroy$.next();\r\n    this._destroy$.complete();\r\n  }\r\n\r\n  getForm(): UntypedFormGroup {\r\n    return this.form;\r\n  }\r\n\r\n  getInvalidFields(): SmartFormInvalidFields {\r\n    let invalidFields: SmartFormInvalidFields = {\r\n      invalidFieldKeys: [],\r\n      invalidFieldNames: [],\r\n    };\r\n    if (this.form) {\r\n      for (const control of Object.keys(this.form.controls)) {\r\n        if (!this.form.controls[control].valid) {\r\n          let widget = this.service.getSmartFormWidgetByKey(control);\r\n          if (\r\n            widget &&\r\n            widget.type !== SmartFormWidgetType.CONTAINER &&\r\n            widget.type !== SmartFormWidgetType.INDICATOR &&\r\n            widget.type !== SmartFormWidgetType.LABEL &&\r\n            widget.type !== SmartFormWidgetType.FILE_UPLOADER &&\r\n            widget.type !== SmartFormWidgetType.IMAGE &&\r\n            widget.type !== SmartFormWidgetType.SVG &&\r\n            widget.type !== SmartFormWidgetType.DIVIDER &&\r\n            widget.type !== SmartFormWidgetType.BUTTON &&\r\n            widget.type !== SmartFormWidgetType.COMPONENT &&\r\n            widget.type !== SmartFormWidgetType.YOUTUBE_PLAYER &&\r\n            !widget.isDisabled\r\n          ) {\r\n            invalidFields.invalidFieldNames.push(widget.label);\r\n            invalidFields.invalidFieldKeys.push(widget.key);\r\n          }\r\n        }\r\n      }\r\n    }\r\n    return invalidFields;\r\n  }\r\n\r\n  submitForm(validate = true): SmartForm {\r\n    if (validate) {\r\n      this.smartForm!.invalidFields = undefined;\r\n\r\n      if (this.form && this.form.invalid) {\r\n        for (const control of Object.keys(this.form.controls)) {\r\n          this.form.controls[control].markAsTouched();\r\n          this.form.controls[control].markAsDirty();\r\n          // this.form.controls[control].setValue(value);\r\n        }\r\n\r\n        this.smartForm!.invalidFields = this.getInvalidFields();\r\n        this.markAllWidgetsForChangeDetection();\r\n        return this.smartForm!;\r\n      }\r\n    }\r\n    return this.service.toSmartForm(this.form);\r\n  }\r\n\r\n  keyDownFunction(event: any): void {\r\n    if (event.keyCode === 13 && this.smartForm!.submitOnEnter) {\r\n      this.smartForm!.submitOnEnter();\r\n    }\r\n  }\r\n\r\n  getModel(): any {\r\n    return this.service.getModel(this.form);\r\n  }\r\n\r\n  getToolbars(): UiActionToolbarComponent[] {\r\n    if (this.smartWidgetsQL) {\r\n      let toolbars = this.smartWidgetsQL\r\n        .filter((widget) => widget.toolbar !== undefined && widget.toolbar !== null)\r\n        .map((widget) => widget.toolbar!);\r\n      if (toolbars) {\r\n        return toolbars;\r\n      }\r\n    }\r\n    return [];\r\n  }\r\n}\r\n","<form *ngIf=\"smartForm\" (keydown)=\"keyDownFunction($event)\" [formGroup]=\"form\" class=\"flex form\">\r\n  <h2 *ngIf=\"smartForm.name\">\r\n    {{ smartForm.name }}\r\n  </h2>\r\n  <div [ngClass]=\"smartForm.direction === direction.ROW ? 'row' : 'col'\">\r\n    <div *ngFor=\"let widget of smartForm.widgets\" class=\"item\">\r\n      <smartformwidget\r\n        *ngIf=\"widget.isVisible === undefined ? true : widget.isVisible\"\r\n        [widgetInstance]=\"widget\"\r\n        [form]=\"form\"\r\n        class=\"grid-item\"\r\n        [onBlur]=\"onBlurSubject\"\r\n        [onValueChange]=\"onValueChangeSubject\"\r\n        [blurSophisticatedValueChange]=\"blurSophisticatedValueChange\"\r\n        [sophisticatedValueChange]=\"sophisticatedValueChange\"\r\n        class=\"{{ widget.key }}\"\r\n        [labelColor]=\"smartForm.labelTheme\"\r\n        (valueCleared)=\"submitForm(true)\"\r\n      ></smartformwidget>\r\n    </div>\r\n  </div>\r\n</form>\r\n"]}
@@ -1,8 +1,9 @@
1
- import { Component, EventEmitter, Inject, Input, Optional, Output, ViewChild, } from '@angular/core';
1
+ import { Component, EventEmitter, forwardRef, Inject, Input, Optional, Output, ViewChild, } from '@angular/core';
2
2
  import { SmartStyleUtility } from '../../../../view-context/utility/smart-style-utility';
3
3
  import { IconPosition, UiActionButtonType, } from '../../../../view-context/api/model/models';
4
4
  import { COMPONENT_LIBRARY, ComponentLibrary, } from '../../../../view-context/utility/componentLibrary';
5
5
  import { UploadWidgetUtils } from '../../../../view-context/smart-ui-action/components/upload-widget/upload-widget.utils';
6
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
6
7
  import * as i0 from "@angular/core";
7
8
  import * as i1 from "@angular/common";
8
9
  import * as i2 from "../../../../smart-icon/smart-icon/smart-icon.component";
@@ -11,37 +12,51 @@ import * as i4 from "../../../../view-context/smart-ui-action/ui-action-button/u
11
12
  import * as i5 from "../../../../view-context/smart-ui-action/components/upload-widget/upload-widget.component";
12
13
  import * as i6 from "../../../../view-context/utility/componentLibrary";
13
14
  export class SmartFileEditorComponent {
14
- constructor(compLib) {
15
+ get widgetInstance() {
16
+ return this._widgetInstance;
17
+ }
18
+ set widgetInstance(value) {
19
+ if (value) {
20
+ this.clone(value);
21
+ }
22
+ }
23
+ constructor(cdr, compLib) {
24
+ this.cdr = cdr;
15
25
  this.compLib = compLib;
16
26
  this.uploadFilesEvent = new EventEmitter();
17
- this.uiActionModels = [];
18
- }
19
- ngOnInit() {
20
- if (!this.widgetInstance.fileUploaderProperties?.undoIcon) {
21
- this.widgetInstance.fileUploaderProperties.undoIcon = {
22
- identifier: 'undo',
27
+ // ---- ControlValueAccessor implementation ----
28
+ this.onChange = (value) => { };
29
+ this.onTouched = () => { };
30
+ this.isDisabled = false;
31
+ }
32
+ clone(value) {
33
+ this._widgetInstance =
34
+ typeof structuredClone === 'function'
35
+ ? structuredClone(value)
36
+ : JSON.parse(JSON.stringify(value));
37
+ if (!this._widgetInstance.fileUploaderProperties?.undoIcon) {
38
+ this._widgetInstance.fileUploaderProperties = {
39
+ ...(this._widgetInstance.fileUploaderProperties ?? {}),
40
+ undoIcon: { identifier: 'undo' },
23
41
  };
24
42
  }
43
+ this.cdr.markForCheck();
25
44
  }
26
45
  upload(event) {
27
- if (!this.fileToChange) {
28
- this.uploadFilesEvent.emit({
29
- files: event.files,
30
- uiAction: this.widgetInstance.fileUploaderProperties.uploadAction,
31
- uploadDescriptor: event.uploadDescriptor,
32
- });
33
- }
34
- else {
35
- var changeAction = this.widgetInstance.fileUploaderProperties?.changeAction;
36
- if (!changeAction) {
37
- changeAction = this.widgetInstance.fileUploaderProperties?.uploadAction;
38
- }
39
- this.uploadFilesEvent.emit({
40
- files: event.files,
41
- uiAction: changeAction,
42
- uploadDescriptor: event.uploadDescriptor,
43
- });
46
+ if (!event.files || event.files.length == 0) {
47
+ return;
44
48
  }
49
+ const props = this._widgetInstance.fileUploaderProperties;
50
+ const uiAction = this.fileToChange
51
+ ? props.changeAction ?? props.uploadAction
52
+ : props.uploadAction;
53
+ this.uploadFilesEvent.emit({
54
+ files: event.files,
55
+ uiAction: uiAction,
56
+ uploadDescriptor: event.uploadDescriptor,
57
+ });
58
+ this.onChange(this._widgetInstance.value);
59
+ this.fileToChange = undefined;
45
60
  }
46
61
  change(file) {
47
62
  this.fileToChange = file;
@@ -49,75 +64,78 @@ export class SmartFileEditorComponent {
49
64
  cancelChange() {
50
65
  this.fileToChange = undefined;
51
66
  }
67
+ isTypeSupported(value) {
68
+ return !!(value && !Array.isArray(value) && 'dataUri' in value);
69
+ }
70
+ formatSize(bytes) {
71
+ return UploadWidgetUtils.formatSize(bytes);
72
+ }
73
+ // ---- Smart form widget functions ----
52
74
  getLabelNgClass() {
53
- if ('labelStyle' in this.widgetInstance) {
54
- return SmartStyleUtility.getNgClasses(this.widgetInstance.labelStyle);
55
- }
56
- return {};
75
+ return this._widgetInstance?.labelStyle
76
+ ? SmartStyleUtility.getNgClasses(this._widgetInstance.labelStyle)
77
+ : {};
57
78
  }
58
79
  getLabelStyle() {
59
- if ('labelStyle' in this.widgetInstance) {
60
- return SmartStyleUtility.getNgStyles(this.widgetInstance.labelStyle);
61
- }
62
- return {};
80
+ return this._widgetInstance?.labelStyle
81
+ ? SmartStyleUtility.getNgStyles(this._widgetInstance.labelStyle)
82
+ : {};
63
83
  }
64
84
  getNgClass() {
65
- return SmartStyleUtility.getNgClasses(this.widgetInstance.style);
85
+ return SmartStyleUtility.getNgClasses(this._widgetInstance?.style);
66
86
  }
67
87
  getStyle() {
68
- if (!this.widgetInstance.style) {
69
- this.widgetInstance.style = {
88
+ if (!this._widgetInstance.style) {
89
+ this._widgetInstance.style = {
70
90
  classesToAdd: [],
71
91
  classesToRemove: [],
72
92
  style: {},
73
93
  };
74
94
  }
75
- if (!('width' in this.widgetInstance.style.style) && 'minWidth' in this.widgetInstance) {
76
- this.widgetInstance.style.style['width'] = `${this.widgetInstance.minWidth}px`;
95
+ if (!('width' in this._widgetInstance.style.style) && 'minWidth' in this._widgetInstance) {
96
+ this._widgetInstance.style.style['width'] = `${this._widgetInstance.minWidth}px`;
77
97
  }
78
- return SmartStyleUtility.getNgStyles(this.widgetInstance.style);
98
+ return SmartStyleUtility.getNgStyles(this._widgetInstance.style);
79
99
  }
80
- isTypeSupported(value) {
81
- if (Array.isArray(value))
82
- return false;
83
- if (!value || !('dataUri' in value))
84
- return false;
85
- return true;
100
+ writeValue(value) {
101
+ if (value !== undefined && this._widgetInstance) {
102
+ this._widgetInstance.value = value;
103
+ this.cdr.markForCheck();
104
+ }
86
105
  }
87
- formatSize(bytes) {
88
- return UploadWidgetUtils.formatSize(bytes);
106
+ registerOnChange(fn) {
107
+ this.onChange = fn;
89
108
  }
109
+ registerOnTouched(fn) {
110
+ this.onTouched = fn;
111
+ }
112
+ setDisabledState(isDisabled) {
113
+ this.isDisabled = isDisabled;
114
+ }
115
+ // ---- UI getters ----
90
116
  get fileIcon() {
91
117
  return this.compLib == ComponentLibrary.PRIMENG ? 'file' : 'insert_drive_file';
92
118
  }
93
119
  get changeButton() {
94
- var props = this.widgetInstance.fileUploaderProperties;
95
- var changeAction = props.changeAction ?? props.uploadAction;
96
- changeAction.descriptor ??= {
120
+ var props = this._widgetInstance.fileUploaderProperties;
121
+ var baseAction = props.changeAction ?? props.uploadAction;
122
+ var changeDescriptor = {
123
+ ...(baseAction.descriptor ?? {}),
97
124
  title: '',
98
125
  color: 'primary',
99
126
  type: UiActionButtonType.ICON,
100
127
  icon: this.compLib === ComponentLibrary.PRIMENG ? 'sync' : 'sync_alt',
101
128
  iconPosition: IconPosition.PRE,
102
129
  };
103
- changeAction.descriptor.title = '';
104
- var d = changeAction.descriptor;
105
- return {
106
- title: d.title ?? '',
107
- color: d.color ?? 'primary',
108
- type: d.type ?? UiActionButtonType.ICON,
109
- icon: this.compLib === ComponentLibrary.PRIMENG ? 'sync' : 'sync_alt',
110
- iconPosition: d.iconPosition,
111
- };
130
+ return changeDescriptor;
112
131
  }
113
132
  get removeButton() {
114
133
  var changeButton = this.changeButton;
115
- var undoIcon = this.widgetInstance.fileUploaderProperties?.undoIcon;
116
134
  return {
117
135
  title: '',
118
136
  color: changeButton.color,
119
137
  type: changeButton.type,
120
- iconResource: undoIcon,
138
+ iconResource: this._widgetInstance.fileUploaderProperties.undoIcon,
121
139
  iconPosition: IconPosition.PRE,
122
140
  };
123
141
  }
@@ -127,13 +145,25 @@ export class SmartFileEditorComponent {
127
145
  get toolbarComponent() {
128
146
  return this.toolbar;
129
147
  }
130
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SmartFileEditorComponent, deps: [{ token: COMPONENT_LIBRARY, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
131
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.11", type: SmartFileEditorComponent, selector: "smart-file-editor", inputs: { widgetInstance: "widgetInstance" }, outputs: { uploadFilesEvent: "uploadFilesEvent" }, viewQueries: [{ propertyName: "toolbar", first: true, predicate: ["toolbar"], descendants: true }], ngImport: i0, template: "@if( widgetInstance.fileUploaderProperties){\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\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 value type for this widget.</span>\r\n </div>\r\n } @else if(!widgetInstance.value || fileToChange ) {\r\n <smart-upload-widget\r\n class=\"widgetContent {{ widgetInstance.cssClass ?? '' }}\"\r\n [ngClass]=\"getNgClass()\"\r\n [ngStyle]=\"getStyle()\"\r\n [uploadDescriptor]=\"widgetInstance.fileUploaderProperties.uploadDescriptor!\"\r\n [isMultiple]=\"false\"\r\n (uploadFilesEvent)=\"upload($event)\"\r\n />\r\n } @if (widgetInstance.value && isTypeSupported(widgetInstance.value)) {\r\n <div class=\"uploadedFileContainer\">\r\n <ng-container\r\n *ngTemplateOutlet=\"fileRow; context: { file: widgetInstance.value }\"\r\n ></ng-container>\r\n </div>\r\n }\r\n</div>\r\n}\r\n\r\n<ng-template #fileRow let-file=\"file\" let-i=\"index\">\r\n <div class=\"uploadedFile\">\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 <smart-ui-action-toolbar [id]=\"widgetInstance.toolbarId\" #toolbar> </smart-ui-action-toolbar>\r\n\r\n @if(!fileToChange){\r\n <ui-action-button (actionClick)=\"change(file)\" [descriptor]=\"changeButton\">\r\n </ui-action-button>\r\n } @else {\r\n <ui-action-button\r\n class=\"removeIcon\"\r\n (actionClick)=\"cancelChange()\"\r\n [descriptor]=\"removeButton\"\r\n >\r\n </ui-action-button>\r\n\r\n }\r\n </div>\r\n </div>\r\n</ng-template>\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)}.fileEditorComponent ::ng-deep smartfileuploader ::ng-deep .container{border:unset;border-radius:unset}.uploadedFileContainer{display:flex;flex-direction:column}.uploadedFile{display:flex;flex-direction:row;justify-content:flex-start;align-items:center;padding:1rem;gap:1rem}.fileEditorComponent:has(::ng-deep smartfileuploader) ::ng-deep .uploadedFile{border-top: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:1rem}.fileActions ::ng-deep button{border:unset}.fileActions ::ng-deep button:hover{border:unset}.removeIcon ::ng-deep mat-icon{color:var(--warninig-color)}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}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { 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"] }, { kind: "component", type: i4.UiActionButtonComponent, selector: "ui-action-button", inputs: ["disabled", "descriptor", "code", "addedCssClass"], outputs: ["actionClick", "actionDoubleClick"] }, { kind: "component", type: i5.UploadWidgetComponent, selector: "smart-upload-widget", inputs: ["uploadDescriptor", "isMultiple"], outputs: ["uploadFilesEvent"] }] }); }
148
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SmartFileEditorComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: COMPONENT_LIBRARY, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
149
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.11", type: SmartFileEditorComponent, selector: "smart-file-editor", inputs: { widgetInstance: "widgetInstance" }, outputs: { uploadFilesEvent: "uploadFilesEvent" }, providers: [
150
+ {
151
+ provide: NG_VALUE_ACCESSOR,
152
+ useExisting: forwardRef(() => SmartFileEditorComponent),
153
+ multi: true,
154
+ },
155
+ ], viewQueries: [{ propertyName: "toolbar", first: true, predicate: ["toolbar"], descendants: true }], ngImport: i0, template: "@if (widgetInstance && widgetInstance.fileUploaderProperties) {\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\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 if (!widgetInstance.value || fileToChange) {\r\n <smart-upload-widget\r\n class=\"widgetContent {{ widgetInstance.cssClass ?? '' }}\"\r\n [ngClass]=\"getNgClass()\"\r\n [ngStyle]=\"getStyle()\"\r\n [uploadDescriptor]=\"widgetInstance.fileUploaderProperties.uploadDescriptor!\"\r\n [isMultiple]=\"false\"\r\n (uploadFilesEvent)=\"upload($event)\"\r\n />\r\n }\r\n\r\n <div\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=\"uploadedFile\">\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\">{{ widgetInstance.value?.fileName }}</span>\r\n <span class=\"fileSize\">{{ formatSize(widgetInstance.value?.size) }}</span>\r\n </div>\r\n </div>\r\n\r\n <div class=\"fileActions\">\r\n <smart-ui-action-toolbar [id]=\"widgetInstance.toolbarId\" #toolbar></smart-ui-action-toolbar>\r\n\r\n @if (!fileToChange) {\r\n <ui-action-button (actionClick)=\"change(widgetInstance.value)\" [descriptor]=\"changeButton\">\r\n </ui-action-button>\r\n } @else {\r\n <ui-action-button\r\n class=\"removeIcon\"\r\n (actionClick)=\"cancelChange()\"\r\n [descriptor]=\"removeButton\"\r\n ></ui-action-button>\r\n }\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)}.fileEditorComponent ::ng-deep smartfileuploader ::ng-deep .container{border:unset;border-radius:unset}.uploadedFileContainer{display:flex;flex-direction:column}.uploadedFile{display:flex;flex-direction:row;justify-content:flex-start;align-items:center;padding:1rem;gap:1rem}.fileEditorComponent:has(::ng-deep prime-file-uploader) ::ng-deep .uploadedFile,.fileEditorComponent:has(::ng-deep smartfileuploader) ::ng-deep .uploadedFile{border-top: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:1rem}.fileActions ::ng-deep button{border:unset}.fileActions ::ng-deep button:hover{border:unset}.removeIcon ::ng-deep mat-icon{color:var(--warninig-color)}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}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { 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"] }, { kind: "component", type: i4.UiActionButtonComponent, selector: "ui-action-button", inputs: ["disabled", "descriptor", "code", "addedCssClass"], outputs: ["actionClick", "actionDoubleClick"] }, { kind: "component", type: i5.UploadWidgetComponent, selector: "smart-upload-widget", inputs: ["uploadDescriptor", "isMultiple"], outputs: ["uploadFilesEvent"] }] }); }
132
156
  }
133
157
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SmartFileEditorComponent, decorators: [{
134
158
  type: Component,
135
- args: [{ selector: 'smart-file-editor', template: "@if( widgetInstance.fileUploaderProperties){\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\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 value type for this widget.</span>\r\n </div>\r\n } @else if(!widgetInstance.value || fileToChange ) {\r\n <smart-upload-widget\r\n class=\"widgetContent {{ widgetInstance.cssClass ?? '' }}\"\r\n [ngClass]=\"getNgClass()\"\r\n [ngStyle]=\"getStyle()\"\r\n [uploadDescriptor]=\"widgetInstance.fileUploaderProperties.uploadDescriptor!\"\r\n [isMultiple]=\"false\"\r\n (uploadFilesEvent)=\"upload($event)\"\r\n />\r\n } @if (widgetInstance.value && isTypeSupported(widgetInstance.value)) {\r\n <div class=\"uploadedFileContainer\">\r\n <ng-container\r\n *ngTemplateOutlet=\"fileRow; context: { file: widgetInstance.value }\"\r\n ></ng-container>\r\n </div>\r\n }\r\n</div>\r\n}\r\n\r\n<ng-template #fileRow let-file=\"file\" let-i=\"index\">\r\n <div class=\"uploadedFile\">\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 <smart-ui-action-toolbar [id]=\"widgetInstance.toolbarId\" #toolbar> </smart-ui-action-toolbar>\r\n\r\n @if(!fileToChange){\r\n <ui-action-button (actionClick)=\"change(file)\" [descriptor]=\"changeButton\">\r\n </ui-action-button>\r\n } @else {\r\n <ui-action-button\r\n class=\"removeIcon\"\r\n (actionClick)=\"cancelChange()\"\r\n [descriptor]=\"removeButton\"\r\n >\r\n </ui-action-button>\r\n\r\n }\r\n </div>\r\n </div>\r\n</ng-template>\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)}.fileEditorComponent ::ng-deep smartfileuploader ::ng-deep .container{border:unset;border-radius:unset}.uploadedFileContainer{display:flex;flex-direction:column}.uploadedFile{display:flex;flex-direction:row;justify-content:flex-start;align-items:center;padding:1rem;gap:1rem}.fileEditorComponent:has(::ng-deep smartfileuploader) ::ng-deep .uploadedFile{border-top: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:1rem}.fileActions ::ng-deep button{border:unset}.fileActions ::ng-deep button:hover{border:unset}.removeIcon ::ng-deep mat-icon{color:var(--warninig-color)}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}\n"] }]
136
- }], ctorParameters: () => [{ type: i6.ComponentLibrary, decorators: [{
159
+ args: [{ selector: 'smart-file-editor', providers: [
160
+ {
161
+ provide: NG_VALUE_ACCESSOR,
162
+ useExisting: forwardRef(() => SmartFileEditorComponent),
163
+ multi: true,
164
+ },
165
+ ], template: "@if (widgetInstance && widgetInstance.fileUploaderProperties) {\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\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 if (!widgetInstance.value || fileToChange) {\r\n <smart-upload-widget\r\n class=\"widgetContent {{ widgetInstance.cssClass ?? '' }}\"\r\n [ngClass]=\"getNgClass()\"\r\n [ngStyle]=\"getStyle()\"\r\n [uploadDescriptor]=\"widgetInstance.fileUploaderProperties.uploadDescriptor!\"\r\n [isMultiple]=\"false\"\r\n (uploadFilesEvent)=\"upload($event)\"\r\n />\r\n }\r\n\r\n <div\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=\"uploadedFile\">\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\">{{ widgetInstance.value?.fileName }}</span>\r\n <span class=\"fileSize\">{{ formatSize(widgetInstance.value?.size) }}</span>\r\n </div>\r\n </div>\r\n\r\n <div class=\"fileActions\">\r\n <smart-ui-action-toolbar [id]=\"widgetInstance.toolbarId\" #toolbar></smart-ui-action-toolbar>\r\n\r\n @if (!fileToChange) {\r\n <ui-action-button (actionClick)=\"change(widgetInstance.value)\" [descriptor]=\"changeButton\">\r\n </ui-action-button>\r\n } @else {\r\n <ui-action-button\r\n class=\"removeIcon\"\r\n (actionClick)=\"cancelChange()\"\r\n [descriptor]=\"removeButton\"\r\n ></ui-action-button>\r\n }\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)}.fileEditorComponent ::ng-deep smartfileuploader ::ng-deep .container{border:unset;border-radius:unset}.uploadedFileContainer{display:flex;flex-direction:column}.uploadedFile{display:flex;flex-direction:row;justify-content:flex-start;align-items:center;padding:1rem;gap:1rem}.fileEditorComponent:has(::ng-deep prime-file-uploader) ::ng-deep .uploadedFile,.fileEditorComponent:has(::ng-deep smartfileuploader) ::ng-deep .uploadedFile{border-top: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:1rem}.fileActions ::ng-deep button{border:unset}.fileActions ::ng-deep button:hover{border:unset}.removeIcon ::ng-deep mat-icon{color:var(--warninig-color)}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}\n"] }]
166
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i6.ComponentLibrary, decorators: [{
137
167
  type: Inject,
138
168
  args: [COMPONENT_LIBRARY]
139
169
  }, {
@@ -146,4 +176,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
146
176
  }], uploadFilesEvent: [{
147
177
  type: Output
148
178
  }] } });
149
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smart-file-editor.component.js","sourceRoot":"","sources":["../../../../../../../../projects/smart-ng-client/src/lib/smart-form/widgets/components/smart-file-editor/smart-file-editor.component.ts","../../../../../../../../projects/smart-ng-client/src/lib/smart-form/widgets/components/smart-file-editor/smart-file-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Inject,\r\n  Input,\r\n  OnInit,\r\n  Optional,\r\n  Output,\r\n  ViewChild,\r\n  ViewEncapsulation,\r\n} from '@angular/core';\r\nimport { SmartFileUploader } 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 { UiActionModel } from '../../../../view-context/smart-ui-action/ui-action.model';\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\n@Component({\r\n  selector: 'smart-file-editor',\r\n  templateUrl: './smart-file-editor.component.html',\r\n  styleUrl: './smart-file-editor.component.css',\r\n})\r\nexport class SmartFileEditorComponent {\r\n  @ViewChild('toolbar') toolbar!: UiActionToolbarComponent;\r\n\r\n  @Input() widgetInstance!: SmartFileUploader;\r\n\r\n  @Output() uploadFilesEvent = new EventEmitter<{\r\n    files: any[];\r\n    uiAction: UiAction;\r\n    uploadDescriptor?: UiActionUploadDescriptor;\r\n  }>();\r\n  uiActionModels: UiActionModel[] = [];\r\n  fileToChange?: any;\r\n\r\n  constructor(@Inject(COMPONENT_LIBRARY) @Optional() public compLib?: ComponentLibrary) {}\r\n\r\n  ngOnInit() {\r\n    if (!this.widgetInstance.fileUploaderProperties?.undoIcon) {\r\n      this.widgetInstance!.fileUploaderProperties!.undoIcon = {\r\n        identifier: 'undo',\r\n      };\r\n    }\r\n  }\r\n\r\n  upload(event: any): void {\r\n    if (!this.fileToChange) {\r\n      this.uploadFilesEvent.emit({\r\n        files: event.files,\r\n        uiAction: this.widgetInstance.fileUploaderProperties!.uploadAction!,\r\n        uploadDescriptor: event.uploadDescriptor,\r\n      });\r\n    } else {\r\n      var changeAction = this.widgetInstance.fileUploaderProperties?.changeAction;\r\n      if (!changeAction) {\r\n        changeAction = this.widgetInstance.fileUploaderProperties?.uploadAction;\r\n      }\r\n\r\n      this.uploadFilesEvent.emit({\r\n        files: event.files,\r\n        uiAction: changeAction!,\r\n        uploadDescriptor: event.uploadDescriptor,\r\n      });\r\n    }\r\n  }\r\n\r\n  change(file: any): void {\r\n    this.fileToChange = file;\r\n  }\r\n\r\n  cancelChange() {\r\n    this.fileToChange = undefined;\r\n  }\r\n\r\n  getLabelNgClass(): { [className: string]: boolean } {\r\n    if ('labelStyle' in this.widgetInstance) {\r\n      return SmartStyleUtility.getNgClasses(this.widgetInstance.labelStyle);\r\n    }\r\n\r\n    return {};\r\n  }\r\n\r\n  getLabelStyle(): { [key: string]: string | number } {\r\n    if ('labelStyle' in this.widgetInstance) {\r\n      return SmartStyleUtility.getNgStyles(this.widgetInstance.labelStyle);\r\n    }\r\n\r\n    return {};\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    return SmartStyleUtility.getNgStyles(this.widgetInstance.style);\r\n  }\r\n\r\n  isTypeSupported(value: any): boolean {\r\n    if (Array.isArray(value)) return false;\r\n\r\n    if (!value || !('dataUri' in value)) return false;\r\n\r\n    return true;\r\n  }\r\n\r\n  formatSize(bytes: number): string {\r\n    return UploadWidgetUtils.formatSize(bytes);\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 changeButton(): UiActionDescriptor {\r\n    var props = this.widgetInstance.fileUploaderProperties!;\r\n    var changeAction = props.changeAction ?? props.uploadAction!;\r\n\r\n    changeAction.descriptor ??= {\r\n      title: '',\r\n      color: 'primary',\r\n      type: UiActionButtonType.ICON,\r\n      icon: this.compLib === ComponentLibrary.PRIMENG ? 'sync' : 'sync_alt',\r\n      iconPosition: IconPosition.PRE,\r\n    };\r\n\r\n    changeAction.descriptor.title = '';\r\n    var d = changeAction.descriptor;\r\n\r\n    return {\r\n      title: d.title ?? '',\r\n      color: d.color ?? 'primary',\r\n      type: d.type ?? UiActionButtonType.ICON,\r\n      icon: this.compLib === ComponentLibrary.PRIMENG ? 'sync' : 'sync_alt',\r\n      iconPosition: d.iconPosition,\r\n    };\r\n  }\r\n\r\n  get removeButton(): UiActionDescriptor {\r\n    var changeButton = this.changeButton;\r\n    var undoIcon = this.widgetInstance.fileUploaderProperties?.undoIcon;\r\n\r\n    return {\r\n      title: '',\r\n      color: changeButton.color,\r\n      type: changeButton.type,\r\n      iconResource: undoIcon,\r\n      iconPosition: IconPosition.PRE,\r\n    };\r\n  }\r\n\r\n  get errorIcon(): string {\r\n    return this.compLib == ComponentLibrary.PRIMENG ? 'exclamation-circle' : 'error';\r\n  }\r\n  get toolbarComponent(): UiActionToolbarComponent {\r\n    return this.toolbar;\r\n  }\r\n}\r\n","@if( widgetInstance.fileUploaderProperties){\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\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 value type for this widget.</span>\r\n  </div>\r\n  } @else if(!widgetInstance.value || fileToChange ) {\r\n  <smart-upload-widget\r\n    class=\"widgetContent {{ widgetInstance.cssClass ?? '' }}\"\r\n    [ngClass]=\"getNgClass()\"\r\n    [ngStyle]=\"getStyle()\"\r\n    [uploadDescriptor]=\"widgetInstance.fileUploaderProperties.uploadDescriptor!\"\r\n    [isMultiple]=\"false\"\r\n    (uploadFilesEvent)=\"upload($event)\"\r\n  />\r\n  } @if (widgetInstance.value && isTypeSupported(widgetInstance.value)) {\r\n  <div class=\"uploadedFileContainer\">\r\n    <ng-container\r\n      *ngTemplateOutlet=\"fileRow; context: { file: widgetInstance.value }\"\r\n    ></ng-container>\r\n  </div>\r\n  }\r\n</div>\r\n}\r\n\r\n<ng-template #fileRow let-file=\"file\" let-i=\"index\">\r\n  <div class=\"uploadedFile\">\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      <smart-ui-action-toolbar [id]=\"widgetInstance.toolbarId\" #toolbar> </smart-ui-action-toolbar>\r\n\r\n      @if(!fileToChange){\r\n      <ui-action-button (actionClick)=\"change(file)\" [descriptor]=\"changeButton\">\r\n      </ui-action-button>\r\n      } @else {\r\n      <ui-action-button\r\n        class=\"removeIcon\"\r\n        (actionClick)=\"cancelChange()\"\r\n        [descriptor]=\"removeButton\"\r\n      >\r\n      </ui-action-button>\r\n\r\n      }\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n"]}
179
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smart-file-editor.component.js","sourceRoot":"","sources":["../../../../../../../../projects/smart-ng-client/src/lib/smart-form/widgets/components/smart-file-editor/smart-file-editor.component.ts","../../../../../../../../projects/smart-ng-client/src/lib/smart-form/widgets/components/smart-file-editor/smart-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 { SmartFileUploader } 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-file-editor',\r\n  templateUrl: './smart-file-editor.component.html',\r\n  styleUrl: './smart-file-editor.component.css',\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => SmartFileEditorComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class SmartFileEditorComponent implements ControlValueAccessor {\r\n  @ViewChild('toolbar') toolbar!: UiActionToolbarComponent;\r\n\r\n  private _widgetInstance!: SmartFileUploader;\r\n\r\n  @Input()\r\n  get widgetInstance(): SmartFileUploader {\r\n    return this._widgetInstance;\r\n  }\r\n  set widgetInstance(value: SmartFileUploader) {\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  fileToChange?: any;\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: SmartFileUploader) {\r\n    this._widgetInstance =\r\n      typeof structuredClone === 'function'\r\n        ? structuredClone(value)\r\n        : JSON.parse(JSON.stringify(value));\r\n\r\n    if (!this._widgetInstance.fileUploaderProperties?.undoIcon) {\r\n      this._widgetInstance.fileUploaderProperties = {\r\n        ...(this._widgetInstance.fileUploaderProperties ?? {}),\r\n        undoIcon: { identifier: 'undo' },\r\n      };\r\n    }\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    const props = this._widgetInstance.fileUploaderProperties!;\r\n    const uiAction = this.fileToChange\r\n      ? props.changeAction ?? props.uploadAction\r\n      : props.uploadAction;\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    this.fileToChange = undefined;\r\n  }\r\n\r\n  change(file: any): void {\r\n    this.fileToChange = file;\r\n  }\r\n\r\n  cancelChange(): void {\r\n    this.fileToChange = undefined;\r\n  }\r\n\r\n  isTypeSupported(value: any): boolean {\r\n    return !!(value && !Array.isArray(value) && 'dataUri' in value);\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 fileIcon(): string {\r\n    return this.compLib == ComponentLibrary.PRIMENG ? 'file' : 'insert_drive_file';\r\n  }\r\n\r\n  get changeButton(): UiActionDescriptor {\r\n    var props = this._widgetInstance.fileUploaderProperties!;\r\n    var baseAction = props.changeAction ?? props.uploadAction!;\r\n\r\n    var changeDescriptor = {\r\n      ...(baseAction.descriptor ?? {}),\r\n      title: '',\r\n      color: 'primary',\r\n      type: UiActionButtonType.ICON,\r\n      icon: this.compLib === ComponentLibrary.PRIMENG ? 'sync' : 'sync_alt',\r\n      iconPosition: IconPosition.PRE,\r\n    };\r\n\r\n    return changeDescriptor;\r\n  }\r\n\r\n  get removeButton(): UiActionDescriptor {\r\n    var changeButton = this.changeButton;\r\n\r\n    return {\r\n      title: '',\r\n      color: changeButton.color,\r\n      type: changeButton.type,\r\n      iconResource: this._widgetInstance.fileUploaderProperties!.undoIcon,\r\n      iconPosition: IconPosition.PRE,\r\n    };\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.fileUploaderProperties) {\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\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 if (!widgetInstance.value || fileToChange) {\r\n  <smart-upload-widget\r\n    class=\"widgetContent {{ widgetInstance.cssClass ?? '' }}\"\r\n    [ngClass]=\"getNgClass()\"\r\n    [ngStyle]=\"getStyle()\"\r\n    [uploadDescriptor]=\"widgetInstance.fileUploaderProperties.uploadDescriptor!\"\r\n    [isMultiple]=\"false\"\r\n    (uploadFilesEvent)=\"upload($event)\"\r\n  />\r\n  }\r\n\r\n  <div\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=\"uploadedFile\">\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\">{{ widgetInstance.value?.fileName }}</span>\r\n          <span class=\"fileSize\">{{ formatSize(widgetInstance.value?.size) }}</span>\r\n        </div>\r\n      </div>\r\n\r\n      <div class=\"fileActions\">\r\n        <smart-ui-action-toolbar [id]=\"widgetInstance.toolbarId\" #toolbar></smart-ui-action-toolbar>\r\n\r\n        @if (!fileToChange) {\r\n        <ui-action-button (actionClick)=\"change(widgetInstance.value)\" [descriptor]=\"changeButton\">\r\n        </ui-action-button>\r\n        } @else {\r\n        <ui-action-button\r\n          class=\"removeIcon\"\r\n          (actionClick)=\"cancelChange()\"\r\n          [descriptor]=\"removeButton\"\r\n        ></ui-action-button>\r\n        }\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n}\r\n"]}