@dotcms/angular 0.0.1-alpha.39 → 0.0.1-alpha.41

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 (79) hide show
  1. package/README.md +10 -10
  2. package/dotcms-angular.d.ts.map +1 -0
  3. package/esm2022/dotcms-angular.mjs +5 -0
  4. package/esm2022/index.mjs +5 -0
  5. package/esm2022/lib/components/dot-editable-text/dot-editable-text.component.mjs +225 -0
  6. package/esm2022/lib/components/dot-editable-text/utils.mjs +43 -0
  7. package/esm2022/lib/components/no-component/no-component.component.mjs +32 -0
  8. package/esm2022/lib/layout/column/column.component.mjs +45 -0
  9. package/esm2022/lib/layout/container/container.component.mjs +126 -0
  10. package/esm2022/lib/layout/contentlet/contentlet.component.mjs +120 -0
  11. package/esm2022/lib/layout/dotcms-layout/dotcms-layout.component.mjs +100 -0
  12. package/esm2022/lib/layout/row/row.component.mjs +29 -0
  13. package/esm2022/lib/models/dotcms.model.mjs +3 -0
  14. package/esm2022/lib/models/index.mjs +3 -0
  15. package/esm2022/lib/services/dotcms-context/page-context.service.mjs +75 -0
  16. package/esm2022/lib/utils/index.mjs +79 -0
  17. package/fesm2022/dotcms-angular.mjs +858 -0
  18. package/fesm2022/dotcms-angular.mjs.map +1 -0
  19. package/{src/index.ts → index.d.ts} +1 -0
  20. package/index.d.ts.map +1 -0
  21. package/lib/components/dot-editable-text/dot-editable-text.component.d.ts +129 -0
  22. package/lib/components/dot-editable-text/dot-editable-text.component.d.ts.map +1 -0
  23. package/lib/components/dot-editable-text/utils.d.ts +7 -0
  24. package/lib/components/dot-editable-text/utils.d.ts.map +1 -0
  25. package/lib/components/no-component/no-component.component.d.ts +22 -0
  26. package/lib/components/no-component/no-component.component.d.ts.map +1 -0
  27. package/lib/layout/column/column.component.d.ts +29 -0
  28. package/lib/layout/column/column.component.d.ts.map +1 -0
  29. package/lib/layout/container/container.component.d.ts +88 -0
  30. package/lib/layout/container/container.component.d.ts.map +1 -0
  31. package/{src/lib/layout/contentlet/contentlet.component.ts → lib/layout/contentlet/contentlet.component.d.ts} +17 -32
  32. package/lib/layout/contentlet/contentlet.component.d.ts.map +1 -0
  33. package/lib/layout/dotcms-layout/dotcms-layout.component.d.ts +67 -0
  34. package/lib/layout/dotcms-layout/dotcms-layout.component.d.ts.map +1 -0
  35. package/lib/layout/row/row.component.d.ts +20 -0
  36. package/lib/layout/row/row.component.d.ts.map +1 -0
  37. package/{src/lib/models/dotcms.model.ts → lib/models/dotcms.model.d.ts} +3 -21
  38. package/lib/models/dotcms.model.d.ts.map +1 -0
  39. package/{src/lib/models/index.ts → lib/models/index.d.ts} +1 -8
  40. package/lib/models/index.d.ts.map +1 -0
  41. package/{src/lib/services/dotcms-context/page-context.service.ts → lib/services/dotcms-context/page-context.service.d.ts} +12 -41
  42. package/lib/services/dotcms-context/page-context.service.d.ts.map +1 -0
  43. package/lib/utils/index.d.ts +63 -0
  44. package/lib/utils/index.d.ts.map +1 -0
  45. package/package.json +22 -5
  46. package/.eslintrc.json +0 -18
  47. package/jest.config.ts +0 -22
  48. package/ng-package.json +0 -7
  49. package/project.json +0 -33
  50. package/src/lib/components/dot-editable-text/dot-editable-text.component.css +0 -4
  51. package/src/lib/components/dot-editable-text/dot-editable-text.component.html +0 -8
  52. package/src/lib/components/dot-editable-text/dot-editable-text.component.spec.ts +0 -424
  53. package/src/lib/components/dot-editable-text/dot-editable-text.component.ts +0 -269
  54. package/src/lib/components/dot-editable-text/utils.ts +0 -51
  55. package/src/lib/components/no-component/no-component.component.css +0 -3
  56. package/src/lib/components/no-component/no-component.component.spec.ts +0 -24
  57. package/src/lib/components/no-component/no-component.component.ts +0 -31
  58. package/src/lib/layout/column/column.component.css +0 -99
  59. package/src/lib/layout/column/column.component.spec.ts +0 -33
  60. package/src/lib/layout/column/column.component.ts +0 -49
  61. package/src/lib/layout/container/container.component.css +0 -9
  62. package/src/lib/layout/container/container.component.html +0 -26
  63. package/src/lib/layout/container/container.component.spec.ts +0 -205
  64. package/src/lib/layout/container/container.component.ts +0 -140
  65. package/src/lib/layout/contentlet/contentlet.component.spec.ts +0 -22
  66. package/src/lib/layout/dotcms-layout/dotcms-layout.component.css +0 -3
  67. package/src/lib/layout/dotcms-layout/dotcms-layout.component.spec.ts +0 -195
  68. package/src/lib/layout/dotcms-layout/dotcms-layout.component.ts +0 -150
  69. package/src/lib/layout/row/row.component.css +0 -6
  70. package/src/lib/layout/row/row.component.spec.ts +0 -28
  71. package/src/lib/layout/row/row.component.ts +0 -32
  72. package/src/lib/services/dotcms-context/page-context.spec.ts +0 -80
  73. package/src/lib/utils/index.ts +0 -92
  74. package/src/lib/utils/testing.utils.ts +0 -1019
  75. package/src/test-setup.ts +0 -8
  76. package/tsconfig.json +0 -29
  77. package/tsconfig.lib.json +0 -12
  78. package/tsconfig.lib.prod.json +0 -9
  79. package/tsconfig.spec.json +0 -11
