@bizdoc/core 1.16.22 → 1.16.25

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 (43) hide show
  1. package/esm2020/lib/admin/configuration-designer/cube-axes-filter.component.mjs +2 -2
  2. package/esm2020/lib/admin/configuration-designer/declarations.mjs +2 -3
  3. package/esm2020/lib/admin/configuration-designer/designer-element.component.mjs +43 -42
  4. package/esm2020/lib/admin/configuration-designer/designer-privileges.component.mjs +6 -8
  5. package/esm2020/lib/admin/configuration-designer/designer.base.mjs +3 -1
  6. package/esm2020/lib/admin/configuration-designer/designer.component.mjs +74 -47
  7. package/esm2020/lib/admin/configuration-designer/elements/action.component.mjs +6 -5
  8. package/esm2020/lib/admin/configuration-designer/elements/cube.component.mjs +29 -14
  9. package/esm2020/lib/admin/configuration-designer/elements/folder.component.mjs +22 -21
  10. package/esm2020/lib/admin/configuration-designer/elements/form.component.mjs +80 -25
  11. package/esm2020/lib/admin/configuration-designer/elements/guide.component.mjs +13 -7
  12. package/esm2020/lib/admin/configuration-designer/elements/policy.component.mjs +5 -4
  13. package/esm2020/lib/admin/configuration-designer/elements/report.component.mjs +6 -7
  14. package/esm2020/lib/admin/configuration-designer/elements/role.component.mjs +3 -2
  15. package/esm2020/lib/admin/configuration-designer/elements/rule.component.mjs +5 -4
  16. package/esm2020/lib/admin/configuration-designer/elements/state.component.mjs +3 -2
  17. package/esm2020/lib/admin/configuration-designer/elements/type.component.mjs +3 -3
  18. package/esm2020/lib/admin/configuration-designer/elements/utility.component.mjs +5 -8
  19. package/esm2020/lib/admin/configuration-designer/elements/view.component.mjs +5 -4
  20. package/esm2020/lib/admin/configuration-designer/elements/widget.component.mjs +4 -3
  21. package/esm2020/lib/admin/diff/configuration-diff.component.mjs +2 -2
  22. package/esm2020/lib/admin/system.service.mjs +1 -1
  23. package/esm2020/lib/core/translations.mjs +10 -2
  24. package/esm2020/lib/cube/cube-menu.component.mjs +2 -2
  25. package/esm2020/lib/home/home-base.component.mjs +2 -2
  26. package/fesm2015/bizdoc-core.mjs +457 -348
  27. package/fesm2015/bizdoc-core.mjs.map +1 -1
  28. package/fesm2020/bizdoc-core.mjs +454 -346
  29. package/fesm2020/bizdoc-core.mjs.map +1 -1
  30. package/lib/admin/configuration-designer/declarations.d.ts +1 -2
  31. package/lib/admin/configuration-designer/designer-element.component.d.ts +7 -11
  32. package/lib/admin/configuration-designer/designer.base.d.ts +1 -0
  33. package/lib/admin/configuration-designer/designer.component.d.ts +10 -6
  34. package/lib/admin/configuration-designer/elements/action.component.d.ts +1 -3
  35. package/lib/admin/configuration-designer/elements/cube.component.d.ts +3 -6
  36. package/lib/admin/configuration-designer/elements/folder.component.d.ts +11 -3
  37. package/lib/admin/configuration-designer/elements/form.component.d.ts +21 -6
  38. package/lib/admin/configuration-designer/elements/policy.component.d.ts +1 -2
  39. package/lib/admin/configuration-designer/elements/report.component.d.ts +0 -1
  40. package/lib/admin/configuration-designer/elements/utility.component.d.ts +1 -3
  41. package/lib/admin/system.service.d.ts +8 -6
  42. package/lib/core/translations.d.ts +8 -0
  43. package/package.json +1 -1
@@ -34,7 +34,7 @@ export class DesignerCubeFilterComponent {
34
34
  ngOnChanges(_changes) {
35
35
  Object.keys(this.form.controls).forEach(k => this.form.removeControl(k, { emitEvent: false }));
36
36
  this.cube.axes.forEach(a => {
37
- if (a.hidden || a.selectionMode === 'None')
37
+ if (a.selectionMode === 'None')
38
38
  return;
39
39
  let { descendentOf } = a;
40
40
  if (descendentOf) {
@@ -91,4 +91,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImpor
91
91
  }], form: [{
92
92
  type: Input
93
93
  }] } });
