@acorex/platform 18.0.4 → 18.0.5

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 (70) hide show
  1. package/common/lib/data/dexie-storage.service.d.ts +0 -1
  2. package/common/lib/layout/grid-layout/grid-layout.types.d.ts +1 -2
  3. package/common/lib/schema/widgets/lookup/lookup-widget-filter.component.d.ts +1 -1
  4. package/common/lib/schema/widgets/lookup/lookup-widget-view.component.d.ts +2 -1
  5. package/common/lib/utils/data-generator.d.ts +13 -1
  6. package/common/lib/utils/index.d.ts +1 -0
  7. package/common/lib/utils/pdf.service.d.ts +25 -0
  8. package/esm2022/common/lib/data/dexie-storage.service.mjs +2 -4
  9. package/esm2022/common/lib/layout/grid-layout/grid-layout.directive.mjs +5 -5
  10. package/esm2022/common/lib/layout/grid-layout/grid-layout.types.mjs +1 -1
  11. package/esm2022/common/lib/schema/widgets/lookup/lookup-widget-edit.component.mjs +20 -3
  12. package/esm2022/common/lib/schema/widgets/lookup/lookup-widget-filter.component.mjs +20 -3
  13. package/esm2022/common/lib/schema/widgets/lookup/lookup-widget-view.component.mjs +5 -5
  14. package/esm2022/common/lib/utils/data-generator.mjs +67 -2
  15. package/esm2022/common/lib/utils/index.mjs +2 -1
  16. package/esm2022/common/lib/utils/pdf.service.mjs +85 -0
  17. package/esm2022/layout/entity/lib/entity-master-create.viewmodel.mjs +23 -19
  18. package/esm2022/layout/entity/lib/entity-master-list.viewmodel.mjs +27 -8
  19. package/esm2022/layout/entity/lib/entity-master-single.viewmodel.mjs +33 -28
  20. package/esm2022/layout/entity/lib/widgets/lookup-widget/lookup-widget-edit.component.mjs +22 -7
  21. package/esm2022/layout/entity/lib/widgets/lookup-widget/lookup-widget-selector.component.mjs +1 -2
  22. package/esm2022/layout/entity/lib/widgets/lookup-widget/lookup-widget-selector.viewmodel.mjs +15 -3
  23. package/esm2022/layout/entity/lib/workflows/create-entity.workflow.mjs +3 -4
  24. package/esm2022/layout/entity/lib/workflows/delete-entity.workflow.mjs +1 -4
  25. package/esm2022/themes/default/lib/layouts/entity-layouts/entity-master-list-view/entity-master-list-view.component.mjs +4 -1
  26. package/esm2022/themes/default/lib/layouts/entity-layouts/entity-master-single-view/entity-master-single-view.component.mjs +6 -3
  27. package/esm2022/widgets/lib/editors/date-time-box-widget/date-time-box-widget-view.component.mjs +1 -2
  28. package/esm2022/widgets/lib/editors/rich-text-widget/rich-text-widget-edit.component.mjs +3 -3
  29. package/esm2022/widgets/lib/editors/rich-text-widget/rich-text-widget-view.component.mjs +14 -8
  30. package/esm2022/widgets/lib/editors/selection-list-widget/selection-list-widget-view.component.mjs +3 -2
  31. package/esm2022/widgets/lib/editors/signature-pad-widget/signature-pad-widget-edit.component.mjs +3 -2
  32. package/esm2022/widgets/lib/editors/signature-pad-widget/signature-pad-widget-view.component.mjs +3 -2
  33. package/esm2022/widgets/lib/editors/text-box-widget/text-box-widget-edit.component.mjs +3 -2
  34. package/esm2022/widgets/lib/editors/text-box-widget/text-box-widget-view.component.mjs +3 -2
  35. package/esm2022/workflow/lib/actions/start-workflow.action.mjs +7 -3
  36. package/esm2022/workflow/lib/workflow.service.mjs +3 -3
  37. package/esm2022/workflow/lib/workflow.types.mjs +11 -10
  38. package/fesm2022/{acorex-platform-common-lookup-widget-edit.component-D9UhViUG.mjs → acorex-platform-common-lookup-widget-edit.component-Do_yV2hi.mjs} +19 -2
  39. package/fesm2022/acorex-platform-common-lookup-widget-edit.component-Do_yV2hi.mjs.map +1 -0
  40. package/fesm2022/{acorex-platform-common-lookup-widget-filter.component-RWweQQaO.mjs → acorex-platform-common-lookup-widget-filter.component-AKqbYe-l.mjs} +19 -2
  41. package/fesm2022/acorex-platform-common-lookup-widget-filter.component-AKqbYe-l.mjs.map +1 -0
  42. package/fesm2022/{acorex-platform-common-lookup-widget-view.component-mXo8VADX.mjs → acorex-platform-common-lookup-widget-view.component-BHqYDEuU.mjs} +5 -5
  43. package/fesm2022/acorex-platform-common-lookup-widget-view.component-BHqYDEuU.mjs.map +1 -0
  44. package/fesm2022/acorex-platform-common.mjs +159 -13
  45. package/fesm2022/acorex-platform-common.mjs.map +1 -1
  46. package/fesm2022/acorex-platform-layout-entity.mjs +116 -66
  47. package/fesm2022/acorex-platform-layout-entity.mjs.map +1 -1
  48. package/fesm2022/acorex-platform-themes-default.mjs +8 -2
  49. package/fesm2022/acorex-platform-themes-default.mjs.map +1 -1
  50. package/fesm2022/acorex-platform-widgets.mjs +24 -15
  51. package/fesm2022/acorex-platform-widgets.mjs.map +1 -1
  52. package/fesm2022/acorex-platform-workflow.mjs +18 -13
  53. package/fesm2022/acorex-platform-workflow.mjs.map +1 -1
  54. package/layout/entity/lib/entity-master-list.viewmodel.d.ts +7 -5
  55. package/layout/entity/lib/entity-master-single.viewmodel.d.ts +7 -5
  56. package/layout/entity/lib/widgets/lookup-widget/lookup-widget-edit.component.d.ts +2 -0
  57. package/package.json +1 -1
  58. package/themes/default/lib/layouts/entity-layouts/entity-master-list-view/entity-master-list-view.component.d.ts +1 -0
  59. package/themes/default/lib/layouts/entity-layouts/entity-master-single-view/entity-master-single-view.component.d.ts +1 -0
  60. package/widgets/lib/editors/rich-text-widget/rich-text-widget-edit.component.d.ts +1 -1
  61. package/widgets/lib/editors/rich-text-widget/rich-text-widget-view.component.d.ts +3 -2
  62. package/widgets/lib/editors/signature-pad-widget/signature-pad-widget-edit.component.d.ts +1 -1
  63. package/widgets/lib/editors/signature-pad-widget/signature-pad-widget-view.component.d.ts +1 -1
  64. package/widgets/lib/editors/text-box-widget/text-box-widget-edit.component.d.ts +1 -1
  65. package/widgets/lib/editors/text-box-widget/text-box-widget-view.component.d.ts +1 -1
  66. package/workflow/lib/workflow.service.d.ts +1 -1
  67. package/workflow/lib/workflow.types.d.ts +4 -3
  68. package/fesm2022/acorex-platform-common-lookup-widget-edit.component-D9UhViUG.mjs.map +0 -1
  69. package/fesm2022/acorex-platform-common-lookup-widget-filter.component-RWweQQaO.mjs.map +0 -1
  70. package/fesm2022/acorex-platform-common-lookup-widget-view.component-mXo8VADX.mjs.map +0 -1
@@ -18,21 +18,20 @@ export class AXPEntityCreatePopupAction extends AXPWorkflowAction {
18
18
  }
19
19
  async execute(context) {
20
20
  const [module, entity] = context.getVariable('entity').split(".");
21
- const dataContext = context.getVariable('context');
21
+ const data = context.getVariable('data');
22
22
  const entityRef = await this.entityRegistery.resolve(module, entity);
23
23
  const com = await this.config.viewers.master.create();
24
24
  const result = await this.popupService.open(com, {
25
25
  title: `Create New ${entityRef.formats.individual}`,
26
26
  size: this.platform.is('Mobile') || this.platform.is('SM') ? 'full' : 'md',
27
27
  data: {
28
- vm: await this.factory.create(module, entity, dataContext),
28
+ vm: await this.factory.create(module, entity, data),
29
29
  entity,
30
30
  },
31
31
  });
32
32
  context.setOutput('result', false);
33
33
  if (result.data?.save) {
34
34
  context.setOutput('result', true);
35
- context.setVariable('redirect', result.data.redirect);
36
35
  context.setVariable('data', result.data.item);
37
36
  }
38
37
  }
@@ -87,4 +86,4 @@ export const AXPCreateEntityWorkflow = {
87
86
  },
88
87
  },
89
88
  };