@@ -0,0 +1,120 @@
1
+ import { ChangeDetectionStrategy, Component, HostBinding, Input } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ /**
4
+ * This component is responsible to display a contentlet.
5
+ *
6
+ * @export
7
+ * @class ContentletComponent
8
+ * @implements {OnChanges}
9
+ */
10
+ export class ContentletComponent {
11
+ constructor() {
12
+ /**
13
+ * The identifier of contentlet component.
14
+ *
15
+ * @type {(string | null)}
16
+ * @memberof ContentletComponent
17
+ */
18
+ this.identifier = null;
19
+ /**
20
+ * The base type of contentlet component.
21
+ *
22
+ * @type {(string | null)}
23
+ * @memberof ContentletComponent
24
+ */
25
+ this.baseType = null;
26
+ /**
27
+ * The title of contentlet component.
28
+ *
29
+ * @type {(string | null)}
30
+ * @memberof ContentletComponent
31
+ */
32
+ this.title = null;
33
+ /**
34
+ * The inode of contentlet component.
35
+ *
36
+ * @type {(string | null)}
37
+ * @memberof ContentletComponent
38
+ */
39
+ this.inode = null;
40
+ /**
41
+ * The type of contentlet component.
42
+ *
43
+ * @type {(string | null)}
44
+ * @memberof ContentletComponent
45
+ */
46
+ this.dotType = null;
47
+ /**
48
+ * The container of contentlet component.
49
+ *
50
+ * @type {(string | null)}
51
+ * @memberof ContentletComponent
52
+ */
53
+ this.dotContainer = null;
54
+ /**
55
+ * The number of pages where the contentlet appears
56
+ *
57
+ * @type {(string | null)}
58
+ * @memberof ContentletComponent
59
+ */
60
+ this.numberOfPages = null;
61
+ /**
62
+ * The content of contentlet component.
63
+ *
64
+ * @type {(string | null)}
65
+ * @memberof ContentletComponent
66
+ */
67
+ this.dotContent = null;
68
+ }
69
+ ngOnChanges() {
70
+ this.identifier = this.contentlet.identifier;
71
+ this.baseType = this.contentlet.baseType;
72
+ this.title = this.contentlet.title;
73
+ this.inode = this.contentlet.inode;
74
+ this.dotType = this.contentlet.contentType;
75
+ this.dotContainer = this.container;
76
+ this.numberOfPages = this.contentlet['onNumberOfPages'];
77
+ this.dotContent = 'contentlet';
78
+ }
79
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: ContentletComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
80
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.3", type: ContentletComponent, isStandalone: true, selector: "dotcms-contentlet-wrapper", inputs: { contentlet: "contentlet", container: "container" }, host: { properties: { "attr.data-dot-identifier": "this.identifier", "attr.data-dot-basetype": "this.baseType", "attr.data-dot-title": "this.title", "attr.data-dot-inode": "this.inode", "attr.data-dot-type": "this.dotType", "attr.data-dot-container": "this.dotContainer", "attr.data-dot-on-number-of-pages": "this.numberOfPages", "attr.data-dot-object": "this.dotContent" } }, usesOnChanges: true, ngImport: i0, template: '<ng-content></ng-content>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
81
+ }
82
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: ContentletComponent, decorators: [{
83
+ type: Component,
84
+ args: [{
85
+ selector: 'dotcms-contentlet-wrapper',
86
+ standalone: true,
87
+ template: '<ng-content></ng-content>',
88
+ changeDetection: ChangeDetectionStrategy.OnPush
89
+ }]
90
+ }], propDecorators: { contentlet: [{
91
+ type: Input,
92
+ args: [{ required: true }]
93
+ }], container: [{
94
+ type: Input
95
+ }], identifier: [{
96
+ type: HostBinding,
97
+ args: ['attr.data-dot-identifier']
98
+ }], baseType: [{
99
+ type: HostBinding,
100
+ args: ['attr.data-dot-basetype']
101
+ }], title: [{
102
+ type: HostBinding,
103
+ args: ['attr.data-dot-title']
104
+ }], inode: [{
105
+ type: HostBinding,
106
+ args: ['attr.data-dot-inode']
107
+ }], dotType: [{
108
+ type: HostBinding,
109
+ args: ['attr.data-dot-type']
110
+ }], dotContainer: [{
111
+ type: HostBinding,
112
+ args: ['attr.data-dot-container']
113
+ }], numberOfPages: [{
114
+ type: HostBinding,
115
+ args: ['attr.data-dot-on-number-of-pages']
116
+ }], dotContent: [{
117
+ type: HostBinding,
118
+ args: ['attr.data-dot-object']
119
+ }] } });
120
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGVudGxldC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3Nkay9hbmd1bGFyL3NyYy9saWIvbGF5b3V0L2NvbnRlbnRsZXQvY29udGVudGxldC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFhLE1BQU0sZUFBZSxDQUFDOztBQUlsRzs7Ozs7O0dBTUc7QUFPSCxNQUFNLE9BQU8sbUJBQW1CO0lBTmhDO1FBc0JJOzs7OztXQUtHO1FBQ3NDLGVBQVUsR0FBa0IsSUFBSSxDQUFDO1FBQzFFOzs7OztXQUtHO1FBQ29DLGFBQVEsR0FBa0IsSUFBSSxDQUFDO1FBQ3RFOzs7OztXQUtHO1FBQ2lDLFVBQUssR0FBa0IsSUFBSSxDQUFDO1FBQ2hFOzs7OztXQUtHO1FBQ2lDLFVBQUssR0FBa0IsSUFBSSxDQUFDO1FBQ2hFOzs7OztXQUtHO1FBQ2dDLFlBQU8sR0FBa0IsSUFBSSxDQUFDO1FBQ2pFOzs7OztXQUtHO1FBQ3FDLGlCQUFZLEdBQWtCLElBQUksQ0FBQztRQUMzRTs7Ozs7V0FLRztRQUM4QyxrQkFBYSxHQUFrQixJQUFJLENBQUM7UUFDckY7Ozs7O1dBS0c7UUFDa0MsZUFBVSxHQUFrQixJQUFJLENBQUM7S0FZekU7SUFWRyxXQUFXO1FBQ1AsSUFBSSxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLFVBQVUsQ0FBQztRQUM3QyxJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDO1FBQ3pDLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUM7UUFDbkMsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLEtBQUssQ0FBQztRQUNuQyxJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsV0FBVyxDQUFDO1FBQzNDLElBQUksQ0FBQyxZQUFZLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQztRQUNuQyxJQUFJLENBQUMsYUFBYSxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsaUJBQWlCLENBQUMsQ0FBQztRQUN4RCxJQUFJLENBQUMsVUFBVSxHQUFHLFlBQVksQ0FBQztJQUNuQyxDQUFDOzhHQWxGUSxtQkFBbUI7a0dBQW5CLG1CQUFtQixpaUJBSGxCLDJCQUEyQjs7MkZBRzVCLG1CQUFtQjtrQkFOL0IsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsMkJBQTJCO29CQUNyQyxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFLDJCQUEyQjtvQkFDckMsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07aUJBQ2xEOzhCQVE4QixVQUFVO3NCQUFwQyxLQUFLO3VCQUFDLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRTtnQkFPaEIsU0FBUztzQkFBakIsS0FBSztnQkFRbUMsVUFBVTtzQkFBbEQsV0FBVzt1QkFBQywwQkFBMEI7Z0JBT0EsUUFBUTtzQkFBOUMsV0FBVzt1QkFBQyx3QkFBd0I7Z0JBT0QsS0FBSztzQkFBeEMsV0FBVzt1QkFBQyxxQkFBcUI7Z0JBT0UsS0FBSztzQkFBeEMsV0FBVzt1QkFBQyxxQkFBcUI7Z0JBT0MsT0FBTztzQkFBekMsV0FBVzt1QkFBQyxvQkFBb0I7Z0JBT08sWUFBWTtzQkFBbkQsV0FBVzt1QkFBQyx5QkFBeUI7Z0JBT1csYUFBYTtzQkFBN0QsV0FBVzt1QkFBQyxrQ0FBa0M7Z0JBT1YsVUFBVTtzQkFBOUMsV0FBVzt1QkFBQyxzQkFBc0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBIb3N0QmluZGluZywgSW5wdXQsIE9uQ2hhbmdlcyB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBEb3RDTVNDb250ZW50bGV0IH0gZnJvbSAnLi4vLi4vbW9kZWxzJztcblxuLyoqXG4gKiBUaGlzIGNvbXBvbmVudCBpcyByZXNwb25zaWJsZSB0byBkaXNwbGF5IGEgY29udGVudGxldC5cbiAqXG4gKiBAZXhwb3J0XG4gKiBAY2xhc3MgQ29udGVudGxldENvbXBvbmVudFxuICogQGltcGxlbWVudHMge09uQ2hhbmdlc31cbiAqL1xuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdkb3RjbXMtY29udGVudGxldC13cmFwcGVyJyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIHRlbXBsYXRlOiAnPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PicsXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgQ29udGVudGxldENvbXBvbmVudCBpbXBsZW1lbnRzIE9uQ2hhbmdlcyB7XG4gICAgLyoqXG4gICAgICogVGhlIGNvbnRlbnRsZXQgb2JqZWN0IGNvbnRhaW5pbmcgY29udGVudCBkYXRhLlxuICAgICAqXG4gICAgICogQHR5cGUge0RvdENNU0NvbnRlbnRsZXR9XG4gICAgICogQG1lbWJlcm9mIENvbnRlbnRsZXRDb21wb25lbnRcbiAgICAgKi9cbiAgICBASW5wdXQoeyByZXF1aXJlZDogdHJ1ZSB9KSBjb250ZW50bGV0ITogRG90Q01TQ29udGVudGxldDtcbiAgICAvKipcbiAgICAgKiBUaGUgY29udGFpbmVyIGRhdGEgKGFzIHN0cmluZykgd2hlcmUgdGhlIGNvbnRlbnRsZXQgaXMgbG9jYXRlZC5cbiAgICAgKlxuICAgICAqIEB0eXBlIHtzdHJpbmd9XG4gICAgICogQG1lbWJlcm9mIENvbnRlbnRsZXRDb21wb25lbnRcbiAgICAgKi9cbiAgICBASW5wdXQoKSBjb250YWluZXIhOiBzdHJpbmc7XG5cbiAgICAvKipcbiAgICAgKiBUaGUgaWRlbnRpZmllciBvZiBjb250ZW50bGV0IGNvbXBvbmVudC5cbiAgICAgKlxuICAgICAqIEB0eXBlIHsoc3RyaW5nIHwgbnVsbCl9XG4gICAgICogQG1lbWJlcm9mIENvbnRlbnRsZXRDb21wb25lbnRcbiAgICAgKi9cbiAgICBASG9zdEJpbmRpbmcoJ2F0dHIuZGF0YS1kb3QtaWRlbnRpZmllcicpIGlkZW50aWZpZXI6IHN0cmluZyB8IG51bGwgPSBudWxsO1xuICAgIC8qKlxuICAgICAqIFRoZSBiYXNlIHR5cGUgb2YgY29udGVudGxldCBjb21wb25lbnQuXG4gICAgICpcbiAgICAgKiBAdHlwZSB7KHN0cmluZyB8IG51bGwpfVxuICAgICAqIEBtZW1iZXJvZiBDb250ZW50bGV0Q29tcG9uZW50XG4gICAgICovXG4gICAgQEhvc3RCaW5kaW5nKCdhdHRyLmRhdGEtZG90LWJhc2V0eXBlJykgYmFzZVR5cGU6IHN0cmluZyB8IG51bGwgPSBudWxsO1xuICAgIC8qKlxuICAgICAqIFRoZSB0aXRsZSBvZiBjb250ZW50bGV0IGNvbXBvbmVudC5cbiAgICAgKlxuICAgICAqIEB0eXBlIHsoc3RyaW5nIHwgbnVsbCl9XG4gICAgICogQG1lbWJlcm9mIENvbnRlbnRsZXRDb21wb25lbnRcbiAgICAgKi9cbiAgICBASG9zdEJpbmRpbmcoJ2F0dHIuZGF0YS1kb3QtdGl0bGUnKSB0aXRsZTogc3RyaW5nIHwgbnVsbCA9IG51bGw7XG4gICAgLyoqXG4gICAgICogVGhlIGlub2RlIG9mIGNvbnRlbnRsZXQgY29tcG9uZW50LlxuICAgICAqXG4gICAgICogQHR5cGUgeyhzdHJpbmcgfCBudWxsKX1cbiAgICAgKiBAbWVtYmVyb2YgQ29udGVudGxldENvbXBvbmVudFxuICAgICAqL1xuICAgIEBIb3N0QmluZGluZygnYXR0ci5kYXRhLWRvdC1pbm9kZScpIGlub2RlOiBzdHJpbmcgfCBudWxsID0gbnVsbDtcbiAgICAvKipcbiAgICAgKiBUaGUgdHlwZSBvZiBjb250ZW50bGV0IGNvbXBvbmVudC5cbiAgICAgKlxuICAgICAqIEB0eXBlIHsoc3RyaW5nIHwgbnVsbCl9XG4gICAgICogQG1lbWJlcm9mIENvbnRlbnRsZXRDb21wb25lbnRcbiAgICAgKi9cbiAgICBASG9zdEJpbmRpbmcoJ2F0dHIuZGF0YS1kb3QtdHlwZScpIGRvdFR5cGU6IHN0cmluZyB8IG51bGwgPSBudWxsO1xuICAgIC8qKlxuICAgICAqIFRoZSBjb250YWluZXIgb2YgY29udGVudGxldCBjb21wb25lbnQuXG4gICAgICpcbiAgICAgKiBAdHlwZSB7KHN0cmluZyB8IG51bGwpfVxuICAgICAqIEBtZW1iZXJvZiBDb250ZW50bGV0Q29tcG9uZW50XG4gICAgICovXG4gICAgQEhvc3RCaW5kaW5nKCdhdHRyLmRhdGEtZG90LWNvbnRhaW5lcicpIGRvdENvbnRhaW5lcjogc3RyaW5nIHwgbnVsbCA9IG51bGw7XG4gICAgLyoqXG4gICAgICogVGhlIG51bWJlciBvZiBwYWdlcyB3aGVyZSB0aGUgY29udGVudGxldCBhcHBlYXJzXG4gICAgICpcbiAgICAgKiBAdHlwZSB7KHN0cmluZyB8IG51bGwpfVxuICAgICAqIEBtZW1iZXJvZiBDb250ZW50bGV0Q29tcG9uZW50XG4gICAgICovXG4gICAgQEhvc3RCaW5kaW5nKCdhdHRyLmRhdGEtZG90LW9uLW51bWJlci1vZi1wYWdlcycpIG51bWJlck9mUGFnZXM6IHN0cmluZyB8IG51bGwgPSBudWxsO1xuICAgIC8qKlxuICAgICAqIFRoZSBjb250ZW50IG9mIGNvbnRlbnRsZXQgY29tcG9uZW50LlxuICAgICAqXG4gICAgICogQHR5cGUgeyhzdHJpbmcgfCBudWxsKX1cbiAgICAgKiBAbWVtYmVyb2YgQ29udGVudGxldENvbXBvbmVudFxuICAgICAqL1xuICAgIEBIb3N0QmluZGluZygnYXR0ci5kYXRhLWRvdC1vYmplY3QnKSBkb3RDb250ZW50OiBzdHJpbmcgfCBudWxsID0gbnVsbDtcblxuICAgIG5nT25DaGFuZ2VzKCkge1xuICAgICAgICB0aGlzLmlkZW50aWZpZXIgPSB0aGlzLmNvbnRlbnRsZXQuaWRlbnRpZmllcjtcbiAgICAgICAgdGhpcy5iYXNlVHlwZSA9IHRoaXMuY29udGVudGxldC5iYXNlVHlwZTtcbiAgICAgICAgdGhpcy50aXRsZSA9IHRoaXMuY29udGVudGxldC50aXRsZTtcbiAgICAgICAgdGhpcy5pbm9kZSA9IHRoaXMuY29udGVudGxldC5pbm9kZTtcbiAgICAgICAgdGhpcy5kb3RUeXBlID0gdGhpcy5jb250ZW50bGV0LmNvbnRlbnRUeXBlO1xuICAgICAgICB0aGlzLmRvdENvbnRhaW5lciA9IHRoaXMuY29udGFpbmVyO1xuICAgICAgICB0aGlzLm51bWJlck9mUGFnZXMgPSB0aGlzLmNvbnRlbnRsZXRbJ29uTnVtYmVyT2ZQYWdlcyddO1xuICAgICAgICB0aGlzLmRvdENvbnRlbnQgPSAnY29udGVudGxldCc7XG4gICAgfVxufVxuIl19
@@ -0,0 +1,100 @@
1
+ import { AsyncPipe } from '@angular/common';
2
+ import { ChangeDetectionStrategy, Component, DestroyRef, Input, inject } from '@angular/core';
3
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
4
+ import { ActivatedRoute } from '@angular/router';
5
+ import { CUSTOMER_ACTIONS, DotCmsClient, initEditor, isInsideEditor, postMessageToEditor, updateNavigation } from '@dotcms/client';
6
+ import { PageContextService } from '../../services/dotcms-context/page-context.service';
7
+ import { RowComponent } from '../row/row.component';
8
+ import * as i0 from "@angular/core";
9
+ /**
10
+ * `DotcmsLayoutComponent` is a class that represents the layout for a DotCMS page.
11
+ * It includes a `pageAsset` property that represents the DotCMS page asset and a `components` property that represents the dynamic components for the page.
12
+ *
13
+ * @export
14
+ * @class DotcmsLayoutComponent
15
+ */
16
+ export class DotcmsLayoutComponent {
17
+ constructor() {
18
+ this.route = inject(ActivatedRoute);
19
+ this.pageContextService = inject(PageContextService);
20
+ this.destroyRef$ = inject(DestroyRef);
21
+ this.pageAsset$ = this.pageContextService.currentPage$;
22
+ }
23
+ /**
24
+ * Represents the DotCMS page asset.
25
+ *
26
+ * @type {DotCMSPageAsset}
27
+ * @memberof DotcmsLayoutComponent
28
+ */
29
+ set pageAsset(value) {
30
+ this._pageAsset = value;
31
+ if (!value.layout) {
32
+ 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.');
33
+ }
34
+ }
35
+ /**
36
+ * Returns the DotCMS page asset.
37
+ *
38
+ * @readonly
39
+ * @type {DotCMSPageAsset}
40
+ * @memberof DotcmsLayoutComponent
41
+ */
42
+ get pageAsset() {
43
+ return this._pageAsset;
44
+ }
45
+ ngOnInit() {
46
+ this.pageContextService.setContext(this.pageAsset, this.components);
47
+ if (!isInsideEditor()) {
48
+ return;
49
+ }
50
+ this.client = DotCmsClient.instance;
51
+ this.route.url.pipe(takeUntilDestroyed(this.destroyRef$)).subscribe((urlSegments) => {
52
+ const pathname = '/' + urlSegments.join('/');
53
+ initEditor({ pathname });
54
+ updateNavigation(pathname || '/');
55
+ });
56
+ this.client.editor.on('changes', (data) => {
57
+ if (this.onReload) {
58
+ this.onReload();
59
+ return;
60
+ }
61
+ this.pageContextService.setPageAsset(data);
62
+ });
63
+ postMessageToEditor({ action: CUSTOMER_ACTIONS.CLIENT_READY, payload: this.editor });
64
+ }
65
+ ngOnDestroy() {
66
+ if (!isInsideEditor()) {
67
+ return;
68
+ }
69
+ this.client.editor.off('changes');
70
+ }
71
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: DotcmsLayoutComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
72
+ 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: `
73
+ @if (pageAsset$ | async; as page) {
74
+ @for (row of this.page?.layout?.body?.rows; track $index) {
75
+ <dotcms-row [row]="row" />
76
+ }
77
+ }
78
+ `, 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 }); }
79
+ }
80
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: DotcmsLayoutComponent, decorators: [{
81
+ type: Component,
82
+ args: [{ selector: 'dotcms-layout', standalone: true, imports: [RowComponent, AsyncPipe], template: `
83
+ @if (pageAsset$ | async; as page) {
84
+ @for (row of this.page?.layout?.body?.rows; track $index) {
85
+ <dotcms-row [row]="row" />
86
+ }
87
+ }
88
+ `, changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host{display:block}\n"] }]
89
+ }], propDecorators: { pageAsset: [{
90
+ type: Input,
91
+ args: [{ required: true }]
92
+ }], components: [{
93
+ type: Input,
94
+ args: [{ required: true }]
95
+ }], onReload: [{
96
+ type: Input
97
+ }], editor: [{
98
+ type: Input
99
+ }] } });
100
+ //# 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":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,UAAU,EACV,KAAK,EAEL,MAAM,EACT,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAChE,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AAEjD,OAAO,EACH,gBAAgB,EAChB,YAAY,EAEZ,UAAU,EACV,cAAc,EACd,mBAAmB,EACnB,gBAAgB,EACnB,MAAM,gBAAgB,CAAC;AAIxB,OAAO,EAAE,kBAAkB,EAAE,MAAM,oDAAoD,CAAC;AACxF,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;;AAEpD;;;;;;GAMG;AAeH,MAAM,OAAO,qBAAqB;IAdlC;QA0EqB,UAAK,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC;QAC/B,uBAAkB,GAAG,MAAM,CAAC,kBAAkB,CAAC,CAAC;QAChD,gBAAW,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;QAE/B,eAAU,GAAG,IAAI,CAAC,kBAAkB,CAAC,YAAY,CAAC;KAqCxE;IAlGG;;;;;OAKG;IACH,IACI,SAAS,CAAC,KAAsB;QAChC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC;YAChB,OAAO,CAAC,IAAI,CACR,iJAAiJ,CACpJ,CAAC;QACN,CAAC;IACL,CAAC;IAED;;;;;;OAMG;IACH,IAAI,SAAS;QACT,OAAO,IAAI,CAAC,UAAU,CAAC;IAC3B,CAAC;IAsCD,QAAQ;QACJ,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;QAEpE,IAAI,CAAC,cAAc,EAAE,EAAE,CAAC;YACpB,OAAO;QACX,CAAC;QAED,IAAI,CAAC,MAAM,GAAG,YAAY,CAAC,QAAQ,CAAC;QACpC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,EAAE;YAChF,MAAM,QAAQ,GAAG,GAAG,GAAG,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAE7C,UAAU,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC;YACzB,gBAAgB,CAAC,QAAQ,IAAI,GAAG,CAAC,CAAC;QACtC,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,SAAS,EAAE,CAAC,IAAI,EAAE,EAAE;YACtC,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAChB,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAEhB,OAAO;YACX,CAAC;YAED,IAAI,CAAC,kBAAkB,CAAC,YAAY,CAAC,IAAuB,CAAC,CAAC;QAClE,CAAC,CAAC,CAAC;QAEH,mBAAmB,CAAC,EAAE,MAAM,EAAE,gBAAgB,CAAC,YAAY,EAAE,OAAO,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;IACzF,CAAC;IAED,WAAW;QACP,IAAI,CAAC,cAAc,EAAE,EAAE,CAAC;YACpB,OAAO;QACX,CAAC;QAED,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;IACtC,CAAC;8GApGQ,qBAAqB;kGAArB,qBAAqB,+KAVpB;;;;;;KAMT,gGAPS,YAAY,mEAAE,SAAS;;2FAWxB,qBAAqB;kBAdjC,SAAS;+BACI,eAAe,cACb,IAAI,WACP,CAAC,YAAY,EAAE,SAAS,CAAC,YACxB;;;;;;KAMT,mBAEgB,uBAAuB,CAAC,MAAM;8BAY3C,SAAS;sBADZ,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;gBA4BE,UAAU;sBAApC,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;gBAQhB,QAAQ;sBAAhB,KAAK;gBAaG,MAAM;sBAAd,KAAK","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    CUSTOMER_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 this.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: CUSTOMER_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"]}
@@ -0,0 +1,29 @@
1
+ import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
2
+ import { ColumnComponent } from '../column/column.component';
3
+ import * as i0 from "@angular/core";
4
+ /**
5
+ * This component is responsible to display a row with columns.
6
+ *
7
+ * @export
8
+ * @class RowComponent
9
+ */
10
+ export class RowComponent {
11
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: RowComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
12
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.3", type: RowComponent, isStandalone: true, selector: "dotcms-row", inputs: { row: "row" }, ngImport: i0, template: `
13
+ @for (column of row.columns; track $index) {
14
+ <dotcms-column [column]="column" />
15
+ }
16
+ `, isInline: true, styles: [":host{display:grid;grid-template-columns:repeat(12,1fr);gap:1rem;row-gap:1rem}\n"], dependencies: [{ kind: "component", type: ColumnComponent, selector: "dotcms-column", inputs: ["column"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
17
+ }
18
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: RowComponent, decorators: [{
19
+ type: Component,
20
+ args: [{ selector: 'dotcms-row', standalone: true, imports: [ColumnComponent], template: `
21
+ @for (column of row.columns; track $index) {
22
+ <dotcms-column [column]="column" />
23
+ }
24
+ `, changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host{display:grid;grid-template-columns:repeat(12,1fr);gap:1rem;row-gap:1rem}\n"] }]
25
+ }], propDecorators: { row: [{
26
+ type: Input,
27
+ args: [{ required: true }]
28
+ }] } });
29
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm93LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvc2RrL2FuZ3VsYXIvc3JjL2xpYi9sYXlvdXQvcm93L3Jvdy5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHMUUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDRCQUE0QixDQUFDOztBQUU3RDs7Ozs7R0FLRztBQWFILE1BQU0sT0FBTyxZQUFZOzhHQUFaLFlBQVk7a0dBQVosWUFBWSw4RkFSWDs7OztLQUlULDBKQUxTLGVBQWU7OzJGQVNoQixZQUFZO2tCQVp4QixTQUFTOytCQUNJLFlBQVksY0FDVixJQUFJLFdBQ1AsQ0FBQyxlQUFlLENBQUMsWUFDaEI7Ozs7S0FJVCxtQkFFZ0IsdUJBQXVCLENBQUMsTUFBTTs4QkFTcEIsR0FBRztzQkFBN0IsS0FBSzt1QkFBQyxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBEb3RQYWdlQXNzZXRMYXlvdXRSb3cgfSBmcm9tICcuLi8uLi9tb2RlbHMnO1xuaW1wb3J0IHsgQ29sdW1uQ29tcG9uZW50IH0gZnJvbSAnLi4vY29sdW1uL2NvbHVtbi5jb21wb25lbnQnO1xuXG4vKipcbiAqIFRoaXMgY29tcG9uZW50IGlzIHJlc3BvbnNpYmxlIHRvIGRpc3BsYXkgYSByb3cgd2l0aCBjb2x1bW5zLlxuICpcbiAqIEBleHBvcnRcbiAqIEBjbGFzcyBSb3dDb21wb25lbnRcbiAqL1xuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdkb3RjbXMtcm93JyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtDb2x1bW5Db21wb25lbnRdLFxuICAgIHRlbXBsYXRlOiBgXG4gICAgICAgIEBmb3IgKGNvbHVtbiBvZiByb3cuY29sdW1uczsgdHJhY2sgJGluZGV4KSB7XG4gICAgICAgICAgICA8ZG90Y21zLWNvbHVtbiBbY29sdW1uXT1cImNvbHVtblwiIC8+XG4gICAgICAgIH1cbiAgICBgLFxuICAgIHN0eWxlVXJsOiAnLi9yb3cuY29tcG9uZW50LmNzcycsXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgUm93Q29tcG9uZW50IHtcbiAgICAvKipcbiAgICAgKiBUaGUgcm93IG9iamVjdCBjb250YWluaW5nIHRoZSBjb2x1bW5zLlxuICAgICAqXG4gICAgICogQHR5cGUge0RvdFBhZ2VBc3NldExheW91dFJvd31cbiAgICAgKiBAbWVtYmVyb2YgUm93Q29tcG9uZW50XG4gICAgICovXG4gICAgQElucHV0KHsgcmVxdWlyZWQ6IHRydWUgfSkgcm93ITogRG90UGFnZUFzc2V0TGF5b3V0Um93O1xufVxuIl19
@@ -0,0 +1,3 @@
1
+ /* eslint-disable @typescript-eslint/no-explicit-any */
2
+ export {};
3
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dotcms.model.js","sourceRoot":"","sources":["../../../../../../../libs/sdk/angular/src/lib/models/dotcms.model.ts"],"names":[],"mappings":"AAAA,uDAAuD","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\n\nexport interface DotCMSPageAsset {\n    canCreateTemplate: boolean;\n    containers: DotCMSPageAssetContainer;\n    layout: DotCMSLayout;\n    page: DotCMSPage;\n    site: DotCMSSite;\n    template: DotCMSTemplate;\n    viewAs: DotCMSViewAs;\n    vanityUrl?: {\n        pattern: string;\n        vanityUrlId: string;\n        url: string;\n        siteId: string;\n        languageId: number;\n        forwardTo: string;\n        response: number;\n        order: number;\n        temporaryRedirect: boolean;\n        permanentRedirect: boolean;\n        forward: boolean;\n    };\n}\n\nexport interface DotPageAssetLayoutRow {\n    identifier: number;\n    value?: string;\n    id?: string;\n    columns: DotPageAssetLayoutColumn[];\n    styleClass?: string;\n}\n\nexport interface DotPageAssetLayoutColumn {\n    preview: boolean;\n    containers: DotCMSContainer[];\n    widthPercent: number;\n    width: number;\n    leftOffset: number;\n    left: number;\n    styleClass?: string;\n}\n\nexport interface DotCMSPageAssetContainer {\n    [key: string]: {\n        container: DotCMSContainer;\n        containerStructures: DotCMSContainerStructure[];\n        contentlets: {\n            [key: string]: DotCMSContentlet[];\n        };\n    };\n}\n\nexport interface DotCMSContainer {\n    identifier: string;\n    uuid: string;\n    iDate: number;\n    type: string;\n    owner?: string;\n    inode: string;\n    source: string;\n    title: string;\n    friendlyName: string;\n    modDate: number;\n    modUser: string;\n    sortOrder: number;\n    showOnMenu: boolean;\n    code?: string;\n    maxContentlets: number;\n    useDiv: boolean;\n    sortContentletsBy?: string;\n    preLoop: string;\n    postLoop: string;\n    staticify: boolean;\n    luceneQuery?: string;\n    notes: string;\n    languageId?: number;\n    path?: string;\n    live: boolean;\n    locked: boolean;\n    working: boolean;\n    deleted: boolean;\n    name: string;\n    archived: boolean;\n    permissionId: string;\n    versionId: string;\n    versionType: string;\n    permissionType: string;\n    categoryId: string;\n    idate: number;\n    new: boolean;\n    acceptTypes: string;\n    contentlets: DotCMSContentlet[];\n    parentPermissionable: DotCMSSiteParentPermissionable;\n}\n\nexport interface DotCMSContentlet {\n    archived: boolean;\n    baseType: string;\n    deleted?: boolean;\n    binary?: string;\n    binaryContentAsset?: string;\n    binaryVersion?: string;\n    contentType: string;\n    file?: string;\n    folder: string;\n    hasLiveVersion?: boolean;\n    hasTitleImage: boolean;\n    host: string;\n    hostName: string;\n    identifier: string;\n    inode: string;\n    image?: string;\n    languageId: number;\n    language?: string;\n    live: boolean;\n    locked: boolean;\n    mimeType?: string;\n    modDate: string;\n    modUser: string;\n    modUserName: string;\n    owner: string;\n    sortOrder: number;\n    stInode: string;\n    title: string;\n    titleImage: string;\n    text?: string;\n    url: string;\n    working: boolean;\n    body?: string;\n    contentTypeIcon?: string;\n    variant?: string;\n    __icon__?: string;\n    [key: string]: any; // This is a catch-all for any other custom properties that might be on the contentlet.\n}\n\nexport interface DotcmsNavigationItem {\n    code?: any;\n    folder: string;\n    children?: DotcmsNavigationItem[];\n    host: string;\n    languageId: number;\n    href: string;\n    title: string;\n    type: string;\n    hash: number;\n    target: string;\n    order: number;\n}\n\ninterface DotCMSTemplate {\n    iDate: number;\n    type: string;\n    owner: string;\n    inode: string;\n    identifier: string;\n    source: string;\n    title: string;\n    friendlyName: string;\n    modDate: number;\n    modUser: string;\n    sortOrder: number;\n    showOnMenu: boolean;\n    image: string;\n    drawed: boolean;\n    drawedBody: string;\n    theme: string;\n    anonymous: boolean;\n    template: boolean;\n    name: string;\n    live: boolean;\n    archived: boolean;\n    locked: boolean;\n    working: boolean;\n    permissionId: string;\n    versionId: string;\n    versionType: string;\n    deleted: boolean;\n    permissionType: string;\n    categoryId: string;\n    idate: number;\n    new: boolean;\n    canEdit: boolean;\n}\n\ninterface DotCMSPage {\n    template: string;\n    modDate: number;\n    metadata: string;\n    cachettl: string;\n    pageURI: string;\n    title: string;\n    type: string;\n    showOnMenu: string;\n    httpsRequired: boolean;\n    inode: string;\n    disabledWYSIWYG: any[];\n    seokeywords: string;\n    host: string;\n    lastReview: number;\n    working: boolean;\n    locked: boolean;\n    stInode: string;\n    friendlyName: string;\n    live: boolean;\n    owner: string;\n    identifier: string;\n    nullProperties: any[];\n    friendlyname: string;\n    pagemetadata: string;\n    languageId: number;\n    url: string;\n    seodescription: string;\n    modUserName: string;\n    folder: string;\n    deleted: boolean;\n    sortOrder: number;\n    modUser: string;\n    pageUrl: string;\n    workingInode: string;\n    shortyWorking: string;\n    canEdit: boolean;\n    canRead: boolean;\n    canLock: boolean;\n    lockedOn: number;\n    lockedBy: string;\n    lockedByName: string;\n    liveInode: string;\n    shortyLive: string;\n}\n\ninterface DotCMSViewAs {\n    language: {\n        id: number;\n        languageCode: string;\n        countryCode: string;\n        language: string;\n        country: string;\n    };\n    mode: string;\n}\n\ninterface DotCMSLayout {\n    pageWidth: string;\n    width: string;\n    layout: string;\n    title: string;\n    header: boolean;\n    footer: boolean;\n    body: DotPageAssetLayoutBody;\n    sidebar: DotPageAssetLayoutSidebar;\n}\n\ninterface DotCMSContainerStructure {\n    id: string;\n    structureId: string;\n    containerInode: string;\n    containerId: string;\n    code: string;\n    contentTypeVar: string;\n}\n\ninterface DotPageAssetLayoutSidebar {\n    preview: boolean;\n    containers: DotCMSContainer[];\n    location: string;\n    widthPercent: number;\n    width: string;\n}\n\ninterface DotPageAssetLayoutBody {\n    rows: DotPageAssetLayoutRow[];\n}\n\ninterface DotCMSSite {\n    lowIndexPriority: boolean;\n    name: string;\n    default: boolean;\n    aliases: string;\n    parent: boolean;\n    tagStorage: string;\n    systemHost: boolean;\n    inode: string;\n    versionType: string;\n    structureInode: string;\n    hostname: string;\n    hostThumbnail?: any;\n    owner: string;\n    permissionId: string;\n    permissionType: string;\n    type: string;\n    identifier: string;\n    modDate: number;\n    host: string;\n    live: boolean;\n    indexPolicy: string;\n    categoryId: string;\n    actionId?: any;\n    new: boolean;\n    archived: boolean;\n    locked: boolean;\n    disabledWysiwyg: any[];\n    modUser: string;\n    working: boolean;\n    titleImage: {\n        present: boolean;\n    };\n    folder: string;\n    htmlpage: boolean;\n    fileAsset: boolean;\n    vanityUrl: boolean;\n    keyValue: boolean;\n    structure?: DotCMSSiteStructure;\n    title: string;\n    languageId: number;\n    indexPolicyDependencies: string;\n    contentTypeId: string;\n    versionId: string;\n    lastReview: number;\n    nextReview?: any;\n    reviewInterval?: any;\n    sortOrder: number;\n    contentType: DotCMSSiteContentType;\n}\n\ninterface DotCMSSiteContentType {\n    owner?: any;\n    parentPermissionable: DotCMSSiteParentPermissionable;\n    permissionId: string;\n    permissionType: string;\n}\n\nexport interface DotCMSSiteParentPermissionable {\n    Inode: string;\n    Identifier: string;\n    permissionByIdentifier: boolean;\n    type: string;\n    owner?: any;\n    identifier: string;\n    permissionId: string;\n    parentPermissionable?: any;\n    permissionType: string;\n    inode: string;\n    childrenPermissionable?: any;\n    variantId?: string;\n}\n\ninterface DotCMSSiteStructure {\n    iDate: number;\n    type: string;\n    owner?: any;\n    inode: string;\n    identifier: string;\n    name: string;\n    description: string;\n    defaultStructure: boolean;\n    reviewInterval?: any;\n    reviewerRole?: any;\n    pagedetail?: any;\n    structureType: number;\n    fixed: boolean;\n    system: boolean;\n    velocityVarName: string;\n    urlMapPattern?: any;\n    host: string;\n    folder: string;\n    publishDateVar?: any;\n    expireDateVar?: any;\n    modDate: number;\n    fields: DotCMSSiteField[];\n    widget: boolean;\n    detailPage?: any;\n    fieldsBySortOrder: DotCMSSiteField[];\n    form: boolean;\n    htmlpageAsset: boolean;\n    content: boolean;\n    fileAsset: boolean;\n    persona: boolean;\n    permissionId: string;\n    permissionType: string;\n    live: boolean;\n    categoryId: string;\n    idate: number;\n    new: boolean;\n    archived: boolean;\n    locked: boolean;\n    modUser: string;\n    working: boolean;\n    title: string;\n    versionId: string;\n    versionType: string;\n}\n\ninterface DotCMSSiteField {\n    iDate: number;\n    type: string;\n    owner?: any;\n    inode: string;\n    identifier: string;\n    structureInode: string;\n    fieldName: string;\n    fieldType: string;\n    fieldRelationType?: any;\n    fieldContentlet: string;\n    required: boolean;\n    velocityVarName: string;\n    sortOrder: number;\n    values?: any;\n    regexCheck?: any;\n    hint?: any;\n    defaultValue?: any;\n    indexed: boolean;\n    listed: boolean;\n    fixed: boolean;\n    readOnly: boolean;\n    searchable: boolean;\n    unique: boolean;\n    modDate: number;\n    dataType: string;\n    live: boolean;\n    categoryId: string;\n    idate: number;\n    new: boolean;\n    archived: boolean;\n    locked: boolean;\n    modUser: string;\n    working: boolean;\n    permissionId: string;\n    parentPermissionable?: any;\n    permissionType: string;\n    title: string;\n    versionId: string;\n    versionType: string;\n}\n"]}
@@ -0,0 +1,3 @@
1
+ /* eslint-disable @typescript-eslint/no-explicit-any */
2
+ export * from './dotcms.model';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3Nkay9hbmd1bGFyL3NyYy9saWIvbW9kZWxzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLHVEQUF1RDtBQUN2RCxjQUFjLGdCQUFnQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueSAqL1xuZXhwb3J0ICogZnJvbSAnLi9kb3RjbXMubW9kZWwnO1xuXG5pbXBvcnQgeyBUeXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IERvdENNU1BhZ2VBc3NldCB9IGZyb20gJy4vZG90Y21zLm1vZGVsJztcblxuLyoqXG4gKiBSZXByZXNlbnRzIGEgZHluYW1pYyBjb21wb25lbnQgZW50aXR5LlxuICogQHR5cGVkZWYge1Byb21pc2U8VHlwZTxhbnk+Pn0gRHluYW1pY0NvbXBvbmVudEVudGl0eVxuICogQG1lbWJlcm9mIEBkb3RjbXMvYW5ndWxhclxuICovXG5leHBvcnQgdHlwZSBEeW5hbWljQ29tcG9uZW50RW50aXR5ID0gUHJvbWlzZTxUeXBlPGFueT4+O1xuXG4vKipcbiAqIFJlcHJlc2VudHMgdGhlIGNvbnRleHQgb2YgYSBEb3RDTVMgcGFnZS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBEb3RDTVNQYWdlQ29udGV4dCB7XG4gICAgLyoqXG4gICAgICogUmVwcmVzZW50cyB0aGUgRG90Q01TIHBhZ2UgYXNzZXQuXG4gICAgICogQHR5cGUge0RvdENNU1BhZ2VBc3NldH1cbiAgICAgKiBAbWVtYmVyb2YgRG90Q01TUGFnZUNvbnRleHRcbiAgICAgKi9cbiAgICBwYWdlQXNzZXQ6IERvdENNU1BhZ2VBc3NldDtcblxuICAgIC8qKlxuICAgICAqIFJlcHJlc2VudHMgdGhlIGR5bmFtaWMgY29tcG9uZW50cyBvZiB0aGUgcGFnZSBmb3IgZWFjaCBDb250ZW50IFR5cGUuXG4gICAgICogQHR5cGUge0RvdENNU1BhZ2VDb21wb25lbnR9XG4gICAgICogQG1lbWJlcm9mIERvdENNU1BhZ2VDb250ZXh0XG4gICAgICovXG4gICAgY29tcG9uZW50czogRG90Q01TUGFnZUNvbXBvbmVudDtcblxuICAgIC8qKlxuICAgICAqIEluZGljYXRlcyB3aGV0aGVyIHRoZSBwYWdlIGlzIGJlaW5nIHZpZXdlZCBpbnNpZGUgdGhlIGVkaXRvci5cbiAgICAgKiBAdHlwZSB7Ym9vbGVhbn1cbiAgICAgKiBAbWVtYmVyb2YgRG90Q01TUGFnZUNvbnRleHRcbiAgICAgKi9cbiAgICBpc0luc2lkZUVkaXRvcjogYm9vbGVhbjtcbn1cblxuLyoqXG4gKiBSZXByZXNlbnRzIGEgRG90Q01TIHBhZ2UgY29tcG9uZW50LlxuICogVXNlZCB0byBzdG9yZSB0aGUgZHluYW1pYyBjb21wb25lbnRzIG9mIGEgRG90Q01TIHBhZ2UuXG4gKiBAdHlwZWRlZiB7UmVjb3JkPHN0cmluZywgRHluYW1pY0NvbXBvbmVudEVudGl0eT59IERvdENNU1BhZ2VDb21wb25lbnRcbiAqIEBtZW1iZXJvZiBAZG90Y21zL2FuZ3VsYXJcbiAqL1xuZXhwb3J0IHR5cGUgRG90Q01TUGFnZUNvbXBvbmVudCA9IFJlY29yZDxzdHJpbmcsIER5bmFtaWNDb21wb25lbnRFbnRpdHk+O1xuIl19
@@ -0,0 +1,75 @@
1
+ import { BehaviorSubject } from 'rxjs';
2
+ import { Injectable } from '@angular/core';
3
+ import { map } from 'rxjs/operators';
4
+ import { isInsideEditor } from '@dotcms/client';
5
+ import * as i0 from "@angular/core";
6
+ /**
7
+ * @author dotCMS
8
+ * @description This service is responsible for managing the page context.
9
+ * @export
10
+ * @class PageContextService
11
+ */
12
+ export class PageContextService {
13
+ constructor() {
14
+ this.context$ = new BehaviorSubject(null);
15
+ }
16
+ /**
17
+ * @description Get the context
18
+ * @readonly
19
+ * @type {DotCMSPageContext}
20
+ * @memberof PageContextService
21
+ */
22
+ get context() {
23
+ return this.context$.getValue();
24
+ }
25
+ /**
26
+ * @description Get the context as an observable
27
+ * @readonly
28
+ * @memberof PageContextService
29
+ */
30
+ get contextObs$() {
31
+ return this.context$.asObservable();
32
+ }
33
+ /**
34
+ * @description Get the current page asset
35
+ * @readonly
36
+ * @type {(Observable<DotCMSPageAsset | null>)}
37
+ * @memberof PageContextService
38
+ */
39
+ get currentPage$() {
40
+ return this.contextObs$.pipe(map((context) => context?.pageAsset || null));
41
+ }
42
+ /**
43
+ *
44
+ * @description Set the context
45
+ * @param {DotCMSPageAsset} value
46
+ * @memberof DotcmsContextService
47
+ */
48
+ setContext(pageAsset, components) {
49
+ this.context$.next({
50
+ pageAsset,
51
+ components,
52
+ isInsideEditor: isInsideEditor()
53
+ });
54
+ }
55
+ /**
56
+ * @description Set the page asset in the context
57
+ * @param {DotCMSPageAsset} pageAsset
58
+ * @memberof PageContextService
59
+ */
60
+ setPageAsset(pageAsset) {
61
+ this.context$.next({
62
+ ...this.context,
63
+ pageAsset
64
+ });
65
+ }
66
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: PageContextService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
67
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: PageContextService, providedIn: 'root' }); }
68
+ }
69
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: PageContextService, decorators: [{
70
+ type: Injectable,
71
+ args: [{
72
+ providedIn: 'root'
73
+ }]
74
+ }] });
75
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnZS1jb250ZXh0LnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3Nkay9hbmd1bGFyL3NyYy9saWIvc2VydmljZXMvZG90Y21zLWNvbnRleHQvcGFnZS1jb250ZXh0LnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGVBQWUsRUFBYyxNQUFNLE1BQU0sQ0FBQztBQUVuRCxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTNDLE9BQU8sRUFBRSxHQUFHLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUVyQyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7O0FBS2hEOzs7OztHQUtHO0FBSUgsTUFBTSxPQUFPLGtCQUFrQjtJQUgvQjtRQUlZLGFBQVEsR0FBRyxJQUFJLGVBQWUsQ0FBMkIsSUFBSSxDQUFDLENBQUM7S0F3RDFFO0lBdERHOzs7OztPQUtHO0lBQ0gsSUFBSSxPQUFPO1FBQ1AsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDLFFBQVEsRUFBdUIsQ0FBQztJQUN6RCxDQUFDO0lBRUQ7Ozs7T0FJRztJQUNILElBQUksV0FBVztRQUNYLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQUN4QyxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSCxJQUFJLFlBQVk7UUFDWixPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsT0FBTyxFQUFFLFNBQVMsSUFBSSxJQUFJLENBQUMsQ0FBQyxDQUFDO0lBQy9FLENBQUM7SUFFRDs7Ozs7T0FLRztJQUNILFVBQVUsQ0FBQyxTQUEwQixFQUFFLFVBQStCO1FBQ2xFLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDO1lBQ2YsU0FBUztZQUNULFVBQVU7WUFDVixjQUFjLEVBQUUsY0FBYyxFQUFFO1NBQ25DLENBQUMsQ0FBQztJQUNQLENBQUM7SUFFRDs7OztPQUlHO0lBQ0gsWUFBWSxDQUFDLFNBQTBCO1FBQ25DLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDO1lBQ2YsR0FBRyxJQUFJLENBQUMsT0FBTztZQUNmLFNBQVM7U0FDWixDQUFDLENBQUM7SUFDUCxDQUFDOzhHQXhEUSxrQkFBa0I7a0hBQWxCLGtCQUFrQixjQUZmLE1BQU07OzJGQUVULGtCQUFrQjtrQkFIOUIsVUFBVTttQkFBQztvQkFDUixVQUFVLEVBQUUsTUFBTTtpQkFDckIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCZWhhdmlvclN1YmplY3QsIE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcblxuaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBtYXAgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbmltcG9ydCB7IGlzSW5zaWRlRWRpdG9yIH0gZnJvbSAnQGRvdGNtcy9jbGllbnQnO1xuXG5pbXBvcnQgeyBEb3RDTVNQYWdlQ29tcG9uZW50LCBEb3RDTVNQYWdlQ29udGV4dCB9IGZyb20gJy4uLy4uL21vZGVscyc7XG5pbXBvcnQgeyBEb3RDTVNQYWdlQXNzZXQgfSBmcm9tICcuLi8uLi9tb2RlbHMvZG90Y21zLm1vZGVsJztcblxuLyoqXG4gKiBAYXV0aG9yIGRvdENNU1xuICogQGRlc2NyaXB0aW9uIFRoaXMgc2VydmljZSBpcyByZXNwb25zaWJsZSBmb3IgbWFuYWdpbmcgdGhlIHBhZ2UgY29udGV4dC5cbiAqIEBleHBvcnRcbiAqIEBjbGFzcyBQYWdlQ29udGV4dFNlcnZpY2VcbiAqL1xuQEluamVjdGFibGUoe1xuICAgIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBQYWdlQ29udGV4dFNlcnZpY2Uge1xuICAgIHByaXZhdGUgY29udGV4dCQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PERvdENNU1BhZ2VDb250ZXh0IHwgbnVsbD4obnVsbCk7XG5cbiAgICAvKipcbiAgICAgKiBAZGVzY3JpcHRpb24gR2V0IHRoZSBjb250ZXh0XG4gICAgICogQHJlYWRvbmx5XG4gICAgICogQHR5cGUge0RvdENNU1BhZ2VDb250ZXh0fVxuICAgICAqIEBtZW1iZXJvZiBQYWdlQ29udGV4dFNlcnZpY2VcbiAgICAgKi9cbiAgICBnZXQgY29udGV4dCgpOiBEb3RDTVNQYWdlQ29udGV4dCB7XG4gICAgICAgIHJldHVybiB0aGlzLmNvbnRleHQkLmdldFZhbHVlKCkgYXMgRG90Q01TUGFnZUNvbnRleHQ7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQGRlc2NyaXB0aW9uIEdldCB0aGUgY29udGV4dCBhcyBhbiBvYnNlcnZhYmxlXG4gICAgICogQHJlYWRvbmx5XG4gICAgICogQG1lbWJlcm9mIFBhZ2VDb250ZXh0U2VydmljZVxuICAgICAqL1xuICAgIGdldCBjb250ZXh0T2JzJCgpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuY29udGV4dCQuYXNPYnNlcnZhYmxlKCk7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQGRlc2NyaXB0aW9uIEdldCB0aGUgY3VycmVudCBwYWdlIGFzc2V0XG4gICAgICogQHJlYWRvbmx5XG4gICAgICogQHR5cGUgeyhPYnNlcnZhYmxlPERvdENNU1BhZ2VBc3NldCB8IG51bGw+KX1cbiAgICAgKiBAbWVtYmVyb2YgUGFnZUNvbnRleHRTZXJ2aWNlXG4gICAgICovXG4gICAgZ2V0IGN1cnJlbnRQYWdlJCgpOiBPYnNlcnZhYmxlPERvdENNU1BhZ2VBc3NldCB8IG51bGw+IHtcbiAgICAgICAgcmV0dXJuIHRoaXMuY29udGV4dE9icyQucGlwZShtYXAoKGNvbnRleHQpID0+IGNvbnRleHQ/LnBhZ2VBc3NldCB8fCBudWxsKSk7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICpcbiAgICAgKiBAZGVzY3JpcHRpb24gU2V0IHRoZSBjb250ZXh0XG4gICAgICogQHBhcmFtIHtEb3RDTVNQYWdlQXNzZXR9IHZhbHVlXG4gICAgICogQG1lbWJlcm9mIERvdGNtc0NvbnRleHRTZXJ2aWNlXG4gICAgICovXG4gICAgc2V0Q29udGV4dChwYWdlQXNzZXQ6IERvdENNU1BhZ2VBc3NldCwgY29tcG9uZW50czogRG90Q01TUGFnZUNvbXBvbmVudCkge1xuICAgICAgICB0aGlzLmNvbnRleHQkLm5leHQoe1xuICAgICAgICAgICAgcGFnZUFzc2V0LFxuICAgICAgICAgICAgY29tcG9uZW50cyxcbiAgICAgICAgICAgIGlzSW5zaWRlRWRpdG9yOiBpc0luc2lkZUVkaXRvcigpXG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIEBkZXNjcmlwdGlvbiBTZXQgdGhlIHBhZ2UgYXNzZXQgaW4gdGhlIGNvbnRleHRcbiAgICAgKiBAcGFyYW0ge0RvdENNU1BhZ2VBc3NldH0gcGFnZUFzc2V0XG4gICAgICogQG1lbWJlcm9mIFBhZ2VDb250ZXh0U2VydmljZVxuICAgICAqL1xuICAgIHNldFBhZ2VBc3NldChwYWdlQXNzZXQ6IERvdENNU1BhZ2VBc3NldCkge1xuICAgICAgICB0aGlzLmNvbnRleHQkLm5leHQoe1xuICAgICAgICAgICAgLi4udGhpcy5jb250ZXh0LFxuICAgICAgICAgICAgcGFnZUFzc2V0XG4gICAgICAgIH0pO1xuICAgIH1cbn1cbiJdfQ==
@@ -0,0 +1,79 @@
1
+ //Changed the type, to avoid SQ issue.
2
+ //This should be put inside a lib
3
+ /**
4
+ * Represents a mapping of numbers to corresponding CSS class names for column end values.
5
+ * @typedef {Record<number, string | null>} EndClassMap
6
+ */
7
+ const endClassMap = {
8
+ 1: 'col-end-1',
9
+ 2: 'col-end-2',
10
+ 3: 'col-end-3',
11
+ 4: 'col-end-4',
12
+ 5: 'col-end-5',
13
+ 6: 'col-end-6',
14
+ 7: 'col-end-7',
15
+ 8: 'col-end-8',
16
+ 9: 'col-end-9',
17
+ 10: 'col-end-10',
18
+ 11: 'col-end-11',
19
+ 12: 'col-end-12',
20
+ 13: 'col-end-13'
21
+ };
22
+ //Changed the type, to avoid SQ issue.
23
+ //This should be put inside a lib
24
+ /**
25
+ * Represents a mapping of numbers to CSS class names for starting columns.
26
+ * @typedef {Record<number, string | null>} StartClassMap
27
+ */
28
+ const startClassMap = {
29
+ 1: 'col-start-1',
30
+ 2: 'col-start-2',
31
+ 3: 'col-start-3',
32
+ 4: 'col-start-4',
33
+ 5: 'col-start-5',
34
+ 6: 'col-start-6',
35
+ 7: 'col-start-7',
36
+ 8: 'col-start-8',
37
+ 9: 'col-start-9',
38
+ 10: 'col-start-10',
39
+ 11: 'col-start-11',
40
+ 12: 'col-start-12'
41
+ };
42
+ /**
43
+ * Retrieves the data for a set of containers.
44
+ *
45
+ * @param containers - The DotCMSPageAssetContainer object containing the containers.
46
+ * @param containerRef - The DotCMSContainer object representing the container reference.
47
+ * @returns An object containing the container data, accept types, contentlets, and variant ID.
48
+ */
49
+ export const getContainersData = (containers, containerRef) => {
50
+ const { identifier, uuid } = containerRef;
51
+ const { containerStructures, container } = containers[identifier];
52
+ const { variantId } = container?.parentPermissionable || {};
53
+ const acceptTypes = containerStructures
54
+ .map((structure) => structure.contentTypeVar)
55
+ .join(',');
56
+ const contentlets = containers[identifier].contentlets[`uuid-${uuid}`];
57
+ return {
58
+ ...containers[identifier].container,
59
+ acceptTypes,
60
+ contentlets,
61
+ variantId
62
+ };
63
+ };
64
+ /**
65
+ * Returns the position style classes based on the start and end values.
66
+ * Used to set the grid column start and end values.
67
+ * @param start - The start value.
68
+ * @param end - The end value.
69
+ * @returns An object containing the startClass and endClass.
70
+ */
71
+ export const getPositionStyleClasses = (start, end) => {
72
+ const startClass = startClassMap[start];
73
+ const endClass = endClassMap[end];
74
+ return {
75
+ startClass,
76
+ endClass
77
+ };
78
+ };
79
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3Nkay9hbmd1bGFyL3NyYy9saWIvdXRpbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsc0NBQXNDO0FBQ3RDLGlDQUFpQztBQUNqQzs7O0dBR0c7QUFDSCxNQUFNLFdBQVcsR0FBa0M7SUFDL0MsQ0FBQyxFQUFFLFdBQVc7SUFDZCxDQUFDLEVBQUUsV0FBVztJQUNkLENBQUMsRUFBRSxXQUFXO0lBQ2QsQ0FBQyxFQUFFLFdBQVc7SUFDZCxDQUFDLEVBQUUsV0FBVztJQUNkLENBQUMsRUFBRSxXQUFXO0lBQ2QsQ0FBQyxFQUFFLFdBQVc7SUFDZCxDQUFDLEVBQUUsV0FBVztJQUNkLENBQUMsRUFBRSxXQUFXO0lBQ2QsRUFBRSxFQUFFLFlBQVk7SUFDaEIsRUFBRSxFQUFFLFlBQVk7SUFDaEIsRUFBRSxFQUFFLFlBQVk7SUFDaEIsRUFBRSxFQUFFLFlBQVk7Q0FDbkIsQ0FBQztBQUVGLHNDQUFzQztBQUN0QyxpQ0FBaUM7QUFDakM7OztHQUdHO0FBQ0gsTUFBTSxhQUFhLEdBQWtDO0lBQ2pELENBQUMsRUFBRSxhQUFhO0lBQ2hCLENBQUMsRUFBRSxhQUFhO0lBQ2hCLENBQUMsRUFBRSxhQUFhO0lBQ2hCLENBQUMsRUFBRSxhQUFhO0lBQ2hCLENBQUMsRUFBRSxhQUFhO0lBQ2hCLENBQUMsRUFBRSxhQUFhO0lBQ2hCLENBQUMsRUFBRSxhQUFhO0lBQ2hCLENBQUMsRUFBRSxhQUFhO0lBQ2hCLENBQUMsRUFBRSxhQUFhO0lBQ2hCLEVBQUUsRUFBRSxjQUFjO0lBQ2xCLEVBQUUsRUFBRSxjQUFjO0lBQ2xCLEVBQUUsRUFBRSxjQUFjO0NBQ3JCLENBQUM7QUFFRjs7Ozs7O0dBTUc7QUFDSCxNQUFNLENBQUMsTUFBTSxpQkFBaUIsR0FBRyxDQUM3QixVQUFvQyxFQUNwQyxZQUE2QixFQUMvQixFQUFFO0lBQ0EsTUFBTSxFQUFFLFVBQVUsRUFBRSxJQUFJLEVBQUUsR0FBRyxZQUFZLENBQUM7SUFFMUMsTUFBTSxFQUFFLG1CQUFtQixFQUFFLFNBQVMsRUFBRSxHQUFHLFVBQVUsQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUVsRSxNQUFNLEVBQUUsU0FBUyxFQUFFLEdBQUcsU0FBUyxFQUFFLG9CQUFvQixJQUFJLEVBQUUsQ0FBQztJQUU1RCxNQUFNLFdBQVcsR0FBVyxtQkFBbUI7U0FDMUMsR0FBRyxDQUFDLENBQUMsU0FBUyxFQUFFLEVBQUUsQ0FBQyxTQUFTLENBQUMsY0FBYyxDQUFDO1NBQzVDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUVmLE1BQU0sV0FBVyxHQUFHLFVBQVUsQ0FBQyxVQUFVLENBQUMsQ0FBQyxXQUFXLENBQUMsUUFBUSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0lBRXZFLE9BQU87UUFDSCxHQUFHLFVBQVUsQ0FBQyxVQUFVLENBQUMsQ0FBQyxTQUFTO1FBQ25DLFdBQVc7UUFDWCxXQUFXO1FBQ1gsU0FBUztLQUNaLENBQUM7QUFDTixDQUFDLENBQUM7QUFFRjs7Ozs7O0dBTUc7QUFDSCxNQUFNLENBQUMsTUFBTSx1QkFBdUIsR0FBRyxDQUFDLEtBQWEsRUFBRSxHQUFXLEVBQUUsRUFBRTtJQUNsRSxNQUFNLFVBQVUsR0FBRyxhQUFhLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDeEMsTUFBTSxRQUFRLEdBQUcsV0FBVyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBRWxDLE9BQU87UUFDSCxVQUFVO1FBQ1YsUUFBUTtLQUNYLENBQUM7QUFDTixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEb3RDTVNDb250YWluZXIsIERvdENNU1BhZ2VBc3NldENvbnRhaW5lciB9IGZyb20gJy4uL21vZGVscy9kb3RjbXMubW9kZWwnO1xuXG4vL0NoYW5nZWQgdGhlIHR5cGUsIHRvIGF2b2lkIFNRIGlzc3VlLlxuLy9UaGlzIHNob3VsZCBiZSBwdXQgaW5zaWRlIGEgbGliXG4vKipcbiAqIFJlcHJlc2VudHMgYSBtYXBwaW5nIG9mIG51bWJlcnMgdG8gY29ycmVzcG9uZGluZyBDU1MgY2xhc3MgbmFtZXMgZm9yIGNvbHVtbiBlbmQgdmFsdWVzLlxuICogQHR5cGVkZWYge1JlY29yZDxudW1iZXIsIHN0cmluZyB8IG51bGw+fSBFbmRDbGFzc01hcFxuICovXG5jb25zdCBlbmRDbGFzc01hcDogUmVjb3JkPG51bWJlciwgc3RyaW5nIHwgbnVsbD4gPSB7XG4gICAgMTogJ2NvbC1lbmQtMScsXG4gICAgMjogJ2NvbC1lbmQtMicsXG4gICAgMzogJ2NvbC1lbmQtMycsXG4gICAgNDogJ2NvbC1lbmQtNCcsXG4gICAgNTogJ2NvbC1lbmQtNScsXG4gICAgNjogJ2NvbC1lbmQtNicsXG4gICAgNzogJ2NvbC1lbmQtNycsXG4gICAgODogJ2NvbC1lbmQtOCcsXG4gICAgOTogJ2NvbC1lbmQtOScsXG4gICAgMTA6ICdjb2wtZW5kLTEwJyxcbiAgICAxMTogJ2NvbC1lbmQtMTEnLFxuICAgIDEyOiAnY29sLWVuZC0xMicsXG4gICAgMTM6ICdjb2wtZW5kLTEzJ1xufTtcblxuLy9DaGFuZ2VkIHRoZSB0eXBlLCB0byBhdm9pZCBTUSBpc3N1ZS5cbi8vVGhpcyBzaG91bGQgYmUgcHV0IGluc2lkZSBhIGxpYlxuLyoqXG4gKiBSZXByZXNlbnRzIGEgbWFwcGluZyBvZiBudW1iZXJzIHRvIENTUyBjbGFzcyBuYW1lcyBmb3Igc3RhcnRpbmcgY29sdW1ucy5cbiAqIEB0eXBlZGVmIHtSZWNvcmQ8bnVtYmVyLCBzdHJpbmcgfCBudWxsPn0gU3RhcnRDbGFzc01hcFxuICovXG5jb25zdCBzdGFydENsYXNzTWFwOiBSZWNvcmQ8bnVtYmVyLCBzdHJpbmcgfCBudWxsPiA9IHtcbiAgICAxOiAnY29sLXN0YXJ0LTEnLFxuICAgIDI6ICdjb2wtc3RhcnQtMicsXG4gICAgMzogJ2NvbC1zdGFydC0zJyxcbiAgICA0OiAnY29sLXN0YXJ0LTQnLFxuICAgIDU6ICdjb2wtc3RhcnQtNScsXG4gICAgNjogJ2NvbC1zdGFydC02JyxcbiAgICA3OiAnY29sLXN0YXJ0LTcnLFxuICAgIDg6ICdjb2wtc3RhcnQtOCcsXG4gICAgOTogJ2NvbC1zdGFydC05JyxcbiAgICAxMDogJ2NvbC1zdGFydC0xMCcsXG4gICAgMTE6ICdjb2wtc3RhcnQtMTEnLFxuICAgIDEyOiAnY29sLXN0YXJ0LTEyJ1xufTtcblxuLyoqXG4gKiBSZXRyaWV2ZXMgdGhlIGRhdGEgZm9yIGEgc2V0IG9mIGNvbnRhaW5lcnMuXG4gKlxuICogQHBhcmFtIGNvbnRhaW5lcnMgLSBUaGUgRG90Q01TUGFnZUFzc2V0Q29udGFpbmVyIG9iamVjdCBjb250YWluaW5nIHRoZSBjb250YWluZXJzLlxuICogQHBhcmFtIGNvbnRhaW5lclJlZiAtIFRoZSBEb3RDTVNDb250YWluZXIgb2JqZWN0IHJlcHJlc2VudGluZyB0aGUgY29udGFpbmVyIHJlZmVyZW5jZS5cbiAqIEByZXR1cm5zIEFuIG9iamVjdCBjb250YWluaW5nIHRoZSBjb250YWluZXIgZGF0YSwgYWNjZXB0IHR5cGVzLCBjb250ZW50bGV0cywgYW5kIHZhcmlhbnQgSUQuXG4gKi9cbmV4cG9ydCBjb25zdCBnZXRDb250YWluZXJzRGF0YSA9IChcbiAgICBjb250YWluZXJzOiBEb3RDTVNQYWdlQXNzZXRDb250YWluZXIsXG4gICAgY29udGFpbmVyUmVmOiBEb3RDTVNDb250YWluZXJcbikgPT4ge1xuICAgIGNvbnN0IHsgaWRlbnRpZmllciwgdXVpZCB9ID0gY29udGFpbmVyUmVmO1xuXG4gICAgY29uc3QgeyBjb250YWluZXJTdHJ1Y3R1cmVzLCBjb250YWluZXIgfSA9IGNvbnRhaW5lcnNbaWRlbnRpZmllcl07XG5cbiAgICBjb25zdCB7IHZhcmlhbnRJZCB9ID0gY29udGFpbmVyPy5wYXJlbnRQZXJtaXNzaW9uYWJsZSB8fCB7fTtcblxuICAgIGNvbnN0IGFjY2VwdFR5cGVzOiBzdHJpbmcgPSBjb250YWluZXJTdHJ1Y3R1cmVzXG4gICAgICAgIC5tYXAoKHN0cnVjdHVyZSkgPT4gc3RydWN0dXJlLmNvbnRlbnRUeXBlVmFyKVxuICAgICAgICAuam9pbignLCcpO1xuXG4gICAgY29uc3QgY29udGVudGxldHMgPSBjb250YWluZXJzW2lkZW50aWZpZXJdLmNvbnRlbnRsZXRzW2B1dWlkLSR7dXVpZH1gXTtcblxuICAgIHJldHVybiB7XG4gICAgICAgIC4uLmNvbnRhaW5lcnNbaWRlbnRpZmllcl0uY29udGFpbmVyLFxuICAgICAgICBhY2NlcHRUeXBlcyxcbiAgICAgICAgY29udGVudGxldHMsXG4gICAgICAgIHZhcmlhbnRJZFxuICAgIH07XG59O1xuXG4vKipcbiAqIFJldHVybnMgdGhlIHBvc2l0aW9uIHN0eWxlIGNsYXNzZXMgYmFzZWQgb24gdGhlIHN0YXJ0IGFuZCBlbmQgdmFsdWVzLlxuICogVXNlZCB0byBzZXQgdGhlIGdyaWQgY29sdW1uIHN0YXJ0IGFuZCBlbmQgdmFsdWVzLlxuICogQHBhcmFtIHN0YXJ0IC0gVGhlIHN0YXJ0IHZhbHVlLlxuICogQHBhcmFtIGVuZCAtIFRoZSBlbmQgdmFsdWUuXG4gKiBAcmV0dXJucyBBbiBvYmplY3QgY29udGFpbmluZyB0aGUgc3RhcnRDbGFzcyBhbmQgZW5kQ2xhc3MuXG4gKi9cbmV4cG9ydCBjb25zdCBnZXRQb3NpdGlvblN0eWxlQ2xhc3NlcyA9IChzdGFydDogbnVtYmVyLCBlbmQ6IG51bWJlcikgPT4ge1xuICAgIGNvbnN0IHN0YXJ0Q2xhc3MgPSBzdGFydENsYXNzTWFwW3N0YXJ0XTtcbiAgICBjb25zdCBlbmRDbGFzcyA9IGVuZENsYXNzTWFwW2VuZF07XG5cbiAgICByZXR1cm4ge1xuICAgICAgICBzdGFydENsYXNzLFxuICAgICAgICBlbmRDbGFzc1xuICAgIH07XG59O1xuIl19