94
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cube-axes-filter.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/admin/configuration-designer/cube-axes-filter.component.ts","../../../../../../libraries/core/src/lib/admin/configuration-designer/cube-axes-filter.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAuC,MAAM,eAAe,CAAC;AAEtF,OAAO,EAAE,OAAO,EAAc,MAAM,MAAM,CAAC;AAC3C,OAAO,EAAE,YAAY,EAAE,SAAS,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACtE,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAE3D,OAAO,EAAE,kBAAkB,EAAe,MAAM,yBAAyB,CAAC;;;;;;;;;;;;;;;;AAQ1E,sBAAsB;AACtB,MAAM,OAAO,2BAA2B;IA6CtC,kBAAkB;IAClB,YAA6B,QAAqB,EACxC,IAAiB,EACR,GAAgB;QAFN,aAAQ,GAAR,QAAQ,CAAa;QACxC,SAAI,GAAJ,IAAI,CAAa;QACR,QAAG,GAAH,GAAG,CAAa;QA/C1B,YAAO,GAAG,kBAAkB,CAAC;QAG7B,YAAO,GAA2D,EAAE,CAAC;QAC7D,gBAAW,GAAG,EAAkC,CAAC;QACjD,eAAU,GAAG,EAAkC,CAAC;QAChD,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;IA0ChD,CAAC;IAzCD,WAAW,CAAC,QAAuB;QACjC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC,CAAA;QAC9F,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;YACzB,IAAI,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,aAAa,KAAK,MAAM;gBAAE,OAAO;YACnD,IAAI,EAAE,YAAY,EAAE,GAAG,CAAC,CAAC;YACzB,IAAI,YAAY,EAAE;gBAChB,IAAI,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;gBAC7C,OAAO,YAAY,EAAE;oBACnB,IAAI,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,YAAY,CAAC,CAAC;oBAC7D,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oBAC1B,IAAI,CAAC,CAAC,aAAa,KAAK,SAAS,EAAE;wBACjC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC;4BAAE,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;;4BAC1E,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;qBAClD;oBACD,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC;iBAClC;aACF;YACD,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,aAAa,KAAK,SAAS,EAAE;gBAC1D,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC;aAC3F;YACD,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YACpC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;YACzD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,YAAY,CAAC,GAAG,CAAC,EAChE,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;gBACtC,IAAI,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC;oBAC1B,KAAK,IAAI,IAAI,IAAI,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE;wBACzC,IAAI,IAAI,GAAG,EAAE,CAAC;wBACd,KAAK,IAAI,IAAI,IAAI,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;4BACpC,IAAI,CAAC,IAAI,CAAC,GAAI,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAiB,CAAC,KAAK,CAAC;wBAC1D,OAAO,CAAC,IAAI,CAAC,CAAC;wBACd,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC;4BACnE,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC;qBACzB;YACL,CAAC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,IAAI,CAAC,sBAAsB,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;IACzD,CAAC;IAMD,OAAO,CAAC,QAAQ;QACd,OAAO,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC;IAC1C,CAAC;IACD,MAAM,CAAC,IAAY,EAAE,GAAiC;QACpD,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAC1D,CAAC;IACD,WAAW;QACT,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;;wHA3DU,2BAA2B;4GAA3B,2BAA2B,gICfxC,kyDA0BA;2FDXa,2BAA2B;kBANvC,SAAS;+BACE,6BAA6B;sJAO9B,IAAI;sBAAZ,KAAK;gBACG,IAAI;sBAAZ,KAAK","sourcesContent":["import { Component, Input, OnDestroy, OnChanges, SimpleChanges } from '@angular/core';\r\nimport { FormGroup, FormBuilder, FormControl } from '@angular/forms';\r\nimport { Subject, Observable } from 'rxjs';\r\nimport { debounceTime, takeUntil, filter, map } from 'rxjs/operators';\r\nimport { cleanup, mapToArray } from '../../core/functions';\r\nimport { MatAutocompleteSelectedEvent } from '@angular/material/autocomplete';\r\nimport { AXIS_VALUE_PATTERN, CubeService } from '../../cube/cube.service';\r\nimport { DesignerRef, ElementModel } from './declarations';\r\n\r\n@Component({\r\n  selector: 'bizdoc-designer-cube-filter',\r\n  templateUrl: './cube-axes-filter.component.html',\r\n  styleUrls: ['./cube-axes-filter.component.scss']\r\n})\r\n/** filter component*/\r\nexport class DesignerCubeFilterComponent implements OnChanges, OnDestroy {\r\n  readonly pattern = AXIS_VALUE_PATTERN;\r\n  @Input() cube!: ElementModel;\r\n  @Input() form!: FormGroup;\r\n  readonly sources: { [axis: string]: Observable<{ [key: string]: any }> } = {};\r\n  private readonly _decendents = {} as { [name: string]: string[] };\r\n  private readonly _ancestors = {} as { [name: string]: string[] };\r\n  private readonly _destroy = new Subject<void>();\r\n  ngOnChanges(_changes: SimpleChanges): void {\r\n    Object.keys(this.form.controls).forEach(k => this.form.removeControl(k, { emitEvent: false }))\r\n    this.cube.axes.forEach(a => {\r\n      if (a.hidden || a.selectionMode === 'None') return;\r\n      let { descendentOf } = a;\r\n      if (descendentOf) {\r\n        let ancestors = this._ancestors[a.name] = [];\r\n        while (descendentOf) {\r\n          let axis = this.cube.axes.find(a => a.name === descendentOf);\r\n          ancestors.push(axis.name);\r\n          if (a.selectionMode !== 'Pattern') {\r\n            if (!this._decendents[descendentOf]) this._decendents[descendentOf] = [a.name];\r\n            else this._decendents[descendentOf].push(a.name);\r\n          }\r\n          descendentOf = axis.descendentOf;\r\n        }\r\n      }\r\n      if (!this.sources[a.name] && a.selectionMode !== 'Pattern') {\r\n        this.sources[a.name] = this._service.values(this.cube.name, a.name).pipe(map(mapToArray));\r\n      }\r\n      const ctrl = this._fb.control(this);\r\n      this.form.addControl(a.name, ctrl, { emitEvent: false });\r\n      ctrl.valueChanges.pipe(filter(() => ctrl.valid), debounceTime(200),\r\n        takeUntil(this._destroy)).subscribe(v => {\r\n          if (this._decendents[a.name])\r\n            for (let axis of this._decendents[a.name]) {\r\n              let deps = {};\r\n              for (let name of this._ancestors[axis])\r\n                deps[name] = (this.form.get(name) as FormControl).value;\r\n              cleanup(deps);\r\n              this.sources[axis] = this._service.values(this.cube.name, axis, deps).\r\n                pipe(map(mapToArray));\r\n            }\r\n        });\r\n    });\r\n    this.form.updateValueAndValidity({ emitEvent: false });\r\n  }\r\n  /** filter ctor */\r\n  constructor(private readonly _service: CubeService,\r\n    private _ref: DesignerRef,\r\n    private readonly _fb: FormBuilder) {\r\n  }\r\n  display(keyValue) {\r\n    return keyValue ? keyValue.value : null;\r\n  }\r\n  change(axis: string, evt: MatAutocompleteSelectedEvent) {\r\n    this.form.controls[axis].setValue(evt.option.value.key);\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._destroy.next();\r\n    this._destroy.complete();\r\n  }\r\n}\r\n","<h2 class=\"mat-title\">{{'Filters'|translate}}</h2>\r\n<div [formGroup]=\"form\" fxLayout=\"column\">\r\n  <mat-form-field *ngFor=\"let a of cube.axes\" [ngSwitch]=\"a.selectionMode\" [attr.data-help]=\"'axis-'+a.name\">\r\n    <ng-container *ngSwitchCase=\"'Pattern'\">\r\n      <input matInput autocomplete=\"off\"\r\n             [pattern]=\"pattern\" [autofocus]\r\n             [formControlName]=\"a.name\" [placeholder]=\"a.title||a.name\" />\r\n      <mat-error *ngIf=\"form.controls[a.name].invalid\">{{'SimplePatternErr' |translate}}</mat-error>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'Search'\">\r\n      <input matInput autocomplete=\"off\" type=\"search\"\r\n             [matAutocomplete]=\"segment\" #inp\r\n             [placeholder]=\"a.title||a.name\" />\r\n      <mat-autocomplete #segment [displayWith]=\"display\"\r\n                        (optionSelected)=\"change(a.name, $event)\">\r\n        <mat-option *ngFor=\"let r of sources[a.name] | async | filter : 'value' : inp.value | slice:0:50\" [value]=\"r\">{{r.value}}</mat-option>\r\n      </mat-autocomplete>\r\n      <button mat-icon-button *ngIf=\"inp.value\" matSuffix aria-label=\"\" (click)=\"inp.value = ''; form.controls[a.name].setValue(null)\"><mat-icon>close</mat-icon></button>\r\n      <mat-error *ngIf=\"form.controls[a.name].invalid\">{{'SimplePatternErr' |translate}}</mat-error>\r\n    </ng-container>\r\n    <mat-select [formControlName]=\"a.name\" [placeholder]=\"a.title||a.name\" [multiple]=\"a.selectionMode === 'Multiple'\" *ngSwitchDefault>\r\n      <mat-option *ngIf=\"a.selectionMode !== 'Multiple'\">{{'All' | translate}}</mat-option>\r\n      <mat-option *ngFor=\"let r of sources[a.name] | async\" [value]=\"r.key\">{{r.value}}</mat-option>\r\n    </mat-select>\r\n  </mat-form-field>\r\n</div>\r\n"]}
94
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cube-axes-filter.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/admin/configuration-designer/cube-axes-filter.component.ts","../../../../../../libraries/core/src/lib/admin/configuration-designer/cube-axes-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnDestroy, OnChanges, SimpleChanges } from '@angular/core';\r\nimport { FormGroup, FormBuilder, FormControl } from '@angular/forms';\r\nimport { Subject, Observable } from 'rxjs';\r\nimport { debounceTime, takeUntil, filter, map } from 'rxjs/operators';\r\nimport { cleanup, mapToArray } from '../../core/functions';\r\nimport { MatAutocompleteSelectedEvent } from '@angular/material/autocomplete';\r\nimport { AXIS_VALUE_PATTERN, CubeService } from '../../cube/cube.service';\r\nimport { DesignerRef, ElementModel } from './declarations';\r\n\r\n@Component({\r\n  selector: 'bizdoc-designer-cube-filter',\r\n  templateUrl: './cube-axes-filter.component.html',\r\n  styleUrls: ['./cube-axes-filter.component.scss']\r\n})\r\n/** filter component*/\r\nexport class DesignerCubeFilterComponent implements OnChanges, OnDestroy {\r\n  readonly pattern = AXIS_VALUE_PATTERN;\r\n  @Input() cube!: ElementModel;\r\n  @Input() form!: FormGroup;\r\n  readonly sources: { [axis: string]: Observable<{ [key: string]: any }> } = {};\r\n  private readonly _decendents = {} as { [name: string]: string[] };\r\n  private readonly _ancestors = {} as { [name: string]: string[] };\r\n  private readonly _destroy = new Subject<void>();\r\n  ngOnChanges(_changes: SimpleChanges): void {\r\n    Object.keys(this.form.controls).forEach(k => this.form.removeControl(k, { emitEvent: false }))\r\n    this.cube.axes.forEach(a => {\r\n      if (a.selectionMode === 'None') return;\r\n      let { descendentOf } = a;\r\n      if (descendentOf) {\r\n        let ancestors = this._ancestors[a.name] = [];\r\n        while (descendentOf) {\r\n          let axis = this.cube.axes.find(a => a.name === descendentOf);\r\n          ancestors.push(axis.name);\r\n          if (a.selectionMode !== 'Pattern') {\r\n            if (!this._decendents[descendentOf]) this._decendents[descendentOf] = [a.name];\r\n            else this._decendents[descendentOf].push(a.name);\r\n          }\r\n          descendentOf = axis.descendentOf;\r\n        }\r\n      }\r\n      if (!this.sources[a.name] && a.selectionMode !== 'Pattern') {\r\n        this.sources[a.name] = this._service.values(this.cube.name, a.name).pipe(map(mapToArray));\r\n      }\r\n      const ctrl = this._fb.control(this);\r\n      this.form.addControl(a.name, ctrl, { emitEvent: false });\r\n      ctrl.valueChanges.pipe(filter(() => ctrl.valid), debounceTime(200),\r\n        takeUntil(this._destroy)).subscribe(v => {\r\n          if (this._decendents[a.name])\r\n            for (let axis of this._decendents[a.name]) {\r\n              let deps = {};\r\n              for (let name of this._ancestors[axis])\r\n                deps[name] = (this.form.get(name) as FormControl).value;\r\n              cleanup(deps);\r\n              this.sources[axis] = this._service.values(this.cube.name, axis, deps).\r\n                pipe(map(mapToArray));\r\n            }\r\n        });\r\n    });\r\n    this.form.updateValueAndValidity({ emitEvent: false });\r\n  }\r\n  /** filter ctor */\r\n  constructor(private readonly _service: CubeService,\r\n    private _ref: DesignerRef,\r\n    private readonly _fb: FormBuilder) {\r\n  }\r\n  display(keyValue) {\r\n    return keyValue ? keyValue.value : null;\r\n  }\r\n  change(axis: string, evt: MatAutocompleteSelectedEvent) {\r\n    this.form.controls[axis].setValue(evt.option.value.key);\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._destroy.next();\r\n    this._destroy.complete();\r\n  }\r\n}\r\n","<h2 class=\"mat-title\">{{'Filters'|translate}}</h2>\r\n<div [formGroup]=\"form\" fxLayout=\"column\">\r\n  <mat-form-field *ngFor=\"let a of cube.axes\" [ngSwitch]=\"a.selectionMode\" [attr.data-help]=\"'axis-'+a.name\">\r\n    <ng-container *ngSwitchCase=\"'Pattern'\">\r\n      <input matInput autocomplete=\"off\"\r\n             [pattern]=\"pattern\" [autofocus]\r\n             [formControlName]=\"a.name\" [placeholder]=\"a.title||a.name\" />\r\n      <mat-error *ngIf=\"form.controls[a.name].invalid\">{{'SimplePatternErr' |translate}}</mat-error>\r\n    </ng-container>\r\n    <ng-container *ngSwitchCase=\"'Search'\">\r\n      <input matInput autocomplete=\"off\" type=\"search\"\r\n             [matAutocomplete]=\"segment\" #inp\r\n             [placeholder]=\"a.title||a.name\" />\r\n      <mat-autocomplete #segment [displayWith]=\"display\"\r\n                        (optionSelected)=\"change(a.name, $event)\">\r\n        <mat-option *ngFor=\"let r of sources[a.name] | async | filter : 'value' : inp.value | slice:0:50\" [value]=\"r\">{{r.value}}</mat-option>\r\n      </mat-autocomplete>\r\n      <button mat-icon-button *ngIf=\"inp.value\" matSuffix aria-label=\"\" (click)=\"inp.value = ''; form.controls[a.name].setValue(null)\"><mat-icon>close</mat-icon></button>\r\n      <mat-error *ngIf=\"form.controls[a.name].invalid\">{{'SimplePatternErr' |translate}}</mat-error>\r\n    </ng-container>\r\n    <mat-select [formControlName]=\"a.name\" [placeholder]=\"a.title||a.name\" [multiple]=\"a.selectionMode === 'Multiple'\" *ngSwitchDefault>\r\n      <mat-option *ngIf=\"a.selectionMode !== 'Multiple'\">{{'All' | translate}}</mat-option>\r\n      <mat-option *ngFor=\"let r of sources[a.name] | async\" [value]=\"r.key\">{{r.value}}</mat-option>\r\n    </mat-select>\r\n  </mat-form-field>\r\n</div>\r\n"]}
@@ -95,12 +95,11 @@ export class DesignerRef {
95
95
  get unlock() { return this._unlock$.asObservable(); }
96
96
  get state() { return this._state$.value; }
97
97
  set state(val) { this._state$.next(val); }
98
- create(element, template) {
98
+ create(element) {
99
99
  const ref = new DesignerRef(this._designer, element, 'widget');
100
100
  const injector = Injector.create([{
101
101
  provide: DesignerRef, useValue: ref
102
102
  }], this._element.injector);
103
- element.template = template;
104
103
  element.injector = injector;
105
104
  return element;
106
105
  }
@@ -126,4 +125,4 @@ export function programName(name) {
126
125
  replace(NAME_CHAR, (c, i) => (i > 0 && name.charAt(i - 1) !== '-' ? '-' : '') + c.toLowerCase()).
127
126
  replace(NON_NAME_CHAR, '_');
128
127
  }
129
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"declarations.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/admin/configuration-designer/declarations.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAGzC,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAEhD,OAAO,EAAE,eAAe,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAChD,MAAM,CAAC,MAAM,UAAU,GAAG;IACxB,OAAO,EAAE;;;;;;;;;;;;;;;;;;;;;;OAsBJ;IACL,KAAK,EAAE;;;;;;;;OAQF;IACL,KAAK,EAAE;;;;;;;;;;;;;;;OAeF;IACL,UAAU,EAAE;;;;;;;;;;;;;;;;;OAiBP;IACL,kBAAkB,EAAE;;;;;;;;;;;OAWf;CACN,CAAC;AACF,MAAM;AACN,MAAM,OAAO,WAAW;IAGtB,YAAoB,SAAwB,EAClC,QAAsB,EACvB,IAAgB;QAFL,cAAS,GAAT,SAAS,CAAe;QAClC,aAAQ,GAAR,QAAQ,CAAc;QACvB,SAAI,GAAJ,IAAI,CAAY;QAJzB,aAAQ,GAAG,IAAI,OAAO,EAAW,CAAC;QAClC,YAAO,GAAG,IAAI,eAAe,CAAM,IAAI,CAAC,CAAC;IAGZ,CAAC;IAC9B,IAAI,QAAQ,KAAmB,OAAO,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;IACvD,IAAI,KAAK,KAAqB,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;IACrD,IAAI,MAAM,KAAK,OAAO,IAAI,CAAC,QAAQ,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC;IACrD,IAAI,KAAK,KAAK,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC;IAC1C,IAAI,KAAK,CAAC,GAAG,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAC1C,MAAM,CAAC,OAAoB,EAAE,QAAiB;QAC5C,MAAM,GAAG,GAAG,IAAI,WAAW,CAAC,IAAI,CAAC,SAAS,EAAE,OAAuB,EAAE,QAAQ,CAAC,CAAC;QAC/E,MAAM,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC;gBAChC,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,GAAG;aACpC,CAAC,EAAG,IAAI,CAAC,QAAyB,CAAC,QAAQ,CAAC,CAAC;QAC7C,OAAwB,CAAC,QAAQ,GAAG,QAAQ,CAAC;QAC7C,OAAwB,CAAC,QAAQ,GAAG,QAAQ,CAAC;QAC9C,OAAO,OAAO,CAAC;IACjB,CAAC;CACF;AASD,MAAM,UAAU,KAAK,CAAC,OAAqB;IACzC,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC;AAC7C,CAAC;AACD,MAAM,UAAU,OAAO,CAAC,GAAsB;IAC5C,IAAI,CAAC,GAAG;QAAE,OAAO,EAAE,CAAC;IACpB,IAAI,QAAQ,CAAC,GAAG,CAAC;QAAE,OAAO,CAAC,GAAG,CAAC,CAAC;IAChC,OAAO,GAAG,CAAC;AACb,CAAC;AAED,MAAM,SAAS,GAAG,SAAS,EACzB,aAAa,GAAG,SAAS,CAAC;AAC5B;;;GAGG;AACH,MAAM,UAAU,WAAW,CAAC,IAAY;IACtC,OAAO,IAAI;QACT,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC;QACjB,OAAO,CAAC,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,WAAW,EAAE,CAAC;QAChG,OAAO,CAAC,aAAa,EAAE,GAAG,CAAC,CAAC;AAChC,CAAC","sourcesContent":["import { Injector } from \"@angular/core\";\r\nimport { FormGroup } from \"@angular/forms\";\r\nimport { ScopeType } from \"../../core/configuration\";\r\nimport { isString } from \"../../core/functions\";\r\nimport { AxesMap, ChartType, CubeFilter, FieldInfo, FolderColumn, GuideStep, PositionPolicy, ViewType } from \"../../core/models\";\r\nimport { BehaviorSubject, Subject } from \"rxjs\";\r\nexport const FAMILY_SVG = {\r\n  \"Azure\": `<svg width=\"34\" height=\"34\" viewBox=\"0 0 96 96\" xmlns=\"http://www.w3.org/2000/svg\">\r\n    <defs>\r\n        <linearGradient id=\"e399c19f-b68f-429d-b176-18c2117ff73c\" x1=\"-1032.172\" x2=\"-1059.213\" y1=\"145.312\" y2=\"65.426\" gradientTransform=\"matrix(1 0 0 -1 1075 158)\" gradientUnits=\"userSpaceOnUse\">\r\n            <stop offset=\"0\" stop-color=\"#114a8b\"/>\r\n            <stop offset=\"1\" stop-color=\"#0669bc\"/>\r\n        </linearGradient>\r\n        <linearGradient id=\"ac2a6fc2-ca48-4327-9a3c-d4dcc3256e15\" x1=\"-1023.725\" x2=\"-1029.98\" y1=\"108.083\" y2=\"105.968\" gradientTransform=\"matrix(1 0 0 -1 1075 158)\" gradientUnits=\"userSpaceOnUse\">\r\n            <stop offset=\"0\" stop-opacity=\".3\"/>\r\n            <stop offset=\".071\" stop-opacity=\".2\"/>\r\n            <stop offset=\".321\" stop-opacity=\".1\"/>\r\n            <stop offset=\".623\" stop-opacity=\".05\"/>\r\n            <stop offset=\"1\" stop-opacity=\"0\"/>\r\n        </linearGradient>\r\n        <linearGradient id=\"a7fee970-a784-4bb1-af8d-63d18e5f7db9\" x1=\"-1027.165\" x2=\"-997.482\" y1=\"147.642\" y2=\"68.561\" gradientTransform=\"matrix(1 0 0 -1 1075 158)\" gradientUnits=\"userSpaceOnUse\">\r\n            <stop offset=\"0\" stop-color=\"#3ccbf4\"/>\r\n            <stop offset=\"1\" stop-color=\"#2892df\"/>\r\n        </linearGradient>\r\n    </defs>\r\n    <path fill=\"url(#e399c19f-b68f-429d-b176-18c2117ff73c)\" d=\"M33.338 6.544h26.038l-27.03 80.087a4.152 4.152 0 0 1-3.933 2.824H8.149a4.145 4.145 0 0 1-3.928-5.47L29.404 9.368a4.152 4.152 0 0 1 3.934-2.825z\"/>\r\n    <path fill=\"#0078d4\" d=\"M71.175 60.261h-41.29a1.911 1.911 0 0 0-1.305 3.309l26.532 24.764a4.171 4.171 0 0 0 2.846 1.121h23.38z\"/>\r\n    <path fill=\"url(#ac2a6fc2-ca48-4327-9a3c-d4dcc3256e15)\" d=\"M33.338 6.544a4.118 4.118 0 0 0-3.943 2.879L4.252 83.917a4.14 4.14 0 0 0 3.908 5.538h20.787a4.443 4.443 0 0 0 3.41-2.9l5.014-14.777 17.91 16.705a4.237 4.237 0 0 0 2.666.972H81.24L71.024 60.261l-29.781.007L59.47 6.544z\"/>\r\n    <path fill=\"url(#a7fee970-a784-4bb1-af8d-63d18e5f7db9)\" d=\"M66.595 9.364a4.145 4.145 0 0 0-3.928-2.82H33.648a4.146 4.146 0 0 1 3.928 2.82l25.184 74.62a4.146 4.146 0 0 1-3.928 5.472h29.02a4.146 4.146 0 0 0 3.927-5.472z\"/>\r\n</svg>`,\r\n  'SAP': `<svg height=\"45\" viewBox=\"0 0 192.756 192.756\" xmlns=\"http://www.w3.org/2000/svg\">\r\n  <defs></defs>\r\n  <path fill=\"#fff\" d=\"M 0 0 L 192.756 0 L 192.756 192.756 L 0 192.756 L 0 0 Z\" fill-rule=\"evenodd\" clip-rule=\"evenodd\"></path>\r\n  <path d=\"M 183.727 66.775 C 187.006 66.775 189.922 63.861 189.922 60.217 C 189.922 56.756 187.006 54.023 183.727 54.023 C 180.266 54.023 177.17 56.755 177.17 60.217 C 177.17 63.861 180.266 66.775 183.727 66.775 Z M 183.727 65.865 C 180.45 65.865 178.081 63.497 178.081 60.218 C 178.081 57.303 180.45 54.935 183.727 54.935 C 186.644 54.937 189.008 57.301 189.01 60.218 C 189.01 63.497 186.643 65.865 183.727 65.865 Z\" fill=\"#234b8d\" fill-rule=\"evenodd\" clip-rule=\"evenodd\"></path>\r\n  <path d=\"M 182.088 60.946 L 184.274 60.946 C 185.186 60.946 185.368 61.492 185.368 62.039 C 185.368 62.222 185.368 63.314 185.55 63.861 L 186.644 63.861 L 186.644 63.497 C 186.462 63.314 186.279 63.314 186.279 62.95 L 186.279 61.857 C 186.279 60.946 185.916 60.764 185.55 60.582 C 186.097 60.218 186.462 59.853 186.462 58.761 C 186.462 57.486 185.368 56.939 184.274 56.939 L 181.178 56.939 L 181.178 63.862 L 182.088 63.862 L 182.088 60.946 L 182.088 60.946 Z M 182.088 57.85 L 184.274 57.85 C 184.821 57.85 185.549 57.85 185.549 58.943 C 185.549 59.854 184.82 60.036 184.092 60.036 L 182.088 60.036 L 182.088 57.85 L 182.088 57.85 Z M 3.381 53.842 L 87.178 53.842 L 87.178 137.821 L 3.381 137.821 L 3.381 53.842 Z M 174.801 53.842 L 90.822 53.842 L 90.822 137.821 L 174.801 53.842 Z\" fill=\"#234b8d\" fill-rule=\"evenodd\" clip-rule=\"evenodd\"></path>\r\n  <path d=\"M 69.508 129.26 L 76.066 129.26 C 85.721 129.26 87.543 121.062 87.178 118.694 C 86.632 112.865 82.26 109.221 76.248 109.221 L 60.217 109.221 L 60.217 138.55 L 69.508 138.55 L 69.508 129.26 Z M 69.508 122.337 L 69.508 115.961 L 73.515 115.961 C 76.794 115.961 78.069 116.69 78.069 119.058 C 78.069 120.151 78.069 122.337 74.426 122.337 L 69.508 122.337 L 69.508 122.337 Z\" fill=\"#fff\" fill-rule=\"evenodd\" clip-rule=\"evenodd\"></path>\r\n  <path d=\"M 39.997 132.356 L 49.288 132.356 L 51.656 138.549 L 61.493 138.549 L 50.38 109.221 L 39.268 109.221 L 27.974 138.55 L 37.447 138.55 L 39.997 132.356 L 39.997 132.356 Z M 44.916 117.419 L 48.195 126.162 L 41.82 126.162 L 44.916 117.419 Z\" fill=\"#fff\" fill-rule=\"evenodd\" clip-rule=\"evenodd\"></path>\r\n  <path d=\"M 2.834 129.26 L 2.834 130.9 C 2.834 136.729 9.938 138.915 16.679 138.915 C 25.787 138.915 31.253 135.636 31.253 129.261 C 31.253 119.059 13.036 122.156 13.036 116.145 C 13.036 113.958 14.676 113.23 17.226 113.23 C 18.865 113.23 19.412 113.594 19.958 113.959 C 21.051 114.688 21.051 115.599 21.051 117.238 L 30.706 117.238 L 30.706 116.509 C 30.706 112.137 26.88 108.493 17.226 108.493 C 6.66 108.493 3.381 112.501 3.381 117.237 C 3.381 127.621 21.598 124.341 21.598 130.717 C 21.598 131.992 20.505 133.814 16.679 133.814 C 13.582 133.814 12.489 132.357 12.489 130.17 L 12.489 129.26 L 2.834 129.26 L 2.834 129.26 Z\" fill=\"#fff\" fill-rule=\"evenodd\" clip-rule=\"evenodd\"></path>\r\n</svg>`,\r\n  'Mfg': `<svg height=\"34\" viewBox=\"0 0 100 50\" xmlns=\"http://www.w3.org/2000/svg\">\r\n  <defs></defs>\r\n  <rect width=\"93\" height=\"38\" style=\"fill: rgb(216, 216, 216);\"></rect>\r\n  <g transform=\"matrix(1, 0, 0, 1, 5, 6)\">\r\n    <g>\r\n      <g>\r\n        <path fill=\"#FFFFFF\" d=\"M41.1,1.8l13.1,20.5h-3.8L47,17.1H35.6l-3.1,5.2h-3.8L41.1,1.8z M37.2,14.5h8.1l-4.2-6.6L37.2,14.5z\"></path>\r\n        <path fill=\"#FFFFFF\" d=\"M59.3,2.5h9.3c8.8,0,12.7,5.2,12.7,9.9c0,5.1-4.8,9.9-12.6,9.9h-9.3V2.5z M62.7,19.7h5.4\r\n\t\t\t\tc7.8,0,9.5-4.9,9.5-7.4c0-4-3-7.4-9.7-7.4h-5.3V19.7z\"></path>\r\n        <path fill=\"#FFFFFF\" d=\"M25.7,12.3c0-5.8-5.4-10.1-12.5-10.1C5.4,2.2,0,6.4,0,12.4c0,6,5.4,10.2,13.1,10.2c1.4,0,2.6-0.2,3.8-0.5\r\n\t\t\t\tl3.3,2.6h5l-4.9-3.9C23.6,19,25.7,15.9,25.7,12.3z M13.1,20c-6.4,0-9.5-3.5-9.5-7.5c0-3,2.3-7.6,9.5-7.6c5.3,0,9.2,3.3,9.2,7.7\r\n\t\t\t\tC22.1,16.5,18.4,20,13.1,20z\"></path>\r\n      </g>\r\n    </g>\r\n  </g>\r\n</svg>`,\r\n  'Priority': `<svg fill=\"none\" height=\"60\" viewBox=\"0 0 240 133\" xmlns=\"http://www.w3.org/2000/svg\">\r\n  <g>\r\n    <path d=\"M 0 0 L 240 0 L 240 80.47 L 0 80.47 L 0 0 Z\" fill=\"#fff\" style=\"\"/>\r\n    <g transform=\"matrix(1, 0, 0, 1, -12.524841, -24.591444)\">\r\n      <path d=\"M 177.748 50.673 L 173.642 50.673 L 173.642 55.022 L 177.748 55.022 L 177.748 50.673 Z\" fill=\"#00aeef\"/>\r\n      <path d=\"M 62.734 56.578 C 62.734 55.44 62.423 55.077 61.437 55.026 L 59.263 54.869 L 59.263 50.674 L 68.019 50.674 L 68.019 54.558 C 69.211 51.968 71.956 49.896 75.373 49.896 C 77.086 49.896 78.64 50.207 80.348 51.035 L 80.348 58.755 L 75.531 59.117 L 75.531 56.734 C 75.531 56.113 75.428 55.647 75.012 55.44 C 74.544 55.232 74.18 55.18 73.613 55.18 C 70.815 55.18 68.898 57.409 68.898 60.414 L 68.898 72.431 L 73.408 72.636 L 73.408 76.73 L 59.52 76.73 L 59.52 72.795 L 61.232 72.636 C 62.217 72.533 62.734 72.224 62.734 70.929 L 62.734 56.578 Z\" fill=\"#000\"/>\r\n      <path d=\"M 115.469 63.832 C 115.469 58.031 114.074 54.456 109.93 54.456 C 105.833 54.456 104.177 57.978 104.177 62.952 C 104.177 67.768 104.85 72.946 109.825 72.946 C 113.865 72.946 115.469 69.221 115.469 63.832 Z M 110.239 49.896 C 114.074 49.896 121.789 51.085 121.789 63.003 C 121.789 72.946 116.247 77.507 109.41 77.507 C 102.467 77.507 97.909 73.053 97.909 63.674 C 97.909 52.902 104.904 49.896 110.239 49.896 Z\" fill=\"#000\"/>\r\n      <path d=\"M 127.543 56.578 C 127.543 55.44 127.235 55.077 126.25 55.026 L 124.072 54.869 L 124.072 50.674 L 132.83 50.674 L 132.83 54.558 C 134.019 51.968 136.766 49.896 140.187 49.896 C 141.894 49.896 143.449 50.207 145.158 51.035 L 145.158 58.755 L 140.341 59.117 L 140.341 56.734 C 140.341 56.113 140.238 55.647 139.822 55.44 C 139.356 55.232 138.995 55.18 138.425 55.18 C 135.625 55.18 133.71 57.409 133.71 60.414 L 133.71 72.431 L 138.215 72.636 L 138.215 76.73 L 124.333 76.73 L 124.333 72.795 L 126.042 72.636 C 127.026 72.533 127.543 72.224 127.543 70.929 L 127.543 56.578 Z\" fill=\"#000\"/>\r\n      <path d=\"M 202.016 71.812 C 200.203 74.4 197.046 75.851 193.622 75.851 C 188.443 75.851 185.594 73.001 185.594 66.887 L 185.594 56.477 C 185.594 55.386 185.178 55.078 184.301 55.023 L 182.639 54.921 L 182.639 50.673 L 191.756 50.673 L 191.756 65.541 C 191.756 68.7 192.274 71.084 195.591 71.084 C 199.22 71.084 201.136 68.647 201.136 65.957 L 201.136 56.578 C 201.136 55.44 200.822 55.023 199.837 55.023 L 198.182 54.921 L 198.182 50.673 L 207.297 50.673 L 207.297 75.747 C 207.297 84.296 203 87.817 195.278 87.817 C 192.016 87.817 187.719 87.196 185.544 86.109 L 185.544 80.694 L 190.463 80.278 L 190.463 80.978 C 190.463 81.962 190.721 82.482 191.657 82.843 C 192.639 83.207 193.781 83.362 195.334 83.362 C 200.099 83.362 202.016 80.461 202.016 75.747 L 202.016 71.812 Z\" fill=\"#000\"/>\r\n      <path d=\"M 157.671 72.43 L 157.671 50.674 L 148.398 50.674 L 148.398 54.972 L 150.21 55.077 C 151.193 55.077 151.508 55.439 151.508 56.577 L 151.535 76.73 L 160.622 76.73 L 160.622 72.586 L 157.671 72.43 Z\" fill=\"#000\"/>\r\n      <path d=\"M 92.86 72.43 L 92.86 50.674 L 83.589 50.674 L 83.589 54.972 L 85.399 55.077 C 86.386 55.077 86.697 55.439 86.697 56.577 L 86.669 76.73 L 95.814 76.73 L 95.814 72.586 L 92.86 72.43 Z\" fill=\"#000\"/>\r\n      <path d=\"M 179.171 71.653 C 178.346 72.173 177.048 72.741 175.653 72.741 C 173.524 72.741 172.281 71.811 172.281 68.647 L 172.281 45.183 L 168.916 45.183 C 167.828 48.134 166.586 50.933 162.958 51.242 L 162.442 55.023 L 166.12 55.023 L 166.12 68.855 C 166.12 72.481 166.066 77.455 174.144 77.455 C 176.582 77.455 179.171 76.73 180.728 75.644 L 179.171 71.653 Z\" fill=\"#000\"/>\r\n      <path d=\"M 44.332 72.587 C 42.986 72.587 41.121 72.173 39.775 71.291 L 39.775 59.377 C 39.775 56.995 42.053 54.92 45.007 54.92 C 47.751 54.92 50.242 56.684 50.242 63.572 C 50.242 68.077 48.737 72.587 44.332 72.587 Z M 47.289 49.896 C 42.884 49.896 40.036 52.279 39.103 54.04 L 39.103 50.675 L 30.347 50.675 L 30.347 54.868 L 32.525 55.023 C 33.507 55.023 33.816 55.44 33.816 56.578 L 33.781 87.455 L 43.968 87.455 L 43.968 83.362 L 39.775 83.153 L 39.775 76.005 C 41.121 76.833 43.296 77.507 45.317 77.507 C 52.158 77.507 56.662 72.587 56.662 63.055 C 56.662 53.783 53.038 49.896 47.289 49.896 Z\" fill=\"#000\"/>\r\n      <path d=\"M 212.882 72.662 L 212.882 73.272 L 211.674 73.272 L 211.674 76.676 L 210.927 76.676 L 210.927 73.272 L 209.717 73.272 L 209.717 72.662 L 212.882 72.662 Z\" fill=\"#000\"/>\r\n      <path d=\"M 215.401 75.194 C 215.429 75.258 215.456 75.322 215.48 75.388 C 215.51 75.322 215.534 75.253 215.564 75.19 C 215.589 75.124 215.618 75.066 215.65 75.004 L 216.84 72.781 C 216.855 72.752 216.868 72.73 216.884 72.717 C 216.901 72.697 216.921 72.685 216.939 72.678 C 216.956 72.669 216.98 72.668 217.003 72.665 C 217.023 72.663 217.057 72.662 217.089 72.662 L 217.653 72.662 L 217.653 76.676 L 216.994 76.676 L 216.994 74.082 C 216.994 74.033 216.995 73.98 216.999 73.926 C 217.002 73.866 217.005 73.809 217.011 73.751 L 215.799 76.026 C 215.77 76.075 215.734 76.117 215.689 76.146 C 215.646 76.175 215.594 76.187 215.534 76.187 L 215.433 76.187 C 215.373 76.187 215.319 76.175 215.275 76.146 C 215.233 76.117 215.195 76.075 215.165 76.026 L 213.941 73.742 C 213.947 73.803 213.95 73.861 213.953 73.92 C 213.957 73.978 213.958 74.032 213.958 74.082 L 213.958 76.676 L 213.299 76.676 L 213.299 72.662 L 213.866 72.662 C 213.899 72.662 213.924 72.663 213.95 72.665 C 213.974 72.668 213.992 72.669 214.015 72.678 C 214.035 72.685 214.052 72.697 214.067 72.717 C 214.089 72.73 214.103 72.752 214.116 72.781 L 215.314 75.009 C 215.348 75.068 215.375 75.133 215.401 75.194 Z\" fill=\"#000\"/>\r\n    </g>\r\n  </g>\r\n</svg>`,\r\n  'Active Directory': `<svg viewBox=\"0 0 954.1 158.2\" height=\"38\" xmlns=\"http://www.w3.org/2000/svg\">\r\n  <defs></defs>\r\n  <style>.st0{fill:#00aaf2}</style>\r\n  <g id=\"Layer_2_1_\" transform=\"translate(0 -33.561)\">\r\n    <g id=\"Layer_1-2\">\r\n      <path id=\"path6\" class=\"st0\" d=\"M158.6 154.2v33.3c0 3.9-1.2 4.7-4.9 4.1-24.8-3.7-49.9-7.1-74.9-10.6-4.5-.6-6.1-2.2-6.1-7.1.4-17.7.2-35.5 0-53.4 0-3.9 1.2-5.1 5.1-5.1 25.6.2 50.8.2 75.9.2 4.1 0 5.1 1.6 5.1 5.3-.4 11.2-.2 22.2-.2 33.3z\" transform=\"matrix(1, 0, 0, 1, 58.678164, 33.659804)\"></path>\r\n      <path id=\"path8\" class=\"st0\" d=\"M116.1 109.2c-12.6 0-25.2-.2-37.8 0-3.9 0-5.5-.8-5.5-5.3.2-18.1.2-35.9 0-53.8 0-3.5 1.2-4.7 4.5-5.3 25.8-3.7 51.6-7.3 77.4-11.2 4.5-.6 3.7 2.4 3.7 4.9 0 16 .2 32.3 0 48.3 0 5.9-.2 11.8 0 17.7.2 3.7-1.2 4.7-4.7 4.7-12.4-.2-25 0-37.6 0z\" transform=\"matrix(1, 0, 0, 1, 58.678164, 33.659804)\"></path>\r\n      <path id=\"path10\" class=\"st0\" d=\"M32.7 115.9h28.2c3 0 4.3 1 4.3 4.1v55.6c0 3.2-1.4 3.5-4.3 3.2-18.7-2.8-37.4-5.5-56-8.1-3.7-.6-4.9-1.8-4.9-5.7.2-14.8.2-29.6 0-44.7 0-3.7 1-4.7 4.7-4.7 9.5.3 18.6.3 28 .3z\" transform=\"matrix(1, 0, 0, 1, 58.678164, 33.659804)\"></path>\r\n      <path id=\"path12\" class=\"st0\" d=\"M32.7 109.2H4.9c-3.5 0-4.7-1.2-4.7-4.9.2-14.6.2-29.2 0-43.9 0-3.5 1-4.7 4.7-5.3 18.7-2.4 37.4-5.1 56-8.1 4.3-.6 4.7.8 4.7 4.3v53.2c0 3.9-1.6 4.5-5.1 4.5-9.3 0-18.7.2-27.8.2z\" transform=\"matrix(1, 0, 0, 1, 58.678164, 33.659804)\"></path>\r\n    </g>\r\n  </g>\r\n</svg>`\r\n};\r\n/** */\r\nexport class DesignerRef<O = any> {\r\n  _unlock$ = new Subject<boolean>();\r\n  _state$ = new BehaviorSubject<any>(null);\r\n  constructor(private _designer: DesignerModel,\r\n    private _element: ElementModel,\r\n    public mode: DesignMode) { }\r\n  get designer(): DesignerInfo { return this._designer; }\r\n  get model(): ElementInfo<O> { return this._element; }\r\n  get unlock() { return this._unlock$.asObservable(); }\r\n  get state() { return this._state$.value; }\r\n  set state(val) { this._state$.next(val); }\r\n  create(element: ElementInfo, template?: string) {\r\n    const ref = new DesignerRef(this._designer, element as ElementModel, 'widget');\r\n    const injector = Injector.create([{\r\n      provide: DesignerRef, useValue: ref\r\n    }], (this._element as ElementModel).injector);\r\n    (element as ElementModel).template = template;\r\n    (element as ElementModel).injector = injector;\r\n    return element;\r\n  }\r\n}\r\nexport interface DesignerElementComponent<T> {\r\n  model: ElementInfo<T>;\r\n  mode: DesignMode;\r\n  form: FormGroup;\r\n  onContinue?();\r\n  onFinish?();\r\n}\r\nexport declare type DesignMode = 'add' | 'edit' | 'widget';\r\nexport function clone(element: ElementModel) {\r\n  return JSON.parse(JSON.stringify(element));\r\n}\r\nexport function arrayOf(val: string | string[]) {\r\n  if (!val) return [];\r\n  if (isString(val)) return [val];\r\n  return val;\r\n}\r\n\r\nconst NAME_CHAR = /[A-Z]+/g,\r\n  NON_NAME_CHAR = /[^\\w]+/g;\r\n/**\r\n * \r\n * @param name\r\n */\r\nexport function programName(name: string) {\r\n  return name.\r\n    replace(' ', '-').\r\n    replace(NAME_CHAR, (c, i) => (i > 0 && name.charAt(i - 1) !== '-' ? '-' : '') + c.toLowerCase()).\r\n    replace(NON_NAME_CHAR, '_');\r\n}\r\nexport interface DesignerModel {\r\n  types: ElementModel<any>[];\r\n  tTypes: TemplateInfo[];\r\n  guides: ElementModel<any>[];\r\n  reports: ElementModel<any>[];\r\n  tReports: TemplateInfo[];\r\n  forms: ElementModel<any>[];\r\n  tForms: TemplateInfo[];\r\n  cubes: ElementModel<any>[];\r\n  tCubes: TemplateInfo[];\r\n  utilities: ElementModel<any>[];\r\n  tUtilities: TemplateInfo[];\r\n  folders: ElementModel<any>[];\r\n  roles: ElementModel<any>[];\r\n  rules: ElementModel<any>[];\r\n  tRules: TemplateInfo[];\r\n  policies: ElementModel<any>[];\r\n  tPolicies: TemplateInfo[];\r\n  views: ElementModel<any>[];\r\n  tViews: TemplateInfo[];\r\n  widgets: ElementModel<any>[];\r\n  tWidgets: TemplateInfo[];\r\n  actions: ElementModel<any>[];\r\n  tActions: TemplateInfo[];\r\n  states: ElementModel<any>[];\r\n}\r\nexport interface TemplateInfo {\r\n  template?: string;\r\n  title?: string;\r\n  key?: string;\r\n  icon?: string;\r\n  family?: string;\r\n  help?: string;\r\n  type?: string;\r\n  arguments?: FieldInfo[];\r\n}\r\nexport interface ElementModel<T = any> {\r\n  key?: string;\r\n  injector: Injector;\r\n  ordinal?: number;\r\n  help?: string;\r\n  configurationFile?: string;\r\n  template?: string;\r\n  icon?: string;\r\n  resource?: string;\r\n  copyOf?: string;\r\n  family?: string;\r\n  type?: string;\r\n  name: string;\r\n  title: string;\r\n  disabled?: boolean;\r\n  draft?: boolean;\r\n  empty?: boolean;\r\n  options?: T;\r\n  arguments?: FieldInfo[];\r\n  privileges?: PrivilegesModel;\r\n  filters?: CubeFilter;\r\n  columns?: FolderColumn[];\r\n  anomaly?: AnomalyPolicy;\r\n  verb?: string;\r\n  you?: string;\r\n  youMale?: string;\r\n  youFemale?: string;\r\n  past?: string;\r\n  pastMale?: string;\r\n  pastFemale?: string;\r\n  adjective?: string;\r\n  loggable?: boolean;\r\n  adjectivePlural?: string;\r\n  assignable?: boolean;\r\n  position?: PositionPolicy;\r\n  multiple?: boolean;\r\n  shape?: string;\r\n  group?: number;\r\n  dataType?: string;\r\n  steps?: GuideStep[];\r\n  currencyCode?: string;\r\n  axes?: CubeAxisModel[];\r\n  views?: CubeViewModel[];\r\n  indices?: CubeIndexModel[];\r\n  scope?: ScopeType;\r\n  color?: string;\r\n  backgroundColor?: string;\r\n  rules?: PermissionModel[];\r\n  positions?: { [key: string]: string[] };\r\n  patterns?: PatternModel[];\r\n  priority?: number;\r\n  cubes?: string[];\r\n  value?: string;\r\n  sequencePolicy?: 'Both' | 'Either' | 'Higher';\r\n}\r\nexport interface CubeIndexModel {\r\n  name: string;\r\n  accumulate?: boolean;\r\n  hidden?: boolean;\r\n  title: string;\r\n}\r\nexport interface CubeViewModel {\r\n  privileges?: PrivilegesModel;\r\n  xAxis: string[];\r\n  series?: string[];\r\n  filters?: AxesMap;\r\n  indices?: string[];\r\n  icon?: string;\r\n  guide?: string;\r\n  name: string;\r\n  title: string;\r\n  type: ViewType;\r\n  chartType?: ChartType;\r\n  indicesChartType?: ChartType;\r\n}\r\nexport interface PatternModel {\r\n  title: string;\r\n  axes: AxesMap;\r\n  hidden?: boolean;\r\n  rule?: string;\r\n  roles?: string[];\r\n}\r\nexport interface CubeAxisModel {\r\n  name: string;\r\n  title: string;\r\n  dataType: string;\r\n  hidden?: boolean;\r\n  combination?: boolean;\r\n  indexable?: boolean;\r\n  sensitive?: boolean;\r\n  resourceType?: string;\r\n  selectionMode?: 'Single' | 'Pattern' | 'Multiple' | 'Search' | 'None';\r\n  descendentOf?: string;\r\n}\r\nexport type AnomalyPolicy = 'Positions' | 'Recipients';\r\n\r\nexport interface PatternModel {\r\n  title: string;\r\n  resourceType?: string;\r\n  axes: AxesMap;\r\n  rule?: string;\r\n  roles?: string[];\r\n}\r\nexport interface PermissionModel {\r\n  name: string;\r\n  title: string;\r\n  rule?: string;\r\n  roles?: string[];\r\n}\r\nexport interface PrivilegesModel {\r\n  rule?: string;\r\n  roles?: string[];\r\n}\r\nexport interface DesignerInfo {\r\n  types: ElementInfo[];\r\n  guides: ElementInfo[];\r\n  reports: ElementInfo[];\r\n  tReports: TemplateInfo[];\r\n  forms: ElementInfo[];\r\n  cubes: ElementInfo[];\r\n  utilities: ElementInfo[];\r\n  folders: ElementInfo[];\r\n  roles: ElementInfo[];\r\n  rules: ElementInfo[];\r\n  policies: ElementInfo[];\r\n  views: ElementInfo[];\r\n  widgets: ElementInfo[];\r\n  actions: ElementInfo[];\r\n  states: ElementInfo[];\r\n}\r\nexport interface ElementInfo<T = any> {\r\n  family?: string;\r\n  type?: string;\r\n  key?: string;\r\n  name: string;\r\n  title: string;\r\n  disabled?: boolean;\r\n  draft?: boolean;\r\n  empty?: boolean;\r\n  options?: T;\r\n}\r\n"]}
128
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"declarations.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/admin/configuration-designer/declarations.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAGzC,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAEhD,OAAO,EAAE,eAAe,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAChD,MAAM,CAAC,MAAM,UAAU,GAAG;IACxB,OAAO,EAAE;;;;;;;;;;;;;;;;;;;;;;OAsBJ;IACL,KAAK,EAAE;;;;;;;;OAQF;IACL,KAAK,EAAE;;;;;;;;;;;;;;;OAeF;IACL,UAAU,EAAE;;;;;;;;;;;;;;;;;OAiBP;IACL,kBAAkB,EAAE;;;;;;;;;;;OAWf;CACN,CAAC;AACF,MAAM;AACN,MAAM,OAAO,WAAW;IAGtB,YAAoB,SAAwB,EAClC,QAAsB,EACvB,IAAgB;QAFL,cAAS,GAAT,SAAS,CAAe;QAClC,aAAQ,GAAR,QAAQ,CAAc;QACvB,SAAI,GAAJ,IAAI,CAAY;QAJzB,aAAQ,GAAG,IAAI,OAAO,EAAW,CAAC;QAClC,YAAO,GAAG,IAAI,eAAe,CAAM,IAAI,CAAC,CAAC;IAGZ,CAAC;IAC9B,IAAI,QAAQ,KAAmB,OAAO,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;IACvD,IAAI,KAAK,KAAqB,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;IACrD,IAAI,MAAM,KAAK,OAAO,IAAI,CAAC,QAAQ,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC;IACrD,IAAI,KAAK,KAAK,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC;IAC1C,IAAI,KAAK,CAAC,GAAG,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAC1C,MAAM,CAAC,OAAoB;QACzB,MAAM,GAAG,GAAG,IAAI,WAAW,CAAC,IAAI,CAAC,SAAS,EAAE,OAAuB,EAAE,QAAQ,CAAC,CAAC;QAC/E,MAAM,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC;gBAChC,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,GAAG;aACpC,CAAC,EAAG,IAAI,CAAC,QAAyB,CAAC,QAAQ,CAAC,CAAC;QAC7C,OAAwB,CAAC,QAAQ,GAAG,QAAQ,CAAC;QAC9C,OAAO,OAAO,CAAC;IACjB,CAAC;CACF;AASD,MAAM,UAAU,KAAK,CAAC,OAAqB;IACzC,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC;AAC7C,CAAC;AACD,MAAM,UAAU,OAAO,CAAC,GAAsB;IAC5C,IAAI,CAAC,GAAG;QAAE,OAAO,EAAE,CAAC;IACpB,IAAI,QAAQ,CAAC,GAAG,CAAC;QAAE,OAAO,CAAC,GAAG,CAAC,CAAC;IAChC,OAAO,GAAG,CAAC;AACb,CAAC;AAED,MAAM,SAAS,GAAG,SAAS,EACzB,aAAa,GAAG,SAAS,CAAC;AAC5B;;;GAGG;AACH,MAAM,UAAU,WAAW,CAAC,IAAY;IACtC,OAAO,IAAI;QACT,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC;QACjB,OAAO,CAAC,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,WAAW,EAAE,CAAC;QAChG,OAAO,CAAC,aAAa,EAAE,GAAG,CAAC,CAAC;AAChC,CAAC","sourcesContent":["import { Injector } from \"@angular/core\";\r\nimport { FormGroup } from \"@angular/forms\";\r\nimport { ScopeType } from \"../../core/configuration\";\r\nimport { isString } from \"../../core/functions\";\r\nimport { AxesMap, ChartType, CubeFilter, FieldInfo, FolderColumn, GuideStep, PositionPolicy, ViewType } from \"../../core/models\";\r\nimport { BehaviorSubject, Subject } from \"rxjs\";\r\nexport const FAMILY_SVG = {\r\n  \"Azure\": `<svg width=\"34\" height=\"34\" viewBox=\"0 0 96 96\" xmlns=\"http://www.w3.org/2000/svg\">\r\n    <defs>\r\n        <linearGradient id=\"e399c19f-b68f-429d-b176-18c2117ff73c\" x1=\"-1032.172\" x2=\"-1059.213\" y1=\"145.312\" y2=\"65.426\" gradientTransform=\"matrix(1 0 0 -1 1075 158)\" gradientUnits=\"userSpaceOnUse\">\r\n            <stop offset=\"0\" stop-color=\"#114a8b\"/>\r\n            <stop offset=\"1\" stop-color=\"#0669bc\"/>\r\n        </linearGradient>\r\n        <linearGradient id=\"ac2a6fc2-ca48-4327-9a3c-d4dcc3256e15\" x1=\"-1023.725\" x2=\"-1029.98\" y1=\"108.083\" y2=\"105.968\" gradientTransform=\"matrix(1 0 0 -1 1075 158)\" gradientUnits=\"userSpaceOnUse\">\r\n            <stop offset=\"0\" stop-opacity=\".3\"/>\r\n            <stop offset=\".071\" stop-opacity=\".2\"/>\r\n            <stop offset=\".321\" stop-opacity=\".1\"/>\r\n            <stop offset=\".623\" stop-opacity=\".05\"/>\r\n            <stop offset=\"1\" stop-opacity=\"0\"/>\r\n        </linearGradient>\r\n        <linearGradient id=\"a7fee970-a784-4bb1-af8d-63d18e5f7db9\" x1=\"-1027.165\" x2=\"-997.482\" y1=\"147.642\" y2=\"68.561\" gradientTransform=\"matrix(1 0 0 -1 1075 158)\" gradientUnits=\"userSpaceOnUse\">\r\n            <stop offset=\"0\" stop-color=\"#3ccbf4\"/>\r\n            <stop offset=\"1\" stop-color=\"#2892df\"/>\r\n        </linearGradient>\r\n    </defs>\r\n    <path fill=\"url(#e399c19f-b68f-429d-b176-18c2117ff73c)\" d=\"M33.338 6.544h26.038l-27.03 80.087a4.152 4.152 0 0 1-3.933 2.824H8.149a4.145 4.145 0 0 1-3.928-5.47L29.404 9.368a4.152 4.152 0 0 1 3.934-2.825z\"/>\r\n    <path fill=\"#0078d4\" d=\"M71.175 60.261h-41.29a1.911 1.911 0 0 0-1.305 3.309l26.532 24.764a4.171 4.171 0 0 0 2.846 1.121h23.38z\"/>\r\n    <path fill=\"url(#ac2a6fc2-ca48-4327-9a3c-d4dcc3256e15)\" d=\"M33.338 6.544a4.118 4.118 0 0 0-3.943 2.879L4.252 83.917a4.14 4.14 0 0 0 3.908 5.538h20.787a4.443 4.443 0 0 0 3.41-2.9l5.014-14.777 17.91 16.705a4.237 4.237 0 0 0 2.666.972H81.24L71.024 60.261l-29.781.007L59.47 6.544z\"/>\r\n    <path fill=\"url(#a7fee970-a784-4bb1-af8d-63d18e5f7db9)\" d=\"M66.595 9.364a4.145 4.145 0 0 0-3.928-2.82H33.648a4.146 4.146 0 0 1 3.928 2.82l25.184 74.62a4.146 4.146 0 0 1-3.928 5.472h29.02a4.146 4.146 0 0 0 3.927-5.472z\"/>\r\n</svg>`,\r\n  'SAP': `<svg height=\"45\" viewBox=\"0 0 192.756 192.756\" xmlns=\"http://www.w3.org/2000/svg\">\r\n  <defs></defs>\r\n  <path fill=\"#fff\" d=\"M 0 0 L 192.756 0 L 192.756 192.756 L 0 192.756 L 0 0 Z\" fill-rule=\"evenodd\" clip-rule=\"evenodd\"></path>\r\n  <path d=\"M 183.727 66.775 C 187.006 66.775 189.922 63.861 189.922 60.217 C 189.922 56.756 187.006 54.023 183.727 54.023 C 180.266 54.023 177.17 56.755 177.17 60.217 C 177.17 63.861 180.266 66.775 183.727 66.775 Z M 183.727 65.865 C 180.45 65.865 178.081 63.497 178.081 60.218 C 178.081 57.303 180.45 54.935 183.727 54.935 C 186.644 54.937 189.008 57.301 189.01 60.218 C 189.01 63.497 186.643 65.865 183.727 65.865 Z\" fill=\"#234b8d\" fill-rule=\"evenodd\" clip-rule=\"evenodd\"></path>\r\n  <path d=\"M 182.088 60.946 L 184.274 60.946 C 185.186 60.946 185.368 61.492 185.368 62.039 C 185.368 62.222 185.368 63.314 185.55 63.861 L 186.644 63.861 L 186.644 63.497 C 186.462 63.314 186.279 63.314 186.279 62.95 L 186.279 61.857 C 186.279 60.946 185.916 60.764 185.55 60.582 C 186.097 60.218 186.462 59.853 186.462 58.761 C 186.462 57.486 185.368 56.939 184.274 56.939 L 181.178 56.939 L 181.178 63.862 L 182.088 63.862 L 182.088 60.946 L 182.088 60.946 Z M 182.088 57.85 L 184.274 57.85 C 184.821 57.85 185.549 57.85 185.549 58.943 C 185.549 59.854 184.82 60.036 184.092 60.036 L 182.088 60.036 L 182.088 57.85 L 182.088 57.85 Z M 3.381 53.842 L 87.178 53.842 L 87.178 137.821 L 3.381 137.821 L 3.381 53.842 Z M 174.801 53.842 L 90.822 53.842 L 90.822 137.821 L 174.801 53.842 Z\" fill=\"#234b8d\" fill-rule=\"evenodd\" clip-rule=\"evenodd\"></path>\r\n  <path d=\"M 69.508 129.26 L 76.066 129.26 C 85.721 129.26 87.543 121.062 87.178 118.694 C 86.632 112.865 82.26 109.221 76.248 109.221 L 60.217 109.221 L 60.217 138.55 L 69.508 138.55 L 69.508 129.26 Z M 69.508 122.337 L 69.508 115.961 L 73.515 115.961 C 76.794 115.961 78.069 116.69 78.069 119.058 C 78.069 120.151 78.069 122.337 74.426 122.337 L 69.508 122.337 L 69.508 122.337 Z\" fill=\"#fff\" fill-rule=\"evenodd\" clip-rule=\"evenodd\"></path>\r\n  <path d=\"M 39.997 132.356 L 49.288 132.356 L 51.656 138.549 L 61.493 138.549 L 50.38 109.221 L 39.268 109.221 L 27.974 138.55 L 37.447 138.55 L 39.997 132.356 L 39.997 132.356 Z M 44.916 117.419 L 48.195 126.162 L 41.82 126.162 L 44.916 117.419 Z\" fill=\"#fff\" fill-rule=\"evenodd\" clip-rule=\"evenodd\"></path>\r\n  <path d=\"M 2.834 129.26 L 2.834 130.9 C 2.834 136.729 9.938 138.915 16.679 138.915 C 25.787 138.915 31.253 135.636 31.253 129.261 C 31.253 119.059 13.036 122.156 13.036 116.145 C 13.036 113.958 14.676 113.23 17.226 113.23 C 18.865 113.23 19.412 113.594 19.958 113.959 C 21.051 114.688 21.051 115.599 21.051 117.238 L 30.706 117.238 L 30.706 116.509 C 30.706 112.137 26.88 108.493 17.226 108.493 C 6.66 108.493 3.381 112.501 3.381 117.237 C 3.381 127.621 21.598 124.341 21.598 130.717 C 21.598 131.992 20.505 133.814 16.679 133.814 C 13.582 133.814 12.489 132.357 12.489 130.17 L 12.489 129.26 L 2.834 129.26 L 2.834 129.26 Z\" fill=\"#fff\" fill-rule=\"evenodd\" clip-rule=\"evenodd\"></path>\r\n</svg>`,\r\n  'Mfg': `<svg height=\"34\" viewBox=\"0 0 100 50\" xmlns=\"http://www.w3.org/2000/svg\">\r\n  <defs></defs>\r\n  <rect width=\"93\" height=\"38\" style=\"fill: rgb(216, 216, 216);\"></rect>\r\n  <g transform=\"matrix(1, 0, 0, 1, 5, 6)\">\r\n    <g>\r\n      <g>\r\n        <path fill=\"#FFFFFF\" d=\"M41.1,1.8l13.1,20.5h-3.8L47,17.1H35.6l-3.1,5.2h-3.8L41.1,1.8z M37.2,14.5h8.1l-4.2-6.6L37.2,14.5z\"></path>\r\n        <path fill=\"#FFFFFF\" d=\"M59.3,2.5h9.3c8.8,0,12.7,5.2,12.7,9.9c0,5.1-4.8,9.9-12.6,9.9h-9.3V2.5z M62.7,19.7h5.4\r\n\t\t\t\tc7.8,0,9.5-4.9,9.5-7.4c0-4-3-7.4-9.7-7.4h-5.3V19.7z\"></path>\r\n        <path fill=\"#FFFFFF\" d=\"M25.7,12.3c0-5.8-5.4-10.1-12.5-10.1C5.4,2.2,0,6.4,0,12.4c0,6,5.4,10.2,13.1,10.2c1.4,0,2.6-0.2,3.8-0.5\r\n\t\t\t\tl3.3,2.6h5l-4.9-3.9C23.6,19,25.7,15.9,25.7,12.3z M13.1,20c-6.4,0-9.5-3.5-9.5-7.5c0-3,2.3-7.6,9.5-7.6c5.3,0,9.2,3.3,9.2,7.7\r\n\t\t\t\tC22.1,16.5,18.4,20,13.1,20z\"></path>\r\n      </g>\r\n    </g>\r\n  </g>\r\n</svg>`,\r\n  'Priority': `<svg fill=\"none\" height=\"60\" viewBox=\"0 0 240 133\" xmlns=\"http://www.w3.org/2000/svg\">\r\n  <g>\r\n    <path d=\"M 0 0 L 240 0 L 240 80.47 L 0 80.47 L 0 0 Z\" fill=\"#fff\" style=\"\"/>\r\n    <g transform=\"matrix(1, 0, 0, 1, -12.524841, -24.591444)\">\r\n      <path d=\"M 177.748 50.673 L 173.642 50.673 L 173.642 55.022 L 177.748 55.022 L 177.748 50.673 Z\" fill=\"#00aeef\"/>\r\n      <path d=\"M 62.734 56.578 C 62.734 55.44 62.423 55.077 61.437 55.026 L 59.263 54.869 L 59.263 50.674 L 68.019 50.674 L 68.019 54.558 C 69.211 51.968 71.956 49.896 75.373 49.896 C 77.086 49.896 78.64 50.207 80.348 51.035 L 80.348 58.755 L 75.531 59.117 L 75.531 56.734 C 75.531 56.113 75.428 55.647 75.012 55.44 C 74.544 55.232 74.18 55.18 73.613 55.18 C 70.815 55.18 68.898 57.409 68.898 60.414 L 68.898 72.431 L 73.408 72.636 L 73.408 76.73 L 59.52 76.73 L 59.52 72.795 L 61.232 72.636 C 62.217 72.533 62.734 72.224 62.734 70.929 L 62.734 56.578 Z\" fill=\"#000\"/>\r\n      <path d=\"M 115.469 63.832 C 115.469 58.031 114.074 54.456 109.93 54.456 C 105.833 54.456 104.177 57.978 104.177 62.952 C 104.177 67.768 104.85 72.946 109.825 72.946 C 113.865 72.946 115.469 69.221 115.469 63.832 Z M 110.239 49.896 C 114.074 49.896 121.789 51.085 121.789 63.003 C 121.789 72.946 116.247 77.507 109.41 77.507 C 102.467 77.507 97.909 73.053 97.909 63.674 C 97.909 52.902 104.904 49.896 110.239 49.896 Z\" fill=\"#000\"/>\r\n      <path d=\"M 127.543 56.578 C 127.543 55.44 127.235 55.077 126.25 55.026 L 124.072 54.869 L 124.072 50.674 L 132.83 50.674 L 132.83 54.558 C 134.019 51.968 136.766 49.896 140.187 49.896 C 141.894 49.896 143.449 50.207 145.158 51.035 L 145.158 58.755 L 140.341 59.117 L 140.341 56.734 C 140.341 56.113 140.238 55.647 139.822 55.44 C 139.356 55.232 138.995 55.18 138.425 55.18 C 135.625 55.18 133.71 57.409 133.71 60.414 L 133.71 72.431 L 138.215 72.636 L 138.215 76.73 L 124.333 76.73 L 124.333 72.795 L 126.042 72.636 C 127.026 72.533 127.543 72.224 127.543 70.929 L 127.543 56.578 Z\" fill=\"#000\"/>\r\n      <path d=\"M 202.016 71.812 C 200.203 74.4 197.046 75.851 193.622 75.851 C 188.443 75.851 185.594 73.001 185.594 66.887 L 185.594 56.477 C 185.594 55.386 185.178 55.078 184.301 55.023 L 182.639 54.921 L 182.639 50.673 L 191.756 50.673 L 191.756 65.541 C 191.756 68.7 192.274 71.084 195.591 71.084 C 199.22 71.084 201.136 68.647 201.136 65.957 L 201.136 56.578 C 201.136 55.44 200.822 55.023 199.837 55.023 L 198.182 54.921 L 198.182 50.673 L 207.297 50.673 L 207.297 75.747 C 207.297 84.296 203 87.817 195.278 87.817 C 192.016 87.817 187.719 87.196 185.544 86.109 L 185.544 80.694 L 190.463 80.278 L 190.463 80.978 C 190.463 81.962 190.721 82.482 191.657 82.843 C 192.639 83.207 193.781 83.362 195.334 83.362 C 200.099 83.362 202.016 80.461 202.016 75.747 L 202.016 71.812 Z\" fill=\"#000\"/>\r\n      <path d=\"M 157.671 72.43 L 157.671 50.674 L 148.398 50.674 L 148.398 54.972 L 150.21 55.077 C 151.193 55.077 151.508 55.439 151.508 56.577 L 151.535 76.73 L 160.622 76.73 L 160.622 72.586 L 157.671 72.43 Z\" fill=\"#000\"/>\r\n      <path d=\"M 92.86 72.43 L 92.86 50.674 L 83.589 50.674 L 83.589 54.972 L 85.399 55.077 C 86.386 55.077 86.697 55.439 86.697 56.577 L 86.669 76.73 L 95.814 76.73 L 95.814 72.586 L 92.86 72.43 Z\" fill=\"#000\"/>\r\n      <path d=\"M 179.171 71.653 C 178.346 72.173 177.048 72.741 175.653 72.741 C 173.524 72.741 172.281 71.811 172.281 68.647 L 172.281 45.183 L 168.916 45.183 C 167.828 48.134 166.586 50.933 162.958 51.242 L 162.442 55.023 L 166.12 55.023 L 166.12 68.855 C 166.12 72.481 166.066 77.455 174.144 77.455 C 176.582 77.455 179.171 76.73 180.728 75.644 L 179.171 71.653 Z\" fill=\"#000\"/>\r\n      <path d=\"M 44.332 72.587 C 42.986 72.587 41.121 72.173 39.775 71.291 L 39.775 59.377 C 39.775 56.995 42.053 54.92 45.007 54.92 C 47.751 54.92 50.242 56.684 50.242 63.572 C 50.242 68.077 48.737 72.587 44.332 72.587 Z M 47.289 49.896 C 42.884 49.896 40.036 52.279 39.103 54.04 L 39.103 50.675 L 30.347 50.675 L 30.347 54.868 L 32.525 55.023 C 33.507 55.023 33.816 55.44 33.816 56.578 L 33.781 87.455 L 43.968 87.455 L 43.968 83.362 L 39.775 83.153 L 39.775 76.005 C 41.121 76.833 43.296 77.507 45.317 77.507 C 52.158 77.507 56.662 72.587 56.662 63.055 C 56.662 53.783 53.038 49.896 47.289 49.896 Z\" fill=\"#000\"/>\r\n      <path d=\"M 212.882 72.662 L 212.882 73.272 L 211.674 73.272 L 211.674 76.676 L 210.927 76.676 L 210.927 73.272 L 209.717 73.272 L 209.717 72.662 L 212.882 72.662 Z\" fill=\"#000\"/>\r\n      <path d=\"M 215.401 75.194 C 215.429 75.258 215.456 75.322 215.48 75.388 C 215.51 75.322 215.534 75.253 215.564 75.19 C 215.589 75.124 215.618 75.066 215.65 75.004 L 216.84 72.781 C 216.855 72.752 216.868 72.73 216.884 72.717 C 216.901 72.697 216.921 72.685 216.939 72.678 C 216.956 72.669 216.98 72.668 217.003 72.665 C 217.023 72.663 217.057 72.662 217.089 72.662 L 217.653 72.662 L 217.653 76.676 L 216.994 76.676 L 216.994 74.082 C 216.994 74.033 216.995 73.98 216.999 73.926 C 217.002 73.866 217.005 73.809 217.011 73.751 L 215.799 76.026 C 215.77 76.075 215.734 76.117 215.689 76.146 C 215.646 76.175 215.594 76.187 215.534 76.187 L 215.433 76.187 C 215.373 76.187 215.319 76.175 215.275 76.146 C 215.233 76.117 215.195 76.075 215.165 76.026 L 213.941 73.742 C 213.947 73.803 213.95 73.861 213.953 73.92 C 213.957 73.978 213.958 74.032 213.958 74.082 L 213.958 76.676 L 213.299 76.676 L 213.299 72.662 L 213.866 72.662 C 213.899 72.662 213.924 72.663 213.95 72.665 C 213.974 72.668 213.992 72.669 214.015 72.678 C 214.035 72.685 214.052 72.697 214.067 72.717 C 214.089 72.73 214.103 72.752 214.116 72.781 L 215.314 75.009 C 215.348 75.068 215.375 75.133 215.401 75.194 Z\" fill=\"#000\"/>\r\n    </g>\r\n  </g>\r\n</svg>`,\r\n  'Active Directory': `<svg viewBox=\"0 0 954.1 158.2\" height=\"38\" xmlns=\"http://www.w3.org/2000/svg\">\r\n  <defs></defs>\r\n  <style>.st0{fill:#00aaf2}</style>\r\n  <g id=\"Layer_2_1_\" transform=\"translate(0 -33.561)\">\r\n    <g id=\"Layer_1-2\">\r\n      <path id=\"path6\" class=\"st0\" d=\"M158.6 154.2v33.3c0 3.9-1.2 4.7-4.9 4.1-24.8-3.7-49.9-7.1-74.9-10.6-4.5-.6-6.1-2.2-6.1-7.1.4-17.7.2-35.5 0-53.4 0-3.9 1.2-5.1 5.1-5.1 25.6.2 50.8.2 75.9.2 4.1 0 5.1 1.6 5.1 5.3-.4 11.2-.2 22.2-.2 33.3z\" transform=\"matrix(1, 0, 0, 1, 58.678164, 33.659804)\"></path>\r\n      <path id=\"path8\" class=\"st0\" d=\"M116.1 109.2c-12.6 0-25.2-.2-37.8 0-3.9 0-5.5-.8-5.5-5.3.2-18.1.2-35.9 0-53.8 0-3.5 1.2-4.7 4.5-5.3 25.8-3.7 51.6-7.3 77.4-11.2 4.5-.6 3.7 2.4 3.7 4.9 0 16 .2 32.3 0 48.3 0 5.9-.2 11.8 0 17.7.2 3.7-1.2 4.7-4.7 4.7-12.4-.2-25 0-37.6 0z\" transform=\"matrix(1, 0, 0, 1, 58.678164, 33.659804)\"></path>\r\n      <path id=\"path10\" class=\"st0\" d=\"M32.7 115.9h28.2c3 0 4.3 1 4.3 4.1v55.6c0 3.2-1.4 3.5-4.3 3.2-18.7-2.8-37.4-5.5-56-8.1-3.7-.6-4.9-1.8-4.9-5.7.2-14.8.2-29.6 0-44.7 0-3.7 1-4.7 4.7-4.7 9.5.3 18.6.3 28 .3z\" transform=\"matrix(1, 0, 0, 1, 58.678164, 33.659804)\"></path>\r\n      <path id=\"path12\" class=\"st0\" d=\"M32.7 109.2H4.9c-3.5 0-4.7-1.2-4.7-4.9.2-14.6.2-29.2 0-43.9 0-3.5 1-4.7 4.7-5.3 18.7-2.4 37.4-5.1 56-8.1 4.3-.6 4.7.8 4.7 4.3v53.2c0 3.9-1.6 4.5-5.1 4.5-9.3 0-18.7.2-27.8.2z\" transform=\"matrix(1, 0, 0, 1, 58.678164, 33.659804)\"></path>\r\n    </g>\r\n  </g>\r\n</svg>`\r\n};\r\n/** */\r\nexport class DesignerRef<O = any> {\r\n  _unlock$ = new Subject<boolean>();\r\n  _state$ = new BehaviorSubject<any>(null);\r\n  constructor(private _designer: DesignerModel,\r\n    private _element: ElementModel,\r\n    public mode: DesignMode) { }\r\n  get designer(): DesignerInfo { return this._designer; }\r\n  get model(): ElementInfo<O> { return this._element; }\r\n  get unlock() { return this._unlock$.asObservable(); }\r\n  get state() { return this._state$.value; }\r\n  set state(val) { this._state$.next(val); }\r\n  create(element: ElementInfo) {\r\n    const ref = new DesignerRef(this._designer, element as ElementModel, 'widget');\r\n    const injector = Injector.create([{\r\n      provide: DesignerRef, useValue: ref\r\n    }], (this._element as ElementModel).injector);\r\n    (element as ElementModel).injector = injector;\r\n    return element;\r\n  }\r\n}\r\nexport interface DesignerElementComponent<T> {\r\n  model: ElementInfo<T>;\r\n  mode: DesignMode;\r\n  form: FormGroup;\r\n  onContinue?();\r\n  onFinish?();\r\n}\r\nexport declare type DesignMode = 'add' | 'edit' | 'widget';\r\nexport function clone(element: ElementModel) {\r\n  return JSON.parse(JSON.stringify(element));\r\n}\r\nexport function arrayOf(val: string | string[]) {\r\n  if (!val) return [];\r\n  if (isString(val)) return [val];\r\n  return val;\r\n}\r\n\r\nconst NAME_CHAR = /[A-Z]+/g,\r\n  NON_NAME_CHAR = /[^\\w]+/g;\r\n/**\r\n * \r\n * @param name\r\n */\r\nexport function programName(name: string) {\r\n  return name.\r\n    replace(' ', '-').\r\n    replace(NAME_CHAR, (c, i) => (i > 0 && name.charAt(i - 1) !== '-' ? '-' : '') + c.toLowerCase()).\r\n    replace(NON_NAME_CHAR, '_');\r\n}\r\nexport interface DesignerModel {\r\n  types: ElementModel<any>[];\r\n  tTypes: TemplateInfo[];\r\n  guides: ElementModel<any>[];\r\n  reports: ElementModel<any>[];\r\n  tReports: TemplateInfo[];\r\n  forms: ElementModel<any>[];\r\n  tForms: TemplateInfo[];\r\n  cubes: ElementModel<any>[];\r\n  tCubes: TemplateInfo[];\r\n  utilities: ElementModel<any>[];\r\n  tUtilities: TemplateInfo[];\r\n  folders: ElementModel<any>[];\r\n  roles: ElementModel<any>[];\r\n  rules: ElementModel<any>[];\r\n  tRules: TemplateInfo[];\r\n  policies: ElementModel<any>[];\r\n  tPolicies: TemplateInfo[];\r\n  views: ElementModel<any>[];\r\n  tViews: TemplateInfo[];\r\n  widgets: ElementModel<any>[];\r\n  tWidgets: TemplateInfo[];\r\n  actions: ElementModel<any>[];\r\n  tActions: TemplateInfo[];\r\n  states: ElementModel<any>[];\r\n}\r\nexport interface TemplateInfo {\r\n  template?: string;\r\n  title?: string;\r\n  key?: string;\r\n  icon?: string;\r\n  family?: string;\r\n  help?: string;\r\n  type?: string;\r\n  arguments?: FieldInfo[];\r\n}\r\nexport interface ElementModel<T = any> {\r\n  key?: string;\r\n  injector: Injector;\r\n  ordinal?: number;\r\n  help?: string;\r\n  configurationFile?: string;\r\n  template?: string;\r\n  icon?: string;\r\n  resource?: string;\r\n  copyOf?: string;\r\n  family?: string;\r\n  type?: string;\r\n  name: string;\r\n  title: string;\r\n  disabled?: boolean;\r\n  draft?: boolean;\r\n  empty?: boolean;\r\n  options?: T;\r\n  arguments?: FieldInfo[];\r\n  privileges?: PrivilegesModel;\r\n  filters?: CubeFilter;\r\n  columns?: FolderColumn[];\r\n  anomaly?: AnomalyPolicy;\r\n  verb?: string;\r\n  you?: string;\r\n  youMale?: string;\r\n  youFemale?: string;\r\n  past?: string;\r\n  pastMale?: string;\r\n  pastFemale?: string;\r\n  adjective?: string;\r\n  loggable?: boolean;\r\n  adjectivePlural?: string;\r\n  assignable?: boolean;\r\n  position?: PositionPolicy;\r\n  multiple?: boolean;\r\n  shape?: string;\r\n  group?: number;\r\n  dataType?: string;\r\n  steps?: GuideStep[];\r\n  currencyCode?: string;\r\n  axes?: CubeAxisModel[];\r\n  views?: CubeViewModel[];\r\n  indices?: CubeIndexModel[];\r\n  scope?: ScopeType;\r\n  color?: string;\r\n  backgroundColor?: string;\r\n  rules?: PermissionModel[];\r\n  positions?: { [key: string]: string[] };\r\n  patterns?: PatternModel[];\r\n  priority?: number;\r\n  cubes?: string[];\r\n  value?: string;\r\n  sequencePolicy?: 'Both' | 'Either' | 'Higher';\r\n}\r\nexport interface CubeIndexModel {\r\n  name: string;\r\n  accumulate?: boolean;\r\n  hidden?: boolean;\r\n  title: string;\r\n}\r\nexport interface CubeViewModel {\r\n  privileges?: PrivilegesModel;\r\n  xAxis: string[];\r\n  series?: string[];\r\n  filters?: AxesMap;\r\n  indices?: string[];\r\n  icon?: string;\r\n  guide?: string;\r\n  name: string;\r\n  title: string;\r\n  type: ViewType;\r\n  chartType?: ChartType;\r\n  indicesChartType?: ChartType;\r\n}\r\nexport interface PatternModel {\r\n  title: string;\r\n  axes: AxesMap;\r\n  hidden?: boolean;\r\n  rule?: string;\r\n  roles?: string[];\r\n}\r\nexport interface CubeAxisModel {\r\n  name: string;\r\n  title: string;\r\n  dataType: string;\r\n  combination?: boolean;\r\n  indexable?: boolean;\r\n  sensitive?: boolean;\r\n  resourceType?: string;\r\n  selectionMode?: 'Single' | 'Pattern' | 'Multiple' | 'Search' | 'None';\r\n  descendentOf?: string;\r\n}\r\nexport type AnomalyPolicy = 'Positions' | 'Recipients';\r\n\r\nexport interface PatternModel {\r\n  title: string;\r\n  resourceType?: string;\r\n  axes: AxesMap;\r\n  rule?: string;\r\n  roles?: string[];\r\n}\r\nexport interface PermissionModel {\r\n  name: string;\r\n  title: string;\r\n  rule?: string;\r\n  roles?: string[];\r\n}\r\nexport interface PrivilegesModel {\r\n  rule?: string;\r\n  roles?: string[];\r\n}\r\nexport interface DesignerInfo {\r\n  types: ElementInfo[];\r\n  guides: ElementInfo[];\r\n  reports: ElementInfo[];\r\n  tReports: TemplateInfo[];\r\n  forms: ElementInfo[];\r\n  cubes: ElementInfo[];\r\n  utilities: ElementInfo[];\r\n  folders: ElementInfo[];\r\n  roles: ElementInfo[];\r\n  rules: ElementInfo[];\r\n  policies: ElementInfo[];\r\n  views: ElementInfo[];\r\n  widgets: ElementInfo[];\r\n  actions: ElementInfo[];\r\n  states: ElementInfo[];\r\n}\r\nexport interface ElementInfo<T = any> {\r\n  family?: string;\r\n  type?: string;\r\n  key?: string;\r\n  name: string;\r\n  title: string;\r\n  disabled?: boolean;\r\n  draft?: boolean;\r\n  empty?: boolean;\r\n  options?: T;\r\n}\r\n"]}
@@ -1,22 +1,22 @@
1
- import { Component, ContentChild, Directive, EventEmitter, Inject, Input, Optional, Output } from "@angular/core";
2
- import { FormGroup, Validators } from "@angular/forms";
1
+ import { Component, ContentChild, Directive, EventEmitter, Inject, Input, Output } from "@angular/core";
2
+ import { Validators } from "@angular/forms";
3
3
  import { ComponentPortal } from "@angular/cdk/portal";
