@acorex/platform 18.1.0 → 18.1.1
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/layout/builder/lib/builder/builder.module.mjs +4 -3
- package/esm2022/layout/builder/lib/builder/index.mjs +2 -1
- package/esm2022/layout/builder/lib/builder/widget-renderer.component.directive.mjs +280 -0
- package/esm2022/layout/designer/lib/designer/components/board/board.component.mjs +3 -3
- package/esm2022/layout/designer/lib/designer/components/header-menu/header-menu.component.mjs +3 -3
- package/esm2022/layout/designer/lib/designer/designer.component.mjs +9 -5
- package/esm2022/layout/designer/lib/designer/shared/designer.service.mjs +21 -21
- package/esm2022/layout/designer/lib/designer/shared/designer.typs.mjs +6 -2
- package/esm2022/themes/default/lib/layouts/entity-layouts/entity-master-single-view/overview/entity-single-overview.component.mjs +3 -3
- package/esm2022/widgets/lib/widgets/actions/button/button-widget-designer.component.mjs +3 -3
- package/esm2022/widgets/lib/widgets/actions/button/button-widget-view.component.mjs +3 -3
- package/esm2022/widgets/lib/widgets/advance/map/map-box-widget-view.component.mjs +3 -3
- package/esm2022/widgets/lib/widgets/editors/contact/contact-widget-edit.component.mjs +9 -9
- package/esm2022/widgets/lib/widgets/editors/contact/contact-widget-view.component.mjs +6 -6
- package/esm2022/widgets/lib/widgets/editors/rich-text/rich-text-widget-view.component.mjs +5 -3
- package/esm2022/widgets/lib/widgets/editors/select/select-box-widget-column.component.mjs +36 -6
- package/esm2022/widgets/lib/widgets/editors/selection-list/selection-list-widget-column.component.mjs +2 -1
- package/esm2022/widgets/lib/widgets/layout/block/block-widget-view.component.mjs +4 -4
- package/esm2022/widgets/lib/widgets/layout/form-field/form-field-widget-view.component.mjs +28 -16
- package/esm2022/widgets/lib/widgets/layout/grid/grid-widget-designer.component.mjs +37 -31
- package/esm2022/widgets/lib/widgets/layout/grid/grid-widget-view.component.mjs +27 -6
- package/esm2022/widgets/lib/widgets/layout/grid-item/grid-item-widget-designer.component.mjs +32 -26
- package/esm2022/widgets/lib/widgets/layout/grid-item/grid-item-widget-view.component.mjs +82 -8
- package/esm2022/widgets/lib/widgets/layout/grid-row/grid-row-widget-view.component.mjs +27 -6
- package/esm2022/widgets/lib/widgets/layout/page/page-widget-view.component.mjs +6 -4
- package/fesm2022/acorex-platform-layout-builder.mjs +276 -4
- package/fesm2022/acorex-platform-layout-builder.mjs.map +1 -1
- package/fesm2022/acorex-platform-layout-designer.mjs +36 -28
- package/fesm2022/acorex-platform-layout-designer.mjs.map +1 -1
- package/fesm2022/{acorex-platform-themes-default-entity-master-single-view.component-CGhOE3jO.mjs → acorex-platform-themes-default-entity-master-single-view.component-B9lGgO_u.mjs} +3 -3
- package/fesm2022/{acorex-platform-themes-default-entity-master-single-view.component-CGhOE3jO.mjs.map → acorex-platform-themes-default-entity-master-single-view.component-B9lGgO_u.mjs.map} +1 -1
- package/fesm2022/acorex-platform-themes-default.mjs +2 -2
- package/fesm2022/{acorex-platform-widgets-button-widget-designer.component-COvuxaTt.mjs → acorex-platform-widgets-button-widget-designer.component-Oxpdaz9P.mjs} +3 -3
- package/fesm2022/{acorex-platform-widgets-button-widget-designer.component-COvuxaTt.mjs.map → acorex-platform-widgets-button-widget-designer.component-Oxpdaz9P.mjs.map} +1 -1
- package/fesm2022/acorex-platform-widgets.mjs +277 -107
- package/fesm2022/acorex-platform-widgets.mjs.map +1 -1
- package/layout/builder/lib/builder/builder.module.d.ts +5 -4
- package/layout/builder/lib/builder/index.d.ts +1 -0
- package/layout/builder/lib/builder/widget-renderer.component.directive.d.ts +42 -0
- package/layout/designer/lib/designer/designer.component.d.ts +1 -0
- package/layout/designer/lib/designer/shared/designer.service.d.ts +2 -1
- package/layout/designer/lib/designer/shared/designer.typs.d.ts +15 -0
- package/package.json +7 -7
- package/widgets/lib/widgets/actions/button/button-widget-designer.component.d.ts +1 -1
- package/widgets/lib/widgets/actions/button/button-widget-view.component.d.ts +1 -1
- package/widgets/lib/widgets/editors/select/select-box-widget-column.component.d.ts +5 -0
- package/widgets/lib/widgets/layout/form-field/form-field-widget-view.component.d.ts +2 -1
- package/widgets/lib/widgets/layout/grid/grid-widget-view.component.d.ts +3 -0
- package/widgets/lib/widgets/layout/grid-item/grid-item-widget-view.component.d.ts +11 -2
- package/widgets/lib/widgets/layout/grid-row/grid-row-widget-view.component.d.ts +3 -0
|
@@ -6,8 +6,9 @@ import { AXPWidgetRendererComponent } from "./widget-renderer.component";
|
|
|
6
6
|
import { AXPWidgetContainerComponent } from "./widget-container.component";
|
|
7
7
|
import { AXPWidgetRegistryService } from "./widget-registery.service";
|
|
8
8
|
import { AXPWidgetColumnRendererComponent } from "./widget-column-renderer";
|
|
9
|
+
import { AXPWidgetRendererDirective } from "./widget-renderer.component.directive";
|
|
9
10
|
import * as i0 from "@angular/core";
|
|
10
|
-
const COMPONENTS = [AXPWidgetContainerComponent, AXPWidgetRendererComponent, AXPWidgetColumnRendererComponent];
|
|
11
|
+
const COMPONENTS = [AXPWidgetContainerComponent, AXPWidgetRendererComponent, AXPWidgetColumnRendererComponent, AXPWidgetRendererDirective];
|
|
11
12
|
export class AXPLayoutBuilderModule {
|
|
12
13
|
static forRoot(config) {
|
|
13
14
|
return {
|
|
@@ -48,7 +49,7 @@ export class AXPLayoutBuilderModule {
|
|
|
48
49
|
});
|
|
49
50
|
}
|
|
50
51
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXPLayoutBuilderModule, deps: [{ token: 'AXPLayoutBuilderModuleFactory', optional: true }], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
51
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.0", ngImport: i0, type: AXPLayoutBuilderModule, declarations: [AXPWidgetContainerComponent, AXPWidgetRendererComponent, AXPWidgetColumnRendererComponent], imports: [CommonModule, PortalModule, AXSkeletonModule, CommonModule], exports: [AXPWidgetContainerComponent, AXPWidgetRendererComponent, AXPWidgetColumnRendererComponent] }); }
|
|
52
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.0", ngImport: i0, type: AXPLayoutBuilderModule, declarations: [AXPWidgetContainerComponent, AXPWidgetRendererComponent, AXPWidgetColumnRendererComponent, AXPWidgetRendererDirective], imports: [CommonModule, PortalModule, AXSkeletonModule, CommonModule], exports: [AXPWidgetContainerComponent, AXPWidgetRendererComponent, AXPWidgetColumnRendererComponent, AXPWidgetRendererDirective] }); }
|
|
52
53
|
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXPLayoutBuilderModule, imports: [CommonModule, PortalModule, AXSkeletonModule, CommonModule] }); }
|
|
53
54
|
}
|
|
54
55
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXPLayoutBuilderModule, decorators: [{
|
|
@@ -64,4 +65,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
|
64
65
|
type: Inject,
|
|
65
66
|
args: ['AXPLayoutBuilderModuleFactory']
|
|
66
67
|
}] }] });
|
|
67
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
68
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVpbGRlci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3BsYXRmb3JtL2xheW91dC9idWlsZGVyL3NyYy9saWIvYnVpbGRlci9idWlsZGVyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUMvRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDbkQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxNQUFNLEVBQXVCLFFBQVEsRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDaEYsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDekUsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDM0UsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFFdEUsT0FBTyxFQUFFLGdDQUFnQyxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDNUUsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7O0FBTW5GLE1BQU0sVUFBVSxHQUFHLENBQUMsMkJBQTJCLEVBQUUsMEJBQTBCLEVBQUUsZ0NBQWdDLEVBQUUsMEJBQTBCLENBQUMsQ0FBQztBQU8zSSxNQUFNLE9BQU8sc0JBQXNCO0lBQy9CLE1BQU0sQ0FBQyxPQUFPLENBQUMsTUFBc0M7UUFDakQsT0FBTztZQUNILFFBQVEsRUFBRSxzQkFBc0I7WUFDaEMsU0FBUyxFQUFFO2dCQUNQO29CQUNJLE9BQU8sRUFBRSwrQkFBK0I7b0JBQ3hDLFVBQVUsRUFBRSxDQUFDLFFBQWtDLEVBQUUsRUFBRSxDQUFDLEdBQUcsRUFBRTt3QkFDckQsTUFBTSxFQUFFLE9BQU8sRUFBRSxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7b0JBQ3hELENBQUM7b0JBQ0QsSUFBSSxFQUFFLENBQUMsd0JBQXdCLENBQUM7b0JBQ2hDLEtBQUssRUFBRSxJQUFJO2lCQUNkO2FBQ0o7U0FDSixDQUFDO0lBQ04sQ0FBQztJQUVELE1BQU0sQ0FBQyxRQUFRLENBQUMsTUFBc0M7UUFDbEQsT0FBTztZQUNILFFBQVEsRUFBRSxzQkFBc0I7WUFDaEMsU0FBUyxFQUFFO2dCQUNQO29CQUNJLE9BQU8sRUFBRSwrQkFBK0I7b0JBQ3hDLFVBQVUsRUFBRSxDQUFDLFFBQWtDLEVBQUUsRUFBRSxDQUFDLEdBQUcsRUFBRTt3QkFDckQsTUFBTSxFQUFFLE9BQU8sRUFBRSxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7b0JBQ3hELENBQUM7b0JBQ0QsSUFBSSxFQUFFLENBQUMsd0JBQXdCLENBQUM7b0JBQ2hDLEtBQUssRUFBRSxJQUFJO2lCQUNkO2FBQ0o7U0FDSixDQUFDO0lBQ04sQ0FBQztJQUVEOztPQUVHO0lBQ0gsWUFBaUUsU0FBZ0I7UUFDN0UsU0FBUyxFQUFFLE9BQU8sQ0FBQyxDQUFDLENBQUMsRUFBRTtZQUNuQixDQUFDLEVBQUUsQ0FBQztRQUNSLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQzs4R0F4Q1Esc0JBQXNCLGtCQW9DQywrQkFBK0I7K0dBcEN0RCxzQkFBc0IsaUJBUGYsMkJBQTJCLEVBQUUsMEJBQTBCLEVBQUUsZ0NBQWdDLEVBQUUsMEJBQTBCLGFBRzNILFlBQVksRUFBRSxZQUFZLEVBQUUsZ0JBQWdCLEVBQUUsWUFBWSxhQUhwRCwyQkFBMkIsRUFBRSwwQkFBMEIsRUFBRSxnQ0FBZ0MsRUFBRSwwQkFBMEI7K0dBTzVILHNCQUFzQixZQUpyQixZQUFZLEVBQUUsWUFBWSxFQUFFLGdCQUFnQixFQUFFLFlBQVk7OzJGQUkzRCxzQkFBc0I7a0JBTGxDLFFBQVE7bUJBQUM7b0JBQ04sT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLFlBQVksRUFBRSxnQkFBZ0IsRUFBRSxZQUFZLENBQUM7b0JBQ3JFLE9BQU8sRUFBRSxDQUFDLEdBQUcsVUFBVSxDQUFDO29CQUN4QixZQUFZLEVBQUUsQ0FBQyxHQUFHLFVBQVUsQ0FBQztpQkFDaEM7OzBCQXFDZ0IsUUFBUTs7MEJBQUksTUFBTTsyQkFBQywrQkFBK0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBWFNrZWxldG9uTW9kdWxlIH0gZnJvbSBcIkBhY29yZXgvY29tcG9uZW50cy9za2VsZXRvblwiO1xuaW1wb3J0IHsgUG9ydGFsTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2Nkay9wb3J0YWxcIjtcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcbmltcG9ydCB7IEluamVjdCwgTW9kdWxlV2l0aFByb3ZpZGVycywgTmdNb2R1bGUsIE9wdGlvbmFsIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IEFYUFdpZGdldFJlbmRlcmVyQ29tcG9uZW50IH0gZnJvbSBcIi4vd2lkZ2V0LXJlbmRlcmVyLmNvbXBvbmVudFwiO1xuaW1wb3J0IHsgQVhQV2lkZ2V0Q29udGFpbmVyQ29tcG9uZW50IH0gZnJvbSBcIi4vd2lkZ2V0LWNvbnRhaW5lci5jb21wb25lbnRcIjtcbmltcG9ydCB7IEFYUFdpZGdldFJlZ2lzdHJ5U2VydmljZSB9IGZyb20gXCIuL3dpZGdldC1yZWdpc3Rlcnkuc2VydmljZVwiO1xuaW1wb3J0IHsgQVhQV2lkZ2V0Q29uZmlnIH0gZnJvbSBcIi4vd2lkZ2V0LnR5cGVzXCI7XG5pbXBvcnQgeyBBWFBXaWRnZXRDb2x1bW5SZW5kZXJlckNvbXBvbmVudCB9IGZyb20gXCIuL3dpZGdldC1jb2x1bW4tcmVuZGVyZXJcIjtcbmltcG9ydCB7IEFYUFdpZGdldFJlbmRlcmVyRGlyZWN0aXZlIH0gZnJvbSBcIi4vd2lkZ2V0LXJlbmRlcmVyLmNvbXBvbmVudC5kaXJlY3RpdmVcIjtcblxuZXhwb3J0IGludGVyZmFjZSBBWFBMYXlvdXRCdWlsZGVyTW9kdWxlQ29uZmlncyB7XG4gICAgd2lkZ2V0czogQVhQV2lkZ2V0Q29uZmlnW11cbn1cblxuY29uc3QgQ09NUE9ORU5UUyA9IFtBWFBXaWRnZXRDb250YWluZXJDb21wb25lbnQsIEFYUFdpZGdldFJlbmRlcmVyQ29tcG9uZW50LCBBWFBXaWRnZXRDb2x1bW5SZW5kZXJlckNvbXBvbmVudCwgQVhQV2lkZ2V0UmVuZGVyZXJEaXJlY3RpdmVdO1xuXG5ATmdNb2R1bGUoe1xuICAgIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIFBvcnRhbE1vZHVsZSwgQVhTa2VsZXRvbk1vZHVsZSwgQ29tbW9uTW9kdWxlXSxcbiAgICBleHBvcnRzOiBbLi4uQ09NUE9ORU5UU10sXG4gICAgZGVjbGFyYXRpb25zOiBbLi4uQ09NUE9ORU5UU10sXG59KVxuZXhwb3J0IGNsYXNzIEFYUExheW91dEJ1aWxkZXJNb2R1bGUge1xuICAgIHN0YXRpYyBmb3JSb290KGNvbmZpZz86IEFYUExheW91dEJ1aWxkZXJNb2R1bGVDb25maWdzKTogTW9kdWxlV2l0aFByb3ZpZGVyczxBWFBMYXlvdXRCdWlsZGVyTW9kdWxlPiB7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICBuZ01vZHVsZTogQVhQTGF5b3V0QnVpbGRlck1vZHVsZSxcbiAgICAgICAgICAgIHByb3ZpZGVyczogW1xuICAgICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICAgICAgcHJvdmlkZTogJ0FYUExheW91dEJ1aWxkZXJNb2R1bGVGYWN0b3J5JyxcbiAgICAgICAgICAgICAgICAgICAgdXNlRmFjdG9yeTogKHJlZ2lzdHJ5OiBBWFBXaWRnZXRSZWdpc3RyeVNlcnZpY2UpID0+ICgpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgICAgIGNvbmZpZz8ud2lkZ2V0cz8uZm9yRWFjaCh3ID0+IHJlZ2lzdHJ5LnJlZ2lzdGVyKHcpKTtcbiAgICAgICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgICAgICAgZGVwczogW0FYUFdpZGdldFJlZ2lzdHJ5U2VydmljZV0sXG4gICAgICAgICAgICAgICAgICAgIG11bHRpOiB0cnVlXG4gICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIF1cbiAgICAgICAgfTtcbiAgICB9XG5cbiAgICBzdGF0aWMgZm9yQ2hpbGQoY29uZmlnPzogQVhQTGF5b3V0QnVpbGRlck1vZHVsZUNvbmZpZ3MpOiBNb2R1bGVXaXRoUHJvdmlkZXJzPEFYUExheW91dEJ1aWxkZXJNb2R1bGU+IHtcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgIG5nTW9kdWxlOiBBWFBMYXlvdXRCdWlsZGVyTW9kdWxlLFxuICAgICAgICAgICAgcHJvdmlkZXJzOiBbXG4gICAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgICAgICBwcm92aWRlOiAnQVhQTGF5b3V0QnVpbGRlck1vZHVsZUZhY3RvcnknLFxuICAgICAgICAgICAgICAgICAgICB1c2VGYWN0b3J5OiAocmVnaXN0cnk6IEFYUFdpZGdldFJlZ2lzdHJ5U2VydmljZSkgPT4gKCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgY29uZmlnPy53aWRnZXRzPy5mb3JFYWNoKHcgPT4gcmVnaXN0cnkucmVnaXN0ZXIodykpO1xuICAgICAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICAgICAgICBkZXBzOiBbQVhQV2lkZ2V0UmVnaXN0cnlTZXJ2aWNlXSxcbiAgICAgICAgICAgICAgICAgICAgbXVsdGk6IHRydWVcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICBdXG4gICAgICAgIH07XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQGlnbm9yZVxuICAgICAqL1xuICAgIGNvbnN0cnVjdG9yKEBPcHRpb25hbCgpIEBJbmplY3QoJ0FYUExheW91dEJ1aWxkZXJNb2R1bGVGYWN0b3J5JykgaW5zdGFuY2VzOiBhbnlbXSkge1xuICAgICAgICBpbnN0YW5jZXM/LmZvckVhY2goZiA9PiB7XG4gICAgICAgICAgICBmKCk7XG4gICAgICAgIH0pO1xuICAgIH1cbn1cbiJdfQ==
|
|
@@ -6,5 +6,6 @@ export * from './widget-container.component';
|
|
|
6
6
|
export * from './widget-groups';
|
|
7
7
|
export * from './widget-registery.service';
|
|
8
8
|
export * from './widget-renderer.component';
|
|
9
|
+
export * from './widget-renderer.component.directive';
|
|
9
10
|
export * from './widget.types';
|
|
10
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3BsYXRmb3JtL2xheW91dC9idWlsZGVyL3NyYy9saWIvYnVpbGRlci9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyxpQkFBaUIsQ0FBQztBQUNoQyxjQUFjLDRCQUE0QixDQUFDO0FBQzNDLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLGdCQUFnQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9idWlsZGVyLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2J1aWxkZXIuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC1jYXRhbG9nJztcbmV4cG9ydCAqIGZyb20gJy4vd2lkZ2V0LWNvbHVtbi1yZW5kZXJlcic7XG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC1jb250YWluZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vd2lkZ2V0LWdyb3Vwcyc7XG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC1yZWdpc3Rlcnkuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC1yZW5kZXJlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi93aWRnZXQtcmVuZGVyZXIuY29tcG9uZW50LmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC50eXBlcyc7XG4iXX0=
|
|
@@ -0,0 +1,280 @@
|
|
|
1
|
+
import { AXUnsubscriber } from '@acorex/core/utils';
|
|
2
|
+
import { Directive, Injector, ViewContainerRef, effect, inject, input, signal } from '@angular/core';
|
|
3
|
+
import { cloneDeep, get, merge, set, sum } from 'lodash-es';
|
|
4
|
+
import { filter } from 'rxjs';
|
|
5
|
+
import { AXPLayoutBuilderService } from './builder.service';
|
|
6
|
+
import { AXPWidgetRegistryService } from './widget-registery.service';
|
|
7
|
+
import { AXP_WIDGET_TOKEN } from './widget.types';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
export class AXPWidgetRendererDirective {
|
|
10
|
+
constructor() {
|
|
11
|
+
this.parentNode = input();
|
|
12
|
+
this.index = input();
|
|
13
|
+
this.mode = input.required();
|
|
14
|
+
this.node = input.required();
|
|
15
|
+
this.mergedOptions = signal({});
|
|
16
|
+
this.injector = inject(Injector);
|
|
17
|
+
this.builderService = inject(AXPLayoutBuilderService);
|
|
18
|
+
this.widgetRegistery = inject(AXPWidgetRegistryService);
|
|
19
|
+
this.unsubscriber = inject(AXUnsubscriber);
|
|
20
|
+
this.viewContainerRef = inject(ViewContainerRef);
|
|
21
|
+
this.isLoading = signal(true);
|
|
22
|
+
this.expressionCache = new Map();
|
|
23
|
+
this.expressionEvaluators = new Map();
|
|
24
|
+
this.scope = null;
|
|
25
|
+
this.builderService.onChanged.pipe(this.unsubscriber.takeUntilDestroy).subscribe(async (e) => {
|
|
26
|
+
if ((await this.updateOptionsBasedOnContext()) > 0) {
|
|
27
|
+
this.applyOptions();
|
|
28
|
+
}
|
|
29
|
+
if (this.checkFormulaForUpdate(this.node().formula, e.path)) {
|
|
30
|
+
await this.updateValueBasedOnFormula();
|
|
31
|
+
}
|
|
32
|
+
});
|
|
33
|
+
//
|
|
34
|
+
effect(async () => {
|
|
35
|
+
await this.loadComponent();
|
|
36
|
+
}, { allowSignalWrites: true });
|
|
37
|
+
}
|
|
38
|
+
async loadComponent() {
|
|
39
|
+
this.isLoading.set(true);
|
|
40
|
+
this.viewContainerRef.clear();
|
|
41
|
+
const widget = this.widgetRegistery.resolve(this.node().type);
|
|
42
|
+
//
|
|
43
|
+
const props = widget?.components[this.mode()]?.properties
|
|
44
|
+
?.filter((c) => c.schema.defaultValue)
|
|
45
|
+
.map((c) => ({ [c.name]: c.schema.defaultValue }))
|
|
46
|
+
.reduce((acc, curr) => {
|
|
47
|
+
return { ...acc, ...curr };
|
|
48
|
+
}, {});
|
|
49
|
+
//
|
|
50
|
+
this.mergedOptions.set(merge(props, this.node().options) || {});
|
|
51
|
+
this.preprocessAndInitialOptions(cloneDeep(this.node().options));
|
|
52
|
+
await this.updateOptionsBasedOnContext();
|
|
53
|
+
//
|
|
54
|
+
const tokenValue = {
|
|
55
|
+
node: this.node(),
|
|
56
|
+
options: this.mergedOptions(),
|
|
57
|
+
config: widget,
|
|
58
|
+
};
|
|
59
|
+
const token = Injector.create({
|
|
60
|
+
parent: this.injector,
|
|
61
|
+
providers: [
|
|
62
|
+
{
|
|
63
|
+
provide: AXP_WIDGET_TOKEN,
|
|
64
|
+
useValue: tokenValue,
|
|
65
|
+
},
|
|
66
|
+
],
|
|
67
|
+
});
|
|
68
|
+
//
|
|
69
|
+
var com = await widget?.components[this.mode()]?.component();
|
|
70
|
+
this.instance = this.viewContainerRef.createComponent(com, { injector: token }).instance;
|
|
71
|
+
this.instance.parent = this.parentNode();
|
|
72
|
+
this.instance.index = this.index();
|
|
73
|
+
this.instance.mode = this.mode();
|
|
74
|
+
await this.updateValueBasedOnFormula();
|
|
75
|
+
await this.assignTriggers();
|
|
76
|
+
//
|
|
77
|
+
this.isLoading.set(false);
|
|
78
|
+
}
|
|
79
|
+
applyOptions() {
|
|
80
|
+
if (!this.instance)
|
|
81
|
+
return;
|
|
82
|
+
this.instance.setOptions(this.mergedOptions());
|
|
83
|
+
}
|
|
84
|
+
checkFormulaForUpdate(formula, path) {
|
|
85
|
+
if (formula) {
|
|
86
|
+
const regex = /context\.eval\('([^']+)'\)/g;
|
|
87
|
+
const matches = formula.match(regex);
|
|
88
|
+
const nodes = matches ? matches.map((match) => match.match(/'([^']+)'/)[1]) : [];
|
|
89
|
+
return nodes.includes(path);
|
|
90
|
+
}
|
|
91
|
+
else
|
|
92
|
+
return false;
|
|
93
|
+
}
|
|
94
|
+
preprocessAndInitialOptions(obj, pathPrefix = '') {
|
|
95
|
+
if (!obj)
|
|
96
|
+
return;
|
|
97
|
+
Object.entries(obj).forEach(([key, value]) => {
|
|
98
|
+
const currentPath = pathPrefix ? `${pathPrefix}.${key}` : key;
|
|
99
|
+
if (typeof value === 'string' && value.includes('{{')) {
|
|
100
|
+
// Cache dynamic expression for later evaluation
|
|
101
|
+
this.expressionEvaluators.set(currentPath, () => this.evaluateExpression(value));
|
|
102
|
+
}
|
|
103
|
+
else if (typeof value === 'object' && value !== null && (value.constructor === Object || Array.isArray(value))) {
|
|
104
|
+
// Recursively handle nested objects
|
|
105
|
+
this.preprocessAndInitialOptions(value, currentPath);
|
|
106
|
+
}
|
|
107
|
+
else {
|
|
108
|
+
// Apply static values directly
|
|
109
|
+
this.mergedOptions.update((currentOptions) => {
|
|
110
|
+
return set(currentOptions, currentPath, value);
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
});
|
|
114
|
+
}
|
|
115
|
+
async updateOptionsBasedOnContext() {
|
|
116
|
+
const updates = [];
|
|
117
|
+
for (let [path, evaluator] of this.expressionEvaluators) {
|
|
118
|
+
const newValue = await evaluator();
|
|
119
|
+
updates.push({ path, newValue });
|
|
120
|
+
}
|
|
121
|
+
// Apply updates to mergedOptions
|
|
122
|
+
if (updates.length > 0) {
|
|
123
|
+
this.mergedOptions.update((o) => {
|
|
124
|
+
const updatedOptions = { ...o };
|
|
125
|
+
updates.forEach(({ path, newValue }) => {
|
|
126
|
+
// Set the new value in the updatedOptions object by path
|
|
127
|
+
set(updatedOptions, path, newValue); // Assuming 'set' can handle paths like 'property.subproperty'
|
|
128
|
+
});
|
|
129
|
+
return updatedOptions;
|
|
130
|
+
});
|
|
131
|
+
}
|
|
132
|
+
return updates.length;
|
|
133
|
+
}
|
|
134
|
+
async updateValueBasedOnFormula() {
|
|
135
|
+
if (this.node().formula) {
|
|
136
|
+
const value = await this.evaluateExpression(this.node().formula);
|
|
137
|
+
this.instance.setValue(value);
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
async evaluateExpression(templateExpression) {
|
|
141
|
+
try {
|
|
142
|
+
// Check cache first, but cache the function for evaluation, not the evaluated value
|
|
143
|
+
if (!this.expressionCache.has(templateExpression)) {
|
|
144
|
+
const expressionMatch = templateExpression.match(/\{\{\s*(.*?)\s*\}\}/);
|
|
145
|
+
if (!expressionMatch) {
|
|
146
|
+
throw Error(`No valid expression found in "${templateExpression}"`);
|
|
147
|
+
}
|
|
148
|
+
const expression = expressionMatch[1];
|
|
149
|
+
// Cache the evaluation function instead of the result
|
|
150
|
+
const scope = this.getGlobalScope();
|
|
151
|
+
const evaluationFunction = async () => {
|
|
152
|
+
const sandbox = new Function('scope', `with (scope) { return (async function() { return ${expression}; })(); }`);
|
|
153
|
+
return await sandbox(scope);
|
|
154
|
+
};
|
|
155
|
+
this.expressionCache.set(templateExpression, evaluationFunction);
|
|
156
|
+
}
|
|
157
|
+
// Retrieve the function from the cache and call it to evaluate the expression
|
|
158
|
+
const evaluate = this.expressionCache.get(templateExpression);
|
|
159
|
+
if (evaluate) {
|
|
160
|
+
const result = await evaluate();
|
|
161
|
+
return result;
|
|
162
|
+
}
|
|
163
|
+
else {
|
|
164
|
+
throw Error(`Failed to retrieve evaluation function for expression: "${templateExpression}"`);
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
catch (error) {
|
|
168
|
+
console.error('Error evaluating expression:', error);
|
|
169
|
+
return false;
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
getGlobalScope() {
|
|
173
|
+
if (this.scope)
|
|
174
|
+
return this.scope;
|
|
175
|
+
this.scope = {};
|
|
176
|
+
set(this.scope, 'context', this.getContextScope());
|
|
177
|
+
set(this.scope, 'events', this.getEventScope());
|
|
178
|
+
set(this.scope, 'widget', this.getWidgetScope());
|
|
179
|
+
set(this.scope, 'methods', this.getFunctionScope());
|
|
180
|
+
set(this.scope, 'vars', this.getVariablesScope());
|
|
181
|
+
return this.scope;
|
|
182
|
+
}
|
|
183
|
+
getContextScope() {
|
|
184
|
+
const scope = {};
|
|
185
|
+
set(scope, 'eval', (path) => this.builderService.getValue(path));
|
|
186
|
+
return scope;
|
|
187
|
+
}
|
|
188
|
+
getEventScope() {
|
|
189
|
+
const scope = {};
|
|
190
|
+
set(scope, 'context', (path) => this.builderService.onChanged.pipe(filter((c) => c.path == path)));
|
|
191
|
+
set(scope, 'from', (event) => get(this.instance.api(), event));
|
|
192
|
+
return scope;
|
|
193
|
+
}
|
|
194
|
+
getWidgetScope() {
|
|
195
|
+
const scope = {};
|
|
196
|
+
set(scope, 'call', (name, ...args) => {
|
|
197
|
+
this.instance.call(name, ...args);
|
|
198
|
+
});
|
|
199
|
+
set(scope, 'find', (id) => {
|
|
200
|
+
return this.builderService.getWidget(id)?.api();
|
|
201
|
+
});
|
|
202
|
+
return scope;
|
|
203
|
+
}
|
|
204
|
+
getFunctionScope() {
|
|
205
|
+
const scope = {};
|
|
206
|
+
set(scope, 'sum', (values) => {
|
|
207
|
+
return sum(values);
|
|
208
|
+
});
|
|
209
|
+
Object.entries(this.builderService.functions).forEach((i) => {
|
|
210
|
+
set(scope, i[0], (...args) => {
|
|
211
|
+
return i[1](...args);
|
|
212
|
+
});
|
|
213
|
+
});
|
|
214
|
+
return scope;
|
|
215
|
+
}
|
|
216
|
+
getVariablesScope() {
|
|
217
|
+
const scope = {};
|
|
218
|
+
set(scope, 'eval', (path) => get(this.builderService.variables, path));
|
|
219
|
+
return scope;
|
|
220
|
+
}
|
|
221
|
+
async assignTriggers() {
|
|
222
|
+
this.node().triggers?.forEach((t) => {
|
|
223
|
+
const event = this.evaluateTrigger(t.event);
|
|
224
|
+
event?.pipe(this.unsubscriber.takeUntilDestroy).subscribe((c) => {
|
|
225
|
+
this.evaluateAction(t.action);
|
|
226
|
+
});
|
|
227
|
+
});
|
|
228
|
+
}
|
|
229
|
+
evaluateTrigger(templateExpression) {
|
|
230
|
+
try {
|
|
231
|
+
const expressionMatch = templateExpression.match(/\{\{\s*(.*?)\s*\}\}/);
|
|
232
|
+
if (!expressionMatch) {
|
|
233
|
+
throw Error(`No valid expression found in "${templateExpression}"`);
|
|
234
|
+
}
|
|
235
|
+
const expression = expressionMatch[1];
|
|
236
|
+
// Cache the evaluation function instead of the result
|
|
237
|
+
const scope = this.getGlobalScope();
|
|
238
|
+
const sandbox = new Function('scope', `with (scope) { return ( function() { return ${expression}; })(); }`);
|
|
239
|
+
return sandbox(scope);
|
|
240
|
+
}
|
|
241
|
+
catch (error) {
|
|
242
|
+
console.error('Error evaluating expression:', error);
|
|
243
|
+
return null;
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
evaluateAction(templateExpression) {
|
|
247
|
+
try {
|
|
248
|
+
const expressionMatch = templateExpression.match(/\{\{\s*(.*?)\s*\}\}/);
|
|
249
|
+
if (!expressionMatch) {
|
|
250
|
+
throw Error(`No valid expression found in "${templateExpression}"`);
|
|
251
|
+
}
|
|
252
|
+
const expression = expressionMatch[1];
|
|
253
|
+
// Cache the evaluation function instead of the result
|
|
254
|
+
const scope = this.getGlobalScope();
|
|
255
|
+
const sandbox = new Function('scope', `with (scope) { ${expression} }`);
|
|
256
|
+
sandbox(scope);
|
|
257
|
+
}
|
|
258
|
+
catch (error) {
|
|
259
|
+
console.error('Error evaluating expression:', error);
|
|
260
|
+
}
|
|
261
|
+
}
|
|
262
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXPWidgetRendererDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
263
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.0", type: AXPWidgetRendererDirective, selector: "[axp-widget-renderer]", inputs: { parentNode: { classPropertyName: "parentNode", publicName: "parentNode", isSignal: true, isRequired: false, transformFunction: null }, index: { classPropertyName: "index", publicName: "index", isSignal: true, isRequired: false, transformFunction: null }, mode: { classPropertyName: "mode", publicName: "mode", isSignal: true, isRequired: true, transformFunction: null }, node: { classPropertyName: "node", publicName: "node", isSignal: true, isRequired: true, transformFunction: null } }, providers: [
|
|
264
|
+
{
|
|
265
|
+
provide: AXUnsubscriber,
|
|
266
|
+
},
|
|
267
|
+
], ngImport: i0 }); }
|
|
268
|
+
}
|
|
269
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXPWidgetRendererDirective, decorators: [{
|
|
270
|
+
type: Directive,
|
|
271
|
+
args: [{
|
|
272
|
+
selector: '[axp-widget-renderer]',
|
|
273
|
+
providers: [
|
|
274
|
+
{
|
|
275
|
+
provide: AXUnsubscriber,
|
|
276
|
+
},
|
|
277
|
+
],
|
|
278
|
+
}]
|
|
279
|
+
}], ctorParameters: () => [] });
|
|
280
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-renderer.component.directive.js","sourceRoot":"","sources":["../../../../../../../../libs/platform/layout/builder/src/lib/builder/widget-renderer.component.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { AXUnsubscriber } from '@acorex/core/utils';\nimport { Directive, Injector, ViewContainerRef, WritableSignal, effect, inject, input, signal } from '@angular/core';\nimport { cloneDeep, get, merge, set, sum } from 'lodash-es';\nimport { Observable, filter } from 'rxjs';\nimport { AXPLayoutBuilderService } from './builder.service';\nimport { AXPWidgetRegistryService } from './widget-registery.service';\nimport { AXPWidgetComponent, AXPWidgetNode, AXPWidgetNodeToken, AXPWidgetRenderMode, AXP_WIDGET_TOKEN } from './widget.types';\n\n\n@Directive({\n  selector: '[axp-widget-renderer]',\n  providers: [\n    {\n      provide: AXUnsubscriber,\n    },\n  ],\n})\nexport class AXPWidgetRendererDirective {\n\n\n  parentNode = input<AXPWidgetComponent | null>();\n\n  index = input<number | null>();\n\n  mode = input.required<AXPWidgetRenderMode>();\n  node = input.required<AXPWidgetNode>();\n\n  protected mergedOptions: WritableSignal<any> = signal<any>({});\n\n  private injector = inject(Injector);\n  protected builderService = inject(AXPLayoutBuilderService);\n  protected widgetRegistery = inject(AXPWidgetRegistryService);\n  protected unsubscriber = inject(AXUnsubscriber);\n  private viewContainerRef = inject(ViewContainerRef);\n\n  protected isLoading = signal(true);\n  private instance!: AXPWidgetComponent;\n  private expressionCache: Map<string, () => Promise<any>> = new Map();\n  private expressionEvaluators: Map<string, () => Promise<any>> = new Map();\n  private scope: any = null;\n\n  constructor() {\n    this.builderService.onChanged.pipe(this.unsubscriber.takeUntilDestroy).subscribe(async (e) => {\n      if ((await this.updateOptionsBasedOnContext()) > 0) {\n        this.applyOptions();\n      }\n      if (this.checkFormulaForUpdate(this.node().formula, e.path)) {\n        await this.updateValueBasedOnFormula();\n      }\n    });\n    //\n    effect(\n      async () => {\n        await this.loadComponent();\n      },\n      { allowSignalWrites: true }\n    );\n  }\n\n  private async loadComponent() {\n    this.isLoading.set(true);\n    this.viewContainerRef.clear();\n    const widget = this.widgetRegistery.resolve(this.node().type);\n    //\n    const props = widget?.components[this.mode()]?.properties\n      ?.filter((c) => c.schema.defaultValue)\n      .map((c) => ({ [c.name]: c.schema.defaultValue }))\n      .reduce((acc, curr) => {\n        return { ...acc, ...curr };\n      }, {});\n    //\n    this.mergedOptions.set(merge(props, this.node().options) || {});\n    this.preprocessAndInitialOptions(cloneDeep(this.node().options));\n    await this.updateOptionsBasedOnContext();\n    //\n    const tokenValue = {\n      node: this.node(),\n      options: this.mergedOptions(),\n      config: widget,\n    } as AXPWidgetNodeToken;\n    const token = Injector.create({\n      parent: this.injector,\n      providers: [\n        {\n          provide: AXP_WIDGET_TOKEN,\n          useValue: tokenValue,\n        },\n      ],\n    });\n    //\n    var com = await widget?.components[this.mode()]?.component();\n    this.instance = this.viewContainerRef.createComponent<AXPWidgetComponent<any>>(com, { injector: token }).instance;\n    this.instance.parent = this.parentNode();\n    this.instance.index = this.index();\n    this.instance.mode = this.mode();\n    await this.updateValueBasedOnFormula();\n    await this.assignTriggers();\n    //\n    this.isLoading.set(false);\n  }\n\n  private applyOptions() {\n    if (!this.instance) return;\n    this.instance.setOptions(this.mergedOptions());\n  }\n\n  private checkFormulaForUpdate(formula: string | undefined, path?: string | null): boolean {\n    if (formula) {\n      const regex = /context\\.eval\\('([^']+)'\\)/g;\n      const matches = formula.match(regex);\n      const nodes = matches ? matches.map((match: any) => match.match(/'([^']+)'/)[1]) : [];\n      return nodes.includes(path);\n    } else return false;\n  }\n\n  preprocessAndInitialOptions(obj: any, pathPrefix: string = ''): void {\n    if (!obj) return;\n    Object.entries(obj).forEach(([key, value]) => {\n      const currentPath = pathPrefix ? `${pathPrefix}.${key}` : key;\n      if (typeof value === 'string' && value.includes('{{')) {\n        // Cache dynamic expression for later evaluation\n        this.expressionEvaluators.set(currentPath, () => this.evaluateExpression(value));\n      } else if (typeof value === 'object' && value !== null && (value.constructor === Object || Array.isArray(value))) {\n        // Recursively handle nested objects\n        this.preprocessAndInitialOptions(value, currentPath);\n      } else {\n        // Apply static values directly\n        this.mergedOptions.update((currentOptions) => {\n          return set(currentOptions, currentPath, value);\n        });\n      }\n    });\n  }\n\n  async updateOptionsBasedOnContext() {\n    const updates: any[] = [];\n    for (let [path, evaluator] of this.expressionEvaluators) {\n      const newValue = await evaluator();\n      updates.push({ path, newValue });\n    }\n    // Apply updates to mergedOptions\n    if (updates.length > 0) {\n      this.mergedOptions.update((o) => {\n        const updatedOptions = { ...o };\n        updates.forEach(({ path, newValue }) => {\n          // Set the new value in the updatedOptions object by path\n          set(updatedOptions, path, newValue); // Assuming 'set' can handle paths like 'property.subproperty'\n        });\n        return updatedOptions;\n      });\n    }\n    return updates.length;\n  }\n\n  async updateValueBasedOnFormula() {\n    if (this.node().formula) {\n      const value = await this.evaluateExpression(this.node().formula!);\n      this.instance.setValue(value);\n    }\n  }\n\n  private async evaluateExpression(templateExpression: string): Promise<any> {\n    try {\n      // Check cache first, but cache the function for evaluation, not the evaluated value\n      if (!this.expressionCache.has(templateExpression)) {\n        const expressionMatch = templateExpression.match(/\\{\\{\\s*(.*?)\\s*\\}\\}/);\n        if (!expressionMatch) {\n          throw Error(`No valid expression found in \"${templateExpression}\"`);\n        }\n        const expression = expressionMatch[1];\n\n        // Cache the evaluation function instead of the result\n        const scope = this.getGlobalScope();\n        const evaluationFunction = async () => {\n          const sandbox = new Function('scope', `with (scope) { return (async function() { return ${expression}; })(); }`);\n          return await sandbox(scope);\n        };\n\n        this.expressionCache.set(templateExpression, evaluationFunction);\n      }\n\n      // Retrieve the function from the cache and call it to evaluate the expression\n      const evaluate = this.expressionCache.get(templateExpression);\n      if (evaluate) {\n        const result = await evaluate();\n        return result;\n      } else {\n        throw Error(`Failed to retrieve evaluation function for expression: \"${templateExpression}\"`);\n      }\n    } catch (error) {\n      console.error('Error evaluating expression:', error);\n      return false;\n    }\n  }\n\n  private getGlobalScope() {\n    if (this.scope) return this.scope;\n    this.scope = {};\n    set(this.scope, 'context', this.getContextScope());\n    set(this.scope, 'events', this.getEventScope());\n    set(this.scope, 'widget', this.getWidgetScope());\n    set(this.scope, 'methods', this.getFunctionScope());\n    set(this.scope, 'vars', this.getVariablesScope());\n    return this.scope;\n  }\n\n  private getContextScope(): any {\n    const scope: any = {};\n    set(scope, 'eval', (path: string) => this.builderService.getValue(path));\n    return scope;\n  }\n\n  private getEventScope(): any {\n    const scope: any = {};\n    set(scope, 'context', (path: string) => this.builderService.onChanged.pipe(filter((c) => c.path == path)));\n    set(scope, 'from', (event: string) => get(this.instance.api(), event));\n    return scope;\n  }\n\n  private getWidgetScope(): any {\n    const scope: any = {};\n    set(scope, 'call', (name: string, ...args: any[]) => {\n      this.instance.call(name, ...args);\n    });\n    set(scope, 'find', (id: string) => {\n      return this.builderService.getWidget(id)?.api();\n    });\n    return scope;\n  }\n\n  private getFunctionScope(): any {\n    const scope: any = {};\n    set(scope, 'sum', (values: any) => {\n      return sum(values);\n    });\n    Object.entries(this.builderService.functions).forEach((i) => {\n      set(scope, i[0], (...args: any[]) => {\n        return i[1](...args);\n      });\n    });\n    return scope;\n  }\n\n  private getVariablesScope(): any {\n    const scope: any = {};\n    set(scope, 'eval', (path: string) => get(this.builderService.variables, path));\n    return scope;\n  }\n\n  private async assignTriggers() {\n    this.node().triggers?.forEach((t) => {\n      const event = this.evaluateTrigger(t.event);\n      event?.pipe(this.unsubscriber.takeUntilDestroy).subscribe((c) => {\n        this.evaluateAction(t.action);\n      });\n    });\n  }\n\n  private evaluateTrigger(templateExpression: string): Observable<any> | null {\n    try {\n      const expressionMatch = templateExpression.match(/\\{\\{\\s*(.*?)\\s*\\}\\}/);\n      if (!expressionMatch) {\n        throw Error(`No valid expression found in \"${templateExpression}\"`);\n      }\n      const expression = expressionMatch[1];\n\n      // Cache the evaluation function instead of the result\n      const scope = this.getGlobalScope();\n      const sandbox = new Function('scope', `with (scope) { return (  function() { return ${expression}; })(); }`);\n      return sandbox(scope);\n    } catch (error) {\n      console.error('Error evaluating expression:', error);\n      return null;\n    }\n  }\n\n  private evaluateAction(templateExpression: string) {\n    try {\n      const expressionMatch = templateExpression.match(/\\{\\{\\s*(.*?)\\s*\\}\\}/);\n      if (!expressionMatch) {\n        throw Error(`No valid expression found in \"${templateExpression}\"`);\n      }\n      const expression = expressionMatch[1];\n\n      // Cache the evaluation function instead of the result\n      const scope: any = this.getGlobalScope();\n      const sandbox = new Function('scope', `with (scope) {  ${expression} }`);\n      sandbox(scope);\n    } catch (error) {\n      console.error('Error evaluating expression:', error);\n    }\n  }\n}\n"]}
|
|
@@ -93,7 +93,7 @@ export class AXPDesignerBoardComponent {
|
|
|
93
93
|
return cls;
|
|
94
94
|
}
|
|
95
95
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXPDesignerBoardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
96
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.0", type: AXPDesignerBoardComponent, isStandalone: true, selector: "axp-designer-board", host: { properties: { "style": "this.__style", "class": "this.__class" } }, ngImport: i0, template: "<axp-widgets-container [(context)]=\"context\">\n <ng-container axp-widget-designer-renderer [node]=\"service.currentPage()\" [mode]=\"service.mode()\"></ng-container>\n</axp-widgets-container>", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: AXPLayoutBuilderModule }, { kind: "component", type: i1.AXPWidgetContainerComponent, selector: "axp-widgets-container", inputs: ["context", "variables", "functions"], outputs: ["onChanged", "contextChange"] }, { kind: "directive", type: AXPWidgetDesignerRendererDirective, selector: "[axp-widget-designer-renderer]", inputs: ["parentNode", "index", "mode", "node"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
96
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.0", type: AXPDesignerBoardComponent, isStandalone: true, selector: "axp-designer-board", host: { properties: { "style": "this.__style", "class": "this.__class" } }, ngImport: i0, template: "<axp-widgets-container [(context)]=\"context\">\n <ng-container axp-widget-designer-renderer [node]=\"service.currentPage()\" [mode]=\"service.mode().id\"></ng-container>\n</axp-widgets-container>", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: AXPLayoutBuilderModule }, { kind: "component", type: i1.AXPWidgetContainerComponent, selector: "axp-widgets-container", inputs: ["context", "variables", "functions"], outputs: ["onChanged", "contextChange"] }, { kind: "directive", type: AXPWidgetDesignerRendererDirective, selector: "[axp-widget-designer-renderer]", inputs: ["parentNode", "index", "mode", "node"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
97
97
|
}
|
|
98
98
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXPDesignerBoardComponent, decorators: [{
|
|
99
99
|
type: Component,
|
|
@@ -101,7 +101,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
|
101
101
|
CommonModule,
|
|
102
102
|
AXPLayoutBuilderModule,
|
|
103
103
|
AXPWidgetDesignerRendererDirective
|
|
104
|
-
], template: "<axp-widgets-container [(context)]=\"context\">\n <ng-container axp-widget-designer-renderer [node]=\"service.currentPage()\" [mode]=\"service.mode()\"></ng-container>\n</axp-widgets-container>" }]
|
|
104
|
+
], template: "<axp-widgets-container [(context)]=\"context\">\n <ng-container axp-widget-designer-renderer [node]=\"service.currentPage()\" [mode]=\"service.mode().id\"></ng-container>\n</axp-widgets-container>" }]
|
|
105
105
|
}], propDecorators: { __style: [{
|
|
106
106
|
type: HostBinding,
|
|
107
107
|
args: ['style']
|
|
@@ -109,4 +109,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
|
109
109
|
type: HostBinding,
|
|
110
110
|
args: ['class']
|
|
111
111
|
}] } });
|
|
112
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"board.component.js","sourceRoot":"","sources":["../../../../../../../../../../libs/platform/layout/designer/src/lib/designer/components/board/board.component.ts","../../../../../../../../../../libs/platform/layout/designer/src/lib/designer/components/board/board.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXPLayoutBuilderModule } from '@acorex/platform/layout/builder';\nimport { CommonModule } from '@angular/common';\nimport { Component, inject, ViewEncapsulation, ChangeDetectionStrategy, computed, effect, ElementRef, HostBinding } from '@angular/core';\nimport { get } from 'lodash-es';\nimport { AXPWidgetDesignerRendererDirective } from '../../shared/widget-designer-renderer.directive';\nimport { AXPDesignerService } from '../../shared/designer.service';\n\n\n@Component({\n    selector: 'axp-designer-board',\n    templateUrl: './board.component.html',\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true,\n    imports: [\n        CommonModule,\n        AXPLayoutBuilderModule,\n        AXPWidgetDesignerRendererDirective\n    ],\n})\nexport class AXPDesignerBoardComponent {\n\n    protected context: any = {};\n    private elementRef = inject(ElementRef<HTMLDivElement>) as ElementRef<HTMLDivElement>;\n\n    private breakpointMap = {\n        'sm': 640,\n        'md': 768,\n        'lg': 1024,\n        'xl': 1280,\n        'xxl': 1536\n    };\n\n    // Unified method to extract media queries and create a custom class\n    applyResponsiveStyles(breakpoint: string) {\n        const minWidth = get(this.breakpointMap, breakpoint) as number;\n        const mediaRules = [];\n\n        // Loop through all the stylesheets\n        for (let sheet of Array.from(document.styleSheets)) {\n            try {\n                // Loop through CSS rules\n                for (let rule of Array.from(sheet.cssRules)) {\n                    // Check if the rule is a CSSMediaRule\n                    if (rule instanceof CSSMediaRule && rule.media.mediaText.includes(`min-width: ${minWidth}px`)) {\n                        // Loop through the media rule's CSS rules\n                        for (let subRule of Array.from(rule.cssRules)) {\n                            mediaRules.push(subRule.cssText);\n                        }\n                    }\n                }\n            } catch (e) {\n                console.error('Error accessing stylesheet:', e);\n            }\n        }\n\n        // Create a dynamic class for the media queries\n        this.createCustomClass(`axp-preview-${breakpoint}`, mediaRules, breakpoint);\n    }\n\n    private createCustomClass(className: string, styles: string[], breakpoint: string) {\n        const styleSheet = document.createElement('style');\n        styleSheet.setAttribute(\"data-screen\", breakpoint);\n\n        // Construct a pure CSS string, dynamically replacing the breakpoint prefix\n        let styleString = \"\";\n        styles.forEach(style => {\n            // Replace any prefixed classes like 'lg:' or 'md:' dynamically\n            const dynamicPrefix = new RegExp(`\\\\.${breakpoint}\\\\\\\\:`, 'g');\n            styleString += `.${className} ${style.replace(dynamicPrefix, '.')}`; // Replace the breakpoint prefix\n        });\n\n        styleSheet.innerText = styleString;\n        this.removeCustomClass();\n        this.elementRef.nativeElement.appendChild(styleSheet);\n    }\n\n    private removeCustomClass() {\n        this.elementRef.nativeElement.querySelectorAll('style').forEach(s => s.remove());\n    }\n\n    protected service = inject(AXPDesignerService);\n\n\n    protected width = computed(() => {\n        switch (this.service.size()) {\n            case 'sm':\n                return '340px';\n            case 'md':\n            case 'lg':\n                return '768px';\n            default:\n                return '100%';\n        }\n    });\n\n\n    private ef = effect(() => {\n        this.removeCustomClass();\n        if (this.service.size() != 'xl') {\n            this.applyResponsiveStyles(this.service.size());\n        }\n    });\n\n\n    @HostBinding('style')\n    private get __style(): string {\n        const cls: any = {};\n        cls[`width`] = this.width();\n        return cls;\n    }\n\n    @HostBinding('class')\n    private get __class(): string {\n        const cls: any = {};\n        cls[`axp-designer-board`] = true;\n        cls[`axp-state-design`] = true;\n        cls['ax-h-full'] = true;\n        cls['ax-overflow-auto'] = true;\n        cls[`axp-preview-${this.service.size()}`] = true;\n        return cls;\n    }\n\n}\n","<axp-widgets-container [(context)]=\"context\">\n    <ng-container axp-widget-designer-renderer [node]=\"service.currentPage()\" [mode]=\"service.mode()\"></ng-container>\n</axp-widgets-container>"]}
|
|
112
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"board.component.js","sourceRoot":"","sources":["../../../../../../../../../../libs/platform/layout/designer/src/lib/designer/components/board/board.component.ts","../../../../../../../../../../libs/platform/layout/designer/src/lib/designer/components/board/board.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXPLayoutBuilderModule } from '@acorex/platform/layout/builder';\nimport { CommonModule } from '@angular/common';\nimport { Component, inject, ViewEncapsulation, ChangeDetectionStrategy, computed, effect, ElementRef, HostBinding } from '@angular/core';\nimport { get } from 'lodash-es';\nimport { AXPWidgetDesignerRendererDirective } from '../../shared/widget-designer-renderer.directive';\nimport { AXPDesignerService } from '../../shared/designer.service';\n\n\n@Component({\n    selector: 'axp-designer-board',\n    templateUrl: './board.component.html',\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true,\n    imports: [\n        CommonModule,\n        AXPLayoutBuilderModule,\n        AXPWidgetDesignerRendererDirective\n    ],\n})\nexport class AXPDesignerBoardComponent {\n\n    protected context: any = {};\n    private elementRef = inject(ElementRef<HTMLDivElement>) as ElementRef<HTMLDivElement>;\n\n    private breakpointMap = {\n        'sm': 640,\n        'md': 768,\n        'lg': 1024,\n        'xl': 1280,\n        'xxl': 1536\n    };\n\n    // Unified method to extract media queries and create a custom class\n    applyResponsiveStyles(breakpoint: string) {\n        const minWidth = get(this.breakpointMap, breakpoint) as number;\n        const mediaRules = [];\n\n        // Loop through all the stylesheets\n        for (let sheet of Array.from(document.styleSheets)) {\n            try {\n                // Loop through CSS rules\n                for (let rule of Array.from(sheet.cssRules)) {\n                    // Check if the rule is a CSSMediaRule\n                    if (rule instanceof CSSMediaRule && rule.media.mediaText.includes(`min-width: ${minWidth}px`)) {\n                        // Loop through the media rule's CSS rules\n                        for (let subRule of Array.from(rule.cssRules)) {\n                            mediaRules.push(subRule.cssText);\n                        }\n                    }\n                }\n            } catch (e) {\n                console.error('Error accessing stylesheet:', e);\n            }\n        }\n\n        // Create a dynamic class for the media queries\n        this.createCustomClass(`axp-preview-${breakpoint}`, mediaRules, breakpoint);\n    }\n\n    private createCustomClass(className: string, styles: string[], breakpoint: string) {\n        const styleSheet = document.createElement('style');\n        styleSheet.setAttribute(\"data-screen\", breakpoint);\n\n        // Construct a pure CSS string, dynamically replacing the breakpoint prefix\n        let styleString = \"\";\n        styles.forEach(style => {\n            // Replace any prefixed classes like 'lg:' or 'md:' dynamically\n            const dynamicPrefix = new RegExp(`\\\\.${breakpoint}\\\\\\\\:`, 'g');\n            styleString += `.${className} ${style.replace(dynamicPrefix, '.')}`; // Replace the breakpoint prefix\n        });\n\n        styleSheet.innerText = styleString;\n        this.removeCustomClass();\n        this.elementRef.nativeElement.appendChild(styleSheet);\n    }\n\n    private removeCustomClass() {\n        this.elementRef.nativeElement.querySelectorAll('style').forEach(s => s.remove());\n    }\n\n    protected service = inject(AXPDesignerService);\n\n\n    protected width = computed(() => {\n        switch (this.service.size()) {\n            case 'sm':\n                return '340px';\n            case 'md':\n            case 'lg':\n                return '768px';\n            default:\n                return '100%';\n        }\n    });\n\n\n    private ef = effect(() => {\n        this.removeCustomClass();\n        if (this.service.size() != 'xl') {\n            this.applyResponsiveStyles(this.service.size());\n        }\n    });\n\n\n    @HostBinding('style')\n    private get __style(): string {\n        const cls: any = {};\n        cls[`width`] = this.width();\n        return cls;\n    }\n\n    @HostBinding('class')\n    private get __class(): string {\n        const cls: any = {};\n        cls[`axp-designer-board`] = true;\n        cls[`axp-state-design`] = true;\n        cls['ax-h-full'] = true;\n        cls['ax-overflow-auto'] = true;\n        cls[`axp-preview-${this.service.size()}`] = true;\n        return cls;\n    }\n\n}\n","<axp-widgets-container [(context)]=\"context\">\n    <ng-container axp-widget-designer-renderer [node]=\"service.currentPage()\" [mode]=\"service.mode().id\"></ng-container>\n</axp-widgets-container>"]}
|
package/esm2022/layout/designer/lib/designer/components/header-menu/header-menu.component.mjs
CHANGED
|
@@ -11,7 +11,7 @@ export class AXPDesignerHeaderMenuComponent {
|
|
|
11
11
|
this.service = inject(AXPDesignerService);
|
|
12
12
|
}
|
|
13
13
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXPDesignerHeaderMenuComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
14
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.0", type: AXPDesignerHeaderMenuComponent, isStandalone: true, selector: "axp-designer-header-menu", ngImport: i0, template: "<ax-menu [openOn]=\"'hover'\">\n <ax-menu-item>\n <ax-text>Home</ax-text>\n <ax-menu-item (onClick)=\"service.new()\">\n <ax-text>New</ax-text>\n <ax-suffix>\n <ax-text>\n Shift+N\n </ax-text>\n </ax-suffix>\n </ax-menu-item>\n <ax-menu-item>\n <ax-text>Export</ax-text>\n <ax-menu-item (onClick)=\"service.downloadJson()\">\n <ax-text>Download JSON</ax-text>\n </ax-menu-item>\n </ax-menu-item>\n <ax-menu-item>\n <ax-text>Import</ax-text>\n <ax-menu-item (onClick)=\"service.importJSon()\">\n <ax-text>Import JSON</ax-text>\n </ax-menu-item>\n </ax-menu-item>\n </ax-menu-item>\n <ax-menu-item>\n <ax-text>Edit</ax-text>\n <ax-menu-item [disabled]=\"!service.canUndo()\" (onClick)=\"service.undo()\">\n <ax-text>Undo</ax-text>\n <ax-prefix>\n <ax-icon>\n <i class=\"fa-solid fa-rotate-left\"></i>\n </ax-icon>\n </ax-prefix>\n <ax-suffix>\n <ax-text>\n Ctrl+Z\n </ax-text>\n </ax-suffix>\n </ax-menu-item>\n <ax-menu-item [disabled]=\"!service.canRedo()\" (onClick)=\"service.redo()\">\n <ax-text>Redo</ax-text>\n <ax-prefix>\n <ax-icon>\n <i class=\"fa-solid fa-rotate-right\"></i>\n </ax-icon>\n </ax-prefix>\n <ax-suffix>\n <ax-text>\n Ctrl+Y\n </ax-text>\n </ax-suffix>\n </ax-menu-item>\n <ax-divider></ax-divider>\n <ax-menu-item [disabled]=\"!service.canCutCopy()\" (onClick)=\"service.cut()\">\n <ax-text>Cut</ax-text>\n <ax-prefix>\n <ax-icon>\n <i class=\"fa-solid fa-cut\"></i>\n </ax-icon>\n </ax-prefix>\n <ax-suffix>\n <ax-text>\n Ctrl+X\n </ax-text>\n </ax-suffix>\n </ax-menu-item>\n <ax-menu-item [disabled]=\"!service.canCutCopy()\" (onClick)=\"service.copy()\">\n <ax-text>Copy</ax-text>\n <ax-prefix>\n <ax-icon>\n <i class=\"fa-solid fa-copy\"></i>\n </ax-icon>\n </ax-prefix>\n <ax-suffix>\n <ax-text>\n Ctrl+C\n </ax-text>\n </ax-suffix>\n </ax-menu-item>\n <ax-menu-item [disabled]=\"!service.canPaste()\" (onClick)=\"service.paste()\">\n <ax-text>Paste</ax-text>\n <ax-prefix>\n <ax-icon>\n <i class=\"fa-solid fa-paste\"></i>\n </ax-icon>\n </ax-prefix>\n <ax-suffix>\n <ax-text>\n Ctrl+V\n </ax-text>\n </ax-suffix>\n </ax-menu-item>\n </ax-menu-item>\n <ax-menu-item>\n <ax-text>Help</ax-text>\n <ax-menu-item>\n <ax-text>About</ax-text>\n </ax-menu-item>\n </ax-menu-item>\n</ax-menu>", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: AXDecoratorModule }, { kind: "component", type: i1.AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }, { kind: "component", type: i1.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: AXMenuModule }, { kind: "component", type: i2.AXMenuItemComponent, selector: "ax-menu-item", inputs: ["name", "data", "disabled", "color"], outputs: ["onClick"] }, { kind: "component", type: i2.AXMenuComponent, selector: "ax-menu", inputs: ["orientation", "openOn", "closeOn", "items"], outputs: ["onItemClick"] }] }); }
|
|
14
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.0", type: AXPDesignerHeaderMenuComponent, isStandalone: true, selector: "axp-designer-header-menu", ngImport: i0, template: "<ax-menu [openOn]=\"'hover'\">\n <ax-menu-item>\n <ax-text>Home</ax-text>\n <ax-menu-item (onClick)=\"service.new()\">\n <ax-text>New</ax-text>\n <ax-suffix>\n <ax-text>\n Shift+N\n </ax-text>\n </ax-suffix>\n </ax-menu-item>\n <ax-divider></ax-divider>\n <ax-menu-item>\n <ax-text>Export</ax-text>\n <ax-menu-item (onClick)=\"service.downloadJson()\">\n <ax-text>Download JSON</ax-text>\n </ax-menu-item>\n </ax-menu-item>\n <ax-menu-item>\n <ax-text>Import</ax-text>\n <ax-menu-item (onClick)=\"service.importJSon()\">\n <ax-text>Import JSON</ax-text>\n </ax-menu-item>\n </ax-menu-item>\n </ax-menu-item>\n <ax-menu-item>\n <ax-text>Edit</ax-text>\n <ax-menu-item [disabled]=\"!service.canUndo()\" (onClick)=\"service.undo()\">\n <ax-text>Undo</ax-text>\n <ax-prefix>\n <ax-icon>\n <i class=\"fa-solid fa-rotate-left\"></i>\n </ax-icon>\n </ax-prefix>\n <ax-suffix>\n <ax-text>\n Ctrl+Z\n </ax-text>\n </ax-suffix>\n </ax-menu-item>\n <ax-menu-item [disabled]=\"!service.canRedo()\" (onClick)=\"service.redo()\">\n <ax-text>Redo</ax-text>\n <ax-prefix>\n <ax-icon>\n <i class=\"fa-solid fa-rotate-right\"></i>\n </ax-icon>\n </ax-prefix>\n <ax-suffix>\n <ax-text>\n Ctrl+Y\n </ax-text>\n </ax-suffix>\n </ax-menu-item>\n <ax-divider></ax-divider>\n <ax-menu-item [disabled]=\"!service.canCutCopy()\" (onClick)=\"service.cut()\">\n <ax-text>Cut</ax-text>\n <ax-prefix>\n <ax-icon>\n <i class=\"fa-solid fa-cut\"></i>\n </ax-icon>\n </ax-prefix>\n <ax-suffix>\n <ax-text>\n Ctrl+X\n </ax-text>\n </ax-suffix>\n </ax-menu-item>\n <ax-menu-item [disabled]=\"!service.canCutCopy()\" (onClick)=\"service.copy()\">\n <ax-text>Copy</ax-text>\n <ax-prefix>\n <ax-icon>\n <i class=\"fa-solid fa-copy\"></i>\n </ax-icon>\n </ax-prefix>\n <ax-suffix>\n <ax-text>\n Ctrl+C\n </ax-text>\n </ax-suffix>\n </ax-menu-item>\n <ax-menu-item [disabled]=\"!service.canPaste()\" (onClick)=\"service.paste()\">\n <ax-text>Paste</ax-text>\n <ax-prefix>\n <ax-icon>\n <i class=\"fa-solid fa-paste\"></i>\n </ax-icon>\n </ax-prefix>\n <ax-suffix>\n <ax-text>\n Ctrl+V\n </ax-text>\n </ax-suffix>\n </ax-menu-item>\n </ax-menu-item>\n <ax-menu-item>\n <ax-text>Help</ax-text>\n <ax-menu-item>\n <ax-text>About</ax-text>\n </ax-menu-item>\n </ax-menu-item>\n</ax-menu>", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: AXDecoratorModule }, { kind: "component", type: i1.AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }, { kind: "component", type: i1.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: AXMenuModule }, { kind: "component", type: i2.AXMenuItemComponent, selector: "ax-menu-item", inputs: ["name", "data", "disabled", "color"], outputs: ["onClick"] }, { kind: "component", type: i2.AXMenuComponent, selector: "ax-menu", inputs: ["orientation", "openOn", "closeOn", "items"], outputs: ["onItemClick"] }] }); }
|
|
15
15
|
}
|
|
16
16
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXPDesignerHeaderMenuComponent, decorators: [{
|
|
17
17
|
type: Component,
|
|
@@ -19,6 +19,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
|
19
19
|
CommonModule,
|
|
20
20
|
AXDecoratorModule,
|
|
21
21
|
AXMenuModule,
|
|
22
|
-
], selector: 'axp-designer-header-menu', template: "<ax-menu [openOn]=\"'hover'\">\n <ax-menu-item>\n <ax-text>Home</ax-text>\n <ax-menu-item (onClick)=\"service.new()\">\n <ax-text>New</ax-text>\n <ax-suffix>\n <ax-text>\n Shift+N\n </ax-text>\n </ax-suffix>\n </ax-menu-item>\n <ax-menu-item>\n <ax-text>Export</ax-text>\n <ax-menu-item (onClick)=\"service.downloadJson()\">\n <ax-text>Download JSON</ax-text>\n </ax-menu-item>\n </ax-menu-item>\n <ax-menu-item>\n <ax-text>Import</ax-text>\n <ax-menu-item (onClick)=\"service.importJSon()\">\n <ax-text>Import JSON</ax-text>\n </ax-menu-item>\n </ax-menu-item>\n </ax-menu-item>\n <ax-menu-item>\n <ax-text>Edit</ax-text>\n <ax-menu-item [disabled]=\"!service.canUndo()\" (onClick)=\"service.undo()\">\n <ax-text>Undo</ax-text>\n <ax-prefix>\n <ax-icon>\n <i class=\"fa-solid fa-rotate-left\"></i>\n </ax-icon>\n </ax-prefix>\n <ax-suffix>\n <ax-text>\n Ctrl+Z\n </ax-text>\n </ax-suffix>\n </ax-menu-item>\n <ax-menu-item [disabled]=\"!service.canRedo()\" (onClick)=\"service.redo()\">\n <ax-text>Redo</ax-text>\n <ax-prefix>\n <ax-icon>\n <i class=\"fa-solid fa-rotate-right\"></i>\n </ax-icon>\n </ax-prefix>\n <ax-suffix>\n <ax-text>\n Ctrl+Y\n </ax-text>\n </ax-suffix>\n </ax-menu-item>\n <ax-divider></ax-divider>\n <ax-menu-item [disabled]=\"!service.canCutCopy()\" (onClick)=\"service.cut()\">\n <ax-text>Cut</ax-text>\n <ax-prefix>\n <ax-icon>\n <i class=\"fa-solid fa-cut\"></i>\n </ax-icon>\n </ax-prefix>\n <ax-suffix>\n <ax-text>\n Ctrl+X\n </ax-text>\n </ax-suffix>\n </ax-menu-item>\n <ax-menu-item [disabled]=\"!service.canCutCopy()\" (onClick)=\"service.copy()\">\n <ax-text>Copy</ax-text>\n <ax-prefix>\n <ax-icon>\n <i class=\"fa-solid fa-copy\"></i>\n </ax-icon>\n </ax-prefix>\n <ax-suffix>\n <ax-text>\n Ctrl+C\n </ax-text>\n </ax-suffix>\n </ax-menu-item>\n <ax-menu-item [disabled]=\"!service.canPaste()\" (onClick)=\"service.paste()\">\n <ax-text>Paste</ax-text>\n <ax-prefix>\n <ax-icon>\n <i class=\"fa-solid fa-paste\"></i>\n </ax-icon>\n </ax-prefix>\n <ax-suffix>\n <ax-text>\n Ctrl+V\n </ax-text>\n </ax-suffix>\n </ax-menu-item>\n </ax-menu-item>\n <ax-menu-item>\n <ax-text>Help</ax-text>\n <ax-menu-item>\n <ax-text>About</ax-text>\n </ax-menu-item>\n </ax-menu-item>\n</ax-menu>" }]
|
|
22
|
+
], selector: 'axp-designer-header-menu', template: "<ax-menu [openOn]=\"'hover'\">\n <ax-menu-item>\n <ax-text>Home</ax-text>\n <ax-menu-item (onClick)=\"service.new()\">\n <ax-text>New</ax-text>\n <ax-suffix>\n <ax-text>\n Shift+N\n </ax-text>\n </ax-suffix>\n </ax-menu-item>\n <ax-divider></ax-divider>\n <ax-menu-item>\n <ax-text>Export</ax-text>\n <ax-menu-item (onClick)=\"service.downloadJson()\">\n <ax-text>Download JSON</ax-text>\n </ax-menu-item>\n </ax-menu-item>\n <ax-menu-item>\n <ax-text>Import</ax-text>\n <ax-menu-item (onClick)=\"service.importJSon()\">\n <ax-text>Import JSON</ax-text>\n </ax-menu-item>\n </ax-menu-item>\n </ax-menu-item>\n <ax-menu-item>\n <ax-text>Edit</ax-text>\n <ax-menu-item [disabled]=\"!service.canUndo()\" (onClick)=\"service.undo()\">\n <ax-text>Undo</ax-text>\n <ax-prefix>\n <ax-icon>\n <i class=\"fa-solid fa-rotate-left\"></i>\n </ax-icon>\n </ax-prefix>\n <ax-suffix>\n <ax-text>\n Ctrl+Z\n </ax-text>\n </ax-suffix>\n </ax-menu-item>\n <ax-menu-item [disabled]=\"!service.canRedo()\" (onClick)=\"service.redo()\">\n <ax-text>Redo</ax-text>\n <ax-prefix>\n <ax-icon>\n <i class=\"fa-solid fa-rotate-right\"></i>\n </ax-icon>\n </ax-prefix>\n <ax-suffix>\n <ax-text>\n Ctrl+Y\n </ax-text>\n </ax-suffix>\n </ax-menu-item>\n <ax-divider></ax-divider>\n <ax-menu-item [disabled]=\"!service.canCutCopy()\" (onClick)=\"service.cut()\">\n <ax-text>Cut</ax-text>\n <ax-prefix>\n <ax-icon>\n <i class=\"fa-solid fa-cut\"></i>\n </ax-icon>\n </ax-prefix>\n <ax-suffix>\n <ax-text>\n Ctrl+X\n </ax-text>\n </ax-suffix>\n </ax-menu-item>\n <ax-menu-item [disabled]=\"!service.canCutCopy()\" (onClick)=\"service.copy()\">\n <ax-text>Copy</ax-text>\n <ax-prefix>\n <ax-icon>\n <i class=\"fa-solid fa-copy\"></i>\n </ax-icon>\n </ax-prefix>\n <ax-suffix>\n <ax-text>\n Ctrl+C\n </ax-text>\n </ax-suffix>\n </ax-menu-item>\n <ax-menu-item [disabled]=\"!service.canPaste()\" (onClick)=\"service.paste()\">\n <ax-text>Paste</ax-text>\n <ax-prefix>\n <ax-icon>\n <i class=\"fa-solid fa-paste\"></i>\n </ax-icon>\n </ax-prefix>\n <ax-suffix>\n <ax-text>\n Ctrl+V\n </ax-text>\n </ax-suffix>\n </ax-menu-item>\n </ax-menu-item>\n <ax-menu-item>\n <ax-text>Help</ax-text>\n <ax-menu-item>\n <ax-text>About</ax-text>\n </ax-menu-item>\n </ax-menu-item>\n</ax-menu>" }]
|
|
23
23
|
}] });
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhZGVyLW1lbnUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9wbGF0Zm9ybS9sYXlvdXQvZGVzaWduZXIvc3JjL2xpYi9kZXNpZ25lci9jb21wb25lbnRzL2hlYWRlci1tZW51L2hlYWRlci1tZW51LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvcGxhdGZvcm0vbGF5b3V0L2Rlc2lnbmVyL3NyYy9saWIvZGVzaWduZXIvY29tcG9uZW50cy9oZWFkZXItbWVudS9oZWFkZXItbWVudS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDdkQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBQzFELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLCtCQUErQixDQUFDOzs7O0FBYW5FLE1BQU0sT0FBTyw4QkFBOEI7SUFYM0M7UUFZYyxZQUFPLEdBQUcsTUFBTSxDQUFDLGtCQUFrQixDQUFDLENBQUM7S0FDbEQ7OEdBRlksOEJBQThCO2tHQUE5Qiw4QkFBOEIsb0ZDakIzQyxrekdBb0dVLDJDRDNGRixZQUFZLDhCQUNaLGlCQUFpQix1VkFDakIsWUFBWTs7MkZBTVAsOEJBQThCO2tCQVgxQyxTQUFTO2lDQUNNLElBQUksV0FDUDt3QkFDTCxZQUFZO3dCQUNaLGlCQUFpQjt3QkFDakIsWUFBWTtxQkFDZixZQUNTLDBCQUEwQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFYRGVjb3JhdG9yTW9kdWxlIH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzL2RlY29yYXRvcnMnO1xuaW1wb3J0IHsgQVhNZW51TW9kdWxlIH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzL21lbnUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudCwgaW5qZWN0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFYUERlc2lnbmVyU2VydmljZSB9IGZyb20gJy4uLy4uL3NoYXJlZC9kZXNpZ25lci5zZXJ2aWNlJztcblxuQENvbXBvbmVudCh7XG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbXG4gICAgICAgIENvbW1vbk1vZHVsZSxcbiAgICAgICAgQVhEZWNvcmF0b3JNb2R1bGUsXG4gICAgICAgIEFYTWVudU1vZHVsZSxcbiAgICBdLFxuICAgIHNlbGVjdG9yOiAnYXhwLWRlc2lnbmVyLWhlYWRlci1tZW51JyxcbiAgICB0ZW1wbGF0ZVVybDogJ2hlYWRlci1tZW51LmNvbXBvbmVudC5odG1sJ1xufSlcblxuZXhwb3J0IGNsYXNzIEFYUERlc2lnbmVySGVhZGVyTWVudUNvbXBvbmVudCB7XG4gICAgcHJvdGVjdGVkIHNlcnZpY2UgPSBpbmplY3QoQVhQRGVzaWduZXJTZXJ2aWNlKTtcbn0iLCI8YXgtbWVudSBbb3Blbk9uXT1cIidob3ZlcidcIj5cbiAgICA8YXgtbWVudS1pdGVtPlxuICAgICAgICA8YXgtdGV4dD5Ib21lPC9heC10ZXh0PlxuICAgICAgICA8YXgtbWVudS1pdGVtIChvbkNsaWNrKT1cInNlcnZpY2UubmV3KClcIj5cbiAgICAgICAgICAgIDxheC10ZXh0Pk5ldzwvYXgtdGV4dD5cbiAgICAgICAgICAgIDxheC1zdWZmaXg+XG4gICAgICAgICAgICAgICAgPGF4LXRleHQ+XG4gICAgICAgICAgICAgICAgICAgIFNoaWZ0K05cbiAgICAgICAgICAgICAgICA8L2F4LXRleHQ+XG4gICAgICAgICAgICA8L2F4LXN1ZmZpeD5cbiAgICAgICAgPC9heC1tZW51LWl0ZW0+XG4gICAgICAgIDxheC1kaXZpZGVyPjwvYXgtZGl2aWRlcj5cbiAgICAgICAgPGF4LW1lbnUtaXRlbT5cbiAgICAgICAgICAgIDxheC10ZXh0PkV4cG9ydDwvYXgtdGV4dD5cbiAgICAgICAgICAgIDxheC1tZW51LWl0ZW0gKG9uQ2xpY2spPVwic2VydmljZS5kb3dubG9hZEpzb24oKVwiPlxuICAgICAgICAgICAgICAgIDxheC10ZXh0PkRvd25sb2FkIEpTT048L2F4LXRleHQ+XG4gICAgICAgICAgICA8L2F4LW1lbnUtaXRlbT5cbiAgICAgICAgPC9heC1tZW51LWl0ZW0+XG4gICAgICAgIDxheC1tZW51LWl0ZW0+XG4gICAgICAgICAgICA8YXgtdGV4dD5JbXBvcnQ8L2F4LXRleHQ+XG4gICAgICAgICAgICA8YXgtbWVudS1pdGVtIChvbkNsaWNrKT1cInNlcnZpY2UuaW1wb3J0SlNvbigpXCI+XG4gICAgICAgICAgICAgICAgPGF4LXRleHQ+SW1wb3J0IEpTT048L2F4LXRleHQ+XG4gICAgICAgICAgICA8L2F4LW1lbnUtaXRlbT5cbiAgICAgICAgPC9heC1tZW51LWl0ZW0+XG4gICAgPC9heC1tZW51LWl0ZW0+XG4gICAgPGF4LW1lbnUtaXRlbT5cbiAgICAgICAgPGF4LXRleHQ+RWRpdDwvYXgtdGV4dD5cbiAgICAgICAgPGF4LW1lbnUtaXRlbSBbZGlzYWJsZWRdPVwiIXNlcnZpY2UuY2FuVW5kbygpXCIgKG9uQ2xpY2spPVwic2VydmljZS51bmRvKClcIj5cbiAgICAgICAgICAgIDxheC10ZXh0PlVuZG88L2F4LXRleHQ+XG4gICAgICAgICAgICA8YXgtcHJlZml4PlxuICAgICAgICAgICAgICAgIDxheC1pY29uPlxuICAgICAgICAgICAgICAgICAgICA8aSBjbGFzcz1cImZhLXNvbGlkIGZhLXJvdGF0ZS1sZWZ0XCI+PC9pPlxuICAgICAgICAgICAgICAgIDwvYXgtaWNvbj5cbiAgICAgICAgICAgIDwvYXgtcHJlZml4PlxuICAgICAgICAgICAgPGF4LXN1ZmZpeD5cbiAgICAgICAgICAgICAgICA8YXgtdGV4dD5cbiAgICAgICAgICAgICAgICAgICAgQ3RybCtaXG4gICAgICAgICAgICAgICAgPC9heC10ZXh0PlxuICAgICAgICAgICAgPC9heC1zdWZmaXg+XG4gICAgICAgIDwvYXgtbWVudS1pdGVtPlxuICAgICAgICA8YXgtbWVudS1pdGVtIFtkaXNhYmxlZF09XCIhc2VydmljZS5jYW5SZWRvKClcIiAob25DbGljayk9XCJzZXJ2aWNlLnJlZG8oKVwiPlxuICAgICAgICAgICAgPGF4LXRleHQ+UmVkbzwvYXgtdGV4dD5cbiAgICAgICAgICAgIDxheC1wcmVmaXg+XG4gICAgICAgICAgICAgICAgPGF4LWljb24+XG4gICAgICAgICAgICAgICAgICAgIDxpIGNsYXNzPVwiZmEtc29saWQgZmEtcm90YXRlLXJpZ2h0XCI+PC9pPlxuICAgICAgICAgICAgICAgIDwvYXgtaWNvbj5cbiAgICAgICAgICAgIDwvYXgtcHJlZml4PlxuICAgICAgICAgICAgPGF4LXN1ZmZpeD5cbiAgICAgICAgICAgICAgICA8YXgtdGV4dD5cbiAgICAgICAgICAgICAgICAgICAgQ3RybCtZXG4gICAgICAgICAgICAgICAgPC9heC10ZXh0PlxuICAgICAgICAgICAgPC9heC1zdWZmaXg+XG4gICAgICAgIDwvYXgtbWVudS1pdGVtPlxuICAgICAgICA8YXgtZGl2aWRlcj48L2F4LWRpdmlkZXI+XG4gICAgICAgIDxheC1tZW51LWl0ZW0gW2Rpc2FibGVkXT1cIiFzZXJ2aWNlLmNhbkN1dENvcHkoKVwiIChvbkNsaWNrKT1cInNlcnZpY2UuY3V0KClcIj5cbiAgICAgICAgICAgIDxheC10ZXh0PkN1dDwvYXgtdGV4dD5cbiAgICAgICAgICAgIDxheC1wcmVmaXg+XG4gICAgICAgICAgICAgICAgPGF4LWljb24+XG4gICAgICAgICAgICAgICAgICAgIDxpIGNsYXNzPVwiZmEtc29saWQgZmEtY3V0XCI+PC9pPlxuICAgICAgICAgICAgICAgIDwvYXgtaWNvbj5cbiAgICAgICAgICAgIDwvYXgtcHJlZml4PlxuICAgICAgICAgICAgPGF4LXN1ZmZpeD5cbiAgICAgICAgICAgICAgICA8YXgtdGV4dD5cbiAgICAgICAgICAgICAgICAgICAgQ3RybCtYXG4gICAgICAgICAgICAgICAgPC9heC10ZXh0PlxuICAgICAgICAgICAgPC9heC1zdWZmaXg+XG4gICAgICAgIDwvYXgtbWVudS1pdGVtPlxuICAgICAgICA8YXgtbWVudS1pdGVtIFtkaXNhYmxlZF09XCIhc2VydmljZS5jYW5DdXRDb3B5KClcIiAob25DbGljayk9XCJzZXJ2aWNlLmNvcHkoKVwiPlxuICAgICAgICAgICAgPGF4LXRleHQ+Q29weTwvYXgtdGV4dD5cbiAgICAgICAgICAgIDxheC1wcmVmaXg+XG4gICAgICAgICAgICAgICAgPGF4LWljb24+XG4gICAgICAgICAgICAgICAgICAgIDxpIGNsYXNzPVwiZmEtc29saWQgZmEtY29weVwiPjwvaT5cbiAgICAgICAgICAgICAgICA8L2F4LWljb24+XG4gICAgICAgICAgICA8L2F4LXByZWZpeD5cbiAgICAgICAgICAgIDxheC1zdWZmaXg+XG4gICAgICAgICAgICAgICAgPGF4LXRleHQ+XG4gICAgICAgICAgICAgICAgICAgIEN0cmwrQ1xuICAgICAgICAgICAgICAgIDwvYXgtdGV4dD5cbiAgICAgICAgICAgIDwvYXgtc3VmZml4PlxuICAgICAgICA8L2F4LW1lbnUtaXRlbT5cbiAgICAgICAgPGF4LW1lbnUtaXRlbSBbZGlzYWJsZWRdPVwiIXNlcnZpY2UuY2FuUGFzdGUoKVwiIChvbkNsaWNrKT1cInNlcnZpY2UucGFzdGUoKVwiPlxuICAgICAgICAgICAgPGF4LXRleHQ+UGFzdGU8L2F4LXRleHQ+XG4gICAgICAgICAgICA8YXgtcHJlZml4PlxuICAgICAgICAgICAgICAgIDxheC1pY29uPlxuICAgICAgICAgICAgICAgICAgICA8aSBjbGFzcz1cImZhLXNvbGlkIGZhLXBhc3RlXCI+PC9pPlxuICAgICAgICAgICAgICAgIDwvYXgtaWNvbj5cbiAgICAgICAgICAgIDwvYXgtcHJlZml4PlxuICAgICAgICAgICAgPGF4LXN1ZmZpeD5cbiAgICAgICAgICAgICAgICA8YXgtdGV4dD5cbiAgICAgICAgICAgICAgICAgICAgQ3RybCtWXG4gICAgICAgICAgICAgICAgPC9heC10ZXh0PlxuICAgICAgICAgICAgPC9heC1zdWZmaXg+XG4gICAgICAgIDwvYXgtbWVudS1pdGVtPlxuICAgIDwvYXgtbWVudS1pdGVtPlxuICAgIDxheC1tZW51LWl0ZW0+XG4gICAgICAgIDxheC10ZXh0PkhlbHA8L2F4LXRleHQ+XG4gICAgICAgIDxheC1tZW51LWl0ZW0+XG4gICAgICAgICAgICA8YXgtdGV4dD5BYm91dDwvYXgtdGV4dD5cbiAgICAgICAgPC9heC1tZW51LWl0ZW0+XG4gICAgPC9heC1tZW51LWl0ZW0+XG48L2F4LW1lbnU+Il19
|