90
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-entity.workflow.js","sourceRoot":"","sources":["../../../../../../../../libs/platform/layout/entity/src/lib/workflows/create-entity.workflow.ts"],"names":[],"mappings":"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","sourcesContent":["import { AXPopupService } from '@acorex/components/popup';\r\nimport { AXPlatform } from '@acorex/core/platform';\r\nimport { AXPWorkflow, AXPWorkflowAction, AXPWorkflowContext, createWorkFlowEvent } from '@acorex/platform/workflow';\r\nimport { Injectable, inject } from '@angular/core';\r\nimport { AXPEntityCreateViewModelFactory } from '../entity-master-create.viewmodel';\r\nimport { AXPEntityDefinitionRegistryService } from '../entity-registery.service';\r\nimport { AXP_ENTITY_CONFIG_TOKEN } from '../entity.config';\r\n\r\nexport const AXPEntityCreateEvent = createWorkFlowEvent<{ entity: string }>('[Entity] Created!');\r\n\r\n@Injectable()\r\nexport class AXPEntityCreatePopupAction extends AXPWorkflowAction {\r\n  private entityRegistery = inject(AXPEntityDefinitionRegistryService);\r\n  private popupService = inject(AXPopupService);\r\n  private platform = inject(AXPlatform);\r\n  private factory = inject(AXPEntityCreateViewModelFactory);\r\n  private config = inject(AXP_ENTITY_CONFIG_TOKEN)\r\n\r\n\r\n\r\n  async execute(context: AXPWorkflowContext): Promise<void> {\r\n\r\n    const [module, entity] = context.getVariable<string>('entity').split(\".\");\r\n    const dataContext = context.getVariable<any>('context');\r\n    const entityRef = await this.entityRegistery.resolve(module, entity);\r\n    const com = await this.config.viewers.master.create();\r\n    const result = await this.popupService.open(com, {\r\n      title: `Create New ${entityRef.formats.individual}`,\r\n      size: this.platform.is('Mobile') || this.platform.is('SM') ? 'full' : 'md',\r\n      data: {\r\n        vm: await this.factory.create(module, entity, dataContext),\r\n        entity,\r\n      },\r\n    });\r\n    context.setOutput('result', false);\r\n    if (result.data?.save) {\r\n      context.setOutput('result', true);\r\n      context.setVariable('redirect', result.data.redirect);\r\n      context.setVariable('data', result.data.item);\r\n    }\r\n  }\r\n}\r\n\r\nexport class AXPEntityCreateSubmittedAction extends AXPWorkflowAction {\r\n  async execute(context: AXPWorkflowContext): Promise<void> {\r\n    this.dispatch(AXPEntityCreateEvent({ entity: context.getVariable<string>('entity') }));\r\n  }\r\n}\r\n\r\nexport const AXPCreateEntityWorkflow: AXPWorkflow = {\r\n  startStepId: 'show-popup',\r\n  steps: {\r\n    \"show-popup\": {\r\n      action: 'AXPEntityCreatePopupAction',\r\n      nextSteps: [\r\n        {\r\n          conditions: [{ type: 'SINGLE', expression: 'context.getOutput(\"result\") == true' }],\r\n          nextStepId: 'show-toast',\r\n        },\r\n      ],\r\n    },\r\n    \"show-toast\": {\r\n      action: 'AXPToastAction',\r\n      input: {\r\n        color: 'success',\r\n        title: 'Entity Created',\r\n        content: 'New Record has been successfully created.',\r\n      },\r\n      nextSteps: [\r\n        {\r\n          conditions: [],\r\n          nextStepId: 'dispatch-event',\r\n        },\r\n      ],\r\n    },\r\n    \"dispatch-event\": {\r\n      action: 'AXPEntityCreateSubmittedAction',\r\n      nextSteps: [\r\n        {\r\n          conditions: [{ type: 'SINGLE', expression: 'context.getVariable(\"redirect\") == true' }],\r\n          nextStepId: 'show-entity',\r\n        },\r\n      ],\r\n    },\r\n    \"show-entity\": {\r\n      action: 'AXPShowDetailViewAction',\r\n    },\r\n  },\r\n};\r\n"]}
89
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-entity.workflow.js","sourceRoot":"","sources":["../../../../../../../../libs/platform/layout/entity/src/lib/workflows/create-entity.workflow.ts"],"names":[],"mappings":"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","sourcesContent":["import { AXPopupService } from '@acorex/components/popup';\r\nimport { AXPlatform } from '@acorex/core/platform';\r\nimport { AXPWorkflow, AXPWorkflowAction, AXPWorkflowContext, createWorkFlowEvent } from '@acorex/platform/workflow';\r\nimport { Injectable, inject } from '@angular/core';\r\nimport { AXPEntityCreateViewModelFactory } from '../entity-master-create.viewmodel';\r\nimport { AXPEntityDefinitionRegistryService } from '../entity-registery.service';\r\nimport { AXP_ENTITY_CONFIG_TOKEN } from '../entity.config';\r\n\r\nexport const AXPEntityCreateEvent = createWorkFlowEvent<{ entity: string }>('[Entity] Created!');\r\n\r\n@Injectable()\r\nexport class AXPEntityCreatePopupAction extends AXPWorkflowAction {\r\n  private entityRegistery = inject(AXPEntityDefinitionRegistryService);\r\n  private popupService = inject(AXPopupService);\r\n  private platform = inject(AXPlatform);\r\n  private factory = inject(AXPEntityCreateViewModelFactory);\r\n  private config = inject(AXP_ENTITY_CONFIG_TOKEN)\r\n\r\n\r\n\r\n  async execute(context: AXPWorkflowContext): Promise<void> {\r\n\r\n    const [module, entity] = context.getVariable<string>('entity').split(\".\");\r\n    const data = context.getVariable<any>('data');\r\n    const entityRef = await this.entityRegistery.resolve(module, entity);\r\n    const com = await this.config.viewers.master.create();\r\n    const result = await this.popupService.open(com, {\r\n      title: `Create New ${entityRef.formats.individual}`,\r\n      size: this.platform.is('Mobile') || this.platform.is('SM') ? 'full' : 'md',\r\n      data: {\r\n        vm: await this.factory.create(module, entity, data),\r\n        entity,\r\n      },\r\n    });\r\n    context.setOutput('result', false);\r\n    if (result.data?.save) {\r\n      context.setOutput('result', true);\r\n      context.setVariable('data', result.data.item);\r\n    }\r\n  }\r\n}\r\n\r\nexport class AXPEntityCreateSubmittedAction extends AXPWorkflowAction {\r\n  async execute(context: AXPWorkflowContext): Promise<void> {\r\n    this.dispatch(AXPEntityCreateEvent({ entity: context.getVariable<string>('entity') }));\r\n  }\r\n}\r\n\r\nexport const AXPCreateEntityWorkflow: AXPWorkflow = {\r\n  startStepId: 'show-popup',\r\n  steps: {\r\n    \"show-popup\": {\r\n      action: 'AXPEntityCreatePopupAction',\r\n      nextSteps: [\r\n        {\r\n          conditions: [{ type: 'SINGLE', expression: 'context.getOutput(\"result\") == true' }],\r\n          nextStepId: 'show-toast',\r\n        },\r\n      ],\r\n    },\r\n    \"show-toast\": {\r\n      action: 'AXPToastAction',\r\n      input: {\r\n        color: 'success',\r\n        title: 'Entity Created',\r\n        content: 'New Record has been successfully created.',\r\n      },\r\n      nextSteps: [\r\n        {\r\n          conditions: [],\r\n          nextStepId: 'dispatch-event',\r\n        },\r\n      ],\r\n    },\r\n    \"dispatch-event\": {\r\n      action: 'AXPEntityCreateSubmittedAction',\r\n      nextSteps: [\r\n        {\r\n          conditions: [{ type: 'SINGLE', expression: 'context.getVariable(\"redirect\") == true' }],\r\n          nextStepId: 'show-entity',\r\n        },\r\n      ],\r\n    },\r\n    \"show-entity\": {\r\n      action: 'AXPShowDetailViewAction',\r\n    },\r\n  },\r\n};\r\n"]}
@@ -13,7 +13,6 @@ export class AXPEntityPerformDeleteAction extends AXPWorkflowAction {
13
13
  this.loadingDialog = inject(AXLoadingDialogService);
14
14
  }
15
15
  async execute(context) {
16
- debugger;
17
16
  const moduleEntity = context.getVariable('entity');
18
17
  const [moduleName, entityName] = moduleEntity.split(".");
19
18
  const items = context.getVariable('data');
@@ -63,14 +62,12 @@ export class AXPEntityPerformDeleteAction extends AXPWorkflowAction {
63
62
  if (successfulPromises > 0 && failedPromises === 0) {
64
63
  // All items deleted successfully
65
64
  await this.dialogService.alert('Deletion Successful', `${successfulPromises} item(s) has been deleted.`, 'success');
66
- debugger;
67
65
  // Dispatch actions
68
66
  this.dispatch(AXPEntityDeletedEvent({ entity: moduleEntity, ids: ids }));
69
67
  }
70
68
  else if (successfulPromises > 0 && failedPromises > 0) {
71
69
  // Some items deleted successfully, some failed
72
70
  await this.dialogService.alert('Partial Deletion Completed', `${successfulPromises} item(s) deleted successfully. However, ${failedPromises} item(s) could not be deleted.`, 'warning');
73
- debugger;
74
71
  // Dispatch actions
75
72
  this.dispatch(AXPEntityDeletedEvent({ entity: moduleEntity, ids: ids }));
76
73
  }
@@ -122,4 +119,4 @@ export const AXPDeleteEntityWorkflow = {
122
119
  },
123
120
  },
124
121
  };
125
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"delete-entity.workflow.js","sourceRoot":"","sources":["../../../../../../../../libs/platform/layout/entity/src/lib/workflows/delete-entity.workflow.ts"],"names":[],"mappings":"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","sourcesContent":["import { AXDialogService } from '@acorex/components/dialog';\r\nimport { AXLoadingDialogService } from '@acorex/components/loading-dialog';\r\nimport {\r\n  AXPWorkflow,\r\n  AXPWorkflowAction,\r\n  AXPWorkflowContext,\r\n  createWorkFlowEvent,\r\n} from '@acorex/platform/workflow';\r\nimport { Injectable, inject } from '@angular/core';\r\nimport { AXPEntityDefinitionRegistryService } from '../entity-registery.service';\r\n\r\nexport const AXPEntityDeletedEvent = createWorkFlowEvent<{ entity: string; ids: string[] }>(\r\n  '[Entity] Deleted'\r\n);\r\n\r\n@Injectable()\r\nexport class AXPEntityPerformDeleteAction extends AXPWorkflowAction {\r\n  private entityRegistery = inject(AXPEntityDefinitionRegistryService);\r\n  private dialogService = inject(AXDialogService);\r\n  private loadingDialog = inject(AXLoadingDialogService);\r\n\r\n  async execute(context: AXPWorkflowContext): Promise<void> {\r\n    debugger\r\n    const moduleEntity = context.getVariable('entity');\r\n    const [moduleName, entityName] = moduleEntity.split(\".\");\r\n    const items = context.getVariable<any[]>('data');\r\n    const ids = items.map(c => c.id);\r\n    const entity = await this.entityRegistery.resolve(moduleName, entityName);\r\n    let deletedCount = 0;\r\n    context.setVariable('deleteSuccessful', false);\r\n    const dialog = this.loadingDialog.show({\r\n      title: 'Deleting Record...',\r\n      mode: 'determinate',\r\n      status: 'Deleting...',\r\n      progressValue: 0,\r\n      text: `0/${ids.length}`,\r\n      buttons: [\r\n        {\r\n          text: 'Cancel',\r\n          color: 'danger',\r\n          onClick: () => {\r\n            dialog.close();\r\n          },\r\n        },\r\n      ],\r\n    });\r\n\r\n    if (entity.commands?.delete != null) {\r\n      const deleteExec = entity.commands?.delete?.execute as Function\r\n      const wrappedPromises = (ids as any[])\r\n        .map((id, i) => {\r\n          return new Promise((resolve) => {\r\n            setTimeout(() => {\r\n              resolve(deleteExec(id));\r\n            }, i * 200);\r\n          });\r\n        })\r\n        .map((p) =>\r\n          p?.then(\r\n            (value) => {\r\n              deletedCount++;\r\n              dialog.setProgressText(`${deletedCount}/${ids.length}`);\r\n              dialog.setProgressValue((deletedCount / ids.length) * 100);\r\n              return { status: 'fulfilled', value };\r\n            },\r\n            (reason) => ({ status: 'rejected', reason })\r\n          )\r\n        );\r\n\r\n      const results = await Promise.all(wrappedPromises);\r\n      const successfulPromises = results.filter((result) => result?.status === 'fulfilled').length;\r\n      const failedPromises = results.filter((result) => result?.status === 'rejected').length;\r\n      setTimeout(() => {\r\n        dialog.close();\r\n      }, 300);\r\n\r\n      // Handle different scenarios for alerts\r\n      if (successfulPromises > 0 && failedPromises === 0) {\r\n        // All items deleted successfully\r\n        await this.dialogService.alert(\r\n          'Deletion Successful',\r\n          `${successfulPromises} item(s) has been deleted.`,\r\n          'success'\r\n        );\r\n        debugger\r\n        // Dispatch actions\r\n        this.dispatch(AXPEntityDeletedEvent({ entity: moduleEntity, ids: ids }));\r\n      } else if (successfulPromises > 0 && failedPromises > 0) {\r\n        // Some items deleted successfully, some failed\r\n        await this.dialogService.alert(\r\n          'Partial Deletion Completed',\r\n          `${successfulPromises} item(s) deleted successfully. However, ${failedPromises} item(s) could not be deleted.`,\r\n          'warning'\r\n        );\r\n        debugger\r\n        // Dispatch actions\r\n        this.dispatch(AXPEntityDeletedEvent({ entity: moduleEntity, ids: ids }));\r\n      } else if (successfulPromises === 0 && failedPromises > 0) {\r\n        // No items deleted, all failed\r\n        await this.dialogService.alert(\r\n          'Deletion Failed',\r\n          `No items were deleted. ${failedPromises} item(s) failed to delete.`,\r\n          'danger'\r\n        );\r\n      } else {\r\n        // No items to delete (no successful or failed promises)\r\n        await this.dialogService.alert('No Deletion Needed', 'No items were available to delete.', 'info');\r\n      }\r\n    } else {\r\n      throw new Error(\r\n        `The delete operation cannot be performed on ${entity.title}. This action might be restricted or not applicable for the selected item.`\r\n      );\r\n    }\r\n  }\r\n}\r\n\r\n\r\nexport const AXPDeleteEntityWorkflow: AXPWorkflow = {\r\n  startStepId: 'confirm-delete',\r\n  steps: {\r\n    \"confirm-delete\": {\r\n      action: 'show-prompt-dialog',\r\n      input: {\r\n        title: 'Warning',\r\n        message: `Are you sure want to delete selected item(s)?`,\r\n        type: 'danger',\r\n      },\r\n      nextSteps: [\r\n        {\r\n          conditions: [\r\n            {\r\n              type: 'AND',\r\n              conditions: [\r\n                { type: 'SINGLE', expression: 'context.getOutput(\"result\") == true' },\r\n              ],\r\n            },\r\n          ],\r\n          nextStepId: 'perform-delete',\r\n        },\r\n      ],\r\n    },\r\n    \"perform-delete\": {\r\n      action: 'entity-perform-delete',\r\n    },\r\n  },\r\n};\r\n"]}
122
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"delete-entity.workflow.js","sourceRoot":"","sources":["../../../../../../../../libs/platform/layout/entity/src/lib/workflows/delete-entity.workflow.ts"],"names":[],"mappings":"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","sourcesContent":["import { AXDialogService } from '@acorex/components/dialog';\r\nimport { AXLoadingDialogService } from '@acorex/components/loading-dialog';\r\nimport {\r\n  AXPWorkflow,\r\n  AXPWorkflowAction,\r\n  AXPWorkflowContext,\r\n  createWorkFlowEvent,\r\n} from '@acorex/platform/workflow';\r\nimport { Injectable, inject } from '@angular/core';\r\nimport { AXPEntityDefinitionRegistryService } from '../entity-registery.service';\r\n\r\nexport const AXPEntityDeletedEvent = createWorkFlowEvent<{ entity: string; ids: string[] }>(\r\n  '[Entity] Deleted'\r\n);\r\n\r\n@Injectable()\r\nexport class AXPEntityPerformDeleteAction extends AXPWorkflowAction {\r\n  private entityRegistery = inject(AXPEntityDefinitionRegistryService);\r\n  private dialogService = inject(AXDialogService);\r\n  private loadingDialog = inject(AXLoadingDialogService);\r\n\r\n  async execute(context: AXPWorkflowContext): Promise<void> {\r\n    const moduleEntity = context.getVariable('entity');\r\n    const [moduleName, entityName] = moduleEntity.split(\".\");\r\n    const items = context.getVariable<any[]>('data');\r\n    const ids = items.map(c => c.id);\r\n    const entity = await this.entityRegistery.resolve(moduleName, entityName);\r\n    let deletedCount = 0;\r\n    context.setVariable('deleteSuccessful', false);\r\n    const dialog = this.loadingDialog.show({\r\n      title: 'Deleting Record...',\r\n      mode: 'determinate',\r\n      status: 'Deleting...',\r\n      progressValue: 0,\r\n      text: `0/${ids.length}`,\r\n      buttons: [\r\n        {\r\n          text: 'Cancel',\r\n          color: 'danger',\r\n          onClick: () => {\r\n            dialog.close();\r\n          },\r\n        },\r\n      ],\r\n    });\r\n\r\n    if (entity.commands?.delete != null) {\r\n      const deleteExec = entity.commands?.delete?.execute as Function\r\n      const wrappedPromises = (ids as any[])\r\n        .map((id, i) => {\r\n          return new Promise((resolve) => {\r\n            setTimeout(() => {\r\n              resolve(deleteExec(id));\r\n            }, i * 200);\r\n          });\r\n        })\r\n        .map((p) =>\r\n          p?.then(\r\n            (value) => {\r\n              deletedCount++;\r\n              dialog.setProgressText(`${deletedCount}/${ids.length}`);\r\n              dialog.setProgressValue((deletedCount / ids.length) * 100);\r\n              return { status: 'fulfilled', value };\r\n            },\r\n            (reason) => ({ status: 'rejected', reason })\r\n          )\r\n        );\r\n\r\n      const results = await Promise.all(wrappedPromises);\r\n      const successfulPromises = results.filter((result) => result?.status === 'fulfilled').length;\r\n      const failedPromises = results.filter((result) => result?.status === 'rejected').length;\r\n      setTimeout(() => {\r\n        dialog.close();\r\n      }, 300);\r\n\r\n      // Handle different scenarios for alerts\r\n      if (successfulPromises > 0 && failedPromises === 0) {\r\n        // All items deleted successfully\r\n        await this.dialogService.alert(\r\n          'Deletion Successful',\r\n          `${successfulPromises} item(s) has been deleted.`,\r\n          'success'\r\n        );\r\n        // Dispatch actions\r\n        this.dispatch(AXPEntityDeletedEvent({ entity: moduleEntity, ids: ids }));\r\n      } else if (successfulPromises > 0 && failedPromises > 0) {\r\n        // Some items deleted successfully, some failed\r\n        await this.dialogService.alert(\r\n          'Partial Deletion Completed',\r\n          `${successfulPromises} item(s) deleted successfully. However, ${failedPromises} item(s) could not be deleted.`,\r\n          'warning'\r\n        );\r\n        // Dispatch actions\r\n        this.dispatch(AXPEntityDeletedEvent({ entity: moduleEntity, ids: ids }));\r\n      } else if (successfulPromises === 0 && failedPromises > 0) {\r\n        // No items deleted, all failed\r\n        await this.dialogService.alert(\r\n          'Deletion Failed',\r\n          `No items were deleted. ${failedPromises} item(s) failed to delete.`,\r\n          'danger'\r\n        );\r\n      } else {\r\n        // No items to delete (no successful or failed promises)\r\n        await this.dialogService.alert('No Deletion Needed', 'No items were available to delete.', 'info');\r\n      }\r\n    } else {\r\n      throw new Error(\r\n        `The delete operation cannot be performed on ${entity.title}. This action might be restricted or not applicable for the selected item.`\r\n      );\r\n    }\r\n  }\r\n}\r\n\r\n\r\nexport const AXPDeleteEntityWorkflow: AXPWorkflow = {\r\n  startStepId: 'confirm-delete',\r\n  steps: {\r\n    \"confirm-delete\": {\r\n      action: 'show-prompt-dialog',\r\n      input: {\r\n        title: 'Warning',\r\n        message: `Are you sure want to delete selected item(s)?`,\r\n        type: 'danger',\r\n      },\r\n      nextSteps: [\r\n        {\r\n          conditions: [\r\n            {\r\n              type: 'AND',\r\n              conditions: [\r\n                { type: 'SINGLE', expression: 'context.getOutput(\"result\") == true' },\r\n              ],\r\n            },\r\n          ],\r\n          nextStepId: 'perform-delete',\r\n        },\r\n      ],\r\n    },\r\n    \"perform-delete\": {\r\n      action: 'entity-perform-delete',\r\n    },\r\n  },\r\n};\r\n"]}
@@ -118,6 +118,9 @@ export class AXPEntityMasterListViewComponent {
118
118
  async handleSelectedRowsChange(rows) {
119
119
  this.vm.selectedItems.set(rows);
120
120
  }
121
+ ngOnDestroy() {
122
+ this.vm.destroy();
123
+ }
121
124
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: AXPEntityMasterListViewComponent, deps: [{ token: i1.AXActionSheetService }, { token: i2.AXPlatform }], target: i0.ɵɵFactoryTarget.Component }); }
122
125
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.2", type: AXPEntityMasterListViewComponent, isStandalone: true, selector: "ng-component", viewQueries: [{ propertyName: "grid", first: true, predicate: ["grid"], descendants: true }], ngImport: i0, template: "<ax-drawer-container>\r\n <ax-content class=\"ax-flex ax-flex-col ax-overflow-hidden\" #content>\r\n <div\r\n class=\"ax-flex ax-flex-col ax-gap-4 ax-px-4 ax-pb-4 md:ax-px-6 ax-bg-surface ax-border-b md:ax-border-0 md:ax-bg-default\">\r\n <div class=\"ax-flex ax-flex-col ax-pt-4 ax-gap-4 ax-sticky ax-top-0 ax-z-10 ax-transition-all\" #sticky=\"axpSticky\"\r\n [axpSticky]=\"'ax-bg-surface ax-px-6 ax-py-3 -ax-mx-6 ax-shadow-xl'\" [stickyParent]=\"content.getHostElement()\">\r\n <!-------- Begin Toolbar -------->\r\n <!-------- Begin Line 1 -------->\r\n <div class=\"ax-flex ax-justify-between ax-items-center\">\r\n <!-------- Begin Title -------->\r\n <div class=\"ax-flex ax-gap-1 ax-items-center\">\r\n <div class=\"ax-flex ax-flex-col ax-gap-2 ax-transition\">\r\n <div class=\"ax-text-xl md:ax-text-3xl ax-font-bold\">{{ vm.title()}}</div>\r\n @if(vm.description())\r\n {\r\n <div class=\"ax-text-sm ax-text-neutral-600\" [class.ax-hidden]=\"sticky.isSticky\">{{\r\n vm.description() }}</div>\r\n }\r\n <ax-breadcrumbs class=\"child:ax-font-normal child:ax-text-neutral-400\" [class.ax-hidden]=\"isSM | async\">\r\n <ng-template #divider>\r\n <i class=\"fa-solid fa-chevron-right ax-text-xs ax-mx-2\"></i>\r\n </ng-template>\r\n @for(b of vm.beardcrumbs();track $index;let last=$last)\r\n {\r\n <ax-breadcrumbs-item [active]=\"last\" [class.!ax-font-semibold]=\"last\"\r\n [class.!ax-text-neutral-600]=\"last\" [routerLink]=\"b.url\">\r\n @if(b.icon)\r\n {\r\n <i [class]=\"b.icon\"></i>\r\n }\r\n {{b.title}}\r\n </ax-breadcrumbs-item>\r\n }\r\n </ax-breadcrumbs>\r\n </div>\r\n </div>\r\n <!-------- Finish Title -------->\r\n <!--------------------------------------------------------------->\r\n <!-- Begin Action Menu -->\r\n <div class=\"ax-flex ax-items-center ax-gap-3\">\r\n @for(tr of vm.primaryActions();track $index)\r\n {\r\n <ax-button [text]=\"tr.title\" [color]=\"tr.color\" (onClick)=\"vm.executeCommand(tr.name)\">\r\n <ax-prefix>\r\n <ax-icon [icon]=\"tr.icon\"> </ax-icon>\r\n </ax-prefix>\r\n </ax-button>\r\n }\r\n @if(vm.secondaryActions().length) {\r\n <ax-button [text]=\"(isSM | async) ? null : 'Actions'\" color=\"ghost\">\r\n <ax-prefix>\r\n <i class=\"fa-solid fa-ellipsis-vertical\"></i>\r\n </ax-prefix>\r\n <ax-dropdown-panel>\r\n <ax-button-item-list>\r\n @for(tr of vm.secondaryActions();track $index;let first=$first)\r\n {\r\n <ng-container>\r\n @if(tr.separated && !$first)\r\n {\r\n <ax-divider></ax-divider>\r\n }\r\n <ax-button-item [text]=\"tr.title\" class=\"ax-font-semibold ax-text-{{tr.color}}\"\r\n (onClick)=\"vm.executeCommand(tr.name)\">\r\n <ax-prefix>\r\n <ax-icon [icon]=\"tr.icon\"> </ax-icon>\r\n </ax-prefix>\r\n </ax-button-item>\r\n </ng-container>\r\n }\r\n </ax-button-item-list>\r\n </ax-dropdown-panel>\r\n </ax-button>\r\n }\r\n </div>\r\n <!-- Finish Action Menu -->\r\n </div>\r\n\r\n <!-------- Finish Line 1 -------->\r\n\r\n <!-------- Begin Line 2 -------->\r\n <div class=\"ax-flex ax-justify-between ax-items-center\">\r\n <div class=\"ax-flex ax-justify-start ax-items-center ax-gap-4\">\r\n <!-------- Begin Selection -------->\r\n\r\n @if(vm.hasSelectedItems())\r\n {\r\n <div class=\"ax-flex ax-gap-3 ax-items-center ax-h-10\">\r\n <span class=\"ax-text-xl ax-font-bold\"> {{ vm.selectedItems().length }} Items Selected </span>\r\n <span (click)=\"vm.clearSelection()\"\r\n class=\"ax-text-sm ax-text-primary dark:ax-text-primary-300 ax-underline ax-cursor-pointer\">Clear\r\n Items</span>\r\n </div>\r\n\r\n <!-------- Finish Selection -------->\r\n\r\n } @else {\r\n\r\n <!-------- Begin View -------->\r\n\r\n <ax-button [text]=\"vm.view().title\" #views color=\"ghost\">\r\n <ax-prefix>\r\n <i class=\"fa-solid fa-eye\"></i>\r\n </ax-prefix>\r\n <ax-suffix>\r\n <i class=\"fa-solid fa-caret-down\"></i>\r\n </ax-suffix>\r\n <ax-dropdown-panel [adaptivityEnabled]=\"true\">\r\n <ax-button-item-list class=\"ax-bg-surface\">\r\n <ax-title class=\"ax-font-bold ax-opacity-100\">Public Views</ax-title>\r\n <ax-button-item *ngFor=\"let v of vm.views()\" [text]=\"v.title\" [class.ax-bg-on-surface]=\"vm.view()==v\"\r\n (onClick)=\"vm.setView(v.name)\"></ax-button-item>\r\n <!-- <ax-title class=\"ax-font-bold ax-opacity-100\" *ngIf=\"hasCustomViews$ | async\">Created by me</ax-title>\r\n <ax-button-item class=\"ax-pe-4 ax-flex ax-justify-between\" *ngFor=\"let v of customViews$ | async\"\r\n [text]=\"v.title\" [class.ax-bg-on-surface]=\"(view$ | async) == v\" (onClick)=\"loader.setView(v.name)\">\r\n <ax-suffix>\r\n <ax-button (onClick)=\"updateViewPopup($event, v)\" class=\"ax-xs\" look=\"none\">\r\n <ax-icon class=\"far fa-edit\"> </ax-icon>\r\n </ax-button>\r\n </ax-suffix>\r\n </ax-button-item> -->\r\n <!-- <ng-container *feature=\"'axp-entity-list-custom-view'\">\r\n <ax-divider></ax-divider>\r\n <ax-button-item text=\"Add Custom View\" (onClick)=\"addCustomViewPopup()\"\r\n class=\"ax-font-semibold ax-text-primary\"></ax-button-item>\r\n </ng-container> -->\r\n </ax-button-item-list>\r\n </ax-dropdown-panel>\r\n </ax-button>\r\n <!-------- Finish View -------->\r\n\r\n <!-------- Begin Inline Search -------->\r\n\r\n @if(vm.hasInlineFilters())\r\n {\r\n <div class=\"ax-w-72\" *feature=\"'axp-entity-list-inline-filter'\">\r\n <ax-search-box [placeholder]=\"'Search on '+vm.inlineFiltersPlaceholders().join(', ')\"\r\n (onValueChanged)=\"handleChangeSearchValue($event)\"><ax-clear-button></ax-clear-button></ax-search-box>\r\n </div>\r\n }\r\n }\r\n <!-------- Finish Inline Search -------->\r\n </div>\r\n\r\n <!-- Begin View Action Menu -->\r\n @if(!vm.hasSelectedItems())\r\n {\r\n <div class=\"ax-flex ax-gap-3\">\r\n <ax-button text=\"Columns\" color=\"ghost\" (onClick)=\"columnsDrawer.open()\">\r\n <ax-prefix>\r\n <i class=\"fa-solid fa-bars\"></i>\r\n </ax-prefix>\r\n <ax-suffix>\r\n <ax-badge [text]=\"vm.visibleColumnCount().toString()\" color=\"primary\"></ax-badge>\r\n </ax-suffix>\r\n </ax-button>\r\n <ax-button text=\"Filters\" color=\"ghost\" (onClick)=\"conditionsDrawer.open()\"\r\n *feature=\"'axp-entity-list-advance-filter'\">\r\n <ax-prefix>\r\n <i class=\"fa-solid fa-sliders\"></i>\r\n </ax-prefix>\r\n <ax-suffix>\r\n <ax-badge text=\"3\" color=\"primary\"></ax-badge>\r\n </ax-suffix>\r\n </ax-button>\r\n @if(vm.canSort())\r\n {\r\n <ax-button text=\"Sort\" color=\"ghost\" (onClick)=\"sortsDrawer.open()\">\r\n <ax-prefix>\r\n <i class=\"fa-solid fa-bars-sort\"></i>\r\n </ax-prefix>\r\n @if(vm.sortedCount())\r\n {\r\n <ax-suffix>\r\n <ax-badge [text]=\"vm.sortedCount().toString()\" color=\"primary\"></ax-badge>\r\n </ax-suffix>\r\n }\r\n </ax-button>\r\n }\r\n </div>\r\n }\r\n <!-- Finish View Action Menu -->\r\n </div>\r\n <!-------- Finish Line 2 -------->\r\n\r\n <!----- Finish Toolbar ----->\r\n\r\n </div>\r\n </div>\r\n <!----- Begin DataTable ----->\r\n <div class=\"ax-flex ax-flex-1 ax-px-6 ax-py-4 ax-overflow-auto\">\r\n <ax-data-table #grid [showFooter]=\"false\" class=\"ax-flex-1\" [paging]=\"true\" [fetchDataMode]=\"'manual'\"\r\n [loading]=\"{ enabled: true, animation: true }\" [dataSource]=\"vm.dataSource\"\r\n (selectedRowsChange)=\"handleSelectedRowsChange($event)\" (onRowDbClick)=\"handleRowDbClick($event)\">\r\n <ax-select-column fixed=\"start\" [width]=\"'50px'\"></ax-select-column>\r\n @for(col of vm.columns();track col.name) {\r\n @if(col.visible)\r\n {\r\n <axp-widget-column-renderer [caption]=\"col.title\" [node]=\"col.node()\"></axp-widget-column-renderer>\r\n }\r\n }\r\n <ax-dropdown-command-column fixed=\"end\" [width]=\"'60px'\" [items]=\"getDropdownRowItems\"\r\n (onItemClick)=\"handleRowCommandClick($event)\"></ax-dropdown-command-column>\r\n </ax-data-table>\r\n </div>\r\n <!----- Finish DataTable ----->\r\n </ax-content>\r\n\r\n <ax-drawer (collapsedChange)=\"closeDrawer('columns', $event)\" #columnsDrawer location=\"end\" [mode]=\"'overlay'\">\r\n <ax-content class=\"ax-w-[85vw] md:ax-w-[45vw] lg:ax-w-[35vw] 2xl:ax-w-[20vw] ax-border-e\">\r\n <axp-list-view-option-columns [viewModel]=\"vm\" (onClosed)=\"columnsDrawer.close()\"></axp-list-view-option-columns>\r\n </ax-content>\r\n </ax-drawer>\r\n <ax-drawer (collapsedChange)=\"closeDrawer('conditions', $event)\" #conditionsDrawer location=\"end\" [mode]=\"'overlay'\">\r\n <ax-content class=\"ax-w-[85vw] md:ax-w-[45vw] lg:ax-w-[35vw] 2xl:ax-w-[25vw] ax-border-e\">\r\n <!-- <axp-list-view-option-conditions [loader]=\"loader\"\r\n (onClosed)=\"conditionsDrawer.close()\"></axp-list-view-option-conditions> -->\r\n </ax-content>\r\n </ax-drawer>\r\n <ax-drawer (collapsedChange)=\"closeDrawer('sorts', $event)\" #sortsDrawer location=\"end\" [mode]=\"'overlay'\">\r\n <ax-content class=\"ax-w-[85vw] md:ax-w-[45vw] lg:ax-w-[35vw] 2xl:ax-w-[20vw] ax-border-e\">\r\n <axp-list-view-option-sorting (onClosed)=\"sortsDrawer.close()\" [viewModel]=\"vm\"></axp-list-view-option-sorting>\r\n </ax-content>\r\n </ax-drawer>\r\n</ax-drawer-container>", styles: [".cdk-drag-preview{border-radius:.375rem;border-width:1px;--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);background:rgba(var(--ax-color-on-surface));padding:.5rem;height:max-content!important}.collapsed-search-box{margin-top:0;height:0px;opacity:0}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: RouterModule }, { kind: "directive", type: i4.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "ngmodule", type: AXButtonModule }, { kind: "component", type: i5.AXButtonComponent, selector: "ax-button", inputs: ["disabled", "size", "tabIndex", "color", "look", "text", "toggleable", "selected", "type"], outputs: ["onBlur", "onFocus", "onClick", "selectedChange", "toggleableChange", "lookChange", "colorChange", "disabledChange"] }, { kind: "component", type: i5.AXButtonItemComponent, selector: "ax-button-item", inputs: ["color", "disabled", "text", "selected", "divided", "data", "name"], outputs: ["onClick", "onFocus", "onBlur", "disabledChange"] }, { kind: "component", type: i5.AXButtonItemListComponent, selector: "ax-button-item-list", inputs: ["items"], outputs: ["onItemClick"] }, { kind: "ngmodule", type: AXDecoratorModule }, { kind: "component", type: i6.AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }, { kind: "component", type: i6.AXDecoratorClearButtonComponent, selector: "ax-clear-button", inputs: ["icon"] }, { kind: "component", type: i6.AXDecoratorGenericComponent, selector: "ax-footer, ax-header, ax-content, ax-divider, ax-form-hint, ax-prefix, ax-suffix, ax-text, ax-title, ax-sub-title, ax-placeholder, ax-overlay" }, { kind: "ngmodule", type: AXBadgeModule }, { kind: "component", type: i7.AXBadgeComponent, selector: "ax-badge", inputs: ["color", "look", "text"] }, { kind: "ngmodule", type: AXDropdownModule }, { kind: "component", type: i8.AXDropdownPanelComponent, selector: "ax-dropdown-panel", inputs: ["isOpen", "fitParent", "dropdownWidth", "position", "_target", "adaptivityEnabled"], outputs: ["onOpened", "onClosed"] }, { kind: "ngmodule", type: AXPopoverModule }, { kind: "ngmodule", type: AXFormModule }, { kind: "ngmodule", type: AXActionSheetModule }, { kind: "ngmodule", type: AXDrawerModule }, { kind: "component", type: i9.AXDrawerComponent, selector: "ax-drawer", inputs: ["location", "showBackdrop", "mode", "collapsed"], outputs: ["locationChange", "modeChange", "collapsedChange"] }, { kind: "component", type: i9.AXDrawerContainerComponent, selector: "ax-drawer-container" }, { kind: "ngmodule", type: AXDialogModule }, { kind: "ngmodule", type: AXLoadingModule }, { kind: "ngmodule", type: AXTabsModule }, { kind: "ngmodule", type: AXTooltipModule }, { kind: "ngmodule", type: AXBreadcrumbsModule }, { kind: "component", type: i10.AXBreadCrumbsComponent, selector: "ax-breadcrumbs" }, { kind: "component", type: i10.AXBreadCrumbsItemComponent, selector: "ax-breadcrumbs-item", inputs: ["disabled", "active"] }, { kind: "ngmodule", type: AXSearchBoxModule }, { kind: "component", type: i11.AXSearchBoxComponent, selector: "ax-search-box", inputs: ["disabled", "readonly", "tabIndex", "placeholder", "value", "state", "name", "id", "look", "delayTime"], outputs: ["valueChange", "stateChange", "onValueChanged", "onBlur", "onFocus", "readonlyChange", "disabledChange", "onKeyDown", "onKeyUp", "onKeyPress"] }, { kind: "ngmodule", type: AXDataTableModule }, { kind: "component", type: i12.AXDataTableComponent, selector: "ax-data-table", inputs: ["dataSource", "rowTemplate", "emptyTemplate", "alternative", "showHeader", "fixedHeader", "showFooter", "fixedFooter", "itemHeight", "allowReordering", "paging", "fetchDataMode", "loading", "focusedRow"], outputs: ["selectedRowsChange", "focusedRowChange", "onRowClick", "onRowDbClick", "onColumnsOrderChanged"] }, { kind: "component", type: i12.AXRowSelectColumnComponent, selector: "ax-select-column", inputs: ["width", "caption", "fixed"] }, { kind: "component", type: i12.AXRowDropdownCommandColumnComponent, selector: "ax-dropdown-command-column", inputs: ["width", "caption", "fixed", "footerTemplate", "items"], outputs: ["onItemClick"] }, { kind: "ngmodule", type:
123
126
  //
@@ -160,4 +163,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImpor
160
163
  type: ViewChild,
161
164
  args: ['grid']
162
165
  }] } });
