@mediusinc/mng-commons 0.0.1-rc.3 → 0.0.1-rc.4

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 (56) hide show
  1. package/README.md +1 -1
  2. package/assets/i18n/en.json +105 -0
  3. package/assets/i18n/sl.json +110 -0
  4. package/assets/templates/tableview-route.component.html +5 -0
  5. package/esm2020/lib/api/models/builders/query-param.builder.mjs +2 -3
  6. package/esm2020/lib/components/action/action.component.mjs +1 -1
  7. package/esm2020/lib/components/action/dialog/action-dialog.component.mjs +13 -4
  8. package/esm2020/lib/components/form/editor/form-editor.component.mjs +17 -15
  9. package/esm2020/lib/components/form/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.mjs +28 -13
  10. package/esm2020/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.mjs +2 -4
  11. package/esm2020/lib/components/layout/app.breadcrumb.component.mjs +8 -9
  12. package/esm2020/lib/components/layout/app.menu.component.mjs +10 -24
  13. package/esm2020/lib/components/layout/app.menuitem.component.mjs +3 -5
  14. package/esm2020/lib/components/layout/app.topbar.component.mjs +32 -32
  15. package/esm2020/lib/components/tableview/route/tableview-route.abstract.component.mjs +1 -8
  16. package/esm2020/lib/components/tableview/tableview.component.mjs +2 -1
  17. package/esm2020/lib/components/tableview/tableview.component.service.mjs +1 -1
  18. package/esm2020/lib/config/formly.config.mjs +23 -52
  19. package/esm2020/lib/mng-commons.module.mjs +6 -31
  20. package/esm2020/lib/models/config/mng-config.model.mjs +1 -1
  21. package/esm2020/lib/models/descriptors/action-descriptor.model.mjs +46 -4
  22. package/esm2020/lib/models/descriptors/editor-descriptor.model.mjs +20 -1
  23. package/esm2020/lib/models/types/type.decorator.mjs +1 -2
  24. package/esm2020/lib/services/action.service.mjs +44 -14
  25. package/esm2020/lib/services/breadcrumb.service.mjs +62 -9
  26. package/esm2020/lib/services/configuration.service.mjs +1 -1
  27. package/esm2020/lib/services/menu.service.mjs +18 -7
  28. package/esm2020/lib/services/settings.service.mjs +46 -5
  29. package/esm2020/lib/utils/editor-formly.util.mjs +19 -8
  30. package/esm2020/lib/utils/i18n.util.mjs +29 -13
  31. package/esm2020/lib/utils/toast.util.mjs +26 -0
  32. package/esm2020/lib/utils/type.util.mjs +1 -5
  33. package/fesm2015/mediusinc-mng-commons.mjs +2458 -2274
  34. package/fesm2015/mediusinc-mng-commons.mjs.map +1 -1
  35. package/fesm2020/mediusinc-mng-commons.mjs +2603 -2426
  36. package/fesm2020/mediusinc-mng-commons.mjs.map +1 -1
  37. package/lib/components/form/editor/form-editor.component.d.ts +3 -1
  38. package/lib/components/layout/app.breadcrumb.component.d.ts +5 -7
  39. package/lib/components/layout/app.menu.component.d.ts +4 -3
  40. package/lib/components/layout/app.topbar.component.d.ts +2 -3
  41. package/lib/components/tableview/route/tableview-route.abstract.component.d.ts +0 -1
  42. package/lib/components/tableview/tableview.component.service.d.ts +2 -0
  43. package/lib/config/formly.config.d.ts +6 -0
  44. package/lib/mng-commons.module.d.ts +0 -3
  45. package/lib/models/config/mng-config.model.d.ts +1 -0
  46. package/lib/models/descriptors/action-descriptor.model.d.ts +21 -0
  47. package/lib/models/descriptors/editor-descriptor.model.d.ts +7 -0
  48. package/lib/services/action.service.d.ts +1 -1
  49. package/lib/services/breadcrumb.service.d.ts +9 -3
  50. package/lib/services/menu.service.d.ts +9 -4
  51. package/lib/services/settings.service.d.ts +13 -1
  52. package/lib/utils/i18n.util.d.ts +5 -4
  53. package/lib/utils/toast.util.d.ts +12 -0
  54. package/mediusinc-mng-commons-0.0.1-rc.4.tgz +0 -0
  55. package/package.json +36 -37
  56. package/mediusinc-mng-commons-0.0.1-rc.3.tgz +0 -0
@@ -30,11 +30,14 @@ export class FormlyFieldTableDialogFormComponent extends FieldType {
30
30
  .withIcon('pi pi-plus')
31
31
  .withClassName('mng-formly-field-table-form-dialog')
32
32
  .withSubmitFunction(ctx => {
33
+ if (!ctx.data?.item) {
34
+ throw new Error(`No item was provided in context, edit cannot be done.`);
35
+ }
33
36
  this.formState.submittedOn = Date.now();
34
37
  let value = this.formControl.value;
35
- value = [...value, ctx.data?.item];
38
+ value = [...value, ctx.data.item];
36
39
  this.formControl.patchValue(value);
37
- return of(value);
40
+ return of(ctx.data.item);
38
41
  })
39
42
  .withIsVisibleFunction(ctx => of(!this.options?.formState.disabled));
40
43
  this.toolbarActions.push(addAction);
@@ -45,11 +48,14 @@ export class FormlyFieldTableDialogFormComponent extends FieldType {
45
48
  .withIcon('pi pi-pencil')
46
49
  .withClassName('mng-formly-field-table-form-dialog')
47
50
  .withSubmitFunction(ctx => {
51
+ if (!ctx.data?.item) {
52
+ throw new Error(`No item was provided in context, edit cannot be done.`);
53
+ }
48
54
  this.formState.submittedOn = Date.now();
49
- let value = this.formControl.value;
50
- value[ctx.data?.actionData?.['itemIndex']] = ctx.data?.item;
51
- this.formControl.patchValue(value);
52
- return of(value);
55
+ let formControlValue = this.formControl.value;
56
+ formControlValue[ctx.data.actionData?.['itemIndex']] = ctx.data.item;
57
+ this.formControl.patchValue(formControlValue);
58
+ return of(ctx.data.item);
53
59
  })
54
60
  .withIsVisibleFunction(ctx => of(!this.options?.formState.disabled));
55
61
  this.rowActions.push(editAction);
@@ -60,12 +66,21 @@ export class FormlyFieldTableDialogFormComponent extends FieldType {
60
66
  .withTitle(null)
61
67
  .withIcon('pi pi-trash')
62
68
  .withRunFunction(ctx => {
63
- let value = this.formControl.value;
64
- // TODO: resolve ts ignore
65
- // @ts-ignore
66
- value = value.filter(i => i[this.descriptor.tableDescriptor.dataKeyProperty] !== ctx.data.item?.[this.descriptor.tableDescriptor.dataKeyProperty]);
67
- this.formControl.patchValue(value);
68
- return of(value);
69
+ if (!ctx.data?.item) {
70
+ throw new Error(`No item was provided in context, delete cannot be done.`);
71
+ }
72
+ let formControlValue = this.formControl.value;
73
+ const compareProperty = this.descriptor.tableDescriptor.dataKeyProperty ? this.descriptor.tableDescriptor.dataKeyProperty : this.descriptor.tableDescriptor.model.idPropertyName;
74
+ if (!compareProperty) {
75
+ throw new Error('Cannot compare items, please provide main table data key property or model id property.');
76
+ }
77
+ const ctxItem = ctx.data.item;
78
+ if (!ctxItem?.[compareProperty]) {
79
+ return formControlValue;
80
+ }
81
+ formControlValue = formControlValue.filter((i) => i[compareProperty] !== ctxItem[compareProperty]);
82
+ this.formControl.patchValue(formControlValue);
83
+ return of(ctx.data.item);
69
84
  })
70
85
  .withIsVisibleFunction(ctx => of(!this.options?.formState.disabled));
71
86
  this.rowActions.push(deleteAction);
@@ -91,4 +106,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
91
106
  type: Component,
92
107
  args: [{ selector: 'mng-formly-table-dialog-form-field', changeDetection: ChangeDetectionStrategy.OnPush, template: "<mng-table [descriptor]=\"descriptor.tableDescriptor\" [items]=\"items$\">\n <ng-template mngTemplate=\"caption\">\n <div class=\"flex flex-column md:flex-row md:justify-content-end table-header\">\n <label class=\"mng-datatable-form-label p-m-0\" [for]=\"key\">{{ to?.label! | translate }} <span *ngIf=\"to.required && to['hideRequiredMarker'] !== true\">*</span></label>\n <mng-action *ngFor=\"let action of toolbarActions\" [action]=\"action\"></mng-action>\n </div>\n </ng-template>\n <ng-template mngTemplate=\"columnAction\" let-item=\"rowItem\" let-idx=\"rowIndex\">\n <mng-action *ngFor=\"let action of rowActions\"\n [action]=\"action\" [item]=\"item\" [itemId]=\"descriptor.tableviewDescriptor.model.idPropertyName ? item[descriptor.tableviewDescriptor.model.idPropertyName] : undefined\" [actionData]=\"{ itemIndex: idx }\">\n </mng-action>\n </ng-template>\n</mng-table>\n", styles: [".submit-button{display:none!important;visibility:hidden}\n"] }]
93
108
  }] });