4
4
  import { Subject, takeUntil } from "rxjs";
5
5
  import { DesignerRef, programName, FAMILY_SVG } from "./declarations";
6
6
  import { LayoutComponent } from "../../core/layout/layout.component";
7
7
  import * as i0 from "@angular/core";
8
8
  import * as i1 from "@angular/forms";
9
- import * as i2 from "../../core/slots/pane-ref";
10
- import * as i3 from "../../core/component-factory-resolver";
11
- import * as i4 from "@angular/common";
12
- import * as i5 from "@angular/cdk/portal";
13
- import * as i6 from "@angular/material/toolbar";
14
- import * as i7 from "@angular/material/form-field";
15
- import * as i8 from "@angular/material/button";
16
- import * as i9 from "@angular/material/input";
17
- import * as i10 from "@angular/material/icon";
18
- import * as i11 from "../../core/popup/tooltip.directive";
19
- import * as i12 from "./designer-privileges.component";
9
+ import * as i2 from "../../core/component-factory-resolver";
10
+ import * as i3 from "@angular/common";
11
+ import * as i4 from "@angular/cdk/portal";
12
+ import * as i5 from "@angular/material/toolbar";
13
+ import * as i6 from "@angular/material/form-field";
14
+ import * as i7 from "@angular/material/button";
15
+ import * as i8 from "@angular/material/input";
16
+ import * as i9 from "@angular/material/icon";
17
+ import * as i10 from "../../core/popup/tooltip.directive";
18
+ import * as i11 from "./designer-privileges.component";
19
+ import * as i12 from "./icon-picker.component";
20
20
  import * as i13 from "../../core/pipes/sanitize-html.pipe";
