@acorex/platform 18.2.3 → 18.2.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.
- package/esm2022/common/lib/layout/sticky.directive.mjs +15 -11
- package/esm2022/layout/builder/lib/builder/widget-column-renderer.mjs +22 -11
- package/esm2022/layout/designer/lib/designer/components/size-mode/view-size-toolbar.component.mjs +27 -32
- package/esm2022/layout/entity/lib/entity-master-list.viewmodel.mjs +33 -8
- package/esm2022/layout/entity/lib/entity.module.mjs +1 -17
- package/esm2022/layout/entity/lib/index.mjs +5 -4
- package/esm2022/layout/setting/lib/convert-setting-data.mjs +59 -0
- package/esm2022/layout/setting/lib/setting.viewmodel.mjs +123 -41
- package/esm2022/layouts/lib/admin/entity-layout/entity-list-view/entity-list-view.component.mjs +3 -3
- package/esm2022/themes/default/lib/default.module.mjs +83 -39
- package/esm2022/themes/default/lib/layouts/entity-layouts/entity-detail-list-view/entity-detail-list-view.component.mjs +3 -3
- package/esm2022/themes/default/lib/layouts/entity-layouts/entity-master-list-view/entity-master-list-view.component.mjs +18 -18
- package/esm2022/themes/default/lib/layouts/entity-layouts/entity-master-list-view/list-view-option-columns/list-view-option-columns.component.mjs +18 -8
- package/esm2022/themes/default/lib/layouts/root-layout/components/menu/root-menu.component.mjs +1 -1
- package/esm2022/themes/default/lib/layouts/setting-layout/index.mjs +3 -3
- package/esm2022/themes/default/lib/layouts/setting-layout/setting-menu/setting-menu.component.mjs +28 -0
- package/esm2022/themes/default/lib/layouts/setting-layout/setting-view/setting-view.component.mjs +42 -0
- package/esm2022/widgets/lib/widgets/advance/cron-job/cron-job-widget-edit.component.mjs +2 -2
- package/esm2022/widgets/lib/widgets/advance/cron-job/cron-job-widget.config.mjs +3 -2
- package/esm2022/workflow/lib/workflow.service.mjs +1 -1
- package/fesm2022/acorex-platform-common.mjs +13 -9
- package/fesm2022/acorex-platform-common.mjs.map +1 -1
- package/fesm2022/acorex-platform-layout-builder.mjs +18 -7
- package/fesm2022/acorex-platform-layout-builder.mjs.map +1 -1
- package/fesm2022/acorex-platform-layout-designer.mjs +25 -30
- package/fesm2022/acorex-platform-layout-designer.mjs.map +1 -1
- package/fesm2022/acorex-platform-layout-entity.mjs +842 -833
- package/fesm2022/acorex-platform-layout-entity.mjs.map +1 -1
- package/fesm2022/acorex-platform-layout-setting.mjs +180 -40
- package/fesm2022/acorex-platform-layout-setting.mjs.map +1 -1
- package/fesm2022/acorex-platform-layouts.mjs.map +1 -1
- package/fesm2022/{acorex-platform-themes-default-entity-master-create-view.component-CJY8R3sa.mjs → acorex-platform-themes-default-entity-master-create-view.component-Bs6fn6z2.mjs} +3 -3
- package/fesm2022/{acorex-platform-themes-default-entity-master-create-view.component-CJY8R3sa.mjs.map → acorex-platform-themes-default-entity-master-create-view.component-Bs6fn6z2.mjs.map} +1 -1
- package/fesm2022/{acorex-platform-themes-default-entity-master-list-view.component-C6zgLyry.mjs → acorex-platform-themes-default-entity-master-list-view.component-DPHXeucj.mjs} +39 -30
- package/fesm2022/acorex-platform-themes-default-entity-master-list-view.component-DPHXeucj.mjs.map +1 -0
- package/fesm2022/{acorex-platform-themes-default-entity-master-modify-view.component-wPZPhMgy.mjs → acorex-platform-themes-default-entity-master-modify-view.component-CWrpcOC2.mjs} +3 -3
- package/fesm2022/{acorex-platform-themes-default-entity-master-modify-view.component-wPZPhMgy.mjs.map → acorex-platform-themes-default-entity-master-modify-view.component-CWrpcOC2.mjs.map} +1 -1
- package/fesm2022/{acorex-platform-themes-default-entity-master-single-view.component-DNXWb6ij.mjs → acorex-platform-themes-default-entity-master-single-view.component-DHfe0Qtu.mjs} +10 -10
- package/fesm2022/{acorex-platform-themes-default-entity-master-single-view.component-DNXWb6ij.mjs.map → acorex-platform-themes-default-entity-master-single-view.component-DHfe0Qtu.mjs.map} +1 -1
- package/fesm2022/acorex-platform-themes-default.mjs +153 -257
- package/fesm2022/acorex-platform-themes-default.mjs.map +1 -1
- package/fesm2022/acorex-platform-widgets.mjs +3 -2
- package/fesm2022/acorex-platform-widgets.mjs.map +1 -1
- package/fesm2022/acorex-platform-workflow.mjs.map +1 -1
- package/layout/builder/lib/builder/widget-column-renderer.d.ts +1 -1
- package/layout/entity/lib/entity-master-list.viewmodel.d.ts +6 -2
- package/layout/entity/lib/index.d.ts +4 -3
- package/layout/setting/README.md +2 -3
- package/{themes/default/lib/layouts/setting-layout → layout/setting/lib}/convert-setting-data.d.ts +6 -6
- package/layout/setting/lib/setting.viewmodel.d.ts +35 -9
- package/package.json +7 -7
- package/themes/default/lib/default.module.d.ts +3 -4
- package/themes/default/lib/layouts/entity-layouts/entity-master-list-view/list-view-option-columns/list-view-option-columns.component.d.ts +3 -0
- package/themes/default/lib/layouts/setting-layout/index.d.ts +2 -2
- package/themes/default/lib/layouts/setting-layout/setting-menu/setting-menu.component.d.ts +12 -0
- package/themes/default/lib/layouts/setting-layout/setting-view/setting-view.component.d.ts +7 -0
- package/widgets/lib/widgets/advance/cron-job/cron-job-widget-edit.component.d.ts +1 -2
- package/workflow/lib/workflow.service.d.ts +1 -1
- package/esm2022/themes/default/lib/layout.routes.mjs +0 -20
- package/esm2022/themes/default/lib/layouts/setting-layout/convert-setting-data.mjs +0 -49
- package/esm2022/themes/default/lib/layouts/setting-layout/setting-preview/setting-preview.component.mjs +0 -104
- package/esm2022/themes/default/lib/layouts/setting-layout/setting-view/setting-menu.component.mjs +0 -44
- package/fesm2022/acorex-platform-themes-default-entity-master-list-view.component-C6zgLyry.mjs.map +0 -1
- package/themes/default/lib/layout.routes.d.ts +0 -2
- package/themes/default/lib/layouts/setting-layout/setting-preview/setting-preview.component.d.ts +0 -24
- package/themes/default/lib/layouts/setting-layout/setting-view/setting-menu.component.d.ts +0 -20
|
@@ -1,16 +1,57 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import { AXPEntityReuseStrategy } from
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
1
|
+
import { AXPCommonModule } from '@acorex/platform/common';
|
|
2
|
+
import { AXP_ENTITY_CONFIG_TOKEN } from '@acorex/platform/layout/entity';
|
|
3
|
+
import { AXPThemesSharedModule } from '@acorex/platform/themes/shared';
|
|
4
|
+
import { inject, NgModule } from '@angular/core';
|
|
5
|
+
import { RouteReuseStrategy, ROUTES } from '@angular/router';
|
|
6
|
+
import { AXPEntityReuseStrategy } from './entity-reuse.strategy';
|
|
7
|
+
import { AXPRootLayoutComponent } from './layouts/root-layout';
|
|
8
|
+
import { AXPSettingsMenuComponent, AXPSettingsViewComponent } from './layouts/setting-layout';
|
|
9
9
|
import * as i0 from "@angular/core";
|
|
10
|
-
|
|
10
|
+
function routesFacory() {
|
|
11
|
+
const config = inject(AXP_ENTITY_CONFIG_TOKEN);
|
|
12
|
+
let routes = [
|
|
13
|
+
{
|
|
14
|
+
path: ':app/settings',
|
|
15
|
+
component: config.viewers.root(),
|
|
16
|
+
children: [
|
|
17
|
+
{
|
|
18
|
+
path: '',
|
|
19
|
+
component: AXPSettingsMenuComponent,
|
|
20
|
+
data: { reuse: true },
|
|
21
|
+
children: [
|
|
22
|
+
{
|
|
23
|
+
path: ':group',
|
|
24
|
+
component: AXPSettingsViewComponent,
|
|
25
|
+
},
|
|
26
|
+
],
|
|
27
|
+
},
|
|
28
|
+
],
|
|
29
|
+
},
|
|
30
|
+
{
|
|
31
|
+
path: 'error',
|
|
32
|
+
children: [
|
|
33
|
+
{
|
|
34
|
+
path: 'offline',
|
|
35
|
+
loadComponent: () => import('./pages/errors/error-offline/error-offline.component').then((c) => c.AXPErrorOfflineComponent),
|
|
36
|
+
},
|
|
37
|
+
{
|
|
38
|
+
path: '404',
|
|
39
|
+
loadComponent: () => import('./pages/errors/error-404/error-404.component').then((c) => c.AXPError404Component),
|
|
40
|
+
},
|
|
41
|
+
{
|
|
42
|
+
path: '401',
|
|
43
|
+
loadComponent: () => import('./pages/errors/error-401/error-401.component').then((c) => c.AXPError401Component),
|
|
44
|
+
},
|
|
45
|
+
],
|
|
46
|
+
},
|
|
47
|
+
];
|
|
48
|
+
return routes;
|
|
49
|
+
}
|
|
11
50
|
export class AXPDefaultThemeModule {
|
|
12
51
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXPDefaultThemeModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
13
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.0", ngImport: i0, type: AXPDefaultThemeModule, imports: [
|
|
52
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.0", ngImport: i0, type: AXPDefaultThemeModule, imports: [
|
|
53
|
+
// RouterModule.forChild(routes),
|
|
54
|
+
AXPCommonModule,
|
|
14
55
|
AXPThemesSharedModule] }); }
|
|
15
56
|
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXPDefaultThemeModule, providers: [
|
|
16
57
|
{
|
|
@@ -19,23 +60,25 @@ export class AXPDefaultThemeModule {
|
|
|
19
60
|
viewers: {
|
|
20
61
|
root: () => AXPRootLayoutComponent,
|
|
21
62
|
master: {
|
|
22
|
-
single: () => import('./layouts/entity-layouts/entity-master-single-view/entity-master-single-view.component')
|
|
23
|
-
.then(c => c.AXPEntityMasterSingleViewComponent),
|
|
63
|
+
single: () => import('./layouts/entity-layouts/entity-master-single-view/entity-master-single-view.component').then((c) => c.AXPEntityMasterSingleViewComponent),
|
|
24
64
|
///
|
|
25
|
-
create: () => import('./layouts/entity-layouts/entity-master-create-view/entity-master-create-view.component')
|
|
26
|
-
.then(c => c.AXPEntityMasterCreateViewComponent),
|
|
65
|
+
create: () => import('./layouts/entity-layouts/entity-master-create-view/entity-master-create-view.component').then((c) => c.AXPEntityMasterCreateViewComponent),
|
|
27
66
|
///
|
|
28
|
-
modify: () => import('./layouts/entity-layouts/entity-master-modify-view/entity-master-modify-view.component')
|
|
29
|
-
.then(c => c.AXPEntityMasterModifyViewComponent),
|
|
67
|
+
modify: () => import('./layouts/entity-layouts/entity-master-modify-view/entity-master-modify-view.component').then((c) => c.AXPEntityMasterModifyViewComponent),
|
|
30
68
|
//
|
|
31
|
-
list: () => import('./layouts/entity-layouts/entity-master-list-view/entity-master-list-view.component')
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
}
|
|
69
|
+
list: () => import('./layouts/entity-layouts/entity-master-list-view/entity-master-list-view.component').then((c) => c.AXPEntityMasterListViewComponent),
|
|
70
|
+
},
|
|
71
|
+
},
|
|
72
|
+
},
|
|
36
73
|
},
|
|
37
|
-
{ provide: RouteReuseStrategy, useClass: AXPEntityReuseStrategy }
|
|
38
|
-
|
|
74
|
+
{ provide: RouteReuseStrategy, useClass: AXPEntityReuseStrategy },
|
|
75
|
+
{
|
|
76
|
+
provide: ROUTES,
|
|
77
|
+
multi: true,
|
|
78
|
+
useFactory: routesFacory,
|
|
79
|
+
},
|
|
80
|
+
], imports: [
|
|
81
|
+
// RouterModule.forChild(routes),
|
|
39
82
|
AXPCommonModule,
|
|
40
83
|
AXPThemesSharedModule] }); }
|
|
41
84
|
}
|
|
@@ -43,9 +86,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
|
43
86
|
type: NgModule,
|
|
44
87
|
args: [{
|
|
45
88
|
imports: [
|
|
46
|
-
RouterModule.forChild(routes),
|
|
89
|
+
// RouterModule.forChild(routes),
|
|
47
90
|
AXPCommonModule,
|
|
48
|
-
AXPThemesSharedModule
|
|
91
|
+
AXPThemesSharedModule,
|
|
49
92
|
],
|
|
50
93
|
exports: [],
|
|
51
94
|
declarations: [],
|
|
@@ -56,23 +99,24 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
|
56
99
|
viewers: {
|
|
57
100
|
root: () => AXPRootLayoutComponent,
|
|
58
101
|
master: {
|
|
59
|
-
single: () => import('./layouts/entity-layouts/entity-master-single-view/entity-master-single-view.component')
|
|
60
|
-
.then(c => c.AXPEntityMasterSingleViewComponent),
|
|
102
|
+
single: () => import('./layouts/entity-layouts/entity-master-single-view/entity-master-single-view.component').then((c) => c.AXPEntityMasterSingleViewComponent),
|
|
61
103
|
///
|
|
62
|
-
create: () => import('./layouts/entity-layouts/entity-master-create-view/entity-master-create-view.component')
|
|
63
|
-
.then(c => c.AXPEntityMasterCreateViewComponent),
|
|
104
|
+
create: () => import('./layouts/entity-layouts/entity-master-create-view/entity-master-create-view.component').then((c) => c.AXPEntityMasterCreateViewComponent),
|
|
64
105
|
///
|
|
65
|
-
modify: () => import('./layouts/entity-layouts/entity-master-modify-view/entity-master-modify-view.component')
|
|
66
|
-
.then(c => c.AXPEntityMasterModifyViewComponent),
|
|
106
|
+
modify: () => import('./layouts/entity-layouts/entity-master-modify-view/entity-master-modify-view.component').then((c) => c.AXPEntityMasterModifyViewComponent),
|
|
67
107
|
//
|
|
68
|
-
list: () => import('./layouts/entity-layouts/entity-master-list-view/entity-master-list-view.component')
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
}
|
|
108
|
+
list: () => import('./layouts/entity-layouts/entity-master-list-view/entity-master-list-view.component').then((c) => c.AXPEntityMasterListViewComponent),
|
|
109
|
+
},
|
|
110
|
+
},
|
|
111
|
+
},
|
|
73
112
|
},
|
|
74
|
-
{ provide: RouteReuseStrategy, useClass: AXPEntityReuseStrategy }
|
|
75
|
-
|
|
113
|
+
{ provide: RouteReuseStrategy, useClass: AXPEntityReuseStrategy },
|
|
114
|
+
{
|
|
115
|
+
provide: ROUTES,
|
|
116
|
+
multi: true,
|
|
117
|
+
useFactory: routesFacory,
|
|
118
|
+
},
|
|
119
|
+
],
|
|
76
120
|
}]
|
|
77
121
|
}] });
|
|
78
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
122
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"default.module.js","sourceRoot":"","sources":["../../../../../../../libs/platform/themes/default/src/lib/default.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { AXPCommonModule } from '@acorex/platform/common';\nimport { AXP_ENTITY_CONFIG_TOKEN, AXPEntityConfigs } from '@acorex/platform/layout/entity';\nimport { AXPThemesSharedModule } from '@acorex/platform/themes/shared';\nimport { inject, NgModule } from '@angular/core';\nimport { RouteReuseStrategy, Routes, ROUTES } from '@angular/router';\nimport { AXPEntityReuseStrategy } from './entity-reuse.strategy';\nimport { AXPRootLayoutComponent } from './layouts/root-layout';\nimport { AXPSettingsMenuComponent, AXPSettingsViewComponent } from './layouts/setting-layout';\n\nfunction routesFacory() {\n  const config = inject(AXP_ENTITY_CONFIG_TOKEN);\n  let routes: Routes = [\n    {\n      path: ':app/settings',\n      component: config.viewers.root(),\n      children: [\n        {\n          path: '',\n          component: AXPSettingsMenuComponent,\n          data: { reuse: true },\n          children: [\n            {\n              path: ':group',\n              component: AXPSettingsViewComponent,\n            },\n          ],\n        },\n      ],\n    },\n\n    {\n      path: 'error',\n      children: [\n        {\n          path: 'offline',\n          loadComponent: () =>\n            import('./pages/errors/error-offline/error-offline.component').then((c) => c.AXPErrorOfflineComponent),\n        },\n        {\n          path: '404',\n          loadComponent: () =>\n            import('./pages/errors/error-404/error-404.component').then((c) => c.AXPError404Component),\n        },\n        {\n          path: '401',\n          loadComponent: () =>\n            import('./pages/errors/error-401/error-401.component').then((c) => c.AXPError401Component),\n        },\n      ],\n    },\n  ];\n  return routes;\n}\n\n@NgModule({\n  imports: [\n    // RouterModule.forChild(routes),\n    AXPCommonModule,\n    AXPThemesSharedModule,\n  ],\n  exports: [],\n  declarations: [],\n  providers: [\n    {\n      provide: AXP_ENTITY_CONFIG_TOKEN,\n      useValue: {\n        viewers: {\n          root: () => AXPRootLayoutComponent,\n          master: {\n            single: () =>\n              import('./layouts/entity-layouts/entity-master-single-view/entity-master-single-view.component').then(\n                (c) => c.AXPEntityMasterSingleViewComponent\n              ),\n            ///\n            create: () =>\n              import('./layouts/entity-layouts/entity-master-create-view/entity-master-create-view.component').then(\n                (c) => c.AXPEntityMasterCreateViewComponent\n              ),\n            ///\n            modify: () =>\n              import('./layouts/entity-layouts/entity-master-modify-view/entity-master-modify-view.component').then(\n                (c) => c.AXPEntityMasterModifyViewComponent\n              ),\n            //\n            list: () =>\n              import('./layouts/entity-layouts/entity-master-list-view/entity-master-list-view.component').then(\n                (c) => c.AXPEntityMasterListViewComponent\n              ),\n          },\n        },\n      } as AXPEntityConfigs,\n    },\n    { provide: RouteReuseStrategy, useClass: AXPEntityReuseStrategy },\n    {\n      provide: ROUTES,\n      multi: true,\n      useFactory: routesFacory,\n    },\n  ],\n})\nexport class AXPDefaultThemeModule { }\n"]}
|
|
@@ -117,7 +117,7 @@ export class AXPEntityDetailListViewComponent {
|
|
|
117
117
|
this.destroy();
|
|
118
118
|
}
|
|
119
119
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXPEntityDetailListViewComponent, deps: [{ token: i1.AXActionSheetService }, { token: i2.AXUnsubscriber }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
120
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: AXPEntityDetailListViewComponent, isStandalone: true, selector: "axp-entity-detail-list-view", inputs: { vm: ["viewModel", "vm"] }, providers: [AXUnsubscriber], viewQueries: [{ propertyName: "grid", first: true, predicate: ["grid"], descendants: true }], ngImport: i0, template: "<div class=\"ax-flex ax-p-2\">\n <div class=\"ax-flex ax-flex-col ax-items-end ax-gap-3 ax-flex-1 ax-overflow-auto ax-min-h-72\">\n <div class=\"ax-flex ax-justify-between ax-items-center ax-w-full\">\n <div class=\"ax-flex ax-justify-between ax-items-center\">\n <div class=\"ax-flex ax-justify-start ax-items-center ax-gap-4\">\n @if(vm.hasSelectedItems()) {\n <div class=\"ax-flex ax-gap-3 ax-items-center ax-h-10\">\n <span class=\"ax-text-xl ax-font-bold\">\n {{ vm.selectedItems().length }} {{ 't(\"itemsSelected\", { scope: \"common\" })' | translate | async }}\n </span>\n <span
|
|
120
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: AXPEntityDetailListViewComponent, isStandalone: true, selector: "axp-entity-detail-list-view", inputs: { vm: ["viewModel", "vm"] }, providers: [AXUnsubscriber], viewQueries: [{ propertyName: "grid", first: true, predicate: ["grid"], descendants: true }], ngImport: i0, template: "<div class=\"ax-flex ax-p-2\">\n <div class=\"ax-flex ax-flex-col ax-items-end ax-gap-3 ax-flex-1 ax-overflow-auto ax-min-h-72\">\n <div class=\"ax-flex ax-justify-between ax-items-center ax-w-full\">\n <div class=\"ax-flex ax-justify-between ax-items-center\">\n <div class=\"ax-flex ax-justify-start ax-items-center ax-gap-4\">\n @if(vm.hasSelectedItems()) {\n <div class=\"ax-flex ax-gap-3 ax-items-center ax-h-10\">\n <span class=\"ax-text-xl ax-font-bold\">\n {{ vm.selectedItems().length }} {{ 't(\"itemsSelected\", { scope: \"common\" })' | translate | async }}\n </span>\n <span\n (click)=\"vm.clearSelection()\"\n class=\"ax-text-sm ax-text-primary dark:ax-text-primary-300 ax-underline ax-cursor-pointer\"\n >{{ 't(\"unselect\", { scope: \"common\" })' | translate | async }}</span\n >\n </div>\n\n } @else { @if(vm.hasInlineFilters() && !store.isSmall()) {\n <div class=\"ax-w-72\">\n <ax-search-box\n [placeholder]=\"('widget.lookup.search' | translate | async) + vm.inlineFiltersPlaceholders().join(', ')\"\n (onValueChanged)=\"handleChangeSearchValue($event)\"\n ><ax-clear-button></ax-clear-button\n ></ax-search-box>\n </div>\n } }\n </div>\n </div>\n <div class=\"ax-flex ax-items-center ax-gap-3\">\n @for(tr of vm.primaryActions();track $index) {\n <ax-button [text]=\"(tr.title | translate | async)!\" [color]=\"tr.color\" (onClick)=\"vm.executeCommand(tr.name)\">\n <ax-prefix>\n <ax-icon [icon]=\"tr.icon\"> </ax-icon>\n </ax-prefix>\n </ax-button>\n } @if(vm.secondaryActions().length) {\n <ax-button [text]=\"store.isSmall() ? null : ('actions' | translate | async)\" color=\"ghost\">\n <ax-prefix>\n <i class=\"fa-solid fa-ellipsis-vertical\"></i>\n </ax-prefix>\n <ax-dropdown-panel>\n <ax-button-item-list>\n @for(tr of vm.secondaryActions();track $index) {\n <ng-container>\n @if(tr.separated && !$first) {\n <ax-divider></ax-divider>\n }\n <ax-button-item\n [text]=\"(tr.title | translate | async)!\"\n class=\"ax-font-semibold ax-text-{{ tr.color }}\"\n (onClick)=\"vm.executeCommand(tr.name)\"\n >\n <ax-prefix>\n <ax-icon [icon]=\"tr.icon\"> </ax-icon>\n </ax-prefix>\n </ax-button-item>\n </ng-container>\n }\n </ax-button-item-list>\n </ax-dropdown-panel>\n </ax-button>\n }\n </div>\n </div>\n\n <ax-data-table\n #grid\n [showFooter]=\"false\"\n class=\"ax-flex-1\"\n [paging]=\"true\"\n [fetchDataMode]=\"'manual'\"\n [loading]=\"{ enabled: true, animation: true }\"\n [dataSource]=\"vm.dataSource\"\n (selectedRowsChange)=\"handleSelectedRowsChange($event)\"\n (onRowDbClick)=\"handleRowDbClick($event)\"\n >\n <ax-select-column fixed=\"start\" [width]=\"'50px'\"></ax-select-column>\n @for(col of vm.columns();track col.name) { @if(col.visible) {\n <axp-widget-column-renderer\n [caption]=\"col.title | translate | async\"\n [node]=\"col.node()\"\n ></axp-widget-column-renderer>\n } } @if(getCommandRowItems().length){\n\n <ax-command-column\n fixed=\"end\"\n [width]=\"getCommandRowItems().length * 60 + 'px'\"\n [items]=\"getCommandRowItems()\"\n (onItemClick)=\"handleRowCommandClick($event)\"\n ></ax-command-column>\n\n } @if(dropdownRowItems().length){\n <ax-dropdown-command-column\n fixed=\"end\"\n [width]=\"'60px'\"\n [items]=\"getDropdownRowItems\"\n (onItemClick)=\"handleRowCommandClick($event)\"\n ></ax-dropdown-command-column>\n }\n </ax-data-table>\n </div>\n</div>\n", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: RouterModule }, { kind: "ngmodule", type: AXButtonModule }, { kind: "component", type: i4.AXButtonComponent, selector: "ax-button", inputs: ["disabled", "size", "tabIndex", "color", "look", "text", "toggleable", "selected", "type", "responsiveOn", "loadingText"], outputs: ["onBlur", "onFocus", "onClick", "selectedChange", "toggleableChange", "lookChange", "colorChange", "disabledChange", "responsiveOnChange", "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: AXDecoratorModule }, { kind: "component", type: i5.AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }, { kind: "component", type: i5.AXDecoratorClearButtonComponent, selector: "ax-clear-button", inputs: ["icon"] }, { kind: "component", type: i5.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: "ngmodule", type: AXDropdownModule }, { kind: "component", type: i6.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: "ngmodule", type: AXDialogModule }, { kind: "ngmodule", type: AXLoadingModule }, { kind: "ngmodule", type: AXTabsModule }, { kind: "ngmodule", type: AXTooltipModule }, { kind: "ngmodule", type: AXBreadcrumbsModule }, { kind: "ngmodule", type: AXSearchBoxModule }, { kind: "component", type: i7.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: i8.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: i8.AXRowSelectColumnComponent, selector: "ax-select-column", inputs: ["width", "caption", "fixed"] }, { kind: "component", type: i8.AXRowCommandColumnComponent, selector: "ax-command-column", inputs: ["width", "caption", "fixed", "footerTemplate", "items"], outputs: ["onItemClick"] }, { kind: "component", type: i8.AXRowDropdownCommandColumnComponent, selector: "ax-dropdown-command-column", inputs: ["width", "caption", "fixed", "footerTemplate", "items"], outputs: ["onItemClick"] }, { kind: "ngmodule", type:
|
|
121
121
|
//
|
|
122
122
|
AXPLayoutBuilderModule }, { kind: "component", type: i9.AXPWidgetColumnRendererComponent, selector: "axp-widget-column-renderer", inputs: ["caption", "node", "footerTemplate", "cellTemplate", "headerTemplate"] }, { kind: "ngmodule", type: AXPWidgetsModule }, { kind: "ngmodule", type: AXPAuthModule }, { kind: "ngmodule", type: AXTranslationModule }, { kind: "pipe", type: i10.AXTranslatorPipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
123
123
|
}
|
|
@@ -149,7 +149,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
|
149
149
|
AXPGridLayoutDirective,
|
|
150
150
|
AXPAuthModule,
|
|
151
151
|
AXTranslationModule,
|
|
152
|
-
], standalone: true, template: "<div class=\"ax-flex ax-p-2\">\n <div class=\"ax-flex ax-flex-col ax-items-end ax-gap-3 ax-flex-1 ax-overflow-auto ax-min-h-72\">\n <div class=\"ax-flex ax-justify-between ax-items-center ax-w-full\">\n <div class=\"ax-flex ax-justify-between ax-items-center\">\n <div class=\"ax-flex ax-justify-start ax-items-center ax-gap-4\">\n @if(vm.hasSelectedItems()) {\n <div class=\"ax-flex ax-gap-3 ax-items-center ax-h-10\">\n <span class=\"ax-text-xl ax-font-bold\">\n {{ vm.selectedItems().length }} {{ 't(\"itemsSelected\", { scope: \"common\" })' | translate | async }}\n </span>\n <span
|
|
152
|
+
], standalone: true, template: "<div class=\"ax-flex ax-p-2\">\n <div class=\"ax-flex ax-flex-col ax-items-end ax-gap-3 ax-flex-1 ax-overflow-auto ax-min-h-72\">\n <div class=\"ax-flex ax-justify-between ax-items-center ax-w-full\">\n <div class=\"ax-flex ax-justify-between ax-items-center\">\n <div class=\"ax-flex ax-justify-start ax-items-center ax-gap-4\">\n @if(vm.hasSelectedItems()) {\n <div class=\"ax-flex ax-gap-3 ax-items-center ax-h-10\">\n <span class=\"ax-text-xl ax-font-bold\">\n {{ vm.selectedItems().length }} {{ 't(\"itemsSelected\", { scope: \"common\" })' | translate | async }}\n </span>\n <span\n (click)=\"vm.clearSelection()\"\n class=\"ax-text-sm ax-text-primary dark:ax-text-primary-300 ax-underline ax-cursor-pointer\"\n >{{ 't(\"unselect\", { scope: \"common\" })' | translate | async }}</span\n >\n </div>\n\n } @else { @if(vm.hasInlineFilters() && !store.isSmall()) {\n <div class=\"ax-w-72\">\n <ax-search-box\n [placeholder]=\"('widget.lookup.search' | translate | async) + vm.inlineFiltersPlaceholders().join(', ')\"\n (onValueChanged)=\"handleChangeSearchValue($event)\"\n ><ax-clear-button></ax-clear-button\n ></ax-search-box>\n </div>\n } }\n </div>\n </div>\n <div class=\"ax-flex ax-items-center ax-gap-3\">\n @for(tr of vm.primaryActions();track $index) {\n <ax-button [text]=\"(tr.title | translate | async)!\" [color]=\"tr.color\" (onClick)=\"vm.executeCommand(tr.name)\">\n <ax-prefix>\n <ax-icon [icon]=\"tr.icon\"> </ax-icon>\n </ax-prefix>\n </ax-button>\n } @if(vm.secondaryActions().length) {\n <ax-button [text]=\"store.isSmall() ? null : ('actions' | translate | async)\" color=\"ghost\">\n <ax-prefix>\n <i class=\"fa-solid fa-ellipsis-vertical\"></i>\n </ax-prefix>\n <ax-dropdown-panel>\n <ax-button-item-list>\n @for(tr of vm.secondaryActions();track $index) {\n <ng-container>\n @if(tr.separated && !$first) {\n <ax-divider></ax-divider>\n }\n <ax-button-item\n [text]=\"(tr.title | translate | async)!\"\n class=\"ax-font-semibold ax-text-{{ tr.color }}\"\n (onClick)=\"vm.executeCommand(tr.name)\"\n >\n <ax-prefix>\n <ax-icon [icon]=\"tr.icon\"> </ax-icon>\n </ax-prefix>\n </ax-button-item>\n </ng-container>\n }\n </ax-button-item-list>\n </ax-dropdown-panel>\n </ax-button>\n }\n </div>\n </div>\n\n <ax-data-table\n #grid\n [showFooter]=\"false\"\n class=\"ax-flex-1\"\n [paging]=\"true\"\n [fetchDataMode]=\"'manual'\"\n [loading]=\"{ enabled: true, animation: true }\"\n [dataSource]=\"vm.dataSource\"\n (selectedRowsChange)=\"handleSelectedRowsChange($event)\"\n (onRowDbClick)=\"handleRowDbClick($event)\"\n >\n <ax-select-column fixed=\"start\" [width]=\"'50px'\"></ax-select-column>\n @for(col of vm.columns();track col.name) { @if(col.visible) {\n <axp-widget-column-renderer\n [caption]=\"col.title | translate | async\"\n [node]=\"col.node()\"\n ></axp-widget-column-renderer>\n } } @if(getCommandRowItems().length){\n\n <ax-command-column\n fixed=\"end\"\n [width]=\"getCommandRowItems().length * 60 + 'px'\"\n [items]=\"getCommandRowItems()\"\n (onItemClick)=\"handleRowCommandClick($event)\"\n ></ax-command-column>\n\n } @if(dropdownRowItems().length){\n <ax-dropdown-command-column\n fixed=\"end\"\n [width]=\"'60px'\"\n [items]=\"getDropdownRowItems\"\n (onItemClick)=\"handleRowCommandClick($event)\"\n ></ax-dropdown-command-column>\n }\n </ax-data-table>\n </div>\n</div>\n" }]
|
|
153
153
|
}], ctorParameters: () => [{ type: i1.AXActionSheetService }, { type: i2.AXUnsubscriber }], propDecorators: { vm: [{
|
|
154
154
|
type: Input,
|
|
155
155
|
args: ['viewModel']
|
|
@@ -157,4 +157,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
|
157
157
|
type: ViewChild,
|
|
158
158
|
args: ['grid']
|
|
159
159
|
}] } });
|
|
160
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity-detail-list-view.component.js","sourceRoot":"","sources":["../../../../../../../../../../libs/platform/themes/default/src/lib/layouts/entity-layouts/entity-detail-list-view/entity-detail-list-view.component.ts","../../../../../../../../../../libs/platform/themes/default/src/lib/layouts/entity-layouts/entity-detail-list-view/entity-detail-list-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXActionSheetModule, AXActionSheetService } from '@acorex/components/action-sheet';\nimport { AXBadgeModule } from '@acorex/components/badge';\nimport { AXBreadcrumbsModule } from '@acorex/components/breadcrumbs';\nimport { AXButtonModule } from '@acorex/components/button';\nimport { AXValueChangedEvent } from '@acorex/components/common';\nimport {\n  AXDataTableComponent,\n  AXDataTableModule,\n  AXDataTableRowDbClick,\n  AXRowCommandItem,\n  AXRowCommandItemClickEvent,\n} from '@acorex/components/data-table';\nimport { AXDecoratorModule } from '@acorex/components/decorators';\nimport { AXDialogModule } from '@acorex/components/dialog';\nimport { AXDrawerModule } from '@acorex/components/drawer';\nimport { AXDropdownModule } from '@acorex/components/dropdown';\nimport { AXFormModule } from '@acorex/components/form';\nimport { AXLoadingModule } from '@acorex/components/loading';\nimport { AXPopoverModule } from '@acorex/components/popover';\nimport { AXSearchBoxModule } from '@acorex/components/search-box';\nimport { AXTabsModule } from '@acorex/components/tabs';\nimport { AXTooltipModule } from '@acorex/components/tooltip';\nimport { AXTranslationModule } from '@acorex/core/translation';\nimport { AXUnsubscriber } from '@acorex/core/utils';\nimport { AXPAuthModule } from '@acorex/platform/auth';\nimport {\n  AXPGridLayoutDirective,\n  AXPStickyDirective,\n} from '@acorex/platform/common';\nimport { AXPLayoutBuilderModule } from '@acorex/platform/layout/builder';\nimport { AXPEntityDetailListViewModel } from '@acorex/platform/layout/entity';\nimport { AXPEntityCreateEvent, AXPEntityDeletedEvent } from '@acorex/platform/layouts';\nimport { AXPLayoutThemeService } from '@acorex/platform/themes/shared';\nimport { AXPWidgetsModule } from '@acorex/platform/widgets';\nimport { AXPWorkflowService, ofType } from '@acorex/platform/workflow';\nimport { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  Input,\n  ViewChild,\n  ViewEncapsulation,\n  computed,\n  effect,\n  inject,\n} from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { RouterModule } from '@angular/router';\n\nimport { Subject, takeUntil } from 'rxjs';\n\n@Component({\n  selector: 'axp-entity-detail-list-view',\n  templateUrl: 'entity-detail-list-view.component.html',\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [AXUnsubscriber],\n  imports: [\n    CommonModule,\n    FormsModule,\n    RouterModule,\n    AXButtonModule,\n    AXDecoratorModule,\n    AXBadgeModule,\n    AXDropdownModule,\n    AXPopoverModule,\n    AXFormModule,\n    AXActionSheetModule,\n    AXDrawerModule,\n    AXDialogModule,\n    AXLoadingModule,\n    AXTabsModule,\n    AXTooltipModule,\n    AXBreadcrumbsModule,\n    AXSearchBoxModule,\n    AXDataTableModule,\n    //\n    AXPLayoutBuilderModule,\n    AXPWidgetsModule,\n    AXPStickyDirective,\n    AXPGridLayoutDirective,\n    AXPAuthModule,\n    AXTranslationModule,\n  ],\n  standalone: true,\n})\nexport class AXPEntityDetailListViewComponent {\n  private workflow = inject(AXPWorkflowService);\n  protected store = inject(AXPLayoutThemeService)\n\n  @Input('viewModel')\n  vm: AXPEntityDetailListViewModel;\n\n  protected focusedRow: any;\n  //\n  @ViewChild('grid') grid!: AXDataTableComponent;\n\n  constructor(\n    private actionSheetService: AXActionSheetService,\n    private unsubscriber: AXUnsubscriber,\n  ) {\n    effect(\n      () => {\n        this.grid.selectedRows = this.vm.selectedItems();\n      },\n      { allowSignalWrites: true }\n    );\n    this.subscribeActionEvents();\n  }\n\n\n  private readonly destroyed = new Subject<void>();\n\n  handleChangeSearchValue(e: AXValueChangedEvent) {\n    if (e.isUserInteraction) {\n      this.vm.applyInlineFilter(e.value);\n    }\n  }\n\n  protected subscribeActionEvents() {\n    this.workflow.events$\n      .pipe(ofType(AXPEntityDeletedEvent, AXPEntityCreateEvent))\n      .pipe(takeUntil(this.destroyed))\n      .subscribe((event) => {\n        console.log(event);\n        this.grid.refresh();\n      });\n  }\n\n  ngAfterViewInit(): void {\n    // this.grid.refresh();\n  }\n\n  protected dropdownRowItems = computed<AXRowCommandItem[]>(() => {\n    return this.vm.secondaryRowActions().map(\n      (c) =>\n      ({\n        icon: c.icon,\n        name: c.name,\n        text: c.title,\n        color: c.color,\n      } as AXRowCommandItem)\n    );\n  });\n\n  protected commandRowItems = computed<AXRowCommandItem[]>(() => {\n    return this.vm.primaryRowActions().map((c) => {\n      return {\n        icon: c.icon,\n        name: c.name,\n        text: c.title,\n        color: c.color,\n      } as AXRowCommandItem;\n    });\n  });\n\n  protected handleRowDbClick(e: AXDataTableRowDbClick) {\n    const item = this.dropdownRowItems()?.[0];\n    if (item) {\n      const d: AXRowCommandItemClickEvent = {\n        component: e.component,\n        name: item.name,\n        data: e.data,\n      };\n      this.handleRowCommandClick(d);\n    }\n  }\n\n  protected getCommandRowItems = (): AXRowCommandItem[] => {\n    return this.commandRowItems();\n  };\n\n  protected getDropdownRowItems = (rowData: unknown): Promise<AXRowCommandItem[]> => {\n    return Promise.resolve(this.dropdownRowItems());\n  };\n\n  protected async handleSelectedRowsChange(rows: unknown[]) {\n    this.vm.selectedItems.set(rows);\n  }\n\n  protected async handleRowCommandClick(e: AXRowCommandItemClickEvent) {\n    this.vm.executeCommand(e.name, e.data);\n  }\n\n  protected destroy() {\n    this.destroyed.next();\n    this.destroyed.complete();\n  }\n\n  ngOnDestroy(): void {\n    this.destroy();\n  }\n}\n","<div class=\"ax-flex ax-p-2\">\n  <div class=\"ax-flex ax-flex-col ax-items-end ax-gap-3 ax-flex-1 ax-overflow-auto ax-min-h-72\">\n    <div class=\"ax-flex ax-justify-between ax-items-center ax-w-full\">\n      <div class=\"ax-flex ax-justify-between ax-items-center\">\n        <div class=\"ax-flex ax-justify-start ax-items-center ax-gap-4\">\n          @if(vm.hasSelectedItems()) {\n          <div class=\"ax-flex ax-gap-3 ax-items-center ax-h-10\">\n            <span class=\"ax-text-xl ax-font-bold\">\n              {{ vm.selectedItems().length }} {{ 't(\"itemsSelected\", { scope: \"common\" })' | translate | async }}\n            </span>\n            <span (click)=\"vm.clearSelection()\"\n              class=\"ax-text-sm ax-text-primary dark:ax-text-primary-300 ax-underline ax-cursor-pointer\">{{\n              't(\"unselect\", { scope: \"common\" })' | translate | async }}</span>\n          </div>\n\n          } @else { @if(vm.hasInlineFilters() && !store.isSmall()) {\n          <div class=\"ax-w-72\">\n            <ax-search-box\n              [placeholder]=\"('widget.lookup.search' | translate | async) + vm.inlineFiltersPlaceholders().join(', ')\"\n              (onValueChanged)=\"handleChangeSearchValue($event)\"><ax-clear-button></ax-clear-button></ax-search-box>\n          </div>\n          } }\n        </div>\n      </div>\n      <div class=\"ax-flex ax-items-center ax-gap-3\">\n        @for(tr of vm.primaryActions();track $index) {\n        <ax-button [text]=\"(tr.title | translate | async)!\" [color]=\"tr.color\" (onClick)=\"vm.executeCommand(tr.name)\">\n          <ax-prefix>\n            <ax-icon [icon]=\"tr.icon\"> </ax-icon>\n          </ax-prefix>\n        </ax-button>\n        } @if(vm.secondaryActions().length) {\n        <ax-button [text]=\"store.isSmall() ? null : ('actions' | translate | async)\" color=\"ghost\">\n          <ax-prefix>\n            <i class=\"fa-solid fa-ellipsis-vertical\"></i>\n          </ax-prefix>\n          <ax-dropdown-panel>\n            <ax-button-item-list>\n              @for(tr of vm.secondaryActions();track $index) {\n              <ng-container>\n                @if(tr.separated && !$first) {\n                <ax-divider></ax-divider>\n                }\n                <ax-button-item [text]=\"(tr.title | translate | async)!\" class=\"ax-font-semibold ax-text-{{ tr.color }}\"\n                  (onClick)=\"vm.executeCommand(tr.name)\">\n                  <ax-prefix>\n                    <ax-icon [icon]=\"tr.icon\"> </ax-icon>\n                  </ax-prefix>\n                </ax-button-item>\n              </ng-container>\n              }\n            </ax-button-item-list>\n          </ax-dropdown-panel>\n        </ax-button>\n        }\n      </div>\n    </div>\n\n    <ax-data-table #grid [showFooter]=\"false\" class=\"ax-flex-1\" [paging]=\"true\" [fetchDataMode]=\"'manual'\"\n      [loading]=\"{ enabled: true, animation: true }\" [dataSource]=\"vm.dataSource\"\n      (selectedRowsChange)=\"handleSelectedRowsChange($event)\" (onRowDbClick)=\"handleRowDbClick($event)\">\n      <ax-select-column fixed=\"start\" [width]=\"'50px'\"></ax-select-column>\n      @for(col of vm.columns();track col.name) { @if(col.visible) {\n      <axp-widget-column-renderer [caption]=\"col.title | translate | async\"\n        [node]=\"col.node()\"></axp-widget-column-renderer>\n      } } @if(getCommandRowItems().length){\n\n      <ax-command-column fixed=\"end\" [width]=\"getCommandRowItems().length * 60 + 'px'\" [items]=\"getCommandRowItems()\"\n        (onItemClick)=\"handleRowCommandClick($event)\"></ax-command-column>\n\n      } @if(dropdownRowItems().length){\n      <ax-dropdown-command-column fixed=\"end\" [width]=\"'60px'\" [items]=\"getDropdownRowItems\"\n        (onItemClick)=\"handleRowCommandClick($event)\"></ax-dropdown-command-column>\n      }\n    </ax-data-table>\n  </div>\n</div>"]}
|
|
160
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity-detail-list-view.component.js","sourceRoot":"","sources":["../../../../../../../../../../libs/platform/themes/default/src/lib/layouts/entity-layouts/entity-detail-list-view/entity-detail-list-view.component.ts","../../../../../../../../../../libs/platform/themes/default/src/lib/layouts/entity-layouts/entity-detail-list-view/entity-detail-list-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXActionSheetModule, AXActionSheetService } from '@acorex/components/action-sheet';\nimport { AXBadgeModule } from '@acorex/components/badge';\nimport { AXBreadcrumbsModule } from '@acorex/components/breadcrumbs';\nimport { AXButtonModule } from '@acorex/components/button';\nimport { AXValueChangedEvent } from '@acorex/components/common';\nimport {\n  AXDataTableComponent,\n  AXDataTableModule,\n  AXDataTableRowDbClick,\n  AXRowCommandItem,\n  AXRowCommandItemClickEvent,\n} from '@acorex/components/data-table';\nimport { AXDecoratorModule } from '@acorex/components/decorators';\nimport { AXDialogModule } from '@acorex/components/dialog';\nimport { AXDrawerModule } from '@acorex/components/drawer';\nimport { AXDropdownModule } from '@acorex/components/dropdown';\nimport { AXFormModule } from '@acorex/components/form';\nimport { AXLoadingModule } from '@acorex/components/loading';\nimport { AXPopoverModule } from '@acorex/components/popover';\nimport { AXSearchBoxModule } from '@acorex/components/search-box';\nimport { AXTabsModule } from '@acorex/components/tabs';\nimport { AXTooltipModule } from '@acorex/components/tooltip';\nimport { AXTranslationModule } from '@acorex/core/translation';\nimport { AXUnsubscriber } from '@acorex/core/utils';\nimport { AXPAuthModule } from '@acorex/platform/auth';\nimport {\n  AXPGridLayoutDirective,\n  AXPStickyDirective,\n} from '@acorex/platform/common';\nimport { AXPLayoutBuilderModule } from '@acorex/platform/layout/builder';\nimport { AXPEntityDetailListViewModel } from '@acorex/platform/layout/entity';\nimport { AXPEntityCreateEvent, AXPEntityDeletedEvent } from '@acorex/platform/layouts';\nimport { AXPLayoutThemeService } from '@acorex/platform/themes/shared';\nimport { AXPWidgetsModule } from '@acorex/platform/widgets';\nimport { AXPWorkflowService, ofType } from '@acorex/platform/workflow';\nimport { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  Input,\n  ViewChild,\n  ViewEncapsulation,\n  computed,\n  effect,\n  inject,\n} from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { RouterModule } from '@angular/router';\n\nimport { Subject, takeUntil } from 'rxjs';\n\n@Component({\n  selector: 'axp-entity-detail-list-view',\n  templateUrl: 'entity-detail-list-view.component.html',\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [AXUnsubscriber],\n  imports: [\n    CommonModule,\n    FormsModule,\n    RouterModule,\n    AXButtonModule,\n    AXDecoratorModule,\n    AXBadgeModule,\n    AXDropdownModule,\n    AXPopoverModule,\n    AXFormModule,\n    AXActionSheetModule,\n    AXDrawerModule,\n    AXDialogModule,\n    AXLoadingModule,\n    AXTabsModule,\n    AXTooltipModule,\n    AXBreadcrumbsModule,\n    AXSearchBoxModule,\n    AXDataTableModule,\n    //\n    AXPLayoutBuilderModule,\n    AXPWidgetsModule,\n    AXPStickyDirective,\n    AXPGridLayoutDirective,\n    AXPAuthModule,\n    AXTranslationModule,\n  ],\n  standalone: true,\n})\nexport class AXPEntityDetailListViewComponent {\n  private workflow = inject(AXPWorkflowService);\n  protected store = inject(AXPLayoutThemeService)\n\n  @Input('viewModel')\n  vm: AXPEntityDetailListViewModel;\n\n  protected focusedRow: any;\n  //\n  @ViewChild('grid') grid!: AXDataTableComponent;\n\n  constructor(\n    private actionSheetService: AXActionSheetService,\n    private unsubscriber: AXUnsubscriber,\n  ) {\n    effect(\n      () => {\n        this.grid.selectedRows = this.vm.selectedItems();\n      },\n      { allowSignalWrites: true }\n    );\n    this.subscribeActionEvents();\n  }\n\n\n  private readonly destroyed = new Subject<void>();\n\n  handleChangeSearchValue(e: AXValueChangedEvent) {\n    if (e.isUserInteraction) {\n      this.vm.applyInlineFilter(e.value);\n    }\n  }\n\n  protected subscribeActionEvents() {\n    this.workflow.events$\n      .pipe(ofType(AXPEntityDeletedEvent, AXPEntityCreateEvent))\n      .pipe(takeUntil(this.destroyed))\n      .subscribe((event) => {\n        console.log(event);\n        this.grid.refresh();\n      });\n  }\n\n  ngAfterViewInit(): void {\n    // this.grid.refresh();\n  }\n\n  protected dropdownRowItems = computed<AXRowCommandItem[]>(() => {\n    return this.vm.secondaryRowActions().map(\n      (c) =>\n      ({\n        icon: c.icon,\n        name: c.name,\n        text: c.title,\n        color: c.color,\n      } as AXRowCommandItem)\n    );\n  });\n\n  protected commandRowItems = computed<AXRowCommandItem[]>(() => {\n    return this.vm.primaryRowActions().map((c) => {\n      return {\n        icon: c.icon,\n        name: c.name,\n        text: c.title,\n        color: c.color,\n      } as AXRowCommandItem;\n    });\n  });\n\n  protected handleRowDbClick(e: AXDataTableRowDbClick) {\n    const item = this.dropdownRowItems()?.[0];\n    if (item) {\n      const d: AXRowCommandItemClickEvent = {\n        component: e.component,\n        name: item.name,\n        data: e.data,\n      };\n      this.handleRowCommandClick(d);\n    }\n  }\n\n  protected getCommandRowItems = (): AXRowCommandItem[] => {\n    return this.commandRowItems();\n  };\n\n  protected getDropdownRowItems = (rowData: unknown): Promise<AXRowCommandItem[]> => {\n    return Promise.resolve(this.dropdownRowItems());\n  };\n\n  protected async handleSelectedRowsChange(rows: unknown[]) {\n    this.vm.selectedItems.set(rows);\n  }\n\n  protected async handleRowCommandClick(e: AXRowCommandItemClickEvent) {\n    this.vm.executeCommand(e.name, e.data);\n  }\n\n  protected destroy() {\n    this.destroyed.next();\n    this.destroyed.complete();\n  }\n\n  ngOnDestroy(): void {\n    this.destroy();\n  }\n}\n","<div class=\"ax-flex ax-p-2\">\n  <div class=\"ax-flex ax-flex-col ax-items-end ax-gap-3 ax-flex-1 ax-overflow-auto ax-min-h-72\">\n    <div class=\"ax-flex ax-justify-between ax-items-center ax-w-full\">\n      <div class=\"ax-flex ax-justify-between ax-items-center\">\n        <div class=\"ax-flex ax-justify-start ax-items-center ax-gap-4\">\n          @if(vm.hasSelectedItems()) {\n          <div class=\"ax-flex ax-gap-3 ax-items-center ax-h-10\">\n            <span class=\"ax-text-xl ax-font-bold\">\n              {{ vm.selectedItems().length }} {{ 't(\"itemsSelected\", { scope: \"common\" })' | translate | async }}\n            </span>\n            <span\n              (click)=\"vm.clearSelection()\"\n              class=\"ax-text-sm ax-text-primary dark:ax-text-primary-300 ax-underline ax-cursor-pointer\"\n              >{{ 't(\"unselect\", { scope: \"common\" })' | translate | async }}</span\n            >\n          </div>\n\n          } @else { @if(vm.hasInlineFilters() && !store.isSmall()) {\n          <div class=\"ax-w-72\">\n            <ax-search-box\n              [placeholder]=\"('widget.lookup.search' | translate | async) + vm.inlineFiltersPlaceholders().join(', ')\"\n              (onValueChanged)=\"handleChangeSearchValue($event)\"\n              ><ax-clear-button></ax-clear-button\n            ></ax-search-box>\n          </div>\n          } }\n        </div>\n      </div>\n      <div class=\"ax-flex ax-items-center ax-gap-3\">\n        @for(tr of vm.primaryActions();track $index) {\n        <ax-button [text]=\"(tr.title | translate | async)!\" [color]=\"tr.color\" (onClick)=\"vm.executeCommand(tr.name)\">\n          <ax-prefix>\n            <ax-icon [icon]=\"tr.icon\"> </ax-icon>\n          </ax-prefix>\n        </ax-button>\n        } @if(vm.secondaryActions().length) {\n        <ax-button [text]=\"store.isSmall() ? null : ('actions' | translate | async)\" color=\"ghost\">\n          <ax-prefix>\n            <i class=\"fa-solid fa-ellipsis-vertical\"></i>\n          </ax-prefix>\n          <ax-dropdown-panel>\n            <ax-button-item-list>\n              @for(tr of vm.secondaryActions();track $index) {\n              <ng-container>\n                @if(tr.separated && !$first) {\n                <ax-divider></ax-divider>\n                }\n                <ax-button-item\n                  [text]=\"(tr.title | translate | async)!\"\n                  class=\"ax-font-semibold ax-text-{{ tr.color }}\"\n                  (onClick)=\"vm.executeCommand(tr.name)\"\n                >\n                  <ax-prefix>\n                    <ax-icon [icon]=\"tr.icon\"> </ax-icon>\n                  </ax-prefix>\n                </ax-button-item>\n              </ng-container>\n              }\n            </ax-button-item-list>\n          </ax-dropdown-panel>\n        </ax-button>\n        }\n      </div>\n    </div>\n\n    <ax-data-table\n      #grid\n      [showFooter]=\"false\"\n      class=\"ax-flex-1\"\n      [paging]=\"true\"\n      [fetchDataMode]=\"'manual'\"\n      [loading]=\"{ enabled: true, animation: true }\"\n      [dataSource]=\"vm.dataSource\"\n      (selectedRowsChange)=\"handleSelectedRowsChange($event)\"\n      (onRowDbClick)=\"handleRowDbClick($event)\"\n    >\n      <ax-select-column fixed=\"start\" [width]=\"'50px'\"></ax-select-column>\n      @for(col of vm.columns();track col.name) { @if(col.visible) {\n      <axp-widget-column-renderer\n        [caption]=\"col.title | translate | async\"\n        [node]=\"col.node()\"\n      ></axp-widget-column-renderer>\n      } } @if(getCommandRowItems().length){\n\n      <ax-command-column\n        fixed=\"end\"\n        [width]=\"getCommandRowItems().length * 60 + 'px'\"\n        [items]=\"getCommandRowItems()\"\n        (onItemClick)=\"handleRowCommandClick($event)\"\n      ></ax-command-column>\n\n      } @if(dropdownRowItems().length){\n      <ax-dropdown-command-column\n        fixed=\"end\"\n        [width]=\"'60px'\"\n        [items]=\"getDropdownRowItems\"\n        (onItemClick)=\"handleRowCommandClick($event)\"\n      ></ax-dropdown-command-column>\n      }\n    </ax-data-table>\n  </div>\n</div>\n"]}
|
|
@@ -18,14 +18,14 @@ import { AXTabsModule } from '@acorex/components/tabs';
|
|
|
18
18
|
import { AXTooltipModule } from '@acorex/components/tooltip';
|
|
19
19
|
import { AXTranslationModule } from '@acorex/core/translation';
|
|
20
20
|
import { AXPAuthModule } from '@acorex/platform/auth';
|
|
21
|
-
import { AXPGridLayoutDirective, AXPStickyDirective
|
|
21
|
+
import { AXPGridLayoutDirective, AXPStickyDirective } from '@acorex/platform/common';
|
|
22
22
|
import { AXPLayoutBuilderModule } from '@acorex/platform/layout/builder';
|
|
23
|
+
import { AXPLayoutThemeService } from '@acorex/platform/themes/shared';
|
|
23
24
|
import { AXPWidgetsModule } from '@acorex/platform/widgets';
|
|
24
25
|
import { CommonModule } from '@angular/common';
|
|
25
26
|
import { FormsModule } from '@angular/forms';
|
|
26
27
|
import { AXPListViewOptionsColumnsComponent } from './list-view-option-columns/list-view-option-columns.component';
|
|
27
28
|
import { AXPListViewOptionSortingComponent } from './list-view-option-sorting/list-view-option-sorting.component';
|
|
28
|
-
import { AXPLayoutThemeService } from '@acorex/platform/themes/shared';
|
|
29
29
|
import * as i0 from "@angular/core";
|
|
30
30
|
import * as i1 from "@acorex/components/action-sheet";
|
|
31
31
|
import * as i2 from "@acorex/core/platform";
|
|
@@ -90,21 +90,21 @@ export class AXPEntityMasterListViewComponent {
|
|
|
90
90
|
this.vm.setView();
|
|
91
91
|
}
|
|
92
92
|
closeDrawer(name, collapsed) {
|
|
93
|
-
if (collapsed) {
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
}
|
|
93
|
+
// if (collapsed) {
|
|
94
|
+
// switch (name) {
|
|
95
|
+
// case 'conditions':
|
|
96
|
+
// //this.loader.resetConditions();
|
|
97
|
+
// break;
|
|
98
|
+
// case 'columns':
|
|
99
|
+
// this.vm.applyColumns();
|
|
100
|
+
// break;
|
|
101
|
+
// case 'sorts':
|
|
102
|
+
// //this.vm.resetSorts();
|
|
103
|
+
// break;
|
|
104
|
+
// default:
|
|
105
|
+
// break;
|
|
106
|
+
// }
|
|
107
|
+
// }
|
|
108
108
|
}
|
|
109
109
|
handleChangeSearchValue(e) {
|
|
110
110
|
if (e.isUserInteraction) {
|
|
@@ -187,4 +187,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
|
187
187
|
type: ViewChild,
|
|
188
188
|
args: ['grid']
|
|
189
189
|
}] } });
|
|
190
|
-
//# 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":"AAAA,OAAO,EAAE,mBAAmB,EAAE,oBAAoB,EAAE,MAAM,iCAAiC,CAAC;AAC5F,OAAO,EACL,oBAAoB,EACpB,iBAAiB,GAIlB,MAAM,+BAA+B,CAAC;AACvC,OAAO,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAC3D,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AACnD,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,SAAS,EACT,iBAAiB,EACjB,QAAQ,EACR,MAAM,EACN,MAAM,EACN,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAG/D,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AACzD,OAAO,EAAE,mBAAmB,EAAE,MAAM,gCAAgC,CAAC;AACrE,OAAO,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAE3D,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAClE,OAAO,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAC3D,OAAO,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAC;AAC/D,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AACvD,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAClE,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AACvD,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;AAC/D,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,EACL,sBAAsB,EACtB,kBAAkB,GACnB,MAAM,yBAAyB,CAAC;AACjC,OAAO,EAAE,sBAAsB,EAAE,MAAM,iCAAiC,CAAC;AAEzE,OAAO,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAC5D,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,kCAAkC,EAAE,MAAM,+DAA+D,CAAC;AACnH,OAAO,EAAE,iCAAiC,EAAE,MAAM,+DAA+D,CAAC;AAClH,OAAO,EAAE,qBAAqB,EAAE,MAAM,gCAAgC,CAAC;;;;;;;;;;;;;;;;;AAwCvE,MAAM,OAAO,gCAAgC;IAc3C,YAAoB,kBAAwC,EAAY,QAAoB;QAAxE,uBAAkB,GAAlB,kBAAkB,CAAsB;QAAY,aAAQ,GAAR,QAAQ,CAAY;QAbpF,gBAAW,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC;QAE1B,OAAE,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAiC,CAAC;QAE7F,EAAE;QACQ,UAAK,GAAG,MAAM,CAAC,qBAAqB,CAAC,CAAC;QAGhD,EAAE;QACQ,mBAAc,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC;QA+C9B,qBAAgB,GAAG,QAAQ,CAAqB,GAAG,EAAE;YAC7D,OAAO,IAAI,CAAC,EAAE,CAAC,mBAAmB,EAAE,CAAC,GAAG,CACtC,CAAC,CAAC,EAAE,EAAE,CACN,CAAC;gBACC,IAAI,EAAE,CAAC,CAAC,IAAI;gBACZ,IAAI,EAAE,CAAC,CAAC,IAAI;gBACZ,IAAI,EAAE,CAAC,CAAC,KAAK;gBACb,KAAK,EAAE,CAAC,CAAC,KAAK;aACM,CAAA,CACvB,CAAC;QACJ,CAAC,CAAC,CAAC;QAEK,oBAAe,GAAG,QAAQ,CAAqB,GAAG,EAAE;YAC1D,OAAO,IAAI,CAAC,EAAE,CAAC,iBAAiB,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;gBAC3C,OAAO;oBACL,IAAI,EAAE,CAAC,CAAC,IAAI;oBACZ,IAAI,EAAE,CAAC,CAAC,IAAI;oBACZ,IAAI,EAAE,CAAC,CAAC,KAAK;oBACb,KAAK,EAAE,CAAC,CAAC,KAAK;iBACK,CAAC;YACxB,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAeO,wBAAmB,GAAG,CAAC,OAAgB,EAA+B,EAAE;YAChF,OAAO,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAC;QAClD,CAAC,CAAC;QAEQ,uBAAkB,GAAG,GAAuB,EAAE;YACtD,OAAO,IAAI,CAAC,eAAe,EAAE,CAAC;QAChC,CAAC,CAAC;QApFA,MAAM,CACJ,GAAG,EAAE;YACH,IAAI,CAAC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;QACnD,CAAC,EACD,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAC5B,CAAC;QACF,EAAE;QACF,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YAC9B,IAAI,CAAC,CAAC,MAAM,IAAI,SAAS,EAAE,CAAC;gBAC1B,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YACtB,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,eAAe;QACb,IAAI,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC;IACpB,CAAC;IAES,WAAW,CAAC,IAAY,EAAE,SAAkB;QACpD,IAAI,SAAS,EAAE,CAAC;YACd,QAAQ,IAAI,EAAE,CAAC;gBACb,KAAK,YAAY;oBACf,gCAAgC;oBAChC,MAAM;gBACR,KAAK,SAAS;oBACZ,IAAI,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC;oBACvB,MAAM;gBACR,KAAK,OAAO;oBACV,uBAAuB;oBACvB,MAAM;gBACR;oBACE,MAAM;YACV,CAAC;QACH,CAAC;IACH,CAAC;IAED,uBAAuB,CAAC,CAAsB;QAC5C,IAAI,CAAC,CAAC,iBAAiB,EAAE,CAAC;YACxB,IAAI,CAAC,EAAE,CAAC,iBAAiB,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;QACrC,CAAC;IACH,CAAC;IAyBS,gBAAgB,CAAC,CAAwB;QACjD,qCAAqC;QACrC,MAAM,IAAI,GAAG,CAAC,GAAG,IAAI,CAAC,eAAe,EAAE,EAAE,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QACxE,IAAI,IAAI,EAAE,CAAC;YACT,MAAM,CAAC,GAA+B;gBACpC,SAAS,EAAE,CAAC,CAAC,SAAS;gBACtB,IAAI,EAAE,IAAI,CAAC,IAAI;gBACf,IAAI,EAAE,CAAC,CAAC,IAAI;aACb,CAAC;YACF,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QAChC,CAAC;IACH,CAAC;IAUS,KAAK,CAAC,qBAAqB,CAAC,CAA6B;QACjE,IAAI,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC;IACzC,CAAC;IAES,KAAK,CAAC,wBAAwB,CAAC,IAAe;QACtD,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAClC,CAAC;IAES,cAAc,CAAI,KAAQ;QAClC,IAAI,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC;YACzD,OAAO,EAAE,CAAC;QACZ,CAAC;aAAM,CAAC;YACN,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IAES,eAAe;QACvB,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC;IAClD,CAAC;IAED,WAAW;QACT,IAAI,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC;IACpB,CAAC;8GA3HU,gCAAgC;kGAAhC,gCAAgC,sKCzF7C,2mYAyOsB,0hBDhLlB,YAAY,gNACZ,WAAW,8BACX,YAAY,+QACZ,cAAc,8vBACd,iBAAiB,ucACjB,aAAa,yIACb,gBAAgB,wPAChB,eAAe,8BACf,YAAY,8BACZ,mBAAmB,8BACnB,cAAc,6UACd,cAAc,8BACd,eAAe,8BACf,YAAY,8BACZ,eAAe,8BACf,mBAAmB,iPACnB,iBAAiB,4XACjB,iBAAiB,u7BACjB,mBAAmB;gBACnB,EAAE;gBACF,sBAAsB,0NACtB,gBAAgB,+BAChB,kBAAkB,oLAElB,aAAa;gBACb,EAAE;gBACF,kCAAkC,uHAClC,iCAAiC;;2FAKxB,gCAAgC;kBAtC5C,SAAS;oCAGO,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM,WACtC;wBACP,YAAY;wBACZ,WAAW;wBACX,YAAY;wBACZ,cAAc;wBACd,iBAAiB;wBACjB,aAAa;wBACb,gBAAgB;wBAChB,eAAe;wBACf,YAAY;wBACZ,mBAAmB;wBACnB,cAAc;wBACd,cAAc;wBACd,eAAe;wBACf,YAAY;wBACZ,eAAe;wBACf,mBAAmB;wBACnB,iBAAiB;wBACjB,iBAAiB;wBACjB,mBAAmB;wBACnB,EAAE;wBACF,sBAAsB;wBACtB,gBAAgB;wBAChB,kBAAkB;wBAClB,sBAAsB;wBACtB,aAAa;wBACb,EAAE;wBACF,kCAAkC;wBAClC,iCAAiC;wBACjC,mBAAmB;qBACpB,cACW,IAAI;kHAcG,IAAI;sBAAtB,SAAS;uBAAC,MAAM","sourcesContent":["import { AXActionSheetModule, AXActionSheetService } from '@acorex/components/action-sheet';\nimport {\n  AXDataTableComponent,\n  AXDataTableModule,\n  AXDataTableRowDbClick,\n  AXRowCommandItem,\n  AXRowCommandItemClickEvent,\n} from '@acorex/components/data-table';\nimport { AXDrawerModule } from '@acorex/components/drawer';\nimport { AXPlatform } from '@acorex/core/platform';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ViewChild,\n  ViewEncapsulation,\n  computed,\n  effect,\n  inject,\n  signal,\n} from '@angular/core';\nimport { ActivatedRoute, RouterModule } from '@angular/router';\nimport { Store } from '@ngrx/store';\n\nimport { AXBadgeModule } from '@acorex/components/badge';\nimport { AXBreadcrumbsModule } from '@acorex/components/breadcrumbs';\nimport { AXButtonModule } from '@acorex/components/button';\nimport { AXValueChangedEvent } from '@acorex/components/common';\nimport { AXDecoratorModule } from '@acorex/components/decorators';\nimport { AXDialogModule } from '@acorex/components/dialog';\nimport { AXDropdownModule } from '@acorex/components/dropdown';\nimport { AXFormModule } from '@acorex/components/form';\nimport { AXLoadingModule } from '@acorex/components/loading';\nimport { AXPopoverModule } from '@acorex/components/popover';\nimport { AXSearchBoxModule } from '@acorex/components/search-box';\nimport { AXTabsModule } from '@acorex/components/tabs';\nimport { AXTooltipModule } from '@acorex/components/tooltip';\nimport { AXTranslationModule } from '@acorex/core/translation';\nimport { AXPAuthModule } from '@acorex/platform/auth';\nimport {\n  AXPGridLayoutDirective,\n  AXPStickyDirective,\n} from '@acorex/platform/common';\nimport { AXPLayoutBuilderModule } from '@acorex/platform/layout/builder';\nimport { AXPEntityMasterListViewModel } from '@acorex/platform/layout/entity';\nimport { AXPWidgetsModule } from '@acorex/platform/widgets';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\nimport { AXPListViewOptionsColumnsComponent } from './list-view-option-columns/list-view-option-columns.component';\nimport { AXPListViewOptionSortingComponent } from './list-view-option-sorting/list-view-option-sorting.component';\nimport { AXPLayoutThemeService } from '@acorex/platform/themes/shared';\n\n@Component({\n  templateUrl: 'entity-master-list-view.component.html',\n  styleUrls: ['entity-master-list-view.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    CommonModule,\n    FormsModule,\n    RouterModule,\n    AXButtonModule,\n    AXDecoratorModule,\n    AXBadgeModule,\n    AXDropdownModule,\n    AXPopoverModule,\n    AXFormModule,\n    AXActionSheetModule,\n    AXDrawerModule,\n    AXDialogModule,\n    AXLoadingModule,\n    AXTabsModule,\n    AXTooltipModule,\n    AXBreadcrumbsModule,\n    AXSearchBoxModule,\n    AXDataTableModule,\n    AXTranslationModule,\n    //\n    AXPLayoutBuilderModule,\n    AXPWidgetsModule,\n    AXPStickyDirective,\n    AXPGridLayoutDirective,\n    AXPAuthModule,\n    //\n    AXPListViewOptionsColumnsComponent,\n    AXPListViewOptionSortingComponent,\n    AXTranslationModule,\n  ],\n  standalone: true,\n})\nexport class AXPEntityMasterListViewComponent {\n  private activeRoute = inject(ActivatedRoute);\n\n  protected readonly vm = this.activeRoute.snapshot.data['vm'] as AXPEntityMasterListViewModel;\n\n  //\n  protected store = inject(AXPLayoutThemeService);\n  //\n  protected focusedRow: any;\n  //\n  protected searchBarShown = signal(true);\n\n  @ViewChild('grid') grid!: AXDataTableComponent;\n\n  constructor(private actionSheetService: AXActionSheetService, protected platform: AXPlatform) {\n    effect(\n      () => {\n        this.grid.selectedRows = this.vm.selectedItems();\n      },\n      { allowSignalWrites: true }\n    );\n    //\n    this.vm.events$.subscribe((e) => {\n      if (e.action == 'refresh') {\n        this.grid.refresh();\n      }\n    });\n  }\n\n  ngAfterViewInit() {\n    this.vm.setView();\n  }\n\n  protected closeDrawer(name: string, collapsed: boolean) {\n    if (collapsed) {\n      switch (name) {\n        case 'conditions':\n          //this.loader.resetConditions();\n          break;\n        case 'columns':\n          this.vm.applyColumns();\n          break;\n        case 'sorts':\n          //this.vm.resetSorts();\n          break;\n        default:\n          break;\n      }\n    }\n  }\n\n  handleChangeSearchValue(e: AXValueChangedEvent) {\n    if (e.isUserInteraction) {\n      this.vm.applyInlineFilter(e.value);\n    }\n  }\n\n  protected dropdownRowItems = computed<AXRowCommandItem[]>(() => {\n    return this.vm.secondaryRowActions().map(\n      (c) =>\n      ({\n        icon: c.icon,\n        name: c.name,\n        text: c.title,\n        color: c.color,\n      } as AXRowCommandItem)\n    );\n  });\n\n  private commandRowItems = computed<AXRowCommandItem[]>(() => {\n    return this.vm.primaryRowActions().map((c) => {\n      return {\n        icon: c.icon,\n        name: c.name,\n        text: c.title,\n        color: c.color,\n      } as AXRowCommandItem;\n    });\n  });\n\n  protected handleRowDbClick(e: AXDataTableRowDbClick) {\n    //TODO: find a way for default action\n    const item = [...this.commandRowItems(), ...this.dropdownRowItems()][0];\n    if (item) {\n      const d: AXRowCommandItemClickEvent = {\n        component: e.component,\n        name: item.name,\n        data: e.data,\n      };\n      this.handleRowCommandClick(d);\n    }\n  }\n\n  protected getDropdownRowItems = (rowData: unknown): Promise<AXRowCommandItem[]> => {\n    return Promise.resolve(this.dropdownRowItems());\n  };\n\n  protected getCommandRowItems = (): AXRowCommandItem[] => {\n    return this.commandRowItems();\n  };\n\n  protected async handleRowCommandClick(e: AXRowCommandItemClickEvent) {\n    this.vm.executeCommand(e.name, e.data);\n  }\n\n  protected async handleSelectedRowsChange(rows: unknown[]) {\n    this.vm.selectedItems.set(rows);\n  }\n\n  protected makeResponsive<t>(value: t): t | string {\n    if (this.platform.is('Mobile') || this.platform.is('SM')) {\n      return '';\n    } else {\n      return value;\n    }\n  }\n\n  protected toggleSearchBar() {\n    this.searchBarShown.set(!this.searchBarShown());\n  }\n\n  ngOnDestroy(): void {\n    this.vm.destroy();\n  }\n}\n","<ax-drawer-container>\n  <ax-content class=\"ax-flex ax-flex-col ax-overflow-hidden\" #content>\n    <div\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\">\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\"\n        [axpSticky]=\"'ax-bg-surface ax-px-6 ax-py-3 -ax-mx-6 ax-shadow-xl'\" [stickyParent]=\"content.getHostElement()\">\n        <!-------- Begin Toolbar  -------->\n        <!-------- Begin Line 1  -------->\n        <div class=\"ax-flex ax-justify-between ax-items-center\">\n          <!-------- Begin Title  -------->\n          <div class=\"ax-flex ax-gap-1 ax-items-center\">\n            <div class=\"ax-flex ax-flex-col ax-gap-2 ax-transition\">\n              <div class=\"ax-text-xl md:ax-text-2xl ax-font-bold\">{{ vm.title() | translate | async }}</div>\n              @if(vm.description() ) {\n              <div class=\"ax-text-sm ax-text-neutral-600\" [class.ax-hidden]=\"sticky.isSticky\">\n                {{ vm.description()! | translate | async }}\n              </div>\n              }\n              <ax-breadcrumbs class=\"child:ax-font-normal child:ax-text-neutral-400\"\n                [class.ax-hidden]=\"store.isSmall()\">\n                <ng-template #divider>\n                  <i class=\"fa-solid fa-chevron-right ax-text-xs ax-mx-2\"></i>\n                </ng-template>\n                @for(b of vm.beardcrumbs();track $index;let last=$last) {\n                <ax-breadcrumbs-item [active]=\"last\" [class.!ax-font-semibold]=\"last\"\n                  [class.!ax-text-neutral-600]=\"last\" [routerLink]=\"b.url\">\n                  @if(b.icon) {\n                  <i [class]=\"b.icon\"></i>\n                  }\n                  {{ b.title | translate | async }}\n                </ax-breadcrumbs-item>\n                }\n              </ax-breadcrumbs>\n            </div>\n          </div>\n          <!-------- Finish Title  -------->\n          <!--------------------------------------------------------------->\n          <!-- Begin Action Menu  -->\n          <div class=\"ax-flex ax-items-center ax-gap-3\">\n            @for(tr of vm.primaryActions();track $index) {\n            <ax-button [text]=\"tr.title | translate | async\" [color]=\"tr.color\" (onClick)=\"vm.executeCommand(tr.name)\">\n              <ax-prefix>\n                <ax-icon [icon]=\"tr.icon\"> </ax-icon>\n              </ax-prefix>\n            </ax-button>\n            } @if(vm.secondaryActions().length) {\n            <ax-button [text]=\"(store.isSmall()) ? null : ('actions' | translate | async)\" color=\"ghost\">\n              <ax-prefix>\n                <i class=\"fa-solid fa-ellipsis-vertical\"></i>\n              </ax-prefix>\n              <ax-dropdown-panel>\n                <ax-button-item-list>\n                  @for(tr of vm.secondaryActions();track $index;let first=$first) {\n                  <ng-container>\n                    @if(tr.separated && !$first) {\n                    <ax-divider></ax-divider>\n                    }\n                    <ax-button-item [text]=\"(tr.title | translate | async)!\"\n                      class=\"ax-font-semibold ax-text-{{ tr.color }}\" (onClick)=\"vm.executeCommand(tr.name)\">\n                      <ax-prefix>\n                        <ax-icon [icon]=\"tr.icon\"> </ax-icon>\n                      </ax-prefix>\n                    </ax-button-item>\n                  </ng-container>\n                  }\n                </ax-button-item-list>\n              </ax-dropdown-panel>\n            </ax-button>\n            }\n          </div>\n          <!-- Finish Action Menu  -->\n        </div>\n\n        <!-------- Finish Line 1  -------->\n\n        <!-------- Begin Line 2 -------->\n        <div class=\"ax-flex ax-justify-between ax-items-center\">\n          <div class=\"ax-flex ax-justify-start ax-items-center ax-gap-4\">\n            <!-------- Begin Selection  -------->\n\n            @if(vm.hasSelectedItems()) {\n            <div class=\"ax-flex ax-gap-3 ax-items-center ax-h-10\">\n              <span class=\"ax-text-xl ax-font-bold\">\n                {{ vm.selectedItems().length }} {{ 't(\"itemsSelected\", { scope: \"common\" })' | translate | async }}\n              </span>\n              <span (click)=\"vm.clearSelection()\"\n                class=\"ax-text-sm ax-text-primary dark:ax-text-primary-300 ax-underline ax-cursor-pointer\">{{\n                't(\"unselect\", { scope: \"common\" })' | translate | async }}</span>\n            </div>\n\n            <!-------- Finish Selection  -------->\n\n            } @else {\n\n            <!-------- Begin View  -------->\n\n            <ax-button [text]=\"vm.view().title | translate | async\" #views color=\"ghost\">\n              <ax-prefix>\n                <i class=\"fa-solid fa-eye\"></i>\n              </ax-prefix>\n              <ax-suffix>\n                <i class=\"fa-solid fa-caret-down\"></i>\n              </ax-suffix>\n              <ax-dropdown-panel [adaptivityEnabled]=\"true\">\n                <ax-button-item-list class=\"ax-bg-surface ax-p-2\">\n                  <ax-title class=\"ax-font-bold ax-opacity-100\">{{\n                    'entity.public-view' | translate | async\n                    }}</ax-title>\n                  <ax-button-item *ngFor=\"let v of vm.views()\" [text]=\"(v.title | translate | async)!\"\n                    [class.ax-bg-on-surface]=\"vm.view() == v\" (onClick)=\"vm.setView(v.name)\"></ax-button-item>\n                  <!-- <ax-title class=\"ax-font-bold ax-opacity-100\" *ngIf=\"hasCustomViews$ | async\">Created by me</ax-title>\n                <ax-button-item class=\"ax-pe-4 ax-flex ax-justify-between\" *ngFor=\"let v of customViews$ | async\"\n                  [text]=\"v.title\" [class.ax-bg-on-surface]=\"(view$ | async) == v\" (onClick)=\"loader.setView(v.name)\">\n                  <ax-suffix>\n                    <ax-button (onClick)=\"updateViewPopup($event, v)\" class=\"ax-xs\" look=\"none\">\n                      <ax-icon class=\"far fa-edit\"> </ax-icon>\n                    </ax-button>\n                  </ax-suffix>\n                </ax-button-item> -->\n                  <!-- <ng-container *feature=\"'axp-entity-list-custom-view'\">\n                  <ax-divider></ax-divider>\n                  <ax-button-item text=\"Add Custom View\" (onClick)=\"addCustomViewPopup()\"\n                    class=\"ax-font-semibold ax-text-primary\"></ax-button-item>\n                </ng-container> -->\n                </ax-button-item-list>\n              </ax-dropdown-panel>\n            </ax-button>\n            <!-------- Finish View  -------->\n\n            <!-------- Begin Inline Search   -------->\n            @if(vm.hasInlineFilters() && !(this.platform.is('Mobile') || this.platform.is('SM'))) {\n            <div class=\"ax-w-72\">\n              <ax-search-box\n                [placeholder]=\"('widget.lookup.search' | translate | async) + vm.inlineFiltersPlaceholders().join(', ')\"\n                (onValueChanged)=\"handleChangeSearchValue($event)\"><ax-clear-button></ax-clear-button></ax-search-box>\n            </div>\n            } }\n            <!-------- Finish Inline Search -------->\n          </div>\n          <!-- Begin View Action Menu  -->\n          @if(!vm.hasSelectedItems()) {\n          <div class=\"ax-flex ax-gap-3\">\n            @if(vm.hasInlineFilters() && (this.platform.is('Mobile') || this.platform.is('SM'))) {\n            <ax-button (onClick)=\"toggleSearchBar()\" color=\"ghost\">\n              <ax-icon class=\"fa-solid fa-search\"> </ax-icon> </ax-button>}\n\n            <ax-button [text]=\"makeResponsive('entity.columns' | translate | async)\" color=\"ghost\"\n              (onClick)=\"columnsDrawer.open()\">\n              <ax-prefix>\n                <i class=\"fa-solid fa-bars\"></i>\n              </ax-prefix>\n              <ax-suffix>\n                <ax-badge [text]=\"makeResponsive(vm.visibleColumnCount().toString())\" color=\"primary\"></ax-badge>\n              </ax-suffix>\n            </ax-button>\n            <ax-button text=\"Filters\" color=\"ghost\" (onClick)=\"conditionsDrawer.open()\"\n              *feature=\"'axp-entity-list-advance-filter'\">\n              <ax-prefix>\n                <i class=\"fa-solid fa-sliders\"></i>\n              </ax-prefix>\n              <ax-suffix>\n                <ax-badge text=\"3\" color=\"primary\"></ax-badge>\n              </ax-suffix>\n            </ax-button>\n\n            @if(vm.canSort()) {\n            <ax-button [text]=\"makeResponsive('entity.sort' | translate | async)\" color=\"ghost\"\n              (onClick)=\"sortsDrawer.open()\">\n              <ax-prefix>\n                <i class=\"fa-solid fa-bars-sort\"></i>\n              </ax-prefix>\n              @if(vm.sortedCount()) {\n              <ax-suffix>\n                <ax-badge [text]=\"makeResponsive(vm.sortedCount().toString())\" color=\"primary\"></ax-badge>\n              </ax-suffix>\n              }\n            </ax-button>\n            }\n          </div>\n          }\n          <!-- Finish View Action Menu  -->\n        </div>\n        <div>\n          @if(vm.hasInlineFilters() && (this.platform.is('Mobile') || this.platform.is('SM'))) {\n          <ax-search-box [class.collapsed-search-box]=\"searchBarShown()\" class=\"ax-transition-all\"\n            [placeholder]=\"('widget.lookup.search' | translate | async) + vm.inlineFiltersPlaceholders().join(', ')\"\n            (onValueChanged)=\"handleChangeSearchValue($event)\"><ax-clear-button></ax-clear-button></ax-search-box>\n          }\n        </div>\n        <!-------- Finish Line 2  -------->\n\n        <!----- Finish Toolbar  ----->\n      </div>\n    </div>\n    <!----- Begin DataTable  ----->\n    <div class=\"ax-flex ax-flex-1 ax-px-6 ax-py-6 ax-pt-0 ax-overflow-auto\">\n      <ax-data-table #grid [showFooter]=\"false\" class=\"ax-flex-1\" [paging]=\"true\" [fetchDataMode]=\"'manual'\"\n        [loading]=\"{ enabled: true, animation: true }\" [dataSource]=\"vm.dataSource\"\n        (selectedRowsChange)=\"handleSelectedRowsChange($event)\" (onRowDbClick)=\"handleRowDbClick($event)\">\n        <ax-select-column fixed=\"start\" [width]=\"'50px'\"></ax-select-column>\n        @for(col of vm.columns();track col.name) { @if(col.visible) {\n        <axp-widget-column-renderer [caption]=\"(col.title | translate | async)!\"\n          [node]=\"col.node()\"></axp-widget-column-renderer>\n        } } @if(getCommandRowItems().length){\n\n        <ax-command-column fixed=\"end\" [width]=\"getCommandRowItems().length * 60 + 'px'\" [items]=\"getCommandRowItems()\"\n          (onItemClick)=\"handleRowCommandClick($event)\"></ax-command-column>\n\n        } @if(dropdownRowItems().length){\n        <ax-dropdown-command-column fixed=\"end\" [width]=\"'60px'\" [items]=\"getDropdownRowItems\"\n          (onItemClick)=\"handleRowCommandClick($event)\"></ax-dropdown-command-column>\n        }\n      </ax-data-table>\n    </div>\n    <!----- Finish DataTable  ----->\n  </ax-content>\n\n  <ax-drawer (collapsedChange)=\"closeDrawer('columns', $event)\" #columnsDrawer location=\"end\" [mode]=\"'overlay'\">\n    <ax-content class=\"ax-w-[85vw] md:ax-w-[45vw] lg:ax-w-[35vw] 2xl:ax-w-[20vw] ax-border-e\">\n      <axp-list-view-option-columns [viewModel]=\"vm\" (onClosed)=\"columnsDrawer.close()\"></axp-list-view-option-columns>\n    </ax-content>\n  </ax-drawer>\n  <ax-drawer (collapsedChange)=\"closeDrawer('conditions', $event)\" #conditionsDrawer location=\"end\" [mode]=\"'overlay'\">\n    <ax-content class=\"ax-w-[85vw] md:ax-w-[45vw] lg:ax-w-[35vw] 2xl:ax-w-[25vw] ax-border-e\">\n      <!-- <axp-list-view-option-conditions [loader]=\"loader\"\n        (onClosed)=\"conditionsDrawer.close()\"></axp-list-view-option-conditions> -->\n    </ax-content>\n  </ax-drawer>\n  <ax-drawer (collapsedChange)=\"closeDrawer('sorts', $event)\" #sortsDrawer location=\"end\" [mode]=\"'overlay'\">\n    <ax-content class=\"ax-w-[85vw] md:ax-w-[45vw] lg:ax-w-[35vw] 2xl:ax-w-[20vw] ax-border-e\">\n      <axp-list-view-option-sorting (onClosed)=\"sortsDrawer.close()\" [viewModel]=\"vm\"></axp-list-view-option-sorting>\n    </ax-content>\n  </ax-drawer>\n</ax-drawer-container>"]}
|
|
190
|
+
//# 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';\nimport {\n  AXDataTableComponent,\n  AXDataTableModule,\n  AXDataTableRowDbClick,\n  AXRowCommandItem,\n  AXRowCommandItemClickEvent,\n} from '@acorex/components/data-table';\nimport { AXDrawerModule } from '@acorex/components/drawer';\nimport { AXPlatform } from '@acorex/core/platform';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ViewChild,\n  ViewEncapsulation,\n  computed,\n  effect,\n  inject,\n  signal,\n} from '@angular/core';\nimport { ActivatedRoute, RouterModule } from '@angular/router';\n\nimport { AXBadgeModule } from '@acorex/components/badge';\nimport { AXBreadcrumbsModule } from '@acorex/components/breadcrumbs';\nimport { AXButtonModule } from '@acorex/components/button';\nimport { AXValueChangedEvent } from '@acorex/components/common';\nimport { AXDecoratorModule } from '@acorex/components/decorators';\nimport { AXDialogModule } from '@acorex/components/dialog';\nimport { AXDropdownModule } from '@acorex/components/dropdown';\nimport { AXFormModule } from '@acorex/components/form';\nimport { AXLoadingModule } from '@acorex/components/loading';\nimport { AXPopoverModule } from '@acorex/components/popover';\nimport { AXSearchBoxModule } from '@acorex/components/search-box';\nimport { AXTabsModule } from '@acorex/components/tabs';\nimport { AXTooltipModule } from '@acorex/components/tooltip';\nimport { AXTranslationModule } from '@acorex/core/translation';\nimport { AXPAuthModule } from '@acorex/platform/auth';\nimport { AXPGridLayoutDirective, AXPStickyDirective } from '@acorex/platform/common';\nimport { AXPLayoutBuilderModule } from '@acorex/platform/layout/builder';\nimport { AXPEntityMasterListViewModel } from '@acorex/platform/layout/entity';\nimport { AXPLayoutThemeService } from '@acorex/platform/themes/shared';\nimport { AXPWidgetsModule } from '@acorex/platform/widgets';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\nimport { AXPListViewOptionsColumnsComponent } from './list-view-option-columns/list-view-option-columns.component';\nimport { AXPListViewOptionSortingComponent } from './list-view-option-sorting/list-view-option-sorting.component';\n\n@Component({\n  templateUrl: 'entity-master-list-view.component.html',\n  styleUrls: ['entity-master-list-view.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    CommonModule,\n    FormsModule,\n    RouterModule,\n    AXButtonModule,\n    AXDecoratorModule,\n    AXBadgeModule,\n    AXDropdownModule,\n    AXPopoverModule,\n    AXFormModule,\n    AXActionSheetModule,\n    AXDrawerModule,\n    AXDialogModule,\n    AXLoadingModule,\n    AXTabsModule,\n    AXTooltipModule,\n    AXBreadcrumbsModule,\n    AXSearchBoxModule,\n    AXDataTableModule,\n    AXTranslationModule,\n    //\n    AXPLayoutBuilderModule,\n    AXPWidgetsModule,\n    AXPStickyDirective,\n    AXPGridLayoutDirective,\n    AXPAuthModule,\n    //\n    AXPListViewOptionsColumnsComponent,\n    AXPListViewOptionSortingComponent,\n    AXTranslationModule,\n  ],\n  standalone: true,\n})\nexport class AXPEntityMasterListViewComponent {\n  private activeRoute = inject(ActivatedRoute);\n\n  protected readonly vm = this.activeRoute.snapshot.data['vm'] as AXPEntityMasterListViewModel;\n\n  //\n  protected store = inject(AXPLayoutThemeService);\n  //\n  protected focusedRow: any;\n  //\n  protected searchBarShown = signal(true);\n\n  @ViewChild('grid') grid!: AXDataTableComponent;\n\n  constructor(private actionSheetService: AXActionSheetService, protected platform: AXPlatform) {\n    effect(\n      () => {\n        this.grid.selectedRows = this.vm.selectedItems();\n      },\n      { allowSignalWrites: true }\n    );\n    //\n    this.vm.events$.subscribe((e) => {\n      if (e.action == 'refresh') {\n        this.grid.refresh();\n      }\n    });\n  }\n\n  ngAfterViewInit() {\n    this.vm.setView();\n  }\n\n  protected closeDrawer(name: string, collapsed: boolean) {\n    // if (collapsed) {\n    //   switch (name) {\n    //     case 'conditions':\n    //       //this.loader.resetConditions();\n    //       break;\n    //     case 'columns':\n    //       this.vm.applyColumns();\n    //       break;\n    //     case 'sorts':\n    //       //this.vm.resetSorts();\n    //       break;\n    //     default:\n    //       break;\n    //   }\n    // }\n  }\n\n  handleChangeSearchValue(e: AXValueChangedEvent) {\n    if (e.isUserInteraction) {\n      this.vm.applyInlineFilter(e.value);\n    }\n  }\n\n  protected dropdownRowItems = computed<AXRowCommandItem[]>(() => {\n    return this.vm.secondaryRowActions().map(\n      (c) =>\n        ({\n          icon: c.icon,\n          name: c.name,\n          text: c.title,\n          color: c.color,\n        } as AXRowCommandItem)\n    );\n  });\n\n  private commandRowItems = computed<AXRowCommandItem[]>(() => {\n    return this.vm.primaryRowActions().map((c) => {\n      return {\n        icon: c.icon,\n        name: c.name,\n        text: c.title,\n        color: c.color,\n      } as AXRowCommandItem;\n    });\n  });\n\n  protected handleRowDbClick(e: AXDataTableRowDbClick) {\n    //TODO: find a way for default action\n    const item = [...this.commandRowItems(), ...this.dropdownRowItems()][0];\n    if (item) {\n      const d: AXRowCommandItemClickEvent = {\n        component: e.component,\n        name: item.name,\n        data: e.data,\n      };\n      this.handleRowCommandClick(d);\n    }\n  }\n\n  protected getDropdownRowItems = (rowData: unknown): Promise<AXRowCommandItem[]> => {\n    return Promise.resolve(this.dropdownRowItems());\n  };\n\n  protected getCommandRowItems = (): AXRowCommandItem[] => {\n    return this.commandRowItems();\n  };\n\n  protected async handleRowCommandClick(e: AXRowCommandItemClickEvent) {\n    this.vm.executeCommand(e.name, e.data);\n  }\n\n  protected async handleSelectedRowsChange(rows: unknown[]) {\n    this.vm.selectedItems.set(rows);\n  }\n\n  protected makeResponsive<t>(value: t): t | string {\n    if (this.platform.is('Mobile') || this.platform.is('SM')) {\n      return '';\n    } else {\n      return value;\n    }\n  }\n\n  protected toggleSearchBar() {\n    this.searchBarShown.set(!this.searchBarShown());\n  }\n\n  ngOnDestroy(): void {\n    this.vm.destroy();\n  }\n}\n","<ax-drawer-container>\n  <ax-content class=\"ax-flex ax-flex-col ax-overflow-hidden\" #content>\n    <div\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\">\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\"\n        [axpSticky]=\"'ax-bg-surface ax-px-6 ax-py-3 -ax-mx-6 ax-shadow-xl'\" [stickyParent]=\"content.getHostElement()\">\n        <!-------- Begin Toolbar  -------->\n        <!-------- Begin Line 1  -------->\n        <div class=\"ax-flex ax-justify-between ax-items-center\">\n          <!-------- Begin Title  -------->\n          <div class=\"ax-flex ax-gap-1 ax-items-center\">\n            <div class=\"ax-flex ax-flex-col ax-gap-2 ax-transition\">\n              <div class=\"ax-text-xl md:ax-text-2xl ax-font-bold\">{{ vm.title() | translate | async }}</div>\n              @if(vm.description() ) {\n              <div class=\"ax-text-sm ax-text-neutral-600\" [class.ax-hidden]=\"sticky.isSticky\">\n                {{ vm.description()! | translate | async }}\n              </div>\n              }\n              <ax-breadcrumbs class=\"child:ax-font-normal child:ax-text-neutral-400\"\n                [class.ax-hidden]=\"store.isSmall()\">\n                <ng-template #divider>\n                  <i class=\"fa-solid fa-chevron-right ax-text-xs ax-mx-2\"></i>\n                </ng-template>\n                @for(b of vm.beardcrumbs();track $index;let last=$last) {\n                <ax-breadcrumbs-item [active]=\"last\" [class.!ax-font-semibold]=\"last\"\n                  [class.!ax-text-neutral-600]=\"last\" [routerLink]=\"b.url\">\n                  @if(b.icon) {\n                  <i [class]=\"b.icon\"></i>\n                  }\n                  {{ b.title | translate | async }}\n                </ax-breadcrumbs-item>\n                }\n              </ax-breadcrumbs>\n            </div>\n          </div>\n          <!-------- Finish Title  -------->\n          <!--------------------------------------------------------------->\n          <!-- Begin Action Menu  -->\n          <div class=\"ax-flex ax-items-center ax-gap-3\">\n            @for(tr of vm.primaryActions();track $index) {\n            <ax-button [text]=\"tr.title | translate | async\" [color]=\"tr.color\" (onClick)=\"vm.executeCommand(tr.name)\">\n              <ax-prefix>\n                <ax-icon [icon]=\"tr.icon\"> </ax-icon>\n              </ax-prefix>\n            </ax-button>\n            } @if(vm.secondaryActions().length) {\n            <ax-button [text]=\"(store.isSmall()) ? null : ('actions' | translate | async)\" color=\"ghost\">\n              <ax-prefix>\n                <i class=\"fa-solid fa-ellipsis-vertical\"></i>\n              </ax-prefix>\n              <ax-dropdown-panel>\n                <ax-button-item-list>\n                  @for(tr of vm.secondaryActions();track $index;let first=$first) {\n                  <ng-container>\n                    @if(tr.separated && !$first) {\n                    <ax-divider></ax-divider>\n                    }\n                    <ax-button-item [text]=\"(tr.title | translate | async)!\"\n                      class=\"ax-font-semibold ax-text-{{ tr.color }}\" (onClick)=\"vm.executeCommand(tr.name)\">\n                      <ax-prefix>\n                        <ax-icon [icon]=\"tr.icon\"> </ax-icon>\n                      </ax-prefix>\n                    </ax-button-item>\n                  </ng-container>\n                  }\n                </ax-button-item-list>\n              </ax-dropdown-panel>\n            </ax-button>\n            }\n          </div>\n          <!-- Finish Action Menu  -->\n        </div>\n\n        <!-------- Finish Line 1  -------->\n\n        <!-------- Begin Line 2 -------->\n        <div class=\"ax-flex ax-justify-between ax-items-center\">\n          <div class=\"ax-flex ax-justify-start ax-items-center ax-gap-4\">\n            <!-------- Begin Selection  -------->\n\n            @if(vm.hasSelectedItems()) {\n            <div class=\"ax-flex ax-gap-3 ax-items-center ax-h-10\">\n              <span class=\"ax-text-xl ax-font-bold\">\n                {{ vm.selectedItems().length }} {{ 't(\"itemsSelected\", { scope: \"common\" })' | translate | async }}\n              </span>\n              <span (click)=\"vm.clearSelection()\"\n                class=\"ax-text-sm ax-text-primary dark:ax-text-primary-300 ax-underline ax-cursor-pointer\">{{\n                't(\"unselect\", { scope: \"common\" })' | translate | async }}</span>\n            </div>\n\n            <!-------- Finish Selection  -------->\n\n            } @else {\n\n            <!-------- Begin View  -------->\n\n            <ax-button [text]=\"vm.view().title | translate | async\" #views color=\"ghost\">\n              <ax-prefix>\n                <i class=\"fa-solid fa-eye\"></i>\n              </ax-prefix>\n              <ax-suffix>\n                <i class=\"fa-solid fa-caret-down\"></i>\n              </ax-suffix>\n              <ax-dropdown-panel [adaptivityEnabled]=\"true\">\n                <ax-button-item-list class=\"ax-bg-surface ax-p-2\">\n                  <ax-title class=\"ax-font-bold ax-opacity-100\">{{\n                    'entity.public-view' | translate | async\n                    }}</ax-title>\n                  <ax-button-item *ngFor=\"let v of vm.views()\" [text]=\"(v.title | translate | async)!\"\n                    [class.ax-bg-on-surface]=\"vm.view() == v\" (onClick)=\"vm.setView(v.name)\"></ax-button-item>\n                  <!-- <ax-title class=\"ax-font-bold ax-opacity-100\" *ngIf=\"hasCustomViews$ | async\">Created by me</ax-title>\n                <ax-button-item class=\"ax-pe-4 ax-flex ax-justify-between\" *ngFor=\"let v of customViews$ | async\"\n                  [text]=\"v.title\" [class.ax-bg-on-surface]=\"(view$ | async) == v\" (onClick)=\"loader.setView(v.name)\">\n                  <ax-suffix>\n                    <ax-button (onClick)=\"updateViewPopup($event, v)\" class=\"ax-xs\" look=\"none\">\n                      <ax-icon class=\"far fa-edit\"> </ax-icon>\n                    </ax-button>\n                  </ax-suffix>\n                </ax-button-item> -->\n                  <!-- <ng-container *feature=\"'axp-entity-list-custom-view'\">\n                  <ax-divider></ax-divider>\n                  <ax-button-item text=\"Add Custom View\" (onClick)=\"addCustomViewPopup()\"\n                    class=\"ax-font-semibold ax-text-primary\"></ax-button-item>\n                </ng-container> -->\n                </ax-button-item-list>\n              </ax-dropdown-panel>\n            </ax-button>\n            <!-------- Finish View  -------->\n\n            <!-------- Begin Inline Search   -------->\n            @if(vm.hasInlineFilters() && !(this.platform.is('Mobile') || this.platform.is('SM'))) {\n            <div class=\"ax-w-72\">\n              <ax-search-box\n                [placeholder]=\"('widget.lookup.search' | translate | async) + vm.inlineFiltersPlaceholders().join(', ')\"\n                (onValueChanged)=\"handleChangeSearchValue($event)\"><ax-clear-button></ax-clear-button></ax-search-box>\n            </div>\n            } }\n            <!-------- Finish Inline Search -------->\n          </div>\n          <!-- Begin View Action Menu  -->\n          @if(!vm.hasSelectedItems()) {\n          <div class=\"ax-flex ax-gap-3\">\n            @if(vm.hasInlineFilters() && (this.platform.is('Mobile') || this.platform.is('SM'))) {\n            <ax-button (onClick)=\"toggleSearchBar()\" color=\"ghost\">\n              <ax-icon class=\"fa-solid fa-search\"> </ax-icon> </ax-button>}\n\n            <ax-button [text]=\"makeResponsive('entity.columns' | translate | async)\" color=\"ghost\"\n              (onClick)=\"columnsDrawer.open()\">\n              <ax-prefix>\n                <i class=\"fa-solid fa-bars\"></i>\n              </ax-prefix>\n              <ax-suffix>\n                <ax-badge [text]=\"makeResponsive(vm.visibleColumnCount().toString())\" color=\"primary\"></ax-badge>\n              </ax-suffix>\n            </ax-button>\n            <ax-button text=\"Filters\" color=\"ghost\" (onClick)=\"conditionsDrawer.open()\"\n              *feature=\"'axp-entity-list-advance-filter'\">\n              <ax-prefix>\n                <i class=\"fa-solid fa-sliders\"></i>\n              </ax-prefix>\n              <ax-suffix>\n                <ax-badge text=\"3\" color=\"primary\"></ax-badge>\n              </ax-suffix>\n            </ax-button>\n\n            @if(vm.canSort()) {\n            <ax-button [text]=\"makeResponsive('entity.sort' | translate | async)\" color=\"ghost\"\n              (onClick)=\"sortsDrawer.open()\">\n              <ax-prefix>\n                <i class=\"fa-solid fa-bars-sort\"></i>\n              </ax-prefix>\n              @if(vm.sortedCount()) {\n              <ax-suffix>\n                <ax-badge [text]=\"makeResponsive(vm.sortedCount().toString())\" color=\"primary\"></ax-badge>\n              </ax-suffix>\n              }\n            </ax-button>\n            }\n          </div>\n          }\n          <!-- Finish View Action Menu  -->\n        </div>\n        <div>\n          @if(vm.hasInlineFilters() && (this.platform.is('Mobile') || this.platform.is('SM'))) {\n          <ax-search-box [class.collapsed-search-box]=\"searchBarShown()\" class=\"ax-transition-all\"\n            [placeholder]=\"('widget.lookup.search' | translate | async) + vm.inlineFiltersPlaceholders().join(', ')\"\n            (onValueChanged)=\"handleChangeSearchValue($event)\"><ax-clear-button></ax-clear-button></ax-search-box>\n          }\n        </div>\n        <!-------- Finish Line 2  -------->\n\n        <!----- Finish Toolbar  ----->\n      </div>\n    </div>\n    <!----- Begin DataTable  ----->\n    <div class=\"ax-flex ax-flex-1 ax-px-6 ax-py-6 ax-pt-0 ax-overflow-auto\">\n      <ax-data-table #grid [showFooter]=\"false\" class=\"ax-flex-1\" [paging]=\"true\" [fetchDataMode]=\"'manual'\"\n        [loading]=\"{ enabled: true, animation: true }\" [dataSource]=\"vm.dataSource\"\n        (selectedRowsChange)=\"handleSelectedRowsChange($event)\" (onRowDbClick)=\"handleRowDbClick($event)\">\n        <ax-select-column fixed=\"start\" [width]=\"'50px'\"></ax-select-column>\n        @for(col of vm.columns();track col.name) { @if(col.visible) {\n        <axp-widget-column-renderer [caption]=\"(col.title | translate | async)!\"\n          [node]=\"col.node()\"></axp-widget-column-renderer>\n        } } @if(getCommandRowItems().length){\n\n        <ax-command-column fixed=\"end\" [width]=\"getCommandRowItems().length * 60 + 'px'\" [items]=\"getCommandRowItems()\"\n          (onItemClick)=\"handleRowCommandClick($event)\"></ax-command-column>\n\n        } @if(dropdownRowItems().length){\n        <ax-dropdown-command-column fixed=\"end\" [width]=\"'60px'\" [items]=\"getDropdownRowItems\"\n          (onItemClick)=\"handleRowCommandClick($event)\"></ax-dropdown-command-column>\n        }\n      </ax-data-table>\n    </div>\n    <!----- Finish DataTable  ----->\n  </ax-content>\n\n  <ax-drawer (collapsedChange)=\"closeDrawer('columns', $event)\" #columnsDrawer location=\"end\" [mode]=\"'overlay'\">\n    <ax-content class=\"ax-w-[85vw] md:ax-w-[45vw] lg:ax-w-[35vw] 2xl:ax-w-[20vw] ax-border-e\">\n      <axp-list-view-option-columns [viewModel]=\"vm\" (onClosed)=\"columnsDrawer.close()\"></axp-list-view-option-columns>\n    </ax-content>\n  </ax-drawer>\n  <ax-drawer (collapsedChange)=\"closeDrawer('conditions', $event)\" #conditionsDrawer location=\"end\" [mode]=\"'overlay'\">\n    <ax-content class=\"ax-w-[85vw] md:ax-w-[45vw] lg:ax-w-[35vw] 2xl:ax-w-[25vw] ax-border-e\">\n      <!-- <axp-list-view-option-conditions [loader]=\"loader\"\n        (onClosed)=\"conditionsDrawer.close()\"></axp-list-view-option-conditions> -->\n    </ax-content>\n  </ax-drawer>\n  <ax-drawer (collapsedChange)=\"closeDrawer('sorts', $event)\" #sortsDrawer location=\"end\" [mode]=\"'overlay'\">\n    <ax-content class=\"ax-w-[85vw] md:ax-w-[45vw] lg:ax-w-[35vw] 2xl:ax-w-[20vw] ax-border-e\">\n      <axp-list-view-option-sorting (onClosed)=\"sortsDrawer.close()\" [viewModel]=\"vm\"></axp-list-view-option-sorting>\n    </ax-content>\n  </ax-drawer>\n</ax-drawer-container>"]}
|