94
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly-field-table-dialog-form.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/mng-commons/src/lib/components/form/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.ts","../../../../../../../../../projects/mng-commons/src/lib/components/form/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,uBAAuB,EAAE,SAAS,EAAoB,MAAM,eAAe,CAAC;AAEpF,OAAO,EAAC,SAAS,EAAC,MAAM,kBAAkB,CAAC;AAC3C,OAAO,EAAa,EAAE,EAAE,aAAa,EAAwB,MAAM,MAAM,CAAC;AAC1E,OAAO,EAAC,SAAS,EAAC,MAAM,gBAAgB,CAAC;AAEzC,OAAO,EAAC,yBAAyB,EAAE,gBAAgB,EAAE,sBAAsB,EAAE,eAAe,EAAC,MAAM,mCAAmC,CAAC;;;;;;;AAUvI,MAAM,OAAO,mCAA2C,SAAQ,SAAS;IANzE;;QAUW,iBAAY,GAAsB,IAAI,aAAa,CAAC,CAAC,CAAC,CAAC;QACvD,WAAM,GAAyB,IAAI,CAAC,YAAY,CAAC,YAAY,EAAE,CAAC;QAEhE,mBAAc,GAA+B,EAAE,CAAC;QAChD,eAAU,GAA+B,EAAE,CAAC;QAE3C,kBAAa,GAAmB,EAAE,CAAC;KA0E9C;IAxEU,QAAQ;QAEX,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC;QACxC,MAAM,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,yBAAyB,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;QACvG,MAAM,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,yBAAyB,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;QACzG,MAAM,eAAe,GAAG,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,yBAAyB,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;QAE7G,IAAI,YAAY,EAAE;YACd,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,mBAAmB,CAAC,SAAS,CAAC,CAAC;YAC3D,MAAM,SAAS,GAAG,IAAI,sBAAsB,CAAC,IAAI,CAAC,UAAU,CAAC,mBAAmB,CAAC,SAAS,EAAE,KAAK,EAAE,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC;iBAC1J,SAAS,CAAC,IAAI,CAAC;iBACf,QAAQ,CAAC,YAAY,CAAC;iBACtB,aAAa,CAAC,oCAAoC,CAAC;iBACnD,kBAAkB,CAAC,GAAG,CAAC,EAAE;gBACtB,IAAI,CAAC,SAAS,CAAC,WAAW,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;gBACxC,IAAI,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC;gBACnC,KAAK,GAAG,CAAC,GAAG,KAAK,EAAE,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;gBACnC,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;gBACnC,OAAO,EAAE,CAAC,KAAK,CAAC,CAAC;YACrB,CAAC,CAAC;iBACD,qBAAqB,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC;YACzE,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,SAAgC,CAAC,CAAC;SAC9D;QACD,IAAI,aAAa,EAAE;YACf,MAAM,UAAU,GAAG,IAAI,sBAAsB,CAAC,IAAI,CAAC,UAAU,CAAC,mBAAmB,CAAC,UAAU,EAAE,MAAM,EAAE,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC;iBAC7J,SAAS,CAAC,IAAI,CAAC;iBACf,QAAQ,CAAC,cAAc,CAAC;iBACxB,aAAa,CAAC,oCAAoC,CAAC;iBACnD,kBAAkB,CAAC,GAAG,CAAC,EAAE;gBACtB,IAAI,CAAC,SAAS,CAAC,WAAW,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;gBACxC,IAAI,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC;gBACnC,KAAK,CAAC,GAAG,CAAC,IAAI,EAAE,UAAU,EAAE,CAAC,WAAW,CAAC,CAAC,GAAG,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC;gBAC5D,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;gBACnC,OAAO,EAAE,CAAC,KAAK,CAAC,CAAC;YACrB,CAAC,CAAC;iBACD,qBAAqB,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC;YACzE,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,UAAiC,CAAC,CAAC;SAC3D;QACD,IAAI,eAAe,EAAE;YACjB,MAAM,YAAY,GAAG,IAAI,gBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,mBAAmB,CAAC,KAAK,EAAE,QAAQ,EAAE,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC;iBACtJ,SAAS,CAAC,eAAe,CAAC,MAAM,CAAC;iBACjC,SAAS,CAAC,IAAI,CAAC;iBACf,QAAQ,CAAC,aAAa,CAAC;iBACvB,eAAe,CAAC,GAAG,CAAC,EAAE;gBACnB,IAAI,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC;gBACnC,0BAA0B;gBAC1B,aAAa;gBACb,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,eAAe,CAAC,eAAe,CAAC,KAAK,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,CAAC;gBACnJ,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;gBACnC,OAAO,EAAE,CAAC,KAAK,CAAC,CAAC;YACrB,CAAC,CAAC;iBACD,qBAAqB,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC;YACzE,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;SACtC;QAED,cAAc;QACd,IAAI,OAAO,IAAI,CAAC,WAAW,CAAC,KAAK,KAAK,WAAW,IAAI,IAAI,CAAC,WAAW,CAAC,KAAK,KAAK,IAAI,EAAE;YAClF,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;SACnC;QACD,MAAM,YAAY,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY;aAC7C,IAAI,CACD,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CACpC;aACA,SAAS,CAAC,CAAC,CAAC,EAAE;YACX,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC9B,CAAC,CAAC,CAAC;QACP,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAC1C,CAAC;IAEM,WAAW;QACd,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;IACrD,CAAC;;gIAnFQ,mCAAmC;oHAAnC,mCAAmC,iGChBhD,u8BAaA;2FDGa,mCAAmC;kBAN/C,SAAS;+BACI,oCAAoC,mBAG7B,uBAAuB,CAAC,MAAM","sourcesContent":["import {ChangeDetectionStrategy, Component, OnDestroy, OnInit} from '@angular/core';\n\nimport {FieldType} from '@ngx-formly/core';\nimport {Observable, of, ReplaySubject, Subject, Subscription} from 'rxjs';\nimport {startWith} from 'rxjs/operators';\n\nimport {FieldManyEditorDescriptor, ActionDescriptor, ActionEditorDescriptor, ActionLevelEnum} from '../../../../../models/descriptors';\nimport {ActionExecContext} from '../../../../../models/action';\nimport {IDataProvider, IEditorDataProvider} from '../../../../../models/providers';\n\n@Component({\n    selector: 'mng-formly-table-dialog-form-field',\n    templateUrl: './formly-field-table-dialog-form.component.html',\n    styleUrls: ['./formly-field-table-dialog-form.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class FormlyFieldTableDialogFormComponent<T, ET> extends FieldType implements OnInit, OnDestroy {\n\n    public descriptor!: FieldManyEditorDescriptor<T, ET>;\n\n    public itemsSubject: Subject<Array<T>> = new ReplaySubject(1);\n    public items$: Observable<Array<T>> = this.itemsSubject.asObservable();\n\n    public toolbarActions: Array<ActionDescriptor<T>> = [];\n    public rowActions: Array<ActionDescriptor<T>> = [];\n\n    private subscriptions: Subscription[] = [];\n\n    public ngOnInit() {\n\n        this.descriptor = this.to['descriptor'];\n        const hasAddAction = this.descriptor.actions.some(a => a === FieldManyEditorDescriptor.ActionEnum.Add);\n        const hasEditAction = this.descriptor.actions.some(a => a === FieldManyEditorDescriptor.ActionEnum.Edit);\n        const hasDeleteAction = this.descriptor.actions.some(a => a === FieldManyEditorDescriptor.ActionEnum.Delete);\n\n        if (hasAddAction) {\n            console.log(this.descriptor.tableviewDescriptor.addEditor);\n            const addAction = new ActionEditorDescriptor(this.descriptor.tableviewDescriptor.addEditor, 'add', this.descriptor.editor.model.type, this.descriptor.property)\n                .withTitle(null)\n                .withIcon('pi pi-plus')\n                .withClassName('mng-formly-field-table-form-dialog')\n                .withSubmitFunction(ctx => {\n                    this.formState.submittedOn = Date.now();\n                    let value = this.formControl.value;\n                    value = [...value, ctx.data?.item];\n                    this.formControl.patchValue(value);\n                    return of(value);\n                })\n                .withIsVisibleFunction(ctx => of(!this.options?.formState.disabled));\n            this.toolbarActions.push(addAction as ActionDescriptor<T>);\n        }\n        if (hasEditAction) {\n            const editAction = new ActionEditorDescriptor(this.descriptor.tableviewDescriptor.editEditor, 'edit', this.descriptor.editor.model.type, this.descriptor.property)\n                .withTitle(null)\n                .withIcon('pi pi-pencil')\n                .withClassName('mng-formly-field-table-form-dialog')\n                .withSubmitFunction(ctx => {\n                    this.formState.submittedOn = Date.now();\n                    let value = this.formControl.value;\n                    value[ctx.data?.actionData?.['itemIndex']] = ctx.data?.item;\n                    this.formControl.patchValue(value);\n                    return of(value);\n                })\n                .withIsVisibleFunction(ctx => of(!this.options?.formState.disabled));\n            this.rowActions.push(editAction as ActionDescriptor<T>);\n        }\n        if (hasDeleteAction) {\n            const deleteAction = new ActionDescriptor(this.descriptor.tableviewDescriptor.model, 'delete', this.descriptor.editor.model.type, this.descriptor.property)\n                .withLevel(ActionLevelEnum.Danger)\n                .withTitle(null)\n                .withIcon('pi pi-trash')\n                .withRunFunction(ctx => {\n                    let value = this.formControl.value;\n                    // TODO: resolve ts ignore\n                    // @ts-ignore\n                    value = value.filter(i => i[this.descriptor.tableDescriptor.dataKeyProperty] !== ctx.data.item?.[this.descriptor.tableDescriptor.dataKeyProperty]);\n                    this.formControl.patchValue(value);\n                    return of(value);\n                })\n                .withIsVisibleFunction(ctx => of(!this.options?.formState.disabled));\n            this.rowActions.push(deleteAction);\n        }\n\n        // init values\n        if (typeof this.formControl.value === 'undefined' || this.formControl.value === null) {\n            this.formControl.patchValue([]);\n        }\n        const subscription = this.formControl.valueChanges\n            .pipe(\n                startWith(this.formControl.value)\n            )\n            .subscribe(v => {\n                this.itemsSubject.next(v);\n            });\n        this.subscriptions.push(subscription);\n    }\n\n    public ngOnDestroy() {\n        this.subscriptions.forEach(s => s.unsubscribe());\n    }\n}\n","<mng-table [descriptor]=\"descriptor.tableDescriptor\" [items]=\"items$\">\n    <ng-template mngTemplate=\"caption\">\n        <div class=\"flex flex-column md:flex-row md:justify-content-end table-header\">\n            <label class=\"mng-datatable-form-label p-m-0\" [for]=\"key\">{{ to?.label! | translate }} <span *ngIf=\"to.required && to['hideRequiredMarker'] !== true\">*</span></label>\n            <mng-action *ngFor=\"let action of toolbarActions\" [action]=\"action\"></mng-action>\n        </div>\n    </ng-template>\n    <ng-template mngTemplate=\"columnAction\" let-item=\"rowItem\" let-idx=\"rowIndex\">\n        <mng-action *ngFor=\"let action of rowActions\"\n                    [action]=\"action\" [item]=\"item\" [itemId]=\"descriptor.tableviewDescriptor.model.idPropertyName ? item[descriptor.tableviewDescriptor.model.idPropertyName] : undefined\" [actionData]=\"{ itemIndex: idx }\">\n        </mng-action>\n    </ng-template>\n</mng-table>\n"]}
109
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly-field-table-dialog-form.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/mng-commons/src/lib/components/form/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.ts","../../../../../../../../../projects/mng-commons/src/lib/components/form/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, OnDestroy, OnInit} from '@angular/core';\n\nimport {FieldType} from '@ngx-formly/core';\nimport {Observable, of, ReplaySubject, Subject, Subscription} from 'rxjs';\nimport {startWith} from 'rxjs/operators';\n\nimport {FieldManyEditorDescriptor, ActionDescriptor, ActionEditorDescriptor, ActionLevelEnum} from '../../../../../models/descriptors';\nimport {ActionExecContext} from '../../../../../models/action';\nimport {IDataProvider, IEditorDataProvider} from '../../../../../models/providers';\n\n@Component({\n    selector: 'mng-formly-table-dialog-form-field',\n    templateUrl: './formly-field-table-dialog-form.component.html',\n    styleUrls: ['./formly-field-table-dialog-form.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class FormlyFieldTableDialogFormComponent<T, ET> extends FieldType implements OnInit, OnDestroy {\n\n    public descriptor!: FieldManyEditorDescriptor<T, ET>;\n\n    public itemsSubject: Subject<Array<T>> = new ReplaySubject(1);\n    public items$: Observable<Array<T>> = this.itemsSubject.asObservable();\n\n    public toolbarActions: Array<ActionDescriptor<T>> = [];\n    public rowActions: Array<ActionDescriptor<T>> = [];\n\n    private subscriptions: Subscription[] = [];\n\n    public ngOnInit() {\n\n        this.descriptor = this.to['descriptor'];\n        const hasAddAction = this.descriptor.actions.some(a => a === FieldManyEditorDescriptor.ActionEnum.Add);\n        const hasEditAction = this.descriptor.actions.some(a => a === FieldManyEditorDescriptor.ActionEnum.Edit);\n        const hasDeleteAction = this.descriptor.actions.some(a => a === FieldManyEditorDescriptor.ActionEnum.Delete);\n\n        if (hasAddAction) {\n            console.log(this.descriptor.tableviewDescriptor.addEditor);\n            const addAction = new ActionEditorDescriptor(this.descriptor.tableviewDescriptor.addEditor, 'add', this.descriptor.editor.model.type, this.descriptor.property)\n                .withTitle(null)\n                .withIcon('pi pi-plus')\n                .withClassName('mng-formly-field-table-form-dialog')\n                .withSubmitFunction(ctx => {\n                    if (!ctx.data?.item) {\n                        throw new Error(`No item was provided in context, edit cannot be done.`);\n                    }\n                    this.formState.submittedOn = Date.now();\n                    let value = this.formControl.value;\n                    value = [...value, ctx.data.item];\n                    this.formControl.patchValue(value);\n                    return of(ctx.data.item);\n                })\n                .withIsVisibleFunction(ctx => of(!this.options?.formState.disabled));\n            this.toolbarActions.push(addAction as ActionDescriptor<T>);\n        }\n        if (hasEditAction) {\n            const editAction = new ActionEditorDescriptor(this.descriptor.tableviewDescriptor.editEditor, 'edit', this.descriptor.editor.model.type, this.descriptor.property)\n                .withTitle(null)\n                .withIcon('pi pi-pencil')\n                .withClassName('mng-formly-field-table-form-dialog')\n                .withSubmitFunction(ctx => {\n                    if (!ctx.data?.item) {\n                        throw new Error(`No item was provided in context, edit cannot be done.`);\n                    }\n                    this.formState.submittedOn = Date.now();\n                    let formControlValue = this.formControl.value;\n                    formControlValue[ctx.data.actionData?.['itemIndex']] = ctx.data.item;\n                    this.formControl.patchValue(formControlValue);\n                    return of(ctx.data.item);\n                })\n                .withIsVisibleFunction(ctx => of(!this.options?.formState.disabled));\n            this.rowActions.push(editAction as ActionDescriptor<T>);\n        }\n        if (hasDeleteAction) {\n            const deleteAction = new ActionDescriptor(this.descriptor.tableviewDescriptor.model, 'delete', this.descriptor.editor.model.type, this.descriptor.property)\n                .withLevel(ActionLevelEnum.Danger)\n                .withTitle(null)\n                .withIcon('pi pi-trash')\n                .withRunFunction(ctx => {\n                    if (!ctx.data?.item) {\n                        throw new Error(`No item was provided in context, delete cannot be done.`);\n                    }\n                    let formControlValue = this.formControl.value;\n                    const compareProperty = this.descriptor.tableDescriptor.dataKeyProperty ? this.descriptor.tableDescriptor.dataKeyProperty : this.descriptor.tableDescriptor.model.idPropertyName;\n                    if (!compareProperty) {\n                        throw new Error('Cannot compare items, please provide main table data key property or model id property.');\n                    }\n                    const ctxItem: any = ctx.data.item;\n                    if (!ctxItem?.[compareProperty]) {\n                        return formControlValue;\n                    }\n                    formControlValue = formControlValue.filter((i: any) => i[compareProperty] !== ctxItem[compareProperty]);\n                    this.formControl.patchValue(formControlValue);\n                    return of(ctx.data.item);\n                })\n                .withIsVisibleFunction(ctx => of(!this.options?.formState.disabled));\n            this.rowActions.push(deleteAction);\n        }\n\n        // init values\n        if (typeof this.formControl.value === 'undefined' || this.formControl.value === null) {\n            this.formControl.patchValue([]);\n        }\n        const subscription = this.formControl.valueChanges\n            .pipe(\n                startWith(this.formControl.value)\n            )\n            .subscribe(v => {\n                this.itemsSubject.next(v);\n            });\n        this.subscriptions.push(subscription);\n    }\n\n    public ngOnDestroy() {\n        this.subscriptions.forEach(s => s.unsubscribe());\n    }\n}\n","<mng-table [descriptor]=\"descriptor.tableDescriptor\" [items]=\"items$\">\n    <ng-template mngTemplate=\"caption\">\n        <div class=\"flex flex-column md:flex-row md:justify-content-end table-header\">\n            <label class=\"mng-datatable-form-label p-m-0\" [for]=\"key\">{{ to?.label! | translate }} <span *ngIf=\"to.required && to['hideRequiredMarker'] !== true\">*</span></label>\n            <mng-action *ngFor=\"let action of toolbarActions\" [action]=\"action\"></mng-action>\n        </div>\n    </ng-template>\n    <ng-template mngTemplate=\"columnAction\" let-item=\"rowItem\" let-idx=\"rowIndex\">\n        <mng-action *ngFor=\"let action of rowActions\"\n                    [action]=\"action\" [item]=\"item\" [itemId]=\"descriptor.tableviewDescriptor.model.idPropertyName ? item[descriptor.tableviewDescriptor.model.idPropertyName] : undefined\" [actionData]=\"{ itemIndex: idx }\">\n        </mng-action>\n    </ng-template>\n</mng-table>\n"]}
@@ -64,9 +64,7 @@ export class FormlyFieldTableDialogMultiselectComponent extends FieldType {
64
64
  this.descriptor.lookupTableDescriptor.defaultSortProperty.forEach((p, idx) => queryParamBuilder.withSort(p, this.descriptor.lookupTableDescriptor.defaultSortAsc[idx]));
65
65
  }
66
66
  if (this.descriptor.hasLookupExcludeValues) {
67
- // TODO: resolve ts ignore
68
- // @ts-ignore
69
- const filterValues = this.formControl.value.map(i => i[this.descriptor.excludeValueProperty]);
67
+ const filterValues = this.formControl.value.map((i) => i[this.descriptor.excludeValueProperty]);
70
68
  queryParamBuilder.withFilter(this.descriptor.excludeFilterProperty, filterValues, undefined, FilterMatchType.NotIn);
71
69
  }
72
70
  this.descriptor.lookupTableDataProvider?.getAll(queryParamBuilder.build(), this.dialogDataProviderService)
@@ -121,4 +119,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
121
119
  type: Component,
122
120
  args: [{ selector: 'mng-formly-table-multiselect-add-field', changeDetection: ChangeDetectionStrategy.OnPush, template: "<mng-table [descriptor]=\"descriptor.mainTableDescriptor\" [items]=\"itemsAsync\">\n <ng-template mngTemplate=\"caption\">\n <div class=\"flex flex-column md:flex-row md:justify-content-end table-header\">\n <label class=\"mng-datatable-form-label p-m-0\" [for]=\"key\">{{ to?.label! | translate }} <span *ngIf=\"to.required && to['hideRequiredMarker'] !== true\">*</span></label>\n <button *ngIf=\"hasAddAction && !formControl.disabled\" pButton pRipple type=\"button\" icon=\"pi pi-plus\" class=\"p-button-rounded p-button-success\"\n (click)=\"openAddDialog()\">\n </button>\n </div>\n </ng-template>\n <ng-template mngTemplate=\"columnAction\" let-item=\"rowItem\">\n <button *ngIf=\"hasDeleteAction && !formControl.disabled\" pButton pRipple type=\"button\" icon=\"pi pi-trash\" class=\"p-button-rounded p-button-danger\"\n (click)=\"removeItem(item)\">\n </button>\n </ng-template>\n</mng-table>\n\n<p-dialog *ngIf=\"hasAddAction\" [(visible)]=\"isDialogVisible\"\n [draggable]=\"false\"\n [header]=\"'general.addItem' | translate: {item: to?.label!}\"\n [modal]=\"true\"\n styleClass=\"p-fluid mng-formly-field-table-multiselect-dialog\">\n <ng-template pTemplate=\"content\">\n <mng-table [descriptor]=\"descriptor.mainTableDescriptor\"\n [queryResult]=\"addItemsAsync\"\n [selectionEnabled]=\"true\"\n [loading]=\"dialogIsLoading$\"\n (onSelectionChange)=\"onSelectionChange($event)\">\n </mng-table>\n <p-messages [value]=\"dialogMessages\"></p-messages>\n </ng-template>\n\n <ng-template pTemplate=\"footer\">\n <button pButton pRipple type=\"button\" [label]=\"'general.cancel' | translate\" icon=\"pi pi-times\" class=\"p-button-text\" (click)=\"hideDialog()\"></button>\n <button pButton pRipple type=\"button\" [label]=\"'general.add' | translate\" icon=\"pi pi-check\" class=\"p-button-text\" (click)=\"addItems()\" [loading]=\"(dialogIsLoading$ | async) ?? false\" [disabled]=\"form.disabled\"></button>\n </ng-template>\n</p-dialog>\n" }]
123
121
  }], ctorParameters: function () { return [{ type: i0.Injector }]; } });
124
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly-field-table-dialog-multiselect.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/mng-commons/src/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.ts","../../../../../../../../../projects/mng-commons/src/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, Injector, OnDestroy, OnInit} from '@angular/core';\n\nimport {FieldType} from '@ngx-formly/core';\nimport {Message} from 'primeng/api';\nimport {finalize, first, startWith} from 'rxjs/operators';\nimport {Observable, ReplaySubject, Subject, Subscription} from 'rxjs';\n\nimport {FilterMatchType, QueryParamBuilder, QueryResult} from '../../../../../api/models';\nimport {FieldManyToManyEditorDescriptor} from '../../../../../models/descriptors';\n\n@Component({\n    selector: 'mng-formly-table-multiselect-add-field',\n    templateUrl: './formly-field-table-dialog-multiselect.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class FormlyFieldTableDialogMultiselectComponent<T, ET> extends FieldType implements OnInit, OnDestroy {\n\n    public descriptor!: FieldManyToManyEditorDescriptor<T, ET>;\n\n    public itemsSubject: Subject<Array<T>> = new ReplaySubject(1);\n    public itemsAsync: Observable<Array<T>> = this.itemsSubject.asObservable();\n    public addItemsSubject: Subject<QueryResult<T>> = new ReplaySubject(1);\n    public addItemsAsync: Observable<QueryResult<T>> = this.addItemsSubject.asObservable();\n\n    public dialogUseDataProvider: boolean = false;\n    private dialogDataProviderService: any = null;\n    private dialogIsLoadingSubject = new ReplaySubject<boolean>(1);\n\n    public isDialogVisible = false;\n    public dialogAreItemsLoaded = false;\n    public dialogSelectedAddItems: Array<any> = [];\n    public dialogMessages: Message[] = [];\n    public dialogIsLoading$ = this.dialogIsLoadingSubject.asObservable();\n\n    public hasAddAction: boolean = false;\n    public hasDeleteAction: boolean = false;\n\n    private subscriptions: Subscription[] = [];\n\n    constructor(private injector: Injector) {\n        super();\n    }\n\n    public ngOnInit() {\n\n        this.descriptor = this.to['descriptor'];\n        if (this.descriptor.lookupTableDataProvider?.serviceType) {\n            this.dialogUseDataProvider = true;\n            this.dialogDataProviderService = this.injector.get<any>(this.descriptor.lookupTableDataProvider.serviceType);\n        }\n        this.hasAddAction = this.descriptor.actions.some(a => a === FieldManyToManyEditorDescriptor.ActionEnum.Add);\n        this.hasDeleteAction = this.descriptor.actions.some(a => a === FieldManyToManyEditorDescriptor.ActionEnum.Delete);\n\n        // init values\n        if (typeof this.formControl.value === 'undefined' || this.formControl.value === null) {\n            this.formControl.patchValue([]);\n        }\n        const subscription = this.formControl.valueChanges\n            .pipe(\n                startWith(this.formControl.value)\n            )\n            .subscribe(v => {\n                this.itemsSubject.next(v);\n            });\n        this.subscriptions.push(subscription);\n    }\n\n    public ngOnDestroy() {\n        this.subscriptions.forEach(s => s.unsubscribe());\n    }\n\n    openAddDialog() {\n        if (!this.dialogAreItemsLoaded && this.dialogUseDataProvider) {\n            this.dialogIsLoadingSubject.next(true);\n            const queryParamBuilder = QueryParamBuilder.create(50);\n            if (this.descriptor.lookupTableDescriptor.hasDefaultSort) {\n                this.descriptor.lookupTableDescriptor.defaultSortProperty.forEach((p, idx) => queryParamBuilder.withSort(p, this.descriptor.lookupTableDescriptor.defaultSortAsc[idx]));\n            }\n            if (this.descriptor.hasLookupExcludeValues) {\n                // TODO: resolve ts ignore\n                // @ts-ignore\n                const filterValues = this.formControl.value.map(i => i[this.descriptor.excludeValueProperty])\n                queryParamBuilder.withFilter(this.descriptor.excludeFilterProperty, filterValues, undefined, FilterMatchType.NotIn);\n            }\n            this.descriptor.lookupTableDataProvider?.getAll(queryParamBuilder.build(), this.dialogDataProviderService)\n                .pipe(\n                    first(),\n                    finalize(() => this.dialogIsLoadingSubject.next(false))\n                )\n                .subscribe(res => {\n                    this.addItemsSubject.next(res);\n                    this.dialogAreItemsLoaded = true;\n                });\n        }\n        this.dialogSelectedAddItems = [];\n        this.isDialogVisible = true;\n    }\n\n    onSelectionChange(items: Array<any>) {\n        this.dialogSelectedAddItems = items;\n    }\n\n    hideDialog() {\n        this.isDialogVisible = false;\n    }\n\n    addItems() {\n        let value = this.formControl.value;\n        if (Array.isArray(value)) {\n            value = [...value, ...this.dialogSelectedAddItems];\n            this.formControl.patchValue(value);\n            this.dialogSelectedAddItems = [];\n            this.dialogAreItemsLoaded = false;\n            this.hideDialog();\n        } else {\n            console.error(\"Values are not an valid array, cannot add selected items to array\");\n            this.dialogMessages = [{ severity: 'error', summary: 'Error', detail: 'Selected items could not be added' }];\n        }\n    }\n\n    removeItem(item: any) {\n        let value = this.formControl.value;\n        if (Array.isArray(value)) {\n            const compareProperty = this.descriptor.mainTableDescriptor.dataKeyProperty ? this.descriptor.mainTableDescriptor.dataKeyProperty : this.descriptor.mainTableDescriptor.model.idPropertyName;\n            if (!compareProperty) {\n                throw new Error('Cannot compare items, please provide main table data key property or model id property.');\n            }\n            value = value.filter(i => i[compareProperty] !== item[compareProperty]);\n            this.formControl.patchValue(value);\n            this.dialogAreItemsLoaded = false;\n        } else {\n            console.error(\"Values are not an valid array, cannot delete selected item from array\");\n        }\n    }\n}\n","<mng-table [descriptor]=\"descriptor.mainTableDescriptor\" [items]=\"itemsAsync\">\n    <ng-template mngTemplate=\"caption\">\n        <div class=\"flex flex-column md:flex-row md:justify-content-end table-header\">\n            <label class=\"mng-datatable-form-label p-m-0\" [for]=\"key\">{{ to?.label! | translate }} <span *ngIf=\"to.required && to['hideRequiredMarker'] !== true\">*</span></label>\n            <button *ngIf=\"hasAddAction && !formControl.disabled\" pButton pRipple type=\"button\" icon=\"pi pi-plus\" class=\"p-button-rounded p-button-success\"\n                    (click)=\"openAddDialog()\">\n            </button>\n        </div>\n    </ng-template>\n    <ng-template mngTemplate=\"columnAction\" let-item=\"rowItem\">\n        <button *ngIf=\"hasDeleteAction && !formControl.disabled\" pButton pRipple type=\"button\" icon=\"pi pi-trash\" class=\"p-button-rounded p-button-danger\"\n                (click)=\"removeItem(item)\">\n        </button>\n    </ng-template>\n</mng-table>\n\n<p-dialog *ngIf=\"hasAddAction\" [(visible)]=\"isDialogVisible\"\n          [draggable]=\"false\"\n          [header]=\"'general.addItem' | translate: {item: to?.label!}\"\n          [modal]=\"true\"\n          styleClass=\"p-fluid mng-formly-field-table-multiselect-dialog\">\n    <ng-template pTemplate=\"content\">\n        <mng-table [descriptor]=\"descriptor.mainTableDescriptor\"\n                   [queryResult]=\"addItemsAsync\"\n                   [selectionEnabled]=\"true\"\n                   [loading]=\"dialogIsLoading$\"\n                   (onSelectionChange)=\"onSelectionChange($event)\">\n        </mng-table>\n        <p-messages [value]=\"dialogMessages\"></p-messages>\n    </ng-template>\n\n    <ng-template pTemplate=\"footer\">\n        <button pButton pRipple type=\"button\" [label]=\"'general.cancel' | translate\" icon=\"pi pi-times\" class=\"p-button-text\" (click)=\"hideDialog()\"></button>\n        <button pButton pRipple type=\"button\" [label]=\"'general.add' | translate\" icon=\"pi pi-check\" class=\"p-button-text\" (click)=\"addItems()\" [loading]=\"(dialogIsLoading$ | async) ?? false\" [disabled]=\"form.disabled\"></button>\n    </ng-template>\n</p-dialog>\n"]}
122
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly-field-table-dialog-multiselect.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/mng-commons/src/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.ts","../../../../../../../../../projects/mng-commons/src/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, Injector, OnDestroy, OnInit} from '@angular/core';\n\nimport {FieldType} from '@ngx-formly/core';\nimport {Message} from 'primeng/api';\nimport {finalize, first, startWith} from 'rxjs/operators';\nimport {Observable, ReplaySubject, Subject, Subscription} from 'rxjs';\n\nimport {FilterMatchType, QueryParamBuilder, QueryResult} from '../../../../../api/models';\nimport {FieldManyToManyEditorDescriptor} from '../../../../../models/descriptors';\n\n@Component({\n    selector: 'mng-formly-table-multiselect-add-field',\n    templateUrl: './formly-field-table-dialog-multiselect.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class FormlyFieldTableDialogMultiselectComponent<T, ET> extends FieldType implements OnInit, OnDestroy {\n\n    public descriptor!: FieldManyToManyEditorDescriptor<T, ET>;\n\n    public itemsSubject: Subject<Array<T>> = new ReplaySubject(1);\n    public itemsAsync: Observable<Array<T>> = this.itemsSubject.asObservable();\n    public addItemsSubject: Subject<QueryResult<T>> = new ReplaySubject(1);\n    public addItemsAsync: Observable<QueryResult<T>> = this.addItemsSubject.asObservable();\n\n    public dialogUseDataProvider: boolean = false;\n    private dialogDataProviderService: any = null;\n    private dialogIsLoadingSubject = new ReplaySubject<boolean>(1);\n\n    public isDialogVisible = false;\n    public dialogAreItemsLoaded = false;\n    public dialogSelectedAddItems: Array<any> = [];\n    public dialogMessages: Message[] = [];\n    public dialogIsLoading$ = this.dialogIsLoadingSubject.asObservable();\n\n    public hasAddAction: boolean = false;\n    public hasDeleteAction: boolean = false;\n\n    private subscriptions: Subscription[] = [];\n\n    constructor(private injector: Injector) {\n        super();\n    }\n\n    public ngOnInit() {\n\n        this.descriptor = this.to['descriptor'];\n        if (this.descriptor.lookupTableDataProvider?.serviceType) {\n            this.dialogUseDataProvider = true;\n            this.dialogDataProviderService = this.injector.get<any>(this.descriptor.lookupTableDataProvider.serviceType);\n        }\n        this.hasAddAction = this.descriptor.actions.some(a => a === FieldManyToManyEditorDescriptor.ActionEnum.Add);\n        this.hasDeleteAction = this.descriptor.actions.some(a => a === FieldManyToManyEditorDescriptor.ActionEnum.Delete);\n\n        // init values\n        if (typeof this.formControl.value === 'undefined' || this.formControl.value === null) {\n            this.formControl.patchValue([]);\n        }\n        const subscription = this.formControl.valueChanges\n            .pipe(\n                startWith(this.formControl.value)\n            )\n            .subscribe(v => {\n                this.itemsSubject.next(v);\n            });\n        this.subscriptions.push(subscription);\n    }\n\n    public ngOnDestroy() {\n        this.subscriptions.forEach(s => s.unsubscribe());\n    }\n\n    openAddDialog() {\n        if (!this.dialogAreItemsLoaded && this.dialogUseDataProvider) {\n            this.dialogIsLoadingSubject.next(true);\n            const queryParamBuilder = QueryParamBuilder.create(50);\n            if (this.descriptor.lookupTableDescriptor.hasDefaultSort) {\n                this.descriptor.lookupTableDescriptor.defaultSortProperty.forEach((p, idx) => queryParamBuilder.withSort(p, this.descriptor.lookupTableDescriptor.defaultSortAsc[idx]));\n            }\n            if (this.descriptor.hasLookupExcludeValues) {\n                const filterValues = this.formControl.value.map((i: any) => i[this.descriptor.excludeValueProperty])\n                queryParamBuilder.withFilter(this.descriptor.excludeFilterProperty, filterValues, undefined, FilterMatchType.NotIn);\n            }\n            this.descriptor.lookupTableDataProvider?.getAll(queryParamBuilder.build(), this.dialogDataProviderService)\n                .pipe(\n                    first(),\n                    finalize(() => this.dialogIsLoadingSubject.next(false))\n                )\n                .subscribe(res => {\n                    this.addItemsSubject.next(res);\n                    this.dialogAreItemsLoaded = true;\n                });\n        }\n        this.dialogSelectedAddItems = [];\n        this.isDialogVisible = true;\n    }\n\n    onSelectionChange(items: Array<any>) {\n        this.dialogSelectedAddItems = items;\n    }\n\n    hideDialog() {\n        this.isDialogVisible = false;\n    }\n\n    addItems() {\n        let value = this.formControl.value;\n        if (Array.isArray(value)) {\n            value = [...value, ...this.dialogSelectedAddItems];\n            this.formControl.patchValue(value);\n            this.dialogSelectedAddItems = [];\n            this.dialogAreItemsLoaded = false;\n            this.hideDialog();\n        } else {\n            console.error(\"Values are not an valid array, cannot add selected items to array\");\n            this.dialogMessages = [{ severity: 'error', summary: 'Error', detail: 'Selected items could not be added' }];\n        }\n    }\n\n    removeItem(item: any) {\n        let value = this.formControl.value;\n        if (Array.isArray(value)) {\n            const compareProperty = this.descriptor.mainTableDescriptor.dataKeyProperty ? this.descriptor.mainTableDescriptor.dataKeyProperty : this.descriptor.mainTableDescriptor.model.idPropertyName;\n            if (!compareProperty) {\n                throw new Error('Cannot compare items, please provide main table data key property or model id property.');\n            }\n            value = value.filter(i => i[compareProperty] !== item[compareProperty]);\n            this.formControl.patchValue(value);\n            this.dialogAreItemsLoaded = false;\n        } else {\n            console.error(\"Values are not an valid array, cannot delete selected item from array\");\n        }\n    }\n}\n","<mng-table [descriptor]=\"descriptor.mainTableDescriptor\" [items]=\"itemsAsync\">\n    <ng-template mngTemplate=\"caption\">\n        <div class=\"flex flex-column md:flex-row md:justify-content-end table-header\">\n            <label class=\"mng-datatable-form-label p-m-0\" [for]=\"key\">{{ to?.label! | translate }} <span *ngIf=\"to.required && to['hideRequiredMarker'] !== true\">*</span></label>\n            <button *ngIf=\"hasAddAction && !formControl.disabled\" pButton pRipple type=\"button\" icon=\"pi pi-plus\" class=\"p-button-rounded p-button-success\"\n                    (click)=\"openAddDialog()\">\n            </button>\n        </div>\n    </ng-template>\n    <ng-template mngTemplate=\"columnAction\" let-item=\"rowItem\">\n        <button *ngIf=\"hasDeleteAction && !formControl.disabled\" pButton pRipple type=\"button\" icon=\"pi pi-trash\" class=\"p-button-rounded p-button-danger\"\n                (click)=\"removeItem(item)\">\n        </button>\n    </ng-template>\n</mng-table>\n\n<p-dialog *ngIf=\"hasAddAction\" [(visible)]=\"isDialogVisible\"\n          [draggable]=\"false\"\n          [header]=\"'general.addItem' | translate: {item: to?.label!}\"\n          [modal]=\"true\"\n          styleClass=\"p-fluid mng-formly-field-table-multiselect-dialog\">\n    <ng-template pTemplate=\"content\">\n        <mng-table [descriptor]=\"descriptor.mainTableDescriptor\"\n                   [queryResult]=\"addItemsAsync\"\n                   [selectionEnabled]=\"true\"\n                   [loading]=\"dialogIsLoading$\"\n                   (onSelectionChange)=\"onSelectionChange($event)\">\n        </mng-table>\n        <p-messages [value]=\"dialogMessages\"></p-messages>\n    </ng-template>\n\n    <ng-template pTemplate=\"footer\">\n        <button pButton pRipple type=\"button\" [label]=\"'general.cancel' | translate\" icon=\"pi pi-times\" class=\"p-button-text\" (click)=\"hideDialog()\"></button>\n        <button pButton pRipple type=\"button\" [label]=\"'general.add' | translate\" icon=\"pi pi-check\" class=\"p-button-text\" (click)=\"addItems()\" [loading]=\"(dialogIsLoading$ | async) ?? false\" [disabled]=\"form.disabled\"></button>\n    </ng-template>\n</p-dialog>\n"]}
@@ -1,21 +1,20 @@
1
1
  import { Component } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
- import * as i1 from "../../services/breadcrumb.service";
3
+ import * as i1 from "../../services";
4
4
  import * as i2 from "primeng/breadcrumb";
5
5
  export class AppBreadcrumbComponent {
6
6
  constructor(breadcrumbService) {
7
7
  this.breadcrumbService = breadcrumbService;
8
+ this.subscriptions = [];
8
9
  this.items = [];
9
- this.search = '';
10
- this.subscription = breadcrumbService.itemsHandler.subscribe(response => {
10
+ }
11
+ ngOnInit() {
12
+ this.subscriptions.push(this.breadcrumbService.breadcrumbs.subscribe(response => {
11
13
  this.items = response;
12
- });
13
- this.home = { icon: 'pi pi-home', routerLink: '/' };
14
+ }));
14
15
  }
15
16
  ngOnDestroy() {
16
- if (this.subscription) {
17
- this.subscription.unsubscribe();
18
- }
17
+ this.subscriptions.forEach(value => value.unsubscribe());
19
18
  }
20
19
  }
21
20
  AppBreadcrumbComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AppBreadcrumbComponent, deps: [{ token: i1.AppBreadcrumbService }], target: i0.ɵɵFactoryTarget.Component });
@@ -24,4 +23,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
24
23
  type: Component,
25
24
  args: [{ selector: 'app-breadcrumb', template: "<div class=\"layout-breadcrumb-container\">\n <div class=\"layout-breadcrumb\">\n <p-breadcrumb [model]=\"items\" styleClass=\"layout-breadcrumb py-2\"></p-breadcrumb>\n </div>\n</div>\n" }]
26
25
  }], ctorParameters: function () { return [{ type: i1.AppBreadcrumbService }]; } });
