@dotcms/angular 0.0.1-alpha.36 → 0.0.1-alpha.38

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 (30) hide show
  1. package/README.md +128 -78
  2. package/esm2022/lib/components/dot-editable-text/dot-editable-text.component.mjs +3 -3
  3. package/esm2022/lib/components/no-component/no-component.component.mjs +11 -6
  4. package/esm2022/lib/layout/column/column.component.mjs +16 -4
  5. package/esm2022/lib/layout/container/container.component.mjs +52 -4
  6. package/esm2022/lib/layout/contentlet/contentlet.component.mjs +59 -4
  7. package/esm2022/lib/layout/dotcms-layout/dotcms-layout.component.mjs +17 -4
  8. package/esm2022/lib/layout/row/row.component.mjs +10 -4
  9. package/esm2022/lib/models/index.mjs +1 -1
  10. package/esm2022/lib/services/dotcms-context/page-context.service.mjs +3 -3
  11. package/esm2022/lib/utils/index.mjs +23 -1
  12. package/fesm2022/dotcms-angular.mjs +187 -26
  13. package/fesm2022/dotcms-angular.mjs.map +1 -1
  14. package/lib/components/no-component/no-component.component.d.ts +11 -2
  15. package/lib/components/no-component/no-component.component.d.ts.map +1 -1
  16. package/lib/layout/column/column.component.d.ts +18 -0
  17. package/lib/layout/column/column.component.d.ts.map +1 -1
  18. package/lib/layout/container/container.component.d.ts +54 -0
  19. package/lib/layout/container/container.component.d.ts.map +1 -1
  20. package/lib/layout/contentlet/contentlet.component.d.ts +67 -0
  21. package/lib/layout/contentlet/contentlet.component.d.ts.map +1 -1
  22. package/lib/layout/dotcms-layout/dotcms-layout.component.d.ts +16 -3
  23. package/lib/layout/dotcms-layout/dotcms-layout.component.d.ts.map +1 -1
  24. package/lib/layout/row/row.component.d.ts +12 -0
  25. package/lib/layout/row/row.component.d.ts.map +1 -1
  26. package/lib/models/index.d.ts +29 -0
  27. package/lib/models/index.d.ts.map +1 -1
  28. package/lib/utils/index.d.ts +14 -0
  29. package/lib/utils/index.d.ts.map +1 -1
  30. package/package.json +2 -2
package/README.md CHANGED
@@ -1,17 +1,31 @@
1
1
  # @dotcms/angular
2
2
 