163
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity-master-list-view.component.js","sourceRoot":"","sources":["../../../../../../../../../../libs/platform/themes/default/src/lib/layouts/entity-layouts/entity-master-list-view/entity-master-list-view.component.ts","../../../../../../../../../../libs/platform/themes/default/src/lib/layouts/entity-layouts/entity-master-list-view/entity-master-list-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXActionSheetModule, AXActionSheetService } from '@acorex/components/action-sheet';\r\nimport { AXDataTableComponent, AXDataTableModule, AXDataTableRowDbClick, AXRowCommandItem, AXRowCommandItemClickEvent } from '@acorex/components/data-table';\r\nimport { AXDrawerModule } from '@acorex/components/drawer';\r\nimport { AXPlatform } from '@acorex/core/platform';\r\nimport { ChangeDetectionStrategy, Component, ViewChild, ViewEncapsulation, effect, inject } from '@angular/core';\r\nimport { ActivatedRoute, RouterModule } from '@angular/router';\r\nimport { Store } from '@ngrx/store';\r\n\r\nimport { AXPAdminLayoutState, AXPGridLayoutDirective, AXPLayoutService, AXPStickyDirective, getChildDrawer, isSmallScreen } from '@acorex/platform/common';\r\nimport { AXBadgeModule } from '@acorex/components/badge';\r\nimport { AXBreadcrumbsModule } from '@acorex/components/breadcrumbs';\r\nimport { AXButtonModule } from '@acorex/components/button';\r\nimport { AXDecoratorModule } from '@acorex/components/decorators';\r\nimport { AXDialogModule } from '@acorex/components/dialog';\r\nimport { AXDropdownModule } from '@acorex/components/dropdown';\r\nimport { AXFormModule } from '@acorex/components/form';\r\nimport { AXLoadingModule } from '@acorex/components/loading';\r\nimport { AXPopoverModule } from '@acorex/components/popover';\r\nimport { AXTabsModule } from '@acorex/components/tabs';\r\nimport { AXTooltipModule } from '@acorex/components/tooltip';\r\nimport { AXPLayoutBuilderModule } from '@acorex/platform/layout/builder';\r\nimport { AXPWidgetsModule } from '@acorex/platform/widgets';\r\nimport { CommonModule } from '@angular/common';\r\nimport { AXSearchBoxModule } from '@acorex/components/search-box';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { AXPAuthModule } from '@acorex/platform/auth';\r\nimport { AXPListViewOptionsColumnsComponent } from './list-view-option-columns/list-view-option-columns.component';\r\nimport { AXPListViewOptionSortingComponent } from './list-view-option-sorting/list-view-option-sorting.component';\r\nimport { AXValueChangedEvent } from '@acorex/components/common';\r\nimport { AXPEntityMasterListViewModel } from '@acorex/platform/layout/entity';\r\n\r\n@Component({\r\n  templateUrl: 'entity-master-list-view.component.html',\r\n  styleUrls: ['entity-master-list-view.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    RouterModule,\r\n    AXButtonModule,\r\n    AXDecoratorModule,\r\n    AXBadgeModule,\r\n    AXDropdownModule,\r\n    AXPopoverModule,\r\n    AXFormModule,\r\n    AXActionSheetModule,\r\n    AXDrawerModule,\r\n    AXDialogModule,\r\n    AXLoadingModule,\r\n    AXTabsModule,\r\n    AXTooltipModule,\r\n    AXBreadcrumbsModule,\r\n    AXSearchBoxModule,\r\n    AXDataTableModule,\r\n    //\r\n    AXPLayoutBuilderModule,\r\n    AXPWidgetsModule,\r\n    AXPStickyDirective,\r\n    AXPGridLayoutDirective,\r\n    AXPAuthModule,\r\n    //\r\n    AXPListViewOptionsColumnsComponent,\r\n    AXPListViewOptionSortingComponent\r\n\r\n  ],\r\n  standalone: true,\r\n})\r\nexport class AXPEntityMasterListViewComponent {\r\n\r\n  private layout = inject(AXPLayoutService);\r\n  private activeRoute = inject(ActivatedRoute);\r\n\r\n  protected readonly vm = this.activeRoute.snapshot.data['vm'] as AXPEntityMasterListViewModel;\r\n\r\n  //\r\n  private store = inject(Store<AXPAdminLayoutState>);\r\n  protected isSM = this.store.select(isSmallScreen());\r\n  protected isOpen = this.store.select(getChildDrawer());\r\n  //\r\n  protected focusedRow: any;\r\n  //\r\n  @ViewChild('grid') grid!: AXDataTableComponent;\r\n\r\n  constructor(\r\n    private actionSheetService: AXActionSheetService,\r\n    protected platform: AXPlatform,\r\n  ) {\r\n    effect(() => {\r\n      this.grid.selectedRows = this.vm.selectedItems();\r\n    }, { allowSignalWrites: true });\r\n    //\r\n    this.vm.events$.subscribe(e => {\r\n      if (e.action == \"refresh\") {\r\n        this.grid.refresh();\r\n      }\r\n    })\r\n\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.vm.setView();\r\n  }\r\n\r\n  protected closeDrawer(name: string, collapsed: boolean) {\r\n    if (collapsed) {\r\n      switch (name) {\r\n        case 'conditions':\r\n          //this.loader.resetConditions();\r\n          break;\r\n        case 'columns':\r\n          this.vm.applyColumns()\r\n          break;\r\n        case 'sorts':\r\n          //this.vm.resetSorts();\r\n          break;\r\n        default:\r\n          break;\r\n      }\r\n    }\r\n  }\r\n\r\n  handleChangeSearchValue(e: AXValueChangedEvent) {\r\n    if (e.isUserInteraction) {\r\n      this.vm.applyInlineFilter(e.value);\r\n    }\r\n  }\r\n\r\n  private dropdownRowItems: AXRowCommandItem[] = [\r\n    {\r\n      text: 'Details',\r\n      icon: 'fa-solid fa-eye',\r\n      name: 'open-entity',\r\n      divided: true,\r\n    },\r\n    {\r\n      text: 'Delete',\r\n      icon: 'fa-solid fa-trash-can',\r\n      name: 'delete-entity',\r\n      color: 'danger',\r\n      disabled: true,\r\n    },\r\n  ];\r\n\r\n  protected handleRowDbClick(e: AXDataTableRowDbClick) {\r\n    const d: AXRowCommandItemClickEvent = {\r\n      component: e.component,\r\n      name: this.dropdownRowItems[0].name,\r\n      data: e.data,\r\n    };\r\n    this.handleRowCommandClick(d);\r\n  }\r\n\r\n  protected getDropdownRowItems = (rowData: unknown): Promise<AXRowCommandItem[]> => {\r\n    return Promise.resolve(this.dropdownRowItems);\r\n  };\r\n\r\n  protected async handleRowCommandClick(e: AXRowCommandItemClickEvent) {\r\n    this.vm.executeCommand(e.name, e.data);\r\n  }\r\n\r\n  protected async handleSelectedRowsChange(rows: unknown[]) {\r\n    this.vm.selectedItems.set(rows);\r\n  }\r\n\r\n}\r\n","<ax-drawer-container>\r\n  <ax-content class=\"ax-flex ax-flex-col ax-overflow-hidden\" #content>\r\n    <div\r\n      class=\"ax-flex ax-flex-col ax-gap-4 ax-px-4 ax-pb-4 md:ax-px-6 ax-bg-surface   ax-border-b md:ax-border-0 md:ax-bg-default\">\r\n      <div class=\"ax-flex ax-flex-col ax-pt-4 ax-gap-4 ax-sticky ax-top-0 ax-z-10 ax-transition-all\" #sticky=\"axpSticky\"\r\n        [axpSticky]=\"'ax-bg-surface ax-px-6 ax-py-3 -ax-mx-6 ax-shadow-xl'\" [stickyParent]=\"content.getHostElement()\">\r\n        <!-------- Begin Toolbar  -------->\r\n        <!-------- Begin Line 1  -------->\r\n        <div class=\"ax-flex ax-justify-between ax-items-center\">\r\n          <!-------- Begin Title  -------->\r\n          <div class=\"ax-flex ax-gap-1 ax-items-center\">\r\n            <div class=\"ax-flex ax-flex-col ax-gap-2 ax-transition\">\r\n              <div class=\"ax-text-xl md:ax-text-3xl ax-font-bold\">{{ vm.title()}}</div>\r\n              @if(vm.description())\r\n              {\r\n              <div class=\"ax-text-sm ax-text-neutral-600\" [class.ax-hidden]=\"sticky.isSticky\">{{\r\n                vm.description() }}</div>\r\n              }\r\n              <ax-breadcrumbs class=\"child:ax-font-normal child:ax-text-neutral-400\" [class.ax-hidden]=\"isSM | async\">\r\n                <ng-template #divider>\r\n                  <i class=\"fa-solid fa-chevron-right ax-text-xs ax-mx-2\"></i>\r\n                </ng-template>\r\n                @for(b of vm.beardcrumbs();track $index;let last=$last)\r\n                {\r\n                <ax-breadcrumbs-item [active]=\"last\" [class.!ax-font-semibold]=\"last\"\r\n                  [class.!ax-text-neutral-600]=\"last\" [routerLink]=\"b.url\">\r\n                  @if(b.icon)\r\n                  {\r\n                  <i [class]=\"b.icon\"></i>\r\n                  }\r\n                  {{b.title}}\r\n                </ax-breadcrumbs-item>\r\n                }\r\n              </ax-breadcrumbs>\r\n            </div>\r\n          </div>\r\n          <!-------- Finish Title  -------->\r\n          <!--------------------------------------------------------------->\r\n          <!-- Begin Action Menu  -->\r\n          <div class=\"ax-flex ax-items-center ax-gap-3\">\r\n            @for(tr of vm.primaryActions();track $index)\r\n            {\r\n            <ax-button [text]=\"tr.title\" [color]=\"tr.color\" (onClick)=\"vm.executeCommand(tr.name)\">\r\n              <ax-prefix>\r\n                <ax-icon [icon]=\"tr.icon\"> </ax-icon>\r\n              </ax-prefix>\r\n            </ax-button>\r\n            }\r\n            @if(vm.secondaryActions().length) {\r\n            <ax-button [text]=\"(isSM | async) ? null : 'Actions'\" color=\"ghost\">\r\n              <ax-prefix>\r\n                <i class=\"fa-solid fa-ellipsis-vertical\"></i>\r\n              </ax-prefix>\r\n              <ax-dropdown-panel>\r\n                <ax-button-item-list>\r\n                  @for(tr of vm.secondaryActions();track $index;let first=$first)\r\n                  {\r\n                  <ng-container>\r\n                    @if(tr.separated && !$first)\r\n                    {\r\n                    <ax-divider></ax-divider>\r\n                    }\r\n                    <ax-button-item [text]=\"tr.title\" class=\"ax-font-semibold ax-text-{{tr.color}}\"\r\n                      (onClick)=\"vm.executeCommand(tr.name)\">\r\n                      <ax-prefix>\r\n                        <ax-icon [icon]=\"tr.icon\"> </ax-icon>\r\n                      </ax-prefix>\r\n                    </ax-button-item>\r\n                  </ng-container>\r\n                  }\r\n                </ax-button-item-list>\r\n              </ax-dropdown-panel>\r\n            </ax-button>\r\n            }\r\n          </div>\r\n          <!-- Finish Action Menu  -->\r\n        </div>\r\n\r\n        <!-------- Finish Line 1  -------->\r\n\r\n        <!-------- Begin Line 2 -------->\r\n        <div class=\"ax-flex ax-justify-between ax-items-center\">\r\n          <div class=\"ax-flex ax-justify-start ax-items-center ax-gap-4\">\r\n            <!-------- Begin Selection  -------->\r\n\r\n            @if(vm.hasSelectedItems())\r\n            {\r\n            <div class=\"ax-flex ax-gap-3 ax-items-center ax-h-10\">\r\n              <span class=\"ax-text-xl ax-font-bold\"> {{ vm.selectedItems().length }} Items Selected </span>\r\n              <span (click)=\"vm.clearSelection()\"\r\n                class=\"ax-text-sm ax-text-primary dark:ax-text-primary-300 ax-underline ax-cursor-pointer\">Clear\r\n                Items</span>\r\n            </div>\r\n\r\n            <!-------- Finish Selection  -------->\r\n\r\n            } @else {\r\n\r\n            <!-------- Begin View  -------->\r\n\r\n            <ax-button [text]=\"vm.view().title\" #views color=\"ghost\">\r\n              <ax-prefix>\r\n                <i class=\"fa-solid fa-eye\"></i>\r\n              </ax-prefix>\r\n              <ax-suffix>\r\n                <i class=\"fa-solid fa-caret-down\"></i>\r\n              </ax-suffix>\r\n              <ax-dropdown-panel [adaptivityEnabled]=\"true\">\r\n                <ax-button-item-list class=\"ax-bg-surface\">\r\n                  <ax-title class=\"ax-font-bold ax-opacity-100\">Public Views</ax-title>\r\n                  <ax-button-item *ngFor=\"let v of vm.views()\" [text]=\"v.title\" [class.ax-bg-on-surface]=\"vm.view()==v\"\r\n                    (onClick)=\"vm.setView(v.name)\"></ax-button-item>\r\n                  <!-- <ax-title class=\"ax-font-bold ax-opacity-100\" *ngIf=\"hasCustomViews$ | async\">Created by me</ax-title>\r\n                <ax-button-item class=\"ax-pe-4 ax-flex ax-justify-between\" *ngFor=\"let v of customViews$ | async\"\r\n                  [text]=\"v.title\" [class.ax-bg-on-surface]=\"(view$ | async) == v\" (onClick)=\"loader.setView(v.name)\">\r\n                  <ax-suffix>\r\n                    <ax-button (onClick)=\"updateViewPopup($event, v)\" class=\"ax-xs\" look=\"none\">\r\n                      <ax-icon class=\"far fa-edit\"> </ax-icon>\r\n                    </ax-button>\r\n                  </ax-suffix>\r\n                </ax-button-item> -->\r\n                  <!-- <ng-container *feature=\"'axp-entity-list-custom-view'\">\r\n                  <ax-divider></ax-divider>\r\n                  <ax-button-item text=\"Add Custom View\" (onClick)=\"addCustomViewPopup()\"\r\n                    class=\"ax-font-semibold ax-text-primary\"></ax-button-item>\r\n                </ng-container> -->\r\n                </ax-button-item-list>\r\n              </ax-dropdown-panel>\r\n            </ax-button>\r\n            <!-------- Finish View  -------->\r\n\r\n            <!-------- Begin Inline Search   -------->\r\n\r\n            @if(vm.hasInlineFilters())\r\n            {\r\n            <div class=\"ax-w-72\" *feature=\"'axp-entity-list-inline-filter'\">\r\n              <ax-search-box [placeholder]=\"'Search on '+vm.inlineFiltersPlaceholders().join(', ')\"\r\n                (onValueChanged)=\"handleChangeSearchValue($event)\"><ax-clear-button></ax-clear-button></ax-search-box>\r\n            </div>\r\n            }\r\n            }\r\n            <!-------- Finish Inline Search -------->\r\n          </div>\r\n\r\n          <!-- Begin View Action Menu  -->\r\n          @if(!vm.hasSelectedItems())\r\n          {\r\n          <div class=\"ax-flex ax-gap-3\">\r\n            <ax-button text=\"Columns\" color=\"ghost\" (onClick)=\"columnsDrawer.open()\">\r\n              <ax-prefix>\r\n                <i class=\"fa-solid fa-bars\"></i>\r\n              </ax-prefix>\r\n              <ax-suffix>\r\n                <ax-badge [text]=\"vm.visibleColumnCount().toString()\" color=\"primary\"></ax-badge>\r\n              </ax-suffix>\r\n            </ax-button>\r\n            <ax-button text=\"Filters\" color=\"ghost\" (onClick)=\"conditionsDrawer.open()\"\r\n              *feature=\"'axp-entity-list-advance-filter'\">\r\n              <ax-prefix>\r\n                <i class=\"fa-solid fa-sliders\"></i>\r\n              </ax-prefix>\r\n              <ax-suffix>\r\n                <ax-badge text=\"3\" color=\"primary\"></ax-badge>\r\n              </ax-suffix>\r\n            </ax-button>\r\n            @if(vm.canSort())\r\n            {\r\n            <ax-button text=\"Sort\" color=\"ghost\" (onClick)=\"sortsDrawer.open()\">\r\n              <ax-prefix>\r\n                <i class=\"fa-solid fa-bars-sort\"></i>\r\n              </ax-prefix>\r\n              @if(vm.sortedCount())\r\n              {\r\n              <ax-suffix>\r\n                <ax-badge [text]=\"vm.sortedCount().toString()\" color=\"primary\"></ax-badge>\r\n              </ax-suffix>\r\n              }\r\n            </ax-button>\r\n            }\r\n          </div>\r\n          }\r\n          <!-- Finish View Action Menu  -->\r\n        </div>\r\n        <!-------- Finish Line 2  -------->\r\n\r\n        <!----- Finish Toolbar  ----->\r\n\r\n      </div>\r\n    </div>\r\n    <!----- Begin DataTable  ----->\r\n    <div class=\"ax-flex ax-flex-1 ax-px-6 ax-py-4  ax-overflow-auto\">\r\n      <ax-data-table #grid [showFooter]=\"false\" class=\"ax-flex-1\" [paging]=\"true\" [fetchDataMode]=\"'manual'\"\r\n        [loading]=\"{ enabled: true, animation: true }\" [dataSource]=\"vm.dataSource\"\r\n        (selectedRowsChange)=\"handleSelectedRowsChange($event)\" (onRowDbClick)=\"handleRowDbClick($event)\">\r\n        <ax-select-column fixed=\"start\" [width]=\"'50px'\"></ax-select-column>\r\n        @for(col of vm.columns();track col.name) {\r\n        @if(col.visible)\r\n        {\r\n        <axp-widget-column-renderer [caption]=\"col.title\" [node]=\"col.node()\"></axp-widget-column-renderer>\r\n        }\r\n        }\r\n        <ax-dropdown-command-column fixed=\"end\" [width]=\"'60px'\" [items]=\"getDropdownRowItems\"\r\n          (onItemClick)=\"handleRowCommandClick($event)\"></ax-dropdown-command-column>\r\n      </ax-data-table>\r\n    </div>\r\n    <!----- Finish DataTable  ----->\r\n  </ax-content>\r\n\r\n  <ax-drawer (collapsedChange)=\"closeDrawer('columns', $event)\" #columnsDrawer location=\"end\" [mode]=\"'overlay'\">\r\n    <ax-content class=\"ax-w-[85vw] md:ax-w-[45vw] lg:ax-w-[35vw] 2xl:ax-w-[20vw] ax-border-e\">\r\n      <axp-list-view-option-columns [viewModel]=\"vm\" (onClosed)=\"columnsDrawer.close()\"></axp-list-view-option-columns>\r\n    </ax-content>\r\n  </ax-drawer>\r\n  <ax-drawer (collapsedChange)=\"closeDrawer('conditions', $event)\" #conditionsDrawer location=\"end\" [mode]=\"'overlay'\">\r\n    <ax-content class=\"ax-w-[85vw] md:ax-w-[45vw] lg:ax-w-[35vw] 2xl:ax-w-[25vw] ax-border-e\">\r\n      <!-- <axp-list-view-option-conditions [loader]=\"loader\"\r\n        (onClosed)=\"conditionsDrawer.close()\"></axp-list-view-option-conditions> -->\r\n    </ax-content>\r\n  </ax-drawer>\r\n  <ax-drawer (collapsedChange)=\"closeDrawer('sorts', $event)\" #sortsDrawer location=\"end\" [mode]=\"'overlay'\">\r\n    <ax-content class=\"ax-w-[85vw] md:ax-w-[45vw] lg:ax-w-[35vw] 2xl:ax-w-[20vw] ax-border-e\">\r\n      <axp-list-view-option-sorting (onClosed)=\"sortsDrawer.close()\" [viewModel]=\"vm\"></axp-list-view-option-sorting>\r\n    </ax-content>\r\n  </ax-drawer>\r\n</ax-drawer-container>"]}
166
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity-master-list-view.component.js","sourceRoot":"","sources":["../../../../../../../../../../libs/platform/themes/default/src/lib/layouts/entity-layouts/entity-master-list-view/entity-master-list-view.component.ts","../../../../../../../../../../libs/platform/themes/default/src/lib/layouts/entity-layouts/entity-master-list-view/entity-master-list-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXActionSheetModule, AXActionSheetService } from '@acorex/components/action-sheet';\r\nimport { AXDataTableComponent, AXDataTableModule, AXDataTableRowDbClick, AXRowCommandItem, AXRowCommandItemClickEvent } from '@acorex/components/data-table';\r\nimport { AXDrawerModule } from '@acorex/components/drawer';\r\nimport { AXPlatform } from '@acorex/core/platform';\r\nimport { ChangeDetectionStrategy, Component, ViewChild, ViewEncapsulation, effect, inject } from '@angular/core';\r\nimport { ActivatedRoute, RouterModule } from '@angular/router';\r\nimport { Store } from '@ngrx/store';\r\n\r\nimport { AXPAdminLayoutState, AXPGridLayoutDirective, AXPLayoutService, AXPStickyDirective, getChildDrawer, isSmallScreen } from '@acorex/platform/common';\r\nimport { AXBadgeModule } from '@acorex/components/badge';\r\nimport { AXBreadcrumbsModule } from '@acorex/components/breadcrumbs';\r\nimport { AXButtonModule } from '@acorex/components/button';\r\nimport { AXDecoratorModule } from '@acorex/components/decorators';\r\nimport { AXDialogModule } from '@acorex/components/dialog';\r\nimport { AXDropdownModule } from '@acorex/components/dropdown';\r\nimport { AXFormModule } from '@acorex/components/form';\r\nimport { AXLoadingModule } from '@acorex/components/loading';\r\nimport { AXPopoverModule } from '@acorex/components/popover';\r\nimport { AXTabsModule } from '@acorex/components/tabs';\r\nimport { AXTooltipModule } from '@acorex/components/tooltip';\r\nimport { AXPLayoutBuilderModule } from '@acorex/platform/layout/builder';\r\nimport { AXPWidgetsModule } from '@acorex/platform/widgets';\r\nimport { CommonModule } from '@angular/common';\r\nimport { AXSearchBoxModule } from '@acorex/components/search-box';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { AXPAuthModule } from '@acorex/platform/auth';\r\nimport { AXPListViewOptionsColumnsComponent } from './list-view-option-columns/list-view-option-columns.component';\r\nimport { AXPListViewOptionSortingComponent } from './list-view-option-sorting/list-view-option-sorting.component';\r\nimport { AXValueChangedEvent } from '@acorex/components/common';\r\nimport { AXPEntityMasterListViewModel } from '@acorex/platform/layout/entity';\r\n\r\n@Component({\r\n  templateUrl: 'entity-master-list-view.component.html',\r\n  styleUrls: ['entity-master-list-view.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    RouterModule,\r\n    AXButtonModule,\r\n    AXDecoratorModule,\r\n    AXBadgeModule,\r\n    AXDropdownModule,\r\n    AXPopoverModule,\r\n    AXFormModule,\r\n    AXActionSheetModule,\r\n    AXDrawerModule,\r\n    AXDialogModule,\r\n    AXLoadingModule,\r\n    AXTabsModule,\r\n    AXTooltipModule,\r\n    AXBreadcrumbsModule,\r\n    AXSearchBoxModule,\r\n    AXDataTableModule,\r\n    //\r\n    AXPLayoutBuilderModule,\r\n    AXPWidgetsModule,\r\n    AXPStickyDirective,\r\n    AXPGridLayoutDirective,\r\n    AXPAuthModule,\r\n    //\r\n    AXPListViewOptionsColumnsComponent,\r\n    AXPListViewOptionSortingComponent\r\n\r\n  ],\r\n  standalone: true,\r\n})\r\nexport class AXPEntityMasterListViewComponent {\r\n\r\n  private layout = inject(AXPLayoutService);\r\n  private activeRoute = inject(ActivatedRoute);\r\n\r\n  protected readonly vm = this.activeRoute.snapshot.data['vm'] as AXPEntityMasterListViewModel;\r\n\r\n  //\r\n  private store = inject(Store<AXPAdminLayoutState>);\r\n  protected isSM = this.store.select(isSmallScreen());\r\n  protected isOpen = this.store.select(getChildDrawer());\r\n  //\r\n  protected focusedRow: any;\r\n  //\r\n  @ViewChild('grid') grid!: AXDataTableComponent;\r\n\r\n  constructor(\r\n    private actionSheetService: AXActionSheetService,\r\n    protected platform: AXPlatform,\r\n  ) {\r\n    effect(() => {\r\n      this.grid.selectedRows = this.vm.selectedItems();\r\n    }, { allowSignalWrites: true });\r\n    //\r\n    this.vm.events$.subscribe(e => {\r\n      if (e.action == \"refresh\") {\r\n        this.grid.refresh();\r\n      }\r\n    })\r\n\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.vm.setView();\r\n  }\r\n\r\n  protected closeDrawer(name: string, collapsed: boolean) {\r\n    if (collapsed) {\r\n      switch (name) {\r\n        case 'conditions':\r\n          //this.loader.resetConditions();\r\n          break;\r\n        case 'columns':\r\n          this.vm.applyColumns()\r\n          break;\r\n        case 'sorts':\r\n          //this.vm.resetSorts();\r\n          break;\r\n        default:\r\n          break;\r\n      }\r\n    }\r\n  }\r\n\r\n  handleChangeSearchValue(e: AXValueChangedEvent) {\r\n    if (e.isUserInteraction) {\r\n      this.vm.applyInlineFilter(e.value);\r\n    }\r\n  }\r\n\r\n  private dropdownRowItems: AXRowCommandItem[] = [\r\n    {\r\n      text: 'Details',\r\n      icon: 'fa-solid fa-eye',\r\n      name: 'open-entity',\r\n      divided: true,\r\n    },\r\n    {\r\n      text: 'Delete',\r\n      icon: 'fa-solid fa-trash-can',\r\n      name: 'delete-entity',\r\n      color: 'danger',\r\n      disabled: true,\r\n    },\r\n  ];\r\n\r\n  protected handleRowDbClick(e: AXDataTableRowDbClick) {\r\n    const d: AXRowCommandItemClickEvent = {\r\n      component: e.component,\r\n      name: this.dropdownRowItems[0].name,\r\n      data: e.data,\r\n    };\r\n    this.handleRowCommandClick(d);\r\n  }\r\n\r\n  protected getDropdownRowItems = (rowData: unknown): Promise<AXRowCommandItem[]> => {\r\n    return Promise.resolve(this.dropdownRowItems);\r\n  };\r\n\r\n  protected async handleRowCommandClick(e: AXRowCommandItemClickEvent) {\r\n    this.vm.executeCommand(e.name, e.data);\r\n  }\r\n\r\n  protected async handleSelectedRowsChange(rows: unknown[]) {\r\n    this.vm.selectedItems.set(rows);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.vm.destroy();\r\n  }\r\n\r\n}\r\n","<ax-drawer-container>\r\n  <ax-content class=\"ax-flex ax-flex-col ax-overflow-hidden\" #content>\r\n    <div\r\n      class=\"ax-flex ax-flex-col ax-gap-4 ax-px-4 ax-pb-4 md:ax-px-6 ax-bg-surface   ax-border-b md:ax-border-0 md:ax-bg-default\">\r\n      <div class=\"ax-flex ax-flex-col ax-pt-4 ax-gap-4 ax-sticky ax-top-0 ax-z-10 ax-transition-all\" #sticky=\"axpSticky\"\r\n        [axpSticky]=\"'ax-bg-surface ax-px-6 ax-py-3 -ax-mx-6 ax-shadow-xl'\" [stickyParent]=\"content.getHostElement()\">\r\n        <!-------- Begin Toolbar  -------->\r\n        <!-------- Begin Line 1  -------->\r\n        <div class=\"ax-flex ax-justify-between ax-items-center\">\r\n          <!-------- Begin Title  -------->\r\n          <div class=\"ax-flex ax-gap-1 ax-items-center\">\r\n            <div class=\"ax-flex ax-flex-col ax-gap-2 ax-transition\">\r\n              <div class=\"ax-text-xl md:ax-text-3xl ax-font-bold\">{{ vm.title()}}</div>\r\n              @if(vm.description())\r\n              {\r\n              <div class=\"ax-text-sm ax-text-neutral-600\" [class.ax-hidden]=\"sticky.isSticky\">{{\r\n                vm.description() }}</div>\r\n              }\r\n              <ax-breadcrumbs class=\"child:ax-font-normal child:ax-text-neutral-400\" [class.ax-hidden]=\"isSM | async\">\r\n                <ng-template #divider>\r\n                  <i class=\"fa-solid fa-chevron-right ax-text-xs ax-mx-2\"></i>\r\n                </ng-template>\r\n                @for(b of vm.beardcrumbs();track $index;let last=$last)\r\n                {\r\n                <ax-breadcrumbs-item [active]=\"last\" [class.!ax-font-semibold]=\"last\"\r\n                  [class.!ax-text-neutral-600]=\"last\" [routerLink]=\"b.url\">\r\n                  @if(b.icon)\r\n                  {\r\n                  <i [class]=\"b.icon\"></i>\r\n                  }\r\n                  {{b.title}}\r\n                </ax-breadcrumbs-item>\r\n                }\r\n              </ax-breadcrumbs>\r\n            </div>\r\n          </div>\r\n          <!-------- Finish Title  -------->\r\n          <!--------------------------------------------------------------->\r\n          <!-- Begin Action Menu  -->\r\n          <div class=\"ax-flex ax-items-center ax-gap-3\">\r\n            @for(tr of vm.primaryActions();track $index)\r\n            {\r\n            <ax-button [text]=\"tr.title\" [color]=\"tr.color\" (onClick)=\"vm.executeCommand(tr.name)\">\r\n              <ax-prefix>\r\n                <ax-icon [icon]=\"tr.icon\"> </ax-icon>\r\n              </ax-prefix>\r\n            </ax-button>\r\n            }\r\n            @if(vm.secondaryActions().length) {\r\n            <ax-button [text]=\"(isSM | async) ? null : 'Actions'\" color=\"ghost\">\r\n              <ax-prefix>\r\n                <i class=\"fa-solid fa-ellipsis-vertical\"></i>\r\n              </ax-prefix>\r\n              <ax-dropdown-panel>\r\n                <ax-button-item-list>\r\n                  @for(tr of vm.secondaryActions();track $index;let first=$first)\r\n                  {\r\n                  <ng-container>\r\n                    @if(tr.separated && !$first)\r\n                    {\r\n                    <ax-divider></ax-divider>\r\n                    }\r\n                    <ax-button-item [text]=\"tr.title\" class=\"ax-font-semibold ax-text-{{tr.color}}\"\r\n                      (onClick)=\"vm.executeCommand(tr.name)\">\r\n                      <ax-prefix>\r\n                        <ax-icon [icon]=\"tr.icon\"> </ax-icon>\r\n                      </ax-prefix>\r\n                    </ax-button-item>\r\n                  </ng-container>\r\n                  }\r\n                </ax-button-item-list>\r\n              </ax-dropdown-panel>\r\n            </ax-button>\r\n            }\r\n          </div>\r\n          <!-- Finish Action Menu  -->\r\n        </div>\r\n\r\n        <!-------- Finish Line 1  -------->\r\n\r\n        <!-------- Begin Line 2 -------->\r\n        <div class=\"ax-flex ax-justify-between ax-items-center\">\r\n          <div class=\"ax-flex ax-justify-start ax-items-center ax-gap-4\">\r\n            <!-------- Begin Selection  -------->\r\n\r\n            @if(vm.hasSelectedItems())\r\n            {\r\n            <div class=\"ax-flex ax-gap-3 ax-items-center ax-h-10\">\r\n              <span class=\"ax-text-xl ax-font-bold\"> {{ vm.selectedItems().length }} Items Selected </span>\r\n              <span (click)=\"vm.clearSelection()\"\r\n                class=\"ax-text-sm ax-text-primary dark:ax-text-primary-300 ax-underline ax-cursor-pointer\">Clear\r\n                Items</span>\r\n            </div>\r\n\r\n            <!-------- Finish Selection  -------->\r\n\r\n            } @else {\r\n\r\n            <!-------- Begin View  -------->\r\n\r\n            <ax-button [text]=\"vm.view().title\" #views color=\"ghost\">\r\n              <ax-prefix>\r\n                <i class=\"fa-solid fa-eye\"></i>\r\n              </ax-prefix>\r\n              <ax-suffix>\r\n                <i class=\"fa-solid fa-caret-down\"></i>\r\n              </ax-suffix>\r\n              <ax-dropdown-panel [adaptivityEnabled]=\"true\">\r\n                <ax-button-item-list class=\"ax-bg-surface\">\r\n                  <ax-title class=\"ax-font-bold ax-opacity-100\">Public Views</ax-title>\r\n                  <ax-button-item *ngFor=\"let v of vm.views()\" [text]=\"v.title\" [class.ax-bg-on-surface]=\"vm.view()==v\"\r\n                    (onClick)=\"vm.setView(v.name)\"></ax-button-item>\r\n                  <!-- <ax-title class=\"ax-font-bold ax-opacity-100\" *ngIf=\"hasCustomViews$ | async\">Created by me</ax-title>\r\n                <ax-button-item class=\"ax-pe-4 ax-flex ax-justify-between\" *ngFor=\"let v of customViews$ | async\"\r\n                  [text]=\"v.title\" [class.ax-bg-on-surface]=\"(view$ | async) == v\" (onClick)=\"loader.setView(v.name)\">\r\n                  <ax-suffix>\r\n                    <ax-button (onClick)=\"updateViewPopup($event, v)\" class=\"ax-xs\" look=\"none\">\r\n                      <ax-icon class=\"far fa-edit\"> </ax-icon>\r\n                    </ax-button>\r\n                  </ax-suffix>\r\n                </ax-button-item> -->\r\n                  <!-- <ng-container *feature=\"'axp-entity-list-custom-view'\">\r\n                  <ax-divider></ax-divider>\r\n                  <ax-button-item text=\"Add Custom View\" (onClick)=\"addCustomViewPopup()\"\r\n                    class=\"ax-font-semibold ax-text-primary\"></ax-button-item>\r\n                </ng-container> -->\r\n                </ax-button-item-list>\r\n              </ax-dropdown-panel>\r\n            </ax-button>\r\n            <!-------- Finish View  -------->\r\n\r\n            <!-------- Begin Inline Search   -------->\r\n\r\n            @if(vm.hasInlineFilters())\r\n            {\r\n            <div class=\"ax-w-72\" *feature=\"'axp-entity-list-inline-filter'\">\r\n              <ax-search-box [placeholder]=\"'Search on '+vm.inlineFiltersPlaceholders().join(', ')\"\r\n                (onValueChanged)=\"handleChangeSearchValue($event)\"><ax-clear-button></ax-clear-button></ax-search-box>\r\n            </div>\r\n            }\r\n            }\r\n            <!-------- Finish Inline Search -------->\r\n          </div>\r\n\r\n          <!-- Begin View Action Menu  -->\r\n          @if(!vm.hasSelectedItems())\r\n          {\r\n          <div class=\"ax-flex ax-gap-3\">\r\n            <ax-button text=\"Columns\" color=\"ghost\" (onClick)=\"columnsDrawer.open()\">\r\n              <ax-prefix>\r\n                <i class=\"fa-solid fa-bars\"></i>\r\n              </ax-prefix>\r\n              <ax-suffix>\r\n                <ax-badge [text]=\"vm.visibleColumnCount().toString()\" color=\"primary\"></ax-badge>\r\n              </ax-suffix>\r\n            </ax-button>\r\n            <ax-button text=\"Filters\" color=\"ghost\" (onClick)=\"conditionsDrawer.open()\"\r\n              *feature=\"'axp-entity-list-advance-filter'\">\r\n              <ax-prefix>\r\n                <i class=\"fa-solid fa-sliders\"></i>\r\n              </ax-prefix>\r\n              <ax-suffix>\r\n                <ax-badge text=\"3\" color=\"primary\"></ax-badge>\r\n              </ax-suffix>\r\n            </ax-button>\r\n            @if(vm.canSort())\r\n            {\r\n            <ax-button text=\"Sort\" color=\"ghost\" (onClick)=\"sortsDrawer.open()\">\r\n              <ax-prefix>\r\n                <i class=\"fa-solid fa-bars-sort\"></i>\r\n              </ax-prefix>\r\n              @if(vm.sortedCount())\r\n              {\r\n              <ax-suffix>\r\n                <ax-badge [text]=\"vm.sortedCount().toString()\" color=\"primary\"></ax-badge>\r\n              </ax-suffix>\r\n              }\r\n            </ax-button>\r\n            }\r\n          </div>\r\n          }\r\n          <!-- Finish View Action Menu  -->\r\n        </div>\r\n        <!-------- Finish Line 2  -------->\r\n\r\n        <!----- Finish Toolbar  ----->\r\n\r\n      </div>\r\n    </div>\r\n    <!----- Begin DataTable  ----->\r\n    <div class=\"ax-flex ax-flex-1 ax-px-6 ax-py-4  ax-overflow-auto\">\r\n      <ax-data-table #grid [showFooter]=\"false\" class=\"ax-flex-1\" [paging]=\"true\" [fetchDataMode]=\"'manual'\"\r\n        [loading]=\"{ enabled: true, animation: true }\" [dataSource]=\"vm.dataSource\"\r\n        (selectedRowsChange)=\"handleSelectedRowsChange($event)\" (onRowDbClick)=\"handleRowDbClick($event)\">\r\n        <ax-select-column fixed=\"start\" [width]=\"'50px'\"></ax-select-column>\r\n        @for(col of vm.columns();track col.name) {\r\n        @if(col.visible)\r\n        {\r\n        <axp-widget-column-renderer [caption]=\"col.title\" [node]=\"col.node()\"></axp-widget-column-renderer>\r\n        }\r\n        }\r\n        <ax-dropdown-command-column fixed=\"end\" [width]=\"'60px'\" [items]=\"getDropdownRowItems\"\r\n          (onItemClick)=\"handleRowCommandClick($event)\"></ax-dropdown-command-column>\r\n      </ax-data-table>\r\n    </div>\r\n    <!----- Finish DataTable  ----->\r\n  </ax-content>\r\n\r\n  <ax-drawer (collapsedChange)=\"closeDrawer('columns', $event)\" #columnsDrawer location=\"end\" [mode]=\"'overlay'\">\r\n    <ax-content class=\"ax-w-[85vw] md:ax-w-[45vw] lg:ax-w-[35vw] 2xl:ax-w-[20vw] ax-border-e\">\r\n      <axp-list-view-option-columns [viewModel]=\"vm\" (onClosed)=\"columnsDrawer.close()\"></axp-list-view-option-columns>\r\n    </ax-content>\r\n  </ax-drawer>\r\n  <ax-drawer (collapsedChange)=\"closeDrawer('conditions', $event)\" #conditionsDrawer location=\"end\" [mode]=\"'overlay'\">\r\n    <ax-content class=\"ax-w-[85vw] md:ax-w-[45vw] lg:ax-w-[35vw] 2xl:ax-w-[25vw] ax-border-e\">\r\n      <!-- <axp-list-view-option-conditions [loader]=\"loader\"\r\n        (onClosed)=\"conditionsDrawer.close()\"></axp-list-view-option-conditions> -->\r\n    </ax-content>\r\n  </ax-drawer>\r\n  <ax-drawer (collapsedChange)=\"closeDrawer('sorts', $event)\" #sortsDrawer location=\"end\" [mode]=\"'overlay'\">\r\n    <ax-content class=\"ax-w-[85vw] md:ax-w-[45vw] lg:ax-w-[35vw] 2xl:ax-w-[20vw] ax-border-e\">\r\n      <axp-list-view-option-sorting (onClosed)=\"sortsDrawer.close()\" [viewModel]=\"vm\"></axp-list-view-option-sorting>\r\n    </ax-content>\r\n  </ax-drawer>\r\n</ax-drawer-container>"]}
@@ -42,8 +42,11 @@ export class AXPEntityMasterSingleViewComponent {
42
42
  handleActiveTabChanged(e) {
43
43
  this.selectedTabIndex.set(e.index);
44
44
  }
45
+ ngOnDestroy() {
46
+ this.vm.destroy();
47
+ }
45
48
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: AXPEntityMasterSingleViewComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
46
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.2", type: AXPEntityMasterSingleViewComponent, isStandalone: true, selector: "ng-component", ngImport: i0, template: "<ax-drawer-container>\r\n <!-- <ax-drawer #drawer location=\"start\" [collapsed]=\"!(isOpen | async)\" [mode]=\" (isSM | async) ? 'overlay' : 'push'\"\r\n *ngIf=\"loader.hasSections$ | async\" (collapsedChange)=\"handleCollapsedChange($event)\">\r\n <ax-content class=\"ax-border-e ax-p-6 ax-w-64\">\r\n <p class=\"ax-text-xl ax-font-bold ax-mb-6\">{{loader.sectionTitle}}</p>\r\n <ax-tabs look=\"with-line\" location=\"start\">\r\n @for(tab of (loader.sections$ | async); track tab.name)\r\n {\r\n <ax-tab-item [text]=\"tab.title\" [active]=\"isActive(tab)\" (onClick)=\"handleMenuClick($event,tab)\"\r\n [disabled]=\"editForm.context\">\r\n </ax-tab-item>\r\n }\r\n </ax-tabs>\r\n </ax-content>\r\n </ax-drawer> -->\r\n <ax-content #content class=\"ax-overflow-x-hidden\">\r\n <div\r\n class=\"ax-flex ax-flex-col ax-gap-4 ax-min-h-full ax-px-4 ax-pb-4 md:ax-px-6 ax-bg-surface ax-border-b md:ax-border-0 md:ax-bg-default\">\r\n <div class=\"ax-flex ax-flex-col ax-pt-4 ax-sticky ax-top-0 ax-z-10 ax-transition-all\" #sticky=\"axpSticky\"\r\n [axpSticky]=\"'ax-bg-surface ax-px-6 ax-py-3 -ax-mx-6 ax-shadow-xl'\" [stickyOffset]=\"50\"\r\n [stickyParent]=\"content.getHostElement()\">\r\n <!-------- Begin Toolbar -------->\r\n <div class=\"ax-flex ax-justify-between ax-items-center\">\r\n <!-------- Begin Title -------->\r\n <div class=\"ax-flex ax-gap-1 ax-items-center\">\r\n <div class=\"ax-flex ax-flex-col ax-gap-2 ax-transition\">\r\n <div class=\"ax-text-xl md:ax-text-3xl ax-font-bold\">{{ vm.title()}}</div>\r\n @if(vm.description())\r\n {\r\n <div class=\"ax-text-sm ax-text-neutral-600\" [class.ax-hidden]=\"sticky.isSticky\">{{\r\n vm.description() }}</div>\r\n }\r\n <ax-breadcrumbs class=\"child:ax-font-normal child:ax-text-neutral-400\"\r\n [class.ax-hidden]=\"isSM | async\">\r\n <ng-template #divider>\r\n <i class=\"fa-solid fa-chevron-right ax-text-xs ax-mx-2\"></i>\r\n </ng-template>\r\n @for(b of vm.beardcrumbs();track $index;let last=$last)\r\n {\r\n <ax-breadcrumbs-item [active]=\"last\" [class.!ax-font-semibold]=\"last\"\r\n [class.!ax-text-neutral-600]=\"last\" [routerLink]=\"b.url\">\r\n @if(b.icon)\r\n {\r\n <i [class]=\"b.icon\"></i>\r\n }\r\n {{b.title}}\r\n </ax-breadcrumbs-item>\r\n }\r\n </ax-breadcrumbs>\r\n </div>\r\n </div>\r\n <!-------- Finish Title -------->\r\n <!--------------------------------------------------------------->\r\n <!-- Begin Action Menu -->\r\n <div class=\"ax-flex ax-items-center ax-gap-3\">\r\n @for(tr of vm.primaryActions();track $index)\r\n {\r\n <ax-button [text]=\"tr.title\" [color]=\"tr.color\">\r\n <ax-prefix>\r\n <ax-icon [icon]=\"tr.icon\"> </ax-icon>\r\n </ax-prefix>\r\n </ax-button>\r\n }\r\n @if(vm.secondaryActions().length) {\r\n <ax-button [text]=\"(isSM | async) ? null : 'Actions'\" color=\"ghost\">\r\n <ax-prefix>\r\n <i class=\"fa-solid fa-ellipsis-vertical\"></i>\r\n </ax-prefix>\r\n <ax-dropdown-panel>\r\n <ax-button-item-list>\r\n @for(tr of vm.secondaryActions();track $index)\r\n {\r\n <ng-container>\r\n @if(tr.separated)\r\n {\r\n <ax-divider></ax-divider>\r\n }\r\n <ax-button-item [text]=\"tr.title\" class=\"ax-font-semibold ax-text-{{tr.color}}\"\r\n (onClick)=\"vm.executeCommand(tr.name)\">\r\n <ax-prefix>\r\n <ax-icon [icon]=\"tr.icon\"> </ax-icon>\r\n </ax-prefix>\r\n </ax-button-item>\r\n </ng-container>\r\n }\r\n </ax-button-item-list>\r\n </ax-dropdown-panel>\r\n </ax-button>\r\n }\r\n </div>\r\n <!-- Finish Action Menu -->\r\n </div>\r\n <!----- Finish Toolbar ----->\r\n <!--------------------------------------------------------------->\r\n <ax-tabs [look]=\"'classic'\" class=\"ax-mt-4 ax-font-semibold\">\r\n <ax-tab-item text=\"Overview\">\r\n </ax-tab-item>\r\n <ax-tab-item text=\"History\">\r\n </ax-tab-item>\r\n <ax-tab-item text=\"Comments\">\r\n </ax-tab-item>\r\n </ax-tabs>\r\n </div>\r\n <!-- Begin Sections -->\r\n <div class=\"ax-grid ax-grid-cols-12 ax-gap-4\">\r\n @for(section of vm.sections(); track section.name()) {\r\n <div class=\"ax-card ax-shadow-md ax-mt-2\" [gridLayout]=\"section.layout()\">\r\n <ax-form #form>\r\n <axp-widgets-container [context]=\"vm.context()\">\r\n <div class=\"ax-card-header !ax-py-2 !ax-px-4\">\r\n <p>\r\n <span class=\"!ax-text-lg ax-font-semibold \">{{ section.title()\r\n }}</span>\r\n <br>\r\n @if(section.description()) {\r\n <span class=\"ax-text-sm ax-font-normal ax-text-gray-500\">{{ section.description()\r\n }}</span>\r\n }\r\n </p>\r\n @if(section.editable()) {\r\n <ax-button class=\"ax-xs\" color=\"ghost\" [look]=\"'blank'\"\r\n (onClick)=\"vm.executeCommand('modify-entity-section',section)\">\r\n <ax-icon class=\"fa-solid fa-pen ax-text-gray-600\"> </ax-icon>\r\n </ax-button>\r\n }\r\n </div>\r\n <div class=\"ax-card-body !ax-grid !ax-grid-cols-12 !ax-gap-4\">\r\n @for(attr of section.props(); track $index) {\r\n <div class=\"ax-flex ax-flex-col ax-gap-1\" [gridLayout]=\"attr.layout()\">\r\n <div>\r\n <div>\r\n <span class=\"ax-font-semibold\">{{ attr.title() }}</span>\r\n </div>\r\n </div>\r\n <div class=\"ax-text-neutral-500\">\r\n <axp-widget-renderer [node]=\"attr.node()\"> </axp-widget-renderer>\r\n </div>\r\n </div>\r\n }\r\n </div>\r\n </axp-widgets-container>\r\n </ax-form>\r\n </div>\r\n }\r\n </div>\r\n <!-- Finish Sections -->\r\n <!--------------------------------------------------------------->\r\n @if(vm.relatedEntities().length)\r\n {\r\n <ax-tabs [look]=\"'default'\" class=\"ax-mt-2 ax-font-semibold\" #tab\r\n (onActiveTabChanged)=\"handleActiveTabChanged($event)\">\r\n @for(e of vm.relatedEntities();track $index;let index= $index){\r\n <ax-tab-item [text]=\"e.title()\" [key]=\"index.toString()\">\r\n </ax-tab-item>\r\n }\r\n </ax-tabs>\r\n @for(e of vm.relatedEntities();track $index;let index= $index){\r\n <div [class.ax-hidden]=\"$index!=selectedTabIndex()\">\r\n <axp-entity-detail-list-view [viewModel]=\"e\"></axp-entity-detail-list-view>\r\n </div>\r\n }\r\n }\r\n\r\n </div>\r\n </ax-content>\r\n</ax-drawer-container>", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "ngmodule", type: RouterModule }, { kind: "directive", type: i2.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "ngmodule", type: AXDecoratorModule }, { kind: "component", type: i3.AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }, { kind: "component", type: i3.AXDecoratorGenericComponent, selector: "ax-footer, ax-header, ax-content, ax-divider, ax-form-hint, ax-prefix, ax-suffix, ax-text, ax-title, ax-sub-title, ax-placeholder, ax-overlay" }, { kind: "ngmodule", type: AXDropdownModule }, { kind: "component", type: i4.AXDropdownPanelComponent, selector: "ax-dropdown-panel", inputs: ["isOpen", "fitParent", "dropdownWidth", "position", "_target", "adaptivityEnabled"], outputs: ["onOpened", "onClosed"] }, { kind: "ngmodule", type: AXPopoverModule }, { kind: "ngmodule", type: AXFormModule }, { kind: "component", type: i5.AXFormComponent, selector: "ax-form", inputs: ["labelMode", "messageStyle", "updateOn"], outputs: ["onValidate", "updateOnChange"] }, { kind: "ngmodule", type: AXActionSheetModule }, { kind: "ngmodule", type: AXDrawerModule }, { kind: "component", type: i6.AXDrawerContainerComponent, selector: "ax-drawer-container" }, { kind: "ngmodule", type: AXDialogModule }, { kind: "ngmodule", type: AXLoadingModule }, { kind: "ngmodule", type: AXTabsModule }, { kind: "component", type: i7.AXTabsComponent, selector: "ax-tabs", inputs: ["look", "location", "fitParent", "minWidth", "content"], outputs: ["onActiveTabChanged"] }, { kind: "component", type: i7.AXTabItemComponent, selector: "ax-tab-item", inputs: ["disabled", "text", "key", "headerTemplate", "active"], outputs: ["disabledChange", "onClick", "onBlur", "onFocus", "activeChange"] }, { kind: "ngmodule", type: AXButtonModule }, { kind: "component", type: i8.AXButtonComponent, selector: "ax-button", inputs: ["disabled", "size", "tabIndex", "color", "look", "text", "toggleable", "selected", "type"], outputs: ["onBlur", "onFocus", "onClick", "selectedChange", "toggleableChange", "lookChange", "colorChange", "disabledChange"] }, { kind: "component", type: i8.AXButtonItemComponent, selector: "ax-button-item", inputs: ["color", "disabled", "text", "selected", "divided", "data", "name"], outputs: ["onClick", "onFocus", "onBlur", "disabledChange"] }, { kind: "component", type: i8.AXButtonItemListComponent, selector: "ax-button-item-list", inputs: ["items"], outputs: ["onItemClick"] }, { kind: "ngmodule", type: AXBreadcrumbsModule }, { kind: "component", type: i9.AXBreadCrumbsComponent, selector: "ax-breadcrumbs" }, { kind: "component", type: i9.AXBreadCrumbsItemComponent, selector: "ax-breadcrumbs-item", inputs: ["disabled", "active"] }, { kind: "ngmodule", type:
49
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.2", type: AXPEntityMasterSingleViewComponent, isStandalone: true, selector: "ng-component", ngImport: i0, template: "<ax-drawer-container>\r\n <!-- <ax-drawer #drawer location=\"start\" [collapsed]=\"!(isOpen | async)\" [mode]=\" (isSM | async) ? 'overlay' : 'push'\"\r\n *ngIf=\"loader.hasSections$ | async\" (collapsedChange)=\"handleCollapsedChange($event)\">\r\n <ax-content class=\"ax-border-e ax-p-6 ax-w-64\">\r\n <p class=\"ax-text-xl ax-font-bold ax-mb-6\">{{loader.sectionTitle}}</p>\r\n <ax-tabs look=\"with-line\" location=\"start\">\r\n @for(tab of (loader.sections$ | async); track tab.name)\r\n {\r\n <ax-tab-item [text]=\"tab.title\" [active]=\"isActive(tab)\" (onClick)=\"handleMenuClick($event,tab)\"\r\n [disabled]=\"editForm.context\">\r\n </ax-tab-item>\r\n }\r\n </ax-tabs>\r\n </ax-content>\r\n </ax-drawer> -->\r\n <ax-content #content class=\"ax-overflow-x-hidden\">\r\n <div\r\n class=\"ax-flex ax-flex-col ax-gap-4 ax-min-h-full ax-px-4 ax-pb-4 md:ax-px-6 ax-bg-surface ax-border-b md:ax-border-0 md:ax-bg-default\">\r\n <div class=\"ax-flex ax-flex-col ax-pt-4 ax-sticky ax-top-0 ax-z-10 ax-transition-all\" #sticky=\"axpSticky\"\r\n [axpSticky]=\"'ax-bg-surface ax-px-6 ax-py-3 -ax-mx-6 ax-shadow-xl'\" [stickyOffset]=\"50\"\r\n [stickyParent]=\"content.getHostElement()\">\r\n <!-------- Begin Toolbar -------->\r\n <div class=\"ax-flex ax-justify-between ax-items-center\">\r\n <!-------- Begin Title -------->\r\n <div class=\"ax-flex ax-gap-1 ax-items-center\">\r\n <div class=\"ax-flex ax-flex-col ax-gap-2 ax-transition\">\r\n <div class=\"ax-text-xl md:ax-text-3xl ax-font-bold\">{{ vm.title()}}</div>\r\n @if(vm.description())\r\n {\r\n <div class=\"ax-text-sm ax-text-neutral-600\" [class.ax-hidden]=\"sticky.isSticky\">{{\r\n vm.description() }}</div>\r\n }\r\n <ax-breadcrumbs class=\"child:ax-font-normal child:ax-text-neutral-400\"\r\n [class.ax-hidden]=\"isSM | async\">\r\n <ng-template #divider>\r\n <i class=\"fa-solid fa-chevron-right ax-text-xs ax-mx-2\"></i>\r\n </ng-template>\r\n @for(b of vm.beardcrumbs();track $index;let last=$last)\r\n {\r\n <ax-breadcrumbs-item [active]=\"last\" [class.!ax-font-semibold]=\"last\"\r\n [class.!ax-text-neutral-600]=\"last\" [routerLink]=\"b.url\">\r\n @if(b.icon)\r\n {\r\n <i [class]=\"b.icon\"></i>\r\n }\r\n {{b.title}}\r\n </ax-breadcrumbs-item>\r\n }\r\n </ax-breadcrumbs>\r\n </div>\r\n </div>\r\n <!-------- Finish Title -------->\r\n <!--------------------------------------------------------------->\r\n <!-- Begin Action Menu -->\r\n <div class=\"ax-flex ax-items-center ax-gap-3\">\r\n @for(tr of vm.primaryActions();track $index)\r\n {\r\n <ax-button [text]=\"tr.title\" [color]=\"tr.color\" (onClick)=\"vm.executeCommand(tr.name)\">\r\n <ax-prefix>\r\n <ax-icon [icon]=\"tr.icon\"> </ax-icon>\r\n </ax-prefix>\r\n </ax-button>\r\n }\r\n @if(vm.secondaryActions().length) {\r\n <ax-button [text]=\"(isSM | async) ? null : 'Actions'\" color=\"ghost\">\r\n <ax-prefix>\r\n <i class=\"fa-solid fa-ellipsis-vertical\"></i>\r\n </ax-prefix>\r\n <ax-dropdown-panel>\r\n <ax-button-item-list>\r\n @for(tr of vm.secondaryActions();track $index)\r\n {\r\n <ng-container>\r\n @if(tr.separated)\r\n {\r\n <ax-divider></ax-divider>\r\n }\r\n <ax-button-item [text]=\"tr.title\" class=\"ax-font-semibold ax-text-{{tr.color}}\"\r\n (onClick)=\"vm.executeCommand(tr.name)\">\r\n <ax-prefix>\r\n <ax-icon [icon]=\"tr.icon\"> </ax-icon>\r\n </ax-prefix>\r\n </ax-button-item>\r\n </ng-container>\r\n }\r\n </ax-button-item-list>\r\n </ax-dropdown-panel>\r\n </ax-button>\r\n }\r\n </div>\r\n <!-- Finish Action Menu -->\r\n </div>\r\n <!----- Finish Toolbar ----->\r\n <!--------------------------------------------------------------->\r\n <ax-tabs [look]=\"'classic'\" class=\"ax-mt-4 ax-font-semibold\">\r\n <ax-tab-item text=\"Overview\">\r\n </ax-tab-item>\r\n <ax-tab-item text=\"History\">\r\n </ax-tab-item>\r\n <ax-tab-item text=\"Comments\">\r\n </ax-tab-item>\r\n </ax-tabs>\r\n </div>\r\n <!-- Begin Sections -->\r\n <div class=\"ax-grid ax-grid-cols-12 ax-gap-4\">\r\n @for(section of vm.sections(); track section.name()) {\r\n <div class=\"ax-card ax-shadow-md ax-mt-2\" [gridLayout]=\"section.layout()\">\r\n <ax-form #form>\r\n <axp-widgets-container [context]=\"vm.context()\">\r\n <div class=\"ax-card-header !ax-py-2 !ax-px-4\">\r\n <p>\r\n <span class=\"!ax-text-lg ax-font-semibold \">{{ section.title()\r\n }}</span>\r\n <br>\r\n @if(section.description()) {\r\n <span class=\"ax-text-sm ax-font-normal ax-text-gray-500\">{{ section.description()\r\n }}</span>\r\n }\r\n </p>\r\n @if(section.editable()) {\r\n <ax-button class=\"ax-xs\" color=\"ghost\" [look]=\"'blank'\"\r\n (onClick)=\"vm.executeCommand('modify-entity-section',section)\">\r\n <ax-icon class=\"fa-solid fa-pen ax-text-gray-600\"> </ax-icon>\r\n </ax-button>\r\n }\r\n </div>\r\n <div class=\"ax-card-body !ax-grid !ax-grid-cols-12 !ax-gap-4\">\r\n @for(attr of section.props(); track $index) {\r\n <div class=\"ax-flex ax-flex-col ax-gap-1\" [gridLayout]=\"attr.layout()\">\r\n <div>\r\n <div>\r\n <span class=\"ax-font-semibold\">{{ attr.title() }}</span>\r\n </div>\r\n </div>\r\n <div class=\"ax-text-neutral-500\">\r\n <axp-widget-renderer [node]=\"attr.node()\"> </axp-widget-renderer>\r\n </div>\r\n </div>\r\n }\r\n </div>\r\n </axp-widgets-container>\r\n </ax-form>\r\n </div>\r\n }\r\n </div>\r\n <!-- Finish Sections -->\r\n <!--------------------------------------------------------------->\r\n @if(vm.relatedEntities().length)\r\n {\r\n <ax-tabs [look]=\"'default'\" class=\"ax-mt-2 ax-font-semibold\" #tab\r\n (onActiveTabChanged)=\"handleActiveTabChanged($event)\">\r\n @for(e of vm.relatedEntities();track $index;let index= $index){\r\n <ax-tab-item [text]=\"e.title()\" [key]=\"index.toString()\">\r\n </ax-tab-item>\r\n }\r\n </ax-tabs>\r\n @for(e of vm.relatedEntities();track $index;let index= $index){\r\n <div [class.ax-hidden]=\"$index!=selectedTabIndex()\">\r\n <axp-entity-detail-list-view [viewModel]=\"e\"></axp-entity-detail-list-view>\r\n </div>\r\n }\r\n }\r\n\r\n </div>\r\n </ax-content>\r\n</ax-drawer-container>", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "ngmodule", type: RouterModule }, { kind: "directive", type: i2.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "ngmodule", type: AXDecoratorModule }, { kind: "component", type: i3.AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }, { kind: "component", type: i3.AXDecoratorGenericComponent, selector: "ax-footer, ax-header, ax-content, ax-divider, ax-form-hint, ax-prefix, ax-suffix, ax-text, ax-title, ax-sub-title, ax-placeholder, ax-overlay" }, { kind: "ngmodule", type: AXDropdownModule }, { kind: "component", type: i4.AXDropdownPanelComponent, selector: "ax-dropdown-panel", inputs: ["isOpen", "fitParent", "dropdownWidth", "position", "_target", "adaptivityEnabled"], outputs: ["onOpened", "onClosed"] }, { kind: "ngmodule", type: AXPopoverModule }, { kind: "ngmodule", type: AXFormModule }, { kind: "component", type: i5.AXFormComponent, selector: "ax-form", inputs: ["labelMode", "messageStyle", "updateOn"], outputs: ["onValidate", "updateOnChange"] }, { kind: "ngmodule", type: AXActionSheetModule }, { kind: "ngmodule", type: AXDrawerModule }, { kind: "component", type: i6.AXDrawerContainerComponent, selector: "ax-drawer-container" }, { kind: "ngmodule", type: AXDialogModule }, { kind: "ngmodule", type: AXLoadingModule }, { kind: "ngmodule", type: AXTabsModule }, { kind: "component", type: i7.AXTabsComponent, selector: "ax-tabs", inputs: ["look", "location", "fitParent", "minWidth", "content"], outputs: ["onActiveTabChanged"] }, { kind: "component", type: i7.AXTabItemComponent, selector: "ax-tab-item", inputs: ["disabled", "text", "key", "headerTemplate", "active"], outputs: ["disabledChange", "onClick", "onBlur", "onFocus", "activeChange"] }, { kind: "ngmodule", type: AXButtonModule }, { kind: "component", type: i8.AXButtonComponent, selector: "ax-button", inputs: ["disabled", "size", "tabIndex", "color", "look", "text", "toggleable", "selected", "type"], outputs: ["onBlur", "onFocus", "onClick", "selectedChange", "toggleableChange", "lookChange", "colorChange", "disabledChange"] }, { kind: "component", type: i8.AXButtonItemComponent, selector: "ax-button-item", inputs: ["color", "disabled", "text", "selected", "divided", "data", "name"], outputs: ["onClick", "onFocus", "onBlur", "disabledChange"] }, { kind: "component", type: i8.AXButtonItemListComponent, selector: "ax-button-item-list", inputs: ["items"], outputs: ["onItemClick"] }, { kind: "ngmodule", type: AXBreadcrumbsModule }, { kind: "component", type: i9.AXBreadCrumbsComponent, selector: "ax-breadcrumbs" }, { kind: "component", type: i9.AXBreadCrumbsItemComponent, selector: "ax-breadcrumbs-item", inputs: ["disabled", "active"] }, { kind: "ngmodule", type:
47
50
  //
48
51
  AXPLayoutBuilderModule }, { kind: "component", type: i10.AXPWidgetContainerComponent, selector: "axp-widgets-container", inputs: ["context", "variables", "functions"], outputs: ["contextChange"] }, { kind: "component", type: i10.AXPWidgetRendererComponent, selector: "axp-widget-renderer", inputs: ["node"] }, { kind: "ngmodule", type: AXPWidgetsModule }, { kind: "directive", type: AXPStickyDirective, selector: "[axpSticky]", inputs: ["axpSticky", "stickyOffset", "stickyParent", "stickyTarget"], outputs: ["isStickyChange"], exportAs: ["axpSticky"] }, { kind: "directive", type: AXPGridLayoutDirective, selector: "[gridLayout]", inputs: ["gridLayout"] }, { kind: "component", type:
49
52
  //
@@ -72,6 +75,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImpor
72
75
  AXPGridLayoutDirective,
73
76
  //
74
77
  AXPEntityDetailListViewComponent
75
- ], standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ax-drawer-container>\r\n <!-- <ax-drawer #drawer location=\"start\" [collapsed]=\"!(isOpen | async)\" [mode]=\" (isSM | async) ? 'overlay' : 'push'\"\r\n *ngIf=\"loader.hasSections$ | async\" (collapsedChange)=\"handleCollapsedChange($event)\">\r\n <ax-content class=\"ax-border-e ax-p-6 ax-w-64\">\r\n <p class=\"ax-text-xl ax-font-bold ax-mb-6\">{{loader.sectionTitle}}</p>\r\n <ax-tabs look=\"with-line\" location=\"start\">\r\n @for(tab of (loader.sections$ | async); track tab.name)\r\n {\r\n <ax-tab-item [text]=\"tab.title\" [active]=\"isActive(tab)\" (onClick)=\"handleMenuClick($event,tab)\"\r\n [disabled]=\"editForm.context\">\r\n </ax-tab-item>\r\n }\r\n </ax-tabs>\r\n </ax-content>\r\n </ax-drawer> -->\r\n <ax-content #content class=\"ax-overflow-x-hidden\">\r\n <div\r\n class=\"ax-flex ax-flex-col ax-gap-4 ax-min-h-full ax-px-4 ax-pb-4 md:ax-px-6 ax-bg-surface ax-border-b md:ax-border-0 md:ax-bg-default\">\r\n <div class=\"ax-flex ax-flex-col ax-pt-4 ax-sticky ax-top-0 ax-z-10 ax-transition-all\" #sticky=\"axpSticky\"\r\n [axpSticky]=\"'ax-bg-surface ax-px-6 ax-py-3 -ax-mx-6 ax-shadow-xl'\" [stickyOffset]=\"50\"\r\n [stickyParent]=\"content.getHostElement()\">\r\n <!-------- Begin Toolbar -------->\r\n <div class=\"ax-flex ax-justify-between ax-items-center\">\r\n <!-------- Begin Title -------->\r\n <div class=\"ax-flex ax-gap-1 ax-items-center\">\r\n <div class=\"ax-flex ax-flex-col ax-gap-2 ax-transition\">\r\n <div class=\"ax-text-xl md:ax-text-3xl ax-font-bold\">{{ vm.title()}}</div>\r\n @if(vm.description())\r\n {\r\n <div class=\"ax-text-sm ax-text-neutral-600\" [class.ax-hidden]=\"sticky.isSticky\">{{\r\n vm.description() }}</div>\r\n }\r\n <ax-breadcrumbs class=\"child:ax-font-normal child:ax-text-neutral-400\"\r\n [class.ax-hidden]=\"isSM | async\">\r\n <ng-template #divider>\r\n <i class=\"fa-solid fa-chevron-right ax-text-xs ax-mx-2\"></i>\r\n </ng-template>\r\n @for(b of vm.beardcrumbs();track $index;let last=$last)\r\n {\r\n <ax-breadcrumbs-item [active]=\"last\" [class.!ax-font-semibold]=\"last\"\r\n [class.!ax-text-neutral-600]=\"last\" [routerLink]=\"b.url\">\r\n @if(b.icon)\r\n {\r\n <i [class]=\"b.icon\"></i>\r\n }\r\n {{b.title}}\r\n </ax-breadcrumbs-item>\r\n }\r\n </ax-breadcrumbs>\r\n </div>\r\n </div>\r\n <!-------- Finish Title -------->\r\n <!--------------------------------------------------------------->\r\n <!-- Begin Action Menu -->\r\n <div class=\"ax-flex ax-items-center ax-gap-3\">\r\n @for(tr of vm.primaryActions();track $index)\r\n {\r\n <ax-button [text]=\"tr.title\" [color]=\"tr.color\">\r\n <ax-prefix>\r\n <ax-icon [icon]=\"tr.icon\"> </ax-icon>\r\n </ax-prefix>\r\n </ax-button>\r\n }\r\n @if(vm.secondaryActions().length) {\r\n <ax-button [text]=\"(isSM | async) ? null : 'Actions'\" color=\"ghost\">\r\n <ax-prefix>\r\n <i class=\"fa-solid fa-ellipsis-vertical\"></i>\r\n </ax-prefix>\r\n <ax-dropdown-panel>\r\n <ax-button-item-list>\r\n @for(tr of vm.secondaryActions();track $index)\r\n {\r\n <ng-container>\r\n @if(tr.separated)\r\n {\r\n <ax-divider></ax-divider>\r\n }\r\n <ax-button-item [text]=\"tr.title\" class=\"ax-font-semibold ax-text-{{tr.color}}\"\r\n (onClick)=\"vm.executeCommand(tr.name)\">\r\n <ax-prefix>\r\n <ax-icon [icon]=\"tr.icon\"> </ax-icon>\r\n </ax-prefix>\r\n </ax-button-item>\r\n </ng-container>\r\n }\r\n </ax-button-item-list>\r\n </ax-dropdown-panel>\r\n </ax-button>\r\n }\r\n </div>\r\n <!-- Finish Action Menu -->\r\n </div>\r\n <!----- Finish Toolbar ----->\r\n <!--------------------------------------------------------------->\r\n <ax-tabs [look]=\"'classic'\" class=\"ax-mt-4 ax-font-semibold\">\r\n <ax-tab-item text=\"Overview\">\r\n </ax-tab-item>\r\n <ax-tab-item text=\"History\">\r\n </ax-tab-item>\r\n <ax-tab-item text=\"Comments\">\r\n </ax-tab-item>\r\n </ax-tabs>\r\n </div>\r\n <!-- Begin Sections -->\r\n <div class=\"ax-grid ax-grid-cols-12 ax-gap-4\">\r\n @for(section of vm.sections(); track section.name()) {\r\n <div class=\"ax-card ax-shadow-md ax-mt-2\" [gridLayout]=\"section.layout()\">\r\n <ax-form #form>\r\n <axp-widgets-container [context]=\"vm.context()\">\r\n <div class=\"ax-card-header !ax-py-2 !ax-px-4\">\r\n <p>\r\n <span class=\"!ax-text-lg ax-font-semibold \">{{ section.title()\r\n }}</span>\r\n <br>\r\n @if(section.description()) {\r\n <span class=\"ax-text-sm ax-font-normal ax-text-gray-500\">{{ section.description()\r\n }}</span>\r\n }\r\n </p>\r\n @if(section.editable()) {\r\n <ax-button class=\"ax-xs\" color=\"ghost\" [look]=\"'blank'\"\r\n (onClick)=\"vm.executeCommand('modify-entity-section',section)\">\r\n <ax-icon class=\"fa-solid fa-pen ax-text-gray-600\"> </ax-icon>\r\n </ax-button>\r\n }\r\n </div>\r\n <div class=\"ax-card-body !ax-grid !ax-grid-cols-12 !ax-gap-4\">\r\n @for(attr of section.props(); track $index) {\r\n <div class=\"ax-flex ax-flex-col ax-gap-1\" [gridLayout]=\"attr.layout()\">\r\n <div>\r\n <div>\r\n <span class=\"ax-font-semibold\">{{ attr.title() }}</span>\r\n </div>\r\n </div>\r\n <div class=\"ax-text-neutral-500\">\r\n <axp-widget-renderer [node]=\"attr.node()\"> </axp-widget-renderer>\r\n </div>\r\n </div>\r\n }\r\n </div>\r\n </axp-widgets-container>\r\n </ax-form>\r\n </div>\r\n }\r\n </div>\r\n <!-- Finish Sections -->\r\n <!--------------------------------------------------------------->\r\n @if(vm.relatedEntities().length)\r\n {\r\n <ax-tabs [look]=\"'default'\" class=\"ax-mt-2 ax-font-semibold\" #tab\r\n (onActiveTabChanged)=\"handleActiveTabChanged($event)\">\r\n @for(e of vm.relatedEntities();track $index;let index= $index){\r\n <ax-tab-item [text]=\"e.title()\" [key]=\"index.toString()\">\r\n </ax-tab-item>\r\n }\r\n </ax-tabs>\r\n @for(e of vm.relatedEntities();track $index;let index= $index){\r\n <div [class.ax-hidden]=\"$index!=selectedTabIndex()\">\r\n <axp-entity-detail-list-view [viewModel]=\"e\"></axp-entity-detail-list-view>\r\n </div>\r\n }\r\n }\r\n\r\n </div>\r\n </ax-content>\r\n</ax-drawer-container>" }]
78
+ ], standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ax-drawer-container>\r\n <!-- <ax-drawer #drawer location=\"start\" [collapsed]=\"!(isOpen | async)\" [mode]=\" (isSM | async) ? 'overlay' : 'push'\"\r\n *ngIf=\"loader.hasSections$ | async\" (collapsedChange)=\"handleCollapsedChange($event)\">\r\n <ax-content class=\"ax-border-e ax-p-6 ax-w-64\">\r\n <p class=\"ax-text-xl ax-font-bold ax-mb-6\">{{loader.sectionTitle}}</p>\r\n <ax-tabs look=\"with-line\" location=\"start\">\r\n @for(tab of (loader.sections$ | async); track tab.name)\r\n {\r\n <ax-tab-item [text]=\"tab.title\" [active]=\"isActive(tab)\" (onClick)=\"handleMenuClick($event,tab)\"\r\n [disabled]=\"editForm.context\">\r\n </ax-tab-item>\r\n }\r\n </ax-tabs>\r\n </ax-content>\r\n </ax-drawer> -->\r\n <ax-content #content class=\"ax-overflow-x-hidden\">\r\n <div\r\n class=\"ax-flex ax-flex-col ax-gap-4 ax-min-h-full ax-px-4 ax-pb-4 md:ax-px-6 ax-bg-surface ax-border-b md:ax-border-0 md:ax-bg-default\">\r\n <div class=\"ax-flex ax-flex-col ax-pt-4 ax-sticky ax-top-0 ax-z-10 ax-transition-all\" #sticky=\"axpSticky\"\r\n [axpSticky]=\"'ax-bg-surface ax-px-6 ax-py-3 -ax-mx-6 ax-shadow-xl'\" [stickyOffset]=\"50\"\r\n [stickyParent]=\"content.getHostElement()\">\r\n <!-------- Begin Toolbar -------->\r\n <div class=\"ax-flex ax-justify-between ax-items-center\">\r\n <!-------- Begin Title -------->\r\n <div class=\"ax-flex ax-gap-1 ax-items-center\">\r\n <div class=\"ax-flex ax-flex-col ax-gap-2 ax-transition\">\r\n <div class=\"ax-text-xl md:ax-text-3xl ax-font-bold\">{{ vm.title()}}</div>\r\n @if(vm.description())\r\n {\r\n <div class=\"ax-text-sm ax-text-neutral-600\" [class.ax-hidden]=\"sticky.isSticky\">{{\r\n vm.description() }}</div>\r\n }\r\n <ax-breadcrumbs class=\"child:ax-font-normal child:ax-text-neutral-400\"\r\n [class.ax-hidden]=\"isSM | async\">\r\n <ng-template #divider>\r\n <i class=\"fa-solid fa-chevron-right ax-text-xs ax-mx-2\"></i>\r\n </ng-template>\r\n @for(b of vm.beardcrumbs();track $index;let last=$last)\r\n {\r\n <ax-breadcrumbs-item [active]=\"last\" [class.!ax-font-semibold]=\"last\"\r\n [class.!ax-text-neutral-600]=\"last\" [routerLink]=\"b.url\">\r\n @if(b.icon)\r\n {\r\n <i [class]=\"b.icon\"></i>\r\n }\r\n {{b.title}}\r\n </ax-breadcrumbs-item>\r\n }\r\n </ax-breadcrumbs>\r\n </div>\r\n </div>\r\n <!-------- Finish Title -------->\r\n <!--------------------------------------------------------------->\r\n <!-- Begin Action Menu -->\r\n <div class=\"ax-flex ax-items-center ax-gap-3\">\r\n @for(tr of vm.primaryActions();track $index)\r\n {\r\n <ax-button [text]=\"tr.title\" [color]=\"tr.color\" (onClick)=\"vm.executeCommand(tr.name)\">\r\n <ax-prefix>\r\n <ax-icon [icon]=\"tr.icon\"> </ax-icon>\r\n </ax-prefix>\r\n </ax-button>\r\n }\r\n @if(vm.secondaryActions().length) {\r\n <ax-button [text]=\"(isSM | async) ? null : 'Actions'\" color=\"ghost\">\r\n <ax-prefix>\r\n <i class=\"fa-solid fa-ellipsis-vertical\"></i>\r\n </ax-prefix>\r\n <ax-dropdown-panel>\r\n <ax-button-item-list>\r\n @for(tr of vm.secondaryActions();track $index)\r\n {\r\n <ng-container>\r\n @if(tr.separated)\r\n {\r\n <ax-divider></ax-divider>\r\n }\r\n <ax-button-item [text]=\"tr.title\" class=\"ax-font-semibold ax-text-{{tr.color}}\"\r\n (onClick)=\"vm.executeCommand(tr.name)\">\r\n <ax-prefix>\r\n <ax-icon [icon]=\"tr.icon\"> </ax-icon>\r\n </ax-prefix>\r\n </ax-button-item>\r\n </ng-container>\r\n }\r\n </ax-button-item-list>\r\n </ax-dropdown-panel>\r\n </ax-button>\r\n }\r\n </div>\r\n <!-- Finish Action Menu -->\r\n </div>\r\n <!----- Finish Toolbar ----->\r\n <!--------------------------------------------------------------->\r\n <ax-tabs [look]=\"'classic'\" class=\"ax-mt-4 ax-font-semibold\">\r\n <ax-tab-item text=\"Overview\">\r\n </ax-tab-item>\r\n <ax-tab-item text=\"History\">\r\n </ax-tab-item>\r\n <ax-tab-item text=\"Comments\">\r\n </ax-tab-item>\r\n </ax-tabs>\r\n </div>\r\n <!-- Begin Sections -->\r\n <div class=\"ax-grid ax-grid-cols-12 ax-gap-4\">\r\n @for(section of vm.sections(); track section.name()) {\r\n <div class=\"ax-card ax-shadow-md ax-mt-2\" [gridLayout]=\"section.layout()\">\r\n <ax-form #form>\r\n <axp-widgets-container [context]=\"vm.context()\">\r\n <div class=\"ax-card-header !ax-py-2 !ax-px-4\">\r\n <p>\r\n <span class=\"!ax-text-lg ax-font-semibold \">{{ section.title()\r\n }}</span>\r\n <br>\r\n @if(section.description()) {\r\n <span class=\"ax-text-sm ax-font-normal ax-text-gray-500\">{{ section.description()\r\n }}</span>\r\n }\r\n </p>\r\n @if(section.editable()) {\r\n <ax-button class=\"ax-xs\" color=\"ghost\" [look]=\"'blank'\"\r\n (onClick)=\"vm.executeCommand('modify-entity-section',section)\">\r\n <ax-icon class=\"fa-solid fa-pen ax-text-gray-600\"> </ax-icon>\r\n </ax-button>\r\n }\r\n </div>\r\n <div class=\"ax-card-body !ax-grid !ax-grid-cols-12 !ax-gap-4\">\r\n @for(attr of section.props(); track $index) {\r\n <div class=\"ax-flex ax-flex-col ax-gap-1\" [gridLayout]=\"attr.layout()\">\r\n <div>\r\n <div>\r\n <span class=\"ax-font-semibold\">{{ attr.title() }}</span>\r\n </div>\r\n </div>\r\n <div class=\"ax-text-neutral-500\">\r\n <axp-widget-renderer [node]=\"attr.node()\"> </axp-widget-renderer>\r\n </div>\r\n </div>\r\n }\r\n </div>\r\n </axp-widgets-container>\r\n </ax-form>\r\n </div>\r\n }\r\n </div>\r\n <!-- Finish Sections -->\r\n <!--------------------------------------------------------------->\r\n @if(vm.relatedEntities().length)\r\n {\r\n <ax-tabs [look]=\"'default'\" class=\"ax-mt-2 ax-font-semibold\" #tab\r\n (onActiveTabChanged)=\"handleActiveTabChanged($event)\">\r\n @for(e of vm.relatedEntities();track $index;let index= $index){\r\n <ax-tab-item [text]=\"e.title()\" [key]=\"index.toString()\">\r\n </ax-tab-item>\r\n }\r\n </ax-tabs>\r\n @for(e of vm.relatedEntities();track $index;let index= $index){\r\n <div [class.ax-hidden]=\"$index!=selectedTabIndex()\">\r\n <axp-entity-detail-list-view [viewModel]=\"e\"></axp-entity-detail-list-view>\r\n </div>\r\n }\r\n }\r\n\r\n </div>\r\n </ax-content>\r\n</ax-drawer-container>" }]
76
79
  }] });
