@acorex/platform 20.7.6 → 20.7.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (23) hide show
  1. package/fesm2022/acorex-platform-core.mjs +5 -3
  2. package/fesm2022/acorex-platform-core.mjs.map +1 -1
  3. package/fesm2022/acorex-platform-layout-components-binding-expression-editor-popup.component-ZnTG7wlJ.mjs +121 -0
  4. package/fesm2022/acorex-platform-layout-components-binding-expression-editor-popup.component-ZnTG7wlJ.mjs.map +1 -0
  5. package/fesm2022/acorex-platform-layout-components.mjs +232 -107
  6. package/fesm2022/acorex-platform-layout-components.mjs.map +1 -1
  7. package/fesm2022/acorex-platform-layout-entity.mjs +612 -330
  8. package/fesm2022/acorex-platform-layout-entity.mjs.map +1 -1
  9. package/fesm2022/acorex-platform-layout-widget-core.mjs +11 -2
  10. package/fesm2022/acorex-platform-layout-widget-core.mjs.map +1 -1
  11. package/fesm2022/{acorex-platform-layout-widgets-repeater-widget-column.component-D4UOMW6k.mjs → acorex-platform-layout-widgets-repeater-widget-column.component-fcCirNxz.mjs} +2 -2
  12. package/fesm2022/acorex-platform-layout-widgets-repeater-widget-column.component-fcCirNxz.mjs.map +1 -0
  13. package/fesm2022/acorex-platform-layout-widgets.mjs +582 -76
  14. package/fesm2022/acorex-platform-layout-widgets.mjs.map +1 -1
  15. package/fesm2022/{acorex-platform-themes-default-entity-master-list-view.component-C31xDGGb.mjs → acorex-platform-themes-default-entity-master-list-view.component-DzWjSMSK.mjs} +5 -4
  16. package/fesm2022/{acorex-platform-themes-default-entity-master-list-view.component-C31xDGGb.mjs.map → acorex-platform-themes-default-entity-master-list-view.component-DzWjSMSK.mjs.map} +1 -1
  17. package/fesm2022/acorex-platform-themes-default.mjs +2 -2
  18. package/layout/components/index.d.ts +49 -28
  19. package/layout/entity/index.d.ts +42 -41
  20. package/layout/widget-core/index.d.ts +11 -2
  21. package/layout/widgets/index.d.ts +130 -8
  22. package/package.json +1 -1
  23. package/fesm2022/acorex-platform-layout-widgets-repeater-widget-column.component-D4UOMW6k.mjs.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"file":"acorex-platform-layout-widgets-repeater-widget-column.component-D4UOMW6k.mjs","sources":["../tmp-esm2022/layout/widgets/lib/widgets/layout/repeater/repeater-widget-column.component.js"],"sourcesContent":["import { AXBadgeModule } from '@acorex/components/badge';\nimport { AXPColumnWidgetComponent, AXPWidgetCoreModule, AXPWidgetCoreContextStore, AXPWidgetCoreService } from '@acorex/platform/layout/widget-core';\nimport { AXButtonModule } from '@acorex/components/button';\nimport { AXPopoverModule } from '@acorex/components/popover';\nimport { ChangeDetectionStrategy, Component, computed, signal, viewChild } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { isNil } from 'lodash-es';\nimport * as i0 from \"@angular/core\";\nimport * as i1 from \"@acorex/components/popover\";\nimport * as i2 from \"@acorex/platform/layout/widget-core\";\nexport class AXPRepeaterWidgetColumnComponent extends AXPColumnWidgetComponent {\n constructor() {\n super(...arguments);\n //#region ---- View Children ----\n this.moreButton = viewChild('moreButton', ...(ngDevMode ? [{ debugName: \"moreButton\" }] : []));\n this.morePopover = viewChild('morePopover', ...(ngDevMode ? [{ debugName: \"morePopover\" }] : []));\n //#endregion\n //#region ---- Properties ----\n this.maxVisible = this.options['maxVisible'] ?? 2;\n this.childWidgetNode = this.options['children']?.[0];\n //#endregion\n //#region ---- Signals ----\n this.isMorePopoverOpen = signal(false, ...(ngDevMode ? [{ debugName: \"isMorePopoverOpen\" }] : []));\n //#endregion\n //#region ---- Node Cache ----\n // Cache nodes by index to prevent recreation on every change detection\n this.nodeCache = new Map();\n this.lastItems = [];\n //#endregion\n //#region ---- Computed Properties ----\n this.displayItems = computed(() => {\n if (isNil(this.rawValue)) {\n return [];\n }\n const items = Array.isArray(this.rawValue) ? this.rawValue : [this.rawValue];\n return items.filter((item) => item != null);\n }, ...(ngDevMode ? [{ debugName: \"displayItems\" }] : []));\n this.allItems = computed(() => this.displayItems(), ...(ngDevMode ? [{ debugName: \"allItems\" }] : []));\n this.visibleItems = computed(() => {\n const items = this.allItems();\n return items.slice(0, this.maxVisible);\n }, ...(ngDevMode ? [{ debugName: \"visibleItems\" }] : []));\n this.hasMoreItems = computed(() => {\n return this.allItems().length > this.maxVisible;\n }, ...(ngDevMode ? [{ debugName: \"hasMoreItems\" }] : []));\n this.remainingItemsCount = computed(() => {\n return this.allItems().length - this.maxVisible;\n }, ...(ngDevMode ? [{ debugName: \"remainingItemsCount\" }] : []));\n }\n // Clear cache when items change\n clearCacheIfNeeded() {\n const currentItems = this.allItems();\n if (currentItems.length !== this.lastItems.length ||\n currentItems.some((item, idx) => item !== this.lastItems[idx])) {\n this.nodeCache.clear();\n this.lastItems = [...currentItems];\n }\n }\n //#endregion\n //#region ---- Public Methods ----\n showMoreItems() {\n this.openMorePopover();\n }\n onMorePopoverOpenChange(event) {\n this.isMorePopoverOpen.set(event);\n }\n getItemNode(item, index) {\n if (!this.childWidgetNode) {\n return undefined;\n }\n // Clear cache if items changed\n this.clearCacheIfNeeded();\n // Return cached node if exists\n const cachedNode = this.nodeCache.get(index);\n if (cachedNode) {\n return cachedNode;\n }\n // Create new node and cache it\n const node = {\n ...this.childWidgetNode,\n path: `${this.path}[${index}]`,\n defaultValue: item,\n options: {\n ...this.childWidgetNode.options,\n rawValue: item,\n rowData: this.rowData,\n },\n };\n this.nodeCache.set(index, node);\n return node;\n }\n //#endregion\n //#region ---- Private Methods ----\n openMorePopover() {\n if (this.morePopover() && this.moreButton()) {\n this.morePopover().target = this.moreButton().nativeElement;\n this.morePopover().open();\n this.isMorePopoverOpen.set(true);\n }\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.3.16\", ngImport: i0, type: AXPRepeaterWidgetColumnComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }\n static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: \"17.0.0\", version: \"20.3.16\", type: AXPRepeaterWidgetColumnComponent, isStandalone: true, selector: \"axp-repeater-widget-column\", inputs: { rawValue: \"rawValue\", rowData: \"rowData\" }, providers: [AXPWidgetCoreService, AXPWidgetCoreContextStore], viewQueries: [{ propertyName: \"moreButton\", first: true, predicate: [\"moreButton\"], descendants: true, isSignal: true }, { propertyName: \"morePopover\", first: true, predicate: [\"morePopover\"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: \"<div class=\\\"ax-flex ax-gap-1 ax-items-center \\\">\\n\\n @for (item of visibleItems(); track $index) {\\n @if (childWidgetNode) {\\n <ng-container axp-widget-renderer [node]=\\\"getItemNode(item, $index)!\\\" [mode]=\\\"'view'\\\" [parentNode]=\\\"null\\\"\\n [index]=\\\"$index\\\"></ng-container>\\n }\\n }@empty {\\n <span class=\\\"ax-text-muted\\\">---</span>\\n }\\n\\n\\n @if (hasMoreItems()) {\\n <span\\n class=\\\"ax-absolute ax-flex ax-items-center ax-end-0 ax-px-1 ax-cursor-pointer ax-h-full hover:ax-primary-lighter\\\"\\n (click)=\\\"showMoreItems()\\\" #moreButton>\\n <i class=\\\"fa-light fa-ellipsis-vertical\\\"></i>\\n </span>\\n }\\n</div>\\n\\n<!-- More Items Popover -->\\n<ax-popover [openOn]=\\\"'manual'\\\" #morePopover (openChange)=\\\"onMorePopoverOpenChange($event)\\\">\\n <div class=\\\"ax-lightest-surface ax-border ax-rounded-lg ax-shadow-lg ax-p-4 ax-min-w-[280px]\\\">\\n <div class=\\\"ax-mb-4 ax-border-b ax-pb-2\\\">\\n <h3 class=\\\"ax-text-base ax-font-semibold\\\">All {{ allItems().length }} Items</h3>\\n </div>\\n <div class=\\\"ax-max-h-64 ax-flex ax-flex-col ax-gap-3 ax-overflow-auto\\\" style=\\\"max-height: max(30dvh,10rem)\\\">\\n @for (item of allItems(); track $index) {\\n <div>\\n @if (childWidgetNode) {\\n <ng-container axp-widget-renderer [node]=\\\"getItemNode(item, $index)!\\\" [mode]=\\\"'view'\\\"\\n [parentNode]=\\\"null\\\" [index]=\\\"$index\\\"></ng-container>\\n }\\n </div>\\n }\\n </div>\\n </div>\\n</ax-popover>\", dependencies: [{ kind: \"ngmodule\", type: CommonModule }, { kind: \"ngmodule\", type: AXBadgeModule }, { kind: \"ngmodule\", type: AXButtonModule }, { kind: \"ngmodule\", type: AXPopoverModule }, { kind: \"component\", type: i1.AXPopoverComponent, selector: \"ax-popover\", inputs: [\"width\", \"disabled\", \"offsetX\", \"offsetY\", \"target\", \"placement\", \"content\", \"openOn\", \"closeOn\", \"hasBackdrop\", \"openAfter\", \"closeAfter\", \"backdropClass\", \"panelClass\", \"adaptivityEnabled\"], outputs: [\"onOpened\", \"onClosed\"] }, { kind: \"ngmodule\", type: AXPWidgetCoreModule }, { kind: \"directive\", type: i2.AXPWidgetRendererDirective, selector: \"[axp-widget-renderer]\", inputs: [\"parentNode\", \"index\", \"mode\", \"node\"], outputs: [\"onOptionsChanged\", \"onValueChanged\", \"onLoad\"], exportAs: [\"widgetRenderer\"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.3.16\", ngImport: i0, type: AXPRepeaterWidgetColumnComponent, decorators: [{\n type: Component,\n args: [{ selector: 'axp-repeater-widget-column', changeDetection: ChangeDetectionStrategy.OnPush, imports: [CommonModule, AXBadgeModule, AXButtonModule, AXPopoverModule, AXPWidgetCoreModule], providers: [AXPWidgetCoreService, AXPWidgetCoreContextStore], inputs: ['rawValue', 'rowData'], template: \"<div class=\\\"ax-flex ax-gap-1 ax-items-center \\\">\\n\\n @for (item of visibleItems(); track $index) {\\n @if (childWidgetNode) {\\n <ng-container axp-widget-renderer [node]=\\\"getItemNode(item, $index)!\\\" [mode]=\\\"'view'\\\" [parentNode]=\\\"null\\\"\\n [index]=\\\"$index\\\"></ng-container>\\n }\\n }@empty {\\n <span class=\\\"ax-text-muted\\\">---</span>\\n }\\n\\n\\n @if (hasMoreItems()) {\\n <span\\n class=\\\"ax-absolute ax-flex ax-items-center ax-end-0 ax-px-1 ax-cursor-pointer ax-h-full hover:ax-primary-lighter\\\"\\n (click)=\\\"showMoreItems()\\\" #moreButton>\\n <i class=\\\"fa-light fa-ellipsis-vertical\\\"></i>\\n </span>\\n }\\n</div>\\n\\n<!-- More Items Popover -->\\n<ax-popover [openOn]=\\\"'manual'\\\" #morePopover (openChange)=\\\"onMorePopoverOpenChange($event)\\\">\\n <div class=\\\"ax-lightest-surface ax-border ax-rounded-lg ax-shadow-lg ax-p-4 ax-min-w-[280px]\\\">\\n <div class=\\\"ax-mb-4 ax-border-b ax-pb-2\\\">\\n <h3 class=\\\"ax-text-base ax-font-semibold\\\">All {{ allItems().length }} Items</h3>\\n </div>\\n <div class=\\\"ax-max-h-64 ax-flex ax-flex-col ax-gap-3 ax-overflow-auto\\\" style=\\\"max-height: max(30dvh,10rem)\\\">\\n @for (item of allItems(); track $index) {\\n <div>\\n @if (childWidgetNode) {\\n <ng-container axp-widget-renderer [node]=\\\"getItemNode(item, $index)!\\\" [mode]=\\\"'view'\\\"\\n [parentNode]=\\\"null\\\" [index]=\\\"$index\\\"></ng-container>\\n }\\n </div>\\n }\\n </div>\\n </div>\\n</ax-popover>\" }]\n }], propDecorators: { moreButton: [{ type: i0.ViewChild, args: ['moreButton', { isSignal: true }] }], morePopover: [{ type: i0.ViewChild, args: ['morePopover', { isSignal: true }] }] } });\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"repeater-widget-column.component.js","sourceRoot":"","sources":["../../../../../../../../../../libs/platform/layout/widgets/src/lib/widgets/layout/repeater/repeater-widget-column.component.ts","../../../../../../../../../../libs/platform/layout/widgets/src/lib/widgets/layout/repeater/repeater-widget-column.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXBadgeModule } from '@acorex/components/badge';\nimport { AXPColumnWidgetComponent, AXPWidgetNode, AXPWidgetCoreModule, AXPWidgetCoreContextStore, AXPWidgetCoreService } from '@acorex/platform/layout/widget-core';\nimport { AXButtonModule } from '@acorex/components/button';\nimport { AXPopoverComponent, AXPopoverModule } from '@acorex/components/popover';\nimport { ChangeDetectionStrategy, Component, computed, ElementRef, signal, viewChild } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { isNil } from 'lodash-es';\n\n@Component({\n    selector: 'axp-repeater-widget-column',\n    templateUrl: './repeater-widget-column.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    imports: [CommonModule, AXBadgeModule, AXButtonModule, AXPopoverModule, AXPWidgetCoreModule],\n    providers: [AXPWidgetCoreService, AXPWidgetCoreContextStore],\n    inputs: ['rawValue', 'rowData'],\n})\nexport class AXPRepeaterWidgetColumnComponent extends AXPColumnWidgetComponent<any[]> {\n    //#region ----   View Children   ----\n\n    protected moreButton = viewChild<ElementRef>('moreButton');\n    protected morePopover = viewChild<AXPopoverComponent>('morePopover');\n\n    //#endregion\n\n    //#region ----   Properties   ----\n\n    protected maxVisible: number = this.options['maxVisible'] ?? 2;\n    protected childWidgetNode: AXPWidgetNode | undefined = this.options['children']?.[0];\n\n    //#endregion\n\n    //#region ----   Signals   ----\n\n    protected isMorePopoverOpen = signal(false);\n\n    //#endregion\n\n    //#region ----   Node Cache   ----\n\n    // Cache nodes by index to prevent recreation on every change detection\n    private nodeCache = new Map<number, AXPWidgetNode>();\n    private lastItems: any[] = [];\n\n    // Clear cache when items change\n    private clearCacheIfNeeded(): void {\n        const currentItems = this.allItems();\n        if (currentItems.length !== this.lastItems.length ||\n            currentItems.some((item, idx) => item !== this.lastItems[idx])) {\n            this.nodeCache.clear();\n            this.lastItems = [...currentItems];\n        }\n    }\n\n    //#endregion\n\n    //#region ----   Computed Properties   ----\n\n    protected displayItems = computed(() => {\n        if (isNil(this.rawValue)) {\n            return [];\n        }\n        const items = Array.isArray(this.rawValue) ? this.rawValue : [this.rawValue];\n        return items.filter((item) => item != null);\n    });\n\n    protected allItems = computed(() => this.displayItems());\n\n    protected visibleItems = computed(() => {\n        const items = this.allItems();\n        return items.slice(0, this.maxVisible);\n    });\n\n    protected hasMoreItems = computed(() => {\n        return this.allItems().length > this.maxVisible;\n    });\n\n    protected remainingItemsCount = computed(() => {\n        return this.allItems().length - this.maxVisible;\n    });\n\n    //#endregion\n\n    //#region ----   Public Methods   ----\n\n    protected showMoreItems(): void {\n        this.openMorePopover();\n    }\n\n    protected onMorePopoverOpenChange(event: any): void {\n        this.isMorePopoverOpen.set(event);\n    }\n\n    protected getItemNode(item: any, index: number): AXPWidgetNode | undefined {\n        if (!this.childWidgetNode) {\n            return undefined;\n        }\n\n        // Clear cache if items changed\n        this.clearCacheIfNeeded();\n\n        // Return cached node if exists\n        const cachedNode = this.nodeCache.get(index);\n        if (cachedNode) {\n            return cachedNode;\n        }\n\n        // Create new node and cache it\n        const node: AXPWidgetNode = {\n            ...this.childWidgetNode,\n            path: `${this.path}[${index}]`,\n            defaultValue: item,\n            options: {\n                ...this.childWidgetNode.options,\n                rawValue: item,\n                rowData: this.rowData,\n            },\n        };\n\n        this.nodeCache.set(index, node);\n        return node;\n    }\n\n    //#endregion\n\n    //#region ----   Private Methods   ----\n\n    private openMorePopover(): void {\n        if (this.morePopover() && this.moreButton()) {\n            this.morePopover()!.target = this.moreButton()!.nativeElement;\n            this.morePopover()!.open();\n            this.isMorePopoverOpen.set(true);\n        }\n    }\n\n    //#endregion\n}\n\n","<div class=\"ax-flex ax-gap-1 ax-items-center \">\n\n    @for (item of visibleItems(); track $index) {\n    @if (childWidgetNode) {\n    <ng-container axp-widget-renderer [node]=\"getItemNode(item, $index)!\" [mode]=\"'view'\" [parentNode]=\"null\"\n        [index]=\"$index\"></ng-container>\n    }\n    }@empty {\n    <span class=\"ax-text-muted\">---</span>\n    }\n\n\n    @if (hasMoreItems()) {\n    <span\n        class=\"ax-absolute ax-flex ax-items-center ax-end-0 ax-px-1 ax-cursor-pointer ax-h-full hover:ax-primary-lighter\"\n        (click)=\"showMoreItems()\" #moreButton>\n        <i class=\"fa-light fa-ellipsis-vertical\"></i>\n    </span>\n    }\n</div>\n\n<!-- More Items Popover -->\n<ax-popover [openOn]=\"'manual'\" #morePopover (openChange)=\"onMorePopoverOpenChange($event)\">\n    <div class=\"ax-lightest-surface ax-border ax-rounded-lg ax-shadow-lg ax-p-4 ax-min-w-[280px]\">\n        <div class=\"ax-mb-4 ax-border-b ax-pb-2\">\n            <h3 class=\"ax-text-base ax-font-semibold\">All {{ allItems().length }} Items</h3>\n        </div>\n        <div class=\"ax-max-h-64 ax-flex ax-flex-col ax-gap-3 ax-overflow-auto\" style=\"max-height: max(30dvh,10rem)\">\n            @for (item of allItems(); track $index) {\n            <div>\n                @if (childWidgetNode) {\n                <ng-container axp-widget-renderer [node]=\"getItemNode(item, $index)!\" [mode]=\"'view'\"\n                    [parentNode]=\"null\" [index]=\"$index\"></ng-container>\n                }\n            </div>\n            }\n        </div>\n    </div>\n</ax-popover>"]}"],"names":["i1","i2"],"mappings":"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"}