@acorex/platform 19.2.17 → 19.2.20

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 (92) hide show
  1. package/common/lib/search/search-definition.builder.d.ts +0 -1
  2. package/common/lib/search/search.types.d.ts +12 -0
  3. package/common/lib/utils/filter-cleaner.d.ts +2 -0
  4. package/common/lib/utils/index.d.ts +1 -0
  5. package/core/lib/directives/dbl-click.directive.d.ts +11 -0
  6. package/core/lib/directives/index.d.ts +1 -0
  7. package/core/lib/types.d.ts +15 -0
  8. package/fesm2022/acorex-platform-common.mjs +25 -9
  9. package/fesm2022/acorex-platform-common.mjs.map +1 -1
  10. package/fesm2022/acorex-platform-core.mjs +41 -2
  11. package/fesm2022/acorex-platform-core.mjs.map +1 -1
  12. package/fesm2022/acorex-platform-layout-designer.mjs +8 -8
  13. package/fesm2022/acorex-platform-layout-designer.mjs.map +1 -1
  14. package/fesm2022/acorex-platform-layout-entity.mjs +105 -96
  15. package/fesm2022/acorex-platform-layout-entity.mjs.map +1 -1
  16. package/fesm2022/acorex-platform-layout-search.mjs +33 -11
  17. package/fesm2022/acorex-platform-layout-search.mjs.map +1 -1
  18. package/fesm2022/{acorex-platform-themes-default-entity-master-create-view.component-pcNF_wd0.mjs → acorex-platform-themes-default-entity-master-create-view.component-LKhN00ob.mjs} +3 -3
  19. package/fesm2022/{acorex-platform-themes-default-entity-master-create-view.component-pcNF_wd0.mjs.map → acorex-platform-themes-default-entity-master-create-view.component-LKhN00ob.mjs.map} +1 -1
  20. package/fesm2022/{acorex-platform-themes-default-entity-master-list-view.component-DbHEBpPW.mjs → acorex-platform-themes-default-entity-master-list-view.component-BYUOmONk.mjs} +20 -60
  21. package/fesm2022/acorex-platform-themes-default-entity-master-list-view.component-BYUOmONk.mjs.map +1 -0
  22. package/fesm2022/{acorex-platform-themes-default-entity-master-modify-view.component-DOPzt7dM.mjs → acorex-platform-themes-default-entity-master-modify-view.component-B9TUh-2S.mjs} +3 -3
  23. package/fesm2022/{acorex-platform-themes-default-entity-master-modify-view.component-DOPzt7dM.mjs.map → acorex-platform-themes-default-entity-master-modify-view.component-B9TUh-2S.mjs.map} +1 -1
  24. package/fesm2022/acorex-platform-themes-default-entity-master-single-view.component-9U774Tr7.mjs +135 -0
  25. package/fesm2022/acorex-platform-themes-default-entity-master-single-view.component-9U774Tr7.mjs.map +1 -0
  26. package/fesm2022/{acorex-platform-themes-default-error-401.component-Brx-zHqH.mjs → acorex-platform-themes-default-error-401.component-Ycz5LYvk.mjs} +2 -2
  27. package/fesm2022/{acorex-platform-themes-default-error-401.component-Brx-zHqH.mjs.map → acorex-platform-themes-default-error-401.component-Ycz5LYvk.mjs.map} +1 -1
  28. package/fesm2022/{acorex-platform-themes-default-error-404.component-C8mJP9D8.mjs → acorex-platform-themes-default-error-404.component-DvVSMoRS.mjs} +2 -2
  29. package/fesm2022/{acorex-platform-themes-default-error-404.component-C8mJP9D8.mjs.map → acorex-platform-themes-default-error-404.component-DvVSMoRS.mjs.map} +1 -1
  30. package/fesm2022/{acorex-platform-themes-default-error-offline.component-CwBClgcf.mjs → acorex-platform-themes-default-error-offline.component-DU6dstng.mjs} +2 -2
  31. package/fesm2022/{acorex-platform-themes-default-error-offline.component-CwBClgcf.mjs.map → acorex-platform-themes-default-error-offline.component-DU6dstng.mjs.map} +1 -1
  32. package/fesm2022/acorex-platform-themes-default-search-popup.component-BY3oQqbr.mjs +128 -0
  33. package/fesm2022/acorex-platform-themes-default-search-popup.component-BY3oQqbr.mjs.map +1 -0
  34. package/fesm2022/acorex-platform-themes-default-setting-page.component-_IStMWcu.mjs +74 -0
  35. package/fesm2022/acorex-platform-themes-default-setting-page.component-_IStMWcu.mjs.map +1 -0
  36. package/fesm2022/{acorex-platform-themes-default-setting-view.component-B3Aob67f.mjs → acorex-platform-themes-default-setting-view.component-CeHpcfsc.mjs} +2 -2
  37. package/fesm2022/{acorex-platform-themes-default-setting-view.component-B3Aob67f.mjs.map → acorex-platform-themes-default-setting-view.component-CeHpcfsc.mjs.map} +1 -1
  38. package/fesm2022/{acorex-platform-themes-default-theme-palette-preview.page-DiDSZx-u.mjs → acorex-platform-themes-default-theme-palette-preview.page-D_EkB2k8.mjs} +4 -4
  39. package/fesm2022/{acorex-platform-themes-default-theme-palette-preview.page-DiDSZx-u.mjs.map → acorex-platform-themes-default-theme-palette-preview.page-D_EkB2k8.mjs.map} +1 -1
  40. package/fesm2022/acorex-platform-themes-default.mjs +189 -42
  41. package/fesm2022/acorex-platform-themes-default.mjs.map +1 -1
  42. package/fesm2022/acorex-platform-themes-shared.mjs +15 -88
  43. package/fesm2022/acorex-platform-themes-shared.mjs.map +1 -1
  44. package/fesm2022/{acorex-platform-widgets-button-widget-designer.component-BLUSF9_9.mjs → acorex-platform-widgets-button-widget-designer.component-DVhi_mBH.mjs} +2 -2
  45. package/fesm2022/{acorex-platform-widgets-button-widget-designer.component-BLUSF9_9.mjs.map → acorex-platform-widgets-button-widget-designer.component-DVhi_mBH.mjs.map} +1 -1
  46. package/fesm2022/{acorex-platform-widgets-rich-text-popup.component-DIbfD0SV.mjs → acorex-platform-widgets-rich-text-popup.component-CXLjPrFq.mjs} +2 -2
  47. package/fesm2022/{acorex-platform-widgets-rich-text-popup.component-DIbfD0SV.mjs.map → acorex-platform-widgets-rich-text-popup.component-CXLjPrFq.mjs.map} +1 -1
  48. package/fesm2022/{acorex-platform-widgets-tabular-data-edit-popup.component-C5FtQN9y.mjs → acorex-platform-widgets-tabular-data-edit-popup.component-u2RCVYRB.mjs} +2 -2
  49. package/fesm2022/{acorex-platform-widgets-tabular-data-edit-popup.component-C5FtQN9y.mjs.map → acorex-platform-widgets-tabular-data-edit-popup.component-u2RCVYRB.mjs.map} +1 -1
  50. package/fesm2022/{acorex-platform-widgets-tabular-data-view-popup.component-DFopYaFk.mjs → acorex-platform-widgets-tabular-data-view-popup.component-BiO5M_eY.mjs} +2 -2
  51. package/fesm2022/{acorex-platform-widgets-tabular-data-view-popup.component-DFopYaFk.mjs.map → acorex-platform-widgets-tabular-data-view-popup.component-BiO5M_eY.mjs.map} +1 -1
  52. package/fesm2022/acorex-platform-widgets.mjs +1174 -269
  53. package/fesm2022/acorex-platform-widgets.mjs.map +1 -1
  54. package/layout/entity/lib/entity-master-list.viewmodel.d.ts +1 -2
  55. package/layout/entity/lib/entity-storage-service.d.ts +4 -0
  56. package/layout/entity/lib/widgets/lookup-widget/lookup-widget-edit.component.d.ts +1 -0
  57. package/layout/entity/lib/widgets/lookup-widget/lookup-widget-selector.component.d.ts +2 -1
  58. package/layout/entity/lib/widgets/lookup-widget/lookup-widget-selector.viewmodel.d.ts +3 -1
  59. package/layout/entity/lib/workflows/delete-entity.workflow.d.ts +4 -0
  60. package/layout/search/lib/search.viewmodel.d.ts +2 -0
  61. package/package.json +5 -5
  62. package/themes/default/lib/layouts/base/base-page.component.d.ts +100 -0
  63. package/themes/default/lib/layouts/base/base-page.types.d.ts +16 -0
  64. package/themes/default/lib/layouts/base/index.d.ts +3 -0
  65. package/themes/default/lib/layouts/base/page-layout/index.d.ts +1 -0
  66. package/themes/default/lib/layouts/base/{simple-page/simple-page.component.d.ts → page-layout/page-layout.component.d.ts} +9 -6
  67. package/themes/default/lib/layouts/base/simple-page/index.d.ts +0 -1
  68. package/themes/default/lib/layouts/base/simple-page/simple-page.layout.d.ts +2 -0
  69. package/themes/default/lib/layouts/entity-layouts/entity-master-list-view/entity-master-list-view.component.d.ts +3 -3
  70. package/themes/default/lib/layouts/search-layout/search-popup.component.d.ts +1 -0
  71. package/themes/shared/index.d.ts +0 -1
  72. package/themes/shared/lib/components/layout-elements/layout-actions.component.d.ts +1 -1
  73. package/themes/shared/lib/components/layout-elements/layout-blocks.component.d.ts +1 -1
  74. package/widgets/lib/widgets/advance/gallery/gallery-widget-edit.component.d.ts +13 -0
  75. package/widgets/lib/widgets/advance/gallery/index.d.ts +2 -1
  76. package/widgets/lib/widgets/charts/bar-chart/bar-chart-widget-edit.component.d.ts +5 -0
  77. package/widgets/lib/widgets/charts/donut-chart/donut-chart-widget-edit.component.d.ts +32 -2
  78. package/widgets/lib/widgets/charts/donut-chart/donut-chart.type.d.ts +15 -0
  79. package/widgets/lib/widgets/charts/gauge-chart/gauge-chart-widget-edit.component.d.ts +16 -3
  80. package/widgets/lib/widgets/charts/gauge-chart/gauge-chart.type.d.ts +1 -1
  81. package/widgets/lib/widgets/charts/sticky-note/sticky-note-widget-edit.component.d.ts +2 -2
  82. package/widgets/lib/widgets/editors/select/select-box-widget-edit.component.d.ts +1 -0
  83. package/fesm2022/acorex-platform-themes-default-entity-master-list-view.component-DbHEBpPW.mjs.map +0 -1
  84. package/fesm2022/acorex-platform-themes-default-entity-master-single-view.component-CjX7NZpi.mjs +0 -130
  85. package/fesm2022/acorex-platform-themes-default-entity-master-single-view.component-CjX7NZpi.mjs.map +0 -1
  86. package/fesm2022/acorex-platform-themes-default-search-popup.component-BXWbI4Ei.mjs +0 -127
  87. package/fesm2022/acorex-platform-themes-default-search-popup.component-BXWbI4Ei.mjs.map +0 -1
  88. package/fesm2022/acorex-platform-themes-default-setting-page.component-BQRGixPo.mjs +0 -74
  89. package/fesm2022/acorex-platform-themes-default-setting-page.component-BQRGixPo.mjs.map +0 -1
  90. package/themes/default/lib/layouts/entity-layouts/entity-master-list-view/list-view-option-filters/list-view-option-filters.component.d.ts +0 -14
  91. package/themes/shared/lib/components/drawer/drawer.directive.d.ts +0 -22
  92. package/themes/shared/lib/components/drawer/index.d.ts +0 -1