21
21
  import * as i14 from "../../core/pipes/translate.pipe";
22
22
  import * as i15 from "./declarations";
@@ -62,14 +62,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImpor
62
62
  /**
63
63
  */
64
64
  export class DesignerItemComponent {
65
- constructor(_element, _fb, _pane, _ref, _cfr) {
65
+ constructor(_element, _fb, _ref, _cfr) {
66
66
  this._element = _element;
67
67
  this._fb = _fb;
68
- this._pane = _pane;
69
68
  this._ref = _ref;
70
69
  this._cfr = _cfr;
71
70
  this.svg = FAMILY_SVG;
72
- this.form = new FormGroup({});
73
71
  this.onContinue = new EventEmitter();
74
72
  this.onSave = new EventEmitter();
75
73
  this._destroy = new Subject();
@@ -80,12 +78,12 @@ export class DesignerItemComponent {
80
78
  const { instance } = componentRef;
81
79
  this._customDesignerInstance = instance;
82
80
  instance.model = this.model;
83
- if (this.mode === 'add' && !this._customDesignerInstance.onContinue) {
84
- this.mode = 'edit';
85
- this._addEditControls();
81
+ if (this.mode === 'add' && !instance.onContinue) {
86
82
  this.onContinue.emit();
83
+ this.mode = 'edit';
84
+ this._form();
87
85
  }
88
- this._customDesignerInstance.mode = this.mode;
86
+ instance.mode = this.mode;
89
87
  if (this.mode !== 'widget') {
90
88
  this.form.addControl('options', instance.form, { emitEvent: false });
91
89
  instance.form.patchValue(this.model.options, { emitEvent: false });
@@ -103,6 +101,8 @@ export class DesignerItemComponent {
103
101
  if (this.mode == 'add') {
104
102
  this.form.markAsDirty();
105
103
  this.form.patchValue({});
104
+ if (this.model.copyOf)
105
+ this.mode = 'edit';
106
106
  }
107
107
  if (this.model.template) {
108
108
  const comp = this._cfr.component(this.model.template);
@@ -113,29 +113,29 @@ export class DesignerItemComponent {
113
113
  else if (this.mode === 'add')
114
114
  this.mode = 'edit';
115
115
  this.mode === 'edit' &&
116
- this._addEditControls();
116
+ this._form();
117
117
  this.mode !== 'widget' &&
118
118
  this._ref._state$.pipe(takeUntil(this._destroy)).subscribe(v => this.optionsstate = v);
119
119
  }
120
- _addEditControls() {
120
+ _form() {
121
121
  const name = this._fb.control(null, Validators.required), title = this._fb.control(null, Validators.required);
122
122
  this.model.resource && title.disable();
123
123
  if (this.model.draft)
124
124
  title.valueChanges.
125
- pipe(takeUntil(this._destroy)).subscribe((t) => t && name.setValue(programName(t)));
125
+ pipe( /*takeUntil(this._destroy)*/).subscribe((t) => t && name.setValue(programName(t)));
126
126
  else
127
127
  name.disable();
128
- this.form.addControl('name', name);
129
- this.form.addControl('title', title);
130
- this.model.privileges &&
131
- this.form.addControl('privileges', this._fb.group({
132
- rule: null,
133
- roles: this._fb.control(null),
134
- }), { emitEvent: false });
135
- this.form.patchValue(this.model, { emitEvent: !this.model.draft });
128
+ this.form.addControl('name', name, { emitEvent: false });
129
+ this.form.addControl('title', title, { emitEvent: false });
130
+ this.icon && this.form.addControl('icon', this._fb.control(null), { emitEvent: false });
131
+ this.privileges && this.form.addControl('privileges', this._fb.group({
132
+ rule: null,
133
+ roles: []
134
+ }));
135
+ this.form.patchValue(this.model, { emitEvent: false });
136
136
  }
137
137
  ngAfterViewInit() {
138
- this.mode !== 'widget' &&
138
+ (this.mode === 'edit' || (this.mode === 'add' && !this.options)) &&
139
139
  setTimeout(() => this._element.nativeElement.querySelector('input')?.focus());
140
140
  }
141
141
  unlock(evt) {
@@ -151,16 +151,15 @@ export class DesignerItemComponent {
151
151
  Object.assign(this.options, this._customDesignerInstance.form.getRawValue());
152
152
  }
153
153
  this.onContinue.emit();
154
- this._addEditControls();
155
154
  if (this._customDesignerInstance)
156
155
  this._customDesignerInstance.mode = 'edit';
157
156
  this.mode = 'edit';
157
+ this._form();
158
158
  }
159
159
  save() {
160
160
  Object.assign(this.model, this.form.getRawValue());
161
161
  this._customDesignerInstance?.onFinish && this._customDesignerInstance.onFinish();
162
162
  this.onSave.emit(this.model);
163
- this._pane.close();
164
163
  }
165
164
  /**
166
165
  * Ctrl-s save
@@ -177,17 +176,19 @@ export class DesignerItemComponent {
177
176
  this._destroy?.complete();
178
177
  }
179
178
  }
180
- DesignerItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: DesignerItemComponent, deps: [{ token: i0.ElementRef }, { token: i1.FormBuilder }, { token: i2.PaneRef, optional: true }, { token: DesignerRef }, { token: i3.BizDocComponentFactoryResolver }], target: i0.ɵɵFactoryTarget.Component });
181
- DesignerItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.0", type: DesignerItemComponent, selector: "bizdoc-designer-element", inputs: { form: "form" }, outputs: { onContinue: "continue", onSave: "save" }, queries: [{ propertyName: "editContent", first: true, predicate: EditContentDirective, descendants: true }, { propertyName: "widgetContent", first: true, predicate: WidgetContentDirective, descendants: true }], ngImport: i0, template: "<ng-conatiner [ngSwitch]=\"mode\">\r\n <!--add mode-->\r\n <form autocomplete=\"off\" class=\"column\" *ngSwitchCase=\"'add'\">\r\n <!--arguments-->\r\n <ng-container *ngIf=\"arguments\" (attached)=\"argumentsattached($event)\" [cdkPortalOutlet]=\"arguments\"></ng-container>\r\n <!--options-->\r\n <ng-container *ngIf=\"options\" (attached)=\"optionsattached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n <div class=\"row actions\">\r\n <span class=\"divider\"></span>\r\n <button mat-stroked-button [disabled]=\"!form.valid\" (click)=\"continue()\">{{'Continue'|translate}}&nbsp;<mat-icon>double_arrow</mat-icon></button>\r\n </div>\r\n </form>\r\n <!--edit mode-->\r\n <ng-container *ngSwitchCase=\"'edit'\">\r\n <mat-toolbar>\r\n <button mat-icon-button (click)=\"save()\" [disabled]=\"!form.valid || !form.dirty\"><mat-icon>save</mat-icon></button>\r\n </mat-toolbar>\r\n <p class=\"help\">{{model.help}}</p>\r\n <p *ngIf=\"model.resource\" class=\"message\" (click)=\"unlock($event)\" [innerHTML]=\"'UnlockMultilang'|translate\"></p>\r\n <form autocomplete=\"off\" [formGroup]=\"form\" class=\"column\"\r\n (document:keydown)=\"handleKeyboardEvent($event)\">\r\n <ng-container *ngIf=\"!optionsstate\">\r\n <div class=\"row\">\r\n <mat-form-field class=\"flex\">\r\n <mat-label>{{'Title'|translate}}</mat-label>\r\n <input matInput formControlName=\"title\" required #title />\r\n <mat-error *ngIf=\"form.get('title').hasError('required')\" [innerHTML]=\"'RequiredErr'|translate:('Title'|translate)\"></mat-error>\r\n </mat-form-field>\r\n &nbsp;\r\n <mat-form-field class=\"flex\">\r\n <mat-label>{{'Name'|translate}}</mat-label>\r\n <input matInput formControlName=\"name\" required />\r\n <mat-error *ngIf=\"form.get('name').hasError('required')\" [innerHTML]=\"'RequiredErr'|translate:('Name'|translate)\"></mat-error>\r\n </mat-form-field>\r\n </div>\r\n <!--arguments-->\r\n <ng-container *ngIf=\"arguments\" (attached)=\"argumentsattached($event)\" [cdkPortalOutlet]=\"arguments\"></ng-container>\r\n <!--options-->\r\n <ng-container *ngIf=\"options\" (attached)=\"optionsattached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n </ng-container>\r\n <ng-container [ngTemplateOutlet]=\"editContent?.templateRef\"></ng-container>\r\n <!--privileges-->\r\n <bizdoc-designer-privileges *ngIf=\"form.contains('privileges') && !optionsstate\" [form]=\"form.get('privileges')\"></bizdoc-designer-privileges>\r\n </form>\r\n </ng-container>\r\n <!--widget mode -->\r\n <ng-container *ngSwitchDefault>\r\n <ng-container *ngIf=\"model.family\">\r\n <div *ngIf=\"svg[model.family]\" [innerHTML]=\"svg[model.family]|sanitizeHtml\" [bizdocTooltip]=\"model.family\"></div>\r\n <div *ngIf=\"!svg[model.family]\">{{model.family}}</div>\r\n </ng-container>\r\n <ng-container [ngTemplateOutlet]=\"widgetContent?.templateRef\"></ng-container>\r\n <!--options-->\r\n <ng-container *ngIf=\"options\" (attached)=\"optionsattached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n </ng-container>\r\n</ng-conatiner>\r\n", styles: [":host{flex:1}::ng-deep form{padding:8px}::ng-deep .flex{flex:1}p.message{margin:5px}\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i4.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i4.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i4.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i5.CdkPortalOutlet, selector: "[cdkPortalOutlet]", inputs: ["cdkPortalOutlet"], outputs: ["attached"], exportAs: ["cdkPortalOutlet"] }, { kind: "component", type: i6.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { kind: "directive", type: i7.MatError, selector: "mat-error", inputs: ["id"] }, { kind: "component", type: i7.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i7.MatLabel, selector: "mat-label" }, { kind: "component", type: i8.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i9.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i10.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i11.TooltipDirective, selector: "[bizdocTooltip]", inputs: ["bizdocTooltip", "bizdocTooltipTemplate", "bizdocTooltipContext", "bizdocTooltipPosition", "bizdocTooltipDuration", "bizdocTooltipDisabled"] }, { kind: "component", type: i12.DesignerPrivilegesComponent, selector: "bizdoc-designer-privileges", inputs: ["form"] }, { kind: "pipe", type: i13.SanitizeHtmlPipe, name: "sanitizeHtml" }, { kind: "pipe", type: i14.TranslatePipe, name: "translate" }] });
179
+ DesignerItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: DesignerItemComponent, deps: [{ token: i0.ElementRef }, { token: i1.FormBuilder }, { token: DesignerRef }, { token: i2.BizDocComponentFactoryResolver }], target: i0.ɵɵFactoryTarget.Component });
180
+ DesignerItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.0", type: DesignerItemComponent, selector: "bizdoc-designer-element", inputs: { privileges: "privileges", icon: "icon", form: "form" }, outputs: { onContinue: "continue", onSave: "save" }, queries: [{ propertyName: "editContent", first: true, predicate: EditContentDirective, descendants: true }, { propertyName: "widgetContent", first: true, predicate: WidgetContentDirective, descendants: true }], ngImport: i0, template: " <!--widget mode -->\r\n<ng-container *ngIf=\"mode === 'widget'; else editing\">\r\n <ng-container *ngIf=\"model.family\">\r\n <div *ngIf=\"svg[model.family]\" [innerHTML]=\"svg[model.family]|sanitizeHtml\" [bizdocTooltip]=\"model.family\"></div>\r\n <div *ngIf=\"!svg[model.family]\">{{model.family}}</div>\r\n </ng-container>\r\n <!--options-->\r\n <ng-container (attached)=\"optionsattached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n <ng-container [ngTemplateOutlet]=\"widgetContent?.templateRef\"></ng-container>\r\n</ng-container>\r\n<!--add or edit mode-->\r\n<ng-template #editing>\r\n <ng-container *ngIf=\"mode === 'edit'\">\r\n <mat-toolbar>\r\n <button mat-icon-button (click)=\"save()\" [disabled]=\"!form.valid || !form.dirty\"><mat-icon>save</mat-icon></button>\r\n </mat-toolbar>\r\n <p *ngIf=\"model.resource\" class=\"message\" (click)=\"unlock($event)\" [innerHTML]=\"'UnlockMultilang'|translate\"></p>\r\n </ng-container>\r\n <form autocomplete=\"off\" [formGroup]=\"form\" class=\"column\" (keydown)=\"handleKeyboardEvent($event)\">\r\n <ng-container *ngIf=\"mode === 'edit' && !optionsstate\">\r\n <div class=\"row\">\r\n <mat-form-field class=\"flex\">\r\n <mat-label>{{'Title'|translate}}</mat-label>\r\n <input matInput formControlName=\"title\" required #title />\r\n <mat-error *ngIf=\"form.get('title').hasError('required')\" [innerHTML]=\"'RequiredErr'|translate:('Title'|translate)\"></mat-error>\r\n </mat-form-field>\r\n &nbsp;\r\n <mat-form-field class=\"flex\">\r\n <mat-label>{{'Name'|translate}}</mat-label>\r\n <input matInput formControlName=\"name\" required />\r\n <mat-error *ngIf=\"form.get('name').hasError('required')\" [innerHTML]=\"'RequiredErr'|translate:('Name'|translate)\"></mat-error>\r\n </mat-form-field>\r\n </div>\r\n <bizdoc-icon-picker *ngIf=\"icon\" formControlName=\"icon\" required></bizdoc-icon-picker>\r\n </ng-container>\r\n <!--arguments-->\r\n <ng-container *ngIf=\"arguments\" (attached)=\"argumentsattached($event)\" [cdkPortalOutlet]=\"arguments\"></ng-container>\r\n <!--options-->\r\n <ng-container *ngIf=\"options\" (attached)=\"optionsattached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n <ng-container *ngIf=\"mode === 'edit'\" [ngTemplateOutlet]=\"editContent?.templateRef\"></ng-container>\r\n <!--privileges-->\r\n <bizdoc-designer-privileges *ngIf=\"form.contains('privileges') && !optionsstate\" [form]=\"form.get('privileges')\"></bizdoc-designer-privileges>\r\n </form>\r\n <div class=\"row actions\" *ngIf=\"mode === 'add'\">\r\n <span class=\"divider\"></span>\r\n <button mat-stroked-button [disabled]=\"!form.valid\" (click)=\"continue()\" type=\"button\">{{'Continue'|translate}}&nbsp;<mat-icon>double_arrow</mat-icon></button>\r\n </div>\r\n</ng-template>\r\n", styles: [":host{flex:1}::ng-deep form{padding:8px}::ng-deep .flex{flex:1}p.message{margin:5px}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i4.CdkPortalOutlet, selector: "[cdkPortalOutlet]", inputs: ["cdkPortalOutlet"], outputs: ["attached"], exportAs: ["cdkPortalOutlet"] }, { kind: "component", type: i5.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { kind: "directive", type: i6.MatError, selector: "mat-error", inputs: ["id"] }, { kind: "component", type: i6.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i6.MatLabel, selector: "mat-label" }, { kind: "component", type: i7.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i8.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i9.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i10.TooltipDirective, selector: "[bizdocTooltip]", inputs: ["bizdocTooltip", "bizdocTooltipTemplate", "bizdocTooltipContext", "bizdocTooltipPosition", "bizdocTooltipDuration", "bizdocTooltipDisabled"] }, { kind: "component", type: i11.DesignerPrivilegesComponent, selector: "bizdoc-designer-privileges", inputs: ["form"] }, { kind: "component", type: i12.IconPickerComponent, selector: "bizdoc-icon-picker", inputs: ["value", "required", "disabled"], outputs: ["valueChanges"] }, { kind: "pipe", type: i13.SanitizeHtmlPipe, name: "sanitizeHtml" }, { kind: "pipe", type: i14.TranslatePipe, name: "translate" }] });
182
181
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: DesignerItemComponent, decorators: [{
183
182
  type: Component,
184
- args: [{ selector: 'bizdoc-designer-element', template: "<ng-conatiner [ngSwitch]=\"mode\">\r\n <!--add mode-->\r\n <form autocomplete=\"off\" class=\"column\" *ngSwitchCase=\"'add'\">\r\n <!--arguments-->\r\n <ng-container *ngIf=\"arguments\" (attached)=\"argumentsattached($event)\" [cdkPortalOutlet]=\"arguments\"></ng-container>\r\n <!--options-->\r\n <ng-container *ngIf=\"options\" (attached)=\"optionsattached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n <div class=\"row actions\">\r\n <span class=\"divider\"></span>\r\n <button mat-stroked-button [disabled]=\"!form.valid\" (click)=\"continue()\">{{'Continue'|translate}}&nbsp;<mat-icon>double_arrow</mat-icon></button>\r\n </div>\r\n </form>\r\n <!--edit mode-->\r\n <ng-container *ngSwitchCase=\"'edit'\">\r\n <mat-toolbar>\r\n <button mat-icon-button (click)=\"save()\" [disabled]=\"!form.valid || !form.dirty\"><mat-icon>save</mat-icon></button>\r\n </mat-toolbar>\r\n <p class=\"help\">{{model.help}}</p>\r\n <p *ngIf=\"model.resource\" class=\"message\" (click)=\"unlock($event)\" [innerHTML]=\"'UnlockMultilang'|translate\"></p>\r\n <form autocomplete=\"off\" [formGroup]=\"form\" class=\"column\"\r\n (document:keydown)=\"handleKeyboardEvent($event)\">\r\n <ng-container *ngIf=\"!optionsstate\">\r\n <div class=\"row\">\r\n <mat-form-field class=\"flex\">\r\n <mat-label>{{'Title'|translate}}</mat-label>\r\n <input matInput formControlName=\"title\" required #title />\r\n <mat-error *ngIf=\"form.get('title').hasError('required')\" [innerHTML]=\"'RequiredErr'|translate:('Title'|translate)\"></mat-error>\r\n </mat-form-field>\r\n &nbsp;\r\n <mat-form-field class=\"flex\">\r\n <mat-label>{{'Name'|translate}}</mat-label>\r\n <input matInput formControlName=\"name\" required />\r\n <mat-error *ngIf=\"form.get('name').hasError('required')\" [innerHTML]=\"'RequiredErr'|translate:('Name'|translate)\"></mat-error>\r\n </mat-form-field>\r\n </div>\r\n <!--arguments-->\r\n <ng-container *ngIf=\"arguments\" (attached)=\"argumentsattached($event)\" [cdkPortalOutlet]=\"arguments\"></ng-container>\r\n <!--options-->\r\n <ng-container *ngIf=\"options\" (attached)=\"optionsattached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n </ng-container>\r\n <ng-container [ngTemplateOutlet]=\"editContent?.templateRef\"></ng-container>\r\n <!--privileges-->\r\n <bizdoc-designer-privileges *ngIf=\"form.contains('privileges') && !optionsstate\" [form]=\"form.get('privileges')\"></bizdoc-designer-privileges>\r\n </form>\r\n </ng-container>\r\n <!--widget mode -->\r\n <ng-container *ngSwitchDefault>\r\n <ng-container *ngIf=\"model.family\">\r\n <div *ngIf=\"svg[model.family]\" [innerHTML]=\"svg[model.family]|sanitizeHtml\" [bizdocTooltip]=\"model.family\"></div>\r\n <div *ngIf=\"!svg[model.family]\">{{model.family}}</div>\r\n </ng-container>\r\n <ng-container [ngTemplateOutlet]=\"widgetContent?.templateRef\"></ng-container>\r\n <!--options-->\r\n <ng-container *ngIf=\"options\" (attached)=\"optionsattached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n </ng-container>\r\n</ng-conatiner>\r\n", styles: [":host{flex:1}::ng-deep form{padding:8px}::ng-deep .flex{flex:1}p.message{margin:5px}\n"] }]
185
- }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.FormBuilder }, { type: i2.PaneRef, decorators: [{
186
- type: Optional
187
- }] }, { type: i15.DesignerRef, decorators: [{
183
+ args: [{ selector: 'bizdoc-designer-element', template: " <!--widget mode -->\r\n<ng-container *ngIf=\"mode === 'widget'; else editing\">\r\n <ng-container *ngIf=\"model.family\">\r\n <div *ngIf=\"svg[model.family]\" [innerHTML]=\"svg[model.family]|sanitizeHtml\" [bizdocTooltip]=\"model.family\"></div>\r\n <div *ngIf=\"!svg[model.family]\">{{model.family}}</div>\r\n </ng-container>\r\n <!--options-->\r\n <ng-container (attached)=\"optionsattached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n <ng-container [ngTemplateOutlet]=\"widgetContent?.templateRef\"></ng-container>\r\n</ng-container>\r\n<!--add or edit mode-->\r\n<ng-template #editing>\r\n <ng-container *ngIf=\"mode === 'edit'\">\r\n <mat-toolbar>\r\n <button mat-icon-button (click)=\"save()\" [disabled]=\"!form.valid || !form.dirty\"><mat-icon>save</mat-icon></button>\r\n </mat-toolbar>\r\n <p *ngIf=\"model.resource\" class=\"message\" (click)=\"unlock($event)\" [innerHTML]=\"'UnlockMultilang'|translate\"></p>\r\n </ng-container>\r\n <form autocomplete=\"off\" [formGroup]=\"form\" class=\"column\" (keydown)=\"handleKeyboardEvent($event)\">\r\n <ng-container *ngIf=\"mode === 'edit' && !optionsstate\">\r\n <div class=\"row\">\r\n <mat-form-field class=\"flex\">\r\n <mat-label>{{'Title'|translate}}</mat-label>\r\n <input matInput formControlName=\"title\" required #title />\r\n <mat-error *ngIf=\"form.get('title').hasError('required')\" [innerHTML]=\"'RequiredErr'|translate:('Title'|translate)\"></mat-error>\r\n </mat-form-field>\r\n &nbsp;\r\n <mat-form-field class=\"flex\">\r\n <mat-label>{{'Name'|translate}}</mat-label>\r\n <input matInput formControlName=\"name\" required />\r\n <mat-error *ngIf=\"form.get('name').hasError('required')\" [innerHTML]=\"'RequiredErr'|translate:('Name'|translate)\"></mat-error>\r\n </mat-form-field>\r\n </div>\r\n <bizdoc-icon-picker *ngIf=\"icon\" formControlName=\"icon\" required></bizdoc-icon-picker>\r\n </ng-container>\r\n <!--arguments-->\r\n <ng-container *ngIf=\"arguments\" (attached)=\"argumentsattached($event)\" [cdkPortalOutlet]=\"arguments\"></ng-container>\r\n <!--options-->\r\n <ng-container *ngIf=\"options\" (attached)=\"optionsattached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n <ng-container *ngIf=\"mode === 'edit'\" [ngTemplateOutlet]=\"editContent?.templateRef\"></ng-container>\r\n <!--privileges-->\r\n <bizdoc-designer-privileges *ngIf=\"form.contains('privileges') && !optionsstate\" [form]=\"form.get('privileges')\"></bizdoc-designer-privileges>\r\n </form>\r\n <div class=\"row actions\" *ngIf=\"mode === 'add'\">\r\n <span class=\"divider\"></span>\r\n <button mat-stroked-button [disabled]=\"!form.valid\" (click)=\"continue()\" type=\"button\">{{'Continue'|translate}}&nbsp;<mat-icon>double_arrow</mat-icon></button>\r\n </div>\r\n</ng-template>\r\n", styles: [":host{flex:1}::ng-deep form{padding:8px}::ng-deep .flex{flex:1}p.message{margin:5px}\n"] }]
184
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.FormBuilder }, { type: i15.DesignerRef, decorators: [{
188
185
  type: Inject,
189
186
  args: [DesignerRef]
190
- }] }, { type: i3.BizDocComponentFactoryResolver }]; }, propDecorators: { form: [{
187
+ }] }, { type: i2.BizDocComponentFactoryResolver }]; }, propDecorators: { privileges: [{
188
+ type: Input
189
+ }], icon: [{
190
+ type: Input
191
+ }], form: [{
191
192
  type: Input
192
193
  }], onContinue: [{
193
194
  type: Output,
@@ -202,4 +203,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImpor
202
203
  type: ContentChild,
203
204
  args: [WidgetContentDirective]
204
205
  }] } });
205
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"designer-element.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/admin/configuration-designer/designer-element.component.ts","../../../../../../libraries/core/src/lib/admin/configuration-designer/designer-element.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ComponentRef, ContentChild, Directive, ElementRef, EventEmitter, Inject, Input, OnDestroy, Optional, Output, TemplateRef } from \"@angular/core\";\r\nimport { FormBuilder, FormControl, FormGroup, Validators } from \"@angular/forms\";\r\nimport { ComponentPortal, Portal } from \"@angular/cdk/portal\";\r\nimport { Subject, takeUntil } from \"rxjs\";\r\nimport { BizDocComponentFactoryResolver } from \"../../core/component-factory-resolver\";\r\nimport { Role } from \"../../core/models\";\r\nimport { DesignerRef, ElementModel, programName, DesignMode, FAMILY_SVG, DesignerElementComponent } from \"./declarations\";\r\nimport { LayoutComponent } from \"../../core/layout/layout.component\";\r\nimport { PaneRef } from \"../../core/slots/pane-ref\";\r\n\r\n@Directive({\r\n  selector: '[bizdocEditContent]'\r\n})\r\nexport class EditContentDirective {\r\n  constructor(public templateRef: TemplateRef<unknown>) { }\r\n}\r\n@Directive({\r\n  selector: '[bizdocContent]'\r\n})\r\nexport class WidgetContentDirective {\r\n  constructor(public templateRef: TemplateRef<unknown>) { }\r\n}\r\n@Directive({\r\n  selector: '[bizdocAddContent]'\r\n})\r\nexport class AddContentDirective {\r\n  constructor(public templateRef: TemplateRef<unknown>) { }\r\n}\r\n\r\n/**\r\n*/\r\n@Component({\r\n  selector: 'bizdoc-designer-element',\r\n  templateUrl: 'designer-element.component.html',\r\n  styleUrls: ['designer-element.component.scss'],\r\n})\r\nexport\r\n  class DesignerItemComponent implements AfterViewInit, OnDestroy {\r\n  readonly svg = FAMILY_SVG;\r\n  @Input() form: FormGroup = new FormGroup({});\r\n  @Output('continue') readonly onContinue = new EventEmitter();\r\n  @Output('save') readonly onSave = new EventEmitter<ElementModel>();\r\n  roles: Role[];\r\n  froles: Role[];\r\n  @ContentChild(EditContentDirective) editContent: EditContentDirective;\r\n  @ContentChild(WidgetContentDirective) widgetContent: WidgetContentDirective;\r\n  options: Portal<any>;\r\n  arguments: Portal<any>;\r\n  mode: DesignMode;\r\n  model: ElementModel<any>;\r\n  rolesfilter: FormControl;\r\n  private _customDesignerInstance: DesignerElementComponent<any>;\r\n  private readonly _destroy = new Subject<void>();\r\n  optionsstate: any;\r\n  constructor(\r\n    private _element: ElementRef<HTMLDivElement>,\r\n    private _fb: FormBuilder,\r\n    @Optional() private _pane: PaneRef,\r\n    @Inject(DesignerRef) private _ref: DesignerRef<any>,\r\n    private _cfr: BizDocComponentFactoryResolver,\r\n  ) {\r\n    this.mode = _ref.mode;\r\n    this.model = _ref.model as ElementModel;\r\n  }\r\n  optionsattached(componentRef: ComponentRef<DesignerElementComponent<any>>) {\r\n    const { instance } = componentRef;\r\n    this._customDesignerInstance = instance as DesignerElementComponent<any>;\r\n    instance.model = this.model;\r\n    if (this.mode === 'add' && !this._customDesignerInstance.onContinue) {\r\n      this.mode = 'edit';\r\n      this._addEditControls();\r\n      this.onContinue.emit();\r\n    }\r\n    this._customDesignerInstance.mode = this.mode;\r\n    if (this.mode !== 'widget') {\r\n      this.form.addControl('options', instance.form, { emitEvent: false });\r\n      instance.form.patchValue(this.model.options, { emitEvent: false });\r\n    }\r\n  }\r\n  argumentsattached(componentRef: ComponentRef<LayoutComponent>) {\r\n    const { instance } = componentRef;\r\n    instance.fields = this.model.arguments;\r\n    instance.model = this.model.options;\r\n    instance.layout();\r\n    this.mode !== 'widget' &&\r\n      this.form.addControl('options', instance.form, { emitEvent: false });\r\n  }\r\n  ngOnInit() {\r\n    if (this.mode == 'add') {\r\n      this.form.markAsDirty();\r\n      this.form.patchValue({});\r\n    }\r\n    if (this.model.template) {\r\n      const comp = this._cfr.component(this.model.template);\r\n      this.options = new ComponentPortal<DesignerElementComponent<any>>(comp);\r\n    }\r\n    else if (this.mode !== 'widget' && this.model.arguments?.length)\r\n      this.arguments = new ComponentPortal(LayoutComponent);\r\n    else if (this.mode === 'add')\r\n      this.mode = 'edit';\r\n\r\n    this.mode === 'edit' &&\r\n      this._addEditControls();\r\n    this.mode !== 'widget' &&\r\n      this._ref._state$.pipe(takeUntil(this._destroy)).subscribe(v =>\r\n        this.optionsstate = v);\r\n  }\r\n  private _addEditControls() {\r\n    const name = this._fb.control(null, Validators.required),\r\n      title = this._fb.control(null, Validators.required);\r\n    this.model.resource && title.disable();\r\n    if (this.model.draft) title.valueChanges.\r\n      pipe(takeUntil(this._destroy)).subscribe((t: string) =>\r\n        t && name.setValue(programName(t))\r\n      );\r\n    else\r\n      name.disable();\r\n    this.form.addControl('name', name);\r\n    this.form.addControl('title', title);\r\n    this.model.privileges &&\r\n      this.form.addControl('privileges',\r\n        this._fb.group({\r\n          rule: null,\r\n          roles: this._fb.control<string[]>(null),\r\n        }), { emitEvent: false });\r\n    this.form.patchValue(this.model, { emitEvent: !this.model.draft });\r\n  }\r\n  ngAfterViewInit() {\r\n    this.mode !== 'widget' &&\r\n      setTimeout(() => this._element.nativeElement.querySelector('input')?.focus());\r\n  }\r\n  unlock(evt: Event) {\r\n    if ((evt.srcElement as HTMLElement).tagName !== 'A') return;\r\n    this.model.resource = null;\r\n    this.form.get('title').enable();\r\n    this._ref._unlock$.next(false);\r\n  }\r\n  continue() {\r\n    if (this._customDesignerInstance?.onContinue) {\r\n      this._customDesignerInstance.onContinue();\r\n      Object.assign(this.options, this._customDesignerInstance.form.getRawValue());\r\n    }\r\n    this.onContinue.emit();\r\n    this._addEditControls();\r\n    if (this._customDesignerInstance)\r\n      this._customDesignerInstance.mode = 'edit';\r\n    this.mode = 'edit';\r\n  }\r\n  save() {\r\n    Object.assign(this.model, this.form.getRawValue());\r\n    this._customDesignerInstance?.onFinish && this._customDesignerInstance.onFinish();\r\n    this.onSave.emit(this.model);\r\n    this._pane.close();\r\n  }\r\n  /**\r\n   * Ctrl-s save\r\n   * @param event\r\n   */\r\n  handleKeyboardEvent(event: KeyboardEvent) {\r\n    if (event.ctrlKey && (event.which === 83 || event.which === 115)) {\r\n      this.form.valid && this.save();\r\n      event.preventDefault();\r\n    }\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._destroy?.next();\r\n    this._destroy?.complete();\r\n  }\r\n}\r\n","<ng-conatiner [ngSwitch]=\"mode\">\r\n  <!--add mode-->\r\n  <form autocomplete=\"off\" class=\"column\" *ngSwitchCase=\"'add'\">\r\n    <!--arguments-->\r\n    <ng-container *ngIf=\"arguments\" (attached)=\"argumentsattached($event)\" [cdkPortalOutlet]=\"arguments\"></ng-container>\r\n    <!--options-->\r\n    <ng-container *ngIf=\"options\" (attached)=\"optionsattached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n    <div class=\"row actions\">\r\n      <span class=\"divider\"></span>\r\n      <button mat-stroked-button [disabled]=\"!form.valid\" (click)=\"continue()\">{{'Continue'|translate}}&nbsp;<mat-icon>double_arrow</mat-icon></button>\r\n    </div>\r\n  </form>\r\n  <!--edit mode-->\r\n  <ng-container *ngSwitchCase=\"'edit'\">\r\n    <mat-toolbar>\r\n      <button mat-icon-button (click)=\"save()\" [disabled]=\"!form.valid || !form.dirty\"><mat-icon>save</mat-icon></button>\r\n    </mat-toolbar>\r\n    <p class=\"help\">{{model.help}}</p>\r\n    <p *ngIf=\"model.resource\" class=\"message\" (click)=\"unlock($event)\" [innerHTML]=\"'UnlockMultilang'|translate\"></p>\r\n    <form autocomplete=\"off\" [formGroup]=\"form\" class=\"column\"\r\n          (document:keydown)=\"handleKeyboardEvent($event)\">\r\n      <ng-container *ngIf=\"!optionsstate\">\r\n        <div class=\"row\">\r\n          <mat-form-field class=\"flex\">\r\n            <mat-label>{{'Title'|translate}}</mat-label>\r\n            <input matInput formControlName=\"title\" required #title />\r\n            <mat-error *ngIf=\"form.get('title').hasError('required')\" [innerHTML]=\"'RequiredErr'|translate:('Title'|translate)\"></mat-error>\r\n          </mat-form-field>\r\n          &nbsp;\r\n          <mat-form-field class=\"flex\">\r\n            <mat-label>{{'Name'|translate}}</mat-label>\r\n            <input matInput formControlName=\"name\" required />\r\n            <mat-error *ngIf=\"form.get('name').hasError('required')\" [innerHTML]=\"'RequiredErr'|translate:('Name'|translate)\"></mat-error>\r\n          </mat-form-field>\r\n        </div>\r\n        <!--arguments-->\r\n        <ng-container *ngIf=\"arguments\" (attached)=\"argumentsattached($event)\" [cdkPortalOutlet]=\"arguments\"></ng-container>\r\n        <!--options-->\r\n        <ng-container *ngIf=\"options\" (attached)=\"optionsattached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n      </ng-container>\r\n      <ng-container [ngTemplateOutlet]=\"editContent?.templateRef\"></ng-container>\r\n      <!--privileges-->\r\n      <bizdoc-designer-privileges *ngIf=\"form.contains('privileges') && !optionsstate\" [form]=\"form.get('privileges')\"></bizdoc-designer-privileges>\r\n    </form>\r\n  </ng-container>\r\n  <!--widget mode -->\r\n  <ng-container *ngSwitchDefault>\r\n    <ng-container *ngIf=\"model.family\">\r\n      <div *ngIf=\"svg[model.family]\" [innerHTML]=\"svg[model.family]|sanitizeHtml\" [bizdocTooltip]=\"model.family\"></div>\r\n      <div *ngIf=\"!svg[model.family]\">{{model.family}}</div>\r\n    </ng-container>\r\n    <ng-container [ngTemplateOutlet]=\"widgetContent?.templateRef\"></ng-container>\r\n    <!--options-->\r\n    <ng-container *ngIf=\"options\" (attached)=\"optionsattached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n  </ng-container>\r\n</ng-conatiner>\r\n"]}
206
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"designer-element.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/admin/configuration-designer/designer-element.component.ts","../../../../../../libraries/core/src/lib/admin/configuration-designer/designer-element.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ComponentRef, ContentChild, Directive, ElementRef, EventEmitter, Inject, Input, OnDestroy, Output, TemplateRef } from \"@angular/core\";\r\nimport { FormBuilder, FormControl, FormGroup, Validators } from \"@angular/forms\";\r\nimport { ComponentPortal, Portal } from \"@angular/cdk/portal\";\r\nimport { Subject, takeUntil } from \"rxjs\";\r\nimport { BizDocComponentFactoryResolver } from \"../../core/component-factory-resolver\";\r\nimport { DesignerRef, ElementModel, programName, DesignMode, FAMILY_SVG, DesignerElementComponent } from \"./declarations\";\r\nimport { LayoutComponent } from \"../../core/layout/layout.component\";\r\nimport { ESCAPE } from \"@angular/cdk/keycodes\";\r\nimport { element } from \"protractor\";\r\n\r\n@Directive({\r\n  selector: '[bizdocEditContent]'\r\n})\r\nexport class EditContentDirective {\r\n  constructor(public templateRef: TemplateRef<unknown>) { }\r\n}\r\n@Directive({\r\n  selector: '[bizdocContent]'\r\n})\r\nexport class WidgetContentDirective {\r\n  constructor(public templateRef: TemplateRef<unknown>) { }\r\n}\r\n@Directive({\r\n  selector: '[bizdocAddContent]'\r\n})\r\nexport class AddContentDirective {\r\n  constructor(public templateRef: TemplateRef<unknown>) { }\r\n}\r\n\r\n/**\r\n*/\r\n@Component({\r\n  selector: 'bizdoc-designer-element',\r\n  templateUrl: 'designer-element.component.html',\r\n  styleUrls: ['designer-element.component.scss'],\r\n})\r\nexport\r\n  class DesignerItemComponent implements AfterViewInit, OnDestroy {\r\n  readonly svg = FAMILY_SVG;\r\n  @Input() privileges: boolean;\r\n  @Input() icon: boolean;\r\n  @Input() form: FormGroup;\r\n  @Output('continue') readonly onContinue = new EventEmitter();\r\n  @Output('save') readonly onSave = new EventEmitter<ElementModel>();\r\n  @ContentChild(EditContentDirective) editContent: EditContentDirective;\r\n  @ContentChild(WidgetContentDirective) widgetContent: WidgetContentDirective;\r\n  options: Portal<any>;\r\n  arguments: Portal<any>;\r\n  mode: DesignMode;\r\n  model: ElementModel<any>;\r\n  private _customDesignerInstance: DesignerElementComponent<any>;\r\n  private readonly _destroy = new Subject<void>();\r\n  optionsstate: any;\r\n  constructor(\r\n    private _element: ElementRef<HTMLDivElement>,\r\n    private _fb: FormBuilder,\r\n    @Inject(DesignerRef) private _ref: DesignerRef<any>,\r\n    private _cfr: BizDocComponentFactoryResolver,\r\n  ) {\r\n    this.mode = _ref.mode;\r\n    this.model = _ref.model as ElementModel;\r\n  }\r\n  optionsattached(componentRef: ComponentRef<DesignerElementComponent<any>>) {\r\n    const { instance } = componentRef;\r\n    this._customDesignerInstance = instance as DesignerElementComponent<any>;\r\n    instance.model = this.model;\r\n    if (this.mode === 'add' && !instance.onContinue) {\r\n      this.onContinue.emit();\r\n      this.mode = 'edit';\r\n      this._form();\r\n    }\r\n    instance.mode = this.mode;\r\n    if (this.mode !== 'widget') {\r\n      this.form.addControl('options', instance.form, { emitEvent: false });\r\n      instance.form.patchValue(this.model.options, { emitEvent: false });\r\n    }\r\n  }\r\n  argumentsattached(componentRef: ComponentRef<LayoutComponent>) {\r\n    const { instance } = componentRef;\r\n    instance.fields = this.model.arguments;\r\n    instance.model = this.model.options;\r\n    instance.layout();\r\n    this.mode !== 'widget' &&\r\n      this.form.addControl('options', instance.form, { emitEvent: false });\r\n  }\r\n  ngOnInit() {\r\n    if (this.mode == 'add') {\r\n      this.form.markAsDirty();\r\n      this.form.patchValue({});\r\n      if (this.model.copyOf)\r\n        this.mode = 'edit';\r\n    }\r\n    if (this.model.template) {\r\n      const comp = this._cfr.component(this.model.template);\r\n      this.options = new ComponentPortal<DesignerElementComponent<any>>(comp);\r\n    }\r\n    else if (this.mode !== 'widget' && this.model.arguments?.length)\r\n      this.arguments = new ComponentPortal(LayoutComponent);\r\n    else if (this.mode === 'add')\r\n      this.mode = 'edit';\r\n\r\n    this.mode === 'edit' &&\r\n      this._form();\r\n    this.mode !== 'widget' &&\r\n      this._ref._state$.pipe(takeUntil(this._destroy)).subscribe(v =>\r\n        this.optionsstate = v);\r\n  }\r\n  private _form() {\r\n    const name = this._fb.control(null, Validators.required),\r\n      title = this._fb.control(null, Validators.required);\r\n    this.model.resource && title.disable();\r\n    if (this.model.draft) title.valueChanges.\r\n      pipe(/*takeUntil(this._destroy)*/).subscribe((t: string) =>\r\n        t && name.setValue(programName(t))\r\n      );\r\n    else\r\n      name.disable();\r\n    this.form.addControl('name', name, { emitEvent: false });\r\n    this.form.addControl('title', title, { emitEvent: false });\r\n    this.icon && this.form.addControl('icon', this._fb.control(null), { emitEvent: false });\r\n    this.privileges && this.form.addControl('privileges', this._fb.group({\r\n      rule: null,\r\n      roles: []\r\n    }));\r\n    this.form.patchValue(this.model, { emitEvent: false });\r\n  }\r\n  ngAfterViewInit() {\r\n    (this.mode === 'edit' || (this.mode === 'add' && !this.options)) &&\r\n      setTimeout(() => this._element.nativeElement.querySelector('input')?.focus());\r\n  }\r\n  unlock(evt: Event) {\r\n    if ((evt.srcElement as HTMLElement).tagName !== 'A') return;\r\n    this.model.resource = null;\r\n    this.form.get('title').enable();\r\n    this._ref._unlock$.next(false);\r\n  }\r\n  continue() {\r\n    if (this._customDesignerInstance?.onContinue) {\r\n      this._customDesignerInstance.onContinue();\r\n      Object.assign(this.options, this._customDesignerInstance.form.getRawValue());\r\n    }\r\n    this.onContinue.emit();\r\n    if (this._customDesignerInstance)\r\n      this._customDesignerInstance.mode = 'edit';\r\n    this.mode = 'edit';\r\n    this._form();\r\n  }\r\n  save() {\r\n    Object.assign(this.model, this.form.getRawValue());\r\n    this._customDesignerInstance?.onFinish && this._customDesignerInstance.onFinish();\r\n    this.onSave.emit(this.model);\r\n  }\r\n  /**\r\n   * Ctrl-s save\r\n   * @param event\r\n   */\r\n  handleKeyboardEvent(event: KeyboardEvent) {\r\n    if (event.ctrlKey && (event.which === 83 || event.which === 115)) {\r\n      this.form.valid && this.save();\r\n      event.preventDefault();\r\n    }\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._destroy?.next();\r\n    this._destroy?.complete();\r\n  }\r\n}\r\n","  <!--widget mode -->\r\n<ng-container *ngIf=\"mode === 'widget'; else editing\">\r\n  <ng-container *ngIf=\"model.family\">\r\n    <div *ngIf=\"svg[model.family]\" [innerHTML]=\"svg[model.family]|sanitizeHtml\" [bizdocTooltip]=\"model.family\"></div>\r\n    <div *ngIf=\"!svg[model.family]\">{{model.family}}</div>\r\n  </ng-container>\r\n  <!--options-->\r\n  <ng-container (attached)=\"optionsattached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n  <ng-container [ngTemplateOutlet]=\"widgetContent?.templateRef\"></ng-container>\r\n</ng-container>\r\n<!--add or edit mode-->\r\n<ng-template #editing>\r\n  <ng-container *ngIf=\"mode === 'edit'\">\r\n    <mat-toolbar>\r\n      <button mat-icon-button (click)=\"save()\" [disabled]=\"!form.valid || !form.dirty\"><mat-icon>save</mat-icon></button>\r\n    </mat-toolbar>\r\n    <p *ngIf=\"model.resource\" class=\"message\" (click)=\"unlock($event)\" [innerHTML]=\"'UnlockMultilang'|translate\"></p>\r\n  </ng-container>\r\n  <form autocomplete=\"off\" [formGroup]=\"form\" class=\"column\" (keydown)=\"handleKeyboardEvent($event)\">\r\n    <ng-container *ngIf=\"mode === 'edit' && !optionsstate\">\r\n      <div class=\"row\">\r\n        <mat-form-field class=\"flex\">\r\n          <mat-label>{{'Title'|translate}}</mat-label>\r\n          <input matInput formControlName=\"title\" required #title />\r\n          <mat-error *ngIf=\"form.get('title').hasError('required')\" [innerHTML]=\"'RequiredErr'|translate:('Title'|translate)\"></mat-error>\r\n        </mat-form-field>\r\n        &nbsp;\r\n        <mat-form-field class=\"flex\">\r\n          <mat-label>{{'Name'|translate}}</mat-label>\r\n          <input matInput formControlName=\"name\" required />\r\n          <mat-error *ngIf=\"form.get('name').hasError('required')\" [innerHTML]=\"'RequiredErr'|translate:('Name'|translate)\"></mat-error>\r\n        </mat-form-field>\r\n      </div>\r\n      <bizdoc-icon-picker *ngIf=\"icon\" formControlName=\"icon\" required></bizdoc-icon-picker>\r\n    </ng-container>\r\n    <!--arguments-->\r\n    <ng-container *ngIf=\"arguments\" (attached)=\"argumentsattached($event)\" [cdkPortalOutlet]=\"arguments\"></ng-container>\r\n    <!--options-->\r\n    <ng-container *ngIf=\"options\" (attached)=\"optionsattached($event)\" [cdkPortalOutlet]=\"options\"></ng-container>\r\n    <ng-container *ngIf=\"mode === 'edit'\" [ngTemplateOutlet]=\"editContent?.templateRef\"></ng-container>\r\n    <!--privileges-->\r\n    <bizdoc-designer-privileges *ngIf=\"form.contains('privileges') && !optionsstate\" [form]=\"form.get('privileges')\"></bizdoc-designer-privileges>\r\n  </form>\r\n  <div class=\"row actions\" *ngIf=\"mode === 'add'\">\r\n    <span class=\"divider\"></span>\r\n    <button mat-stroked-button [disabled]=\"!form.valid\" (click)=\"continue()\" type=\"button\">{{'Continue'|translate}}&nbsp;<mat-icon>double_arrow</mat-icon></button>\r\n  </div>\r\n</ng-template>\r\n"]}