@acorex/modules 20.0.2 → 20.0.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (49) hide show
  1. package/fesm2022/acorex-modules-content-management.mjs +1 -0
  2. package/fesm2022/acorex-modules-content-management.mjs.map +1 -1
  3. package/fesm2022/{acorex-modules-document-management-acorex-modules-document-management-BP-HLvDt.mjs → acorex-modules-document-management-acorex-modules-document-management-ClH75xx1.mjs} +28 -27
  4. package/fesm2022/{acorex-modules-document-management-acorex-modules-document-management-BP-HLvDt.mjs.map → acorex-modules-document-management-acorex-modules-document-management-ClH75xx1.mjs.map} +1 -1
  5. package/fesm2022/{acorex-modules-document-management-attachment-widget.component-DiE1iI_0.mjs → acorex-modules-document-management-attachment-widget.component-B_tjfzIn.mjs} +2 -2
  6. package/fesm2022/{acorex-modules-document-management-attachment-widget.component-DiE1iI_0.mjs.map → acorex-modules-document-management-attachment-widget.component-B_tjfzIn.mjs.map} +1 -1
  7. package/fesm2022/{acorex-modules-document-management-create-folder-dialog.component-Bq7bRA5y.mjs → acorex-modules-document-management-create-folder-dialog.component-DNdRcCAs.mjs} +2 -2
  8. package/fesm2022/{acorex-modules-document-management-create-folder-dialog.component-Bq7bRA5y.mjs.map → acorex-modules-document-management-create-folder-dialog.component-DNdRcCAs.mjs.map} +1 -1
  9. package/fesm2022/{acorex-modules-document-management-details-view.component-C3R3GojY.mjs → acorex-modules-document-management-details-view.component-JsK1UgZh.mjs} +2 -2
  10. package/fesm2022/{acorex-modules-document-management-details-view.component-C3R3GojY.mjs.map → acorex-modules-document-management-details-view.component-JsK1UgZh.mjs.map} +1 -1
  11. package/fesm2022/{acorex-modules-document-management-drive-choose.component-DnzJ7ujZ.mjs → acorex-modules-document-management-drive-choose.component-DJT9oLek.mjs} +2 -2
  12. package/fesm2022/{acorex-modules-document-management-drive-choose.component-DnzJ7ujZ.mjs.map → acorex-modules-document-management-drive-choose.component-DJT9oLek.mjs.map} +1 -1
  13. package/fesm2022/{acorex-modules-document-management-drive.component-BW0gVjML.mjs → acorex-modules-document-management-drive.component-DYxpvUWX.mjs} +2 -2
  14. package/fesm2022/{acorex-modules-document-management-drive.component-BW0gVjML.mjs.map → acorex-modules-document-management-drive.component-DYxpvUWX.mjs.map} +1 -1
  15. package/fesm2022/{acorex-modules-document-management-large-icons-view.component-B02pUo3R.mjs → acorex-modules-document-management-large-icons-view.component-B324V2hL.mjs} +2 -2
  16. package/fesm2022/{acorex-modules-document-management-large-icons-view.component-B02pUo3R.mjs.map → acorex-modules-document-management-large-icons-view.component-B324V2hL.mjs.map} +1 -1
  17. package/fesm2022/{acorex-modules-document-management-large-tiles-view.component-IOgOKZHe.mjs → acorex-modules-document-management-large-tiles-view.component-V5gHyu9X.mjs} +2 -2
  18. package/fesm2022/{acorex-modules-document-management-large-tiles-view.component-IOgOKZHe.mjs.map → acorex-modules-document-management-large-tiles-view.component-V5gHyu9X.mjs.map} +1 -1
  19. package/fesm2022/{acorex-modules-document-management-list-view.component-B1tWiewp.mjs → acorex-modules-document-management-list-view.component-Bm2EH2aT.mjs} +2 -2
  20. package/fesm2022/{acorex-modules-document-management-list-view.component-B1tWiewp.mjs.map → acorex-modules-document-management-list-view.component-Bm2EH2aT.mjs.map} +1 -1
  21. package/fesm2022/{acorex-modules-document-management-meta-choose-popup.component-BcwgdkCu.mjs → acorex-modules-document-management-meta-choose-popup.component-q6mDKrFi.mjs} +56 -49
  22. package/fesm2022/acorex-modules-document-management-meta-choose-popup.component-q6mDKrFi.mjs.map +1 -0
  23. package/fesm2022/{acorex-modules-document-management-permission-definition.provider-BxGnnbvr.mjs → acorex-modules-document-management-permission-definition.provider-DGqVDVLJ.mjs} +2 -2
  24. package/fesm2022/{acorex-modules-document-management-permission-definition.provider-BxGnnbvr.mjs.map → acorex-modules-document-management-permission-definition.provider-DGqVDVLJ.mjs.map} +1 -1
  25. package/fesm2022/{acorex-modules-document-management-rename-node-dialog.component-BtH4ZteD.mjs → acorex-modules-document-management-rename-node-dialog.component-LgpvDguk.mjs} +2 -2
  26. package/fesm2022/{acorex-modules-document-management-rename-node-dialog.component-BtH4ZteD.mjs.map → acorex-modules-document-management-rename-node-dialog.component-LgpvDguk.mjs.map} +1 -1
  27. package/fesm2022/{acorex-modules-document-management-small-icons-view.component-CSZM_GTs.mjs → acorex-modules-document-management-small-icons-view.component-BwFoe1vd.mjs} +2 -2
  28. package/fesm2022/{acorex-modules-document-management-small-icons-view.component-CSZM_GTs.mjs.map → acorex-modules-document-management-small-icons-view.component-BwFoe1vd.mjs.map} +1 -1
  29. package/fesm2022/{acorex-modules-document-management-small-tiles-view.component-CpYgK225.mjs → acorex-modules-document-management-small-tiles-view.component-B5gp0wus.mjs} +2 -2
  30. package/fesm2022/{acorex-modules-document-management-small-tiles-view.component-CpYgK225.mjs.map → acorex-modules-document-management-small-tiles-view.component-B5gp0wus.mjs.map} +1 -1
  31. package/fesm2022/acorex-modules-document-management.mjs +1 -1
  32. package/fesm2022/{acorex-modules-platform-management-acorex-modules-platform-management-D0GgVrM1.mjs → acorex-modules-platform-management-acorex-modules-platform-management-DqpAYmHM.mjs} +33 -5
  33. package/fesm2022/{acorex-modules-platform-management-acorex-modules-platform-management-D0GgVrM1.mjs.map → acorex-modules-platform-management-acorex-modules-platform-management-DqpAYmHM.mjs.map} +1 -1
  34. package/fesm2022/{acorex-modules-platform-management-list-version.component-ZXM2ZJtt.mjs → acorex-modules-platform-management-list-version.component-DidjxkmH.mjs} +2 -2
  35. package/fesm2022/{acorex-modules-platform-management-list-version.component-ZXM2ZJtt.mjs.map → acorex-modules-platform-management-list-version.component-DidjxkmH.mjs.map} +1 -1
  36. package/fesm2022/{acorex-modules-platform-management-settings.provider-D5WKWolF.mjs → acorex-modules-platform-management-settings.provider-DcHKHrSK.mjs} +2 -2
  37. package/fesm2022/{acorex-modules-platform-management-settings.provider-D5WKWolF.mjs.map → acorex-modules-platform-management-settings.provider-DcHKHrSK.mjs.map} +1 -1
  38. package/fesm2022/acorex-modules-platform-management.mjs +1 -1
  39. package/fesm2022/acorex-modules-project-management.mjs +30 -1
  40. package/fesm2022/acorex-modules-project-management.mjs.map +1 -1
  41. package/fesm2022/acorex-modules-workflow-management-task-board.page-R4x5Rq-D.mjs +494 -0
  42. package/fesm2022/acorex-modules-workflow-management-task-board.page-R4x5Rq-D.mjs.map +1 -0
  43. package/fesm2022/acorex-modules-workflow-management.mjs +17 -3
  44. package/fesm2022/acorex-modules-workflow-management.mjs.map +1 -1
  45. package/package.json +1 -1
  46. package/workflow-management/index.d.ts +2 -1
  47. package/fesm2022/acorex-modules-document-management-meta-choose-popup.component-BcwgdkCu.mjs.map +0 -1
  48. package/fesm2022/acorex-modules-workflow-management-task-board.page-BzLr0QnF.mjs +0 -305
  49. package/fesm2022/acorex-modules-workflow-management-task-board.page-BzLr0QnF.mjs.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"file":"acorex-modules-document-management-meta-choose-popup.component-BcwgdkCu.mjs","sources":["../tmp-esm2022/document-management/lib/features/meta-choose-widget/meta-choose-popup/meta-choose-popup.component.js"],"sourcesContent":["import { Component, signal, ViewEncapsulation, viewChild, inject } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { AXBasePageComponent } from '@acorex/components/page';\nimport { AXSearchBoxModule } from '@acorex/components/search-box';\nimport { AXTreeViewModule } from '@acorex/components/tree-view';\nimport { AXDecoratorModule } from '@acorex/components/decorators';\nimport { AXButtonModule } from '@acorex/components/button';\nimport { AXTranslationModule } from '@acorex/core/translation';\nimport { AXMMetaDataDefinitionCategoryService } from '@acorex/modules/platform-management';\nimport * as i0 from \"@angular/core\";\nimport * as i1 from \"@angular/common\";\nimport * as i2 from \"@acorex/components/search-box\";\nimport * as i3 from \"@acorex/components/tree-view\";\nimport * as i4 from \"@acorex/components/decorators\";\nimport * as i5 from \"@acorex/components/button\";\nimport * as i6 from \"@acorex/core/translation\";\nexport class AXPMetaChoosePopupComponent extends AXBasePageComponent {\n constructor() {\n super(...arguments);\n this.categoryService = inject(AXMMetaDataDefinitionCategoryService);\n this.treeRef = viewChild('treeRef');\n /**\n * Holds the complete list of tree items in a flattened structure.\n * This structure makes it easy to:\n * 1) Provide children lazily via `provideLazyTreeView` using `parentId`.\n * 2) Perform search across all levels while still being able to include\n * ancestor nodes of matched items.\n */\n this.treeViewData = signal([]);\n /**\n * Keeps an immutable reference to the original (unfiltered) data so that\n * we can restore the tree when the search box is cleared.\n */\n this.originalTreeData = [];\n this.searchTerm = signal('');\n this.selectedNode = null;\n this.provideLazyTreeView = (selectedItemId) => {\n if (selectedItemId) {\n return Promise.resolve(this.treeViewData().filter((x) => x.parentId === selectedItemId));\n }\n else {\n return Promise.resolve(this.treeViewData().filter((x) => !x.parentId));\n }\n };\n }\n ngOnInit() {\n this.categoryService.getAllWithItems().then((categories) => {\n //#region ---- Helper Functions ----\n const convertCategoryToTreeItem = (category) => {\n const categoryChildren = [\n // Map sub-categories recursively\n ...category.categories.map((c) => convertCategoryToTreeItem(c)),\n // Map items of current category\n ...category.items.map((item) => ({\n id: item.id,\n text: item.name,\n parentId: category.id,\n hasCheckBox: true,\n hasChild: false,\n isSelected: false\n })),\n ];\n return {\n id: category.id,\n text: category.title,\n parentId: category.parentId,\n hasCheckBox: false,\n hasChild: categoryChildren.length > 0,\n children: categoryChildren,\n isSelected: false\n };\n };\n //#endregion\n // Build a flattened list of all categories & items to simplify\n // lazy-loading & search operations.\n const flatList = [];\n const buildTree = (category) => {\n const categoryItem = {\n id: category.id,\n text: category.title,\n parentId: category.parentId,\n hasCheckBox: false,\n hasChild: (category.categories?.length ?? 0) + (category.items?.length ?? 0) > 0,\n isSelected: false\n };\n flatList.push(categoryItem);\n // Recurse into sub-categories\n category.categories.forEach((sub) => buildTree(sub));\n // Push items of current category\n category.items.forEach((item) => {\n flatList.push({\n id: item.id,\n text: item.name,\n parentId: category.id,\n hasCheckBox: true,\n hasChild: false,\n isSelected: false\n });\n });\n };\n categories.forEach((c) => buildTree(c));\n // Persist original data & initialise reactive signal.\n this.originalTreeData = flatList;\n this.treeViewData.set([...flatList]);\n });\n }\n handleNodeClick(e) {\n this.selectedNode = e.data;\n }\n handleSelectClick() {\n if (this.selectedNode) {\n this.close(this.selectedNode);\n }\n else {\n this.close();\n }\n }\n handleCreateNewClick() {\n this.close('create-new');\n }\n handleCloseClick() {\n this.close();\n }\n handleChangeSearchValue(e) {\n const term = (e.value ?? '').trim();\n this.searchTerm.set(term);\n // When search is cleared, simply restore the initial dataset\n if (!term) {\n this.treeViewData.set([...this.originalTreeData]);\n return;\n }\n const loweredTerm = term.toLowerCase();\n // Build a quick lookup map to traverse ancestors efficiently\n const mapById = new Map(this.originalTreeData.map((item) => [item.id, item]));\n // Helper to collect all ancestors of a given node\n const collectAncestors = (node) => {\n const ancestors = [];\n let currentParentId = node.parentId;\n while (currentParentId) {\n const parent = mapById.get(currentParentId);\n if (!parent) {\n break;\n }\n ancestors.push(parent);\n currentParentId = parent.parentId;\n }\n return ancestors;\n };\n // 1) Find all nodes whose text contains the search term\n const matchedNodes = this.originalTreeData.filter((item) => item.text.toLowerCase().includes(loweredTerm));\n // 2) Collect their ancestors to ensure the tree can render correct paths\n const resultSet = new Map();\n matchedNodes.forEach((node) => {\n resultSet.set(node.id, node);\n collectAncestors(node).forEach((ancestor) => resultSet.set(ancestor.id, ancestor));\n });\n this.treeViewData.set(Array.from(resultSet.values()));\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.0.4\", ngImport: i0, type: AXPMetaChoosePopupComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }\n static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: \"17.2.0\", version: \"20.0.4\", type: AXPMetaChoosePopupComponent, isStandalone: true, selector: \"axp-meta-choose-popup\", providers: [], viewQueries: [{ propertyName: \"treeRef\", first: true, predicate: [\"treeRef\"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: \"<div class=\\\"ax-p-4 ax-flex ax-flex-col ax-gap-4 ax-overflow-hidden\\\">\\n <div class=\\\"ax-w-full\\\">\\n <ax-search-box\\n [placeholder]=\\\"('widget.lookup.search' | translate | async)\\\"\\n [value]=\\\"searchTerm()\\\"\\n (onValueChanged)=\\\"handleChangeSearchValue($event)\\\"\\n ><ax-clear-button></ax-clear-button\\n ></ax-search-box>\\n </div>\\n <ax-tree-view\\n class=\\\"ax-h-[50vh]\\\"\\n #treeRef\\n [parentField]=\\\"'parentId'\\\"\\n hasChildField=\\\"hasChild\\\"\\n [items]=\\\"provideLazyTreeView\\\"\\n (onNodeClick)=\\\"handleNodeClick($event)\\\"\\n [selectionMode]=\\\"'multiple'\\\"\\n [hasCheckboxField]=\\\"'isSelected'\\\"\\n >\\n \\n </ax-tree-view>\\n </div>\\n <ax-footer>\\n <ax-suffix>\\n <ax-button look=\\\"solid\\\" [text]=\\\"('close' | translate | async)!\\\" (onClick)=\\\"handleCloseClick()\\\"> </ax-button>\\n <ax-button\\n look=\\\"solid\\\"\\n color=\\\"primary\\\"\\n [text]=\\\"('select' | translate | async)!\\\"\\n (onClick)=\\\"handleSelectClick()\\\"\\n >\\n </ax-button>\\n </ax-suffix>\\n </ax-footer>\", styles: [\"\"], dependencies: [{ kind: \"ngmodule\", type: \n // Angular\n CommonModule }, { kind: \"pipe\", type: i1.AsyncPipe, name: \"async\" }, { kind: \"ngmodule\", type: \n // ACoreX\n AXSearchBoxModule }, { kind: \"component\", type: i2.AXSearchBoxComponent, selector: \"ax-search-box\", inputs: [\"disabled\", \"readonly\", \"tabIndex\", \"placeholder\", \"value\", \"state\", \"name\", \"id\", \"look\", \"class\", \"delayTime\", \"type\"], outputs: [\"valueChange\", \"stateChange\", \"onValueChanged\", \"onBlur\", \"onFocus\", \"readonlyChange\", \"disabledChange\", \"onKeyDown\", \"onKeyUp\", \"onKeyPress\"] }, { kind: \"ngmodule\", type: AXTreeViewModule }, { kind: \"component\", type: i3.AXTreeViewComponent, selector: \"ax-tree-view\", inputs: [\"items\", \"showCheckbox\", \"hasCheckboxField\", \"selectionMode\", \"selectionBehavior\", \"selectionScope\", \"focusNodeEnabled\", \"valueField\", \"textField\", \"visibleField\", \"disableField\", \"hasChildField\", \"selectedField\", \"expandedField\", \"tooltipField\", \"childrenField\", \"activeField\", \"indeterminateField\", \"parentField\", \"iconField\", \"toggleIcons\", \"look\", \"showEmptyNodeMassage\", \"itemTemplate\", \"emptyTemplate\", \"expandOn\"], outputs: [\"onSelectionChanged\", \"onItemSelectedChanged\", \"onNodeClick\", \"onCollapsedChanged\", \"onNodedbClick\"] }, { kind: \"ngmodule\", type: AXDecoratorModule }, { kind: \"component\", type: i4.AXDecoratorClearButtonComponent, selector: \"ax-clear-button\", inputs: [\"icon\"] }, { kind: \"component\", type: i4.AXDecoratorGenericComponent, selector: \"ax-footer, ax-header, ax-content, ax-divider, ax-form-hint, ax-prefix, ax-suffix, ax-text, ax-title, ax-subtitle, ax-placeholder, ax-overlay\" }, { kind: \"ngmodule\", type: AXButtonModule }, { kind: \"component\", type: i5.AXButtonComponent, selector: \"ax-button\", inputs: [\"disabled\", \"size\", \"tabIndex\", \"color\", \"look\", \"text\", \"toggleable\", \"selected\", \"iconOnly\", \"type\", \"loadingText\"], outputs: [\"onBlur\", \"onFocus\", \"onClick\", \"selectedChange\", \"toggleableChange\", \"lookChange\", \"colorChange\", \"disabledChange\", \"loadingTextChange\"] }, { kind: \"ngmodule\", type: AXTranslationModule }, { kind: \"pipe\", type: i6.AXTranslatorPipe, name: \"translate\" }], encapsulation: i0.ViewEncapsulation.None }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.0.4\", ngImport: i0, type: AXPMetaChoosePopupComponent, decorators: [{\n type: Component,\n args: [{ selector: 'axp-meta-choose-popup', imports: [\n // Angular\n CommonModule,\n // ACoreX\n AXSearchBoxModule,\n AXTreeViewModule,\n AXDecoratorModule,\n AXButtonModule,\n AXTranslationModule\n // Platform\n ], encapsulation: ViewEncapsulation.None, providers: [], template: \"<div class=\\\"ax-p-4 ax-flex ax-flex-col ax-gap-4 ax-overflow-hidden\\\">\\n <div class=\\\"ax-w-full\\\">\\n <ax-search-box\\n [placeholder]=\\\"('widget.lookup.search' | translate | async)\\\"\\n [value]=\\\"searchTerm()\\\"\\n (onValueChanged)=\\\"handleChangeSearchValue($event)\\\"\\n ><ax-clear-button></ax-clear-button\\n ></ax-search-box>\\n </div>\\n <ax-tree-view\\n class=\\\"ax-h-[50vh]\\\"\\n #treeRef\\n [parentField]=\\\"'parentId'\\\"\\n hasChildField=\\\"hasChild\\\"\\n [items]=\\\"provideLazyTreeView\\\"\\n (onNodeClick)=\\\"handleNodeClick($event)\\\"\\n [selectionMode]=\\\"'multiple'\\\"\\n [hasCheckboxField]=\\\"'isSelected'\\\"\\n >\\n \\n </ax-tree-view>\\n </div>\\n <ax-footer>\\n <ax-suffix>\\n <ax-button look=\\\"solid\\\" [text]=\\\"('close' | translate | async)!\\\" (onClick)=\\\"handleCloseClick()\\\"> </ax-button>\\n <ax-button\\n look=\\\"solid\\\"\\n color=\\\"primary\\\"\\n [text]=\\\"('select' | translate | async)!\\\"\\n (onClick)=\\\"handleSelectClick()\\\"\\n >\\n </ax-button>\\n </ax-suffix>\\n </ax-footer>\" }]\n }] });\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"meta-choose-popup.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/modules/document-management/src/lib/features/meta-choose-widget/meta-choose-popup/meta-choose-popup.component.ts","../../../../../../../../../libs/modules/document-management/src/lib/features/meta-choose-widget/meta-choose-popup/meta-choose-popup.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, signal, ViewEncapsulation, viewChild, inject } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { AXBasePageComponent } from '@acorex/components/page';\nimport { AXSearchBoxModule } from '@acorex/components/search-box';\nimport { AXTreeViewModule, AXTreeItemClickBaseEvent, AXTreeViewComponent } from '@acorex/components/tree-view';\nimport { AXDecoratorModule } from '@acorex/components/decorators';\nimport { AXButtonModule } from '@acorex/components/button';\nimport { AXTranslationModule } from '@acorex/core/translation';\nimport { AXValueChangedEvent } from '@acorex/cdk/common';\nimport { AXMMetaDataDefinitionCategoryService, AXMMetaDataDefinitionCategoryWithItemsEntityModel, AXMMetaDataDefinitionEntityModel } from '@acorex/modules/platform-management';\n\nexport interface AXPMetaTreeItem {\n    id: string;\n    text: string;\n    icon?: string;\n    parentId?: string;\n    hasChild?: boolean;\n    hasCheckBox?: boolean;\n    [key: string]: any;\n    isSelected : boolean;\n}\n\n@Component({\n    selector:'axp-meta-choose-popup',\n    templateUrl: './meta-choose-popup.component.html',\n    styleUrl: './meta-choose-popup.component.scss',\n    imports: [\n        // Angular\n        CommonModule,\n        // ACoreX\n        AXSearchBoxModule,\n        AXTreeViewModule,\n        AXDecoratorModule,\n        AXButtonModule,\n        AXTranslationModule\n        // Platform\n    ],\n    encapsulation: ViewEncapsulation.None,\n    providers: [\n       \n    ],\n})\nexport class AXPMetaChoosePopupComponent extends AXBasePageComponent {\n\n    protected categoryService = inject(AXMMetaDataDefinitionCategoryService);\n    \n    treeRef = viewChild<AXTreeViewComponent>('treeRef');\n    \n    /**\n     * Holds the complete list of tree items in a flattened structure.\n     * This structure makes it easy to:\n     *  1) Provide children lazily via `provideLazyTreeView` using `parentId`.\n     *  2) Perform search across all levels while still being able to include\n     *     ancestor nodes of matched items.\n     */\n    treeViewData = signal<AXPMetaTreeItem[]>([]);\n\n    /**\n     * Keeps an immutable reference to the original (unfiltered) data so that\n     * we can restore the tree when the search box is cleared.\n     */\n    private originalTreeData: AXPMetaTreeItem[] = [];\n\n    protected searchTerm = signal<string>('');\n    protected selectedNode: AXPMetaTreeItem | null = null;\n\n    override ngOnInit() {\n        this.categoryService.getAllWithItems().then((categories) => {\n\n            //#region ----   Helper Functions   ----\n\n            const convertCategoryToTreeItem = (category: AXMMetaDataDefinitionCategoryWithItemsEntityModel<string>): AXPMetaTreeItem => {\n                const categoryChildren: AXPMetaTreeItem[] = [\n                    // Map sub-categories recursively\n                    ...category.categories.map((c: AXMMetaDataDefinitionCategoryWithItemsEntityModel<string>) => convertCategoryToTreeItem(c)),\n                    // Map items of current category\n                    ...category.items.map((item: AXMMetaDataDefinitionEntityModel) => ({\n                        id: item.id,\n                        text: item.name,\n                        parentId: category.id,\n                        hasCheckBox: true,\n                        hasChild: false,\n                        isSelected : false\n                    })),\n                ];\n\n                return {\n                    id: category.id,\n                    text: category.title,\n                    parentId: category.parentId,\n                    hasCheckBox: false,\n                    hasChild: categoryChildren.length > 0,\n                    children: categoryChildren,\n                    isSelected : false\n                };\n            };\n\n            //#endregion\n\n            // Build a flattened list of all categories & items to simplify\n            // lazy-loading & search operations.\n            const flatList: AXPMetaTreeItem[] = [];\n\n            const buildTree = (category: AXMMetaDataDefinitionCategoryWithItemsEntityModel<string>): void => {\n                const categoryItem: AXPMetaTreeItem = {\n                    id: category.id,\n                    text: category.title,\n                    parentId: category.parentId,\n                    hasCheckBox: false,\n                    hasChild: (category.categories?.length ?? 0) + (category.items?.length ?? 0) > 0,\n                    isSelected : false\n                };\n\n                flatList.push(categoryItem);\n\n                // Recurse into sub-categories\n                category.categories.forEach((sub) => buildTree(sub));\n\n                // Push items of current category\n                category.items.forEach((item) => {\n                    flatList.push({\n                        id: item.id,\n                        text: item.name,\n                        parentId: category.id,\n                        hasCheckBox: true,\n                        hasChild: false,\n                        isSelected : false\n                    });\n                });\n            };\n\n            categories.forEach((c) => buildTree(c));\n\n            // Persist original data & initialise reactive signal.\n            this.originalTreeData = flatList;\n            this.treeViewData.set([...flatList]);\n        });\n        \n    }\n\n    provideLazyTreeView = (selectedItemId?: string | number): Promise<AXPMetaTreeItem[]> => {\n        if (selectedItemId) {\n            return Promise.resolve(\n                this.treeViewData().filter((x) => x.parentId === selectedItemId)\n            );\n        } else {\n            return Promise.resolve(\n                this.treeViewData().filter((x) => !x.parentId)\n            );\n        }\n    };\n\n    protected handleNodeClick(e: AXTreeItemClickBaseEvent) {\n        this.selectedNode = e.data as AXPMetaTreeItem;\n    }\n\n    protected handleSelectClick() {\n        if (this.selectedNode) {\n            this.close(this.selectedNode);\n        } else {\n            this.close();\n        }\n    }\n\n    protected handleCreateNewClick() {\n        this.close('create-new');\n    }\n\n    protected handleCloseClick() {\n        this.close();\n    }\n\n    protected handleChangeSearchValue(e: AXValueChangedEvent) {\n        const term = (e.value ?? '').trim();\n        this.searchTerm.set(term);\n\n        // When search is cleared, simply restore the initial dataset\n        if (!term) {\n            this.treeViewData.set([...this.originalTreeData]);\n            return;\n        }\n\n        const loweredTerm = term.toLowerCase();\n\n        // Build a quick lookup map to traverse ancestors efficiently\n        const mapById = new Map<string, AXPMetaTreeItem>(\n            this.originalTreeData.map((item) => [item.id, item])\n        );\n\n        // Helper to collect all ancestors of a given node\n        const collectAncestors = (node: AXPMetaTreeItem): AXPMetaTreeItem[] => {\n            const ancestors: AXPMetaTreeItem[] = [];\n            let currentParentId = node.parentId;\n            while (currentParentId) {\n                const parent = mapById.get(currentParentId);\n                if (!parent) {\n                    break;\n                }\n                ancestors.push(parent);\n                currentParentId = parent.parentId;\n            }\n            return ancestors;\n        };\n\n        // 1) Find all nodes whose text contains the search term\n        const matchedNodes = this.originalTreeData.filter((item) =>\n            item.text.toLowerCase().includes(loweredTerm)\n        );\n\n        // 2) Collect their ancestors to ensure the tree can render correct paths\n        const resultSet = new Map<string, AXPMetaTreeItem>();\n        matchedNodes.forEach((node) => {\n            resultSet.set(node.id, node);\n            collectAncestors(node).forEach((ancestor) => resultSet.set(ancestor.id, ancestor));\n        });\n\n        this.treeViewData.set(Array.from(resultSet.values()));\n    }\n}\n","<div class=\"ax-p-4 ax-flex ax-flex-col ax-gap-4  ax-overflow-hidden\">\n      <div class=\"ax-w-full\">\n        <ax-search-box\n          [placeholder]=\"('widget.lookup.search' | translate | async)\"\n          [value]=\"searchTerm()\"\n          (onValueChanged)=\"handleChangeSearchValue($event)\"\n          ><ax-clear-button></ax-clear-button\n        ></ax-search-box>\n      </div>\n    <ax-tree-view\n      class=\"ax-h-[50vh]\"\n      #treeRef\n      [parentField]=\"'parentId'\"\n      hasChildField=\"hasChild\"\n      [items]=\"provideLazyTreeView\"\n      (onNodeClick)=\"handleNodeClick($event)\"\n      [selectionMode]=\"'multiple'\"\n      [hasCheckboxField]=\"'isSelected'\"\n    >\n      \n    </ax-tree-view>\n  </div>\n  <ax-footer>\n    <ax-suffix>\n      <ax-button look=\"solid\" [text]=\"('close' | translate | async)!\" (onClick)=\"handleCloseClick()\"> </ax-button>\n      <ax-button\n        look=\"solid\"\n        color=\"primary\"\n        [text]=\"('select' | translate | async)!\"\n        (onClick)=\"handleSelectClick()\"\n      >\n      </ax-button>\n    </ax-suffix>\n  </ax-footer>"]}"],"names":["i2","i4","i5","i6"],"mappings":"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"}
@@ -1,305 +0,0 @@
1
- import { AXBadgeModule } from '@acorex/components/badge';
2
- import { AXBreadcrumbsModule } from '@acorex/components/breadcrumbs';
3
- import * as i4 from '@acorex/components/button';
4
- import { AXButtonModule } from '@acorex/components/button';
5
- import { AXCalendarComponent } from '@acorex/components/calendar';
6
- import * as i6 from '@acorex/components/decorators';
7
- import { AXDecoratorModule } from '@acorex/components/decorators';
8
- import { AXDropdownPanelComponent } from '@acorex/components/dropdown';
9
- import { AXDropdownButtonModule } from '@acorex/components/dropdown-button';
10
- import { AXLoadingModule } from '@acorex/components/loading';
11
- import * as i3 from '@acorex/components/menu';
12
- import { AXMenuModule } from '@acorex/components/menu';
13
- import * as i7 from '@acorex/components/popover';
14
- import { AXPopoverModule } from '@acorex/components/popover';
15
- import { AXLocaleService } from '@acorex/core/locale';
16
- import * as i5 from '@acorex/core/translation';
17
- import { AXTranslationModule } from '@acorex/core/translation';
18
- import { AXPThemeLayoutBlockComponent } from '@acorex/platform/layout/components';
19
- import { AXPPageLayoutBaseComponent, AXPPageLayoutComponent, AXPPageLayoutBase } from '@acorex/platform/layout/views';
20
- import * as i2 from '@angular/common';
21
- import { CommonModule } from '@angular/common';
22
- import * as i0 from '@angular/core';
23
- import { computed, inject, viewChild, input, model, output, ViewEncapsulation, ChangeDetectionStrategy, Component, signal } from '@angular/core';
24
- import * as i1 from '@angular/forms';
25
- import { FormsModule } from '@angular/forms';
26
- import { RouterModule } from '@angular/router';
27
- import { AXPTaskBoardService } from './acorex-modules-workflow-management.mjs';
28
- import { AXPSettingService } from '@acorex/platform/common';
29
- import { AXPPlatformScope } from '@acorex/platform/core';
30
- import { signalStore, withState, withComputed, withMethods, patchState } from '@ngrx/signals';
31
- import { AXSchedulerComponent } from '@acorex/components/scheduler';
32
-
33
- const config = {
34
- i18n: 'workflow-management',
35
- };
36
- const RootConfig = {
37
- config,
38
- module: {
39
- module: 'WorkflowManagement',
40
- name: 'WorkflowManagement',
41
- title: `t('module-name', {scope:"${config.i18n}"})`,
42
- icon: 'fa-light fa-clipboard-list-check',
43
- },
44
- };
45
-
46
- var AXMTaskBoardSettings;
47
- (function (AXMTaskBoardSettings) {
48
- AXMTaskBoardSettings["CalendarViewMode"] = "taskboard.calendar.viewMode";
49
- AXMTaskBoardSettings["CurrentDate"] = "taskboard.calendar.currentDate";
50
- AXMTaskBoardSettings["SelectedTaskTypeFilter"] = "taskboard.filter.selectedTaskType";
51
- })(AXMTaskBoardSettings || (AXMTaskBoardSettings = {}));
52
-
53
- const AXMTaskBoardViewModel = signalStore({ providedIn: 'root' }, withState(() => ({
54
- isLoading: true, // Start with loading true until initialized
55
- calendarViewMode: 'month', // Default value
56
- currentDate: new Date(), // Default to today
57
- selectedTaskTypeName: null, // Store the name/ID of the task type for persistence
58
- taskTypes: [],
59
- })), withComputed((store) => ({
60
- // Computed property to get the actual AXPWorkflowTaskProvider object
61
- selectedTaskType: computed(() => {
62
- const name = store.selectedTaskTypeName();
63
- if (!name) {
64
- return null;
65
- }
66
- return store.taskTypes().find((tt) => tt.name === name) || null;
67
- }),
68
- // Example computed (you can add more as needed):
69
- // isMonthView: computed(() => store.calendarViewMode() === 'month'),
70
- })), withMethods((store, settingService = inject(AXPSettingService), // Inject the main service
71
- taskBoardService = inject(AXPTaskBoardService)) => ({
72
- async initialize() {
73
- patchState(store, { isLoading: true });
74
- const userScopedSettings = settingService.scope(AXPPlatformScope.User); // Get user scope once
75
- try {
76
- // 1. Load Task Types first
77
- const taskTypes = await taskBoardService.getTaskTypes();
78
- patchState(store, { taskTypes });
79
- // 2. Load Persisted Settings individually
80
- const [savedViewMode, savedDateString, savedTaskTypeName] = await Promise.all([
81
- userScopedSettings.get(AXMTaskBoardSettings.CalendarViewMode),
82
- userScopedSettings.get(AXMTaskBoardSettings.CurrentDate),
83
- userScopedSettings.get(AXMTaskBoardSettings.SelectedTaskTypeFilter),
84
- ]);
85
- patchState(store, {
86
- calendarViewMode: savedViewMode || 'month', // Fallback to default
87
- currentDate: savedDateString ? new Date(savedDateString) : new Date(), // Parse stored date string
88
- selectedTaskTypeName: savedTaskTypeName || null, // Load persisted task type name
89
- isLoading: false,
90
- });
91
- }
92
- catch (error) {
93
- console.error('Error initializing TaskBoard ViewModel:', error);
94
- // Fallback to defaults on error to ensure the app is usable
95
- patchState(store, {
96
- calendarViewMode: 'month',
97
- currentDate: new Date(),
98
- selectedTaskTypeName: null,
99
- taskTypes: store.taskTypes(), // Retain loaded task types if any, or empty if error was before taskTypes load
100
- isLoading: false,
101
- });
102
- }
103
- },
104
- setCalendarViewMode(mode) {
105
- patchState(store, { calendarViewMode: mode });
106
- settingService
107
- .scope(AXPPlatformScope.User)
108
- .set(AXMTaskBoardSettings.CalendarViewMode, mode)
109
- .catch((error) => console.error('Error saving calendar view mode:', error));
110
- },
111
- setCurrentDate(date) {
112
- patchState(store, { currentDate: new Date(date) }); // Ensure it's a new Date object
113
- settingService
114
- .scope(AXPPlatformScope.User)
115
- .set(AXMTaskBoardSettings.CurrentDate, date.toISOString()) // Store as ISO string
116
- .catch((error) => console.error('Error saving current date:', error));
117
- },
118
- setSelectedTaskTypeProvider(taskType) {
119
- const taskTypeName = taskType ? taskType.name : null;
120
- patchState(store, { selectedTaskTypeName: taskTypeName });
121
- settingService
122
- .scope(AXPPlatformScope.User)
123
- .set(AXMTaskBoardSettings.SelectedTaskTypeFilter, taskTypeName)
124
- .catch((error) => console.error('Error saving selected task type filter:', error));
125
- },
126
- })));
127
-
128
- /**
129
- * Component for displaying and interacting with an organizational chart.
130
- */
131
- class AXMTaskBoardCalendarViewComponent {
132
- constructor() {
133
- this.taskBoardService = inject(AXPTaskBoardService);
134
- this.schedulerComponent = viewChild(AXSchedulerComponent);
135
- this.startingDate = input(new Date());
136
- this.selectedView = model('day');
137
- this.dataSource = input.required();
138
- this.onTaskChanged = output();
139
- this.onMonthSlotDblClicked = output();
140
- this.component = output();
141
- this.onTaskRightClick = output();
142
- }
143
- ngAfterViewInit() {
144
- if (this.schedulerComponent()) {
145
- this.component.emit(this.schedulerComponent());
146
- }
147
- }
148
- onTaskDrop(event) {
149
- this.taskBoardService
150
- .updateTask(event.appointment, {
151
- from: event.slot.startDate.date,
152
- end: event.slot.endDate.date,
153
- })
154
- .then((task) => {
155
- this.onTaskChanged.emit(task);
156
- this.schedulerComponent()?.refresh([task]);
157
- });
158
- }
159
- onTaskRightClickHandler(event) {
160
- this.onTaskRightClick.emit(event);
161
- }
162
- onSlotDblClicked(event) {
163
- if (event.sender.selectedView() === 'month') {
164
- this.onMonthSlotDblClicked.emit(event.slot.startDate.date);
165
- }
166
- }
167
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.4", ngImport: i0, type: AXMTaskBoardCalendarViewComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
168
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "20.0.4", type: AXMTaskBoardCalendarViewComponent, isStandalone: true, selector: "axm-task-board-calendar-view", inputs: { startingDate: { classPropertyName: "startingDate", publicName: "startingDate", isSignal: true, isRequired: false, transformFunction: null }, selectedView: { classPropertyName: "selectedView", publicName: "selectedView", isSignal: true, isRequired: false, transformFunction: null }, dataSource: { classPropertyName: "dataSource", publicName: "dataSource", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { selectedView: "selectedViewChange", onTaskChanged: "onTaskChanged", onMonthSlotDblClicked: "onMonthSlotDblClicked", component: "component", onTaskRightClick: "onTaskRightClick" }, viewQueries: [{ propertyName: "schedulerComponent", first: true, predicate: AXSchedulerComponent, descendants: true, isSignal: true }], ngImport: i0, template: "<ax-scheduler\n [hasHeader]=\"false\"\n [dataSource]=\"dataSource()\"\n [startingDate]=\"startingDate()\"\n [selectedView]=\"selectedView()\"\n (onAppointmentDrop)=\"onTaskDrop($event)\"\n (onSlotDblClicked)=\"onSlotDblClicked($event)\"\n (onAppointmentRightClick)=\"onTaskRightClickHandler($event)\"\n></ax-scheduler>\n", styles: ["ax-scheduler{line-height:1.5;background-color:rgba(var(--ax-sys-color-lightest-surface))!important}\n"], dependencies: [{ kind: "component", type: AXSchedulerComponent, selector: "ax-scheduler", inputs: ["calendar", "startingDate", "endDayHour", "startDayHour", "hasHeader", "readonly", "draggable", "allowFullScreen", "multiDayViewDaysCount", "dataSource", "firstDayOfWeek", "views", "selectedView"], outputs: ["selectedViewChange", "onDataLoaded", "onRangeChanged", "onSlotClicked", "onSlotDblClicked", "onSlotRightClick", "onAppointmentDrop", "onAppointmentClicked", "onAppointmentDblClicked", "onAppointmentRightClick"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
169
- }
170
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.4", ngImport: i0, type: AXMTaskBoardCalendarViewComponent, decorators: [{
171
- type: Component,
172
- args: [{ selector: 'axm-task-board-calendar-view', imports: [AXSchedulerComponent], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<ax-scheduler\n [hasHeader]=\"false\"\n [dataSource]=\"dataSource()\"\n [startingDate]=\"startingDate()\"\n [selectedView]=\"selectedView()\"\n (onAppointmentDrop)=\"onTaskDrop($event)\"\n (onSlotDblClicked)=\"onSlotDblClicked($event)\"\n (onAppointmentRightClick)=\"onTaskRightClickHandler($event)\"\n></ax-scheduler>\n", styles: ["ax-scheduler{line-height:1.5;background-color:rgba(var(--ax-sys-color-lightest-surface))!important}\n"] }]
173
- }] });
174
-
175
- /**
176
- * Component for displaying and interacting with an organizational chart.
177
- */
178
- class AXMTaskBoardPage extends AXPPageLayoutBaseComponent {
179
- constructor() {
180
- super(...arguments);
181
- this.rootConfig = RootConfig;
182
- this.localeService = inject(AXLocaleService);
183
- this.taskBoardService = inject(AXPTaskBoardService);
184
- this.vm = inject(AXMTaskBoardViewModel);
185
- this.currentTask = signal(null);
186
- this.schedulerComponent = signal(null);
187
- this.viewsItems = signal([
188
- { key: 'day', text: 'daily', icon: 'fa-light fa-calendar-day' },
189
- { key: 'week', text: 'weekly', icon: 'fa-light fa-calendar-week' },
190
- { key: 'month', text: 'monthly', icon: 'fa-light fa-calendar-alt' },
191
- { key: 'agenda', text: 'agenda', icon: 'fa-light fa-calendar-range' },
192
- ]);
193
- this.calendarType = computed(() => this.localeService.activeProfile().calendar.system);
194
- this.contextMenu = viewChild('rootContextMenu');
195
- this.selectedViewMode = computed(() => this.viewsItems().find((item) => item.key === this.vm.calendarViewMode()) || this.viewsItems()[0]);
196
- this.dataSource = (filter) => {
197
- const taskTypeProvider = this.vm.selectedTaskType();
198
- const types = taskTypeProvider ? [taskTypeProvider.name] : undefined;
199
- return this.taskBoardService.getTasks({ ...filter, types });
200
- };
201
- }
202
- async ngOnInit() {
203
- await super.ngOnInit();
204
- await this.vm.initialize();
205
- }
206
- async getPageTitle() {
207
- return await this.translateService.translateAsync('task-board.page-title', { scope: this.rootConfig.config.i18n });
208
- }
209
- async getPageBreadcrumbs() {
210
- return [
211
- {
212
- title: await this.translateService.translateAsync('root-menu', { scope: this.rootConfig.config.i18n }),
213
- },
214
- ];
215
- }
216
- schedulerComponentChanged(component) {
217
- this.schedulerComponent.set(component);
218
- }
219
- handleContextMenuOnOpening(event) {
220
- for (const item of this.currentTask()?.data?.actions || []) {
221
- event.items.push({
222
- text: item.title,
223
- icon: item.icon,
224
- data: {
225
- command: item.command,
226
- },
227
- });
228
- }
229
- }
230
- handleTaskRightClick(event) {
231
- this.currentTask.set(event.appointment);
232
- const x = event.nativeEvent.clientX;
233
- const y = event.nativeEvent.clientY;
234
- const element = event.sender.nativeElement;
235
- this.contextMenu()?.showAt({ x, y }, element);
236
- }
237
- handleMonthSlotDblClicked(date) {
238
- this.vm.setCurrentDate(date);
239
- this.vm.setCalendarViewMode('day');
240
- }
241
- handleCalendarViewChange(view) {
242
- this.vm.setCalendarViewMode(view);
243
- }
244
- handleSelectedTaskTypeChange(taskType) {
245
- this.vm.setSelectedTaskTypeProvider(taskType);
246
- this.schedulerComponent()?.refresh();
247
- }
248
- handleSchedulerDateChanged(event) {
249
- if (this.vm.isLoading()) {
250
- return;
251
- }
252
- const newDate = event.value;
253
- const currentDateInVm = this.vm.currentDate();
254
- const dateToSet = newDate || new Date();
255
- if (!currentDateInVm || currentDateInVm.getTime() !== dateToSet.getTime()) {
256
- this.vm.setCurrentDate(dateToSet);
257
- }
258
- }
259
- handleContextMenuItemClick(event) {
260
- this.taskBoardService.executeCommand(event.item.data?.command, this.currentTask()?.data?.provider ?? '');
261
- }
262
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.4", ngImport: i0, type: AXMTaskBoardPage, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
263
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.0.4", type: AXMTaskBoardPage, isStandalone: true, selector: "ng-component", providers: [
264
- {
265
- provide: AXPPageLayoutBase,
266
- useExisting: AXMTaskBoardPage,
267
- },
268
- ], viewQueries: [{ propertyName: "contextMenu", first: true, predicate: ["rootContextMenu"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<axp-page-layout *translate=\"let t\">\n <axp-page-toolbar>\n <axp-layout-prefix>\n <ax-button\n [text]=\"t(vm.selectedTaskType()?.title || 'task-board.all', { scope: rootConfig.config.i18n }) | async\"\n >\n <ax-prefix><ax-icon icon=\"fa-light {{vm.selectedTaskType()?.icon || 'fa-tasks'}}\"></ax-icon></ax-prefix>\n <ax-dropdown-panel>\n <ax-button-item-list class=\"ax-p-2\">\n <ax-button-item\n (onClick)=\"handleSelectedTaskTypeChange(null)\"\n [text]=\"(t('task-board.all', { scope: rootConfig.config.i18n }) | async)!\"\n >\n <ax-prefix><ax-icon icon=\"fa-light fa-tasks\"></ax-icon></ax-prefix>\n </ax-button-item>\n @for(item of vm.taskTypes(); track item.name) {\n <ax-button-item\n (onClick)=\"handleSelectedTaskTypeChange(item)\"\n [text]=\"(t(item.title, { scope: rootConfig.config.i18n }) | async)!\"\n >\n <ax-prefix><ax-icon icon=\"fa-light {{ item.icon }}\"></ax-icon></ax-prefix>\n </ax-button-item>\n }\n </ax-button-item-list>\n </ax-dropdown-panel>\n </ax-button>\n\n <div class=\"ax-scheduler-header\">\n <ax-button look=\"blank\" (onClick)=\"schedulerComponent()?.prevClick()\">\n <ax-icon class=\"ax-icon ax-text-xl ax-icon-chevron-left arrow-icon\"></ax-icon>\n </ax-button>\n <ax-button look=\"blank\" [text]=\"schedulerComponent()?.currentDateText()\" #date></ax-button>\n <ax-button look=\"blank\" (onClick)=\"schedulerComponent()?.nextClick()\">\n <ax-icon class=\"ax-icon ax-text-xl ax-icon-chevron-right arrow-icon\"></ax-icon>\n </ax-button>\n <ax-popover [target]=\"date\" [placement]=\"'bottom'\">\n <div class=\"ax-overlay-pane\">\n <ax-calendar\n [type]=\"calendarType()\"\n [ngModel]=\"vm.currentDate()\"\n [depth]=\"schedulerComponent()?.calendarDepth()\"\n (onValueChanged)=\"handleSchedulerDateChanged($event)\"\n ></ax-calendar>\n </div>\n </ax-popover>\n </div>\n </axp-layout-prefix>\n <axp-layout-suffix>\n <ax-button>\n <ax-icon icon=\"fa-light {{ selectedViewMode().icon }}\"></ax-icon>\n <ax-dropdown-panel>\n <ax-button-item-list>\n @for(item of viewsItems(); track item.key) {\n <ax-button-item\n [text]=\"(t('dateTime.duration.' + item.text, { scope: 'common' }) | async)!\"\n [selected]=\"vm.calendarViewMode() === item.key\"\n (onClick)=\"handleCalendarViewChange(item.key)\"\n >\n <ax-prefix>\n <ax-icon icon=\"fa-light {{ item.icon }}\"></ax-icon>\n </ax-prefix>\n </ax-button-item>\n @if(item.break) {\n <ax-divider></ax-divider>\n } }\n </ax-button-item-list>\n </ax-dropdown-panel>\n </ax-button>\n </axp-layout-suffix>\n </axp-page-toolbar>\n <axp-page-content class=\"ax-overflow-hidden\">\n <axm-task-board-calendar-view\n class=\"axp-scheduler-container\"\n [dataSource]=\"dataSource\"\n [startingDate]=\"vm.currentDate()\"\n [selectedView]=\"vm.calendarViewMode()\"\n (component)=\"schedulerComponentChanged($event)\"\n (onTaskRightClick)=\"handleTaskRightClick($event)\"\n (onMonthSlotDblClicked)=\"handleMonthSlotDblClicked($event)\"\n ></axm-task-board-calendar-view>\n <ax-context-menu\n #rootContextMenu\n [closeOn]=\"'leave'\"\n [orientation]=\"'vertical'\"\n (onOpening)=\"handleContextMenuOnOpening($event)\"\n (onItemClick)=\"handleContextMenuItemClick($event)\"\n >\n </ax-context-menu>\n </axp-page-content>\n</axp-page-layout>\n", styles: ["axm-task-board-calendar-view{height:100%}html[dir=rtl] axp-page-layout axp-page-toolbar axp-layout-prefix .ax-scheduler-header .arrow-icon:before{-moz-transform:scale(-1,1);-webkit-transform:scale(-1,1);-o-transform:scale(-1,1);-ms-transform:scale(-1,1);transform:scaleX(-1)}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "ngmodule", type: RouterModule }, { kind: "ngmodule", type:
269
- //
270
- AXMenuModule }, { kind: "component", type: i3.AXContextMenuComponent, selector: "ax-context-menu", inputs: ["orientation", "openOn", "closeOn", "items", "target"], outputs: ["onItemClick", "onOpening"] }, { kind: "ngmodule", type: AXButtonModule }, { kind: "component", type: i4.AXButtonComponent, selector: "ax-button", inputs: ["disabled", "size", "tabIndex", "color", "look", "text", "toggleable", "selected", "iconOnly", "type", "loadingText"], outputs: ["onBlur", "onFocus", "onClick", "selectedChange", "toggleableChange", "lookChange", "colorChange", "disabledChange", "loadingTextChange"] }, { kind: "component", type: i4.AXButtonItemComponent, selector: "ax-button-item", inputs: ["color", "disabled", "text", "selected", "divided", "data", "name"], outputs: ["onClick", "onFocus", "onBlur", "disabledChange"] }, { kind: "component", type: i4.AXButtonItemListComponent, selector: "ax-button-item-list", inputs: ["items"], outputs: ["onItemClick"] }, { kind: "ngmodule", type: AXDropdownButtonModule }, { kind: "ngmodule", type: AXTranslationModule }, { kind: "directive", type: i5.AXTranslatorDirective, selector: "[translate]" }, { kind: "ngmodule", type: AXDecoratorModule }, { kind: "component", type: i6.AXDecoratorIconComponent, selector: "ax-icon", 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-subtitle, ax-placeholder, ax-overlay" }, { kind: "ngmodule", type: AXLoadingModule }, { kind: "ngmodule", type: AXBreadcrumbsModule }, { kind: "ngmodule", type: AXBadgeModule }, { kind: "component", type:
271
- //
272
- AXPThemeLayoutBlockComponent, selector: " axp-page-content, axp-page-footer-container, axp-page-footer, axp-page-header, axp-page-header-container, axp-page-toolbar, axp-layout-content, axp-layout-page-content, axp-layout-sections, axp-layout-body, axp-layout-page-body, axp-layout-prefix, axp-layout-suffix, axp-layout-title-bar, axp-layout-title, axp-layout-title-actions, axp-layout-nav-button, axp-layout-description, axp-layout-breadcrumbs, axp-layout-list-action, " }, { kind: "component", type: AXPPageLayoutComponent, selector: "axp-page-layout" }, { kind: "component", type: AXMTaskBoardCalendarViewComponent, selector: "axm-task-board-calendar-view", inputs: ["startingDate", "selectedView", "dataSource"], outputs: ["selectedViewChange", "onTaskChanged", "onMonthSlotDblClicked", "component", "onTaskRightClick"] }, { kind: "component", type: AXDropdownPanelComponent, selector: "ax-dropdown-panel", inputs: ["isOpen", "fitParent", "dropdownWidth", "position", "placement", "_target", "adaptivityEnabled"], outputs: ["onOpened", "onClosed"] }, { kind: "ngmodule", type: AXPopoverModule }, { kind: "component", type: i7.AXPopoverComponent, selector: "ax-popover", inputs: ["offsetX", "offsetY", "target", "placement", "content", "openOn", "closeOn", "hasBackdrop", "openAfter", "closeAfter", "backdropClass", "panelClass", "adaptivityEnabled"], outputs: ["onOpened", "onClosed"] }, { kind: "component", type: AXCalendarComponent, selector: "ax-calendar", inputs: ["rtl", "readonly", "value", "name", "disabled", "depth", "activeView", "minValue", "maxValue", "disabledDates", "holidayDates", "type", "cellTemplate", "cellClass", "showNavigation", "count", "id"], outputs: ["onOptionChanged", "valueChange", "onValueChanged", "minValueChange", "maxValueChange", "onBlur", "onFocus", "depthChange", "typeChange", "activeViewChange", "disabledDatesChange", "holidayDatesChange", "onNavigate", "onSlotClick", "countChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
273
- }
274
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.4", ngImport: i0, type: AXMTaskBoardPage, decorators: [{
275
- type: Component,
276
- args: [{ imports: [
277
- FormsModule,
278
- CommonModule,
279
- RouterModule,
280
- //
281
- AXMenuModule,
282
- AXButtonModule,
283
- AXDropdownButtonModule,
284
- AXTranslationModule,
285
- AXDecoratorModule,
286
- AXLoadingModule,
287
- AXBreadcrumbsModule,
288
- AXBadgeModule,
289
- //
290
- AXPThemeLayoutBlockComponent,
291
- AXPPageLayoutComponent,
292
- AXMTaskBoardCalendarViewComponent,
293
- AXDropdownPanelComponent,
294
- AXPopoverModule,
295
- AXCalendarComponent,
296
- ], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, providers: [
297
- {
298
- provide: AXPPageLayoutBase,
299
- useExisting: AXMTaskBoardPage,
300
- },
301
- ], template: "<axp-page-layout *translate=\"let t\">\n <axp-page-toolbar>\n <axp-layout-prefix>\n <ax-button\n [text]=\"t(vm.selectedTaskType()?.title || 'task-board.all', { scope: rootConfig.config.i18n }) | async\"\n >\n <ax-prefix><ax-icon icon=\"fa-light {{vm.selectedTaskType()?.icon || 'fa-tasks'}}\"></ax-icon></ax-prefix>\n <ax-dropdown-panel>\n <ax-button-item-list class=\"ax-p-2\">\n <ax-button-item\n (onClick)=\"handleSelectedTaskTypeChange(null)\"\n [text]=\"(t('task-board.all', { scope: rootConfig.config.i18n }) | async)!\"\n >\n <ax-prefix><ax-icon icon=\"fa-light fa-tasks\"></ax-icon></ax-prefix>\n </ax-button-item>\n @for(item of vm.taskTypes(); track item.name) {\n <ax-button-item\n (onClick)=\"handleSelectedTaskTypeChange(item)\"\n [text]=\"(t(item.title, { scope: rootConfig.config.i18n }) | async)!\"\n >\n <ax-prefix><ax-icon icon=\"fa-light {{ item.icon }}\"></ax-icon></ax-prefix>\n </ax-button-item>\n }\n </ax-button-item-list>\n </ax-dropdown-panel>\n </ax-button>\n\n <div class=\"ax-scheduler-header\">\n <ax-button look=\"blank\" (onClick)=\"schedulerComponent()?.prevClick()\">\n <ax-icon class=\"ax-icon ax-text-xl ax-icon-chevron-left arrow-icon\"></ax-icon>\n </ax-button>\n <ax-button look=\"blank\" [text]=\"schedulerComponent()?.currentDateText()\" #date></ax-button>\n <ax-button look=\"blank\" (onClick)=\"schedulerComponent()?.nextClick()\">\n <ax-icon class=\"ax-icon ax-text-xl ax-icon-chevron-right arrow-icon\"></ax-icon>\n </ax-button>\n <ax-popover [target]=\"date\" [placement]=\"'bottom'\">\n <div class=\"ax-overlay-pane\">\n <ax-calendar\n [type]=\"calendarType()\"\n [ngModel]=\"vm.currentDate()\"\n [depth]=\"schedulerComponent()?.calendarDepth()\"\n (onValueChanged)=\"handleSchedulerDateChanged($event)\"\n ></ax-calendar>\n </div>\n </ax-popover>\n </div>\n </axp-layout-prefix>\n <axp-layout-suffix>\n <ax-button>\n <ax-icon icon=\"fa-light {{ selectedViewMode().icon }}\"></ax-icon>\n <ax-dropdown-panel>\n <ax-button-item-list>\n @for(item of viewsItems(); track item.key) {\n <ax-button-item\n [text]=\"(t('dateTime.duration.' + item.text, { scope: 'common' }) | async)!\"\n [selected]=\"vm.calendarViewMode() === item.key\"\n (onClick)=\"handleCalendarViewChange(item.key)\"\n >\n <ax-prefix>\n <ax-icon icon=\"fa-light {{ item.icon }}\"></ax-icon>\n </ax-prefix>\n </ax-button-item>\n @if(item.break) {\n <ax-divider></ax-divider>\n } }\n </ax-button-item-list>\n </ax-dropdown-panel>\n </ax-button>\n </axp-layout-suffix>\n </axp-page-toolbar>\n <axp-page-content class=\"ax-overflow-hidden\">\n <axm-task-board-calendar-view\n class=\"axp-scheduler-container\"\n [dataSource]=\"dataSource\"\n [startingDate]=\"vm.currentDate()\"\n [selectedView]=\"vm.calendarViewMode()\"\n (component)=\"schedulerComponentChanged($event)\"\n (onTaskRightClick)=\"handleTaskRightClick($event)\"\n (onMonthSlotDblClicked)=\"handleMonthSlotDblClicked($event)\"\n ></axm-task-board-calendar-view>\n <ax-context-menu\n #rootContextMenu\n [closeOn]=\"'leave'\"\n [orientation]=\"'vertical'\"\n (onOpening)=\"handleContextMenuOnOpening($event)\"\n (onItemClick)=\"handleContextMenuItemClick($event)\"\n >\n </ax-context-menu>\n </axp-page-content>\n</axp-page-layout>\n", styles: ["axm-task-board-calendar-view{height:100%}html[dir=rtl] axp-page-layout axp-page-toolbar axp-layout-prefix .ax-scheduler-header .arrow-icon:before{-moz-transform:scale(-1,1);-webkit-transform:scale(-1,1);-o-transform:scale(-1,1);-ms-transform:scale(-1,1);transform:scaleX(-1)}\n"] }]
302
- }] });
303
-
304
- export { AXMTaskBoardPage };
305
- //# sourceMappingURL=acorex-modules-workflow-management-task-board.page-BzLr0QnF.mjs.map