27
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwLmJyZWFkY3J1bWIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbW5nLWNvbW1vbnMvc3JjL2xpYi9jb21wb25lbnRzL2xheW91dC9hcHAuYnJlYWRjcnVtYi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tbmctY29tbW9ucy9zcmMvbGliL2NvbXBvbmVudHMvbGF5b3V0L2FwcC5icmVhZGNydW1iLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWEsTUFBTSxlQUFlLENBQUM7Ozs7QUFXckQsTUFBTSxPQUFPLHNCQUFzQjtJQVUvQixZQUFtQixpQkFBdUM7UUFBdkMsc0JBQWlCLEdBQWpCLGlCQUFpQixDQUFzQjtRQU4xRCxVQUFLLEdBQWUsRUFBRSxDQUFDO1FBSXZCLFdBQU0sR0FBVyxFQUFFLENBQUM7UUFHaEIsSUFBSSxDQUFDLFlBQVksR0FBRyxpQkFBaUIsQ0FBQyxZQUFZLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxFQUFFO1lBQ3BFLElBQUksQ0FBQyxLQUFLLEdBQUcsUUFBUSxDQUFDO1FBQzFCLENBQUMsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLElBQUksR0FBRyxFQUFFLElBQUksRUFBRSxZQUFZLEVBQUUsVUFBVSxFQUFFLEdBQUcsRUFBRSxDQUFDO0lBQ3hELENBQUM7SUFFRCxXQUFXO1FBQ1AsSUFBSSxJQUFJLENBQUMsWUFBWSxFQUFFO1lBQ25CLElBQUksQ0FBQyxZQUFZLENBQUMsV0FBVyxFQUFFLENBQUM7U0FDbkM7SUFDTCxDQUFDOzttSEF0QlEsc0JBQXNCO3VHQUF0QixzQkFBc0Isc0RDWG5DLHlNQUtBOzJGRE1hLHNCQUFzQjtrQkFKbEMsU0FBUzsrQkFDSSxnQkFBZ0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uRGVzdHJveSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBTdWJzY3JpcHRpb24gfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IE1lbnVJdGVtIH0gZnJvbSAncHJpbWVuZy9hcGknO1xuXG5pbXBvcnQge0FwcEJyZWFkY3J1bWJTZXJ2aWNlfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9icmVhZGNydW1iLnNlcnZpY2UnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2FwcC1icmVhZGNydW1iJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vYXBwLmJyZWFkY3J1bWIuY29tcG9uZW50Lmh0bWwnXG59KVxuZXhwb3J0IGNsYXNzIEFwcEJyZWFkY3J1bWJDb21wb25lbnQgaW1wbGVtZW50cyBPbkRlc3Ryb3kge1xuXG4gICAgc3Vic2NyaXB0aW9uOiBTdWJzY3JpcHRpb247XG5cbiAgICBpdGVtczogTWVudUl0ZW1bXSA9IFtdO1xuXG4gICAgaG9tZTogTWVudUl0ZW07XG5cbiAgICBzZWFyY2g6IHN0cmluZyA9ICcnO1xuXG4gICAgY29uc3RydWN0b3IocHVibGljIGJyZWFkY3J1bWJTZXJ2aWNlOiBBcHBCcmVhZGNydW1iU2VydmljZSkge1xuICAgICAgICB0aGlzLnN1YnNjcmlwdGlvbiA9IGJyZWFkY3J1bWJTZXJ2aWNlLml0ZW1zSGFuZGxlci5zdWJzY3JpYmUocmVzcG9uc2UgPT4ge1xuICAgICAgICAgICAgdGhpcy5pdGVtcyA9IHJlc3BvbnNlO1xuICAgICAgICB9KTtcblxuICAgICAgICB0aGlzLmhvbWUgPSB7IGljb246ICdwaSBwaS1ob21lJywgcm91dGVyTGluazogJy8nIH07XG4gICAgfVxuXG4gICAgbmdPbkRlc3Ryb3koKSB7XG4gICAgICAgIGlmICh0aGlzLnN1YnNjcmlwdGlvbikge1xuICAgICAgICAgICAgdGhpcy5zdWJzY3JpcHRpb24udW5zdWJzY3JpYmUoKTtcbiAgICAgICAgfVxuICAgIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJsYXlvdXQtYnJlYWRjcnVtYi1jb250YWluZXJcIj5cbiAgICA8ZGl2IGNsYXNzPVwibGF5b3V0LWJyZWFkY3J1bWJcIj5cbiAgICAgICAgPHAtYnJlYWRjcnVtYiBbbW9kZWxdPVwiaXRlbXNcIiBzdHlsZUNsYXNzPVwibGF5b3V0LWJyZWFkY3J1bWIgcHktMlwiPjwvcC1icmVhZGNydW1iPlxuICAgIDwvZGl2PlxuPC9kaXY+XG4iXX0=
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwLmJyZWFkY3J1bWIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbW5nLWNvbW1vbnMvc3JjL2xpYi9jb21wb25lbnRzL2xheW91dC9hcHAuYnJlYWRjcnVtYi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tbmctY29tbW9ucy9zcmMvbGliL2NvbXBvbmVudHMvbGF5b3V0L2FwcC5icmVhZGNydW1iLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQW9CLE1BQU0sZUFBZSxDQUFDOzs7O0FBVzNELE1BQU0sT0FBTyxzQkFBc0I7SUFNL0IsWUFBbUIsaUJBQXVDO1FBQXZDLHNCQUFpQixHQUFqQixpQkFBaUIsQ0FBc0I7UUFKbEQsa0JBQWEsR0FBd0IsRUFBRSxDQUFDO1FBRWhELFVBQUssR0FBZSxFQUFFLENBQUM7SUFHdkIsQ0FBQztJQUVELFFBQVE7UUFDSixJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsaUJBQWlCLENBQUMsV0FBVyxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsRUFBRTtZQUM1RSxJQUFJLENBQUMsS0FBSyxHQUFHLFFBQVEsQ0FBQztRQUMxQixDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ1IsQ0FBQztJQUVELFdBQVc7UUFDUCxJQUFJLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxXQUFXLEVBQUUsQ0FBQyxDQUFDO0lBQzdELENBQUM7O21IQWpCUSxzQkFBc0I7dUdBQXRCLHNCQUFzQixzRENYbkMseU1BS0E7MkZETWEsc0JBQXNCO2tCQUpsQyxTQUFTOytCQUNJLGdCQUFnQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBPbkRlc3Ryb3ksIE9uSW5pdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IFN1YnNjcmlwdGlvbiB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgTWVudUl0ZW0gfSBmcm9tICdwcmltZW5nL2FwaSc7XG5cbmltcG9ydCB7QXBwQnJlYWRjcnVtYlNlcnZpY2V9IGZyb20gJy4uLy4uL3NlcnZpY2VzJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdhcHAtYnJlYWRjcnVtYicsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2FwcC5icmVhZGNydW1iLmNvbXBvbmVudC5odG1sJ1xufSlcbmV4cG9ydCBjbGFzcyBBcHBCcmVhZGNydW1iQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3kge1xuXG4gICAgcHJpdmF0ZSBzdWJzY3JpcHRpb25zOiBBcnJheTxTdWJzY3JpcHRpb24+ID0gW107XG5cbiAgICBpdGVtczogTWVudUl0ZW1bXSA9IFtdO1xuXG4gICAgY29uc3RydWN0b3IocHVibGljIGJyZWFkY3J1bWJTZXJ2aWNlOiBBcHBCcmVhZGNydW1iU2VydmljZSkge1xuICAgIH1cblxuICAgIG5nT25Jbml0KCkge1xuICAgICAgICB0aGlzLnN1YnNjcmlwdGlvbnMucHVzaCh0aGlzLmJyZWFkY3J1bWJTZXJ2aWNlLmJyZWFkY3J1bWJzLnN1YnNjcmliZShyZXNwb25zZSA9PiB7XG4gICAgICAgICAgICB0aGlzLml0ZW1zID0gcmVzcG9uc2U7XG4gICAgICAgIH0pKTtcbiAgICB9XG5cbiAgICBuZ09uRGVzdHJveSgpIHtcbiAgICAgICAgdGhpcy5zdWJzY3JpcHRpb25zLmZvckVhY2godmFsdWUgPT4gdmFsdWUudW5zdWJzY3JpYmUoKSk7XG4gICAgfVxufVxuIiwiPGRpdiBjbGFzcz1cImxheW91dC1icmVhZGNydW1iLWNvbnRhaW5lclwiPlxuICAgIDxkaXYgY2xhc3M9XCJsYXlvdXQtYnJlYWRjcnVtYlwiPlxuICAgICAgICA8cC1icmVhZGNydW1iIFttb2RlbF09XCJpdGVtc1wiIHN0eWxlQ2xhc3M9XCJsYXlvdXQtYnJlYWRjcnVtYiBweS0yXCI+PC9wLWJyZWFkY3J1bWI+XG4gICAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==
@@ -1,38 +1,24 @@
1
1
  import { Component } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
