UNPKG

@dotcms/angular

Version:

Official Angular Components library to render a dotCMS page.

126 lines 19.2 kB
import { AsyncPipe, NgComponentOutlet } from '@angular/common'; import { ChangeDetectionStrategy, Component, HostBinding, Input, computed, inject, signal } from '@angular/core'; import { NoComponent } from '../../components/no-component/no-component.component'; import { PageContextService } from '../../services/dotcms-context/page-context.service'; import { getContainersData } from '../../utils'; import { ContentletComponent } from '../contentlet/contentlet.component'; import * as i0 from "@angular/core"; /** * This component is responsible to display a container with contentlets. * * @export * @class ContainerComponent * @implements {OnChanges} */ export class ContainerComponent { constructor() { this.pageContextService = inject(PageContextService); this.NoComponent = NoComponent; this.$isInsideEditor = signal(false); this.$contentlets = signal([]); this.$dotContainer = signal(null); this.$dotContainerAsString = computed(() => JSON.stringify(this.$dotContainer())); /** * The accept types for the container component. * * @type {(string | null)} * @memberof ContainerComponent */ this.acceptTypes = null; /** * The identifier for the container component. * * @type {(string | null)} * @memberof ContainerComponent */ this.identifier = null; /** * The max contentlets for the container component. * * @type {(number | null)} * @memberof ContainerComponent */ this.maxContentlets = null; /** * The uuid for the container component. * * @type {(string | null)} * @memberof ContainerComponent */ this.uuid = null; /** * The class for the container component. * * @type {(string | null)} * @memberof ContainerComponent */ this.class = null; /** * The dot object for the container component. * * @type {(string | null)} * @memberof ContainerComponent */ this.dotObject = null; /** * The data-testid attribute used for identifying the component during testing. * * @memberof ContainerComponent */ this.testId = 'dot-container'; } ngOnChanges() { const { pageAsset, components, isInsideEditor } = this.pageContextService.context; const { acceptTypes, maxContentlets, variantId, path, contentlets } = getContainersData(pageAsset.containers, this.container); const { identifier, uuid } = this.container; this.componentsMap = components; this.$isInsideEditor.set(isInsideEditor); this.$contentlets.set(contentlets); this.$dotContainer.set({ identifier: path ?? identifier, acceptTypes, maxContentlets, variantId, uuid }); if (this.$isInsideEditor()) { this.acceptTypes = acceptTypes; this.identifier = identifier; this.maxContentlets = maxContentlets; this.uuid = uuid; this.class = this.$contentlets().length ? null : 'empty-container'; this.dotObject = 'container'; } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: ContainerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.3", type: ContainerComponent, isStandalone: true, selector: "dotcms-container", inputs: { container: "container" }, host: { properties: { "attr.data-dot-accept-types": "this.acceptTypes", "attr.data-dot-identifier": "this.identifier", "attr.data-max-contentlets": "this.maxContentlets", "attr.data-dot-uuid": "this.uuid", "class": "this.class", "attr.data-dot-object": "this.dotObject", "attr.data-testid": "this.testId" } }, usesOnChanges: true, ngImport: i0, template: "@if ($isInsideEditor()) {\n @if ($contentlets().length) {\n @for (contentlet of $contentlets(); track $index) {\n <dotcms-contentlet-wrapper\n [contentlet]=\"contentlet\"\n [container]=\"$dotContainerAsString()\">\n <ng-container\n *ngComponentOutlet=\"\n (componentsMap[contentlet.contentType] || componentsMap['CustomNoComponent']\n | async) || NoComponent;\n inputs: { contentlet }\n \" />\n </dotcms-contentlet-wrapper>\n }\n } @else {\n This container is empty.\n }\n} @else {\n @for (contentlet of $contentlets(); track $index) {\n <ng-container\n *ngComponentOutlet=\"\n componentsMap[contentlet.contentType] | async;\n inputs: { contentlet }\n \" />\n }\n}\n", styles: [":host.empty-container{width:100%;background-color:#ecf0fd;display:flex;justify-content:center;align-items:center;color:#030e32;height:10rem}\n"], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "directive", type: NgComponentOutlet, selector: "[ngComponentOutlet]", inputs: ["ngComponentOutlet", "ngComponentOutletInputs", "ngComponentOutletInjector", "ngComponentOutletContent", "ngComponentOutletNgModule", "ngComponentOutletNgModuleFactory"] }, { kind: "component", type: ContentletComponent, selector: "dotcms-contentlet-wrapper", inputs: ["contentlet", "container"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: ContainerComponent, decorators: [{ type: Component, args: [{ selector: 'dotcms-container', standalone: true, imports: [AsyncPipe, NgComponentOutlet, NoComponent, ContentletComponent], changeDetection: ChangeDetectionStrategy.OnPush, template: "@if ($isInsideEditor()) {\n @if ($contentlets().length) {\n @for (contentlet of $contentlets(); track $index) {\n <dotcms-contentlet-wrapper\n [contentlet]=\"contentlet\"\n [container]=\"$dotContainerAsString()\">\n <ng-container\n *ngComponentOutlet=\"\n (componentsMap[contentlet.contentType] || componentsMap['CustomNoComponent']\n | async) || NoComponent;\n inputs: { contentlet }\n \" />\n </dotcms-contentlet-wrapper>\n }\n } @else {\n This container is empty.\n }\n} @else {\n @for (contentlet of $contentlets(); track $index) {\n <ng-container\n *ngComponentOutlet=\"\n componentsMap[contentlet.contentType] | async;\n inputs: { contentlet }\n \" />\n }\n}\n", styles: [":host.empty-container{width:100%;background-color:#ecf0fd;display:flex;justify-content:center;align-items:center;color:#030e32;height:10rem}\n"] }] }], propDecorators: { container: [{ type: Input, args: [{ required: true }] }], acceptTypes: [{ type: HostBinding, args: ['attr.data-dot-accept-types'] }], identifier: [{ type: HostBinding, args: ['attr.data-dot-identifier'] }], maxContentlets: [{ type: HostBinding, args: ['attr.data-max-contentlets'] }], uuid: [{ type: HostBinding, args: ['attr.data-dot-uuid'] }], class: [{ type: HostBinding, args: ['class'] }], dotObject: [{ type: HostBinding, args: ['attr.data-dot-object'] }], testId: [{ type: HostBinding, args: ['attr.data-testid'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"container.component.js","sourceRoot":"","sources":["../../../../../../../../libs/sdk/angular/src/lib/layout/container/container.component.ts","../../../../../../../../libs/sdk/angular/src/lib/layout/container/container.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AsyncPipe, NgComponentOutlet } from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    HostBinding,\n    Input,\n    OnChanges,\n    computed,\n    inject,\n    signal\n} from '@angular/core';\n\nimport { NoComponent } from '../../components/no-component/no-component.component';\nimport { DynamicComponentEntity } from '../../models';\nimport { DotCMSContainer, DotCMSContentlet } from '../../models/dotcms.model';\nimport { PageContextService } from '../../services/dotcms-context/page-context.service';\nimport { getContainersData } from '../../utils';\nimport { ContentletComponent } from '../contentlet/contentlet.component';\n\ninterface DotContainer {\n    acceptTypes: string;\n    identifier: string;\n    maxContentlets: number;\n    uuid: string;\n    variantId?: string;\n}\n\n/**\n * This component is responsible to display a container with contentlets.\n *\n * @export\n * @class ContainerComponent\n * @implements {OnChanges}\n */\n@Component({\n    selector: 'dotcms-container',\n    standalone: true,\n    imports: [AsyncPipe, NgComponentOutlet, NoComponent, ContentletComponent],\n    templateUrl: './container.component.html',\n    styleUrl: './container.component.css',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ContainerComponent implements OnChanges {\n    /**\n     * The container object containing the contentlets.\n     *\n     * @type {DotCMSContainer}\n     * @memberof ContainerComponent\n     */\n    @Input({ required: true }) container!: DotCMSContainer;\n\n    private readonly pageContextService: PageContextService = inject(PageContextService);\n    protected readonly NoComponent = NoComponent;\n    protected readonly $isInsideEditor = signal<boolean>(false);\n\n    protected componentsMap!: Record<string, DynamicComponentEntity>;\n    protected $contentlets = signal<DotCMSContentlet[]>([]);\n    protected $dotContainer = signal<DotContainer | null>(null);\n    protected $dotContainerAsString = computed(() => JSON.stringify(this.$dotContainer()));\n\n    /**\n     * The accept types for the container component.\n     *\n     * @type {(string | null)}\n     * @memberof ContainerComponent\n     */\n    @HostBinding('attr.data-dot-accept-types') acceptTypes: string | null = null;\n\n    /**\n     * The identifier for the container component.\n     *\n     * @type {(string | null)}\n     * @memberof ContainerComponent\n     */\n    @HostBinding('attr.data-dot-identifier') identifier: string | null = null;\n    /**\n     * The max contentlets for the container component.\n     *\n     * @type {(number | null)}\n     * @memberof ContainerComponent\n     */\n    @HostBinding('attr.data-max-contentlets') maxContentlets: number | null = null;\n    /**\n     * The uuid for the container component.\n     *\n     * @type {(string | null)}\n     * @memberof ContainerComponent\n     */\n    @HostBinding('attr.data-dot-uuid') uuid: string | null = null;\n    /**\n     * The class for the container component.\n     *\n     * @type {(string | null)}\n     * @memberof ContainerComponent\n     */\n    @HostBinding('class') class: string | null = null;\n    /**\n     * The dot object for the container component.\n     *\n     * @type {(string | null)}\n     * @memberof ContainerComponent\n     */\n    @HostBinding('attr.data-dot-object') dotObject: string | null = null;\n    /**\n     * The data-testid attribute used for identifying the component during testing.\n     *\n     * @memberof ContainerComponent\n     */\n    @HostBinding('attr.data-testid') testId = 'dot-container';\n\n    ngOnChanges() {\n        const { pageAsset, components, isInsideEditor } = this.pageContextService.context;\n        const { acceptTypes, maxContentlets, variantId, path, contentlets } = getContainersData(\n            pageAsset.containers,\n            this.container\n        );\n        const { identifier, uuid } = this.container;\n\n        this.componentsMap = components;\n\n        this.$isInsideEditor.set(isInsideEditor);\n        this.$contentlets.set(contentlets);\n        this.$dotContainer.set({\n            identifier: path ?? identifier,\n            acceptTypes,\n            maxContentlets,\n            variantId,\n            uuid\n        });\n\n        if (this.$isInsideEditor()) {\n            this.acceptTypes = acceptTypes;\n            this.identifier = identifier;\n            this.maxContentlets = maxContentlets;\n            this.uuid = uuid;\n            this.class = this.$contentlets().length ? null : 'empty-container';\n            this.dotObject = 'container';\n        }\n    }\n}\n","@if ($isInsideEditor()) {\n    @if ($contentlets().length) {\n        @for (contentlet of $contentlets(); track $index) {\n            <dotcms-contentlet-wrapper\n                [contentlet]=\"contentlet\"\n                [container]=\"$dotContainerAsString()\">\n                <ng-container\n                    *ngComponentOutlet=\"\n                        (componentsMap[contentlet.contentType] || componentsMap['CustomNoComponent']\n                            | async) || NoComponent;\n                        inputs: { contentlet }\n                    \" />\n            </dotcms-contentlet-wrapper>\n        }\n    } @else {\n        This container is empty.\n    }\n} @else {\n    @for (contentlet of $contentlets(); track $index) {\n        <ng-container\n            *ngComponentOutlet=\"\n                componentsMap[contentlet.contentType] | async;\n                inputs: { contentlet }\n            \" />\n    }\n}\n"]}