@dotcms/angular
Version:
Official Angular Components library to render a dotCMS page.
100 lines • 14.1 kB
JavaScript
import { AsyncPipe } from '@angular/common';
import { ChangeDetectionStrategy, Component, DestroyRef, Input, inject } from '@angular/core';
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
import { ActivatedRoute } from '@angular/router';
import { CLIENT_ACTIONS, DotCmsClient, initEditor, isInsideEditor, postMessageToEditor, updateNavigation } from '@dotcms/client';
import { PageContextService } from '../../services/dotcms-context/page-context.service';
import { RowComponent } from '../row/row.component';
import * as i0 from "@angular/core";
/**
* `DotcmsLayoutComponent` is a class that represents the layout for a DotCMS page.
* It includes a `pageAsset` property that represents the DotCMS page asset and a `components` property that represents the dynamic components for the page.
*
* @export
* @class DotcmsLayoutComponent
*/
export class DotcmsLayoutComponent {
constructor() {
this.route = inject(ActivatedRoute);
this.pageContextService = inject(PageContextService);
this.destroyRef$ = inject(DestroyRef);
this.pageAsset$ = this.pageContextService.currentPage$;
}
/**
* Represents the DotCMS page asset.
*
* @type {DotCMSPageAsset}
* @memberof DotcmsLayoutComponent
*/
set pageAsset(value) {
this._pageAsset = value;
if (!value.layout) {
console.warn('Warning: pageAsset does not have a `layout` property. Might be using an advaced template or your dotCMS instance not have a enterprise license.');
}
}
/**
* Returns the DotCMS page asset.
*
* @readonly
* @type {DotCMSPageAsset}
* @memberof DotcmsLayoutComponent
*/
get pageAsset() {
return this._pageAsset;
}
ngOnInit() {
this.pageContextService.setContext(this.pageAsset, this.components);
if (!isInsideEditor()) {
return;
}
this.client = DotCmsClient.instance;
this.route.url.pipe(takeUntilDestroyed(this.destroyRef$)).subscribe((urlSegments) => {
const pathname = '/' + urlSegments.join('/');
initEditor({ pathname });
updateNavigation(pathname || '/');
});
this.client.editor.on('changes', (data) => {
if (this.onReload) {
this.onReload();
return;
}
this.pageContextService.setPageAsset(data);
});
postMessageToEditor({ action: CLIENT_ACTIONS.CLIENT_READY, payload: this.editor });
}
ngOnDestroy() {
if (!isInsideEditor()) {
return;
}
this.client.editor.off('changes');
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: DotcmsLayoutComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.3", type: DotcmsLayoutComponent, isStandalone: true, selector: "dotcms-layout", inputs: { pageAsset: "pageAsset", components: "components", onReload: "onReload", editor: "editor" }, ngImport: i0, template: `
(pageAsset$ | async; as page) {
(row of page?.layout?.body?.rows; track $index) {
<dotcms-row [row]="row" />
}
}
`, isInline: true, styles: [":host{display:block}\n"], dependencies: [{ kind: "component", type: RowComponent, selector: "dotcms-row", inputs: ["row"] }, { kind: "pipe", type: AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: DotcmsLayoutComponent, decorators: [{
type: Component,
args: [{ selector: 'dotcms-layout', standalone: true, imports: [RowComponent, AsyncPipe], template: `
(pageAsset$ | async; as page) {
(row of page?.layout?.body?.rows; track $index) {
<dotcms-row [row]="row" />
}
}
`, changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host{display:block}\n"] }]
}], propDecorators: { pageAsset: [{
type: Input,
args: [{ required: true }]
}], components: [{
type: Input,
args: [{ required: true }]
}], onReload: [{
type: Input
}], editor: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dotcms-layout.component.js","sourceRoot":"","sources":["../../../../../../../../libs/sdk/angular/src/lib/layout/dotcms-layout/dotcms-layout.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AsyncPipe } from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    DestroyRef,\n    Input,\n    OnInit,\n    inject\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { ActivatedRoute } from '@angular/router';\n\nimport {\n    CLIENT_ACTIONS,\n    DotCmsClient,\n    EditorConfig,\n    initEditor,\n    isInsideEditor,\n    postMessageToEditor,\n    updateNavigation\n} from '@dotcms/client';\n\nimport { DotCMSPageComponent } from '../../models';\nimport { DotCMSPageAsset } from '../../models/dotcms.model';\nimport { PageContextService } from '../../services/dotcms-context/page-context.service';\nimport { RowComponent } from '../row/row.component';\n\n/**\n * `DotcmsLayoutComponent` is a class that represents the layout for a DotCMS page.\n *  It includes a `pageAsset` property that represents the DotCMS page asset and a `components` property that represents the dynamic components for the page.\n *\n * @export\n * @class DotcmsLayoutComponent\n */\n@Component({\n    selector: 'dotcms-layout',\n    standalone: true,\n    imports: [RowComponent, AsyncPipe],\n    template: `\n        @if (pageAsset$ | async; as page) {\n            @for (row of page?.layout?.body?.rows; track $index) {\n                <dotcms-row [row]=\"row\" />\n            }\n        }\n    `,\n    styleUrl: './dotcms-layout.component.css',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DotcmsLayoutComponent implements OnInit {\n    private _pageAsset!: DotCMSPageAsset;\n\n    /**\n     * Represents the DotCMS page asset.\n     *\n     * @type {DotCMSPageAsset}\n     * @memberof DotcmsLayoutComponent\n     */\n    @Input({ required: true })\n    set pageAsset(value: DotCMSPageAsset) {\n        this._pageAsset = value;\n        if (!value.layout) {\n            console.warn(\n                'Warning: pageAsset does not have a `layout` property. Might be using an advaced template or your dotCMS instance not have a enterprise license.'\n            );\n        }\n    }\n\n    /**\n     * Returns the DotCMS page asset.\n     *\n     * @readonly\n     * @type {DotCMSPageAsset}\n     * @memberof DotcmsLayoutComponent\n     */\n    get pageAsset(): DotCMSPageAsset {\n        return this._pageAsset;\n    }\n\n    /**\n     * The `components` property is a record of dynamic components for each Contentlet on the page.\n     *\n     * @type {DotCMSPageComponent}\n     * @memberof DotcmsLayoutComponent\n     * @required\n     */\n    @Input({ required: true }) components!: DotCMSPageComponent;\n\n    /**\n     * The `onReload` property is a function that reloads the page after changes are made.\n     *\n     * @memberof DotcmsLayoutComponent\n     * @deprecated In future implementation we will be listening for the changes from the editor to update the page state so reload will not be needed.\n     */\n    @Input() onReload!: () => void;\n\n    /**\n     *\n     * @type {DotCMSFetchConfig}\n     * @memberof DotCMSPageEditorConfig\n     * @description The configuration custom params for data fetching on Edit Mode.\n     * @example <caption>Example with Custom GraphQL query</caption>\n     * <dotcms-layout [editor]=\"{ query: 'query { ... }' }\"/>\n     *\n     * @example <caption>Example usage with Custom Page API parameters</caption>\n     * <dotcms-layout [editor]=\"{ params: { depth: '2' } }\"/>;\n     */\n    @Input() editor!: EditorConfig;\n\n    private readonly route = inject(ActivatedRoute);\n    private readonly pageContextService = inject(PageContextService);\n    private readonly destroyRef$ = inject(DestroyRef);\n    private client!: DotCmsClient;\n    protected readonly pageAsset$ = this.pageContextService.currentPage$;\n\n    ngOnInit() {\n        this.pageContextService.setContext(this.pageAsset, this.components);\n\n        if (!isInsideEditor()) {\n            return;\n        }\n\n        this.client = DotCmsClient.instance;\n        this.route.url.pipe(takeUntilDestroyed(this.destroyRef$)).subscribe((urlSegments) => {\n            const pathname = '/' + urlSegments.join('/');\n\n            initEditor({ pathname });\n            updateNavigation(pathname || '/');\n        });\n\n        this.client.editor.on('changes', (data) => {\n            if (this.onReload) {\n                this.onReload();\n\n                return;\n            }\n\n            this.pageContextService.setPageAsset(data as DotCMSPageAsset);\n        });\n\n        postMessageToEditor({ action: CLIENT_ACTIONS.CLIENT_READY, payload: this.editor });\n    }\n\n    ngOnDestroy() {\n        if (!isInsideEditor()) {\n            return;\n        }\n\n        this.client.editor.off('changes');\n    }\n}\n"]}