- import * as i1 from "../../services/settings.service";
3
+ import * as i1 from "../../services";
4
4
  import * as i2 from "./app.main.component.service";
5
5
  import * as i3 from "./app.menuitem.component";
6
6
  import * as i4 from "@angular/common";
7
7
  export class AppMenuComponent {
8
- constructor(appSettings, appMainService) {
8
+ constructor(appSettings, appMainService, menuService) {
9
9
  this.appSettings = appSettings;
10
10
  this.appMainService = appMainService;
11
- this.model = [];
11
+ this.menuService = menuService;
12
+ this.menu = [];
12
13
  }
13
14
  ngOnInit() {
14
- this.model = [
15
- {
16
- label: 'pages.dashboard.name', icon: 'pi pi-home', routerLink: ['/dashboard'],
17
- },
18
- {
19
- label: 'pages.publicServices.name', icon: 'pi pi-fw pi-book', routerLink: ['/public-services']
20
- },
21
- {
22
- label: 'pages.codelists.name', icon: 'pi pi-fw pi-list', routerLink: ['/codelists'],
23
- items: [
24
- {
25
- label: 'pages.publicOrganizations.name', icon: 'pi pi-fw pi-globe', routerLink: ['/codelists/public-organizations']
26
- }
27
- ]
28
- }
29
- ];
15
+ this.menu = this.menuService.menuItems;
30
16
  }
31
17
  }
32
- AppMenuComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AppMenuComponent, deps: [{ token: i1.AppSettingsService }, { token: i2.AppMainComponentService }], target: i0.ɵɵFactoryTarget.Component });
33
- AppMenuComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: AppMenuComponent, selector: "app-menu", ngImport: i0, template: "<div class=\"layout-menu-wrapper\" [ngClass]=\"{'layout-sidebar-active': appMainService.sidebarActive}\"\n (click)=\"appMainService.onSidebarClick($event)\" (mouseover)=\"appMainService.onSidebarMouseOver($event)\" (mouseleave)=\"appMainService.onSidebarMouseLeave($event)\">\n <div class=\"menu-logo\" *ngIf=\"!appSettings.isHorizontal() || appMainService.isMobile()\">\n\n <a href=\"#\" class=\"logo\">\n <img [src]=\"'assets/layout/images/logo-'+ (appSettings.colorScheme === 'light' ? 'dark' : 'light') + '.png'\">\n </a>\n\n <a href=\"#\" class=\"app-name\" *ngIf=\"!appSettings.isSlim() || appMainService.isMobile()\">\n <img [src]=\"'assets/layout/images/appname-'+ (appSettings.colorScheme === 'light' ? 'dark' : 'light') + '.png'\"/>\n </a>\n<!-- <a href=\"#\" class=\"menu-pin\" (click)=\"appMain.onToggleMenu($event)\">-->\n<!-- <span *ngIf=\"appMain.isOverlay()\" class=\"pi pi-times\"></span>-->\n<!-- <span *ngIf=\"appMain.isSidebar() && !appMain.sidebarStatic && appMain.pinActive\" class=\"pi pi-unlock\"></span>-->\n<!-- <span *ngIf=\"appMain.isSidebar() && appMain.sidebarStatic && appMain.pinActive\" class=\"pi pi-lock\"></span>-->\n<!-- </a>-->\n </div>\n\n <div class=\"layout-menu-container\">\n <ul class=\"layout-menu\">\n <ng-container *ngFor=\"let item of model; let i = index;\">\n <li app-menuitem *ngIf=\"!item.separator\" [item]=\"item\" [index]=\"i\" [root]=\"true\"></li>\n <li *ngIf=\"item.separator\" class=\"menu-separator\"></li>\n </ng-container>\n </ul>\n </div>\n</div>\n", components: [{ type: i3.AppMenuitemComponent, selector: "[app-menuitem]", inputs: ["item", "index", "root", "parentKey"] }], directives: [{ type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
18
+ AppMenuComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AppMenuComponent, deps: [{ token: i1.AppSettingsService }, { token: i2.AppMainComponentService }, { token: i1.MenuService }], target: i0.ɵɵFactoryTarget.Component });
19
+ AppMenuComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: AppMenuComponent, selector: "app-menu", ngImport: i0, template: "<div class=\"layout-menu-wrapper\" [ngClass]=\"{'layout-sidebar-active': appMainService.sidebarActive}\"\n (click)=\"appMainService.onSidebarClick($event)\" (mouseover)=\"appMainService.onSidebarMouseOver($event)\" (mouseleave)=\"appMainService.onSidebarMouseLeave($event)\">\n <div class=\"menu-logo\" *ngIf=\"!appSettings.isHorizontal() || appMainService.isMobile()\">\n\n <a href=\"#\" class=\"logo\">\n <img [src]=\"'assets/layout/images/logo-'+ (appSettings.colorScheme === 'light' ? 'dark' : 'light') + '.png'\">\n </a>\n\n <a href=\"#\" class=\"app-name\" *ngIf=\"!appSettings.isSlim() || appMainService.isMobile()\">\n <img [src]=\"'assets/layout/images/appname-'+ (appSettings.colorScheme === 'light' ? 'dark' : 'light') + '.png'\"/>\n </a>\n<!-- <a href=\"#\" class=\"menu-pin\" (click)=\"appMain.onToggleMenu($event)\">-->\n<!-- <span *ngIf=\"appMain.isOverlay()\" class=\"pi pi-times\"></span>-->\n<!-- <span *ngIf=\"appMain.isSidebar() && !appMain.sidebarStatic && appMain.pinActive\" class=\"pi pi-unlock\"></span>-->\n<!-- <span *ngIf=\"appMain.isSidebar() && appMain.sidebarStatic && appMain.pinActive\" class=\"pi pi-lock\"></span>-->\n<!-- </a>-->\n </div>\n\n <div class=\"layout-menu-container\">\n <ul class=\"layout-menu\">\n <ng-container *ngFor=\"let item of menu; let i = index;\">\n <li app-menuitem *ngIf=\"!item.separator\" [item]=\"item\" [index]=\"i\" [root]=\"true\"></li>\n <li *ngIf=\"item.separator\" class=\"menu-separator\"></li>\n </ng-container>\n </ul>\n </div>\n</div>\n", components: [{ type: i3.AppMenuitemComponent, selector: "[app-menuitem]", inputs: ["item", "index", "root", "parentKey"] }], directives: [{ type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
34
20
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: AppMenuComponent, decorators: [{
35
21
  type: Component,
36
- args: [{ selector: 'app-menu', template: "<div class=\"layout-menu-wrapper\" [ngClass]=\"{'layout-sidebar-active': appMainService.sidebarActive}\"\n (click)=\"appMainService.onSidebarClick($event)\" (mouseover)=\"appMainService.onSidebarMouseOver($event)\" (mouseleave)=\"appMainService.onSidebarMouseLeave($event)\">\n <div class=\"menu-logo\" *ngIf=\"!appSettings.isHorizontal() || appMainService.isMobile()\">\n\n <a href=\"#\" class=\"logo\">\n <img [src]=\"'assets/layout/images/logo-'+ (appSettings.colorScheme === 'light' ? 'dark' : 'light') + '.png'\">\n </a>\n\n <a href=\"#\" class=\"app-name\" *ngIf=\"!appSettings.isSlim() || appMainService.isMobile()\">\n <img [src]=\"'assets/layout/images/appname-'+ (appSettings.colorScheme === 'light' ? 'dark' : 'light') + '.png'\"/>\n </a>\n<!-- <a href=\"#\" class=\"menu-pin\" (click)=\"appMain.onToggleMenu($event)\">-->\n<!-- <span *ngIf=\"appMain.isOverlay()\" class=\"pi pi-times\"></span>-->\n<!-- <span *ngIf=\"appMain.isSidebar() && !appMain.sidebarStatic && appMain.pinActive\" class=\"pi pi-unlock\"></span>-->\n<!-- <span *ngIf=\"appMain.isSidebar() && appMain.sidebarStatic && appMain.pinActive\" class=\"pi pi-lock\"></span>-->\n<!-- </a>-->\n </div>\n\n <div class=\"layout-menu-container\">\n <ul class=\"layout-menu\">\n <ng-container *ngFor=\"let item of model; let i = index;\">\n <li app-menuitem *ngIf=\"!item.separator\" [item]=\"item\" [index]=\"i\" [root]=\"true\"></li>\n <li *ngIf=\"item.separator\" class=\"menu-separator\"></li>\n </ng-container>\n </ul>\n </div>\n</div>\n" }]
37
- }], ctorParameters: function () { return [{ type: i1.AppSettingsService }, { type: i2.AppMainComponentService }]; } });
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwLm1lbnUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbW5nLWNvbW1vbnMvc3JjL2xpYi9jb21wb25lbnRzL2xheW91dC9hcHAubWVudS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tbmctY29tbW9ucy9zcmMvbGliL2NvbXBvbmVudHMvbGF5b3V0L2FwcC5tZW51LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQVMsTUFBTSxlQUFlLENBQUM7Ozs7OztBQVdoRCxNQUFNLE9BQU8sZ0JBQWdCO0lBSXpCLFlBQW1CLFdBQStCLEVBQy9CLGNBQXVDO1FBRHZDLGdCQUFXLEdBQVgsV0FBVyxDQUFvQjtRQUMvQixtQkFBYyxHQUFkLGNBQWMsQ0FBeUI7UUFIbkQsVUFBSyxHQUFlLEVBQUUsQ0FBQztJQUcrQixDQUFDO0lBRTlELFFBQVE7UUFDSixJQUFJLENBQUMsS0FBSyxHQUFHO1lBQ1Q7Z0JBQ0ksS0FBSyxFQUFFLHNCQUFzQixFQUFFLElBQUksRUFBRSxZQUFZLEVBQUUsVUFBVSxFQUFFLENBQUMsWUFBWSxDQUFDO2FBQ2hGO1lBQ0Q7Z0JBQ0ksS0FBSyxFQUFFLDJCQUEyQixFQUFFLElBQUksRUFBRSxrQkFBa0IsRUFBRSxVQUFVLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQzthQUNqRztZQUNEO2dCQUNJLEtBQUssRUFBRSxzQkFBc0IsRUFBRSxJQUFJLEVBQUUsa0JBQWtCLEVBQUUsVUFBVSxFQUFFLENBQUMsWUFBWSxDQUFDO2dCQUNuRixLQUFLLEVBQUU7b0JBQ0g7d0JBQ0ksS0FBSyxFQUFFLGdDQUFnQyxFQUFFLElBQUksRUFBRSxtQkFBbUIsRUFBRSxVQUFVLEVBQUUsQ0FBQyxpQ0FBaUMsQ0FBQztxQkFDdEg7aUJBQ0o7YUFDSjtTQUNKLENBQUM7SUFDTixDQUFDOzs2R0F4QlEsZ0JBQWdCO2lHQUFoQixnQkFBZ0IsZ0RDWDdCLDRwREEyQkE7MkZEaEJhLGdCQUFnQjtrQkFKNUIsU0FBUzsrQkFDSSxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21wb25lbnQsIE9uSW5pdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IE1lbnVJdGVtIH0gZnJvbSAncHJpbWVuZy9hcGknO1xuXG5pbXBvcnQge0FwcFNldHRpbmdzU2VydmljZX0gZnJvbSAnLi4vLi4vc2VydmljZXMvc2V0dGluZ3Muc2VydmljZSc7XG5pbXBvcnQge0FwcE1haW5Db21wb25lbnRTZXJ2aWNlfSBmcm9tICcuL2FwcC5tYWluLmNvbXBvbmVudC5zZXJ2aWNlJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdhcHAtbWVudScsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2FwcC5tZW51LmNvbXBvbmVudC5odG1sJ1xufSlcbmV4cG9ydCBjbGFzcyBBcHBNZW51Q29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcblxuICAgIHB1YmxpYyBtb2RlbDogTWVudUl0ZW1bXSA9IFtdO1xuXG4gICAgY29uc3RydWN0b3IocHVibGljIGFwcFNldHRpbmdzOiBBcHBTZXR0aW5nc1NlcnZpY2UsXG4gICAgICAgICAgICAgICAgcHVibGljIGFwcE1haW5TZXJ2aWNlOiBBcHBNYWluQ29tcG9uZW50U2VydmljZSkge31cblxuICAgIG5nT25Jbml0KCkge1xuICAgICAgICB0aGlzLm1vZGVsID0gW1xuICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgIGxhYmVsOiAncGFnZXMuZGFzaGJvYXJkLm5hbWUnLCBpY29uOiAncGkgcGktaG9tZScsIHJvdXRlckxpbms6IFsnL2Rhc2hib2FyZCddLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICBsYWJlbDogJ3BhZ2VzLnB1YmxpY1NlcnZpY2VzLm5hbWUnLCBpY29uOiAncGkgcGktZncgcGktYm9vaycsIHJvdXRlckxpbms6IFsnL3B1YmxpYy1zZXJ2aWNlcyddXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgIGxhYmVsOiAncGFnZXMuY29kZWxpc3RzLm5hbWUnLCBpY29uOiAncGkgcGktZncgcGktbGlzdCcsIHJvdXRlckxpbms6IFsnL2NvZGVsaXN0cyddLFxuICAgICAgICAgICAgICAgIGl0ZW1zOiBbXG4gICAgICAgICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIGxhYmVsOiAncGFnZXMucHVibGljT3JnYW5pemF0aW9ucy5uYW1lJywgaWNvbjogJ3BpIHBpLWZ3IHBpLWdsb2JlJywgcm91dGVyTGluazogWycvY29kZWxpc3RzL3B1YmxpYy1vcmdhbml6YXRpb25zJ11cbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIF1cbiAgICAgICAgICAgIH1cbiAgICAgICAgXTtcbiAgICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwibGF5b3V0LW1lbnUtd3JhcHBlclwiIFtuZ0NsYXNzXT1cInsnbGF5b3V0LXNpZGViYXItYWN0aXZlJzogYXBwTWFpblNlcnZpY2Uuc2lkZWJhckFjdGl2ZX1cIlxuICAgICAoY2xpY2spPVwiYXBwTWFpblNlcnZpY2Uub25TaWRlYmFyQ2xpY2soJGV2ZW50KVwiIChtb3VzZW92ZXIpPVwiYXBwTWFpblNlcnZpY2Uub25TaWRlYmFyTW91c2VPdmVyKCRldmVudClcIiAobW91c2VsZWF2ZSk9XCJhcHBNYWluU2VydmljZS5vblNpZGViYXJNb3VzZUxlYXZlKCRldmVudClcIj5cbiAgICA8ZGl2IGNsYXNzPVwibWVudS1sb2dvXCIgKm5nSWY9XCIhYXBwU2V0dGluZ3MuaXNIb3Jpem9udGFsKCkgfHwgYXBwTWFpblNlcnZpY2UuaXNNb2JpbGUoKVwiPlxuXG4gICAgICAgIDxhIGhyZWY9XCIjXCIgY2xhc3M9XCJsb2dvXCI+XG4gICAgICAgICAgICA8aW1nIFtzcmNdPVwiJ2Fzc2V0cy9sYXlvdXQvaW1hZ2VzL2xvZ28tJysgKGFwcFNldHRpbmdzLmNvbG9yU2NoZW1lID09PSAnbGlnaHQnID8gJ2RhcmsnIDogJ2xpZ2h0JykgKyAnLnBuZydcIj5cbiAgICAgICAgPC9hPlxuXG4gICAgICAgIDxhIGhyZWY9XCIjXCIgY2xhc3M9XCJhcHAtbmFtZVwiICpuZ0lmPVwiIWFwcFNldHRpbmdzLmlzU2xpbSgpIHx8IGFwcE1haW5TZXJ2aWNlLmlzTW9iaWxlKClcIj5cbiAgICAgICAgICAgIDxpbWcgW3NyY109XCInYXNzZXRzL2xheW91dC9pbWFnZXMvYXBwbmFtZS0nKyAoYXBwU2V0dGluZ3MuY29sb3JTY2hlbWUgPT09ICdsaWdodCcgPyAnZGFyaycgOiAnbGlnaHQnKSArICcucG5nJ1wiLz5cbiAgICAgICAgPC9hPlxuPCEtLSAgICAgICAgPGEgaHJlZj1cIiNcIiBjbGFzcz1cIm1lbnUtcGluXCIgKGNsaWNrKT1cImFwcE1haW4ub25Ub2dnbGVNZW51KCRldmVudClcIj4tLT5cbjwhLS0gICAgICAgICAgICA8c3BhbiAqbmdJZj1cImFwcE1haW4uaXNPdmVybGF5KClcIiBjbGFzcz1cInBpIHBpLXRpbWVzXCI+PC9zcGFuPi0tPlxuPCEtLSAgICAgICAgICAgIDxzcGFuICpuZ0lmPVwiYXBwTWFpbi5pc1NpZGViYXIoKSAmJiAhYXBwTWFpbi5zaWRlYmFyU3RhdGljICYmIGFwcE1haW4ucGluQWN0aXZlXCIgY2xhc3M9XCJwaSBwaS11bmxvY2tcIj48L3NwYW4+LS0+XG48IS0tICAgICAgICAgICAgPHNwYW4gKm5nSWY9XCJhcHBNYWluLmlzU2lkZWJhcigpICYmIGFwcE1haW4uc2lkZWJhclN0YXRpYyAmJiBhcHBNYWluLnBpbkFjdGl2ZVwiIGNsYXNzPVwicGkgcGktbG9ja1wiPjwvc3Bhbj4tLT5cbjwhLS0gICAgICAgIDwvYT4tLT5cbiAgICA8L2Rpdj5cblxuICAgIDxkaXYgY2xhc3M9XCJsYXlvdXQtbWVudS1jb250YWluZXJcIj5cbiAgICAgICAgPHVsIGNsYXNzPVwibGF5b3V0LW1lbnVcIj5cbiAgICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nRm9yPVwibGV0IGl0ZW0gb2YgbW9kZWw7IGxldCBpID0gaW5kZXg7XCI+XG4gICAgICAgICAgICAgICAgPGxpIGFwcC1tZW51aXRlbSAqbmdJZj1cIiFpdGVtLnNlcGFyYXRvclwiIFtpdGVtXT1cIml0ZW1cIiBbaW5kZXhdPVwiaVwiIFtyb290XT1cInRydWVcIj48L2xpPlxuICAgICAgICAgICAgICAgIDxsaSAqbmdJZj1cIml0ZW0uc2VwYXJhdG9yXCIgY2xhc3M9XCJtZW51LXNlcGFyYXRvclwiPjwvbGk+XG4gICAgICAgICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICAgICAgPC91bD5cbiAgICA8L2Rpdj5cbjwvZGl2PlxuIl19
22
+ args: [{ selector: 'app-menu', template: "<div class=\"layout-menu-wrapper\" [ngClass]=\"{'layout-sidebar-active': appMainService.sidebarActive}\"\n (click)=\"appMainService.onSidebarClick($event)\" (mouseover)=\"appMainService.onSidebarMouseOver($event)\" (mouseleave)=\"appMainService.onSidebarMouseLeave($event)\">\n <div class=\"menu-logo\" *ngIf=\"!appSettings.isHorizontal() || appMainService.isMobile()\">\n\n <a href=\"#\" class=\"logo\">\n <img [src]=\"'assets/layout/images/logo-'+ (appSettings.colorScheme === 'light' ? 'dark' : 'light') + '.png'\">\n </a>\n\n <a href=\"#\" class=\"app-name\" *ngIf=\"!appSettings.isSlim() || appMainService.isMobile()\">\n <img [src]=\"'assets/layout/images/appname-'+ (appSettings.colorScheme === 'light' ? 'dark' : 'light') + '.png'\"/>\n </a>\n<!-- <a href=\"#\" class=\"menu-pin\" (click)=\"appMain.onToggleMenu($event)\">-->\n<!-- <span *ngIf=\"appMain.isOverlay()\" class=\"pi pi-times\"></span>-->\n<!-- <span *ngIf=\"appMain.isSidebar() && !appMain.sidebarStatic && appMain.pinActive\" class=\"pi pi-unlock\"></span>-->\n<!-- <span *ngIf=\"appMain.isSidebar() && appMain.sidebarStatic && appMain.pinActive\" class=\"pi pi-lock\"></span>-->\n<!-- </a>-->\n </div>\n\n <div class=\"layout-menu-container\">\n <ul class=\"layout-menu\">\n <ng-container *ngFor=\"let item of menu; let i = index;\">\n <li app-menuitem *ngIf=\"!item.separator\" [item]=\"item\" [index]=\"i\" [root]=\"true\"></li>\n <li *ngIf=\"item.separator\" class=\"menu-separator\"></li>\n </ng-container>\n </ul>\n </div>\n</div>\n" }]
23
+ }], ctorParameters: function () { return [{ type: i1.AppSettingsService }, { type: i2.AppMainComponentService }, { type: i1.MenuService }]; } });
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwLm1lbnUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbW5nLWNvbW1vbnMvc3JjL2xpYi9jb21wb25lbnRzL2xheW91dC9hcHAubWVudS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tbmctY29tbW9ucy9zcmMvbGliL2NvbXBvbmVudHMvbGF5b3V0L2FwcC5tZW51LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQVMsTUFBTSxlQUFlLENBQUM7Ozs7OztBQVdoRCxNQUFNLE9BQU8sZ0JBQWdCO0lBSXpCLFlBQW1CLFdBQStCLEVBQy9CLGNBQXVDLEVBQ3RDLFdBQXdCO1FBRnpCLGdCQUFXLEdBQVgsV0FBVyxDQUFvQjtRQUMvQixtQkFBYyxHQUFkLGNBQWMsQ0FBeUI7UUFDdEMsZ0JBQVcsR0FBWCxXQUFXLENBQWE7UUFKckMsU0FBSSxHQUFlLEVBQUUsQ0FBQztJQUlrQixDQUFDO0lBRWhELFFBQVE7UUFDSixJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsU0FBUyxDQUFDO0lBQzNDLENBQUM7OzZHQVZRLGdCQUFnQjtpR0FBaEIsZ0JBQWdCLGdEQ1g3QiwycERBMkJBOzJGRGhCYSxnQkFBZ0I7a0JBSjVCLFNBQVM7K0JBQ0ksVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBPbkluaXR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBNZW51SXRlbSB9IGZyb20gJ3ByaW1lbmcvYXBpJztcblxuaW1wb3J0IHtBcHBTZXR0aW5nc1NlcnZpY2UsIE1lbnVTZXJ2aWNlfSBmcm9tICcuLi8uLi9zZXJ2aWNlcyc7XG5pbXBvcnQge0FwcE1haW5Db21wb25lbnRTZXJ2aWNlfSBmcm9tICcuL2FwcC5tYWluLmNvbXBvbmVudC5zZXJ2aWNlJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdhcHAtbWVudScsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2FwcC5tZW51LmNvbXBvbmVudC5odG1sJ1xufSlcbmV4cG9ydCBjbGFzcyBBcHBNZW51Q29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcblxuICAgIHB1YmxpYyBtZW51OiBNZW51SXRlbVtdID0gW107XG5cbiAgICBjb25zdHJ1Y3RvcihwdWJsaWMgYXBwU2V0dGluZ3M6IEFwcFNldHRpbmdzU2VydmljZSxcbiAgICAgICAgICAgICAgICBwdWJsaWMgYXBwTWFpblNlcnZpY2U6IEFwcE1haW5Db21wb25lbnRTZXJ2aWNlLFxuICAgICAgICAgICAgICAgIHByaXZhdGUgbWVudVNlcnZpY2U6IE1lbnVTZXJ2aWNlKSB7fVxuXG4gICAgbmdPbkluaXQoKSB7XG4gICAgICAgIHRoaXMubWVudSA9IHRoaXMubWVudVNlcnZpY2UubWVudUl0ZW1zO1xuICAgIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJsYXlvdXQtbWVudS13cmFwcGVyXCIgW25nQ2xhc3NdPVwieydsYXlvdXQtc2lkZWJhci1hY3RpdmUnOiBhcHBNYWluU2VydmljZS5zaWRlYmFyQWN0aXZlfVwiXG4gICAgIChjbGljayk9XCJhcHBNYWluU2VydmljZS5vblNpZGViYXJDbGljaygkZXZlbnQpXCIgKG1vdXNlb3Zlcik9XCJhcHBNYWluU2VydmljZS5vblNpZGViYXJNb3VzZU92ZXIoJGV2ZW50KVwiIChtb3VzZWxlYXZlKT1cImFwcE1haW5TZXJ2aWNlLm9uU2lkZWJhck1vdXNlTGVhdmUoJGV2ZW50KVwiPlxuICAgIDxkaXYgY2xhc3M9XCJtZW51LWxvZ29cIiAqbmdJZj1cIiFhcHBTZXR0aW5ncy5pc0hvcml6b250YWwoKSB8fCBhcHBNYWluU2VydmljZS5pc01vYmlsZSgpXCI+XG5cbiAgICAgICAgPGEgaHJlZj1cIiNcIiBjbGFzcz1cImxvZ29cIj5cbiAgICAgICAgICAgIDxpbWcgW3NyY109XCInYXNzZXRzL2xheW91dC9pbWFnZXMvbG9nby0nKyAoYXBwU2V0dGluZ3MuY29sb3JTY2hlbWUgPT09ICdsaWdodCcgPyAnZGFyaycgOiAnbGlnaHQnKSArICcucG5nJ1wiPlxuICAgICAgICA8L2E+XG5cbiAgICAgICAgPGEgaHJlZj1cIiNcIiBjbGFzcz1cImFwcC1uYW1lXCIgKm5nSWY9XCIhYXBwU2V0dGluZ3MuaXNTbGltKCkgfHwgYXBwTWFpblNlcnZpY2UuaXNNb2JpbGUoKVwiPlxuICAgICAgICAgICAgPGltZyBbc3JjXT1cIidhc3NldHMvbGF5b3V0L2ltYWdlcy9hcHBuYW1lLScrIChhcHBTZXR0aW5ncy5jb2xvclNjaGVtZSA9PT0gJ2xpZ2h0JyA/ICdkYXJrJyA6ICdsaWdodCcpICsgJy5wbmcnXCIvPlxuICAgICAgICA8L2E+XG48IS0tICAgICAgICA8YSBocmVmPVwiI1wiIGNsYXNzPVwibWVudS1waW5cIiAoY2xpY2spPVwiYXBwTWFpbi5vblRvZ2dsZU1lbnUoJGV2ZW50KVwiPi0tPlxuPCEtLSAgICAgICAgICAgIDxzcGFuICpuZ0lmPVwiYXBwTWFpbi5pc092ZXJsYXkoKVwiIGNsYXNzPVwicGkgcGktdGltZXNcIj48L3NwYW4+LS0+XG48IS0tICAgICAgICAgICAgPHNwYW4gKm5nSWY9XCJhcHBNYWluLmlzU2lkZWJhcigpICYmICFhcHBNYWluLnNpZGViYXJTdGF0aWMgJiYgYXBwTWFpbi5waW5BY3RpdmVcIiBjbGFzcz1cInBpIHBpLXVubG9ja1wiPjwvc3Bhbj4tLT5cbjwhLS0gICAgICAgICAgICA8c3BhbiAqbmdJZj1cImFwcE1haW4uaXNTaWRlYmFyKCkgJiYgYXBwTWFpbi5zaWRlYmFyU3RhdGljICYmIGFwcE1haW4ucGluQWN0aXZlXCIgY2xhc3M9XCJwaSBwaS1sb2NrXCI+PC9zcGFuPi0tPlxuPCEtLSAgICAgICAgPC9hPi0tPlxuICAgIDwvZGl2PlxuXG4gICAgPGRpdiBjbGFzcz1cImxheW91dC1tZW51LWNvbnRhaW5lclwiPlxuICAgICAgICA8dWwgY2xhc3M9XCJsYXlvdXQtbWVudVwiPlxuICAgICAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdGb3I9XCJsZXQgaXRlbSBvZiBtZW51OyBsZXQgaSA9IGluZGV4O1wiPlxuICAgICAgICAgICAgICAgIDxsaSBhcHAtbWVudWl0ZW0gKm5nSWY9XCIhaXRlbS5zZXBhcmF0b3JcIiBbaXRlbV09XCJpdGVtXCIgW2luZGV4XT1cImlcIiBbcm9vdF09XCJ0cnVlXCI+PC9saT5cbiAgICAgICAgICAgICAgICA8bGkgKm5nSWY9XCJpdGVtLnNlcGFyYXRvclwiIGNsYXNzPVwibWVudS1zZXBhcmF0b3JcIj48L2xpPlxuICAgICAgICAgICAgPC9uZy1jb250YWluZXI+XG4gICAgICAgIDwvdWw+XG4gICAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==
@@ -23,15 +23,13 @@ export class AppMenuitemComponent {
23
23
  this.active = false;
24
24
  this.hover = false;
25
25
  this.key = '';
26
- // TODO: remove ignore
27
- // @ts-ignore
28
- this.menuSourceSubscription = this.menuService.menuSource$.subscribe(key => {
26
+ this.menuSourceSubscription = this.menuService.menu$.subscribe(key => {
29
27
  // deactivate current active menu
30
28
  if (this.active && this.key !== key && key.indexOf(this.key) !== 0) {
31
29
  this.active = false;
32
30
  }
33
31
  });
34
- this.menuResetSubscription = this.menuService.resetSource$.subscribe(() => {
32
+ this.menuResetSubscription = this.menuService.reset$.subscribe(() => {
35
33
  this.active = false;
36
34
  });
37
35
  this.router.events.pipe(filter(event => event instanceof NavigationEnd))
@@ -240,4 +238,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
240
238
  }], parentKey: [{
241
239
  type: Input
242
240
  }] } });
