@3ddv/software-division-components 1.0.0-alpha.3.34 → 1.0.0-alpha.3.35

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.
package/README.md CHANGED
@@ -100,7 +100,24 @@ Depending on the Encapsulation option that you are using in your component, some
100
100
  }
101
101
  ```
102
102
 
103
- Or declare the style in your root stylesheet to avoid any view encapsulation to affect your custom styles.
103
+ You also have the option with SCSS to nest:
104
+
105
+ ```css
106
+ ::ng-deep {
107
+ &.my-class-1 {
108
+ --p-button-primary-background: red;
109
+ }
110
+ &.my-class-2 {
111
+ --p-button-primary-background: green;
112
+ }
113
+
114
+ &.my-class-3 {
115
+ --p-button-primary-background: blue;
116
+ }
117
+ }
118
+ ```
119
+
120
+ Or declare the style in your root stylesheet to avoid any view encapsulation to affect your custom styles. (not recommended)
104
121
 
105
122
  #### Several styleClasses inputs
106
123
 
@@ -391,6 +408,7 @@ Any further information regarding the BEM methodology can be found through the f
391
408
  - https://css-tricks.com/bem-101/
392
409
  - https://getbem.com/introduction/
393
410
  - https://stackoverflow.com/questions/36703546/what-is-bem-methodology
411
+ - https://gauravmahlawat.github.io/online-bem-generator.html#google_vignette
394
412
 
395
413
  #### Why are we not internally using Tailwind or SCSS?
396
414
 
@@ -3,6 +3,18 @@ import { MenuItem } from 'primeng/api';
3
3
  import { Table } from 'primeng/table';
4
4
  import { ObjectColumnData } from './types';
5
5
  import * as i0 from "@angular/core";
6
+ /**
7
+ * A customizable table component built on PrimeNG's Table.
8
+ *
9
+ * This component extends the PrimeNG Table by introducing additional configurations and styling
10
+ * capabilities. It supports defining column data, enabling sorting, exporting data, and integrating
11
+ * context menu options for enhanced user interactions. Additionally, the component allows for dynamic
12
+ * styling through custom CSS classes and leverages Angular's standalone component pattern with OnPush
13
+ * change detection for performance optimization.
14
+ *
15
+ * @since 1.0.0-alpha.2
16
+ * @updated 1.0.0-alpha.2
17
+ */
6
18
  export declare class TableComponent extends Table implements OnInit {
7
19
  props: import("@angular/core").InputSignal<typeof Table | undefined>;
8
20
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"table.component.d.ts","sourceRoot":"","sources":["../../../projects/software-division-components/src/backoffice/table/table.component.ts"],"names":[],"mappings":"AACA,OAAO,EAA6C,MAAM,EAAE,MAAM,eAAe,CAAC;AAClF,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAIvC,OAAO,EAAE,KAAK,EAA6B,MAAM,eAAe,CAAC;AAKjE,OAAO,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;;AAE3C,qBAkBa,cAAe,SAAQ,KAAM,YAAW,MAAM;IAClD,KAAK,gEAAyB;IACrC;;;OAGG;IACI,YAAY,qHAA+E;IAC3F,UAAU,0DAAwC;IAClD,QAAQ,2DAAoB;IAC5B,MAAM,2DAAoB;IAC1B,iBAAiB,8CAA2B;IAC5C,kBAAkB,8DAAuB;IACzC,uBAAuB,4DAAqB;IAEnD,SAAS,CAAC,WAAW,EAAE,CAAC,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC;IAEnD,SAAS,CAAC,EAAE,CAAC,KAAK,EAAE,GAAG;yCAhBZ,cAAc;2CAAd,cAAc;CAiB1B"}
1
+ {"version":3,"file":"table.component.d.ts","sourceRoot":"","sources":["../../../projects/software-division-components/src/backoffice/table/table.component.ts"],"names":[],"mappings":"AACA,OAAO,EAA6C,MAAM,EAAE,MAAM,eAAe,CAAC;AAClF,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAIvC,OAAO,EAAE,KAAK,EAA6B,MAAM,eAAe,CAAC;AAKjE,OAAO,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;;AAE3C;;;;;;;;;;;GAWG;AACH,qBAkBa,cAAe,SAAQ,KAAM,YAAW,MAAM;IAClD,KAAK,gEAAyB;IACrC;;;OAGG;IACI,YAAY,qHAA+E;IAC3F,UAAU,0DAAwC;IAClD,QAAQ,2DAAoB;IAC5B,MAAM,2DAAoB;IAC1B,iBAAiB,8CAA2B;IAC5C,kBAAkB,8DAAuB;IACzC,uBAAuB,4DAAqB;IAEnD,SAAS,CAAC,WAAW,EAAE,CAAC,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC;IAEnD,SAAS,CAAC,EAAE,CAAC,KAAK,EAAE,GAAG;yCAhBZ,cAAc;2CAAd,cAAc;CAiB1B"}
@@ -2,10 +2,13 @@ import { OnInit } from '@angular/core';
2
2
  import { DirectionObjectKeys, NeighboursStyleClasses } from './types';
3
3
  import * as i0 from "@angular/core";
4
4
  /**
5
- * Component for navigating between neighboring sections.
5
+ * Component used to navigating between neighboring sections.
6
6
  *
7
7
  * It determines the next and previous available sections based on predefined mappings
8
8
  * and emits navigation events when users attempt to move between them.
9
+ *
10
+ * @since 1.0.0-alpha.2
11
+ * @updated 1.0.0-alpha.2
9
12
  */
10
13
  export declare class NeighboursComponent implements OnInit {
11
14
  /**
@@ -20,12 +23,7 @@ export declare class NeighboursComponent implements OnInit {
20
23
  activeColor: string;
21
24
  background: string;
22
25
  hoverBackground: string;
23
- activeBackground: string; /**
24
- * Component for navigating between neighboring sections.
25
- *
26
- * It determines the next and previous available sections based on predefined mappings
27
- * and emits navigation events when users attempt to move between them.
28
- */
26
+ activeBackground: string;
29
27
  activeBorderColor: string;
30
28
  hoverBorderColor: string;
31
29
  };
@@ -77,11 +75,11 @@ export declare class NeighboursComponent implements OnInit {
77
75
  /**
78
76
  * The ID of the previous available section.
79
77
  */
80
- private previousAvailableSectionId;
78
+ protected previousAvailableSectionId: import("@angular/core").WritableSignal<string | null>;
81
79
  /**
82
80
  * The ID of the next available section.
83
81
  */
84
- private nextAvailableSectionId;
82
+ protected nextAvailableSectionId: import("@angular/core").WritableSignal<string | null>;
85
83
  /**
86
84
  * Constant representing the absence of a neighboring section.
87
85
  */
@@ -96,7 +94,7 @@ export declare class NeighboursComponent implements OnInit {
96
94
  private keyMapping;
97
95
  ngOnInit(): void;
98
96
  /**
99
- * Handles navigation button clicks.
97
+ * Handles navigation button clicks. Emits the new section identificator to navigate to.
100
98
  * @param goTo - The direction to navigate.
101
99
  * @throws If there is no valid section to navigate to.
102
100
  */
@@ -1 +1 @@
1
- {"version":3,"file":"neighbours.component.d.ts","sourceRoot":"","sources":["../../../projects/software-division-components/src/dvm/neighbours/neighbours.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAA6C,MAAM,EAAU,MAAM,eAAe,CAAC;AAI1F,OAAO,EAAa,mBAAmB,EAAE,sBAAsB,EAAE,MAAM,SAAS,CAAC;;AACjF;;;;;GAKG;AACH,qBAQa,mBAAoB,YAAW,MAAM;IAChD;;OAEG;IACH,SAAS,CAAC,QAAQ,CAAC,eAAe;;;;;;;;;0CAlBpC;;;;;mBAKG;;;;;MAaqD;IAEtD;;OAEG;IACI,cAAc,8CAA4B;IAEjD;;OAEG;IACI,gBAAgB,8DAA8C;IAErE;;OAEG;IACI,gBAAgB,8DAA8C;IAErE;;OAEG;IACI,aAAa,2FAA2E;IAE/F;;OAEG;IACI,QAAQ,8CAAqB;IAEpC;;OAEG;IACI,YAAY,8CAAqB;IAExC;;;;OAIG;IACI,uBAAuB,2DAAoB;IAElD;;;OAGG;IACI,oBAAoB,2DAAkC;IAE7D;;OAEG;IACI,YAAY,mGAKjB;IAEF;;OAEG;IACI,iBAAiB,mDAAoB;IAE5C;;OAEG;IACH,OAAO,CAAC,0BAA0B,CAAuB;IAEzD;;OAEG;IACH,OAAO,CAAC,sBAAsB,CAAuB;IAErD;;OAEG;IACH,OAAO,CAAC,kBAAkB,CAAmB;IAE7C;;OAEG;IACH,OAAO,CAAC,cAAc,CAG6B;IAEnD;;OAEG;IACH,OAAO,CAAC,UAAU,CAGP;IAEX,QAAQ;IAKR;;;;OAIG;IACI,OAAO,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM;IAUpC;;;;OAIG;IACH,OAAO,CAAC,qBAAqB;IAQ7B;;;;;OAKG;IACH,OAAO,CAAC,mBAAmB;yCAtIhB,mBAAmB;2CAAnB,mBAAmB;CAiL/B"}
1
+ {"version":3,"file":"neighbours.component.d.ts","sourceRoot":"","sources":["../../../projects/software-division-components/src/dvm/neighbours/neighbours.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAA6C,MAAM,EAAkB,MAAM,eAAe,CAAC;AAIlG,OAAO,EAAa,mBAAmB,EAAE,sBAAsB,EAAE,MAAM,SAAS,CAAC;;AACjF;;;;;;;;GAQG;AACH,qBAQa,mBAAoB,YAAW,MAAM;IAChD;;OAEG;IACH,SAAS,CAAC,QAAQ,CAAC,eAAe;;;;;;;;;;;;;;MAAoB;IAEtD;;OAEG;IACI,cAAc,8CAA4B;IAEjD;;OAEG;IACI,gBAAgB,8DAA8C;IAErE;;OAEG;IACI,gBAAgB,8DAA8C;IAErE;;OAEG;IACI,aAAa,2FAA2E;IAE/F;;OAEG;IACI,QAAQ,8CAAqB;IAEpC;;OAEG;IACI,YAAY,8CAAqB;IAExC;;;;OAIG;IACI,uBAAuB,2DAAoB;IAElD;;;OAGG;IACI,oBAAoB,2DAAkC;IAE7D;;OAEG;IACI,YAAY,mGAKjB;IAEF;;OAEG;IACI,iBAAiB,mDAAoB;IAE5C;;OAEG;IACH,SAAS,CAAC,0BAA0B,wDAA+B;IAEnE;;OAEG;IACH,SAAS,CAAC,sBAAsB,wDAA+B;IAE/D;;OAEG;IACH,OAAO,CAAC,kBAAkB,CAAmB;IAE7C;;OAEG;IACH,OAAO,CAAC,cAAc,CAG6B;IAEnD;;OAEG;IACH,OAAO,CAAC,UAAU,CAGP;IAEX,QAAQ;IAKR;;;;OAIG;IACI,OAAO,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM;IAUpC;;;;OAIG;IACH,OAAO,CAAC,qBAAqB;IAQ7B;;;;;OAKG;IACH,OAAO,CAAC,mBAAmB;yCAtIhB,mBAAmB;2CAAnB,mBAAmB;CAiL/B"}
@@ -1,2 +1,3 @@
1
1
  export { NeighboursComponent } from './neighbours.component';
2
+ export type { Direction, DirectionObjectKeys, NeighboursData } from './types';
2
3
  //# sourceMappingURL=public-api.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"public-api.d.ts","sourceRoot":"","sources":["../../../projects/software-division-components/src/dvm/neighbours/public-api.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC"}
1
+ {"version":3,"file":"public-api.d.ts","sourceRoot":"","sources":["../../../projects/software-division-components/src/dvm/neighbours/public-api.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAC7D,YAAY,EAAE,SAAS,EAAE,mBAAmB,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"side-button.tokens.d.ts","sourceRoot":"","sources":["../../../../projects/software-division-components/src/dvm/neighbours/styles/side-button.tokens.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,gBAAgB;;;;;;;;;;;;;;CAiBC,CAAC"}
1
+ {"version":3,"file":"side-button.tokens.d.ts","sourceRoot":"","sources":["../../../../projects/software-division-components/src/dvm/neighbours/styles/side-button.tokens.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,gBAAgB;;;;;;;;;;;;;;CAiBC,CAAC"}
@@ -1,5 +1,6 @@
1
1
  export type Direction = 'prev' | 'next';
2
2
  export type DirectionObjectKeys = 'l' | 'r';
3
+ export type NeighboursData = Record<string, Record<DirectionObjectKeys, string>>;
3
4
  export type NeighboursStyleClasses = {
4
5
  sideButtonsClass?: string;
5
6
  middleDivClass?: string;
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../projects/software-division-components/src/dvm/neighbours/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,SAAS,GAAG,MAAM,GAAG,MAAM,CAAC;AAExC,MAAM,MAAM,mBAAmB,GAAG,GAAG,GAAG,GAAG,CAAC;AAE5C,MAAM,MAAM,sBAAsB,GAAG;IACnC,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,cAAc,CAAC,EAAE,MAAM,CAAC;CACzB,CAAC"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../projects/software-division-components/src/dvm/neighbours/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,SAAS,GAAG,MAAM,GAAG,MAAM,CAAC;AAExC,MAAM,MAAM,mBAAmB,GAAG,GAAG,GAAG,GAAG,CAAC;AAE5C,MAAM,MAAM,cAAc,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,mBAAmB,EAAE,MAAM,CAAC,CAAC,CAAC;AAEjF,MAAM,MAAM,sBAAsB,GAAG;IACnC,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,cAAc,CAAC,EAAE,MAAM,CAAC;CACzB,CAAC"}
@@ -12,6 +12,18 @@ import * as i0 from "@angular/core";
12
12
  import * as i1 from "primeng/table";
13
13
  import * as i2 from "primeng/api";
14
14
  import * as i3 from "primeng/contextmenu";
15
+ /**
16
+ * A customizable table component built on PrimeNG's Table.
17
+ *
18
+ * This component extends the PrimeNG Table by introducing additional configurations and styling
19
+ * capabilities. It supports defining column data, enabling sorting, exporting data, and integrating
20
+ * context menu options for enhanced user interactions. Additionally, the component allows for dynamic
21
+ * styling through custom CSS classes and leverages Angular's standalone component pattern with OnPush
22
+ * change detection for performance optimization.
23
+ *
24
+ * @since 1.0.0-alpha.2
25
+ * @updated 1.0.0-alpha.2
26
+ */
15
27
  export class TableComponent extends Table {
16
28
  props = input();
17
29
  /**
@@ -28,7 +40,7 @@ export class TableComponent extends Table {
28
40
  selectedRow;
29
41
  cb(event) { }
30
42
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TableComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
31
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: TableComponent, isStandalone: true, selector: "sdc-table", inputs: { props: { classPropertyName: "props", publicName: "props", isSignal: true, isRequired: false, transformFunction: null }, styleClasses: { classPropertyName: "styleClasses", publicName: "styleClasses", isSignal: true, isRequired: false, transformFunction: null }, columnData: { classPropertyName: "columnData", publicName: "columnData", isSignal: true, isRequired: true, transformFunction: null }, sortable: { classPropertyName: "sortable", publicName: "sortable", isSignal: true, isRequired: false, transformFunction: null }, export: { classPropertyName: "export", publicName: "export", isSignal: true, isRequired: false, transformFunction: null }, exportButtonLabel: { classPropertyName: "exportButtonLabel", publicName: "exportButtonLabel", isSignal: true, isRequired: false, transformFunction: null }, contextMenuOptions: { classPropertyName: "contextMenuOptions", publicName: "contextMenuOptions", isSignal: true, isRequired: false, transformFunction: null }, projectedElementIdArray: { classPropertyName: "projectedElementIdArray", publicName: "projectedElementIdArray", isSignal: true, isRequired: false, transformFunction: null } }, providers: [TableService], usesInheritance: true, ngImport: i0, template: "<div>\n <p-contextMenu #contextMenu [model]=\"contextMenuOptions() ?? undefined\"></p-contextMenu>\n\n <p-table\n #dt\n [tableStyleClass]=\"styleClasses()\"\n [value]=\"value\"\n [style]=\"style\"\n [dataKey]=\"dataKey\"\n [rows]=\"rows\"\n [columns]=\"columnData()\"\n [stripedRows]=\"stripedRows\"\n [showGridlines]=\"showGridlines\"\n [paginator]=\"paginator\"\n [paginator]=\"paginatorPosition\"\n [rows]=\"rowsPerPageOptions\"\n [contextMenu]=\"contextMenuOptions() ? contextMenu : undefined\">\n <ng-template #header>\n <tr\n app-header-row\n [columns]=\"columnData()\"\n [reorderableColumns]=\"!!reorderableColumns\"\n [resizableColumns]=\"!!resizableColumns\"></tr>\n </ng-template>\n\n <ng-template #body let-rows let-index=\"rowIndex\">\n <tr app-body-row [pContextMenuRow]=\"rows\" [columns]=\"columnData()\" [rows]=\"rows\"></tr>\n </ng-template>\n\n @if (export() || projectedElementIdArray()?.length) {\n <ng-template pTemplate=\"caption\">\n @if (export()) {\n <div class=\"button__export--end\">\n <!-- <sdc-button icon=\"pi pi-external-link\" [label]=\"exportButtonLabel()\" (click)=\"dt.exportCSV()\" /> -->\n </div>\n }\n <ng-content [select]=\"'button1'\" />\n\n <ng-content [select]=\"'button2'\" />\n\n <!-- @for (projectedElementId of projectedElementId(); track projectedElementId) {\n <ng-content [select]=\"projectedElementId\" />\n } -->\n </ng-template>\n }\n </p-table>\n</div>\n", styles: [":root{--p-paginator-border-radius: 0px !important}.button__export--end{display:flex;justify-content:flex-end;align-items:center;padding:.5rem}sdc-table .table-test-class{--p-datatable-header-cell-color: red}.mock-side-button{--p-button-primary-color: white;--p-button-primary-background: black;--p-button-primary-border-color: black;--p-button-primary-hover-background: black;--p-button-primary-hover-color: white}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: TableModule }, { kind: "component", type: i1.Table, selector: "p-table", inputs: ["frozenColumns", "frozenValue", "style", "styleClass", "tableStyle", "tableStyleClass", "paginator", "pageLinks", "rowsPerPageOptions", "alwaysShowPaginator", "paginatorPosition", "paginatorStyleClass", "paginatorDropdownAppendTo", "paginatorDropdownScrollHeight", "currentPageReportTemplate", "showCurrentPageReport", "showJumpToPageDropdown", "showJumpToPageInput", "showFirstLastIcon", "showPageLinks", "defaultSortOrder", "sortMode", "resetPageOnSort", "selectionMode", "selectionPageOnly", "contextMenuSelection", "contextMenuSelectionMode", "dataKey", "metaKeySelection", "rowSelectable", "rowTrackBy", "lazy", "lazyLoadOnInit", "compareSelectionBy", "csvSeparator", "exportFilename", "filters", "globalFilterFields", "filterDelay", "filterLocale", "expandedRowKeys", "editingRowKeys", "rowExpandMode", "scrollable", "scrollDirection", "rowGroupMode", "scrollHeight", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "virtualScrollDelay", "frozenWidth", "responsive", "contextMenu", "resizableColumns", "columnResizeMode", "reorderableColumns", "loading", "loadingIcon", "showLoader", "rowHover", "customSort", "showInitialSortBadge", "autoLayout", "exportFunction", "exportHeader", "stateKey", "stateStorage", "editMode", "groupRowsBy", "size", "showGridlines", "stripedRows", "groupRowsByOrder", "responsiveLayout", "breakpoint", "paginatorLocale", "value", "columns", "first", "rows", "totalRecords", "sortField", "sortOrder", "multiSortMeta", "selection", "virtualRowHeight", "selectAll"], outputs: ["contextMenuSelectionChange", "selectAllChange", "selectionChange", "onRowSelect", "onRowUnselect", "onPage", "onSort", "onFilter", "onLazyLoad", "onRowExpand", "onRowCollapse", "onContextMenuSelect", "onColResize", "onColReorder", "onRowReorder", "onEditInit", "onEditComplete", "onEditCancel", "onHeaderCheckboxToggle", "sortFunction", "firstChange", "rowsChange", "onStateSave", "onStateRestore"] }, { kind: "directive", type: i2.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "directive", type: i1.ContextMenuRow, selector: "[pContextMenuRow]", inputs: ["pContextMenuRow", "pContextMenuRowIndex", "pContextMenuRowDisabled"] }, { kind: "ngmodule", type: ContextMenuModule }, { kind: "component", type: i3.ContextMenu, selector: "p-contextMenu, p-contextmenu, p-context-menu", inputs: ["model", "triggerEvent", "target", "global", "style", "styleClass", "appendTo", "autoZIndex", "baseZIndex", "id", "breakpoint", "ariaLabel", "ariaLabelledBy", "pressDelay"], outputs: ["onShow", "onHide"] }, { kind: "ngmodule", type: ButtonModule }, { kind: "ngmodule", type: PaginatorModule }, { kind: "component", type: HeaderRowComponent, selector: "[app-header-row]", inputs: ["columns", "reorderableColumns", "resizableColumns"] }, { kind: "component", type: BodyRowComponent, selector: "[app-body-row]", inputs: ["rows", "columns"] }, { kind: "directive", type: TableDirective, selector: "p-table" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
43
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: TableComponent, isStandalone: true, selector: "sdc-table", inputs: { props: { classPropertyName: "props", publicName: "props", isSignal: true, isRequired: false, transformFunction: null }, styleClasses: { classPropertyName: "styleClasses", publicName: "styleClasses", isSignal: true, isRequired: false, transformFunction: null }, columnData: { classPropertyName: "columnData", publicName: "columnData", isSignal: true, isRequired: true, transformFunction: null }, sortable: { classPropertyName: "sortable", publicName: "sortable", isSignal: true, isRequired: false, transformFunction: null }, export: { classPropertyName: "export", publicName: "export", isSignal: true, isRequired: false, transformFunction: null }, exportButtonLabel: { classPropertyName: "exportButtonLabel", publicName: "exportButtonLabel", isSignal: true, isRequired: false, transformFunction: null }, contextMenuOptions: { classPropertyName: "contextMenuOptions", publicName: "contextMenuOptions", isSignal: true, isRequired: false, transformFunction: null }, projectedElementIdArray: { classPropertyName: "projectedElementIdArray", publicName: "projectedElementIdArray", isSignal: true, isRequired: false, transformFunction: null } }, providers: [TableService], usesInheritance: true, ngImport: i0, template: "<div>\n <p-contextMenu #contextMenu [model]=\"contextMenuOptions() ?? undefined\"></p-contextMenu>\n\n <p-table\n #dt\n [tableStyleClass]=\"styleClasses()\"\n [value]=\"value\"\n [style]=\"style\"\n [dataKey]=\"dataKey\"\n [rows]=\"rows\"\n [columns]=\"columnData()\"\n [stripedRows]=\"stripedRows\"\n [showGridlines]=\"showGridlines\"\n [paginator]=\"paginator\"\n [paginator]=\"paginatorPosition\"\n [rows]=\"rowsPerPageOptions\"\n [contextMenu]=\"contextMenuOptions() ? contextMenu : undefined\">\n <ng-template #header>\n <tr\n app-header-row\n [columns]=\"columnData()\"\n [reorderableColumns]=\"!!reorderableColumns\"\n [resizableColumns]=\"!!resizableColumns\"></tr>\n </ng-template>\n\n <ng-template #body let-rows let-index=\"rowIndex\">\n <tr app-body-row [pContextMenuRow]=\"rows\" [columns]=\"columnData()\" [rows]=\"rows\"></tr>\n </ng-template>\n\n @if (export() || projectedElementIdArray()?.length) {\n <ng-template pTemplate=\"caption\">\n @if (export()) {\n <div class=\"button__export--end\">\n <!-- <sdc-button icon=\"pi pi-external-link\" [label]=\"exportButtonLabel()\" (click)=\"dt.exportCSV()\" /> -->\n </div>\n }\n <ng-content [select]=\"'button1'\" />\n\n <ng-content [select]=\"'button2'\" />\n\n <!-- @for (projectedElementId of projectedElementId(); track projectedElementId) {\n <ng-content [select]=\"projectedElementId\" />\n } -->\n </ng-template>\n }\n </p-table>\n</div>\n", styles: [":root{--p-paginator-border-radius: 0px !important}.table-footer__button--align{display:flex;justify-content:flex-end;align-items:center;padding:.5rem}sdc-table .table-test-class{--p-datatable-header-cell-color: red}.mock-side-button{--p-button-primary-color: white;--p-button-primary-background: black;--p-button-primary-border-color: black;--p-button-primary-hover-background: black;--p-button-primary-hover-color: white}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: TableModule }, { kind: "component", type: i1.Table, selector: "p-table", inputs: ["frozenColumns", "frozenValue", "style", "styleClass", "tableStyle", "tableStyleClass", "paginator", "pageLinks", "rowsPerPageOptions", "alwaysShowPaginator", "paginatorPosition", "paginatorStyleClass", "paginatorDropdownAppendTo", "paginatorDropdownScrollHeight", "currentPageReportTemplate", "showCurrentPageReport", "showJumpToPageDropdown", "showJumpToPageInput", "showFirstLastIcon", "showPageLinks", "defaultSortOrder", "sortMode", "resetPageOnSort", "selectionMode", "selectionPageOnly", "contextMenuSelection", "contextMenuSelectionMode", "dataKey", "metaKeySelection", "rowSelectable", "rowTrackBy", "lazy", "lazyLoadOnInit", "compareSelectionBy", "csvSeparator", "exportFilename", "filters", "globalFilterFields", "filterDelay", "filterLocale", "expandedRowKeys", "editingRowKeys", "rowExpandMode", "scrollable", "scrollDirection", "rowGroupMode", "scrollHeight", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "virtualScrollDelay", "frozenWidth", "responsive", "contextMenu", "resizableColumns", "columnResizeMode", "reorderableColumns", "loading", "loadingIcon", "showLoader", "rowHover", "customSort", "showInitialSortBadge", "autoLayout", "exportFunction", "exportHeader", "stateKey", "stateStorage", "editMode", "groupRowsBy", "size", "showGridlines", "stripedRows", "groupRowsByOrder", "responsiveLayout", "breakpoint", "paginatorLocale", "value", "columns", "first", "rows", "totalRecords", "sortField", "sortOrder", "multiSortMeta", "selection", "virtualRowHeight", "selectAll"], outputs: ["contextMenuSelectionChange", "selectAllChange", "selectionChange", "onRowSelect", "onRowUnselect", "onPage", "onSort", "onFilter", "onLazyLoad", "onRowExpand", "onRowCollapse", "onContextMenuSelect", "onColResize", "onColReorder", "onRowReorder", "onEditInit", "onEditComplete", "onEditCancel", "onHeaderCheckboxToggle", "sortFunction", "firstChange", "rowsChange", "onStateSave", "onStateRestore"] }, { kind: "directive", type: i2.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "directive", type: i1.ContextMenuRow, selector: "[pContextMenuRow]", inputs: ["pContextMenuRow", "pContextMenuRowIndex", "pContextMenuRowDisabled"] }, { kind: "ngmodule", type: ContextMenuModule }, { kind: "component", type: i3.ContextMenu, selector: "p-contextMenu, p-contextmenu, p-context-menu", inputs: ["model", "triggerEvent", "target", "global", "style", "styleClass", "appendTo", "autoZIndex", "baseZIndex", "id", "breakpoint", "ariaLabel", "ariaLabelledBy", "pressDelay"], outputs: ["onShow", "onHide"] }, { kind: "ngmodule", type: ButtonModule }, { kind: "ngmodule", type: PaginatorModule }, { kind: "component", type: HeaderRowComponent, selector: "[app-header-row]", inputs: ["columns", "reorderableColumns", "resizableColumns"] }, { kind: "component", type: BodyRowComponent, selector: "[app-body-row]", inputs: ["rows", "columns"] }, { kind: "directive", type: TableDirective, selector: "p-table" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
32
44
  }
33
45
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TableComponent, decorators: [{
34
46
  type: Component,
@@ -41,6 +53,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
41
53
  HeaderRowComponent,
42
54
  BodyRowComponent,
43
55
  TableDirective,
44
- ], providers: [TableService], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div>\n <p-contextMenu #contextMenu [model]=\"contextMenuOptions() ?? undefined\"></p-contextMenu>\n\n <p-table\n #dt\n [tableStyleClass]=\"styleClasses()\"\n [value]=\"value\"\n [style]=\"style\"\n [dataKey]=\"dataKey\"\n [rows]=\"rows\"\n [columns]=\"columnData()\"\n [stripedRows]=\"stripedRows\"\n [showGridlines]=\"showGridlines\"\n [paginator]=\"paginator\"\n [paginator]=\"paginatorPosition\"\n [rows]=\"rowsPerPageOptions\"\n [contextMenu]=\"contextMenuOptions() ? contextMenu : undefined\">\n <ng-template #header>\n <tr\n app-header-row\n [columns]=\"columnData()\"\n [reorderableColumns]=\"!!reorderableColumns\"\n [resizableColumns]=\"!!resizableColumns\"></tr>\n </ng-template>\n\n <ng-template #body let-rows let-index=\"rowIndex\">\n <tr app-body-row [pContextMenuRow]=\"rows\" [columns]=\"columnData()\" [rows]=\"rows\"></tr>\n </ng-template>\n\n @if (export() || projectedElementIdArray()?.length) {\n <ng-template pTemplate=\"caption\">\n @if (export()) {\n <div class=\"button__export--end\">\n <!-- <sdc-button icon=\"pi pi-external-link\" [label]=\"exportButtonLabel()\" (click)=\"dt.exportCSV()\" /> -->\n </div>\n }\n <ng-content [select]=\"'button1'\" />\n\n <ng-content [select]=\"'button2'\" />\n\n <!-- @for (projectedElementId of projectedElementId(); track projectedElementId) {\n <ng-content [select]=\"projectedElementId\" />\n } -->\n </ng-template>\n }\n </p-table>\n</div>\n", styles: [":root{--p-paginator-border-radius: 0px !important}.button__export--end{display:flex;justify-content:flex-end;align-items:center;padding:.5rem}sdc-table .table-test-class{--p-datatable-header-cell-color: red}.mock-side-button{--p-button-primary-color: white;--p-button-primary-background: black;--p-button-primary-border-color: black;--p-button-primary-hover-background: black;--p-button-primary-hover-color: white}\n"] }]
56
+ ], providers: [TableService], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div>\n <p-contextMenu #contextMenu [model]=\"contextMenuOptions() ?? undefined\"></p-contextMenu>\n\n <p-table\n #dt\n [tableStyleClass]=\"styleClasses()\"\n [value]=\"value\"\n [style]=\"style\"\n [dataKey]=\"dataKey\"\n [rows]=\"rows\"\n [columns]=\"columnData()\"\n [stripedRows]=\"stripedRows\"\n [showGridlines]=\"showGridlines\"\n [paginator]=\"paginator\"\n [paginator]=\"paginatorPosition\"\n [rows]=\"rowsPerPageOptions\"\n [contextMenu]=\"contextMenuOptions() ? contextMenu : undefined\">\n <ng-template #header>\n <tr\n app-header-row\n [columns]=\"columnData()\"\n [reorderableColumns]=\"!!reorderableColumns\"\n [resizableColumns]=\"!!resizableColumns\"></tr>\n </ng-template>\n\n <ng-template #body let-rows let-index=\"rowIndex\">\n <tr app-body-row [pContextMenuRow]=\"rows\" [columns]=\"columnData()\" [rows]=\"rows\"></tr>\n </ng-template>\n\n @if (export() || projectedElementIdArray()?.length) {\n <ng-template pTemplate=\"caption\">\n @if (export()) {\n <div class=\"button__export--end\">\n <!-- <sdc-button icon=\"pi pi-external-link\" [label]=\"exportButtonLabel()\" (click)=\"dt.exportCSV()\" /> -->\n </div>\n }\n <ng-content [select]=\"'button1'\" />\n\n <ng-content [select]=\"'button2'\" />\n\n <!-- @for (projectedElementId of projectedElementId(); track projectedElementId) {\n <ng-content [select]=\"projectedElementId\" />\n } -->\n </ng-template>\n }\n </p-table>\n</div>\n", styles: [":root{--p-paginator-border-radius: 0px !important}.table-footer__button--align{display:flex;justify-content:flex-end;align-items:center;padding:.5rem}sdc-table .table-test-class{--p-datatable-header-cell-color: red}.mock-side-button{--p-button-primary-color: white;--p-button-primary-background: black;--p-button-primary-border-color: black;--p-button-primary-hover-background: black;--p-button-primary-hover-color: white}\n"] }]
45
57
  }] });
46
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvc29mdHdhcmUtZGl2aXNpb24tY29tcG9uZW50cy9zcmMvYmFja29mZmljZS90YWJsZS90YWJsZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi9wcm9qZWN0cy9zb2Z0d2FyZS1kaXZpc2lvbi1jb21wb25lbnRzL3NyYy9iYWNrb2ZmaWNlL3RhYmxlL3RhYmxlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUVsRixPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDOUMsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDeEQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ3BELE9BQU8sRUFBRSxLQUFLLEVBQUUsV0FBVyxFQUFFLFlBQVksRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNqRSxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUNwRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSwwQ0FBMEMsQ0FBQztBQUM1RSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw4Q0FBOEMsQ0FBQztBQUNsRixPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sOEJBQThCLENBQUM7Ozs7O0FBcUI5RCxNQUFNLE9BQU8sY0FBZSxTQUFRLEtBQUs7SUFDaEMsS0FBSyxHQUFHLEtBQUssRUFBZ0IsQ0FBQztJQUNyQzs7O09BR0c7SUFDSSxZQUFZLEdBQUcsS0FBSyxDQUFDLEVBQUUsRUFBRSxFQUFFLFNBQVMsRUFBRSwwQkFBMEIsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUMzRixVQUFVLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBc0IsQ0FBQztJQUNsRCxRQUFRLEdBQUcsS0FBSyxFQUFXLENBQUM7SUFDNUIsTUFBTSxHQUFHLEtBQUssRUFBVyxDQUFDO0lBQzFCLGlCQUFpQixHQUFHLEtBQUssQ0FBUyxRQUFRLENBQUMsQ0FBQztJQUM1QyxrQkFBa0IsR0FBRyxLQUFLLEVBQWMsQ0FBQztJQUN6Qyx1QkFBdUIsR0FBRyxLQUFLLEVBQVksQ0FBQztJQUV6QyxXQUFXLENBQThCO0lBRXpDLEVBQUUsQ0FBQyxLQUFVLElBQUcsQ0FBQzt3R0FoQmhCLGNBQWM7NEZBQWQsY0FBYyxvckNBSGQsQ0FBQyxZQUFZLENBQUMsaURDNUIzQiw0akRBK0NBLHlkRDVCSSxZQUFZLDhCQUNaLFdBQVcsaXZFQUNYLGlCQUFpQiwyVkFDakIsWUFBWSw4QkFDWixlQUFlLCtCQUNmLGtCQUFrQiw0SEFDbEIsZ0JBQWdCLHdGQUNoQixjQUFjOzs0RkFLTCxjQUFjO2tCQWxCMUIsU0FBUztpQ0FDSSxJQUFJLFlBQ04sV0FBVyxXQUdaO3dCQUNQLFlBQVk7d0JBQ1osV0FBVzt3QkFDWCxpQkFBaUI7d0JBQ2pCLFlBQVk7d0JBQ1osZUFBZTt3QkFDZixrQkFBa0I7d0JBQ2xCLGdCQUFnQjt3QkFDaEIsY0FBYztxQkFDZixhQUNVLENBQUMsWUFBWSxDQUFDLG1CQUNSLHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgaW5wdXQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTWVudUl0ZW0gfSBmcm9tICdwcmltZW5nL2FwaSc7XG5pbXBvcnQgeyBCdXR0b25Nb2R1bGUgfSBmcm9tICdwcmltZW5nL2J1dHRvbic7XG5pbXBvcnQgeyBDb250ZXh0TWVudU1vZHVsZSB9IGZyb20gJ3ByaW1lbmcvY29udGV4dG1lbnUnO1xuaW1wb3J0IHsgUGFnaW5hdG9yTW9kdWxlIH0gZnJvbSAncHJpbWVuZy9wYWdpbmF0b3InO1xuaW1wb3J0IHsgVGFibGUsIFRhYmxlTW9kdWxlLCBUYWJsZVNlcnZpY2UgfSBmcm9tICdwcmltZW5nL3RhYmxlJztcbmltcG9ydCB7IHZhbGlkYXRlU3R5bGVzRm9yQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vdXRpbHMvcHVibGljLWFwaSc7XG5pbXBvcnQgeyBCb2R5Um93Q29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2JvZHktcm93L2JvZHktcm93LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBIZWFkZXJSb3dDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvaGVhZGVyLXJvdy9oZWFkZXItcm93LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBUYWJsZURpcmVjdGl2ZSB9IGZyb20gJy4vZGlyZWN0aXZlcy90YWJsZS5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgT2JqZWN0Q29sdW1uRGF0YSB9IGZyb20gJy4vdHlwZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgc2VsZWN0b3I6ICdzZGMtdGFibGUnLFxuICB0ZW1wbGF0ZVVybDogJy4vdGFibGUuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybDogJy4vdGFibGUuY29tcG9uZW50LmNzcycsXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgVGFibGVNb2R1bGUsXG4gICAgQ29udGV4dE1lbnVNb2R1bGUsXG4gICAgQnV0dG9uTW9kdWxlLFxuICAgIFBhZ2luYXRvck1vZHVsZSxcbiAgICBIZWFkZXJSb3dDb21wb25lbnQsXG4gICAgQm9keVJvd0NvbXBvbmVudCxcbiAgICBUYWJsZURpcmVjdGl2ZSxcbiAgXSxcbiAgcHJvdmlkZXJzOiBbVGFibGVTZXJ2aWNlXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIFRhYmxlQ29tcG9uZW50IGV4dGVuZHMgVGFibGUgaW1wbGVtZW50cyBPbkluaXQge1xuICBwdWJsaWMgcHJvcHMgPSBpbnB1dDx0eXBlb2YgVGFibGU+KCk7XG4gIC8qKlxuICAgKiBTaW5nbGUgc3RyaW5nIG9yIHdoaXRlc3BhY2Utc2VwYXJhdGVkIHN0cmluZyBvZiBhZGRpdGlvbmFsIHN0eWxlIGNsYXNzZXMgZm9yIHRoZSBidXR0b24uXG4gICAqIE9ubHkgYWNjZXB0cyB2YWxpZCB3aGl0ZXNwYWNlLXNlcGFyYXRlZCBjbGFzcyBuYW1lcy5cbiAgICovXG4gIHB1YmxpYyBzdHlsZUNsYXNzZXMgPSBpbnB1dCgnJywgeyB0cmFuc2Zvcm06IHZhbGlkYXRlU3R5bGVzRm9yQ29tcG9uZW50KHRoaXMuY29uc3RydWN0b3IubmFtZSkgfSk7XG4gIHB1YmxpYyBjb2x1bW5EYXRhID0gaW5wdXQucmVxdWlyZWQ8T2JqZWN0Q29sdW1uRGF0YVtdPigpO1xuICBwdWJsaWMgc29ydGFibGUgPSBpbnB1dDxib29sZWFuPigpO1xuICBwdWJsaWMgZXhwb3J0ID0gaW5wdXQ8Ym9vbGVhbj4oKTtcbiAgcHVibGljIGV4cG9ydEJ1dHRvbkxhYmVsID0gaW5wdXQ8c3RyaW5nPignRXhwb3J0Jyk7XG4gIHB1YmxpYyBjb250ZXh0TWVudU9wdGlvbnMgPSBpbnB1dDxNZW51SXRlbVtdPigpO1xuICBwdWJsaWMgcHJvamVjdGVkRWxlbWVudElkQXJyYXkgPSBpbnB1dDxzdHJpbmdbXT4oKTtcblxuICBwcm90ZWN0ZWQgc2VsZWN0ZWRSb3c6ICh0eXBlb2YgdGhpcy52YWx1ZSlbbnVtYmVyXTtcblxuICBwcm90ZWN0ZWQgY2IoZXZlbnQ6IGFueSkge31cbn1cbiIsIjxkaXY+XG4gIDxwLWNvbnRleHRNZW51ICNjb250ZXh0TWVudSBbbW9kZWxdPVwiY29udGV4dE1lbnVPcHRpb25zKCkgPz8gdW5kZWZpbmVkXCI+PC9wLWNvbnRleHRNZW51PlxuXG4gIDxwLXRhYmxlXG4gICAgI2R0XG4gICAgW3RhYmxlU3R5bGVDbGFzc109XCJzdHlsZUNsYXNzZXMoKVwiXG4gICAgW3ZhbHVlXT1cInZhbHVlXCJcbiAgICBbc3R5bGVdPVwic3R5bGVcIlxuICAgIFtkYXRhS2V5XT1cImRhdGFLZXlcIlxuICAgIFtyb3dzXT1cInJvd3NcIlxuICAgIFtjb2x1bW5zXT1cImNvbHVtbkRhdGEoKVwiXG4gICAgW3N0cmlwZWRSb3dzXT1cInN0cmlwZWRSb3dzXCJcbiAgICBbc2hvd0dyaWRsaW5lc109XCJzaG93R3JpZGxpbmVzXCJcbiAgICBbcGFnaW5hdG9yXT1cInBhZ2luYXRvclwiXG4gICAgW3BhZ2luYXRvcl09XCJwYWdpbmF0b3JQb3NpdGlvblwiXG4gICAgW3Jvd3NdPVwicm93c1BlclBhZ2VPcHRpb25zXCJcbiAgICBbY29udGV4dE1lbnVdPVwiY29udGV4dE1lbnVPcHRpb25zKCkgPyBjb250ZXh0TWVudSA6IHVuZGVmaW5lZFwiPlxuICAgIDxuZy10ZW1wbGF0ZSAjaGVhZGVyPlxuICAgICAgPHRyXG4gICAgICAgIGFwcC1oZWFkZXItcm93XG4gICAgICAgIFtjb2x1bW5zXT1cImNvbHVtbkRhdGEoKVwiXG4gICAgICAgIFtyZW9yZGVyYWJsZUNvbHVtbnNdPVwiISFyZW9yZGVyYWJsZUNvbHVtbnNcIlxuICAgICAgICBbcmVzaXphYmxlQ29sdW1uc109XCIhIXJlc2l6YWJsZUNvbHVtbnNcIj48L3RyPlxuICAgIDwvbmctdGVtcGxhdGU+XG5cbiAgICA8bmctdGVtcGxhdGUgI2JvZHkgbGV0LXJvd3MgbGV0LWluZGV4PVwicm93SW5kZXhcIj5cbiAgICAgIDx0ciBhcHAtYm9keS1yb3cgW3BDb250ZXh0TWVudVJvd109XCJyb3dzXCIgW2NvbHVtbnNdPVwiY29sdW1uRGF0YSgpXCIgW3Jvd3NdPVwicm93c1wiPjwvdHI+XG4gICAgPC9uZy10ZW1wbGF0ZT5cblxuICAgIEBpZiAoZXhwb3J0KCkgfHwgcHJvamVjdGVkRWxlbWVudElkQXJyYXkoKT8ubGVuZ3RoKSB7XG4gICAgICA8bmctdGVtcGxhdGUgcFRlbXBsYXRlPVwiY2FwdGlvblwiPlxuICAgICAgICBAaWYgKGV4cG9ydCgpKSB7XG4gICAgICAgICAgPGRpdiBjbGFzcz1cImJ1dHRvbl9fZXhwb3J0LS1lbmRcIj5cbiAgICAgICAgICAgIDwhLS0gPHNkYy1idXR0b24gaWNvbj1cInBpIHBpLWV4dGVybmFsLWxpbmtcIiBbbGFiZWxdPVwiZXhwb3J0QnV0dG9uTGFiZWwoKVwiIChjbGljayk9XCJkdC5leHBvcnRDU1YoKVwiIC8+IC0tPlxuICAgICAgICAgIDwvZGl2PlxuICAgICAgICB9XG4gICAgICAgIDxuZy1jb250ZW50IFtzZWxlY3RdPVwiJ2J1dHRvbjEnXCIgLz5cblxuICAgICAgICA8bmctY29udGVudCBbc2VsZWN0XT1cIididXR0b24yJ1wiIC8+XG5cbiAgICAgICAgPCEtLSBAZm9yIChwcm9qZWN0ZWRFbGVtZW50SWQgb2YgcHJvamVjdGVkRWxlbWVudElkKCk7IHRyYWNrIHByb2plY3RlZEVsZW1lbnRJZCkge1xuICAgICAgICA8bmctY29udGVudCBbc2VsZWN0XT1cInByb2plY3RlZEVsZW1lbnRJZFwiIC8+XG4gICAgICAgIH0gLS0+XG4gICAgICA8L25nLXRlbXBsYXRlPlxuICAgIH1cbiAgPC9wLXRhYmxlPlxuPC9kaXY+XG4iXX0=
58
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvc29mdHdhcmUtZGl2aXNpb24tY29tcG9uZW50cy9zcmMvYmFja29mZmljZS90YWJsZS90YWJsZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi9wcm9qZWN0cy9zb2Z0d2FyZS1kaXZpc2lvbi1jb21wb25lbnRzL3NyYy9iYWNrb2ZmaWNlL3RhYmxlL3RhYmxlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUVsRixPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDOUMsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDeEQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ3BELE9BQU8sRUFBRSxLQUFLLEVBQUUsV0FBVyxFQUFFLFlBQVksRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNqRSxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUNwRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSwwQ0FBMEMsQ0FBQztBQUM1RSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw4Q0FBOEMsQ0FBQztBQUNsRixPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sOEJBQThCLENBQUM7Ozs7O0FBRzlEOzs7Ozs7Ozs7OztHQVdHO0FBbUJILE1BQU0sT0FBTyxjQUFlLFNBQVEsS0FBSztJQUNoQyxLQUFLLEdBQUcsS0FBSyxFQUFnQixDQUFDO0lBQ3JDOzs7T0FHRztJQUNJLFlBQVksR0FBRyxLQUFLLENBQUMsRUFBRSxFQUFFLEVBQUUsU0FBUyxFQUFFLDBCQUEwQixDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQzNGLFVBQVUsR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFzQixDQUFDO0lBQ2xELFFBQVEsR0FBRyxLQUFLLEVBQVcsQ0FBQztJQUM1QixNQUFNLEdBQUcsS0FBSyxFQUFXLENBQUM7SUFDMUIsaUJBQWlCLEdBQUcsS0FBSyxDQUFTLFFBQVEsQ0FBQyxDQUFDO0lBQzVDLGtCQUFrQixHQUFHLEtBQUssRUFBYyxDQUFDO0lBQ3pDLHVCQUF1QixHQUFHLEtBQUssRUFBWSxDQUFDO0lBRXpDLFdBQVcsQ0FBOEI7SUFFekMsRUFBRSxDQUFDLEtBQVUsSUFBRyxDQUFDO3dHQWhCaEIsY0FBYzs0RkFBZCxjQUFjLG9yQ0FIZCxDQUFDLFlBQVksQ0FBQyxpREN4QzNCLDRqREErQ0EsaWVEaEJJLFlBQVksOEJBQ1osV0FBVyxpdkVBQ1gsaUJBQWlCLDJWQUNqQixZQUFZLDhCQUNaLGVBQWUsK0JBQ2Ysa0JBQWtCLDRIQUNsQixnQkFBZ0Isd0ZBQ2hCLGNBQWM7OzRGQUtMLGNBQWM7a0JBbEIxQixTQUFTO2lDQUNJLElBQUksWUFDTixXQUFXLFdBR1o7d0JBQ1AsWUFBWTt3QkFDWixXQUFXO3dCQUNYLGlCQUFpQjt3QkFDakIsWUFBWTt3QkFDWixlQUFlO3dCQUNmLGtCQUFrQjt3QkFDbEIsZ0JBQWdCO3dCQUNoQixjQUFjO3FCQUNmLGFBQ1UsQ0FBQyxZQUFZLENBQUMsbUJBQ1IsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBpbnB1dCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBNZW51SXRlbSB9IGZyb20gJ3ByaW1lbmcvYXBpJztcbmltcG9ydCB7IEJ1dHRvbk1vZHVsZSB9IGZyb20gJ3ByaW1lbmcvYnV0dG9uJztcbmltcG9ydCB7IENvbnRleHRNZW51TW9kdWxlIH0gZnJvbSAncHJpbWVuZy9jb250ZXh0bWVudSc7XG5pbXBvcnQgeyBQYWdpbmF0b3JNb2R1bGUgfSBmcm9tICdwcmltZW5nL3BhZ2luYXRvcic7XG5pbXBvcnQgeyBUYWJsZSwgVGFibGVNb2R1bGUsIFRhYmxlU2VydmljZSB9IGZyb20gJ3ByaW1lbmcvdGFibGUnO1xuaW1wb3J0IHsgdmFsaWRhdGVTdHlsZXNGb3JDb21wb25lbnQgfSBmcm9tICcuLi8uLi91dGlscy9wdWJsaWMtYXBpJztcbmltcG9ydCB7IEJvZHlSb3dDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvYm9keS1yb3cvYm9keS1yb3cuY29tcG9uZW50JztcbmltcG9ydCB7IEhlYWRlclJvd0NvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9oZWFkZXItcm93L2hlYWRlci1yb3cuY29tcG9uZW50JztcbmltcG9ydCB7IFRhYmxlRGlyZWN0aXZlIH0gZnJvbSAnLi9kaXJlY3RpdmVzL3RhYmxlLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBPYmplY3RDb2x1bW5EYXRhIH0gZnJvbSAnLi90eXBlcyc7XG5cbi8qKlxuICogQSBjdXN0b21pemFibGUgdGFibGUgY29tcG9uZW50IGJ1aWx0IG9uIFByaW1lTkcncyBUYWJsZS5cbiAqXG4gKiBUaGlzIGNvbXBvbmVudCBleHRlbmRzIHRoZSBQcmltZU5HIFRhYmxlIGJ5IGludHJvZHVjaW5nIGFkZGl0aW9uYWwgY29uZmlndXJhdGlvbnMgYW5kIHN0eWxpbmdcbiAqIGNhcGFiaWxpdGllcy4gSXQgc3VwcG9ydHMgZGVmaW5pbmcgY29sdW1uIGRhdGEsIGVuYWJsaW5nIHNvcnRpbmcsIGV4cG9ydGluZyBkYXRhLCBhbmQgaW50ZWdyYXRpbmdcbiAqIGNvbnRleHQgbWVudSBvcHRpb25zIGZvciBlbmhhbmNlZCB1c2VyIGludGVyYWN0aW9ucy4gQWRkaXRpb25hbGx5LCB0aGUgY29tcG9uZW50IGFsbG93cyBmb3IgZHluYW1pY1xuICogc3R5bGluZyB0aHJvdWdoIGN1c3RvbSBDU1MgY2xhc3NlcyBhbmQgbGV2ZXJhZ2VzIEFuZ3VsYXIncyBzdGFuZGFsb25lIGNvbXBvbmVudCBwYXR0ZXJuIHdpdGggT25QdXNoXG4gKiBjaGFuZ2UgZGV0ZWN0aW9uIGZvciBwZXJmb3JtYW5jZSBvcHRpbWl6YXRpb24uXG4gKlxuICogQHNpbmNlIDEuMC4wLWFscGhhLjJcbiAqIEB1cGRhdGVkIDEuMC4wLWFscGhhLjJcbiAqL1xuQENvbXBvbmVudCh7XG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHNlbGVjdG9yOiAnc2RjLXRhYmxlJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3RhYmxlLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmw6ICcuL3RhYmxlLmNvbXBvbmVudC5jc3MnLFxuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIFRhYmxlTW9kdWxlLFxuICAgIENvbnRleHRNZW51TW9kdWxlLFxuICAgIEJ1dHRvbk1vZHVsZSxcbiAgICBQYWdpbmF0b3JNb2R1bGUsXG4gICAgSGVhZGVyUm93Q29tcG9uZW50LFxuICAgIEJvZHlSb3dDb21wb25lbnQsXG4gICAgVGFibGVEaXJlY3RpdmUsXG4gIF0sXG4gIHByb3ZpZGVyczogW1RhYmxlU2VydmljZV0sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBUYWJsZUNvbXBvbmVudCBleHRlbmRzIFRhYmxlIGltcGxlbWVudHMgT25Jbml0IHtcbiAgcHVibGljIHByb3BzID0gaW5wdXQ8dHlwZW9mIFRhYmxlPigpO1xuICAvKipcbiAgICogU2luZ2xlIHN0cmluZyBvciB3aGl0ZXNwYWNlLXNlcGFyYXRlZCBzdHJpbmcgb2YgYWRkaXRpb25hbCBzdHlsZSBjbGFzc2VzIGZvciB0aGUgYnV0dG9uLlxuICAgKiBPbmx5IGFjY2VwdHMgdmFsaWQgd2hpdGVzcGFjZS1zZXBhcmF0ZWQgY2xhc3MgbmFtZXMuXG4gICAqL1xuICBwdWJsaWMgc3R5bGVDbGFzc2VzID0gaW5wdXQoJycsIHsgdHJhbnNmb3JtOiB2YWxpZGF0ZVN0eWxlc0ZvckNvbXBvbmVudCh0aGlzLmNvbnN0cnVjdG9yLm5hbWUpIH0pO1xuICBwdWJsaWMgY29sdW1uRGF0YSA9IGlucHV0LnJlcXVpcmVkPE9iamVjdENvbHVtbkRhdGFbXT4oKTtcbiAgcHVibGljIHNvcnRhYmxlID0gaW5wdXQ8Ym9vbGVhbj4oKTtcbiAgcHVibGljIGV4cG9ydCA9IGlucHV0PGJvb2xlYW4+KCk7XG4gIHB1YmxpYyBleHBvcnRCdXR0b25MYWJlbCA9IGlucHV0PHN0cmluZz4oJ0V4cG9ydCcpO1xuICBwdWJsaWMgY29udGV4dE1lbnVPcHRpb25zID0gaW5wdXQ8TWVudUl0ZW1bXT4oKTtcbiAgcHVibGljIHByb2plY3RlZEVsZW1lbnRJZEFycmF5ID0gaW5wdXQ8c3RyaW5nW10+KCk7XG5cbiAgcHJvdGVjdGVkIHNlbGVjdGVkUm93OiAodHlwZW9mIHRoaXMudmFsdWUpW251bWJlcl07XG5cbiAgcHJvdGVjdGVkIGNiKGV2ZW50OiBhbnkpIHt9XG59XG4iLCI8ZGl2PlxuICA8cC1jb250ZXh0TWVudSAjY29udGV4dE1lbnUgW21vZGVsXT1cImNvbnRleHRNZW51T3B0aW9ucygpID8/IHVuZGVmaW5lZFwiPjwvcC1jb250ZXh0TWVudT5cblxuICA8cC10YWJsZVxuICAgICNkdFxuICAgIFt0YWJsZVN0eWxlQ2xhc3NdPVwic3R5bGVDbGFzc2VzKClcIlxuICAgIFt2YWx1ZV09XCJ2YWx1ZVwiXG4gICAgW3N0eWxlXT1cInN0eWxlXCJcbiAgICBbZGF0YUtleV09XCJkYXRhS2V5XCJcbiAgICBbcm93c109XCJyb3dzXCJcbiAgICBbY29sdW1uc109XCJjb2x1bW5EYXRhKClcIlxuICAgIFtzdHJpcGVkUm93c109XCJzdHJpcGVkUm93c1wiXG4gICAgW3Nob3dHcmlkbGluZXNdPVwic2hvd0dyaWRsaW5lc1wiXG4gICAgW3BhZ2luYXRvcl09XCJwYWdpbmF0b3JcIlxuICAgIFtwYWdpbmF0b3JdPVwicGFnaW5hdG9yUG9zaXRpb25cIlxuICAgIFtyb3dzXT1cInJvd3NQZXJQYWdlT3B0aW9uc1wiXG4gICAgW2NvbnRleHRNZW51XT1cImNvbnRleHRNZW51T3B0aW9ucygpID8gY29udGV4dE1lbnUgOiB1bmRlZmluZWRcIj5cbiAgICA8bmctdGVtcGxhdGUgI2hlYWRlcj5cbiAgICAgIDx0clxuICAgICAgICBhcHAtaGVhZGVyLXJvd1xuICAgICAgICBbY29sdW1uc109XCJjb2x1bW5EYXRhKClcIlxuICAgICAgICBbcmVvcmRlcmFibGVDb2x1bW5zXT1cIiEhcmVvcmRlcmFibGVDb2x1bW5zXCJcbiAgICAgICAgW3Jlc2l6YWJsZUNvbHVtbnNdPVwiISFyZXNpemFibGVDb2x1bW5zXCI+PC90cj5cbiAgICA8L25nLXRlbXBsYXRlPlxuXG4gICAgPG5nLXRlbXBsYXRlICNib2R5IGxldC1yb3dzIGxldC1pbmRleD1cInJvd0luZGV4XCI+XG4gICAgICA8dHIgYXBwLWJvZHktcm93IFtwQ29udGV4dE1lbnVSb3ddPVwicm93c1wiIFtjb2x1bW5zXT1cImNvbHVtbkRhdGEoKVwiIFtyb3dzXT1cInJvd3NcIj48L3RyPlxuICAgIDwvbmctdGVtcGxhdGU+XG5cbiAgICBAaWYgKGV4cG9ydCgpIHx8IHByb2plY3RlZEVsZW1lbnRJZEFycmF5KCk/Lmxlbmd0aCkge1xuICAgICAgPG5nLXRlbXBsYXRlIHBUZW1wbGF0ZT1cImNhcHRpb25cIj5cbiAgICAgICAgQGlmIChleHBvcnQoKSkge1xuICAgICAgICAgIDxkaXYgY2xhc3M9XCJidXR0b25fX2V4cG9ydC0tZW5kXCI+XG4gICAgICAgICAgICA8IS0tIDxzZGMtYnV0dG9uIGljb249XCJwaSBwaS1leHRlcm5hbC1saW5rXCIgW2xhYmVsXT1cImV4cG9ydEJ1dHRvbkxhYmVsKClcIiAoY2xpY2spPVwiZHQuZXhwb3J0Q1NWKClcIiAvPiAtLT5cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgfVxuICAgICAgICA8bmctY29udGVudCBbc2VsZWN0XT1cIididXR0b24xJ1wiIC8+XG5cbiAgICAgICAgPG5nLWNvbnRlbnQgW3NlbGVjdF09XCInYnV0dG9uMidcIiAvPlxuXG4gICAgICAgIDwhLS0gQGZvciAocHJvamVjdGVkRWxlbWVudElkIG9mIHByb2plY3RlZEVsZW1lbnRJZCgpOyB0cmFjayBwcm9qZWN0ZWRFbGVtZW50SWQpIHtcbiAgICAgICAgPG5nLWNvbnRlbnQgW3NlbGVjdF09XCJwcm9qZWN0ZWRFbGVtZW50SWRcIiAvPlxuICAgICAgICB9IC0tPlxuICAgICAgPC9uZy10ZW1wbGF0ZT5cbiAgICB9XG4gIDwvcC10YWJsZT5cbjwvZGl2PlxuIl19
@@ -1,13 +1,16 @@
1
- import { ChangeDetectionStrategy, Component, input, output } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, input, output, signal } from '@angular/core';
2
2
  import { validateStylesForComponent } from '../../private-exports';
3
3
  import { ButtonComponent } from '../../public-api';
4
4
  import { sideButtonTokens } from './styles/side-button.tokens';
5
5
  import * as i0 from "@angular/core";
6
6
  /**
7
- * Component for navigating between neighboring sections.
7
+ * Component used to navigating between neighboring sections.
8
8
  *
9
9
  * It determines the next and previous available sections based on predefined mappings
10
10
  * and emits navigation events when users attempt to move between them.
11
+ *
12
+ * @since 1.0.0-alpha.2
13
+ * @updated 1.0.0-alpha.2
11
14
  */
12
15
  export class NeighboursComponent {
13
16
  /**
@@ -62,11 +65,11 @@ export class NeighboursComponent {
62
65
  /**
63
66
  * The ID of the previous available section.
64
67
  */
65
- previousAvailableSectionId = null;
68
+ previousAvailableSectionId = signal(null);
66
69
  /**
67
70
  * The ID of the next available section.
68
71
  */
69
- nextAvailableSectionId = null;
72
+ nextAvailableSectionId = signal(null);
70
73
  /**
71
74
  * Constant representing the absence of a neighboring section.
72
75
  */
@@ -90,7 +93,7 @@ export class NeighboursComponent {
90
93
  this.setAvailableSection('next');
91
94
  }
92
95
  /**
93
- * Handles navigation button clicks.
96
+ * Handles navigation button clicks. Emits the new section identificator to navigate to.
94
97
  * @param goTo - The direction to navigate.
95
98
  * @throws If there is no valid section to navigate to.
96
99
  */
@@ -108,10 +111,10 @@ export class NeighboursComponent {
108
111
  */
109
112
  getTdcIdFromDirection(direction) {
110
113
  if (direction === 'prev') {
111
- return this.previousAvailableSectionId;
114
+ return this.previousAvailableSectionId();
112
115
  }
113
116
  else {
114
- return this.nextAvailableSectionId;
117
+ return this.nextAvailableSectionId();
115
118
  }
116
119
  }
117
120
  /**
@@ -139,29 +142,29 @@ export class NeighboursComponent {
139
142
  }
140
143
  }
141
144
  if (type === 'prev') {
142
- this.previousAvailableSectionId = neighborSectionTdcId;
145
+ this.previousAvailableSectionId.set(neighborSectionTdcId);
143
146
  }
144
147
  if (type === 'next') {
145
- this.nextAvailableSectionId = neighborSectionTdcId;
148
+ this.nextAvailableSectionId.set(neighborSectionTdcId);
146
149
  }
147
150
  return;
148
151
  }
149
152
  if (neighborSectionMmcId === this.NO_NEIGHBOUR_VALUE) {
150
153
  if (type === 'prev') {
151
- this.previousAvailableSectionId = null;
154
+ this.previousAvailableSectionId.set(null);
152
155
  }
153
156
  if (type === 'next') {
154
- this.nextAvailableSectionId = null;
157
+ this.nextAvailableSectionId.set(null);
155
158
  }
156
159
  return;
157
160
  }
158
161
  return this.setAvailableSection(type, neighborSectionTdcId);
159
162
  }
160
163
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: NeighboursComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
161
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: NeighboursComponent, isStandalone: true, selector: "sdc-neighbours", inputs: { currentSection: { classPropertyName: "currentSection", publicName: "currentSection", isSignal: true, isRequired: true, transformFunction: null }, sectionsMmcToTdc: { classPropertyName: "sectionsMmcToTdc", publicName: "sectionsMmcToTdc", isSignal: true, isRequired: true, transformFunction: null }, sectionsTdcToMmc: { classPropertyName: "sectionsTdcToMmc", publicName: "sectionsTdcToMmc", isSignal: true, isRequired: true, transformFunction: null }, neigboursData: { classPropertyName: "neigboursData", publicName: "neigboursData", isSignal: true, isRequired: true, transformFunction: null }, nextIcon: { classPropertyName: "nextIcon", publicName: "nextIcon", isSignal: true, isRequired: false, transformFunction: null }, previousIcon: { classPropertyName: "previousIcon", publicName: "previousIcon", isSignal: true, isRequired: false, transformFunction: null }, onlyNavigateToAvailable: { classPropertyName: "onlyNavigateToAvailable", publicName: "onlyNavigateToAvailable", isSignal: true, isRequired: false, transformFunction: null }, sectionsAvailability: { classPropertyName: "sectionsAvailability", publicName: "sectionsAvailability", isSignal: true, isRequired: false, transformFunction: null }, styleClasses: { classPropertyName: "styleClasses", publicName: "styleClasses", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { sectionToNavigate: "sectionToNavigate" }, ngImport: i0, template: "<div id=\"sdc-neighbours\" class=\"wrapper__neighbours--gap\">\n <sdc-button\n iconPos=\"left\"\n [styleClasses]=\"styleClasses().sideButtonsClass\"\n [dt]=\"sideButtonStyle\"\n label=\"Previous section\"\n [icon]=\"previousIcon()\"\n (onClick)=\"onClick('prev')\" />\n\n <div id=\"sdc-neighbours-section-info\" class=\"neighbours__section--info\" [class]=\"styleClasses().middleDivClass\">\n <span>Section</span> <span class=\"content__section--bold\">{{ currentSection() }}</span>\n </div>\n\n <sdc-button\n [dt]=\"sideButtonStyle\"\n [styleClasses]=\"styleClasses().sideButtonsClass\"\n iconPos=\"right\"\n label=\"Next section\"\n [icon]=\"nextIcon()\"\n (onClick)=\"onClick('next')\" />\n</div>\n", styles: [".wrapper__neighbours--gap{display:flex;column-gap:.5em}.content__section--bold{font-weight:900}.neighbours__section--info{display:flex;justify-content:center;column-gap:.5em;align-items:center;background-color:#f9f9f9;border-radius:9999px;row-gap:.25em;min-width:8em}\n"], dependencies: [{ kind: "component", type: ButtonComponent, selector: "sdc-button", inputs: ["props", "tooltip", "tooltipPos", "badgeValue", "debounceTimeInMs", "styleClasses"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
164
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: NeighboursComponent, isStandalone: true, selector: "sdc-neighbours", inputs: { currentSection: { classPropertyName: "currentSection", publicName: "currentSection", isSignal: true, isRequired: true, transformFunction: null }, sectionsMmcToTdc: { classPropertyName: "sectionsMmcToTdc", publicName: "sectionsMmcToTdc", isSignal: true, isRequired: true, transformFunction: null }, sectionsTdcToMmc: { classPropertyName: "sectionsTdcToMmc", publicName: "sectionsTdcToMmc", isSignal: true, isRequired: true, transformFunction: null }, neigboursData: { classPropertyName: "neigboursData", publicName: "neigboursData", isSignal: true, isRequired: true, transformFunction: null }, nextIcon: { classPropertyName: "nextIcon", publicName: "nextIcon", isSignal: true, isRequired: false, transformFunction: null }, previousIcon: { classPropertyName: "previousIcon", publicName: "previousIcon", isSignal: true, isRequired: false, transformFunction: null }, onlyNavigateToAvailable: { classPropertyName: "onlyNavigateToAvailable", publicName: "onlyNavigateToAvailable", isSignal: true, isRequired: false, transformFunction: null }, sectionsAvailability: { classPropertyName: "sectionsAvailability", publicName: "sectionsAvailability", isSignal: true, isRequired: false, transformFunction: null }, styleClasses: { classPropertyName: "styleClasses", publicName: "styleClasses", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { sectionToNavigate: "sectionToNavigate" }, ngImport: i0, template: "<div id=\"sdc-neighbours\" class=\"wrapper__neighbours--gap\">\n @if (previousAvailableSectionId()) {\n <sdc-button\n iconPos=\"left\"\n [styleClasses]=\"styleClasses()?.sideButtonsClass\"\n [dt]=\"sideButtonStyle\"\n label=\"Previous section\"\n [icon]=\"previousIcon()\"\n (onClick)=\"onClick('prev')\" />\n }\n\n <div id=\"sdc-neighbours-section-info\" class=\"neighbours__section--info\" [class]=\"styleClasses().middleDivClass\">\n <span>Section</span> <span class=\"content__section--bold\">{{ currentSection() }}</span>\n </div>\n\n @if (nextAvailableSectionId()) {\n <sdc-button\n [dt]=\"sideButtonStyle\"\n [styleClasses]=\"styleClasses()?.sideButtonsClass\"\n iconPos=\"right\"\n label=\"Next section\"\n [icon]=\"nextIcon()\"\n (onClick)=\"onClick('next')\" />\n }\n</div>\n", styles: [".wrapper__neighbours--gap{display:flex;column-gap:.5em}.content__section--bold{font-weight:900}.neighbours__section--info{display:flex;justify-content:center;column-gap:.5em;align-items:center;background-color:#f9f9f9;border-radius:9999px;row-gap:.25em;min-width:8em}\n"], dependencies: [{ kind: "component", type: ButtonComponent, selector: "sdc-button", inputs: ["props", "tooltip", "tooltipPos", "badgeValue", "debounceTimeInMs", "styleClasses"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
162
165
  }
163
166
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: NeighboursComponent, decorators: [{
164
167
  type: Component,
165
- args: [{ standalone: true, selector: 'sdc-neighbours', imports: [ButtonComponent], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div id=\"sdc-neighbours\" class=\"wrapper__neighbours--gap\">\n <sdc-button\n iconPos=\"left\"\n [styleClasses]=\"styleClasses().sideButtonsClass\"\n [dt]=\"sideButtonStyle\"\n label=\"Previous section\"\n [icon]=\"previousIcon()\"\n (onClick)=\"onClick('prev')\" />\n\n <div id=\"sdc-neighbours-section-info\" class=\"neighbours__section--info\" [class]=\"styleClasses().middleDivClass\">\n <span>Section</span> <span class=\"content__section--bold\">{{ currentSection() }}</span>\n </div>\n\n <sdc-button\n [dt]=\"sideButtonStyle\"\n [styleClasses]=\"styleClasses().sideButtonsClass\"\n iconPos=\"right\"\n label=\"Next section\"\n [icon]=\"nextIcon()\"\n (onClick)=\"onClick('next')\" />\n</div>\n", styles: [".wrapper__neighbours--gap{display:flex;column-gap:.5em}.content__section--bold{font-weight:900}.neighbours__section--info{display:flex;justify-content:center;column-gap:.5em;align-items:center;background-color:#f9f9f9;border-radius:9999px;row-gap:.25em;min-width:8em}\n"] }]
168
+ args: [{ standalone: true, selector: 'sdc-neighbours', imports: [ButtonComponent], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div id=\"sdc-neighbours\" class=\"wrapper__neighbours--gap\">\n @if (previousAvailableSectionId()) {\n <sdc-button\n iconPos=\"left\"\n [styleClasses]=\"styleClasses()?.sideButtonsClass\"\n [dt]=\"sideButtonStyle\"\n label=\"Previous section\"\n [icon]=\"previousIcon()\"\n (onClick)=\"onClick('prev')\" />\n }\n\n <div id=\"sdc-neighbours-section-info\" class=\"neighbours__section--info\" [class]=\"styleClasses().middleDivClass\">\n <span>Section</span> <span class=\"content__section--bold\">{{ currentSection() }}</span>\n </div>\n\n @if (nextAvailableSectionId()) {\n <sdc-button\n [dt]=\"sideButtonStyle\"\n [styleClasses]=\"styleClasses()?.sideButtonsClass\"\n iconPos=\"right\"\n label=\"Next section\"\n [icon]=\"nextIcon()\"\n (onClick)=\"onClick('next')\" />\n }\n</div>\n", styles: [".wrapper__neighbours--gap{display:flex;column-gap:.5em}.content__section--bold{font-weight:900}.neighbours__section--info{display:flex;justify-content:center;column-gap:.5em;align-items:center;background-color:#f9f9f9;border-radius:9999px;row-gap:.25em;min-width:8em}\n"] }]
166
169
  }] });
167
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"neighbours.component.js","sourceRoot":"","sources":["../../../../projects/software-division-components/src/dvm/neighbours/neighbours.component.ts","../../../../projects/software-division-components/src/dvm/neighbours/neighbours.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAC1F,OAAO,EAAE,0BAA0B,EAAE,MAAM,uBAAuB,CAAC;AACnE,OAAO,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AACnD,OAAO,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAC;;AAE/D;;;;;GAKG;AASH,MAAM,OAAO,mBAAmB;IAC9B;;OAEG;IACgB,eAAe,GAAG,gBAAgB,CAAC;IAEtD;;OAEG;IACI,cAAc,GAAG,KAAK,CAAC,QAAQ,EAAU,CAAC;IAEjD;;OAEG;IACI,gBAAgB,GAAG,KAAK,CAAC,QAAQ,CAAyB,EAAE,CAAC,CAAC;IAErE;;OAEG;IACI,gBAAgB,GAAG,KAAK,CAAC,QAAQ,CAAyB,EAAE,CAAC,CAAC;IAErE;;OAEG;IACI,aAAa,GAAG,KAAK,CAAC,QAAQ,CAAsD,EAAE,CAAC,CAAC;IAE/F;;OAEG;IACI,QAAQ,GAAG,KAAK,CAAS,EAAE,CAAC,CAAC;IAEpC;;OAEG;IACI,YAAY,GAAG,KAAK,CAAS,EAAE,CAAC,CAAC;IAExC;;;;OAIG;IACI,uBAAuB,GAAG,KAAK,EAAW,CAAC;IAElD;;;OAGG;IACI,oBAAoB,GAAG,KAAK,CAAsB,EAAE,CAAC,CAAC;IAE7D;;OAEG;IACI,YAAY,GAAG,KAAK,CACzB,EAAE,cAAc,EAAE,EAAE,EAAE,gBAAgB,EAAE,EAAE,EAAE,EAC5C;QACE,SAAS,EAAE,0BAA0B,CAAyB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;KACrF,CACF,CAAC;IAEF;;OAEG;IACI,iBAAiB,GAAG,MAAM,EAAU,CAAC;IAE5C;;OAEG;IACK,0BAA0B,GAAkB,IAAI,CAAC;IAEzD;;OAEG;IACK,sBAAsB,GAAkB,IAAI,CAAC;IAErD;;OAEG;IACK,kBAAkB,GAAG,MAAe,CAAC;IAE7C;;OAEG;IACK,cAAc,GAAG;QACvB,IAAI,EAAE,GAAG;QACT,IAAI,EAAE,GAAG;KACuC,CAAC;IAEnD;;OAEG;IACK,UAAU,GAAG;QACnB,IAAI,EAAE,UAAU;QAChB,IAAI,EAAE,MAAM;KACJ,CAAC;IAEX,QAAQ;QACN,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC;QACjC,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC;IACnC,CAAC;IAED;;;;OAIG;IACI,OAAO,CAAC,IAAqB;QAClC,MAAM,KAAK,GAAG,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;QAE/C,IAAI,CAAC,KAAK,EAAE;YACV,MAAM,IAAI,KAAK,CAAC,qBAAqB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC;SACpF;QAED,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACrC,CAAC;IAED;;;;OAIG;IACK,qBAAqB,CAAC,SAAoB;QAChD,IAAI,SAAS,KAAK,MAAM,EAAE;YACxB,OAAO,IAAI,CAAC,0BAA0B,CAAC;SACxC;aAAM;YACL,OAAO,IAAI,CAAC,sBAAsB,CAAC;SACpC;IACH,CAAC;IAED;;;;;OAKG;IACK,mBAAmB,CAAC,IAAqB,EAAE,cAAuB;QACxE,MAAM,WAAW,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;QAC9C,MAAM,mBAAmB,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC,cAAc,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC;QAC7F,MAAM,cAAc,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,mBAAmB,CAAC,CAAC;QAEjE,MAAM,oBAAoB,GAAG,cAAc,CAAC,WAAW,CAAC,CAAC;QACzD,MAAM,oBAAoB,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC,oBAAoB,CAAC,CAAC;QAE3E,IAAI,oBAAoB,EAAE;YACxB,IAAI,IAAI,CAAC,uBAAuB,EAAE,EAAE;gBAClC,IAAI,IAAI,CAAC,oBAAoB,EAAE,EAAE;oBAC/B,MAAM,eAAe,GAAG,CAAC,CAAC,IAAI,CAAC,oBAAoB,EAAE,CAAC,oBAAoB,CAAC,CAAC;oBAC5E,IAAI,CAAC,eAAe,EAAE;wBACpB,OAAO;qBACR;iBACF;qBAAM;oBACL,MAAM,IAAI,KAAK,CACb,qGAAqG,CACtG,CAAC;iBACH;aACF;YAED,IAAI,IAAI,KAAK,MAAM,EAAE;gBACnB,IAAI,CAAC,0BAA0B,GAAG,oBAAoB,CAAC;aACxD;YACD,IAAI,IAAI,KAAK,MAAM,EAAE;gBACnB,IAAI,CAAC,sBAAsB,GAAG,oBAAoB,CAAC;aACpD;YACD,OAAO;SACR;QAED,IAAI,oBAAoB,KAAK,IAAI,CAAC,kBAAkB,EAAE;YACpD,IAAI,IAAI,KAAK,MAAM,EAAE;gBACnB,IAAI,CAAC,0BAA0B,GAAG,IAAI,CAAC;aACxC;YACD,IAAI,IAAI,KAAK,MAAM,EAAE;gBACnB,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC;aACpC;YACD,OAAO;SACR;QAED,OAAO,IAAI,CAAC,mBAAmB,CAAC,IAAI,EAAE,oBAAoB,CAAC,CAAC;IAC9D,CAAC;wGAhLU,mBAAmB;4FAAnB,mBAAmB,08CCnBhC,0uBAqBA,uUDLY,eAAe;;4FAGd,mBAAmB;kBAR/B,SAAS;iCACI,IAAI,YACN,gBAAgB,WAGjB,CAAC,eAAe,CAAC,mBACT,uBAAuB,CAAC,MAAM","sourcesContent":["import { ChangeDetectionStrategy, Component, input, OnInit, output } from '@angular/core';\nimport { validateStylesForComponent } from '../../private-exports';\nimport { ButtonComponent } from '../../public-api';\nimport { sideButtonTokens } from './styles/side-button.tokens';\nimport { Direction, DirectionObjectKeys, NeighboursStyleClasses } from './types';\n/**\n * Component for navigating between neighboring sections.\n *\n * It determines the next and previous available sections based on predefined mappings\n * and emits navigation events when users attempt to move between them.\n */\n@Component({\n  standalone: true,\n  selector: 'sdc-neighbours',\n  templateUrl: './neighbours.component.html',\n  styleUrl: './styles/neighbours.component.css',\n  imports: [ButtonComponent],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NeighboursComponent implements OnInit {\n  /**\n   * Predefined styles for the side button.\n   */\n  protected readonly sideButtonStyle = sideButtonTokens;\n\n  /**\n   * The current section identifier.\n   */\n  public currentSection = input.required<string>();\n\n  /**\n   * Mapping of MMC section IDs to TDC section IDs.\n   */\n  public sectionsMmcToTdc = input.required<Record<string, string>>({});\n\n  /**\n   * Mapping of TDC section IDs to MMC section IDs.\n   */\n  public sectionsTdcToMmc = input.required<Record<string, string>>({});\n\n  /**\n   * Data structure defining neighboring relationships between sections.\n   */\n  public neigboursData = input.required<Record<string, Record<DirectionObjectKeys, string>>>({});\n\n  /**\n   * Icon for the next navigation button.\n   */\n  public nextIcon = input<string>('');\n\n  /**\n   * Icon for the previous navigation button.\n   */\n  public previousIcon = input<string>('');\n\n  /**\n   * Flag indicating whether navigation is restricted to available sections only.\n   * This requires the sectionsAvailability input to be passed, otherwise the initialization of\n   * the component will fail.\n   */\n  public onlyNavigateToAvailable = input<boolean>();\n\n  /**\n   * Object defining the availability of sections. Required if you are wanting to allow navigation\n   * to available sections only.\n   */\n  public sectionsAvailability = input<Record<string, any>>({});\n\n  /**\n   * Custom styling classes for the component.\n   */\n  public styleClasses = input(\n    { middleDivClass: '', sideButtonsClass: '' },\n    {\n      transform: validateStylesForComponent<NeighboursStyleClasses>(this.constructor.name),\n    }\n  );\n\n  /**\n   * Event emitter for section navigation.\n   */\n  public sectionToNavigate = output<string>();\n\n  /**\n   * The ID of the previous available section.\n   */\n  private previousAvailableSectionId: string | null = null;\n\n  /**\n   * The ID of the next available section.\n   */\n  private nextAvailableSectionId: string | null = null;\n\n  /**\n   * Constant representing the absence of a neighboring section.\n   */\n  private NO_NEIGHBOUR_VALUE = 'none' as const;\n\n  /**\n   * Key mappings for neighboring sections.\n   */\n  private neighboursKeys = {\n    prev: 'l',\n    next: 'r',\n  } satisfies Record<Direction, DirectionObjectKeys>;\n\n  /**\n   * Key mappings for navigation directions.\n   */\n  private keyMapping = {\n    prev: 'previous',\n    next: 'next',\n  } as const;\n\n  ngOnInit() {\n    this.setAvailableSection('prev');\n    this.setAvailableSection('next');\n  }\n\n  /**\n   * Handles navigation button clicks.\n   * @param  goTo - The direction to navigate.\n   * @throws  If there is no valid section to navigate to.\n   */\n  public onClick(goTo: 'prev' | 'next') {\n    const tdcId = this.getTdcIdFromDirection(goTo);\n\n    if (!tdcId) {\n      throw new Error(`There is no valid ${this.keyMapping[goTo]} section to navigate.`);\n    }\n\n    this.sectionToNavigate.emit(tdcId);\n  }\n\n  /**\n   * Retrieves the TDC section ID based on the navigation direction.\n   * @param  direction - The navigation direction.\n   * @returns  The section ID to navigate to, or null if unavailable.\n   */\n  private getTdcIdFromDirection(direction: Direction) {\n    if (direction === 'prev') {\n      return this.previousAvailableSectionId;\n    } else {\n      return this.nextAvailableSectionId;\n    }\n  }\n\n  /**\n   * Determines and sets the available section for navigation in the specified direction.\n   * @param type - The navigation direction.\n   * @param [currentSection] - The current section ID (optional).\n   * @throws If navigation is restricted and sectionsAvailability is not provided.\n   */\n  private setAvailableSection(type: 'prev' | 'next', currentSection?: string): void {\n    const neighborKey = this.neighboursKeys[type];\n    const currentSectionMmcId = this.sectionsTdcToMmc()[currentSection ?? this.currentSection()];\n    const neighborObject = this.neigboursData()[currentSectionMmcId];\n\n    const neighborSectionMmcId = neighborObject[neighborKey];\n    const neighborSectionTdcId = this.sectionsMmcToTdc()[neighborSectionMmcId];\n\n    if (neighborSectionTdcId) {\n      if (this.onlyNavigateToAvailable()) {\n        if (this.sectionsAvailability()) {\n          const hasAvailability = !!this.sectionsAvailability()[neighborSectionTdcId];\n          if (!hasAvailability) {\n            return;\n          }\n        } else {\n          throw new Error(\n            'To only navigate to available sections, it is required to pass the sections availability parameter.'\n          );\n        }\n      }\n\n      if (type === 'prev') {\n        this.previousAvailableSectionId = neighborSectionTdcId;\n      }\n      if (type === 'next') {\n        this.nextAvailableSectionId = neighborSectionTdcId;\n      }\n      return;\n    }\n\n    if (neighborSectionMmcId === this.NO_NEIGHBOUR_VALUE) {\n      if (type === 'prev') {\n        this.previousAvailableSectionId = null;\n      }\n      if (type === 'next') {\n        this.nextAvailableSectionId = null;\n      }\n      return;\n    }\n\n    return this.setAvailableSection(type, neighborSectionTdcId);\n  }\n}\n","<div id=\"sdc-neighbours\" class=\"wrapper__neighbours--gap\">\n  <sdc-button\n    iconPos=\"left\"\n    [styleClasses]=\"styleClasses().sideButtonsClass\"\n    [dt]=\"sideButtonStyle\"\n    label=\"Previous section\"\n    [icon]=\"previousIcon()\"\n    (onClick)=\"onClick('prev')\" />\n\n  <div id=\"sdc-neighbours-section-info\" class=\"neighbours__section--info\" [class]=\"styleClasses().middleDivClass\">\n    <span>Section</span> <span class=\"content__section--bold\">{{ currentSection() }}</span>\n  </div>\n\n  <sdc-button\n    [dt]=\"sideButtonStyle\"\n    [styleClasses]=\"styleClasses().sideButtonsClass\"\n    iconPos=\"right\"\n    label=\"Next section\"\n    [icon]=\"nextIcon()\"\n    (onClick)=\"onClick('next')\" />\n</div>\n"]}
170
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"neighbours.component.js","sourceRoot":"","sources":["../../../../projects/software-division-components/src/dvm/neighbours/neighbours.component.ts","../../../../projects/software-division-components/src/dvm/neighbours/neighbours.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAClG,OAAO,EAAE,0BAA0B,EAAE,MAAM,uBAAuB,CAAC;AACnE,OAAO,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AACnD,OAAO,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAC;;AAE/D;;;;;;;;GAQG;AASH,MAAM,OAAO,mBAAmB;IAC9B;;OAEG;IACgB,eAAe,GAAG,gBAAgB,CAAC;IAEtD;;OAEG;IACI,cAAc,GAAG,KAAK,CAAC,QAAQ,EAAU,CAAC;IAEjD;;OAEG;IACI,gBAAgB,GAAG,KAAK,CAAC,QAAQ,CAAyB,EAAE,CAAC,CAAC;IAErE;;OAEG;IACI,gBAAgB,GAAG,KAAK,CAAC,QAAQ,CAAyB,EAAE,CAAC,CAAC;IAErE;;OAEG;IACI,aAAa,GAAG,KAAK,CAAC,QAAQ,CAAsD,EAAE,CAAC,CAAC;IAE/F;;OAEG;IACI,QAAQ,GAAG,KAAK,CAAS,EAAE,CAAC,CAAC;IAEpC;;OAEG;IACI,YAAY,GAAG,KAAK,CAAS,EAAE,CAAC,CAAC;IAExC;;;;OAIG;IACI,uBAAuB,GAAG,KAAK,EAAW,CAAC;IAElD;;;OAGG;IACI,oBAAoB,GAAG,KAAK,CAAsB,EAAE,CAAC,CAAC;IAE7D;;OAEG;IACI,YAAY,GAAG,KAAK,CACzB,EAAE,cAAc,EAAE,EAAE,EAAE,gBAAgB,EAAE,EAAE,EAAE,EAC5C;QACE,SAAS,EAAE,0BAA0B,CAAyB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;KACrF,CACF,CAAC;IAEF;;OAEG;IACI,iBAAiB,GAAG,MAAM,EAAU,CAAC;IAE5C;;OAEG;IACO,0BAA0B,GAAG,MAAM,CAAgB,IAAI,CAAC,CAAC;IAEnE;;OAEG;IACO,sBAAsB,GAAG,MAAM,CAAgB,IAAI,CAAC,CAAC;IAE/D;;OAEG;IACK,kBAAkB,GAAG,MAAe,CAAC;IAE7C;;OAEG;IACK,cAAc,GAAG;QACvB,IAAI,EAAE,GAAG;QACT,IAAI,EAAE,GAAG;KACuC,CAAC;IAEnD;;OAEG;IACK,UAAU,GAAG;QACnB,IAAI,EAAE,UAAU;QAChB,IAAI,EAAE,MAAM;KACJ,CAAC;IAEX,QAAQ;QACN,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC;QACjC,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC;IACnC,CAAC;IAED;;;;OAIG;IACI,OAAO,CAAC,IAAqB;QAClC,MAAM,KAAK,GAAG,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;QAE/C,IAAI,CAAC,KAAK,EAAE;YACV,MAAM,IAAI,KAAK,CAAC,qBAAqB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC;SACpF;QAED,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACrC,CAAC;IAED;;;;OAIG;IACK,qBAAqB,CAAC,SAAoB;QAChD,IAAI,SAAS,KAAK,MAAM,EAAE;YACxB,OAAO,IAAI,CAAC,0BAA0B,EAAE,CAAC;SAC1C;aAAM;YACL,OAAO,IAAI,CAAC,sBAAsB,EAAE,CAAC;SACtC;IACH,CAAC;IAED;;;;;OAKG;IACK,mBAAmB,CAAC,IAAqB,EAAE,cAAuB;QACxE,MAAM,WAAW,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;QAC9C,MAAM,mBAAmB,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC,cAAc,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC;QAC7F,MAAM,cAAc,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,mBAAmB,CAAC,CAAC;QAEjE,MAAM,oBAAoB,GAAG,cAAc,CAAC,WAAW,CAAC,CAAC;QACzD,MAAM,oBAAoB,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC,oBAAoB,CAAC,CAAC;QAE3E,IAAI,oBAAoB,EAAE;YACxB,IAAI,IAAI,CAAC,uBAAuB,EAAE,EAAE;gBAClC,IAAI,IAAI,CAAC,oBAAoB,EAAE,EAAE;oBAC/B,MAAM,eAAe,GAAG,CAAC,CAAC,IAAI,CAAC,oBAAoB,EAAE,CAAC,oBAAoB,CAAC,CAAC;oBAC5E,IAAI,CAAC,eAAe,EAAE;wBACpB,OAAO;qBACR;iBACF;qBAAM;oBACL,MAAM,IAAI,KAAK,CACb,qGAAqG,CACtG,CAAC;iBACH;aACF;YAED,IAAI,IAAI,KAAK,MAAM,EAAE;gBACnB,IAAI,CAAC,0BAA0B,CAAC,GAAG,CAAC,oBAAoB,CAAC,CAAC;aAC3D;YACD,IAAI,IAAI,KAAK,MAAM,EAAE;gBACnB,IAAI,CAAC,sBAAsB,CAAC,GAAG,CAAC,oBAAoB,CAAC,CAAC;aACvD;YACD,OAAO;SACR;QAED,IAAI,oBAAoB,KAAK,IAAI,CAAC,kBAAkB,EAAE;YACpD,IAAI,IAAI,KAAK,MAAM,EAAE;gBACnB,IAAI,CAAC,0BAA0B,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;aAC3C;YACD,IAAI,IAAI,KAAK,MAAM,EAAE;gBACnB,IAAI,CAAC,sBAAsB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;aACvC;YACD,OAAO;SACR;QAED,OAAO,IAAI,CAAC,mBAAmB,CAAC,IAAI,EAAE,oBAAoB,CAAC,CAAC;IAC9D,CAAC;wGAhLU,mBAAmB;4FAAnB,mBAAmB,08CCtBhC,81BAyBA,uUDNY,eAAe;;4FAGd,mBAAmB;kBAR/B,SAAS;iCACI,IAAI,YACN,gBAAgB,WAGjB,CAAC,eAAe,CAAC,mBACT,uBAAuB,CAAC,MAAM","sourcesContent":["import { ChangeDetectionStrategy, Component, input, OnInit, output, signal } from '@angular/core';\nimport { validateStylesForComponent } from '../../private-exports';\nimport { ButtonComponent } from '../../public-api';\nimport { sideButtonTokens } from './styles/side-button.tokens';\nimport { Direction, DirectionObjectKeys, NeighboursStyleClasses } from './types';\n/**\n * Component used to navigating between neighboring sections.\n *\n * It determines the next and previous available sections based on predefined mappings\n * and emits navigation events when users attempt to move between them.\n *\n * @since 1.0.0-alpha.2\n * @updated 1.0.0-alpha.2\n */\n@Component({\n  standalone: true,\n  selector: 'sdc-neighbours',\n  templateUrl: './neighbours.component.html',\n  styleUrl: './styles/neighbours.component.css',\n  imports: [ButtonComponent],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NeighboursComponent implements OnInit {\n  /**\n   * Predefined styles for the side button.\n   */\n  protected readonly sideButtonStyle = sideButtonTokens;\n\n  /**\n   * The current section identifier.\n   */\n  public currentSection = input.required<string>();\n\n  /**\n   * Mapping of MMC section IDs to TDC section IDs.\n   */\n  public sectionsMmcToTdc = input.required<Record<string, string>>({});\n\n  /**\n   * Mapping of TDC section IDs to MMC section IDs.\n   */\n  public sectionsTdcToMmc = input.required<Record<string, string>>({});\n\n  /**\n   * Data structure defining neighboring relationships between sections.\n   */\n  public neigboursData = input.required<Record<string, Record<DirectionObjectKeys, string>>>({});\n\n  /**\n   * Icon for the next navigation button.\n   */\n  public nextIcon = input<string>('');\n\n  /**\n   * Icon for the previous navigation button.\n   */\n  public previousIcon = input<string>('');\n\n  /**\n   * Flag indicating whether navigation is restricted to available sections only.\n   * This requires the sectionsAvailability input to be passed, otherwise the initialization of\n   * the component will fail.\n   */\n  public onlyNavigateToAvailable = input<boolean>();\n\n  /**\n   * Object defining the availability of sections. Required if you are wanting to allow navigation\n   * to available sections only.\n   */\n  public sectionsAvailability = input<Record<string, any>>({});\n\n  /**\n   * Custom styling classes for the component.\n   */\n  public styleClasses = input(\n    { middleDivClass: '', sideButtonsClass: '' },\n    {\n      transform: validateStylesForComponent<NeighboursStyleClasses>(this.constructor.name),\n    }\n  );\n\n  /**\n   * Event emitter for section navigation.\n   */\n  public sectionToNavigate = output<string>();\n\n  /**\n   * The ID of the previous available section.\n   */\n  protected previousAvailableSectionId = signal<string | null>(null);\n\n  /**\n   * The ID of the next available section.\n   */\n  protected nextAvailableSectionId = signal<string | null>(null);\n\n  /**\n   * Constant representing the absence of a neighboring section.\n   */\n  private NO_NEIGHBOUR_VALUE = 'none' as const;\n\n  /**\n   * Key mappings for neighboring sections.\n   */\n  private neighboursKeys = {\n    prev: 'l',\n    next: 'r',\n  } satisfies Record<Direction, DirectionObjectKeys>;\n\n  /**\n   * Key mappings for navigation directions.\n   */\n  private keyMapping = {\n    prev: 'previous',\n    next: 'next',\n  } as const;\n\n  ngOnInit() {\n    this.setAvailableSection('prev');\n    this.setAvailableSection('next');\n  }\n\n  /**\n   * Handles navigation button clicks. Emits the new section identificator to navigate to.\n   * @param  goTo - The direction to navigate.\n   * @throws  If there is no valid section to navigate to.\n   */\n  public onClick(goTo: 'prev' | 'next') {\n    const tdcId = this.getTdcIdFromDirection(goTo);\n\n    if (!tdcId) {\n      throw new Error(`There is no valid ${this.keyMapping[goTo]} section to navigate.`);\n    }\n\n    this.sectionToNavigate.emit(tdcId);\n  }\n\n  /**\n   * Retrieves the TDC section ID based on the navigation direction.\n   * @param  direction - The navigation direction.\n   * @returns  The section ID to navigate to, or null if unavailable.\n   */\n  private getTdcIdFromDirection(direction: Direction) {\n    if (direction === 'prev') {\n      return this.previousAvailableSectionId();\n    } else {\n      return this.nextAvailableSectionId();\n    }\n  }\n\n  /**\n   * Determines and sets the available section for navigation in the specified direction.\n   * @param type - The navigation direction.\n   * @param [currentSection] - The current section ID (optional).\n   * @throws If navigation is restricted and sectionsAvailability is not provided.\n   */\n  private setAvailableSection(type: 'prev' | 'next', currentSection?: string): void {\n    const neighborKey = this.neighboursKeys[type];\n    const currentSectionMmcId = this.sectionsTdcToMmc()[currentSection ?? this.currentSection()];\n    const neighborObject = this.neigboursData()[currentSectionMmcId];\n\n    const neighborSectionMmcId = neighborObject[neighborKey];\n    const neighborSectionTdcId = this.sectionsMmcToTdc()[neighborSectionMmcId];\n\n    if (neighborSectionTdcId) {\n      if (this.onlyNavigateToAvailable()) {\n        if (this.sectionsAvailability()) {\n          const hasAvailability = !!this.sectionsAvailability()[neighborSectionTdcId];\n          if (!hasAvailability) {\n            return;\n          }\n        } else {\n          throw new Error(\n            'To only navigate to available sections, it is required to pass the sections availability parameter.'\n          );\n        }\n      }\n\n      if (type === 'prev') {\n        this.previousAvailableSectionId.set(neighborSectionTdcId);\n      }\n      if (type === 'next') {\n        this.nextAvailableSectionId.set(neighborSectionTdcId);\n      }\n      return;\n    }\n\n    if (neighborSectionMmcId === this.NO_NEIGHBOUR_VALUE) {\n      if (type === 'prev') {\n        this.previousAvailableSectionId.set(null);\n      }\n      if (type === 'next') {\n        this.nextAvailableSectionId.set(null);\n      }\n      return;\n    }\n\n    return this.setAvailableSection(type, neighborSectionTdcId);\n  }\n}\n","<div id=\"sdc-neighbours\" class=\"wrapper__neighbours--gap\">\n  @if (previousAvailableSectionId()) {\n    <sdc-button\n      iconPos=\"left\"\n      [styleClasses]=\"styleClasses()?.sideButtonsClass\"\n      [dt]=\"sideButtonStyle\"\n      label=\"Previous section\"\n      [icon]=\"previousIcon()\"\n      (onClick)=\"onClick('prev')\" />\n  }\n\n  <div id=\"sdc-neighbours-section-info\" class=\"neighbours__section--info\" [class]=\"styleClasses().middleDivClass\">\n    <span>Section</span> <span class=\"content__section--bold\">{{ currentSection() }}</span>\n  </div>\n\n  @if (nextAvailableSectionId()) {\n    <sdc-button\n      [dt]=\"sideButtonStyle\"\n      [styleClasses]=\"styleClasses()?.sideButtonsClass\"\n      iconPos=\"right\"\n      label=\"Next section\"\n      [icon]=\"nextIcon()\"\n      (onClick)=\"onClick('next')\" />\n  }\n</div>\n"]}
@@ -1,2 +1,2 @@
1
1
  export { NeighboursComponent } from './neighbours.component';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3NvZnR3YXJlLWRpdmlzaW9uLWNvbXBvbmVudHMvc3JjL2R2bS9uZWlnaGJvdXJzL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sd0JBQXdCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBOZWlnaGJvdXJzQ29tcG9uZW50IH0gZnJvbSAnLi9uZWlnaGJvdXJzLmNvbXBvbmVudCc7XG4iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3NvZnR3YXJlLWRpdmlzaW9uLWNvbXBvbmVudHMvc3JjL2R2bS9uZWlnaGJvdXJzL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sd0JBQXdCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBOZWlnaGJvdXJzQ29tcG9uZW50IH0gZnJvbSAnLi9uZWlnaGJvdXJzLmNvbXBvbmVudCc7XG5leHBvcnQgdHlwZSB7IERpcmVjdGlvbiwgRGlyZWN0aW9uT2JqZWN0S2V5cywgTmVpZ2hib3Vyc0RhdGEgfSBmcm9tICcuL3R5cGVzJztcbiJdfQ==
@@ -1,3 +1,4 @@
1
+ // TODO: this requires adaptation to the new design
1
2
  export const sideButtonTokens = {
2
3
  root: {
3
4
  primary: {
@@ -16,4 +17,4 @@ export const sideButtonTokens = {
16
17
  },
17
18
  },
18
19
  };
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZS1idXR0b24udG9rZW5zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc29mdHdhcmUtZGl2aXNpb24tY29tcG9uZW50cy9zcmMvZHZtL25laWdoYm91cnMvc3R5bGVzL3NpZGUtYnV0dG9uLnRva2Vucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLENBQUMsTUFBTSxnQkFBZ0IsR0FBRztJQUM5QixJQUFJLEVBQUU7UUFDSixPQUFPLEVBQUU7WUFDUCxPQUFPO1lBQ1AsS0FBSyxFQUFFLEVBQUU7WUFDVCxXQUFXLEVBQUUsV0FBVztZQUN4QixVQUFVLEVBQUUsRUFBRTtZQUNkLFdBQVcsRUFBRSxFQUFFO1lBQ2YsYUFBYTtZQUNiLFVBQVUsRUFBRSxXQUFXO1lBQ3ZCLGVBQWUsRUFBRSxXQUFXO1lBQzVCLGdCQUFnQixFQUFFLFdBQVc7WUFDN0IsU0FBUztZQUNULGlCQUFpQixFQUFFLFdBQVc7WUFDOUIsZ0JBQWdCLEVBQUUsV0FBVztTQUM5QjtLQUNGO0NBQzJCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCdXR0b25EZXNpZ25Ub2tlbnMgfSBmcm9tICdAcHJpbWVuZy90aGVtZXMvdHlwZXMvYnV0dG9uJztcblxuZXhwb3J0IGNvbnN0IHNpZGVCdXR0b25Ub2tlbnMgPSB7XG4gIHJvb3Q6IHtcbiAgICBwcmltYXJ5OiB7XG4gICAgICAvLyBUZXh0XG4gICAgICBjb2xvcjogJycsXG4gICAgICBib3JkZXJDb2xvcjogJ3t6aW5jLjUwfScsXG4gICAgICBob3ZlckNvbG9yOiAnJyxcbiAgICAgIGFjdGl2ZUNvbG9yOiAnJyxcbiAgICAgIC8vIEJhY2tncm91bmRcbiAgICAgIGJhY2tncm91bmQ6ICd7emluYy41MH0nLFxuICAgICAgaG92ZXJCYWNrZ3JvdW5kOiAne3ppbmMuNTB9JyxcbiAgICAgIGFjdGl2ZUJhY2tncm91bmQ6ICd7emluYy41MH0nLFxuICAgICAgLy8gQm9yZGVyXG4gICAgICBhY3RpdmVCb3JkZXJDb2xvcjogJ3t6aW5jLjUwfScsXG4gICAgICBob3ZlckJvcmRlckNvbG9yOiAne3ppbmMuNTB9JyxcbiAgICB9LFxuICB9LFxufSBzYXRpc2ZpZXMgQnV0dG9uRGVzaWduVG9rZW5zO1xuIl19
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZS1idXR0b24udG9rZW5zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc29mdHdhcmUtZGl2aXNpb24tY29tcG9uZW50cy9zcmMvZHZtL25laWdoYm91cnMvc3R5bGVzL3NpZGUtYnV0dG9uLnRva2Vucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxtREFBbUQ7QUFDbkQsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQUc7SUFDOUIsSUFBSSxFQUFFO1FBQ0osT0FBTyxFQUFFO1lBQ1AsT0FBTztZQUNQLEtBQUssRUFBRSxFQUFFO1lBQ1QsV0FBVyxFQUFFLFdBQVc7WUFDeEIsVUFBVSxFQUFFLEVBQUU7WUFDZCxXQUFXLEVBQUUsRUFBRTtZQUNmLGFBQWE7WUFDYixVQUFVLEVBQUUsV0FBVztZQUN2QixlQUFlLEVBQUUsV0FBVztZQUM1QixnQkFBZ0IsRUFBRSxXQUFXO1lBQzdCLFNBQVM7WUFDVCxpQkFBaUIsRUFBRSxXQUFXO1lBQzlCLGdCQUFnQixFQUFFLFdBQVc7U0FDOUI7S0FDRjtDQUMyQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQnV0dG9uRGVzaWduVG9rZW5zIH0gZnJvbSAnQHByaW1lbmcvdGhlbWVzL3R5cGVzL2J1dHRvbic7XG5cbi8vIFRPRE86IHRoaXMgcmVxdWlyZXMgYWRhcHRhdGlvbiB0byB0aGUgbmV3IGRlc2lnblxuZXhwb3J0IGNvbnN0IHNpZGVCdXR0b25Ub2tlbnMgPSB7XG4gIHJvb3Q6IHtcbiAgICBwcmltYXJ5OiB7XG4gICAgICAvLyBUZXh0XG4gICAgICBjb2xvcjogJycsXG4gICAgICBib3JkZXJDb2xvcjogJ3t6aW5jLjUwfScsXG4gICAgICBob3ZlckNvbG9yOiAnJyxcbiAgICAgIGFjdGl2ZUNvbG9yOiAnJyxcbiAgICAgIC8vIEJhY2tncm91bmRcbiAgICAgIGJhY2tncm91bmQ6ICd7emluYy41MH0nLFxuICAgICAgaG92ZXJCYWNrZ3JvdW5kOiAne3ppbmMuNTB9JyxcbiAgICAgIGFjdGl2ZUJhY2tncm91bmQ6ICd7emluYy41MH0nLFxuICAgICAgLy8gQm9yZGVyXG4gICAgICBhY3RpdmVCb3JkZXJDb2xvcjogJ3t6aW5jLjUwfScsXG4gICAgICBob3ZlckJvcmRlckNvbG9yOiAne3ppbmMuNTB9JyxcbiAgICB9LFxuICB9LFxufSBzYXRpc2ZpZXMgQnV0dG9uRGVzaWduVG9rZW5zO1xuIl19
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9zb2Z0d2FyZS1kaXZpc2lvbi1jb21wb25lbnRzL3NyYy9kdm0vbmVpZ2hib3Vycy90eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgRGlyZWN0aW9uID0gJ3ByZXYnIHwgJ25leHQnO1xuXG5leHBvcnQgdHlwZSBEaXJlY3Rpb25PYmplY3RLZXlzID0gJ2wnIHwgJ3InO1xuXG5leHBvcnQgdHlwZSBOZWlnaGJvdXJzU3R5bGVDbGFzc2VzID0ge1xuICBzaWRlQnV0dG9uc0NsYXNzPzogc3RyaW5nO1xuICBtaWRkbGVEaXZDbGFzcz86IHN0cmluZztcbn07XG4iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9zb2Z0d2FyZS1kaXZpc2lvbi1jb21wb25lbnRzL3NyYy9kdm0vbmVpZ2hib3Vycy90eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgRGlyZWN0aW9uID0gJ3ByZXYnIHwgJ25leHQnO1xuXG5leHBvcnQgdHlwZSBEaXJlY3Rpb25PYmplY3RLZXlzID0gJ2wnIHwgJ3InO1xuXG5leHBvcnQgdHlwZSBOZWlnaGJvdXJzRGF0YSA9IFJlY29yZDxzdHJpbmcsIFJlY29yZDxEaXJlY3Rpb25PYmplY3RLZXlzLCBzdHJpbmc+PjtcblxuZXhwb3J0IHR5cGUgTmVpZ2hib3Vyc1N0eWxlQ2xhc3NlcyA9IHtcbiAgc2lkZUJ1dHRvbnNDbGFzcz86IHN0cmluZztcbiAgbWlkZGxlRGl2Q2xhc3M/OiBzdHJpbmc7XG59O1xuIl19
@@ -15,7 +15,8 @@ import * as i3 from "primeng/tooltip";
15
15
  * This component supports various configurations, such as tooltips, badge values,
16
16
  * and theme styles. It uses the `ThemeProviderDirective` to apply theming dynamically.
17
17
  *
18
- * @class ButtonComponent
18
+ * @since 1.0.0-alpha.1
19
+ * @updated 1.0.0-alpha.2
19
20
  */
20
21
  export class ButtonComponent extends Button {
21
22
  props = input();
@@ -82,4 +83,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
82
83
  type: Component,
83
84
  args: [{ standalone: true, selector: 'sdc-button', providers: [ButtonStyle, Button, TooltipStyle], imports: [CommonModule, ButtonModule, TooltipModule, RippleModule, ThemeProviderDirective], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.Emulated, template: "<button\n pButton\n themeProvider\n id=\"sdc-button\"\n [buttonProps]=\"props()\"\n [dt]=\"dt\"\n [ngClass]=\"[themeClass, styleClasses()]\"\n [text]=\"text\"\n [label]=\"label\"\n [icon]=\"icon\"\n [type]=\"type\"\n [plain]=\"plain\"\n [fluid]=\"fluid\"\n [loading]=\"loading\"\n [rounded]=\"rounded\"\n [severity]=\"severity\"\n [outlined]=\"outlined\"\n [size]=\"size ?? null\"\n [pTooltip]=\"tooltip()\"\n [autofocus]=\"autofocus\"\n [loadingIcon]=\"loadingIcon\"\n [tooltipPosition]=\"tooltipPos()\"\n (click)=\"handleClick($event)\"\n (blur)=\"this.onBlur.emit($event)\">\n <ng-content></ng-content>\n</button>\n", styles: [":root{--p-button-primary-color: white !important;--p-button-primary-contrast-color: white !important;--p-button-primary-hover-color: white !important}\n"] }]
84
85
  }], ctorParameters: () => [] });
85
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3NvZnR3YXJlLWRpdmlzaW9uLWNvbXBvbmVudHMvc3JjL2dlbmVyaWMvYnV0dG9uL2J1dHRvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi9wcm9qZWN0cy9zb2Z0d2FyZS1kaXZpc2lvbi1jb21wb25lbnRzL3NyYy9nZW5lcmljL2J1dHRvbi9idXR0b24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFBO0FBQzlDLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFVLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFBO0FBQ3BHLE9BQU8sRUFBRSxNQUFNLEVBQUUsWUFBWSxFQUFlLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFBO0FBQy9FLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQTtBQUM3QyxPQUFPLEVBQUUsYUFBYSxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFBO0FBQzdELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLGNBQWMsQ0FBQTtBQUNyRCxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSwyQ0FBMkMsQ0FBQTs7Ozs7QUFFdEY7Ozs7Ozs7R0FPRztBQVdILE1BQU0sT0FBTyxlQUFnQixTQUFRLE1BQU07SUFDbEMsS0FBSyxHQUFHLEtBQUssRUFBZSxDQUFDO0lBRXBDOztPQUVHO0lBQ0ksT0FBTyxHQUFHLEtBQUssQ0FBUyxFQUFFLENBQUMsQ0FBQztJQUVuQzs7T0FFRztJQUNJLFVBQVUsR0FBRyxLQUFLLEVBQXlCLENBQUM7SUFFbkQ7O09BRUc7SUFDSSxVQUFVLEdBQUcsS0FBSyxDQUFTLEVBQUUsQ0FBQyxDQUFDO0lBRXRDOztPQUVHO0lBQ0ksZ0JBQWdCLEdBQUcsS0FBSyxDQUFTLENBQUMsQ0FBQyxDQUFDO0lBRTNDOzs7T0FHRztJQUNJLFlBQVksR0FBRyxLQUFLLENBQUMsRUFBRSxFQUFFLEVBQUUsU0FBUyxFQUFFLDBCQUEwQixDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBRWxHOztPQUVHO0lBQ0ssV0FBVyxHQUFHLEtBQUssQ0FBQztJQUU1Qjs7T0FFRztJQUNPLEtBQUssR0FBVyxFQUFFLENBQUM7SUFFN0I7O09BRUc7SUFDTyxVQUFVLEdBQVcsRUFBRSxDQUFDO0lBRWxDO1FBQ0UsS0FBSyxFQUFFLENBQUM7SUFDVixDQUFDO0lBRUQ7Ozs7Ozs7O09BUUc7SUFDSSxXQUFXLENBQUMsS0FBaUI7UUFDbEMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFFekIsSUFBSSxJQUFJLENBQUMsV0FBVyxJQUFJLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxJQUFJLENBQUM7WUFBRSxPQUFPO1FBRTdELElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDO1FBQ3JCLElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDO1FBRXhCLFVBQVUsQ0FBQyxHQUFHLEVBQUU7WUFDZCxJQUFJLENBQUMsUUFBUSxHQUFHLEtBQUssQ0FBQztZQUN0QixJQUFJLENBQUMsV0FBVyxHQUFHLEtBQUssQ0FBQztRQUMzQixDQUFDLEVBQUUsSUFBSSxDQUFDLGdCQUFnQixFQUFFLENBQUMsQ0FBQztJQUM5QixDQUFDO3dHQXJFVSxlQUFlOzRGQUFmLGVBQWUsKzJCQUxmLENBQUMsV0FBVyxFQUFFLE1BQU0sRUFBRSxZQUFZLENBQUMsaURDckJoRCxvb0JBMEJBLGlOREpZLFlBQVksNEhBQUUsWUFBWSxvUUFBRSxhQUFhLHFYQUFFLFlBQVksK0JBQUUsc0JBQXNCOzs0RkFJOUUsZUFBZTtrQkFWM0IsU0FBUztpQ0FDSSxJQUFJLFlBQ04sWUFBWSxhQUdYLENBQUMsV0FBVyxFQUFFLE1BQU0sRUFBRSxZQUFZLENBQUMsV0FDckMsQ0FBQyxZQUFZLEVBQUUsWUFBWSxFQUFFLGFBQWEsRUFBRSxZQUFZLEVBQUUsc0JBQXNCLENBQUMsbUJBQ3pFLHVCQUF1QixDQUFDLE1BQU0saUJBQ2hDLGlCQUFpQixDQUFDLFFBQVEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nXG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBpbnB1dCwgT25Jbml0LCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5pbXBvcnQgeyBCdXR0b24sIEJ1dHRvbk1vZHVsZSwgQnV0dG9uUHJvcHMsIEJ1dHRvblN0eWxlIH0gZnJvbSAncHJpbWVuZy9idXR0b24nXG5pbXBvcnQgeyBSaXBwbGVNb2R1bGUgfSBmcm9tICdwcmltZW5nL3JpcHBsZSdcbmltcG9ydCB7IFRvb2x0aXBNb2R1bGUsIFRvb2x0aXBTdHlsZSB9IGZyb20gJ3ByaW1lbmcvdG9vbHRpcCdcbmltcG9ydCB7IFRoZW1lUHJvdmlkZXJEaXJlY3RpdmUgfSBmcm9tICcuLi8uLi9zaGFyZWQnXG5pbXBvcnQgeyB2YWxpZGF0ZVN0eWxlc0ZvckNvbXBvbmVudCB9IGZyb20gJy4uLy4uL3V0aWxzL3ZhbGlkYXRlLXN0eWxlcy1mb3ItY29tcG9uZW50J1xuaW1wb3J0IHsgVmFsaWRUb29sdGlwUG9zaXRpb25zIH0gZnJvbSAnLi90eXBlcydcbi8qKlxuICogQSBjdXN0b21pemFibGUgYnV0dG9uIGNvbXBvbmVudCBidWlsdCBvbiBQcmltZU5HJ3MgQnV0dG9uIGNvbXBvbmVudC5cbiAqXG4gKiBUaGlzIGNvbXBvbmVudCBzdXBwb3J0cyB2YXJpb3VzIGNvbmZpZ3VyYXRpb25zLCBzdWNoIGFzIHRvb2x0aXBzLCBiYWRnZSB2YWx1ZXMsXG4gKiBhbmQgdGhlbWUgc3R5bGVzLiBJdCB1c2VzIHRoZSBgVGhlbWVQcm92aWRlckRpcmVjdGl2ZWAgdG8gYXBwbHkgdGhlbWluZyBkeW5hbWljYWxseS5cbiAqXG4gKiBAY2xhc3MgQnV0dG9uQ29tcG9uZW50XG4gKi9cbkBDb21wb25lbnQoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBzZWxlY3RvcjogJ3NkYy1idXR0b24nLFxuICBzdHlsZVVybHM6IFsnLi9idXR0b24uY29tcG9uZW50LmNzcyddLFxuICB0ZW1wbGF0ZVVybDogJy4vYnV0dG9uLmNvbXBvbmVudC5odG1sJyxcbiAgcHJvdmlkZXJzOiBbQnV0dG9uU3R5bGUsIEJ1dHRvbiwgVG9vbHRpcFN0eWxlXSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgQnV0dG9uTW9kdWxlLCBUb29sdGlwTW9kdWxlLCBSaXBwbGVNb2R1bGUsIFRoZW1lUHJvdmlkZXJEaXJlY3RpdmVdLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uRW11bGF0ZWRcbn0pXG5leHBvcnQgY2xhc3MgQnV0dG9uQ29tcG9uZW50IGV4dGVuZHMgQnV0dG9uIGltcGxlbWVudHMgT25Jbml0IHtcbiAgcHVibGljIHByb3BzID0gaW5wdXQ8QnV0dG9uUHJvcHM+KCk7XG5cbiAgLyoqXG4gICAqIFRvb2x0aXAgdGV4dCBmb3IgdGhlIGJ1dHRvbi5cbiAgICovXG4gIHB1YmxpYyB0b29sdGlwID0gaW5wdXQ8c3RyaW5nPignJyk7XG5cbiAgLyoqXG4gICAqIFRvb2x0aXAgcG9zaXRpb24gcmVsYXRpdmUgdG8gdGhlIGJ1dHRvbi5cbiAgICovXG4gIHB1YmxpYyB0b29sdGlwUG9zID0gaW5wdXQ8VmFsaWRUb29sdGlwUG9zaXRpb25zPigpO1xuXG4gIC8qKlxuICAgKiBWYWx1ZSBkaXNwbGF5ZWQgYXMgYSBiYWRnZSBvbiB0aGUgYnV0dG9uLlxuICAgKi9cbiAgcHVibGljIGJhZGdlVmFsdWUgPSBpbnB1dDxzdHJpbmc+KCcnKTtcblxuICAvKipcbiAgICogVmFsdWUgZGlzcGxheWVkIGFzIGEgYmFkZ2Ugb24gdGhlIGJ1dHRvbi5cbiAgICovXG4gIHB1YmxpYyBkZWJvdW5jZVRpbWVJbk1zID0gaW5wdXQ8bnVtYmVyPigwKTtcblxuICAvKipcbiAgICogU2luZ2xlIHN0cmluZyBvciB3aGl0ZXNwYWNlLXNlcGFyYXRlZCBzdHJpbmcgb2YgYWRkaXRpb25hbCBzdHlsZSBjbGFzc2VzIGZvciB0aGUgYnV0dG9uLlxuICAgKiBPbmx5IGFjY2VwdHMgdmFsaWQgd2hpdGVzcGFjZS1zZXBhcmF0ZWQgY2xhc3MgbmFtZXMuXG4gICAqL1xuICBwdWJsaWMgc3R5bGVDbGFzc2VzID0gaW5wdXQoJycsIHsgdHJhbnNmb3JtOiB2YWxpZGF0ZVN0eWxlc0ZvckNvbXBvbmVudCh0aGlzLmNvbnN0cnVjdG9yLm5hbWUpIH0pO1xuXG4gIC8qKlxuICAgKiBUcmFja3Mgd2hldGhlciB0aGUgYnV0dG9uIGlzIGluIGEgZGVib3VuY2VkIHN0YXRlLlxuICAgKi9cbiAgcHJpdmF0ZSBpc0RlYm91bmNlZCA9IGZhbHNlO1xuXG4gIC8qKlxuICAgKiBUaGUgY3VycmVudCB0aGVtZSBhcHBsaWVkIHRvIHRoZSBidXR0b24uIFRoaXMgaXMgc2V0IGJ5IHRoZSBgVGhlbWVQcm92aWRlckRpcmVjdGl2ZWAuXG4gICAqL1xuICBwcm90ZWN0ZWQgdGhlbWU6IHN0cmluZyA9ICcnO1xuXG4gIC8qKlxuICAgKiBDU1MgY2xhc3MgYmFzZWQgb24gdGhlIHRoZW1lLiBUaGlzIGlzIGR5bmFtaWNhbGx5IGdlbmVyYXRlZC5cbiAgICovXG4gIHByb3RlY3RlZCB0aGVtZUNsYXNzOiBzdHJpbmcgPSAnJztcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICBzdXBlcigpO1xuICB9XG5cbiAgLyoqXG4gICAqIEhhbmRsZXMgdGhlIGNsaWNrIGV2ZW50IGZvciB0aGUgYnV0dG9uIHdpdGggZGVib3VuY2UgbG9naWMuXG4gICAqXG4gICAqIFRoaXMgbWV0aG9kIHByZXZlbnRzIG11bHRpcGxlIHJhcGlkIGNsaWNrcyBieSBkaXNhYmxpbmcgdGhlIGJ1dHRvblxuICAgKiBmb3IgdGhlIHNwZWNpZmllZCBkZWJvdW5jZSB0aW1lLiBJZiBgZGVib3VuY2VUaW1lYCBpcyBzZXQgdG8gMCxcbiAgICogdGhlIGJ1dHRvbiByZW1haW5zIGludGVyYWN0aXZlIHdpdGhvdXQgZGVib3VuY2UgYmVoYXZpb3IuXG4gICAqXG4gICAqIEBwYXJhbSBldmVudCAtIFRoZSBjbGljayBldmVudCB0cmlnZ2VyZWQgYnkgdGhlIHVzZXIuXG4gICAqL1xuICBwdWJsaWMgaGFuZGxlQ2xpY2soZXZlbnQ6IE1vdXNlRXZlbnQpOiB2b2lkIHtcbiAgICB0aGlzLm9uQ2xpY2suZW1pdChldmVudCk7XG5cbiAgICBpZiAodGhpcy5pc0RlYm91bmNlZCB8fCB0aGlzLmRlYm91bmNlVGltZUluTXMoKSA8PSAwKSByZXR1cm47XG5cbiAgICB0aGlzLmRpc2FibGVkID0gdHJ1ZTtcbiAgICB0aGlzLmlzRGVib3VuY2VkID0gdHJ1ZTtcblxuICAgIHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgdGhpcy5kaXNhYmxlZCA9IGZhbHNlO1xuICAgICAgdGhpcy5pc0RlYm91bmNlZCA9IGZhbHNlO1xuICAgIH0sIHRoaXMuZGVib3VuY2VUaW1lSW5NcygpKTtcbiAgfVxufVxuIiwiPGJ1dHRvblxuICBwQnV0dG9uXG4gIHRoZW1lUHJvdmlkZXJcbiAgaWQ9XCJzZGMtYnV0dG9uXCJcbiAgW2J1dHRvblByb3BzXT1cInByb3BzKClcIlxuICBbZHRdPVwiZHRcIlxuICBbbmdDbGFzc109XCJbdGhlbWVDbGFzcywgc3R5bGVDbGFzc2VzKCldXCJcbiAgW3RleHRdPVwidGV4dFwiXG4gIFtsYWJlbF09XCJsYWJlbFwiXG4gIFtpY29uXT1cImljb25cIlxuICBbdHlwZV09XCJ0eXBlXCJcbiAgW3BsYWluXT1cInBsYWluXCJcbiAgW2ZsdWlkXT1cImZsdWlkXCJcbiAgW2xvYWRpbmddPVwibG9hZGluZ1wiXG4gIFtyb3VuZGVkXT1cInJvdW5kZWRcIlxuICBbc2V2ZXJpdHldPVwic2V2ZXJpdHlcIlxuICBbb3V0bGluZWRdPVwib3V0bGluZWRcIlxuICBbc2l6ZV09XCJzaXplID8/IG51bGxcIlxuICBbcFRvb2x0aXBdPVwidG9vbHRpcCgpXCJcbiAgW2F1dG9mb2N1c109XCJhdXRvZm9jdXNcIlxuICBbbG9hZGluZ0ljb25dPVwibG9hZGluZ0ljb25cIlxuICBbdG9vbHRpcFBvc2l0aW9uXT1cInRvb2x0aXBQb3MoKVwiXG4gIChjbGljayk9XCJoYW5kbGVDbGljaygkZXZlbnQpXCJcbiAgKGJsdXIpPVwidGhpcy5vbkJsdXIuZW1pdCgkZXZlbnQpXCI+XG4gIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbjwvYnV0dG9uPlxuIl19
86
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3NvZnR3YXJlLWRpdmlzaW9uLWNvbXBvbmVudHMvc3JjL2dlbmVyaWMvYnV0dG9uL2J1dHRvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi9wcm9qZWN0cy9zb2Z0d2FyZS1kaXZpc2lvbi1jb21wb25lbnRzL3NyYy9nZW5lcmljL2J1dHRvbi9idXR0b24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzdGLE9BQU8sRUFBRSxNQUFNLEVBQUUsWUFBWSxFQUFlLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2hGLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM5QyxPQUFPLEVBQUUsYUFBYSxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQzlELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUN0RCxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSwyQ0FBMkMsQ0FBQzs7Ozs7QUFFdkY7Ozs7Ozs7O0dBUUc7QUFXSCxNQUFNLE9BQU8sZUFBZ0IsU0FBUSxNQUFNO0lBQ2xDLEtBQUssR0FBRyxLQUFLLEVBQWUsQ0FBQztJQUVwQzs7T0FFRztJQUNJLE9BQU8sR0FBRyxLQUFLLENBQVMsRUFBRSxDQUFDLENBQUM7SUFFbkM7O09BRUc7SUFDSSxVQUFVLEdBQUcsS0FBSyxFQUF5QixDQUFDO0lBRW5EOztPQUVHO0lBQ0ksVUFBVSxHQUFHLEtBQUssQ0FBUyxFQUFFLENBQUMsQ0FBQztJQUV0Qzs7T0FFRztJQUNJLGdCQUFnQixHQUFHLEtBQUssQ0FBUyxDQUFDLENBQUMsQ0FBQztJQUUzQzs7O09BR0c7SUFDSSxZQUFZLEdBQUcsS0FBSyxDQUFDLEVBQUUsRUFBRSxFQUFFLFNBQVMsRUFBRSwwQkFBMEIsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUVsRzs7T0FFRztJQUNLLFdBQVcsR0FBRyxLQUFLLENBQUM7SUFFNUI7O09BRUc7SUFDTyxLQUFLLEdBQVcsRUFBRSxDQUFDO0lBRTdCOztPQUVHO0lBQ08sVUFBVSxHQUFXLEVBQUUsQ0FBQztJQUVsQztRQUNFLEtBQUssRUFBRSxDQUFDO0lBQ1YsQ0FBQztJQUVEOzs7Ozs7OztPQVFHO0lBQ0ksV0FBVyxDQUFDLEtBQWlCO1FBQ2xDLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBRXpCLElBQUksSUFBSSxDQUFDLFdBQVcsSUFBSSxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsSUFBSSxDQUFDO1lBQUUsT0FBTztRQUU3RCxJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQztRQUNyQixJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQztRQUV4QixVQUFVLENBQUMsR0FBRyxFQUFFO1lBQ2QsSUFBSSxDQUFDLFFBQVEsR0FBRyxLQUFLLENBQUM7WUFDdEIsSUFBSSxDQUFDLFdBQVcsR0FBRyxLQUFLLENBQUM7UUFDM0IsQ0FBQyxFQUFFLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDLENBQUM7SUFDOUIsQ0FBQzt3R0FyRVUsZUFBZTs0RkFBZixlQUFlLCsyQkFMZixDQUFDLFdBQVcsRUFBRSxNQUFNLEVBQUUsWUFBWSxDQUFDLGlEQ3RCaEQsb29CQTBCQSxpTkRIWSxZQUFZLDRIQUFFLFlBQVksb1FBQUUsYUFBYSxxWEFBRSxZQUFZLCtCQUFFLHNCQUFzQjs7NEZBSTlFLGVBQWU7a0JBVjNCLFNBQVM7aUNBQ0ksSUFBSSxZQUNOLFlBQVksYUFHWCxDQUFDLFdBQVcsRUFBRSxNQUFNLEVBQUUsWUFBWSxDQUFDLFdBQ3JDLENBQUMsWUFBWSxFQUFFLFlBQVksRUFBRSxhQUFhLEVBQUUsWUFBWSxFQUFFLHNCQUFzQixDQUFDLG1CQUN6RSx1QkFBdUIsQ0FBQyxNQUFNLGlCQUNoQyxpQkFBaUIsQ0FBQyxRQUFRIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGlucHV0LCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQnV0dG9uLCBCdXR0b25Nb2R1bGUsIEJ1dHRvblByb3BzLCBCdXR0b25TdHlsZSB9IGZyb20gJ3ByaW1lbmcvYnV0dG9uJztcbmltcG9ydCB7IFJpcHBsZU1vZHVsZSB9IGZyb20gJ3ByaW1lbmcvcmlwcGxlJztcbmltcG9ydCB7IFRvb2x0aXBNb2R1bGUsIFRvb2x0aXBTdHlsZSB9IGZyb20gJ3ByaW1lbmcvdG9vbHRpcCc7XG5pbXBvcnQgeyBUaGVtZVByb3ZpZGVyRGlyZWN0aXZlIH0gZnJvbSAnLi4vLi4vc2hhcmVkJztcbmltcG9ydCB7IHZhbGlkYXRlU3R5bGVzRm9yQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vdXRpbHMvdmFsaWRhdGUtc3R5bGVzLWZvci1jb21wb25lbnQnO1xuaW1wb3J0IHsgVmFsaWRUb29sdGlwUG9zaXRpb25zIH0gZnJvbSAnLi90eXBlcyc7XG4vKipcbiAqIEEgY3VzdG9taXphYmxlIGJ1dHRvbiBjb21wb25lbnQgYnVpbHQgb24gUHJpbWVORydzIEJ1dHRvbiBjb21wb25lbnQuXG4gKlxuICogVGhpcyBjb21wb25lbnQgc3VwcG9ydHMgdmFyaW91cyBjb25maWd1cmF0aW9ucywgc3VjaCBhcyB0b29sdGlwcywgYmFkZ2UgdmFsdWVzLFxuICogYW5kIHRoZW1lIHN0eWxlcy4gSXQgdXNlcyB0aGUgYFRoZW1lUHJvdmlkZXJEaXJlY3RpdmVgIHRvIGFwcGx5IHRoZW1pbmcgZHluYW1pY2FsbHkuXG4gKlxuICogQHNpbmNlIDEuMC4wLWFscGhhLjFcbiAqIEB1cGRhdGVkIDEuMC4wLWFscGhhLjJcbiAqL1xuQENvbXBvbmVudCh7XG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHNlbGVjdG9yOiAnc2RjLWJ1dHRvbicsXG4gIHN0eWxlVXJsczogWycuL2J1dHRvbi5jb21wb25lbnQuY3NzJ10sXG4gIHRlbXBsYXRlVXJsOiAnLi9idXR0b24uY29tcG9uZW50Lmh0bWwnLFxuICBwcm92aWRlcnM6IFtCdXR0b25TdHlsZSwgQnV0dG9uLCBUb29sdGlwU3R5bGVdLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBCdXR0b25Nb2R1bGUsIFRvb2x0aXBNb2R1bGUsIFJpcHBsZU1vZHVsZSwgVGhlbWVQcm92aWRlckRpcmVjdGl2ZV0sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5FbXVsYXRlZCxcbn0pXG5leHBvcnQgY2xhc3MgQnV0dG9uQ29tcG9uZW50IGV4dGVuZHMgQnV0dG9uIHtcbiAgcHVibGljIHByb3BzID0gaW5wdXQ8QnV0dG9uUHJvcHM+KCk7XG5cbiAgLyoqXG4gICAqIFRvb2x0aXAgdGV4dCBmb3IgdGhlIGJ1dHRvbi5cbiAgICovXG4gIHB1YmxpYyB0b29sdGlwID0gaW5wdXQ8c3RyaW5nPignJyk7XG5cbiAgLyoqXG4gICAqIFRvb2x0aXAgcG9zaXRpb24gcmVsYXRpdmUgdG8gdGhlIGJ1dHRvbi5cbiAgICovXG4gIHB1YmxpYyB0b29sdGlwUG9zID0gaW5wdXQ8VmFsaWRUb29sdGlwUG9zaXRpb25zPigpO1xuXG4gIC8qKlxuICAgKiBWYWx1ZSBkaXNwbGF5ZWQgYXMgYSBiYWRnZSBvbiB0aGUgYnV0dG9uLlxuICAgKi9cbiAgcHVibGljIGJhZGdlVmFsdWUgPSBpbnB1dDxzdHJpbmc+KCcnKTtcblxuICAvKipcbiAgICogVmFsdWUgZGlzcGxheWVkIGFzIGEgYmFkZ2Ugb24gdGhlIGJ1dHRvbi5cbiAgICovXG4gIHB1YmxpYyBkZWJvdW5jZVRpbWVJbk1zID0gaW5wdXQ8bnVtYmVyPigwKTtcblxuICAvKipcbiAgICogU2luZ2xlIHN0cmluZyBvciB3aGl0ZXNwYWNlLXNlcGFyYXRlZCBzdHJpbmcgb2YgYWRkaXRpb25hbCBzdHlsZSBjbGFzc2VzIGZvciB0aGUgYnV0dG9uLlxuICAgKiBPbmx5IGFjY2VwdHMgdmFsaWQgd2hpdGVzcGFjZS1zZXBhcmF0ZWQgY2xhc3MgbmFtZXMuXG4gICAqL1xuICBwdWJsaWMgc3R5bGVDbGFzc2VzID0gaW5wdXQoJycsIHsgdHJhbnNmb3JtOiB2YWxpZGF0ZVN0eWxlc0ZvckNvbXBvbmVudCh0aGlzLmNvbnN0cnVjdG9yLm5hbWUpIH0pO1xuXG4gIC8qKlxuICAgKiBUcmFja3Mgd2hldGhlciB0aGUgYnV0dG9uIGlzIGluIGEgZGVib3VuY2VkIHN0YXRlLlxuICAgKi9cbiAgcHJpdmF0ZSBpc0RlYm91bmNlZCA9IGZhbHNlO1xuXG4gIC8qKlxuICAgKiBUaGUgY3VycmVudCB0aGVtZSBhcHBsaWVkIHRvIHRoZSBidXR0b24uIFRoaXMgaXMgc2V0IGJ5IHRoZSBgVGhlbWVQcm92aWRlckRpcmVjdGl2ZWAuXG4gICAqL1xuICBwcm90ZWN0ZWQgdGhlbWU6IHN0cmluZyA9ICcnO1xuXG4gIC8qKlxuICAgKiBDU1MgY2xhc3MgYmFzZWQgb24gdGhlIHRoZW1lLiBUaGlzIGlzIGR5bmFtaWNhbGx5IGdlbmVyYXRlZC5cbiAgICovXG4gIHByb3RlY3RlZCB0aGVtZUNsYXNzOiBzdHJpbmcgPSAnJztcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICBzdXBlcigpO1xuICB9XG5cbiAgLyoqXG4gICAqIEhhbmRsZXMgdGhlIGNsaWNrIGV2ZW50IGZvciB0aGUgYnV0dG9uIHdpdGggZGVib3VuY2UgbG9naWMuXG4gICAqXG4gICAqIFRoaXMgbWV0aG9kIHByZXZlbnRzIG11bHRpcGxlIHJhcGlkIGNsaWNrcyBieSBkaXNhYmxpbmcgdGhlIGJ1dHRvblxuICAgKiBmb3IgdGhlIHNwZWNpZmllZCBkZWJvdW5jZSB0aW1lLiBJZiBgZGVib3VuY2VUaW1lYCBpcyBzZXQgdG8gMCxcbiAgICogdGhlIGJ1dHRvbiByZW1haW5zIGludGVyYWN0aXZlIHdpdGhvdXQgZGVib3VuY2UgYmVoYXZpb3IuXG4gICAqXG4gICAqIEBwYXJhbSBldmVudCAtIFRoZSBjbGljayBldmVudCB0cmlnZ2VyZWQgYnkgdGhlIHVzZXIuXG4gICAqL1xuICBwdWJsaWMgaGFuZGxlQ2xpY2soZXZlbnQ6IE1vdXNlRXZlbnQpOiB2b2lkIHtcbiAgICB0aGlzLm9uQ2xpY2suZW1pdChldmVudCk7XG5cbiAgICBpZiAodGhpcy5pc0RlYm91bmNlZCB8fCB0aGlzLmRlYm91bmNlVGltZUluTXMoKSA8PSAwKSByZXR1cm47XG5cbiAgICB0aGlzLmRpc2FibGVkID0gdHJ1ZTtcbiAgICB0aGlzLmlzRGVib3VuY2VkID0gdHJ1ZTtcblxuICAgIHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgdGhpcy5kaXNhYmxlZCA9IGZhbHNlO1xuICAgICAgdGhpcy5pc0RlYm91bmNlZCA9IGZhbHNlO1xuICAgIH0sIHRoaXMuZGVib3VuY2VUaW1lSW5NcygpKTtcbiAgfVxufVxuIiwiPGJ1dHRvblxuICBwQnV0dG9uXG4gIHRoZW1lUHJvdmlkZXJcbiAgaWQ9XCJzZGMtYnV0dG9uXCJcbiAgW2J1dHRvblByb3BzXT1cInByb3BzKClcIlxuICBbZHRdPVwiZHRcIlxuICBbbmdDbGFzc109XCJbdGhlbWVDbGFzcywgc3R5bGVDbGFzc2VzKCldXCJcbiAgW3RleHRdPVwidGV4dFwiXG4gIFtsYWJlbF09XCJsYWJlbFwiXG4gIFtpY29uXT1cImljb25cIlxuICBbdHlwZV09XCJ0eXBlXCJcbiAgW3BsYWluXT1cInBsYWluXCJcbiAgW2ZsdWlkXT1cImZsdWlkXCJcbiAgW2xvYWRpbmddPVwibG9hZGluZ1wiXG4gIFtyb3VuZGVkXT1cInJvdW5kZWRcIlxuICBbc2V2ZXJpdHldPVwic2V2ZXJpdHlcIlxuICBbb3V0bGluZWRdPVwib3V0bGluZWRcIlxuICBbc2l6ZV09XCJzaXplID8/IG51bGxcIlxuICBbcFRvb2x0aXBdPVwidG9vbHRpcCgpXCJcbiAgW2F1dG9mb2N1c109XCJhdXRvZm9jdXNcIlxuICBbbG9hZGluZ0ljb25dPVwibG9hZGluZ0ljb25cIlxuICBbdG9vbHRpcFBvc2l0aW9uXT1cInRvb2x0aXBQb3MoKVwiXG4gIChjbGljayk9XCJoYW5kbGVDbGljaygkZXZlbnQpXCJcbiAgKGJsdXIpPVwidGhpcy5vbkJsdXIuZW1pdCgkZXZlbnQpXCI+XG4gIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbjwvYnV0dG9uPlxuIl19
@@ -9,6 +9,10 @@ function validateCssClass(value, componentName) {
9
9
  }
10
10
  export function validateStylesForComponent(componentName) {
11
11
  return (styles) => {
12
+ // Styles will be an empty string if they are not defined
13
+ if (styles === '') {
14
+ return styles;
15
+ }
12
16
  if (typeof styles === 'string') {
13
17
  // Some components just have to style one element,
14
18
  // so a string input is sufficient
@@ -26,4 +30,4 @@ export function validateStylesForComponent(componentName) {
26
30
  return styles;
27
31
  };
28
32
  }
29
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdGUtc3R5bGVzLWZvci1jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wcm9qZWN0cy9zb2Z0d2FyZS1kaXZpc2lvbi1jb21wb25lbnRzL3NyYy91dGlscy92YWxpZGF0ZS1zdHlsZXMtZm9yLWNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxTQUFTLGdCQUFnQixDQUFDLEtBQWEsRUFBRSxhQUFzQjtJQUM3RCxNQUFNLEtBQUssR0FBRyx1REFBdUQsQ0FBQztJQUN0RSxNQUFNLGVBQWUsR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBRTFDLElBQUksQ0FBQyxlQUFlLEVBQUU7UUFDcEIsTUFBTSxJQUFJLEtBQUssQ0FDYiw4RUFBOEUsYUFBYTs7Z0NBRWpFLEtBQUssRUFBRSxDQUNsQyxDQUFDO0tBQ0g7QUFDSCxDQUFDO0FBRUQsTUFBTSxVQUFVLDBCQUEwQixDQUN4QyxhQUFxQjtJQUVyQixPQUFPLENBQUMsTUFBUyxFQUFLLEVBQUU7UUFDdEIsSUFBSSxPQUFPLE1BQU0sS0FBSyxRQUFRLEVBQUU7WUFDOUIsa0RBQWtEO1lBQ2xELGtDQUFrQztZQUNsQyxnQkFBZ0IsQ0FBQyxNQUFNLEVBQUUsYUFBYSxDQUFDLENBQUM7U0FDekM7YUFBTTtZQUNMLHFEQUFxRDtZQUNyRCw2REFBNkQ7WUFDN0QscUVBQXFFO1lBQ3JFLE1BQU0sWUFBWSxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUM7WUFDM0MsS0FBSyxNQUFNLFVBQVUsSUFBSSxZQUFZLEVBQUU7Z0JBQ3JDLGdCQUFnQixDQUFDLFVBQVUsRUFBRSxhQUFhLENBQUMsQ0FBQzthQUM3QztTQUNGO1FBRUQsT0FBTyxNQUFNLENBQUM7SUFDaEIsQ0FBQyxDQUFDO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImZ1bmN0aW9uIHZhbGlkYXRlQ3NzQ2xhc3ModmFsdWU6IHN0cmluZywgY29tcG9uZW50TmFtZT86IHN0cmluZyk6IGFzc2VydHMgdmFsdWUgaXMgc3RyaW5nIHtcbiAgY29uc3QgcmVnZXggPSAvXihbYS16QS1aXVthLXpBLVowLTktX10qKShcXHNbYS16QS1aXVthLXpBLVowLTktX10qKSokLztcbiAgY29uc3QgaXNWYWxpZENzc0NsYXNzID0gcmVnZXgudGVzdCh2YWx1ZSk7XG5cbiAgaWYgKCFpc1ZhbGlkQ3NzQ2xhc3MpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICBgSW52YWxpZCBDU1MgY2xhc3Mgc3RyaW5nIHBhc3NlZCBhcyBpbnB1dCB0byBcInN0eWxlQ2xhc3Nlc1wiIGlucHV0LCBmb3VuZCBvbiAke2NvbXBvbmVudE5hbWV9LlxuICAgICAgUGxlYXNlIG1ha2Ugc3VyZSB5b3VyIGlucHV0IGlzIGEgdmFsaWQgQ1NTIGNsYXNzIG9yIGEgbGlzdCBvZiB3aGl0ZXNwYWNlLXNlcGFyYXRlZCBjbGFzc2VzLlxuICAgICAgVGhlIHZhbHVlIHByb3ZpZGVkIHdhczogJHt2YWx1ZX1gXG4gICAgKTtcbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gdmFsaWRhdGVTdHlsZXNGb3JDb21wb25lbnQ8VCBleHRlbmRzIFJlY29yZDxzdHJpbmcsIHN0cmluZz4gfCBzdHJpbmc+KFxuICBjb21wb25lbnROYW1lOiBzdHJpbmdcbik6IChzdHlsZXM6IFQpID0+IFQge1xuICByZXR1cm4gKHN0eWxlczogVCk6IFQgPT4ge1xuICAgIGlmICh0eXBlb2Ygc3R5bGVzID09PSAnc3RyaW5nJykge1xuICAgICAgLy8gU29tZSBjb21wb25lbnRzIGp1c3QgaGF2ZSB0byBzdHlsZSBvbmUgZWxlbWVudCxcbiAgICAgIC8vIHNvIGEgc3RyaW5nIGlucHV0IGlzIHN1ZmZpY2llbnRcbiAgICAgIHZhbGlkYXRlQ3NzQ2xhc3Moc3R5bGVzLCBjb21wb25lbnROYW1lKTtcbiAgICB9IGVsc2Uge1xuICAgICAgLy8gV2hpbGUgb3RoZXJzIHJlcXVpcmUgYW4gb2JqZWN0IG90IGJlIGFibGUgdG8gc3R5bGVcbiAgICAgIC8vIGRpZmZlcmVudCBwYXJ0cyBvZiB0aGUgY29tcG9uZW50LCB3aGljaCByZXF1aXJlcyBhbiBvYmplY3RcbiAgICAgIC8vIHRvIHRhcmdldCBkaWZmZXJlbnQgcGFydHMgb2YgdGhlIGNvbXBvbmVudHMgd2l0aCBkaWZmZXJlbnQgY2xhc3Nlc1xuICAgICAgY29uc3Qgc3R5bGVzVmFsdWVzID0gT2JqZWN0LnZhbHVlcyhzdHlsZXMpO1xuICAgICAgZm9yIChjb25zdCBzdHlsZVZhbHVlIG9mIHN0eWxlc1ZhbHVlcykge1xuICAgICAgICB2YWxpZGF0ZUNzc0NsYXNzKHN0eWxlVmFsdWUsIGNvbXBvbmVudE5hbWUpO1xuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiBzdHlsZXM7XG4gIH07XG59XG4iXX0=
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdGUtc3R5bGVzLWZvci1jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wcm9qZWN0cy9zb2Z0d2FyZS1kaXZpc2lvbi1jb21wb25lbnRzL3NyYy91dGlscy92YWxpZGF0ZS1zdHlsZXMtZm9yLWNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxTQUFTLGdCQUFnQixDQUFDLEtBQWEsRUFBRSxhQUFzQjtJQUM3RCxNQUFNLEtBQUssR0FBRyx1REFBdUQsQ0FBQztJQUN0RSxNQUFNLGVBQWUsR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBRTFDLElBQUksQ0FBQyxlQUFlLEVBQUU7UUFDcEIsTUFBTSxJQUFJLEtBQUssQ0FDYiw4RUFBOEUsYUFBYTs7Z0NBRWpFLEtBQUssRUFBRSxDQUNsQyxDQUFDO0tBQ0g7QUFDSCxDQUFDO0FBRUQsTUFBTSxVQUFVLDBCQUEwQixDQUN4QyxhQUFxQjtJQUVyQixPQUFPLENBQUMsTUFBUyxFQUFLLEVBQUU7UUFDdEIseURBQXlEO1FBQ3pELElBQUksTUFBTSxLQUFLLEVBQUUsRUFBRTtZQUNqQixPQUFPLE1BQU0sQ0FBQztTQUNmO1FBRUQsSUFBSSxPQUFPLE1BQU0sS0FBSyxRQUFRLEVBQUU7WUFDOUIsa0RBQWtEO1lBQ2xELGtDQUFrQztZQUNsQyxnQkFBZ0IsQ0FBQyxNQUFNLEVBQUUsYUFBYSxDQUFDLENBQUM7U0FDekM7YUFBTTtZQUNMLHFEQUFxRDtZQUNyRCw2REFBNkQ7WUFDN0QscUVBQXFFO1lBQ3JFLE1BQU0sWUFBWSxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUM7WUFDM0MsS0FBSyxNQUFNLFVBQVUsSUFBSSxZQUFZLEVBQUU7Z0JBQ3JDLGdCQUFnQixDQUFDLFVBQVUsRUFBRSxhQUFhLENBQUMsQ0FBQzthQUM3QztTQUNGO1FBRUQsT0FBTyxNQUFNLENBQUM7SUFDaEIsQ0FBQyxDQUFDO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImZ1bmN0aW9uIHZhbGlkYXRlQ3NzQ2xhc3ModmFsdWU6IHN0cmluZywgY29tcG9uZW50TmFtZT86IHN0cmluZyk6IGFzc2VydHMgdmFsdWUgaXMgc3RyaW5nIHtcbiAgY29uc3QgcmVnZXggPSAvXihbYS16QS1aXVthLXpBLVowLTktX10qKShcXHNbYS16QS1aXVthLXpBLVowLTktX10qKSokLztcbiAgY29uc3QgaXNWYWxpZENzc0NsYXNzID0gcmVnZXgudGVzdCh2YWx1ZSk7XG5cbiAgaWYgKCFpc1ZhbGlkQ3NzQ2xhc3MpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICBgSW52YWxpZCBDU1MgY2xhc3Mgc3RyaW5nIHBhc3NlZCBhcyBpbnB1dCB0byBcInN0eWxlQ2xhc3Nlc1wiIGlucHV0LCBmb3VuZCBvbiAke2NvbXBvbmVudE5hbWV9LlxuICAgICAgUGxlYXNlIG1ha2Ugc3VyZSB5b3VyIGlucHV0IGlzIGEgdmFsaWQgQ1NTIGNsYXNzIG9yIGEgbGlzdCBvZiB3aGl0ZXNwYWNlLXNlcGFyYXRlZCBjbGFzc2VzLlxuICAgICAgVGhlIHZhbHVlIHByb3ZpZGVkIHdhczogJHt2YWx1ZX1gXG4gICAgKTtcbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gdmFsaWRhdGVTdHlsZXNGb3JDb21wb25lbnQ8VCBleHRlbmRzIFJlY29yZDxzdHJpbmcsIHN0cmluZz4gfCBzdHJpbmc+KFxuICBjb21wb25lbnROYW1lOiBzdHJpbmdcbik6IChzdHlsZXM6IFQpID0+IFQge1xuICByZXR1cm4gKHN0eWxlczogVCk6IFQgPT4ge1xuICAgIC8vIFN0eWxlcyB3aWxsIGJlIGFuIGVtcHR5IHN0cmluZyBpZiB0aGV5IGFyZSBub3QgZGVmaW5lZFxuICAgIGlmIChzdHlsZXMgPT09ICcnKSB7XG4gICAgICByZXR1cm4gc3R5bGVzO1xuICAgIH1cblxuICAgIGlmICh0eXBlb2Ygc3R5bGVzID09PSAnc3RyaW5nJykge1xuICAgICAgLy8gU29tZSBjb21wb25lbnRzIGp1c3QgaGF2ZSB0byBzdHlsZSBvbmUgZWxlbWVudCxcbiAgICAgIC8vIHNvIGEgc3RyaW5nIGlucHV0IGlzIHN1ZmZpY2llbnRcbiAgICAgIHZhbGlkYXRlQ3NzQ2xhc3Moc3R5bGVzLCBjb21wb25lbnROYW1lKTtcbiAgICB9IGVsc2Uge1xuICAgICAgLy8gV2hpbGUgb3RoZXJzIHJlcXVpcmUgYW4gb2JqZWN0IG90IGJlIGFibGUgdG8gc3R5bGVcbiAgICAgIC8vIGRpZmZlcmVudCBwYXJ0cyBvZiB0aGUgY29tcG9uZW50LCB3aGljaCByZXF1aXJlcyBhbiBvYmplY3RcbiAgICAgIC8vIHRvIHRhcmdldCBkaWZmZXJlbnQgcGFydHMgb2YgdGhlIGNvbXBvbmVudHMgd2l0aCBkaWZmZXJlbnQgY2xhc3Nlc1xuICAgICAgY29uc3Qgc3R5bGVzVmFsdWVzID0gT2JqZWN0LnZhbHVlcyhzdHlsZXMpO1xuICAgICAgZm9yIChjb25zdCBzdHlsZVZhbHVlIG9mIHN0eWxlc1ZhbHVlcykge1xuICAgICAgICB2YWxpZGF0ZUNzc0NsYXNzKHN0eWxlVmFsdWUsIGNvbXBvbmVudE5hbWUpO1xuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiBzdHlsZXM7XG4gIH07XG59XG4iXX0=