@@ -1,4 +1,4 @@
1
- import { AXDataSource, AXDataSourceFilterOption } from '@acorex/components/common';
1
+ import { AXDataSource } from '@acorex/components/common';
2
2
  import { AXPBeardCrumb, AXPEntity, AXPFilterDefinition, AXPFilterQuery, AXPQueryView } from '@acorex/platform/common';
3
3
  import { Injector } from '@angular/core';
4
4
  import { ResolveFn } from '@angular/router';
@@ -72,7 +72,6 @@ export declare class AXPEntityMasterListViewModel {
72
72
  discardFilters(): void;
73
73
  applyInlineFilter(value: string): void;
74
74
  applyFilterAndSort(): Promise<void>;
75
- cleanNestedFilters(filters: AXDataSourceFilterOption[]): AXDataSourceFilterOption[];
76
75
  private allAvailableColumns;
77
76
  visibleColumnCount: () => number;
78
77
  columns: import("@angular/core").WritableSignal<AXPEntityListViewColumnViewModel[]>;
@@ -1,6 +1,10 @@
1
1
  import { AXPPagedListResult, AXPQueryRequest } from './data.types';
2
2
  export interface AXPEntityModel<Id> {
3
3
  id?: Id;
4
+ createdAt?: Date;
5
+ updatedAt?: Date;
6
+ createdBy?: string;
7
+ updatedBy?: string;
4
8
  }
5
9
  export declare abstract class AXPEntityStorageService<K, T extends AXPEntityModel<K>, RCreate = Omit<T, 'id'>, RGetSingle = T, RGetList = RGetSingle> {
6
10
  abstract get dbName(): string;
@@ -17,6 +17,7 @@ export declare class AXPLookupWidgetEditComponent extends AXPWidgetComponent<any
17
17
  private readonly translateService;
18
18
  protected expose: import("@angular/core").Signal<string | any[] | undefined>;
19
19
  protected entity: import("@angular/core").Signal<string>;
20
+ protected customFilter: import("@angular/core").Signal<AXDataSourceFilterOption>;
20
21
  protected textField: import("@angular/core").Signal<string>;
21
22
  protected conditions?: AXPQueryFilter[];
22
23
  protected filter: AXDataSourceFilterOption | null;
@@ -1,4 +1,4 @@
1
- import { AXValueChangedEvent } from '@acorex/components/common';
1
+ import { AXDataSourceFilterOption, AXValueChangedEvent } from '@acorex/components/common';
2
2
  import { AXDataTableRowClick, AXDataTableRowDbClick } from '@acorex/components/data-table';
3
3
  import { AXBasePageComponent } from '@acorex/components/page';
4
4
  import { AXPLookupWidgetSelectorViewModel } from './lookup-widget-selector.viewmodel';
@@ -7,6 +7,7 @@ export declare class AXPLookupWidgetSelectorComponent extends AXBasePageComponen
7
7
  protected vm: AXPLookupWidgetSelectorViewModel;
8
8
  protected searchTerm: string;
9
9
  protected focusedRow: any;
10
+ protected filter: AXDataSourceFilterOption;
10
11
  protected ngAfterViewInit(): void;
11
12
  protected handleRowDbClick(e: AXDataTableRowDbClick): void;
12
13
  protected handleRowClick(e: AXDataTableRowClick): void;
@@ -6,8 +6,10 @@ export declare class AXPLookupWidgetSelectorViewModel {
6
6
  private injector;
7
7
  private entityDef;
8
8
  private parentFilters;
9
+ private customFilter;
9
10
  private workflow;
10
- constructor(injector: Injector, entityDef: AXPEntity, parentFilters?: AXDataSourceFilterOption | null);
11
+ private filterOperatorMiddleware;
12
+ constructor(injector: Injector, entityDef: AXPEntity, parentFilters?: AXDataSourceFilterOption | null, customFilter?: AXDataSourceFilterOption | null);
11
13
  dataSource: AXDataSource<unknown>;
12
14
  canCreate: import("@angular/core").Signal<boolean>;
13
15
  parentKey: import("@angular/core").Signal<string | undefined>;
@@ -15,6 +15,10 @@ export declare const AXPEntityDeletedEvent: {
15
15
  };
16
16
  type: string;
17
17
  };
18
+ export interface AXPEntityDeleteOptions {
19
+ source: string;
20
+ ids: string[];
21
+ }
18
22
  export declare class AXPEntityPerformDeleteAction extends AXPWorkflowAction {
19
23
  private entityRegistery;
20
24
  private dialogService;
@@ -31,4 +31,6 @@ export declare class AXPGlobalSearchViewModel {
31
31
  clearRecentItems(): Promise<void>;
32
32
  private loadSettings;
33
33
  private saveSettings;
34
+ private convertItemForSave;
35
+ private convertItemForLoad;
34
36
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@acorex/platform",
3
- "version": "19.2.17",
3
+ "version": "19.2.20",
4
4
  "peerDependencies": {
5
5
  "@angular/common": ">=19.0.0",
6
6
  "@angular/core": ">=19.0.0",
@@ -73,14 +73,14 @@
73
73
  "types": "./layout/entity/index.d.ts",
74
74
  "default": "./fesm2022/acorex-platform-layout-entity.mjs"
75
75
  },
76
- "./layout/filters": {
77
- "types": "./layout/filters/index.d.ts",
78
- "default": "./fesm2022/acorex-platform-layout-filters.mjs"
79
- },
80
76
  "./layout/search": {
81
77
  "types": "./layout/search/index.d.ts",
82
78
  "default": "./fesm2022/acorex-platform-layout-search.mjs"
83
79
  },
80
+ "./layout/filters": {
81
+ "types": "./layout/filters/index.d.ts",
82
+ "default": "./fesm2022/acorex-platform-layout-filters.mjs"
83
+ },
84
84
  "./layout/setting": {
85
85
  "types": "./layout/setting/index.d.ts",
86
86
  "default": "./fesm2022/acorex-platform-layout-setting.mjs"
@@ -0,0 +1,100 @@
1
+ import { AXPSimplePageLayout } from './simple-page';
2
+ import { AXPSessionService } from '@acorex/platform/auth';
3
+ import { AXTranslationService } from '@acorex/core/translation';
4
+ import { AXPActionMenuItem, AXPBreadcrumbItem, AXPExecuteCommand } from '@acorex/platform/core';
5
+ import { AXPPageLayoutComponent } from './page-layout';
6
+ import { AXFormatService } from '@acorex/core/format';
7
+ import * as i0 from "@angular/core";
8
+ export declare abstract class AXPBasePageComponent {
9
+ #private;
10
+ protected readonly layoutService: {
11
+ currentMode: import("@angular/core").Signal<import("@acorex/platform/themes/shared").AXPThemeMode>;
12
+ currentPallete: import("@angular/core").Signal<string>;
13
+ systemThemeMode: import("@angular/core").Signal<import("@acorex/platform/themes/shared").AXPThemeMode>;
14
+ font: import("@ngrx/signals").DeepSignal<{
15
+ family: string;
16
+ size: string;
17
+ }>;
18
+ screenSize: import("@angular/core").Signal<import("@acorex/platform/themes/shared").AXPScreenSize>;
19
+ deviceType: import("@angular/core").Signal<import("@acorex/platform/themes/shared").AXPDeviceType>;
20
+ isTouchDevice: import("@angular/core").Signal<boolean>;
21
+ overlayLoading: import("@angular/core").Signal<boolean>;
22
+ navigationLoading: import("@angular/core").Signal<boolean>;
23
+ overlayLoadingTaskCount: import("@angular/core").Signal<number>;
24
+ navigationLoadingTaskCount: import("@angular/core").Signal<number>;
25
+ sideMenuState: import("@angular/core").Signal<import("@acorex/platform/themes/shared").AXPSideMenuState>;
26
+ sideMenuWidth: import("@angular/core").Signal<number>;
27
+ menuOrientation: import("@angular/core").Signal<import("@acorex/platform/themes/shared").AXPMenuOrientation>;
28
+ isDarkMode: import("@angular/core").Signal<boolean>;
29
+ isLightMode: import("@angular/core").Signal<boolean>;
30
+ isSystemMode: import("@angular/core").Signal<boolean>;
31
+ isSideMenuOpen: import("@angular/core").Signal<boolean>;
32
+ isSideMenuOverlay: import("@angular/core").Signal<boolean>;
33
+ isSmall: import("@angular/core").Signal<boolean>;
34
+ isMedium: import("@angular/core").Signal<boolean>;
35
+ isLarge: import("@angular/core").Signal<boolean>;
36
+ isMobileDevice: import("@angular/core").Signal<boolean>;
37
+ isTabletDevice: import("@angular/core").Signal<boolean>;
38
+ isDesktopDevice: import("@angular/core").Signal<boolean>;
39
+ isTouchScreen: import("@angular/core").Signal<boolean>;
40
+ isOverlayLoading: import("@angular/core").Signal<boolean>;
41
+ isNavigationLoading: import("@angular/core").Signal<boolean>;
42
+ isMenuHorizontal: import("@angular/core").Signal<boolean>;
43
+ changeThemeMode: (theme: import("@acorex/platform/themes/shared").AXPThemeMode) => void;
44
+ openSideMenu: () => void;
45
+ closeSideMenu: () => void;
46
+ setSideMenuWidth: (width: number) => void;
47
+ toggleSideMenu: () => void;
48
+ setNavigationLoading: (value: boolean, delay?: number) => void;
49
+ setOverlayLoading: (value: boolean, delay?: number) => void;
50
+ loadSettings: () => Promise<void>;
51
+ } & import("@ngrx/signals").StateSource<{
52
+ currentMode: import("@acorex/platform/themes/shared").AXPThemeMode;
53
+ currentPallete: string;
54
+ systemThemeMode: import("@acorex/platform/themes/shared").AXPThemeMode;
55
+ font: {
56
+ family: string;
57
+ size: string;
58
+ };
59
+ screenSize: import("@acorex/platform/themes/shared").AXPScreenSize;
60
+ deviceType: import("@acorex/platform/themes/shared").AXPDeviceType;
61
+ isTouchDevice: boolean;
62
+ overlayLoading: boolean;
63
+ navigationLoading: boolean;
64
+ overlayLoadingTaskCount: number;
65
+ navigationLoadingTaskCount: number;
66
+ sideMenuState: import("@acorex/platform/themes/shared").AXPSideMenuState;
67
+ sideMenuWidth: number;
68
+ menuOrientation: import("@acorex/platform/themes/shared").AXPMenuOrientation;
69
+ }>;
70
+ protected readonly sessionService: AXPSessionService;
71
+ protected readonly translateService: AXTranslationService;
72
+ protected readonly formatService: AXFormatService;
73
+ private _updateTrigger;
74
+ protected updateTrigger: import("@angular/core").Signal<number>;
75
+ protected recompute(): void;
76
+ ngOnInit(): Promise<void>;
77
+ private title;
78
+ protected getPageTitle(): string | Promise<string>;
79
+ private hasTitle;
80
+ private description;
81
+ private hasDescription;
82
+ protected getPageDescription(): string | Promise<string>;
83
+ private breadcrumbs;
84
+ private hasBreadcrumbs;
85
+ protected getPageBreadcrumbs(): AXPBreadcrumbItem[] | Promise<AXPBreadcrumbItem[]>;
86
+ private oldLayout;
87
+ private newLayout;
88
+ protected layout: import("@angular/core").Signal<AXPSimplePageLayout | AXPPageLayoutComponent | undefined>;
89
+ protected toggleEndSide(): void;
90
+ primaryMenuItems: import("@angular/core").WritableSignal<AXPActionMenuItem[]>;
91
+ hasPrimaryActions: import("@angular/core").Signal<boolean>;
92
+ protected getPrimaryMenuItems(): AXPActionMenuItem[] | Promise<AXPActionMenuItem[]>;
93
+ secondaryMenuItems: import("@angular/core").WritableSignal<AXPActionMenuItem[]>;
94
+ hasSecondaryActions: import("@angular/core").Signal<boolean>;
95
+ hasActions: import("@angular/core").Signal<boolean>;
96
+ protected getSecondaryMenuItems(): AXPActionMenuItem[] | Promise<AXPActionMenuItem[]>;
97
+ execute(command: AXPExecuteCommand): void | Promise<void>;
98
+ static ɵfac: i0.ɵɵFactoryDeclaration<AXPBasePageComponent, never>;
99
+ static ɵcmp: i0.ɵɵComponentDeclaration<AXPBasePageComponent, "ng-component", never, {}, {}, never, never, true, never>;
100
+ }
@@ -0,0 +1,16 @@
1
+ import { AXPActionMenuItem, AXPBreadcrumbItem, AXPExecuteCommand } from "@acorex/platform/core";
2
+ import { Signal } from "@angular/core";
3
+ export declare abstract class AXPBasePage {
4
+ abstract primaryMenuItems: Signal<AXPActionMenuItem[]>;
5
+ abstract secondaryMenuItems: Signal<AXPActionMenuItem[]>;
6
+ abstract hasPrimaryActions: Signal<boolean>;
7
+ abstract hasSecondaryActions: Signal<boolean>;
8
+ abstract hasActions: Signal<boolean>;
9
+ abstract breadcrumbs: Signal<AXPBreadcrumbItem[]>;
10
+ abstract title: Signal<string>;
11
+ abstract hasTitle: Signal<boolean>;
12
+ abstract hasDescription: Signal<boolean>;
13
+ abstract description: Signal<string>;
14
+ abstract hasBreadcrumbs: Signal<boolean>;
15
+ abstract execute: (command: AXPExecuteCommand) => void | Promise<void>;
16
+ }
@@ -1 +1,4 @@
1
1
  export * from './simple-page';
2
+ export * from './base-page.types';
3
+ export * from './base-page.component';
4
+ export * from './page-layout';
@@ -0,0 +1 @@
1
+ export * from './page-layout.component';
@@ -1,6 +1,9 @@
1
- import { AXPSimplePageLayout } from './simple-page.layout';
1
+ import { AXPBasePage } from '../base-page.types';
2
+ import { AXPActionMenuItem } from '@acorex/platform/core';
2
3
  import * as i0 from "@angular/core";
3
- export declare class AXPSimplePageComponent {
4
+ export declare class AXPPageLayoutComponent {
5
+ #private;
6
+ protected page: AXPBasePage | null;
4
7
  protected layoutService: {
5
8
  currentMode: import("@angular/core").Signal<import("@acorex/platform/themes/shared").AXPThemeMode>;
6
9
  currentPallete: import("@angular/core").Signal<string>;
@@ -61,8 +64,8 @@ export declare class AXPSimplePageComponent {
61
64
  sideMenuWidth: number;
62
65
  menuOrientation: import("@acorex/platform/themes/shared").AXPMenuOrientation;
63
66
  }>;
64
- protected layout: import("@angular/core").Signal<AXPSimplePageLayout | undefined>;
65
- protected toggleEndSide(): void;
66
- static ɵfac: i0.ɵɵFactoryDeclaration<AXPSimplePageComponent, never>;
67
- static ɵcmp: i0.ɵɵComponentDeclaration<AXPSimplePageComponent, "ng-component", never, {}, {}, never, never, true, never>;
67
+ private checkScrollableContent;
68
+ protected handleActionClick(item: AXPActionMenuItem): void;
69
+ static ɵfac: i0.ɵɵFactoryDeclaration<AXPPageLayoutComponent, never>;
70
+ static ɵcmp: i0.ɵɵComponentDeclaration<AXPPageLayoutComponent, "axp-page-layout", never, {}, {}, never, ["axp-page-toolbar", "axp-page-content", "axp-page-footer"], true, never>;
68
71
  }
@@ -1,2 +1 @@
1
- export * from './simple-page.component';
2
1
  export * from './simple-page.layout';
@@ -1,8 +1,10 @@
1
1
  import { AXDrawerComponent } from '@acorex/components/drawer';
2
2
  import { AXPThemeLayoutActionsComponent, AXPThemeLayoutEndSideComponent, AXPThemeLayoutPageHeaderComponent, AXPThemeLayoutStartSideComponent } from '@acorex/platform/themes/shared';
3
+ import { AXPBasePage } from '../base-page.types';
3
4
  import * as i0 from "@angular/core";
4
5
  export declare class AXPSimplePageLayout {
5
6
  #private;
7
+ protected page: AXPBasePage | null;
6
8
  protected layoutService: {
7
9
  currentMode: import("@angular/core").Signal<import("@acorex/platform/themes/shared").AXPThemeMode>;
8
10
  currentPallete: import("@angular/core").Signal<string>;
@@ -4,9 +4,9 @@ import { AXPlatform } from '@acorex/core/platform';
4
4
  import { AXValueChangedEvent } from '@acorex/components/common';
5
5
  import { AXDataPagerChangedEvent } from '@acorex/components/data-pager';
6
6
  import { AXPEntityMasterListViewModel } from '@acorex/platform/layout/entity';
7
- import { AXPSimplePageComponent } from '../../base';
7
+ import { AXPBasePageComponent } from '../../base';
8
8
  import * as i0 from "@angular/core";
9
- export declare class AXPEntityMasterListViewComponent extends AXPSimplePageComponent {
9
+ export declare class AXPEntityMasterListViewComponent extends AXPBasePageComponent {
10
10
  protected platform: AXPlatform;
11
11
  private activeRoute;
12
12
  protected readonly vm: AXPEntityMasterListViewModel;
@@ -72,7 +72,7 @@ export declare class AXPEntityMasterListViewComponent extends AXPSimplePageCompo
72
72
  }>;
73
73
  protected searchBarShown: import("@angular/core").WritableSignal<boolean>;
74
74
  protected activeEndSideView: import("@angular/core").WritableSignal<"sort" | "filter" | "column">;
75
- grid: AXDataTableComponent;
75
+ protected grid: import("@angular/core").Signal<AXDataTableComponent | undefined>;
76
76
  constructor(platform: AXPlatform);
77
77
  ngAfterViewInit(): void;
78
78
  protected closeFiltersDrawer(e: AXDrawerComponent, collapsed: boolean): void;
@@ -4,6 +4,7 @@ import { AXPSearchDisplayResult } from '@acorex/platform/common';
4
4
  import { AXPGlobalSearchViewModel } from '@acorex/platform/layout/search';
5
5
  import * as i0 from "@angular/core";
6
6
  export declare class AXPGlobalSearchPopupComponent extends AXBasePageComponent {
7
+ protected i18nScope: string;
7
8
  protected vm: AXPGlobalSearchViewModel;
8
9
  protected text: string | null;
9
10
  private list;
@@ -5,4 +5,3 @@ export * from './lib/theme.service';
5
5
  export * from './lib/theme.types';
6
6
  export * from './lib/setting.keys';
7
7
  export * from './lib/shared.module';
8
- export * from './lib/components/drawer';
@@ -6,7 +6,7 @@ export declare class AXPThemeLayoutPagePrimaryActionsComponent {
6
6
  }
7
7
  export declare class AXPThemeLayoutPageSecondaryActionsComponent {
8
8
  static ɵfac: i0.ɵɵFactoryDeclaration<AXPThemeLayoutPageSecondaryActionsComponent, never>;
9
- static ɵcmp: i0.ɵɵComponentDeclaration<AXPThemeLayoutPageSecondaryActionsComponent, "axp-layout-actions-secondary", never, {}, {}, never, ["ax-button-item"], true, never>;
9
+ static ɵcmp: i0.ɵɵComponentDeclaration<AXPThemeLayoutPageSecondaryActionsComponent, "axp-layout-actions-secondary", never, {}, {}, never, ["ax-button-item,ax-divider,ng-container"], true, never>;
10
10
  }
11
11
  export declare class AXPThemeLayoutActionsComponent {
12
12
  readonly primaryTemplate: import("@angular/core").Signal<TemplateRef<any> | undefined>;
@@ -1,5 +1,5 @@
1
1
  import * as i0 from "@angular/core";
2
2
  export declare class AXPThemeLayoutBlockComponent {
3
3
  static ɵfac: i0.ɵɵFactoryDeclaration<AXPThemeLayoutBlockComponent, never>;
4
- static ɵcmp: i0.ɵɵComponentDeclaration<AXPThemeLayoutBlockComponent, " 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, axp-layout-nav-button, axp-layout-description, axp-layout-title-bar, axp-layout-breadcrumbs, axp-layout-list-action, ", never, {}, {}, never, ["*"], true, never>;
4
+ static ɵcmp: i0.ɵɵComponentDeclaration<AXPThemeLayoutBlockComponent, " axp-page-content, axp-page-footer, axp-page-header, 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, axp-layout-nav-button, axp-layout-description, axp-layout-title-bar, axp-layout-breadcrumbs, axp-layout-list-action, ", never, {}, {}, never, ["*"], true, never>;
5
5
  }
@@ -0,0 +1,13 @@
1
+ import { AXMediaViewerData } from '@acorex/components/media-viewer';
2
+ import { AXPWidgetComponent } from '@acorex/platform/layout/builder';
3
+ import * as i0 from "@angular/core";
4
+ export declare class AXPGalleryWidgetEditComponent extends AXPWidgetComponent<any> {
5
+ protected thumbnail: import("@angular/core").Signal<boolean>;
6
+ protected header: import("@angular/core").Signal<boolean>;
7
+ protected fileInfo: import("@angular/core").Signal<boolean>;
8
+ protected fullScreenButton: import("@angular/core").Signal<boolean>;
9
+ protected data: import("@angular/core").WritableSignal<AXMediaViewerData[]>;
10
+ private get __class();
11
+ static ɵfac: i0.ɵɵFactoryDeclaration<AXPGalleryWidgetEditComponent, never>;
12
+ static ɵcmp: i0.ɵɵComponentDeclaration<AXPGalleryWidgetEditComponent, "ng-component", never, {}, {}, never, never, true, never>;
13
+ }
@@ -1,3 +1,4 @@
1
- export * from './gallery-widget-view.component';
1
+ export * from './gallery-widget-edit.component';
2
2
  export * from './gallery-widget-print.component';
3
+ export * from './gallery-widget-view.component';
3
4
  export * from './gallery-widget.config';
@@ -18,8 +18,11 @@ export declare class AXPBarChartWidgetEditComponent extends AXPWidgetComponent<A
18
18
  private data;
19
19
  private isRendered;
20
20
  private readonly DEFAULT_COLOR;
21
+ private readonly HOVER_COLOR;
21
22
  private readonly DEFAULT_MARGIN;
22
23
  private readonly BAR_TRANSITION_DELAY;
24
+ private readonly TRANSITION_DURATION;
25
+ private tooltip;
23
26
  private loadD3;
24
27
  private createChart;
25
28
  private initializeSVG;
@@ -29,7 +32,9 @@ export declare class AXPBarChartWidgetEditComponent extends AXPWidgetComponent<A
29
32
  private updateChart;
30
33
  private updateScales;
31
34
  private updateAxes;
35
+ private formatNumber;
32
36
  private updateBars;
37
+ private createGradient;
33
38
  static ɵfac: i0.ɵɵFactoryDeclaration<AXPBarChartWidgetEditComponent, never>;
34
39
  static ɵcmp: i0.ɵɵComponentDeclaration<AXPBarChartWidgetEditComponent, "ng-component", never, {}, {}, never, never, true, never>;
35
40
  }
@@ -1,13 +1,43 @@
1
1
  import { AXPWidgetComponent } from '@acorex/platform/layout/builder';
2
- import { AXPDonutChartValue } from './donut-chart.type';
2
+ import { AXPDonutChartData, AXPDonutChartValue } from './donut-chart.type';
3
3
  import * as i0 from "@angular/core";
4
4
  export declare class AXPDonutChartWidgetEditComponent extends AXPWidgetComponent<AXPDonutChartValue> {
5
5
  #private;
6
6
  private chartEl;
7
7
  private d3;
8
+ private activeSegmentId;
9
+ private pieData;
10
+ private hiddenSegments;
11
+ protected chartData: import("@angular/core").WritableSignal<AXPDonutChartData[]>;
12
+ protected showLegend: import("@angular/core").WritableSignal<boolean>;
13
+ protected showTooltip: import("@angular/core").WritableSignal<boolean>;
14
+ protected tooltipData: import("@angular/core").WritableSignal<{
15
+ name: string;
16
+ value: number;
17
+ percentage: string;
18
+ id: string;
19
+ }>;
20
+ protected tooltipPosition: import("@angular/core").WritableSignal<{
21
+ x: number;
22
+ y: number;
23
+ }>;
24
+ protected tooltipVisible: import("@angular/core").WritableSignal<boolean>;
25
+ protected tooltipOptions: import("@angular/core").WritableSignal<{
26
+ enabled: boolean;
27
+ showPercentage: boolean;
28
+ showValue: boolean;
29
+ position: "auto" | "fixed";
30
+ offset: number;
31
+ }>;
32
+ private initializeOptions;
8
33
  private loadD3;
9
34
  private createChart;
10
- private getRandomColor;
35
+ protected toggleSegment(id: string): void;
36
+ protected isSegmentHidden(id: string): boolean;
37
+ protected highlightSegment(id: string): void;
38
+ protected resetHighlight(): void;
39
+ protected getModernColor(index: number): string;
40
+ protected getRandomColor(): string;
11
41
  ngOnDestroy(): void;
12
42
  static ɵfac: i0.ɵɵFactoryDeclaration<AXPDonutChartWidgetEditComponent, never>;
13
43
  static ɵcmp: i0.ɵɵComponentDeclaration<AXPDonutChartWidgetEditComponent, "ng-component", never, {}, {}, never, never, true, never>;
@@ -8,6 +8,21 @@ export interface AXPDonutChartData {
8
8
  export interface AXPDonutChartOption {
9
9
  width: number;
10
10
  height: number;
11
+ tooltip?: {
12
+ enabled: boolean;
13
+ showPercentage: boolean;
14
+ showValue: boolean;
15
+ position?: 'auto' | 'fixed';
16
+ offset?: number;
17
+ };
18
+ legend?: {
19
+ enabled: boolean;
20
+ position?: 'bottom' | 'right';
21
+ };
22
+ animation?: {
23
+ enabled: boolean;
24
+ duration?: number;
25
+ };
11
26
  }
12
27
  export interface AXPDonutChartValue extends AXPChartValue<AXPDonutChartData[], AXPDonutChartOption> {
13
28
  }
@@ -8,6 +8,10 @@ export declare class AXPGaugeChartWidgetEditComponent extends AXPWidgetComponent
8
8
  private d3;
9
9
  private loadD3;
10
10
  private createChart;
11
+ /**
12
+ * Create gradient definitions for thresholds
13
+ */
14
+ private createGradients;
11
15
  /**
12
16
  * Draw the background arc.
13
17
  */
@@ -17,13 +21,21 @@ export declare class AXPGaugeChartWidgetEditComponent extends AXPWidgetComponent
17
21
  */
18
22
  private drawThresholds;
19
23
  /**
20
- * Draw a threshold label.
24
+ * Draw tick marks around the gauge
25
+ */
26
+ private drawTicks;
27
+ /**
28
+ * Draw the value display in the center
21
29
  */
22
- private drawThresholdLabel;
30
+ private drawValueDisplay;
23
31
  /**
24
- * Draw the dial/needle.
32
+ * Draw the dial/needle with animation.
25
33
  */
26
34
  private drawDial;
35
+ /**
36
+ * Create a path for the needle
37
+ */
38
+ private createNeedlePath;
27
39
  /**
28
40
  * Draw the chart label.
29
41
  */
@@ -32,6 +44,7 @@ export declare class AXPGaugeChartWidgetEditComponent extends AXPWidgetComponent
32
44
  * Scale a value to an angle for the gauge chart.
33
45
  */
34
46
  private scaleValueToAngle;
47
+ private scaleValueToColorAngle;
35
48
  /**
36
49
  * Convert radians to degrees.
37
50
  */
@@ -10,7 +10,7 @@ export interface AXPGaugeChartOption {
10
10
  height: number;
11
11
  minValue: number;
12
12
  maxValue: number;
13
- thresholds: {
13
+ thresholds?: {
14
14
  range: number;
15
15
  color: string;
16
16
  }[];
@@ -8,9 +8,9 @@ export declare class AXPStickyNoteWidgetEditComponent extends AXPWidgetComponent
8
8
  protected bgColor: import("@angular/core").WritableSignal<string>;
9
9
  protected color: import("@angular/core").WritableSignal<string>;
10
10
  private el;
11
- protected colors: string[];
11
+ protected colorPresets: string[];
12
12
  protected toggleEdit(): void;
13
- protected setColor(event: string): void;
13
+ protected setColor(color: string): void;
14
14
  protected valueChange(event: AXValueChangedEvent<any>): void;
15
15
  static ɵfac: i0.ɵɵFactoryDeclaration<AXPStickyNoteWidgetEditComponent, never>;
16
16
  static ɵcmp: i0.ɵɵComponentDeclaration<AXPStickyNoteWidgetEditComponent, "ng-component", never, {}, {}, never, never, true, never>;
@@ -6,6 +6,7 @@ export declare class AXPSelectBoxWidgetEditComponent extends AXPDataListWidgetCo
6
6
  #private;
7
7
  private selectbox;
8
8
  protected widgetsConfigs: StrategyConfig;
9
+ private readonly filterOperatorMiddleware;
9
10
  protected multiple: import("@angular/core").Signal<boolean>;
10
11
  protected disabled: import("@angular/core").Signal<boolean>;
11
12
  protected placeholder: import("@angular/core").Signal<string>;