243
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"app.menuitem.component.js","sourceRoot":"","sources":["../../../../../../projects/mng-commons/src/lib/components/layout/app.menuitem.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input, OnInit, ChangeDetectorRef, OnDestroy} from '@angular/core';\nimport {Router, NavigationEnd} from '@angular/router';\nimport {trigger, state, style, transition, animate} from '@angular/animations';\n\nimport {Subscription} from 'rxjs';\nimport {filter} from 'rxjs/operators';\n\nimport {MenuService} from '../../services/menu.service';\nimport {AppSettingsService} from '../../services/settings.service';\nimport {AppMainComponentService} from './app.main.component.service';\n\n@Component({\n    /* tslint:disable:component-selector */\n    selector: '[app-menuitem]',\n    /* tslint:enable:component-selector */\n    template: `\n        <ng-container>\n            <div *ngIf=\"root && item.visible !== false\" class=\"layout-menuitem-root-text\">{{ item.label | translate }}</div>\n            <a [attr.href]=\"item.url\" (click)=\"itemClick($event)\" *ngIf=\"(!item.routerLink || item.items) && item.visible !== false\"\n               (mouseenter)=\"onMouseEnter()\" (keydown.enter)=\"itemClick($event)\"\n               [attr.target]=\"item.target\" [attr.tabindex]=\"0\" [ngClass]=\"item.class\" pRipple>\n                <i [ngClass]=\"item.icon\" class=\"layout-menuitem-icon\"></i>\n                <span class=\"layout-menuitem-text\">{{ item.label | translate }}</span>\n                <i class=\"pi pi-fw pi-angle-down layout-submenu-toggler\" *ngIf=\"item.items\"></i>\n                <span class=\"menuitem-badge\" *ngIf=\"item.badge\">{{item.badge}}</span>\n            </a>\n            <a (click)=\"itemClick($event)\" (mouseenter)=\"hover=true\" (mouseleave)=\"hover=false\"\n               *ngIf=\"(item.routerLink && !item.items) && item.visible !== false\"\n               [routerLink]=\"item.routerLink\" routerLinkActive=\"active-menuitem-routerlink\"\n               [routerLinkActiveOptions]=\"{exact: true}\" [attr.target]=\"item.target\" [attr.tabindex]=\"0\"\n               [ngClass]=\"item.class\" pRipple>\n                <i [ngClass]=\"item.icon\" class=\"layout-menuitem-icon\"></i>\n                <span class=\"layout-menuitem-text\">{{ item.label | translate }}</span>\n                <i class=\"pi pi-fw pi-angle-down layout-submenu-toggler\" *ngIf=\"item.items\"></i>\n                <span class=\"menuitem-badge\" *ngIf=\"item.badge\">{{item.badge}}</span>\n            </a>\n            <ul *ngIf=\"((item.items && active) || (item.items && appSettings.isStatic() && (root || active))) && item.visible !== false\" [@children]=\"(\n            (appSettings.isSlim()||appSettings.isHorizontal()) && !appMainService.isMobile() && root) ?\n            (active ? 'visible' : 'hidden') :\n            (appSettings.isStatic() && root && !appMainService.isMobile() ? 'visible' : (active ? 'visibleAnimated' : 'hiddenAnimated'))\">\n                <ng-template ngFor let-child let-i=\"index\" [ngForOf]=\"item.items\">\n                        <li app-menuitem [item]=\"child\" [index]=\"i\" [parentKey]=\"key\" [class]=\"child.badgeClass\"></li>\n                </ng-template>\n            </ul>\n        </ng-container>\n    `,\n    host: {\n        '[class.layout-root-menuitem]': 'root',\n        '[class.active-menuitem]': 'active'\n    },\n    animations: [\n        trigger('children', [\n            state('void', style({\n                height: '0px'\n            })),\n            state('hiddenAnimated', style({\n                height: '0px'\n            })),\n            state('visibleAnimated', style({\n                height: '*'\n            })),\n            state('visible', style({\n                height: '*',\n                'z-index': 100\n            })),\n            state('hidden', style({\n                height: '0px',\n                'z-index': '*'\n            })),\n            transition('visibleAnimated => hiddenAnimated', animate('400ms cubic-bezier(0.86, 0, 0.07, 1)')),\n            transition('hiddenAnimated => visibleAnimated', animate('400ms cubic-bezier(0.86, 0, 0.07, 1)')),\n            transition('void => visibleAnimated, visibleAnimated => void', animate('400ms cubic-bezier(0.86, 0, 0.07, 1)'))\n        ])\n    ]\n})\nexport class AppMenuitemComponent implements OnInit, OnDestroy {\n\n    @Input() item: any;\n\n    @Input() index: number = 0;\n\n    @Input() root: boolean = false;\n\n    @Input() parentKey: string|null = null;\n\n    active = false;\n\n    hover: boolean = false;\n\n    menuSourceSubscription: Subscription;\n\n    menuResetSubscription: Subscription;\n\n    key: string = '';\n\n    constructor(public appSettings: AppSettingsService, public appMainService: AppMainComponentService, public router: Router, private cd: ChangeDetectorRef, private menuService: MenuService) {\n        // TODO: remove ignore\n        // @ts-ignore\n        this.menuSourceSubscription = this.menuService.menuSource$.subscribe(key => {\n            // deactivate current active menu\n            if (this.active && this.key !== key && key.indexOf(this.key) !== 0) {\n                this.active = false;\n            }\n        });\n\n        this.menuResetSubscription = this.menuService.resetSource$.subscribe(() => {\n            this.active = false;\n        });\n\n        this.router.events.pipe(filter(event => event instanceof NavigationEnd))\n            .subscribe(params => {\n                if ((this.appSettings.isSlim() || this.appSettings.isHorizontal()) && !this.appMainService.isMobile()) {\n                    this.active = false;\n                } else {\n                    if (this.item.routerLink) {\n                        this.updateActiveStateFromRoute();\n                    } else {\n                        this.active = false;\n                    }\n                }\n            });\n    }\n\n    ngOnInit() {\n        if (!(this.appSettings.isSlim() || this.appSettings.isHorizontal()) && this.item.routerLink) {\n            this.updateActiveStateFromRoute();\n        }\n\n        this.key = this.parentKey ? this.parentKey + '-' + this.index : String(this.index);\n    }\n\n    updateActiveStateFromRoute() {\n        this.active = this.router.isActive(this.item.routerLink[0], this.item.items ? false : true);\n    }\n\n    itemClick(event: Event) {\n        // avoid processing disabled items\n        if (this.item.disabled) {\n            event.preventDefault();\n            return;\n        }\n\n        // navigate with hover in horizontal mode\n        if (this.root) {\n            this.appMainService.menuHoverActive = !this.appMainService.menuHoverActive;\n        }\n\n        // notify other items\n        this.menuService.onMenuStateChange(this.key);\n\n        // execute command\n        if (this.item.command) {\n            this.item.command({originalEvent: event, item: this.item});\n        }\n\n        // toggle active state\n        if (this.item.items) {\n            this.active = !this.active;\n        } else {\n            // activate item\n            this.active = true;\n\n            if (this.appMainService.isMobile()) {\n                this.appMainService.staticMenuMobileActive = false;\n            }\n\n            if (this.appSettings.isOverlay()) {\n                this.appMainService.overlayMenuActive = false;\n            }\n\n            // reset horizontal menu\n            if ((this.appSettings.isSlim() || this.appSettings.isHorizontal()) && !this.appMainService.isMobile()){\n                this.menuService.reset();\n                this.appMainService.menuHoverActive = false;\n            }\n        }\n    }\n\n    onMouseEnter() {\n        // activate item on hover\n        if (this.root && this.appMainService.menuHoverActive && (this.appSettings.isSlim() || this.appSettings.isHorizontal()) && this.appMainService.isDesktop()) {\n            this.menuService.onMenuStateChange(this.key);\n            this.active = true;\n        }\n    }\n\n    ngOnDestroy() {\n        if (this.menuSourceSubscription) {\n            this.menuSourceSubscription.unsubscribe();\n        }\n\n        if (this.menuResetSubscription) {\n            this.menuResetSubscription.unsubscribe();\n        }\n    }\n}\n"]}
241
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"app.menuitem.component.js","sourceRoot":"","sources":["../../../../../../projects/mng-commons/src/lib/components/layout/app.menuitem.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input, OnInit, ChangeDetectorRef, OnDestroy} from '@angular/core';\nimport {Router, NavigationEnd} from '@angular/router';\nimport {trigger, state, style, transition, animate} from '@angular/animations';\n\nimport {Subscription} from 'rxjs';\nimport {filter} from 'rxjs/operators';\n\nimport {MenuService} from '../../services/menu.service';\nimport {AppSettingsService} from '../../services/settings.service';\nimport {AppMainComponentService} from './app.main.component.service';\n\n@Component({\n    /* tslint:disable:component-selector */\n    selector: '[app-menuitem]',\n    /* tslint:enable:component-selector */\n    template: `\n        <ng-container>\n            <div *ngIf=\"root && item.visible !== false\" class=\"layout-menuitem-root-text\">{{ item.label | translate }}</div>\n            <a [attr.href]=\"item.url\" (click)=\"itemClick($event)\" *ngIf=\"(!item.routerLink || item.items) && item.visible !== false\"\n               (mouseenter)=\"onMouseEnter()\" (keydown.enter)=\"itemClick($event)\"\n               [attr.target]=\"item.target\" [attr.tabindex]=\"0\" [ngClass]=\"item.class\" pRipple>\n                <i [ngClass]=\"item.icon\" class=\"layout-menuitem-icon\"></i>\n                <span class=\"layout-menuitem-text\">{{ item.label | translate }}</span>\n                <i class=\"pi pi-fw pi-angle-down layout-submenu-toggler\" *ngIf=\"item.items\"></i>\n                <span class=\"menuitem-badge\" *ngIf=\"item.badge\">{{item.badge}}</span>\n            </a>\n            <a (click)=\"itemClick($event)\" (mouseenter)=\"hover=true\" (mouseleave)=\"hover=false\"\n               *ngIf=\"(item.routerLink && !item.items) && item.visible !== false\"\n               [routerLink]=\"item.routerLink\" routerLinkActive=\"active-menuitem-routerlink\"\n               [routerLinkActiveOptions]=\"{exact: true}\" [attr.target]=\"item.target\" [attr.tabindex]=\"0\"\n               [ngClass]=\"item.class\" pRipple>\n                <i [ngClass]=\"item.icon\" class=\"layout-menuitem-icon\"></i>\n                <span class=\"layout-menuitem-text\">{{ item.label | translate }}</span>\n                <i class=\"pi pi-fw pi-angle-down layout-submenu-toggler\" *ngIf=\"item.items\"></i>\n                <span class=\"menuitem-badge\" *ngIf=\"item.badge\">{{item.badge}}</span>\n            </a>\n            <ul *ngIf=\"((item.items && active) || (item.items && appSettings.isStatic() && (root || active))) && item.visible !== false\" [@children]=\"(\n            (appSettings.isSlim()||appSettings.isHorizontal()) && !appMainService.isMobile() && root) ?\n            (active ? 'visible' : 'hidden') :\n            (appSettings.isStatic() && root && !appMainService.isMobile() ? 'visible' : (active ? 'visibleAnimated' : 'hiddenAnimated'))\">\n                <ng-template ngFor let-child let-i=\"index\" [ngForOf]=\"item.items\">\n                        <li app-menuitem [item]=\"child\" [index]=\"i\" [parentKey]=\"key\" [class]=\"child.badgeClass\"></li>\n                </ng-template>\n            </ul>\n        </ng-container>\n    `,\n    host: {\n        '[class.layout-root-menuitem]': 'root',\n        '[class.active-menuitem]': 'active'\n    },\n    animations: [\n        trigger('children', [\n            state('void', style({\n                height: '0px'\n            })),\n            state('hiddenAnimated', style({\n                height: '0px'\n            })),\n            state('visibleAnimated', style({\n                height: '*'\n            })),\n            state('visible', style({\n                height: '*',\n                'z-index': 100\n            })),\n            state('hidden', style({\n                height: '0px',\n                'z-index': '*'\n            })),\n            transition('visibleAnimated => hiddenAnimated', animate('400ms cubic-bezier(0.86, 0, 0.07, 1)')),\n            transition('hiddenAnimated => visibleAnimated', animate('400ms cubic-bezier(0.86, 0, 0.07, 1)')),\n            transition('void => visibleAnimated, visibleAnimated => void', animate('400ms cubic-bezier(0.86, 0, 0.07, 1)'))\n        ])\n    ]\n})\nexport class AppMenuitemComponent implements OnInit, OnDestroy {\n\n    @Input() item: any;\n\n    @Input() index: number = 0;\n\n    @Input() root: boolean = false;\n\n    @Input() parentKey: string|null = null;\n\n    active = false;\n\n    hover: boolean = false;\n\n    menuSourceSubscription: Subscription;\n\n    menuResetSubscription: Subscription;\n\n    key: string = '';\n\n    constructor(public appSettings: AppSettingsService, public appMainService: AppMainComponentService, public router: Router, private cd: ChangeDetectorRef, private menuService: MenuService) {\n        this.menuSourceSubscription = this.menuService.menu$.subscribe(key => {\n            // deactivate current active menu\n            if (this.active && this.key !== key && key.indexOf(this.key) !== 0) {\n                this.active = false;\n            }\n        });\n\n        this.menuResetSubscription = this.menuService.reset$.subscribe(() => {\n            this.active = false;\n        });\n\n        this.router.events.pipe(filter(event => event instanceof NavigationEnd))\n            .subscribe(params => {\n                if ((this.appSettings.isSlim() || this.appSettings.isHorizontal()) && !this.appMainService.isMobile()) {\n                    this.active = false;\n                } else {\n                    if (this.item.routerLink) {\n                        this.updateActiveStateFromRoute();\n                    } else {\n                        this.active = false;\n                    }\n                }\n            });\n    }\n\n    ngOnInit() {\n        if (!(this.appSettings.isSlim() || this.appSettings.isHorizontal()) && this.item.routerLink) {\n            this.updateActiveStateFromRoute();\n        }\n\n        this.key = this.parentKey ? this.parentKey + '-' + this.index : String(this.index);\n    }\n\n    updateActiveStateFromRoute() {\n        this.active = this.router.isActive(this.item.routerLink[0], this.item.items ? false : true);\n    }\n\n    itemClick(event: Event) {\n        // avoid processing disabled items\n        if (this.item.disabled) {\n            event.preventDefault();\n            return;\n        }\n\n        // navigate with hover in horizontal mode\n        if (this.root) {\n            this.appMainService.menuHoverActive = !this.appMainService.menuHoverActive;\n        }\n\n        // notify other items\n        this.menuService.onMenuStateChange(this.key);\n\n        // execute command\n        if (this.item.command) {\n            this.item.command({originalEvent: event, item: this.item});\n        }\n\n        // toggle active state\n        if (this.item.items) {\n            this.active = !this.active;\n        } else {\n            // activate item\n            this.active = true;\n\n            if (this.appMainService.isMobile()) {\n                this.appMainService.staticMenuMobileActive = false;\n            }\n\n            if (this.appSettings.isOverlay()) {\n                this.appMainService.overlayMenuActive = false;\n            }\n\n            // reset horizontal menu\n            if ((this.appSettings.isSlim() || this.appSettings.isHorizontal()) && !this.appMainService.isMobile()){\n                this.menuService.reset();\n                this.appMainService.menuHoverActive = false;\n            }\n        }\n    }\n\n    onMouseEnter() {\n        // activate item on hover\n        if (this.root && this.appMainService.menuHoverActive && (this.appSettings.isSlim() || this.appSettings.isHorizontal()) && this.appMainService.isDesktop()) {\n            this.menuService.onMenuStateChange(this.key);\n            this.active = true;\n        }\n    }\n\n    ngOnDestroy() {\n        if (this.menuSourceSubscription) {\n            this.menuSourceSubscription.unsubscribe();\n        }\n\n        if (this.menuResetSubscription) {\n            this.menuResetSubscription.unsubscribe();\n        }\n    }\n}\n"]}