3
- `@dotcms/angular` is the official set of Angular components, services and resolver designed to work seamlessly with dotCMS, making it easy to render dotCMS pages an use the page builder
3
+ `@dotcms/angular` is the official Angular library designed to work seamlessly with dotCMS. This library simplifies the process of rendering dotCMS pages and integrating with the [Universal Visual Editor](dotcms.com/docs/latest/universal-visual-editor) in your Angular applications.
4
+
5
+ ## Table of Contents
6
+
7
+ - [Features](#features)
8
+ - [Installation](#installation)
9
+ - [Configuration](#provider-setup)
10
+ - [Provider Setup](#provider-setup)
11
+ - [Client Usage](#client-usage)
12
+ - [Components](#components)
13
+ - [DotcmsLayoutComponent](#dotcmslayoutcomponent)
14
+ - [Best Practices](#best-practices)
15
+ - [Troubleshooting](#troubleshooting)
16
+ - [Contributing](#contributing)
17
+ - [Licensing](#licensing)
4
18
 
5
19
  ## Features
6
20
 
7
- - A collection of Angular components, services and resolver tailored to render
8
- dotCMS pages.
9
- - Streamlined integration with dotCMS page editor.
10
- - Improved development experience with comprehensive TypeScript typings.
21
+ - A set of Angular components developer for dotCMS page rendering and editor integration.
22
+ - Enhanced development workflow with full TypeScript support.
23
+ - Optimized performance for efficient rendering of dotCMS pages in Angular applications.
24
+ - Flexible customization options to adapt to various project requirements.
11
25
 
12
26
  ## Installation
13
27
 
14
- Install the package via npm:
28
+ Install the package using npm:
15
29
 
16
30
  ```bash
17
31
  npm install @dotcms/angular
@@ -23,111 +37,147 @@ Or using Yarn:
23
37
  yarn add @dotcms/angular
24
38
  ```
25
39
 
26
- ## Provider
27
- ```
40
+ ## Configutarion
41
+ ### Provider Setup
42
+ We need to provide the information of our dotCMS instance
43
+
44
+ ```javascript
45
+
46
+ import { ClientConfig } from '@dotcms/client';
47
+
28
48
  const DOTCMS_CLIENT_CONFIG: ClientConfig = {
29
49
  dotcmsUrl: environment.dotcmsUrl,
30
50
  authToken: environment.authToken,
31
51
  siteId: environment.siteId
32
52
  };
33
53
  ```
34
- Add the dotcms config in the Angular app ApplicationConfig
35
- ```
54
+ And add this config in the Angular app ApplicationConfig.
55
+
56
+ `src/app/app.config.ts`
57
+ ```javascript
58
+ import { InjectionToken } from '@angular/core';
59
+ import { ClientConfig, DotCmsClient } from '@dotcms/client';
60
+
61
+ export const DOTCMS_CLIENT_TOKEN = new InjectionToken<DotCmsClient>('DOTCMS_CLIENT');
62
+
36
63
  export const appConfig: ApplicationConfig = {
37
64
  providers: [
38
- provideDotcmsClient(DOTCMS_CLIENT_CONFIG),
39
65
  provideRouter(routes),
66
+ {
67
+ provide: DOTCMS_CLIENT_TOKEN,
68
+ useValue: DotCmsClient.init(DOTCMS_CLIENT_CONFIG),
69
+ }
40
70
  ],
41
71
  };
42
72
  ```
43
- ## Resolver
44
- ```javascript
45
- export const routes: Routes = [
46
- {
47
- path: '**',
48
- resolve: {
49
- // This should be called `context`.
50
- context: DotCMSPageResolver,
51
- },
52
- component: DotCMSPagesComponent,
53
- runGuardsAndResolvers: 'always' // Run the resolver on every navigation. Even if the URL hasn't changed.
54
- },
55
- ];
56
- ```
73
+ This way, we will have access to `DOTCMS_CLIENT_TOKEN` from anywhere in our application.
57
74
 
58
- Then, in your component, you can read the data using
75
+ ### Client Usage
76
+ To interact with the client and obtain information from, for example, our pages
59
77
 
60
78
  ```javascript
61
- protected readonly context = signal(null);
62
-
63
- ngOnInit() {
64
- // Get the context data from the route
65
- this.route.data.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(data => {
66
- this.context.set(data['context']);
67
- });
68
- }
79
+ private readonly client = inject(DOTCMS_CLIENT_TOKEN);
80
+
81
+ this.client.page
82
+ .get({ ...pageParams })
83
+ .then((response) => {
84
+ // Use your response
85
+ })
86
+ .catch((e) => {
87
+ const error: PageError = {
88
+ message: e.message,
89
+ status: e.status,
90
+ };
91
+ // Use the error response
92
+ })
69
93
  ```
70
- ## Components
94
+ For more information to how to use DotCms Client, you can visit the [documentation](https://github.com/dotCMS/core/blob/master/core-web/libs/sdk/client/README.md)
71
95
 
72
- ### `DotcmsLayoutComponent`
96
+ ## DotCMS Page API
73
97
 
74
- A component that renders a layout for a dotCMS page.
98
+ The `DotcmsLayoutComponent` requires a `DotCMSPageAsset` object to be passed in to it. This object represents a dotCMS page and can be fetched using the `@dotcms/client` library.
75
99
 
76
- #### Inputs
100
+ - [DotCMS Official Angular Example](https://github.com/dotCMS/core/tree/master/examples/angular)
101
+ - [`@dotcms/client` documentation](https://www.npmjs.com/package/@dotcms/client)
102
+ - [Page API documentation](https://dotcms.com/docs/latest/page-api)
77
103
 
78
- - **entity**: The context for a dotCMS page.
79
- - **components**: An object with the relation of contentlets and the component to render each.
104
+ ## Components
80
105
 
106
+ ### DotcmsLayoutComponent
81
107
 
82
- #### Usage
108
+ The `DotcmsLayoutComponent` is a crucial component for rendering dotCMS page layouts in your Angular application.
83
109
 
84
- ```javascript
85
- <dotcms-layout [entity]="pageAsset" [components]="components()" />
86
-
87
- DYNAMIC_COMPONENTS: { [key: string]: DynamicComponentEntity } = {
88
- Activity: import('../pages/content-types/activity/activity.component').then(
89
- (c) => c.ActivityComponent,
90
- ),
91
- Banner: import('../pages/content-types/banner/banner.component').then(
92
- (c) => c.BannerComponent,
93
- ),
94
- Image: import('../pages/content-types/image/image.component').then(
95
- (c) => c.ImageComponent,
96
- ),
97
- webPageContent: import(
98
- '../pages/content-types/web-page-content/web-page-content.component'
99
- ).then((c) => c.WebPageContentComponent),
100
- Product: import('../pages/content-types/product/product.component').then(
101
- (c) => c.ProductComponent,
102
- ),
110
+ #### Inputs
111
+
112
+ | Name | Type | Description |
113
+ |--------------|----------------------|-----------------------------------------------------------------------|
114
+ | `pageAsset` | `DotCMSPageAsset` | The object representing a dotCMS page from PageAPI response. |
115
+ | `components` | `DotCMSPageComponent`| An object mapping contentlets to their respective render components. |
116
+ | `editor` | `EditorConfig` | Configuration for data fetching in Edit Mode. |
117
+
118
+ #### Usage Example
119
+
120
+ In your component file (e.g., `pages.component.ts`):
121
+
122
+ ```typescript
123
+ import { Component, signal } from '@angular/core';
124
+ import { DotCMSPageComponent, EditorConfig } from '@dotcms/angular';
125
+
126
+ @Component({
127
+ selector: 'app-pages',
128
+ templateUrl: './pages.component.html',
129
+ })
130
+ export class PagesComponent {
131
+ DYNAMIC_COMPONENTS: DotCMSPageComponent = {
132
+ Activity: import('../pages/content-types/activity/activity.component').then(
133
+ (c) => c.ActivityComponent
134
+ ),
135
+ Banner: import('../pages/content-types/banner/banner.component').then(
136
+ (c) => c.BannerComponent
137
+ ),
138
+ // Add other components as needed
103
139
  };
140
+
141
+ components = signal(this.DYNAMIC_COMPONENTS);
142
+ editorConfig = signal<EditorConfig>({ params: { depth: 2 } });
143
+
144
+ // Assume pageAsset is fetched or provided somehow
145
+ pageAsset: DotCMSPageAsset;
146
+ }
147
+ ```
104
148
 
105
- components = signal(DYNAMIC_COMPONENTS);
149
+ In your template file (e.g., `pages.component.html`):
150
+
151
+ ```html
152
+ <dotcms-layout
153
+ [pageAsset]="pageAsset"
154
+ [components]="components()"
155
+ [editor]="editorConfig()"
156
+ />
106
157
  ```
107
158
 
108
- ## Contributing
159
+ This setup allows for dynamic rendering of different content types on your dotCMS pages.
109
160
 
110
- GitHub pull requests are the preferred method to contribute code to dotCMS. Before any pull requests can be accepted, an automated tool will ask you to agree to the [dotCMS Contributor's Agreement](https://gist.github.com/wezell/85ef45298c48494b90d92755b583acb3).
161
+ ## Best Practices
111
162
 
112
- ## Licensing
163
+ 1. **Lazy Loading**: Use dynamic imports for components to improve initial load times.
164
+ 2. **Error Handling**: Implement robust error handling for API calls and component rendering.
165
+ 3. **Type Safety**: Leverage TypeScript's type system to ensure proper usage of dotCMS structures.
166
+ 4. **Performance Optimization**: Monitor and optimize the performance of rendered components.
113
167
 
114
- dotCMS comes in multiple editions and as such is dual licensed. The dotCMS Community Edition is licensed under the GPL 3.0 and is freely available for download, customization and deployment for use within organizations of all stripes. dotCMS Enterprise Editions (EE) adds a number of enterprise features and is available via a supported, indemnified commercial license from dotCMS. For the differences between the editions, see [the feature page](http://dotcms.com/cms-platform/features).
168
+ ## Troubleshooting
115
169
 
116
- ## Support
170
+ If you encounter issues:
117
171
 
118
- If you need help or have any questions, please [open an issue](https://github.com/dotCMS/core/issues/new/choose) in the GitHub repository.
172
+ 1. Ensure all dependencies are correctly installed and up to date.
173
+ 2. Verify that your dotCMS configuration (URL, auth token, site ID) is correct.
174
+ 3. Check the browser console for any error messages.
175
+ 4. Refer to the [dotCMS documentation](https://dotcms.com/docs/) for additional guidance.
119
176
 
120
- ## Documentation
177
+ ## Contributing
121
178
 
122
- Always refer to the official [DotCMS documentation](https://www.dotcms.com/docs/latest/) for comprehensive guides and API references.
179
+ GitHub pull requests are the preferred method to contribute code to dotCMS. Before any pull requests can be accepted, an automated tool will ask you to agree to the [dotCMS Contributor's Agreement](https://gist.github.com/wezell/85ef45298c48494b90d92755b583acb3).
123
180
 
124
- ## Getting Help
181
+ ## Licensing
125
182
 
126
- | Source | Location |
127
- | --------------- | ------------------------------------------------------------------- |
128
- | Installation | [Installation](https://dotcms.com/docs/latest/installation) |
129
- | Documentation | [Documentation](https://dotcms.com/docs/latest/table-of-contents) |
130
- | Videos | [Helpful Videos](http://dotcms.com/videos/) |
131
- | Forums/Listserv | [via Google Groups](https://groups.google.com/forum/#!forum/dotCMS) |
132
- | Twitter | @dotCMS |
133
- | Main Site | [dotCMS.com](https://dotcms.com/) |
183
+ dotCMS comes in multiple editions and as such is dual licensed. The dotCMS Community Edition is licensed under the GPL 3.0 and is freely available for download, customization and deployment for use within organizations of all stripes. dotCMS Enterprise Editions (EE) adds a number of enterprise features and is available via a supported, indemnified commercial license from dotCMS. For the differences between the editions, see [the feature page](http://dotcms.com/cms-platform/features).
@@ -187,8 +187,8 @@ export class DotEditableTextComponent {
187
187
  didContentChange(editedContent) {
188
188
  return this.content !== editedContent;
189
189
  }
190
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: DotEditableTextComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
191
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.9", type: DotEditableTextComponent, isStandalone: true, selector: "dot-editable-text", inputs: { mode: "mode", format: "format", contentlet: "contentlet", fieldName: "fieldName" }, host: { listeners: { "window:message": "onMessage($event)" } }, providers: [
190
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: DotEditableTextComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
191
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.3", type: DotEditableTextComponent, isStandalone: true, selector: "dot-editable-text", inputs: { mode: "mode", format: "format", contentlet: "contentlet", fieldName: "fieldName" }, host: { listeners: { "window:message": "onMessage($event)" } }, providers: [
192
192
  {
193
193
  provide: TINYMCE_SCRIPT_SRC,
194
194
  useFactory: () => {
@@ -197,7 +197,7 @@ export class DotEditableTextComponent {
197
197
  }
198
198
  ], viewQueries: [{ propertyName: "editorComponent", first: true, predicate: EditorComponent, descendants: true }], usesOnChanges: true, ngImport: i0, template: "@if (isInsideEditor) {\n <editor\n #tinyEditor\n [init]=\"init\"\n [initialValue]=\"content\"\n (onMouseDown)=\"onMouseDown($event)\"\n (onFocusOut)=\"onFocusOut()\" />\n}\n", styles: [":host ::ng-deep .mce-content-body:not(.mce-edit-focus):hover{outline:2px solid #006ce7;border-radius:4px}\n"], dependencies: [{ kind: "component", type: EditorComponent, selector: "editor", inputs: ["cloudChannel", "apiKey", "init", "id", "initialValue", "outputFormat", "inline", "tagName", "plugins", "toolbar", "modelEvents", "allowedEvents", "ignoreEvents", "disabled"] }] }); }
199
199
  }
200
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: DotEditableTextComponent, decorators: [{
200
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: DotEditableTextComponent, decorators: [{
201
201
  type: Component,
202
202
  args: [{ selector: 'dot-editable-text', standalone: true, imports: [EditorComponent], providers: [
203
203
  {
@@ -1,19 +1,24 @@
1
1
  import { ChangeDetectionStrategy, Component, HostBinding, Input } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
3
  /**
4
- * This is part of the Angular SDK.
5
- * This is a component for the `NoComponentComponent` component.
4
+ * This component is responsible to display a message when there is no component for a contentlet.
5
+ *
6
+ * @export
7
+ * @class NoComponent
6
8
  */
7
9
  export class NoComponent {
8
10
  constructor() {
11
+ /**
12
+ * The data-testid attribute used for identifying the component during testing.
13
+ */
9
14
  this.testId = 'no-component';
10
15
  }
11
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: NoComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
12
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.9", type: NoComponent, isStandalone: true, selector: "dotcms-no-component", inputs: { contentlet: "contentlet" }, host: { properties: { "attr.data-testid": "this.testId" } }, ngImport: i0, template: `
16
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NoComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
17
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.3", type: NoComponent, isStandalone: true, selector: "dotcms-no-component", inputs: { contentlet: "contentlet" }, host: { properties: { "attr.data-testid": "this.testId" } }, ngImport: i0, template: `
13
18
  No Component for {{ contentlet.contentType }}
14
19
  `, isInline: true, styles: [":host{display:block}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
15
20
  }
16
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: NoComponent, decorators: [{
21
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NoComponent, decorators: [{
17
22
  type: Component,
18
23
  args: [{ selector: 'dotcms-no-component', standalone: true, template: `
19
24
  No Component for {{ contentlet.contentType }}
@@ -24,4 +29,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImpor
24
29
  type: HostBinding,
25
30
  args: ['attr.data-testid']
26
31
  }] } });
27
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm8tY29tcG9uZW50LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvc2RrL2FuZ3VsYXIvc3JjL2xpYi9jb21wb25lbnRzL25vLWNvbXBvbmVudC9uby1jb21wb25lbnQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFJdkY7OztHQUdHO0FBVUgsTUFBTSxPQUFPLFdBQVc7SUFUeEI7UUFXcUMsV0FBTSxHQUFHLGNBQWMsQ0FBQztLQUM1RDs4R0FIWSxXQUFXO2tHQUFYLFdBQVcsa0xBTlY7O0tBRVQ7OzJGQUlRLFdBQVc7a0JBVHZCLFNBQVM7K0JBQ0kscUJBQXFCLGNBQ25CLElBQUksWUFDTjs7S0FFVCxtQkFFZ0IsdUJBQXVCLENBQUMsTUFBTTs4QkFHdEMsVUFBVTtzQkFBbEIsS0FBSztnQkFDMkIsTUFBTTtzQkFBdEMsV0FBVzt1QkFBQyxrQkFBa0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBIb3N0QmluZGluZywgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgRG90Q01TQ29udGVudGxldCB9IGZyb20gJy4uLy4uL21vZGVscyc7XG5cbi8qKlxuICogVGhpcyBpcyBwYXJ0IG9mIHRoZSBBbmd1bGFyIFNESy5cbiAqIFRoaXMgaXMgYSBjb21wb25lbnQgZm9yIHRoZSBgTm9Db21wb25lbnRDb21wb25lbnRgIGNvbXBvbmVudC5cbiAqL1xuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdkb3RjbXMtbm8tY29tcG9uZW50JyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIHRlbXBsYXRlOiBgXG4gICAgICAgIE5vIENvbXBvbmVudCBmb3Ige3sgY29udGVudGxldC5jb250ZW50VHlwZSB9fVxuICAgIGAsXG4gICAgc3R5bGVVcmw6ICcuL25vLWNvbXBvbmVudC5jb21wb25lbnQuY3NzJyxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBOb0NvbXBvbmVudCB7XG4gICAgQElucHV0KCkgY29udGVudGxldCE6IERvdENNU0NvbnRlbnRsZXQ7XG4gICAgQEhvc3RCaW5kaW5nKCdhdHRyLmRhdGEtdGVzdGlkJykgdGVzdElkID0gJ25vLWNvbXBvbmVudCc7XG59XG4iXX0=
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm8tY29tcG9uZW50LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvc2RrL2FuZ3VsYXIvc3JjL2xpYi9jb21wb25lbnRzL25vLWNvbXBvbmVudC9uby1jb21wb25lbnQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFJdkY7Ozs7O0dBS0c7QUFVSCxNQUFNLE9BQU8sV0FBVztJQVR4QjtRQWdCSTs7V0FFRztRQUM4QixXQUFNLEdBQUcsY0FBYyxDQUFDO0tBQzVEOzhHQVhZLFdBQVc7a0dBQVgsV0FBVyxrTEFOVjs7S0FFVDs7MkZBSVEsV0FBVztrQkFUdkIsU0FBUzsrQkFDSSxxQkFBcUIsY0FDbkIsSUFBSSxZQUNOOztLQUVULG1CQUVnQix1QkFBdUIsQ0FBQyxNQUFNOzhCQU90QyxVQUFVO3NCQUFsQixLQUFLO2dCQUsyQixNQUFNO3NCQUF0QyxXQUFXO3VCQUFDLGtCQUFrQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEhvc3RCaW5kaW5nLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBEb3RDTVNDb250ZW50bGV0IH0gZnJvbSAnLi4vLi4vbW9kZWxzJztcblxuLyoqXG4gKiBUaGlzIGNvbXBvbmVudCBpcyByZXNwb25zaWJsZSB0byBkaXNwbGF5IGEgbWVzc2FnZSB3aGVuIHRoZXJlIGlzIG5vIGNvbXBvbmVudCBmb3IgYSBjb250ZW50bGV0LlxuICpcbiAqIEBleHBvcnRcbiAqIEBjbGFzcyBOb0NvbXBvbmVudFxuICovXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2RvdGNtcy1uby1jb21wb25lbnQnLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgdGVtcGxhdGU6IGBcbiAgICAgICAgTm8gQ29tcG9uZW50IGZvciB7eyBjb250ZW50bGV0LmNvbnRlbnRUeXBlIH19XG4gICAgYCxcbiAgICBzdHlsZVVybDogJy4vbm8tY29tcG9uZW50LmNvbXBvbmVudC5jc3MnLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIE5vQ29tcG9uZW50IHtcbiAgICAvKipcbiAgICAgKiBUaGUgY29udGVudGxldCBvYmplY3QgY29udGFpbmluZyBjb250ZW50IGRhdGEuXG4gICAgICogVGhlIGNvbXBvbmVudCBkaXNwbGF5cyBhIG1lc3NhZ2UgYmFzZWQgb24gdGhlIGNvbnRlbnQgdHlwZSBvZiB0aGlzIGNvbnRlbnRsZXQuXG4gICAgICovXG4gICAgQElucHV0KCkgY29udGVudGxldCE6IERvdENNU0NvbnRlbnRsZXQ7XG5cbiAgICAvKipcbiAgICAgKiBUaGUgZGF0YS10ZXN0aWQgYXR0cmlidXRlIHVzZWQgZm9yIGlkZW50aWZ5aW5nIHRoZSBjb21wb25lbnQgZHVyaW5nIHRlc3RpbmcuXG4gICAgICovXG4gICAgQEhvc3RCaW5kaW5nKCdhdHRyLmRhdGEtdGVzdGlkJykgdGVzdElkID0gJ25vLWNvbXBvbmVudCc7XG59XG4iXX0=
@@ -2,22 +2,34 @@ import { ChangeDetectionStrategy, Component, HostBinding, Input } from '@angular
2
2
  import { getPositionStyleClasses } from '../../utils';
3
3
  import { ContainerComponent } from '../container/container.component';
4
4
  import * as i0 from "@angular/core";
5
+ /**
6
+ * This component is responsible to display a column with containers.
7
+ *
8
+ * @export
9
+ * @class ColumnComponent
10
+ * @implements {OnInit}
11
+ */
5
12
  export class ColumnComponent {
6
13
  constructor() {
14
+ /**
15
+ * The data-testid attribute used for identifying the component during testing.
16
+ *
17
+ * @memberof ColumnComponent
18
+ */
7
19
  this.containerClasses = '';
8
20
  }
9
21
  ngOnInit() {
10
22
  const { startClass, endClass } = getPositionStyleClasses(this.column.leftOffset, this.column.width + this.column.leftOffset);
11
23
  this.containerClasses = `${startClass} ${endClass}`;
12
24
  }
13
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: ColumnComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
14
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.9", type: ColumnComponent, isStandalone: true, selector: "dotcms-column", inputs: { column: "column" }, host: { properties: { "class": "this.containerClasses" } }, ngImport: i0, template: `
25
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: ColumnComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
26
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.3", type: ColumnComponent, isStandalone: true, selector: "dotcms-column", inputs: { column: "column" }, host: { properties: { "class": "this.containerClasses" } }, ngImport: i0, template: `
15
27
  @for (container of column.containers; track $index) {
16
28
  <dotcms-container [container]="container" />
17
29
  }
18
30
  `, isInline: true, styles: [":host.col-start-1{grid-column-start:1}:host.col-start-2{grid-column-start:2}:host.col-start-3{grid-column-start:3}:host.col-start-4{grid-column-start:4}:host.col-start-5{grid-column-start:5}:host.col-start-6{grid-column-start:6}:host.col-start-7{grid-column-start:7}:host.col-start-8{grid-column-start:8}:host.col-start-9{grid-column-start:9}:host.col-start-10{grid-column-start:10}:host.col-start-11{grid-column-start:11}:host.col-start-12{grid-column-start:12}:host.col-end-1{grid-column-end:1}:host.col-end-2{grid-column-end:2}:host.col-end-3{grid-column-end:3}:host.col-end-4{grid-column-end:4}:host.col-end-5{grid-column-end:5}:host.col-end-6{grid-column-end:6}:host.col-end-7{grid-column-end:7}:host.col-end-8{grid-column-end:8}:host.col-end-9{grid-column-end:9}:host.col-end-10{grid-column-end:10}:host.col-end-11{grid-column-end:11}:host.col-end-12{grid-column-end:12}:host.col-end-13{grid-column-end:13}\n"], dependencies: [{ kind: "component", type: ContainerComponent, selector: "dotcms-container", inputs: ["container"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
19
31
  }
20
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: ColumnComponent, decorators: [{
32
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: ColumnComponent, decorators: [{
21
33
  type: Component,
22
34
  args: [{ selector: 'dotcms-column', standalone: true, imports: [ContainerComponent], template: `
23
35
  @for (container of column.containers; track $index) {
@@ -30,4 +42,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImpor
30
42
  type: HostBinding,
31
43
  args: ['class']
32
44
  }] } });
33
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sdW1uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvc2RrL2FuZ3VsYXIvc3JjL2xpYi9sYXlvdXQvY29sdW1uL2NvbHVtbi5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBRy9GLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUN0RCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQzs7QUFjdEUsTUFBTSxPQUFPLGVBQWU7SUFaNUI7UUFjMEIscUJBQWdCLEdBQUcsRUFBRSxDQUFDO0tBUy9DO0lBUEcsUUFBUTtRQUNKLE1BQU0sRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLEdBQUcsdUJBQXVCLENBQ3BELElBQUksQ0FBQyxNQUFNLENBQUMsVUFBVSxFQUN0QixJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FDN0MsQ0FBQztRQUNGLElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxHQUFHLFVBQVUsSUFBSSxRQUFRLEVBQUUsQ0FBQztJQUN4RCxDQUFDOzhHQVZRLGVBQWU7a0dBQWYsZUFBZSxtS0FSZDs7OztLQUlULDQ5QkFMUyxrQkFBa0I7OzJGQVNuQixlQUFlO2tCQVozQixTQUFTOytCQUNJLGVBQWUsY0FDYixJQUFJLFdBQ1AsQ0FBQyxrQkFBa0IsQ0FBQyxZQUNuQjs7OztLQUlULG1CQUVnQix1QkFBdUIsQ0FBQyxNQUFNOzhCQUd0QyxNQUFNO3NCQUFkLEtBQUs7Z0JBQ2dCLGdCQUFnQjtzQkFBckMsV0FBVzt1QkFBQyxPQUFPIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgRG90UGFnZUFzc2V0TGF5b3V0Q29sdW1uIH0gZnJvbSAnLi4vLi4vbW9kZWxzJztcbmltcG9ydCB7IGdldFBvc2l0aW9uU3R5bGVDbGFzc2VzIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgQ29udGFpbmVyQ29tcG9uZW50IH0gZnJvbSAnLi4vY29udGFpbmVyL2NvbnRhaW5lci5jb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2RvdGNtcy1jb2x1bW4nLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW0NvbnRhaW5lckNvbXBvbmVudF0sXG4gICAgdGVtcGxhdGU6IGBcbiAgICAgICAgQGZvciAoY29udGFpbmVyIG9mIGNvbHVtbi5jb250YWluZXJzOyB0cmFjayAkaW5kZXgpIHtcbiAgICAgICAgICAgIDxkb3RjbXMtY29udGFpbmVyIFtjb250YWluZXJdPVwiY29udGFpbmVyXCIgLz5cbiAgICAgICAgfVxuICAgIGAsXG4gICAgc3R5bGVVcmw6ICcuL2NvbHVtbi5jb21wb25lbnQuY3NzJyxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBDb2x1bW5Db21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICAgIEBJbnB1dCgpIGNvbHVtbiE6IERvdFBhZ2VBc3NldExheW91dENvbHVtbjtcbiAgICBASG9zdEJpbmRpbmcoJ2NsYXNzJykgY29udGFpbmVyQ2xhc3NlcyA9ICcnO1xuXG4gICAgbmdPbkluaXQoKSB7XG4gICAgICAgIGNvbnN0IHsgc3RhcnRDbGFzcywgZW5kQ2xhc3MgfSA9IGdldFBvc2l0aW9uU3R5bGVDbGFzc2VzKFxuICAgICAgICAgICAgdGhpcy5jb2x1bW4ubGVmdE9mZnNldCxcbiAgICAgICAgICAgIHRoaXMuY29sdW1uLndpZHRoICsgdGhpcy5jb2x1bW4ubGVmdE9mZnNldFxuICAgICAgICApO1xuICAgICAgICB0aGlzLmNvbnRhaW5lckNsYXNzZXMgPSBgJHtzdGFydENsYXNzfSAke2VuZENsYXNzfWA7XG4gICAgfVxufVxuIl19
45
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sdW1uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvc2RrL2FuZ3VsYXIvc3JjL2xpYi9sYXlvdXQvY29sdW1uL2NvbHVtbi5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBRy9GLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUN0RCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQzs7QUFFdEU7Ozs7OztHQU1HO0FBYUgsTUFBTSxPQUFPLGVBQWU7SUFaNUI7UUFxQkk7Ozs7V0FJRztRQUNtQixxQkFBZ0IsR0FBRyxFQUFFLENBQUM7S0FTL0M7SUFQRyxRQUFRO1FBQ0osTUFBTSxFQUFFLFVBQVUsRUFBRSxRQUFRLEVBQUUsR0FBRyx1QkFBdUIsQ0FDcEQsSUFBSSxDQUFDLE1BQU0sQ0FBQyxVQUFVLEVBQ3RCLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUM3QyxDQUFDO1FBQ0YsSUFBSSxDQUFDLGdCQUFnQixHQUFHLEdBQUcsVUFBVSxJQUFJLFFBQVEsRUFBRSxDQUFDO0lBQ3hELENBQUM7OEdBdEJRLGVBQWU7a0dBQWYsZUFBZSxtS0FSZDs7OztLQUlULDQ5QkFMUyxrQkFBa0I7OzJGQVNuQixlQUFlO2tCQVozQixTQUFTOytCQUNJLGVBQWUsY0FDYixJQUFJLFdBQ1AsQ0FBQyxrQkFBa0IsQ0FBQyxZQUNuQjs7OztLQUlULG1CQUVnQix1QkFBdUIsQ0FBQyxNQUFNOzhCQVN0QyxNQUFNO3NCQUFkLEtBQUs7Z0JBT2dCLGdCQUFnQjtzQkFBckMsV0FBVzt1QkFBQyxPQUFPIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgRG90UGFnZUFzc2V0TGF5b3V0Q29sdW1uIH0gZnJvbSAnLi4vLi4vbW9kZWxzJztcbmltcG9ydCB7IGdldFBvc2l0aW9uU3R5bGVDbGFzc2VzIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgQ29udGFpbmVyQ29tcG9uZW50IH0gZnJvbSAnLi4vY29udGFpbmVyL2NvbnRhaW5lci5jb21wb25lbnQnO1xuXG4vKipcbiAqIFRoaXMgY29tcG9uZW50IGlzIHJlc3BvbnNpYmxlIHRvIGRpc3BsYXkgYSBjb2x1bW4gd2l0aCBjb250YWluZXJzLlxuICpcbiAqIEBleHBvcnRcbiAqIEBjbGFzcyBDb2x1bW5Db21wb25lbnRcbiAqIEBpbXBsZW1lbnRzIHtPbkluaXR9XG4gKi9cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnZG90Y21zLWNvbHVtbicsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbQ29udGFpbmVyQ29tcG9uZW50XSxcbiAgICB0ZW1wbGF0ZTogYFxuICAgICAgICBAZm9yIChjb250YWluZXIgb2YgY29sdW1uLmNvbnRhaW5lcnM7IHRyYWNrICRpbmRleCkge1xuICAgICAgICAgICAgPGRvdGNtcy1jb250YWluZXIgW2NvbnRhaW5lcl09XCJjb250YWluZXJcIiAvPlxuICAgICAgICB9XG4gICAgYCxcbiAgICBzdHlsZVVybDogJy4vY29sdW1uLmNvbXBvbmVudC5jc3MnLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIENvbHVtbkNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gICAgLyoqXG4gICAgICogVGhlIGNvbHVtbiBvYmplY3QgY29udGFpbmluZyB0aGUgY29udGFpbmVycy5cbiAgICAgKlxuICAgICAqIEB0eXBlIHtEb3RQYWdlQXNzZXRMYXlvdXRDb2x1bW59XG4gICAgICogQG1lbWJlcm9mIENvbHVtbkNvbXBvbmVudFxuICAgICAqL1xuICAgIEBJbnB1dCgpIGNvbHVtbiE6IERvdFBhZ2VBc3NldExheW91dENvbHVtbjtcblxuICAgIC8qKlxuICAgICAqIFRoZSBkYXRhLXRlc3RpZCBhdHRyaWJ1dGUgdXNlZCBmb3IgaWRlbnRpZnlpbmcgdGhlIGNvbXBvbmVudCBkdXJpbmcgdGVzdGluZy5cbiAgICAgKlxuICAgICAqIEBtZW1iZXJvZiBDb2x1bW5Db21wb25lbnRcbiAgICAgKi9cbiAgICBASG9zdEJpbmRpbmcoJ2NsYXNzJykgY29udGFpbmVyQ2xhc3NlcyA9ICcnO1xuXG4gICAgbmdPbkluaXQoKSB7XG4gICAgICAgIGNvbnN0IHsgc3RhcnRDbGFzcywgZW5kQ2xhc3MgfSA9IGdldFBvc2l0aW9uU3R5bGVDbGFzc2VzKFxuICAgICAgICAgICAgdGhpcy5jb2x1bW4ubGVmdE9mZnNldCxcbiAgICAgICAgICAgIHRoaXMuY29sdW1uLndpZHRoICsgdGhpcy5jb2x1bW4ubGVmdE9mZnNldFxuICAgICAgICApO1xuICAgICAgICB0aGlzLmNvbnRhaW5lckNsYXNzZXMgPSBgJHtzdGFydENsYXNzfSAke2VuZENsYXNzfWA7XG4gICAgfVxufVxuIl19
@@ -5,6 +5,13 @@ import { PageContextService } from '../../services/dotcms-context/page-context.s
5
5
  import { getContainersData } from '../../utils';
6
6
  import { ContentletComponent } from '../contentlet/contentlet.component';
7
7
  import * as i0 from "@angular/core";
8
+ /**
9
+ * This component is responsible to display a container with contentlets.
10
+ *
11
+ * @export
12
+ * @class ContainerComponent
13
+ * @implements {OnChanges}
14
+ */
8
15
  export class ContainerComponent {
9
16
  constructor() {
10
17
  this.pageContextService = inject(PageContextService);
@@ -13,12 +20,53 @@ export class ContainerComponent {
13
20
  this.$contentlets = signal([]);
14
21
  this.$dotContainer = signal(null);
15
22
  this.$dotContainerAsString = computed(() => JSON.stringify(this.$dotContainer()));
23
+ /**
24
+ * The accept types for the container component.
25
+ *
26
+ * @type {(string | null)}
27
+ * @memberof ContainerComponent
28
+ */
16
29
  this.acceptTypes = null;
30
+ /**
31
+ * The identifier for the container component.
32
+ *
33
+ * @type {(string | null)}
34
+ * @memberof ContainerComponent
35
+ */
17
36
  this.identifier = null;
37
+ /**
38
+ * The max contentlets for the container component.
39
+ *
40
+ * @type {(number | null)}
41
+ * @memberof ContainerComponent
42
+ */
18
43
  this.maxContentlets = null;
44
+ /**
45
+ * The uuid for the container component.
46
+ *
47
+ * @type {(string | null)}
48
+ * @memberof ContainerComponent
49
+ */
19
50
  this.uuid = null;
51
+ /**
52
+ * The class for the container component.
53
+ *
54
+ * @type {(string | null)}
55
+ * @memberof ContainerComponent
56
+ */
20
57
  this.class = null;
58
+ /**
59
+ * The dot object for the container component.
60
+ *
61
+ * @type {(string | null)}
62
+ * @memberof ContainerComponent
63
+ */
21
64
  this.dotObject = null;
65
+ /**
66
+ * The data-testid attribute used for identifying the component during testing.
67
+ *
68
+ * @memberof ContainerComponent
69
+ */
22
70
  this.testId = 'dot-container';
23
71
  }
24
72
  ngOnChanges() {
@@ -44,10 +92,10 @@ export class ContainerComponent {
44
92
  this.dotObject = 'container';
45
93
  }
46
94
  }
47
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: ContainerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
48
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.9", 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 }); }
95
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: ContainerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
96
+ 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 }); }
49
97
  }
50
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: ContainerComponent, decorators: [{
98
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: ContainerComponent, decorators: [{
51
99
  type: Component,
52
100
  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"] }]
53
101
  }], propDecorators: { container: [{
@@ -75,4 +123,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImpor
75
123
  type: HostBinding,
76
124
  args: ['attr.data-testid']
77
125
  }] } });
78
- //# 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@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    @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    @HostBinding('attr.data-dot-accept-types') acceptTypes: string | null = null;\n    @HostBinding('attr.data-dot-identifier') identifier: string | null = null;\n    @HostBinding('attr.data-max-contentlets') maxContentlets: number | null = null;\n    @HostBinding('attr.data-dot-uuid') uuid: string | null = null;\n    @HostBinding('class') class: string | null = null;\n    @HostBinding('attr.data-dot-object') dotObject: string | null = null;\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"]}
126
+ //# 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"]}