77
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity-master-single-view.component.js","sourceRoot":"","sources":["../../../../../../../../../../libs/platform/themes/default/src/lib/layouts/entity-layouts/entity-master-single-view/entity-master-single-view.component.ts","../../../../../../../../../../libs/platform/themes/default/src/lib/layouts/entity-layouts/entity-master-single-view/entity-master-single-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXActionSheetModule } from '@acorex/components/action-sheet';\r\nimport { AXBreadcrumbsModule } from '@acorex/components/breadcrumbs';\r\nimport { AXButtonModule } from '@acorex/components/button';\r\nimport { AXDecoratorModule } from '@acorex/components/decorators';\r\nimport { AXDialogModule } from '@acorex/components/dialog';\r\nimport { AXDrawerModule } from '@acorex/components/drawer';\r\nimport { AXDropdownModule } from '@acorex/components/dropdown';\r\nimport { AXFormModule } from '@acorex/components/form';\r\nimport { AXLoadingModule } from '@acorex/components/loading';\r\nimport { AXPopoverModule } from '@acorex/components/popover';\r\nimport { AXTabsModule } from '@acorex/components/tabs';\r\nimport { AXPAdminLayoutState, AXPStickyDirective, getChildDrawer, isSmallScreen } from '@acorex/platform/common';\r\nimport { CommonModule } from '@angular/common';\r\nimport { ChangeDetectionStrategy, Component, inject, signal } from '@angular/core';\r\nimport { ActivatedRoute, RouterModule } from '@angular/router';\r\nimport { Store } from '@ngrx/store';\r\nimport { AXPLayoutBuilderModule } from '@acorex/platform/layout/builder';\r\nimport { AXPWidgetsModule } from '@acorex/platform/widgets';\r\nimport { AXPGridLayoutDirective } from '@acorex/platform/common';\r\nimport { AXPEntityDetailListViewComponent } from '../entity-detail-list-view/entity-detail-list-view.component';\r\nimport { AXPEntityMasterSingleViewModel } from '@acorex/platform/layout/entity';\r\n\r\n\r\n@Component({\r\n    templateUrl: './entity-master-single-view.component.html',\r\n    imports: [\r\n        CommonModule,\r\n        RouterModule,\r\n        AXDecoratorModule,\r\n        AXDropdownModule,\r\n        AXPopoverModule,\r\n        AXFormModule,\r\n        AXActionSheetModule,\r\n        AXDrawerModule,\r\n        AXDialogModule,\r\n        AXLoadingModule,\r\n        AXTabsModule,\r\n        AXButtonModule,\r\n        AXBreadcrumbsModule,\r\n        //\r\n        AXPLayoutBuilderModule,\r\n        AXPWidgetsModule,\r\n        AXPStickyDirective,\r\n        AXPGridLayoutDirective,\r\n        //\r\n        AXPEntityDetailListViewComponent\r\n    ],\r\n    standalone: true,\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class AXPEntityMasterSingleViewComponent {\r\n    private activeRoute = inject(ActivatedRoute);\r\n    protected readonly vm = this.activeRoute.snapshot.data['vm'] as AXPEntityMasterSingleViewModel;\r\n    //\r\n    private store = inject(Store<AXPAdminLayoutState>);\r\n    protected isSM = this.store.select(isSmallScreen());\r\n    protected isOpen = this.store.select(getChildDrawer());\r\n\r\n\r\n    protected selectedTabIndex = signal(0);\r\n\r\n    handleActiveTabChanged(e: any) {\r\n        this.selectedTabIndex.set(e.index);\r\n    }\r\n}","<ax-drawer-container>\r\n    <!-- <ax-drawer #drawer location=\"start\" [collapsed]=\"!(isOpen | async)\" [mode]=\" (isSM | async) ? 'overlay' : 'push'\"\r\n      *ngIf=\"loader.hasSections$ | async\" (collapsedChange)=\"handleCollapsedChange($event)\">\r\n      <ax-content class=\"ax-border-e ax-p-6 ax-w-64\">\r\n        <p class=\"ax-text-xl ax-font-bold ax-mb-6\">{{loader.sectionTitle}}</p>\r\n        <ax-tabs look=\"with-line\" location=\"start\">\r\n          @for(tab of (loader.sections$ | async); track tab.name)\r\n          {\r\n          <ax-tab-item [text]=\"tab.title\" [active]=\"isActive(tab)\" (onClick)=\"handleMenuClick($event,tab)\"\r\n            [disabled]=\"editForm.context\">\r\n          </ax-tab-item>\r\n          }\r\n        </ax-tabs>\r\n      </ax-content>\r\n    </ax-drawer> -->\r\n    <ax-content #content class=\"ax-overflow-x-hidden\">\r\n        <div\r\n            class=\"ax-flex ax-flex-col ax-gap-4 ax-min-h-full ax-px-4 ax-pb-4 md:ax-px-6 ax-bg-surface   ax-border-b md:ax-border-0 md:ax-bg-default\">\r\n            <div class=\"ax-flex ax-flex-col ax-pt-4 ax-sticky ax-top-0 ax-z-10 ax-transition-all\" #sticky=\"axpSticky\"\r\n                [axpSticky]=\"'ax-bg-surface ax-px-6 ax-py-3 -ax-mx-6 ax-shadow-xl'\" [stickyOffset]=\"50\"\r\n                [stickyParent]=\"content.getHostElement()\">\r\n                <!-------- Begin Toolbar  -------->\r\n                <div class=\"ax-flex ax-justify-between ax-items-center\">\r\n                    <!-------- Begin Title  -------->\r\n                    <div class=\"ax-flex ax-gap-1 ax-items-center\">\r\n                        <div class=\"ax-flex ax-flex-col ax-gap-2 ax-transition\">\r\n                            <div class=\"ax-text-xl md:ax-text-3xl ax-font-bold\">{{ vm.title()}}</div>\r\n                            @if(vm.description())\r\n                            {\r\n                            <div class=\"ax-text-sm ax-text-neutral-600\" [class.ax-hidden]=\"sticky.isSticky\">{{\r\n                                vm.description() }}</div>\r\n                            }\r\n                            <ax-breadcrumbs class=\"child:ax-font-normal child:ax-text-neutral-400\"\r\n                                [class.ax-hidden]=\"isSM | async\">\r\n                                <ng-template #divider>\r\n                                    <i class=\"fa-solid fa-chevron-right ax-text-xs ax-mx-2\"></i>\r\n                                </ng-template>\r\n                                @for(b of vm.beardcrumbs();track $index;let last=$last)\r\n                                {\r\n                                <ax-breadcrumbs-item [active]=\"last\" [class.!ax-font-semibold]=\"last\"\r\n                                    [class.!ax-text-neutral-600]=\"last\" [routerLink]=\"b.url\">\r\n                                    @if(b.icon)\r\n                                    {\r\n                                    <i [class]=\"b.icon\"></i>\r\n                                    }\r\n                                    {{b.title}}\r\n                                </ax-breadcrumbs-item>\r\n                                }\r\n                            </ax-breadcrumbs>\r\n                        </div>\r\n                    </div>\r\n                    <!-------- Finish Title  -------->\r\n                    <!--------------------------------------------------------------->\r\n                    <!-- Begin Action Menu  -->\r\n                    <div class=\"ax-flex ax-items-center ax-gap-3\">\r\n                        @for(tr of vm.primaryActions();track $index)\r\n                        {\r\n                        <ax-button [text]=\"tr.title\" [color]=\"tr.color\">\r\n                            <ax-prefix>\r\n                                <ax-icon [icon]=\"tr.icon\"> </ax-icon>\r\n                            </ax-prefix>\r\n                        </ax-button>\r\n                        }\r\n                        @if(vm.secondaryActions().length) {\r\n                        <ax-button [text]=\"(isSM | async) ? null : 'Actions'\" color=\"ghost\">\r\n                            <ax-prefix>\r\n                                <i class=\"fa-solid fa-ellipsis-vertical\"></i>\r\n                            </ax-prefix>\r\n                            <ax-dropdown-panel>\r\n                                <ax-button-item-list>\r\n                                    @for(tr of vm.secondaryActions();track $index)\r\n                                    {\r\n                                    <ng-container>\r\n                                        @if(tr.separated)\r\n                                        {\r\n                                        <ax-divider></ax-divider>\r\n                                        }\r\n                                        <ax-button-item [text]=\"tr.title\" class=\"ax-font-semibold ax-text-{{tr.color}}\"\r\n                                            (onClick)=\"vm.executeCommand(tr.name)\">\r\n                                            <ax-prefix>\r\n                                                <ax-icon [icon]=\"tr.icon\"> </ax-icon>\r\n                                            </ax-prefix>\r\n                                        </ax-button-item>\r\n                                    </ng-container>\r\n                                    }\r\n                                </ax-button-item-list>\r\n                            </ax-dropdown-panel>\r\n                        </ax-button>\r\n                        }\r\n                    </div>\r\n                    <!-- Finish Action Menu  -->\r\n                </div>\r\n                <!----- Finish Toolbar  ----->\r\n                <!--------------------------------------------------------------->\r\n                <ax-tabs [look]=\"'classic'\" class=\"ax-mt-4 ax-font-semibold\">\r\n                    <ax-tab-item text=\"Overview\">\r\n                    </ax-tab-item>\r\n                    <ax-tab-item text=\"History\">\r\n                    </ax-tab-item>\r\n                    <ax-tab-item text=\"Comments\">\r\n                    </ax-tab-item>\r\n                </ax-tabs>\r\n            </div>\r\n            <!-- Begin Sections -->\r\n            <div class=\"ax-grid  ax-grid-cols-12     ax-gap-4\">\r\n                @for(section of vm.sections(); track section.name()) {\r\n                <div class=\"ax-card ax-shadow-md ax-mt-2\" [gridLayout]=\"section.layout()\">\r\n                    <ax-form #form>\r\n                        <axp-widgets-container [context]=\"vm.context()\">\r\n                            <div class=\"ax-card-header !ax-py-2 !ax-px-4\">\r\n                                <p>\r\n                                    <span class=\"!ax-text-lg ax-font-semibold \">{{ section.title()\r\n                                        }}</span>\r\n                                    <br>\r\n                                    @if(section.description()) {\r\n                                    <span class=\"ax-text-sm ax-font-normal ax-text-gray-500\">{{ section.description()\r\n                                        }}</span>\r\n                                    }\r\n                                </p>\r\n                                @if(section.editable()) {\r\n                                <ax-button class=\"ax-xs\" color=\"ghost\" [look]=\"'blank'\"\r\n                                    (onClick)=\"vm.executeCommand('modify-entity-section',section)\">\r\n                                    <ax-icon class=\"fa-solid fa-pen ax-text-gray-600\"> </ax-icon>\r\n                                </ax-button>\r\n                                }\r\n                            </div>\r\n                            <div class=\"ax-card-body !ax-grid  !ax-grid-cols-12  !ax-gap-4\">\r\n                                @for(attr of section.props(); track $index) {\r\n                                <div class=\"ax-flex ax-flex-col ax-gap-1\" [gridLayout]=\"attr.layout()\">\r\n                                    <div>\r\n                                        <div>\r\n                                            <span class=\"ax-font-semibold\">{{ attr.title() }}</span>\r\n                                        </div>\r\n                                    </div>\r\n                                    <div class=\"ax-text-neutral-500\">\r\n                                        <axp-widget-renderer [node]=\"attr.node()\"> </axp-widget-renderer>\r\n                                    </div>\r\n                                </div>\r\n                                }\r\n                            </div>\r\n                        </axp-widgets-container>\r\n                    </ax-form>\r\n                </div>\r\n                }\r\n            </div>\r\n            <!-- Finish Sections  -->\r\n            <!--------------------------------------------------------------->\r\n            @if(vm.relatedEntities().length)\r\n            {\r\n            <ax-tabs [look]=\"'default'\" class=\"ax-mt-2 ax-font-semibold\" #tab\r\n                (onActiveTabChanged)=\"handleActiveTabChanged($event)\">\r\n                @for(e of vm.relatedEntities();track $index;let index= $index){\r\n                <ax-tab-item [text]=\"e.title()\" [key]=\"index.toString()\">\r\n                </ax-tab-item>\r\n                }\r\n            </ax-tabs>\r\n            @for(e of vm.relatedEntities();track $index;let index= $index){\r\n            <div [class.ax-hidden]=\"$index!=selectedTabIndex()\">\r\n                <axp-entity-detail-list-view [viewModel]=\"e\"></axp-entity-detail-list-view>\r\n            </div>\r\n            }\r\n            }\r\n\r\n        </div>\r\n    </ax-content>\r\n</ax-drawer-container>"]}
80
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity-master-single-view.component.js","sourceRoot":"","sources":["../../../../../../../../../../libs/platform/themes/default/src/lib/layouts/entity-layouts/entity-master-single-view/entity-master-single-view.component.ts","../../../../../../../../../../libs/platform/themes/default/src/lib/layouts/entity-layouts/entity-master-single-view/entity-master-single-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXActionSheetModule } from '@acorex/components/action-sheet';\r\nimport { AXBreadcrumbsModule } from '@acorex/components/breadcrumbs';\r\nimport { AXButtonModule } from '@acorex/components/button';\r\nimport { AXDecoratorModule } from '@acorex/components/decorators';\r\nimport { AXDialogModule } from '@acorex/components/dialog';\r\nimport { AXDrawerModule } from '@acorex/components/drawer';\r\nimport { AXDropdownModule } from '@acorex/components/dropdown';\r\nimport { AXFormModule } from '@acorex/components/form';\r\nimport { AXLoadingModule } from '@acorex/components/loading';\r\nimport { AXPopoverModule } from '@acorex/components/popover';\r\nimport { AXTabsModule } from '@acorex/components/tabs';\r\nimport { AXPAdminLayoutState, AXPStickyDirective, getChildDrawer, isSmallScreen } from '@acorex/platform/common';\r\nimport { CommonModule } from '@angular/common';\r\nimport { ChangeDetectionStrategy, Component, inject, signal } from '@angular/core';\r\nimport { ActivatedRoute, RouterModule } from '@angular/router';\r\nimport { Store } from '@ngrx/store';\r\nimport { AXPLayoutBuilderModule } from '@acorex/platform/layout/builder';\r\nimport { AXPWidgetsModule } from '@acorex/platform/widgets';\r\nimport { AXPGridLayoutDirective } from '@acorex/platform/common';\r\nimport { AXPEntityDetailListViewComponent } from '../entity-detail-list-view/entity-detail-list-view.component';\r\nimport { AXPEntityMasterSingleViewModel } from '@acorex/platform/layout/entity';\r\n\r\n\r\n@Component({\r\n    templateUrl: './entity-master-single-view.component.html',\r\n    imports: [\r\n        CommonModule,\r\n        RouterModule,\r\n        AXDecoratorModule,\r\n        AXDropdownModule,\r\n        AXPopoverModule,\r\n        AXFormModule,\r\n        AXActionSheetModule,\r\n        AXDrawerModule,\r\n        AXDialogModule,\r\n        AXLoadingModule,\r\n        AXTabsModule,\r\n        AXButtonModule,\r\n        AXBreadcrumbsModule,\r\n        //\r\n        AXPLayoutBuilderModule,\r\n        AXPWidgetsModule,\r\n        AXPStickyDirective,\r\n        AXPGridLayoutDirective,\r\n        //\r\n        AXPEntityDetailListViewComponent\r\n    ],\r\n    standalone: true,\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class AXPEntityMasterSingleViewComponent {\r\n    private activeRoute = inject(ActivatedRoute);\r\n    protected readonly vm = this.activeRoute.snapshot.data['vm'] as AXPEntityMasterSingleViewModel;\r\n    //\r\n    private store = inject(Store<AXPAdminLayoutState>);\r\n    protected isSM = this.store.select(isSmallScreen());\r\n    protected isOpen = this.store.select(getChildDrawer());\r\n\r\n\r\n    protected selectedTabIndex = signal(0);\r\n\r\n    handleActiveTabChanged(e: any) {\r\n        this.selectedTabIndex.set(e.index);\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        this.vm.destroy();\r\n    }\r\n}","<ax-drawer-container>\r\n    <!-- <ax-drawer #drawer location=\"start\" [collapsed]=\"!(isOpen | async)\" [mode]=\" (isSM | async) ? 'overlay' : 'push'\"\r\n      *ngIf=\"loader.hasSections$ | async\" (collapsedChange)=\"handleCollapsedChange($event)\">\r\n      <ax-content class=\"ax-border-e ax-p-6 ax-w-64\">\r\n        <p class=\"ax-text-xl ax-font-bold ax-mb-6\">{{loader.sectionTitle}}</p>\r\n        <ax-tabs look=\"with-line\" location=\"start\">\r\n          @for(tab of (loader.sections$ | async); track tab.name)\r\n          {\r\n          <ax-tab-item [text]=\"tab.title\" [active]=\"isActive(tab)\" (onClick)=\"handleMenuClick($event,tab)\"\r\n            [disabled]=\"editForm.context\">\r\n          </ax-tab-item>\r\n          }\r\n        </ax-tabs>\r\n      </ax-content>\r\n    </ax-drawer> -->\r\n    <ax-content #content class=\"ax-overflow-x-hidden\">\r\n        <div\r\n            class=\"ax-flex ax-flex-col ax-gap-4 ax-min-h-full ax-px-4 ax-pb-4 md:ax-px-6 ax-bg-surface   ax-border-b md:ax-border-0 md:ax-bg-default\">\r\n            <div class=\"ax-flex ax-flex-col ax-pt-4 ax-sticky ax-top-0 ax-z-10 ax-transition-all\" #sticky=\"axpSticky\"\r\n                [axpSticky]=\"'ax-bg-surface ax-px-6 ax-py-3 -ax-mx-6 ax-shadow-xl'\" [stickyOffset]=\"50\"\r\n                [stickyParent]=\"content.getHostElement()\">\r\n                <!-------- Begin Toolbar  -------->\r\n                <div class=\"ax-flex ax-justify-between ax-items-center\">\r\n                    <!-------- Begin Title  -------->\r\n                    <div class=\"ax-flex ax-gap-1 ax-items-center\">\r\n                        <div class=\"ax-flex ax-flex-col ax-gap-2 ax-transition\">\r\n                            <div class=\"ax-text-xl md:ax-text-3xl ax-font-bold\">{{ vm.title()}}</div>\r\n                            @if(vm.description())\r\n                            {\r\n                            <div class=\"ax-text-sm ax-text-neutral-600\" [class.ax-hidden]=\"sticky.isSticky\">{{\r\n                                vm.description() }}</div>\r\n                            }\r\n                            <ax-breadcrumbs class=\"child:ax-font-normal child:ax-text-neutral-400\"\r\n                                [class.ax-hidden]=\"isSM | async\">\r\n                                <ng-template #divider>\r\n                                    <i class=\"fa-solid fa-chevron-right ax-text-xs ax-mx-2\"></i>\r\n                                </ng-template>\r\n                                @for(b of vm.beardcrumbs();track $index;let last=$last)\r\n                                {\r\n                                <ax-breadcrumbs-item [active]=\"last\" [class.!ax-font-semibold]=\"last\"\r\n                                    [class.!ax-text-neutral-600]=\"last\" [routerLink]=\"b.url\">\r\n                                    @if(b.icon)\r\n                                    {\r\n                                    <i [class]=\"b.icon\"></i>\r\n                                    }\r\n                                    {{b.title}}\r\n                                </ax-breadcrumbs-item>\r\n                                }\r\n                            </ax-breadcrumbs>\r\n                        </div>\r\n                    </div>\r\n                    <!-------- Finish Title  -------->\r\n                    <!--------------------------------------------------------------->\r\n                    <!-- Begin Action Menu  -->\r\n                    <div class=\"ax-flex ax-items-center ax-gap-3\">\r\n                        @for(tr of vm.primaryActions();track $index)\r\n                        {\r\n                        <ax-button [text]=\"tr.title\" [color]=\"tr.color\" (onClick)=\"vm.executeCommand(tr.name)\">\r\n                            <ax-prefix>\r\n                                <ax-icon [icon]=\"tr.icon\"> </ax-icon>\r\n                            </ax-prefix>\r\n                        </ax-button>\r\n                        }\r\n                        @if(vm.secondaryActions().length) {\r\n                        <ax-button [text]=\"(isSM | async) ? null : 'Actions'\" color=\"ghost\">\r\n                            <ax-prefix>\r\n                                <i class=\"fa-solid fa-ellipsis-vertical\"></i>\r\n                            </ax-prefix>\r\n                            <ax-dropdown-panel>\r\n                                <ax-button-item-list>\r\n                                    @for(tr of vm.secondaryActions();track $index)\r\n                                    {\r\n                                    <ng-container>\r\n                                        @if(tr.separated)\r\n                                        {\r\n                                        <ax-divider></ax-divider>\r\n                                        }\r\n                                        <ax-button-item [text]=\"tr.title\" class=\"ax-font-semibold ax-text-{{tr.color}}\"\r\n                                            (onClick)=\"vm.executeCommand(tr.name)\">\r\n                                            <ax-prefix>\r\n                                                <ax-icon [icon]=\"tr.icon\"> </ax-icon>\r\n                                            </ax-prefix>\r\n                                        </ax-button-item>\r\n                                    </ng-container>\r\n                                    }\r\n                                </ax-button-item-list>\r\n                            </ax-dropdown-panel>\r\n                        </ax-button>\r\n                        }\r\n                    </div>\r\n                    <!-- Finish Action Menu  -->\r\n                </div>\r\n                <!----- Finish Toolbar  ----->\r\n                <!--------------------------------------------------------------->\r\n                <ax-tabs [look]=\"'classic'\" class=\"ax-mt-4 ax-font-semibold\">\r\n                    <ax-tab-item text=\"Overview\">\r\n                    </ax-tab-item>\r\n                    <ax-tab-item text=\"History\">\r\n                    </ax-tab-item>\r\n                    <ax-tab-item text=\"Comments\">\r\n                    </ax-tab-item>\r\n                </ax-tabs>\r\n            </div>\r\n            <!-- Begin Sections -->\r\n            <div class=\"ax-grid  ax-grid-cols-12     ax-gap-4\">\r\n                @for(section of vm.sections(); track section.name()) {\r\n                <div class=\"ax-card ax-shadow-md ax-mt-2\" [gridLayout]=\"section.layout()\">\r\n                    <ax-form #form>\r\n                        <axp-widgets-container [context]=\"vm.context()\">\r\n                            <div class=\"ax-card-header !ax-py-2 !ax-px-4\">\r\n                                <p>\r\n                                    <span class=\"!ax-text-lg ax-font-semibold \">{{ section.title()\r\n                                        }}</span>\r\n                                    <br>\r\n                                    @if(section.description()) {\r\n                                    <span class=\"ax-text-sm ax-font-normal ax-text-gray-500\">{{ section.description()\r\n                                        }}</span>\r\n                                    }\r\n                                </p>\r\n                                @if(section.editable()) {\r\n                                <ax-button class=\"ax-xs\" color=\"ghost\" [look]=\"'blank'\"\r\n                                    (onClick)=\"vm.executeCommand('modify-entity-section',section)\">\r\n                                    <ax-icon class=\"fa-solid fa-pen ax-text-gray-600\"> </ax-icon>\r\n                                </ax-button>\r\n                                }\r\n                            </div>\r\n                            <div class=\"ax-card-body !ax-grid  !ax-grid-cols-12  !ax-gap-4\">\r\n                                @for(attr of section.props(); track $index) {\r\n                                <div class=\"ax-flex ax-flex-col ax-gap-1\" [gridLayout]=\"attr.layout()\">\r\n                                    <div>\r\n                                        <div>\r\n                                            <span class=\"ax-font-semibold\">{{ attr.title() }}</span>\r\n                                        </div>\r\n                                    </div>\r\n                                    <div class=\"ax-text-neutral-500\">\r\n                                        <axp-widget-renderer [node]=\"attr.node()\"> </axp-widget-renderer>\r\n                                    </div>\r\n                                </div>\r\n                                }\r\n                            </div>\r\n                        </axp-widgets-container>\r\n                    </ax-form>\r\n                </div>\r\n                }\r\n            </div>\r\n            <!-- Finish Sections  -->\r\n            <!--------------------------------------------------------------->\r\n            @if(vm.relatedEntities().length)\r\n            {\r\n            <ax-tabs [look]=\"'default'\" class=\"ax-mt-2 ax-font-semibold\" #tab\r\n                (onActiveTabChanged)=\"handleActiveTabChanged($event)\">\r\n                @for(e of vm.relatedEntities();track $index;let index= $index){\r\n                <ax-tab-item [text]=\"e.title()\" [key]=\"index.toString()\">\r\n                </ax-tab-item>\r\n                }\r\n            </ax-tabs>\r\n            @for(e of vm.relatedEntities();track $index;let index= $index){\r\n            <div [class.ax-hidden]=\"$index!=selectedTabIndex()\">\r\n                <axp-entity-detail-list-view [viewModel]=\"e\"></axp-entity-detail-list-view>\r\n            </div>\r\n            }\r\n            }\r\n\r\n        </div>\r\n    </ax-content>\r\n</ax-drawer-container>"]}