@smartbit4all/ng-client 3.3.178 → 3.3.180
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/esm2020/lib/smart-form/smartform.component.mjs +41 -3
- package/esm2020/lib/smart-form/widgets/smartformwidget/smartformwidget.component.mjs +6 -3
- package/fesm2015/smartbit4all-ng-client.mjs +48 -3
- package/fesm2015/smartbit4all-ng-client.mjs.map +1 -1
- package/fesm2020/smartbit4all-ng-client.mjs +44 -3
- package/fesm2020/smartbit4all-ng-client.mjs.map +1 -1
- package/lib/smart-form/smartform.component.d.ts +4 -0
- package/lib/smart-form/widgets/smartformwidget/smartformwidget.component.d.ts +3 -2
- package/package.json +1 -1
- package/smartbit4all-ng-client-3.3.180.tgz +0 -0
- package/smartbit4all-ng-client-3.3.178.tgz +0 -0
|
@@ -30,6 +30,20 @@ export class SmartformComponent {
|
|
|
30
30
|
}
|
|
31
31
|
this.onBlurSubject = new SmartSubject(this._destroy$);
|
|
32
32
|
}
|
|
33
|
+
// ngAfterViewInit(): void {
|
|
34
|
+
// if (this.smartWidgetsQL) {
|
|
35
|
+
// this.handleQueryList(this.smartWidgetsQL, (widget) => {
|
|
36
|
+
// // ???
|
|
37
|
+
// });
|
|
38
|
+
// }
|
|
39
|
+
// }
|
|
40
|
+
// // TODO this is a duplicate from SmartFormApiClient -> move it to a utility
|
|
41
|
+
// protected handleQueryList<T>(ql: QueryList<T>, handler: (el: T) => void) {
|
|
42
|
+
// ql.forEach((el) => handler(el));
|
|
43
|
+
// ql.changes
|
|
44
|
+
// .pipe(takeUntil(this._destroy$))
|
|
45
|
+
// .subscribe((list) => (list as QueryList<T>).forEach((el) => handler(el)));
|
|
46
|
+
// }
|
|
33
47
|
refresh() {
|
|
34
48
|
this.service.setValuesFromModel();
|
|
35
49
|
}
|
|
@@ -50,9 +64,33 @@ export class SmartformComponent {
|
|
|
50
64
|
this.form = this.service.toFormGroup();
|
|
51
65
|
if (this.smartForm.translateService) {
|
|
52
66
|
this.smartForm.translateService.onLangChange.pipe(takeUntil(this._destroy$)).subscribe(() => {
|
|
53
|
-
this.
|
|
67
|
+
this.translateWidgets(this.smartForm.widgets);
|
|
54
68
|
});
|
|
55
|
-
this.
|
|
69
|
+
this.translateWidgets(this.smartForm.widgets);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
async translateWidgets(widgets) {
|
|
73
|
+
await this.service.translateWidgets(this.smartForm.widgets);
|
|
74
|
+
this.markAllWidgetsForChangeDetection();
|
|
75
|
+
}
|
|
76
|
+
markAllWidgetsForChangeDetection() {
|
|
77
|
+
this.getAllSmartWidgets().forEach((widget) => widget.changeDetector.markForCheck());
|
|
78
|
+
}
|
|
79
|
+
getAllSmartWidgets() {
|
|
80
|
+
const result = [];
|
|
81
|
+
this.smartWidgetsQL?.forEach((widget) => {
|
|
82
|
+
result.push(...this.getChildWidgets(widget));
|
|
83
|
+
});
|
|
84
|
+
return result;
|
|
85
|
+
}
|
|
86
|
+
getChildWidgets(widget) {
|
|
87
|
+
if (widget.widgetInstance.type == SmartFormWidgetType.CONTAINER) {
|
|
88
|
+
const result = [];
|
|
89
|
+
widget.childrenWidgetsQL?.forEach((child) => result.push(...this.getChildWidgets(child)));
|
|
90
|
+
return result;
|
|
91
|
+
}
|
|
92
|
+
else {
|
|
93
|
+
return [widget];
|
|
56
94
|
}
|
|
57
95
|
}
|
|
58
96
|
ngOnDestroy() {
|
|
@@ -137,4 +175,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
137
175
|
type: ViewChildren,
|
|
138
176
|
args: [SmartformwidgetComponent]
|
|
139
177
|
}] } });
|
|
140
|
-
//# 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  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 { FormGroup } 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\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!: FormGroup;\r\n\r\n  direction = SmartFormWidgetDirection;\r\n\r\n  @ViewChildren(SmartformwidgetComponent)\r\n  smartWidgetsQL?: QueryList<SmartformwidgetComponent>;\r\n\r\n  constructor(private service: SmartFormService) {}\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  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);\r\n    this.service.applyConstraints(this.originalWidgets);\r\n    this.smartForm.widgets = this.service.filterWidgetsByVisibility(this.originalWidgets);\r\n    this.form = this.service.toFormGroup();\r\n\r\n    if (this.smartForm.translateService) {\r\n      this.smartForm.translateService.onLangChange.pipe(takeUntil(this._destroy$)).subscribe(() => {\r\n        this.service.translateWidgets(this.smartForm!.widgets);\r\n      });\r\n      this.service.translateWidgets(this.smartForm.widgets);\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(): FormGroup {\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        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      ></smartformwidget>\r\n    </div>\r\n  </div>\r\n</form>\r\n"]}
|
|
178
|
+
//# 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  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 { FormGroup } 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\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!: FormGroup;\r\n\r\n  direction = SmartFormWidgetDirection;\r\n\r\n  @ViewChildren(SmartformwidgetComponent)\r\n  smartWidgetsQL?: QueryList<SmartformwidgetComponent>;\r\n\r\n  constructor(private service: SmartFormService) {}\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);\r\n    this.service.applyConstraints(this.originalWidgets);\r\n    this.smartForm.widgets = this.service.filterWidgetsByVisibility(this.originalWidgets);\r\n    this.form = this.service.toFormGroup();\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(): FormGroup {\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        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      ></smartformwidget>\r\n    </div>\r\n  </div>\r\n</form>\r\n"]}
|