pruebatlp20v17-design-system 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (136) hide show
  1. package/README.md +25 -0
  2. package/esm2022/lib/algeciras-port-logo/algeciras-port-logo.component.mjs +21 -0
  3. package/esm2022/lib/bottom-panel/bottom-panel-content.directive.mjs +14 -0
  4. package/esm2022/lib/bottom-panel/bottom-panel-footer.component.mjs +24 -0
  5. package/esm2022/lib/bottom-panel/bottom-panel-header-heading.directive.mjs +14 -0
  6. package/esm2022/lib/bottom-panel/bottom-panel-header-label.directive.mjs +14 -0
  7. package/esm2022/lib/bottom-panel/bottom-panel-header.component.mjs +30 -0
  8. package/esm2022/lib/bottom-panel/bottom-panel.component.mjs +68 -0
  9. package/esm2022/lib/button/button.component.mjs +24 -0
  10. package/esm2022/lib/checkbox/checkbox.component.mjs +79 -0
  11. package/esm2022/lib/combobox/combobox.component.mjs +185 -0
  12. package/esm2022/lib/data-table/data-table-container.component.mjs +15 -0
  13. package/esm2022/lib/data-table/data-table-header-item.class.mjs +7 -0
  14. package/esm2022/lib/data-table/data-table-item.class.mjs +7 -0
  15. package/esm2022/lib/data-table/data-table-model.class.mjs +4 -0
  16. package/esm2022/lib/data-table/data-table-toolbar-content.component.mjs +15 -0
  17. package/esm2022/lib/data-table/data-table-toolbar.component.mjs +26 -0
  18. package/esm2022/lib/data-table/data-table.component.mjs +76 -0
  19. package/esm2022/lib/datepicker/datepicker.component.mjs +114 -0
  20. package/esm2022/lib/design-system.module.mjs +311 -0
  21. package/esm2022/lib/expandable-tile/expandable-tile.component.mjs +155 -0
  22. package/esm2022/lib/global-styles.component.mjs +11 -0
  23. package/esm2022/lib/header/hamburger.component.mjs +16 -0
  24. package/esm2022/lib/header/header-action.component.mjs +27 -0
  25. package/esm2022/lib/header/header-global.component.mjs +24 -0
  26. package/esm2022/lib/header/header.component.mjs +16 -0
  27. package/esm2022/lib/icons/icon.directive.mjs +39 -0
  28. package/esm2022/lib/icons/icon.service.mjs +2 -0
  29. package/esm2022/lib/input/input.component.mjs +98 -0
  30. package/esm2022/lib/link/link.directive.mjs +14 -0
  31. package/esm2022/lib/loading/loading.component.mjs +16 -0
  32. package/esm2022/lib/modal/base-modal.class.mjs +4 -0
  33. package/esm2022/lib/modal/modal-content.directive.mjs +14 -0
  34. package/esm2022/lib/modal/modal-footer.component.mjs +24 -0
  35. package/esm2022/lib/modal/modal-header-heading.directive.mjs +14 -0
  36. package/esm2022/lib/modal/modal-header-label.directive.mjs +14 -0
  37. package/esm2022/lib/modal/modal-header.component.mjs +30 -0
  38. package/esm2022/lib/modal/modal.component.mjs +27 -0
  39. package/esm2022/lib/modal/modal.service.mjs +11 -0
  40. package/esm2022/lib/modal/placeholder.component.mjs +16 -0
  41. package/esm2022/lib/notification/notification.component.mjs +24 -0
  42. package/esm2022/lib/notification/notification.service.mjs +19 -0
  43. package/esm2022/lib/notification/toast.component.mjs +27 -0
  44. package/esm2022/lib/overflow-menu/overflow-menu-option.component.mjs +13 -0
  45. package/esm2022/lib/overflow-menu/overflow-menu.component.mjs +19 -0
  46. package/esm2022/lib/pagination/pagination-model.class.mjs +4 -0
  47. package/esm2022/lib/pagination/pagination-translations.mjs +2 -0
  48. package/esm2022/lib/pagination/pagination.component.mjs +57 -0
  49. package/esm2022/lib/progress-indicator/progress-indicator.component.mjs +33 -0
  50. package/esm2022/lib/radio/radio-group.component.mjs +94 -0
  51. package/esm2022/lib/radio/radio.component.mjs +77 -0
  52. package/esm2022/lib/search/search.component.mjs +30 -0
  53. package/esm2022/lib/select/select.component.mjs +73 -0
  54. package/esm2022/lib/side-panel/side-panel.component.mjs +68 -0
  55. package/esm2022/lib/sidenav/sidenav-item.component.mjs +13 -0
  56. package/esm2022/lib/sidenav/sidenav-menu.component.mjs +25 -0
  57. package/esm2022/lib/sidenav/sidenav.component.mjs +13 -0
  58. package/esm2022/lib/subheader/subheader.component.mjs +11 -0
  59. package/esm2022/lib/table/table.directive.mjs +17 -0
  60. package/esm2022/lib/tabs/tab.component.mjs +135 -0
  61. package/esm2022/lib/tabs/tabs.component.mjs +100 -0
  62. package/esm2022/lib/tag/tag.component.mjs +31 -0
  63. package/esm2022/lib/tag-filter/tag-filter.component.mjs +16 -0
  64. package/esm2022/lib/textarea/textarea.component.mjs +86 -0
  65. package/esm2022/lib/toggle/toggle.component.mjs +67 -0
  66. package/esm2022/pruebatlp20v17-design-system.mjs +5 -0
  67. package/esm2022/public-api.mjs +75 -0
  68. package/fesm2022/pruebatlp20v17-design-system.mjs +2421 -0
  69. package/fesm2022/pruebatlp20v17-design-system.mjs.map +1 -0
  70. package/index.d.ts +5 -0
  71. package/lib/algeciras-port-logo/algeciras-port-logo.component.d.ts +8 -0
  72. package/lib/bottom-panel/bottom-panel-content.directive.d.ts +6 -0
  73. package/lib/bottom-panel/bottom-panel-footer.component.d.ts +6 -0
  74. package/lib/bottom-panel/bottom-panel-header-heading.directive.d.ts +6 -0
  75. package/lib/bottom-panel/bottom-panel-header-label.directive.d.ts +6 -0
  76. package/lib/bottom-panel/bottom-panel-header.component.d.ts +6 -0
  77. package/lib/bottom-panel/bottom-panel.component.d.ts +10 -0
  78. package/lib/button/button.component.d.ts +9 -0
  79. package/lib/checkbox/checkbox.component.d.ts +26 -0
  80. package/lib/combobox/combobox.component.d.ts +65 -0
  81. package/lib/data-table/data-table-container.component.d.ts +6 -0
  82. package/lib/data-table/data-table-header-item.class.d.ts +15 -0
  83. package/lib/data-table/data-table-item.class.d.ts +13 -0
  84. package/lib/data-table/data-table-model.class.d.ts +3 -0
  85. package/lib/data-table/data-table-toolbar-content.component.d.ts +6 -0
  86. package/lib/data-table/data-table-toolbar.component.d.ts +7 -0
  87. package/lib/data-table/data-table.component.d.ts +25 -0
  88. package/lib/datepicker/datepicker.component.d.ts +43 -0
  89. package/lib/design-system.module.d.ts +87 -0
  90. package/lib/expandable-tile/expandable-tile.component.d.ts +20 -0
  91. package/lib/global-styles.component.d.ts +5 -0
  92. package/lib/header/hamburger.component.d.ts +6 -0
  93. package/lib/header/header-action.component.d.ts +7 -0
  94. package/lib/header/header-global.component.d.ts +6 -0
  95. package/lib/header/header.component.d.ts +7 -0
  96. package/lib/icons/icon.directive.d.ts +16 -0
  97. package/lib/icons/icon.service.d.ts +1 -0
  98. package/lib/input/input.component.d.ts +42 -0
  99. package/lib/link/link.directive.d.ts +6 -0
  100. package/lib/loading/loading.component.d.ts +7 -0
  101. package/lib/modal/base-modal.class.d.ts +3 -0
  102. package/lib/modal/modal-content.directive.d.ts +6 -0
  103. package/lib/modal/modal-footer.component.d.ts +6 -0
  104. package/lib/modal/modal-header-heading.directive.d.ts +6 -0
  105. package/lib/modal/modal-header-label.directive.d.ts +6 -0
  106. package/lib/modal/modal-header.component.d.ts +6 -0
  107. package/lib/modal/modal.component.d.ts +11 -0
  108. package/lib/modal/modal.service.d.ts +6 -0
  109. package/lib/modal/placeholder.component.d.ts +6 -0
  110. package/lib/notification/notification.component.d.ts +9 -0
  111. package/lib/notification/notification.service.d.ts +10 -0
  112. package/lib/notification/toast.component.d.ts +10 -0
  113. package/lib/overflow-menu/overflow-menu-option.component.d.ts +6 -0
  114. package/lib/overflow-menu/overflow-menu.component.d.ts +9 -0
  115. package/lib/pagination/pagination-model.class.d.ts +3 -0
  116. package/lib/pagination/pagination-translations.d.ts +3 -0
  117. package/lib/pagination/pagination.component.d.ts +37 -0
  118. package/lib/progress-indicator/progress-indicator.component.d.ts +29 -0
  119. package/lib/radio/radio-group.component.d.ts +25 -0
  120. package/lib/radio/radio.component.d.ts +24 -0
  121. package/lib/search/search.component.d.ts +7 -0
  122. package/lib/select/select.component.d.ts +23 -0
  123. package/lib/side-panel/side-panel.component.d.ts +9 -0
  124. package/lib/sidenav/sidenav-item.component.d.ts +6 -0
  125. package/lib/sidenav/sidenav-menu.component.d.ts +11 -0
  126. package/lib/sidenav/sidenav.component.d.ts +7 -0
  127. package/lib/subheader/subheader.component.d.ts +5 -0
  128. package/lib/table/table.directive.d.ts +7 -0
  129. package/lib/tabs/tab.component.d.ts +67 -0
  130. package/lib/tabs/tabs.component.d.ts +60 -0
  131. package/lib/tag/tag.component.d.ts +12 -0
  132. package/lib/tag-filter/tag-filter.component.d.ts +7 -0
  133. package/lib/textarea/textarea.component.d.ts +26 -0
  134. package/lib/toggle/toggle.component.d.ts +21 -0
  135. package/package.json +30 -0
  136. package/public-api.d.ts +64 -0
@@ -0,0 +1,185 @@
1
+ import { Component, EventEmitter, Input, Output } from "@angular/core";
2
+ import { NG_VALUE_ACCESSOR } from "@angular/forms";
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/forms";
5
+ import * as i2 from "carbon-components-angular/combobox";
6
+ import * as i3 from "carbon-components-angular/dropdown";
7
+ export class ComboboxComponent {
8
+ items = [];
9
+ /**
10
+ * When `true`, the dropdown is open on top of the input
11
+ *
12
+ * @default false
13
+ */
14
+ dropUp = false;
15
+ disabled = false;
16
+ /**
17
+ * Specifies the property to be used for `ngModel`
18
+ */
19
+ itemValueKey = undefined;
20
+ /**
21
+ * Combo box type (supporting single or multi selection of items).
22
+ */
23
+ type = "single";
24
+ label = "";
25
+ helperText = "";
26
+ invalid = false;
27
+ invalidText = "";
28
+ placeholder = "";
29
+ size = "md";
30
+ /**
31
+ * Specify feedback (mode) of the selection.
32
+ * `top`: selected item jumps to top
33
+ * `fixed`: selected item stays at its position
34
+ * @default `top-after-reopen`: selected item jump to top after reopen dropdown
35
+ */
36
+ selectionFeedback = "top-after-reopen";
37
+ /** Emits an empty event when the menu is closed */
38
+ close = new EventEmitter();
39
+ /** Emits the search string from the input */
40
+ search = new EventEmitter();
41
+ /** Emits an event when the clear button is clicked. */
42
+ clear = new EventEmitter();
43
+ _value = "";
44
+ isTouched = false;
45
+ _onChangeCallback;
46
+ _onTouchCallback;
47
+ handleChange(newValue) {
48
+ this._value = newValue;
49
+ if (!this._onChangeCallback)
50
+ return;
51
+ const isObject = !!newValue && typeof newValue === "object" && !Array.isArray(newValue);
52
+ if (newValue === null) {
53
+ this._onChangeCallback(null);
54
+ return;
55
+ }
56
+ if (typeof newValue === "string") {
57
+ this._onChangeCallback(newValue);
58
+ return;
59
+ }
60
+ if (isObject) {
61
+ this._onChangeCallback(this.mapToConsumerValue(newValue));
62
+ return;
63
+ }
64
+ const isEmptyArray = Array.isArray(newValue) && newValue.length === 0;
65
+ if (this.type === "single" && isEmptyArray) {
66
+ // Carbon emits [] which is a leaky abstraction
67
+ // On single mode it only makes sense for it to be `null`
68
+ this._onChangeCallback(null);
69
+ return;
70
+ }
71
+ if (this.type === "multi") {
72
+ if (typeof newValue[0] === "string") {
73
+ this._onChangeCallback(newValue);
74
+ }
75
+ else {
76
+ this._onChangeCallback(newValue.map((item) => this.mapToConsumerValue(item)));
77
+ }
78
+ return;
79
+ }
80
+ // fallback
81
+ this._onChangeCallback?.(newValue);
82
+ }
83
+ writeValue(newValue) {
84
+ // e.g: null
85
+ // e.g: "one"
86
+ if (newValue === null || typeof newValue === "string") {
87
+ this._value = newValue;
88
+ return;
89
+ }
90
+ // e.g: { content: "one", disabled: true }
91
+ if (!Array.isArray(newValue)) {
92
+ const mappedNewValue = this.mapToInternalValue(newValue);
93
+ this._value = mappedNewValue;
94
+ return;
95
+ }
96
+ // e.g: [{ content: "one", disabled: true }, { content: "two", disabled: true }]
97
+ if (typeof newValue[0] === "object") {
98
+ this._value = newValue.map((item) => this.mapToInternalValue(item));
99
+ }
100
+ else {
101
+ // e.g: ["one", "two"]
102
+ this._value = newValue;
103
+ }
104
+ }
105
+ mapToInternalValue(value) {
106
+ return { ...value, selected: true };
107
+ }
108
+ mapToConsumerValue(ibmListItem) {
109
+ const { selected, ...withoutSelectedProp } = ibmListItem;
110
+ return withoutSelectedProp;
111
+ }
112
+ handleTouch(event) {
113
+ if (!this.isTouched) {
114
+ this.isTouched = true;
115
+ this._onTouchCallback?.(event);
116
+ }
117
+ }
118
+ registerOnChange(fn) {
119
+ this._onChangeCallback = fn;
120
+ }
121
+ registerOnTouched(fn) {
122
+ this._onTouchCallback = fn;
123
+ }
124
+ setDisabledState(isDisabled) {
125
+ this.disabled = isDisabled;
126
+ }
127
+ onClose() {
128
+ this.close.emit();
129
+ }
130
+ onSearch(value) {
131
+ this.search.emit(value);
132
+ }
133
+ onClear() {
134
+ this.clear.emit();
135
+ }
136
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ComboboxComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
137
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ComboboxComponent, selector: "tlp-combobox", inputs: { items: "items", dropUp: "dropUp", disabled: "disabled", itemValueKey: "itemValueKey", type: "type", label: "label", helperText: "helperText", invalid: "invalid", invalidText: "invalidText", placeholder: "placeholder", size: "size", selectionFeedback: "selectionFeedback" }, outputs: { close: "close", search: "search", clear: "clear" }, providers: [
138
+ {
139
+ provide: NG_VALUE_ACCESSOR,
140
+ multi: true,
141
+ useExisting: ComboboxComponent,
142
+ },
143
+ ], ngImport: i0, template: "<!-- $any because we don't want to require the `selected` property on consumer side-->\r\n<ibm-combo-box\r\n [items]=\"$any(items)\"\r\n [dropUp]=\"false\"\r\n [itemValueKey]=\"itemValueKey!\"\r\n [disabled]=\"disabled\"\r\n [ngModel]=\"_value\"\r\n [type]=\"type\"\r\n [invalid]=\"invalid\"\r\n [label]=\"label\"\r\n [helperText]=\"helperText\"\r\n [invalidText]=\"invalidText\"\r\n [placeholder]=\"placeholder\"\r\n [selectionFeedback]=\"selectionFeedback\"\r\n [size]=\"size\"\r\n (ngModelChange)=\"handleChange($event)\"\r\n (focusout)=\"handleTouch($event)\"\r\n (clear)=\"onClear()\"\r\n (search)=\"onSearch($event)\"\r\n (close)=\"onClose()\"\r\n>\r\n <ibm-dropdown-list></ibm-dropdown-list>\r\n</ibm-combo-box>\r\n", styles: [":host ::ng-deep{--cds-selected-ui: var(--cds-layer-accent, #d0e2ff)}:host ::ng-deep .cds--list-box{border:1px solid #003c69;border-radius:4px}:host ::ng-deep .cds--list-box.cds--list-box--disabled{border:1px solid #afafaf;background-color:#f1f1f1}:host ::ng-deep .cds--multi-select--filterable.cds--list-box--disabled:hover .cds--text-input{background-color:unset}:host ::ng-deep .cds--text-input,:host ::ng-deep .cds--multi-select--filterable.cds--combo-box .cds--text-input{border:none}:host ::ng-deep .cds--combo-box[data-invalid] .cds--text-input:not(:focus){outline:none}:host ::ng-deep .cds--list-box__menu-item:first-of-type .cds--list-box__menu-item__option{border-top-color:var(--cds-ui-03, #e0e0e0)}:host ::ng-deep .cds--list-box__menu-item:hover+.cds--list-box__menu-item .cds--list-box__menu-item__option{border-top-color:var(--cds-ui-03, #e0e0e0)}:host ::ng-deep .cds--list-box__menu-item__option:hover{border-top-color:var(--cds-ui-03, #e0e0e0)}:host ::ng-deep .cds--list-box__menu-item--active+.cds--list-box__menu-item>.cds--list-box__menu-item__option{border-top-color:var(--cds-ui-03, #e0e0e0)}:host ::ng-deep .cds--list-box__menu-item--active:hover,:host ::ng-deep .cds--list-box__menu-item--active.cds--list-box__menu-item--highlighted{background-color:var(--cds-selected-ui, #e0e0e0)}:host ::ng-deep .cds--list-box__menu-item--highlighted .cds--list-box__menu-item__option,:host ::ng-deep .cds--list-box__menu-item--highlighted+.cds--list-box__menu-item .cds--list-box__menu-item__option{border-top-color:var(--cds-ui-03, #e0e0e0)}::ng-deep .cds--list-box__menu-item--highlighted{background:unset}\n"], dependencies: [{ kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i2.ComboBox, selector: "cds-combo-box, ibm-combo-box", inputs: ["placeholder", "openMenuAria", "closeMenuAria", "clearSelectionsTitle", "clearSelectionsAria", "clearSelectionTitle", "clearSelectionAria", "id", "labelId", "items", "type", "size", "itemValueKey", "label", "hideLabel", "helperText", "appendInline", "invalid", "invalidText", "warn", "warnText", "maxLength", "theme", "selectionFeedback", "autocomplete", "dropUp", "disabled", "readonly", "fluid"], outputs: ["selected", "submit", "close", "search", "clear"] }, { kind: "component", type: i3.DropdownList, selector: "cds-dropdown-list, ibm-dropdown-list", inputs: ["ariaLabel", "items", "listTpl", "type", "showTitles"], outputs: ["select", "scroll", "blurIntent"] }] });
144
+ }
145
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ComboboxComponent, decorators: [{
146
+ type: Component,
147
+ args: [{ selector: "tlp-combobox", providers: [
148
+ {
149
+ provide: NG_VALUE_ACCESSOR,
150
+ multi: true,
151
+ useExisting: ComboboxComponent,
152
+ },
153
+ ], template: "<!-- $any because we don't want to require the `selected` property on consumer side-->\r\n<ibm-combo-box\r\n [items]=\"$any(items)\"\r\n [dropUp]=\"false\"\r\n [itemValueKey]=\"itemValueKey!\"\r\n [disabled]=\"disabled\"\r\n [ngModel]=\"_value\"\r\n [type]=\"type\"\r\n [invalid]=\"invalid\"\r\n [label]=\"label\"\r\n [helperText]=\"helperText\"\r\n [invalidText]=\"invalidText\"\r\n [placeholder]=\"placeholder\"\r\n [selectionFeedback]=\"selectionFeedback\"\r\n [size]=\"size\"\r\n (ngModelChange)=\"handleChange($event)\"\r\n (focusout)=\"handleTouch($event)\"\r\n (clear)=\"onClear()\"\r\n (search)=\"onSearch($event)\"\r\n (close)=\"onClose()\"\r\n>\r\n <ibm-dropdown-list></ibm-dropdown-list>\r\n</ibm-combo-box>\r\n", styles: [":host ::ng-deep{--cds-selected-ui: var(--cds-layer-accent, #d0e2ff)}:host ::ng-deep .cds--list-box{border:1px solid #003c69;border-radius:4px}:host ::ng-deep .cds--list-box.cds--list-box--disabled{border:1px solid #afafaf;background-color:#f1f1f1}:host ::ng-deep .cds--multi-select--filterable.cds--list-box--disabled:hover .cds--text-input{background-color:unset}:host ::ng-deep .cds--text-input,:host ::ng-deep .cds--multi-select--filterable.cds--combo-box .cds--text-input{border:none}:host ::ng-deep .cds--combo-box[data-invalid] .cds--text-input:not(:focus){outline:none}:host ::ng-deep .cds--list-box__menu-item:first-of-type .cds--list-box__menu-item__option{border-top-color:var(--cds-ui-03, #e0e0e0)}:host ::ng-deep .cds--list-box__menu-item:hover+.cds--list-box__menu-item .cds--list-box__menu-item__option{border-top-color:var(--cds-ui-03, #e0e0e0)}:host ::ng-deep .cds--list-box__menu-item__option:hover{border-top-color:var(--cds-ui-03, #e0e0e0)}:host ::ng-deep .cds--list-box__menu-item--active+.cds--list-box__menu-item>.cds--list-box__menu-item__option{border-top-color:var(--cds-ui-03, #e0e0e0)}:host ::ng-deep .cds--list-box__menu-item--active:hover,:host ::ng-deep .cds--list-box__menu-item--active.cds--list-box__menu-item--highlighted{background-color:var(--cds-selected-ui, #e0e0e0)}:host ::ng-deep .cds--list-box__menu-item--highlighted .cds--list-box__menu-item__option,:host ::ng-deep .cds--list-box__menu-item--highlighted+.cds--list-box__menu-item .cds--list-box__menu-item__option{border-top-color:var(--cds-ui-03, #e0e0e0)}::ng-deep .cds--list-box__menu-item--highlighted{background:unset}\n"] }]
154
+ }], propDecorators: { items: [{
155
+ type: Input
156
+ }], dropUp: [{
157
+ type: Input
158
+ }], disabled: [{
159
+ type: Input
160
+ }], itemValueKey: [{
161
+ type: Input
162
+ }], type: [{
163
+ type: Input
164
+ }], label: [{
165
+ type: Input
166
+ }], helperText: [{
167
+ type: Input
168
+ }], invalid: [{
169
+ type: Input
170
+ }], invalidText: [{
171
+ type: Input
172
+ }], placeholder: [{
173
+ type: Input
174
+ }], size: [{
175
+ type: Input
176
+ }], selectionFeedback: [{
177
+ type: Input
178
+ }], close: [{
179
+ type: Output
180
+ }], search: [{
181
+ type: Output
182
+ }], clear: [{
183
+ type: Output
184
+ }] } });
185
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"combobox.component.js","sourceRoot":"","sources":["../../../../../design-system/src/lib/combobox/combobox.component.ts","../../../../../design-system/src/lib/combobox/combobox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from \"@angular/core\";\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\r\nimport { ListItem as IbmListItem } from \"carbon-components-angular/dropdown\";\r\n\r\n// support Carbon's \"content\" and \"disabled\" properties, alongside the possibility of arbitrary ones\r\n// [!] do not switch `any` to `unknown` as it will break accesses to the model in consumer side\r\nexport type ComboboxItem = Pick<IbmListItem, \"content\" | \"disabled\"> &\r\n  Record<string, any>;\r\n\r\n// the type of the ngModel value that is on the consumer side\r\nexport type ComboboxValue =\r\n  // type=\"single\"\r\n  | string\r\n  | ComboboxItem\r\n  | null\r\n  // type=\"multi\"\r\n  | Array<string>\r\n  | Array<ComboboxItem>;\r\n\r\n// it must have `selected: true` in order to work\r\ntype INTERNAL_SelectedIbmListItem = IbmListItem & { selected: true };\r\n// mirror of the internal carbon value\r\ntype INTERNAL_Value =\r\n  // type=\"single\"\r\n  | string\r\n  | INTERNAL_SelectedIbmListItem\r\n  | null\r\n  // type=\"multi\"\r\n  | Array<string>\r\n  | Array<INTERNAL_SelectedIbmListItem>;\r\n\r\n@Component({\r\n  selector: \"tlp-combobox\",\r\n  templateUrl: \"./combobox.component.html\",\r\n  styleUrls: [\"./combobox.component.scss\"],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: ComboboxComponent,\r\n    },\r\n  ],\r\n})\r\nexport class ComboboxComponent implements ControlValueAccessor {\r\n  @Input() items: Array<ComboboxItem> = [];\r\n  /**\r\n   * When `true`, the dropdown is open on top of the input\r\n   *\r\n   * @default false\r\n   */\r\n  @Input() dropUp = false;\r\n  @Input() disabled = false;\r\n  /**\r\n   * Specifies the property to be used for `ngModel`\r\n   */\r\n  @Input() itemValueKey: string | undefined = undefined;\r\n\r\n  /**\r\n   * Combo box type (supporting single or multi selection of items).\r\n   */\r\n  @Input() type: \"single\" | \"multi\" = \"single\";\r\n\r\n  @Input() label = \"\";\r\n  @Input() helperText = \"\";\r\n  @Input() invalid = false;\r\n  @Input() invalidText = \"\";\r\n  @Input() placeholder = \"\";\r\n  @Input() size: \"sm\" | \"md\" | \"lg\" = \"md\";\r\n  /**\r\n   * Specify feedback (mode) of the selection.\r\n   * `top`: selected item jumps to top\r\n   * `fixed`: selected item stays at its position\r\n   * @default `top-after-reopen`: selected item jump to top after reopen dropdown\r\n   */\r\n  @Input() selectionFeedback: \"top\" | \"fixed\" | \"top-after-reopen\" =\r\n    \"top-after-reopen\";\r\n\r\n  /** Emits an empty event when the menu is closed */\r\n  @Output() close = new EventEmitter<void>();\r\n  /** Emits the search string from the input */\r\n  @Output() search = new EventEmitter<string>();\r\n  /** Emits an event when the clear button is clicked. */\r\n  @Output() clear = new EventEmitter<Event>();\r\n\r\n  _value: INTERNAL_Value = \"\";\r\n  isTouched = false;\r\n\r\n  _onChangeCallback: ((value: ComboboxValue) => void) | undefined;\r\n  _onTouchCallback: ((event: Event) => void) | undefined;\r\n\r\n  handleChange(newValue: INTERNAL_Value) {\r\n    this._value = newValue;\r\n\r\n    if (!this._onChangeCallback) return;\r\n\r\n    const isObject =\r\n      !!newValue && typeof newValue === \"object\" && !Array.isArray(newValue);\r\n\r\n    if (newValue === null) {\r\n      this._onChangeCallback(null);\r\n      return;\r\n    }\r\n\r\n    if (typeof newValue === \"string\") {\r\n      this._onChangeCallback(newValue);\r\n      return;\r\n    }\r\n\r\n    if (isObject) {\r\n      this._onChangeCallback(this.mapToConsumerValue(newValue));\r\n      return;\r\n    }\r\n\r\n    const isEmptyArray = Array.isArray(newValue) && newValue.length === 0;\r\n    if (this.type === \"single\" && isEmptyArray) {\r\n      // Carbon emits [] which is a leaky abstraction\r\n      // On single mode it only makes sense for it to be `null`\r\n      this._onChangeCallback(null);\r\n      return;\r\n    }\r\n\r\n    if (this.type === \"multi\") {\r\n      if (typeof newValue[0] === \"string\") {\r\n        this._onChangeCallback(newValue as Array<string>);\r\n      } else {\r\n        this._onChangeCallback(\r\n          (newValue as Array<INTERNAL_SelectedIbmListItem>).map((item) =>\r\n            this.mapToConsumerValue(item)\r\n          )\r\n        );\r\n      }\r\n\r\n      return;\r\n    }\r\n\r\n    // fallback\r\n    this._onChangeCallback?.(newValue);\r\n  }\r\n\r\n  writeValue(newValue: ComboboxValue): void {\r\n    // e.g: null\r\n    // e.g: \"one\"\r\n    if (newValue === null || typeof newValue === \"string\") {\r\n      this._value = newValue;\r\n      return;\r\n    }\r\n\r\n    // e.g: { content: \"one\", disabled: true }\r\n    if (!Array.isArray(newValue)) {\r\n      const mappedNewValue = this.mapToInternalValue(newValue);\r\n      this._value = mappedNewValue;\r\n\r\n      return;\r\n    }\r\n\r\n    // e.g: [{ content: \"one\", disabled: true }, { content: \"two\", disabled: true }]\r\n    if (typeof newValue[0] === \"object\") {\r\n      this._value = (newValue as Array<ComboboxItem>).map((item) =>\r\n        this.mapToInternalValue(item)\r\n      );\r\n    } else {\r\n      // e.g: [\"one\", \"two\"]\r\n      this._value = newValue as Array<string> | [];\r\n    }\r\n  }\r\n\r\n  mapToInternalValue(value: ComboboxItem): INTERNAL_SelectedIbmListItem {\r\n    return { ...value, selected: true };\r\n  }\r\n\r\n  mapToConsumerValue(ibmListItem: INTERNAL_SelectedIbmListItem): ComboboxItem {\r\n    const { selected, ...withoutSelectedProp } = ibmListItem;\r\n\r\n    return withoutSelectedProp;\r\n  }\r\n\r\n  handleTouch(event: Event) {\r\n    if (!this.isTouched) {\r\n      this.isTouched = true;\r\n      this._onTouchCallback?.(event);\r\n    }\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this._onChangeCallback = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this._onTouchCallback = fn;\r\n  }\r\n\r\n  setDisabledState(isDisabled: boolean) {\r\n    this.disabled = isDisabled;\r\n  }\r\n\r\n  onClose() {\r\n    this.close.emit();\r\n  }\r\n\r\n  onSearch(value: string) {\r\n    this.search.emit(value);\r\n  }\r\n\r\n  onClear() {\r\n    this.clear.emit();\r\n  }\r\n}\r\n","<!-- $any because we don't want to require the `selected` property on consumer side-->\r\n<ibm-combo-box\r\n  [items]=\"$any(items)\"\r\n  [dropUp]=\"false\"\r\n  [itemValueKey]=\"itemValueKey!\"\r\n  [disabled]=\"disabled\"\r\n  [ngModel]=\"_value\"\r\n  [type]=\"type\"\r\n  [invalid]=\"invalid\"\r\n  [label]=\"label\"\r\n  [helperText]=\"helperText\"\r\n  [invalidText]=\"invalidText\"\r\n  [placeholder]=\"placeholder\"\r\n  [selectionFeedback]=\"selectionFeedback\"\r\n  [size]=\"size\"\r\n  (ngModelChange)=\"handleChange($event)\"\r\n  (focusout)=\"handleTouch($event)\"\r\n  (clear)=\"onClear()\"\r\n  (search)=\"onSearch($event)\"\r\n  (close)=\"onClose()\"\r\n>\r\n  <ibm-dropdown-list></ibm-dropdown-list>\r\n</ibm-combo-box>\r\n"]}
@@ -0,0 +1,15 @@
1
+ import { Component } from "@angular/core";
2
+ import { TableContainer as IbmTableContainer } from "carbon-components-angular/table";
3
+ import * as i0 from "@angular/core";
4
+ export class DataTableContainerComponent extends IbmTableContainer {
5
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DataTableContainerComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
6
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DataTableContainerComponent, selector: "tlp-data-table-container", usesInheritance: true, ngImport: i0, template: `<ng-content></ng-content>`, isInline: true });
7
+ }
8
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DataTableContainerComponent, decorators: [{
9
+ type: Component,
10
+ args: [{
11
+ selector: "tlp-data-table-container",
12
+ template: `<ng-content></ng-content>`,
13
+ }]
14
+ }] });
15
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS10YWJsZS1jb250YWluZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vZGVzaWduLXN5c3RlbS9zcmMvbGliL2RhdGEtdGFibGUvZGF0YS10YWJsZS1jb250YWluZXIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLGNBQWMsSUFBSSxpQkFBaUIsRUFBRSxNQUFNLGlDQUFpQyxDQUFDOztBQU10RixNQUFNLE9BQU8sMkJBQTRCLFNBQVEsaUJBQWlCO3dHQUFyRCwyQkFBMkI7NEZBQTNCLDJCQUEyQix1RkFGNUIsMkJBQTJCOzs0RkFFMUIsMkJBQTJCO2tCQUp2QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSwwQkFBMEI7b0JBQ3BDLFFBQVEsRUFBRSwyQkFBMkI7aUJBQ3RDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgVGFibGVDb250YWluZXIgYXMgSWJtVGFibGVDb250YWluZXIgfSBmcm9tIFwiY2FyYm9uLWNvbXBvbmVudHMtYW5ndWxhci90YWJsZVwiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6IFwidGxwLWRhdGEtdGFibGUtY29udGFpbmVyXCIsXHJcbiAgdGVtcGxhdGU6IGA8bmctY29udGVudD48L25nLWNvbnRlbnQ+YCxcclxufSlcclxuZXhwb3J0IGNsYXNzIERhdGFUYWJsZUNvbnRhaW5lckNvbXBvbmVudCBleHRlbmRzIElibVRhYmxlQ29udGFpbmVyIHt9XHJcbiJdfQ==
@@ -0,0 +1,7 @@
1
+ import { TableHeaderItem as IbmTableHeaderItem } from "carbon-components-angular/table";
2
+ export class DataTableHeaderItem extends IbmTableHeaderItem {
3
+ constructor(options) {
4
+ super(options);
5
+ }
6
+ }
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS10YWJsZS1oZWFkZXItaXRlbS5jbGFzcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2Rlc2lnbi1zeXN0ZW0vc3JjL2xpYi9kYXRhLXRhYmxlL2RhdGEtdGFibGUtaGVhZGVyLWl0ZW0uY2xhc3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLGVBQWUsSUFBSSxrQkFBa0IsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBU3hGLE1BQU0sT0FBTyxtQkFBb0IsU0FBUSxrQkFBa0I7SUFDekQsWUFBWSxPQUFnQjtRQUMxQixLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDakIsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGVtcGxhdGVSZWYgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBUYWJsZUhlYWRlckl0ZW0gYXMgSWJtVGFibGVIZWFkZXJJdGVtIH0gZnJvbSBcImNhcmJvbi1jb21wb25lbnRzLWFuZ3VsYXIvdGFibGVcIjtcclxuXHJcbmludGVyZmFjZSBPcHRpb25zIHtcclxuICBkYXRhPzogdW5rbm93bjtcclxuICBzb3J0YWJsZT86IGJvb2xlYW47XHJcbiAgc3R5bGU/OiB7IHdpZHRoOiBzdHJpbmcgfTtcclxuICB0ZW1wbGF0ZT86IFRlbXBsYXRlUmVmPGFueT47XHJcbiAgdmlzaWJsZT86IGJvb2xlYW47XHJcbn1cclxuZXhwb3J0IGNsYXNzIERhdGFUYWJsZUhlYWRlckl0ZW0gZXh0ZW5kcyBJYm1UYWJsZUhlYWRlckl0ZW0ge1xyXG4gIGNvbnN0cnVjdG9yKG9wdGlvbnM6IE9wdGlvbnMpIHtcclxuICAgIHN1cGVyKG9wdGlvbnMpO1xyXG4gIH1cclxufVxyXG4iXX0=
@@ -0,0 +1,7 @@
1
+ import { TableItem as IbmTableItem } from "carbon-components-angular/table";
2
+ export class DataTableItem extends IbmTableItem {
3
+ constructor(options) {
4
+ super(options);
5
+ }
6
+ }
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS10YWJsZS1pdGVtLmNsYXNzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vZGVzaWduLXN5c3RlbS9zcmMvbGliL2RhdGEtdGFibGUvZGF0YS10YWJsZS1pdGVtLmNsYXNzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxTQUFTLElBQUksWUFBWSxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFVNUUsTUFBTSxPQUFPLGFBQWMsU0FBUSxZQUFZO0lBQzdDLFlBQVksT0FBZ0I7UUFDMUIsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ2pCLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRlbXBsYXRlUmVmIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgVGFibGVJdGVtIGFzIElibVRhYmxlSXRlbSB9IGZyb20gXCJjYXJib24tY29tcG9uZW50cy1hbmd1bGFyL3RhYmxlXCI7XHJcblxyXG5pbnRlcmZhY2UgT3B0aW9ucyB7XHJcbiAgZGF0YT86IHVua25vd247XHJcbiAgdGVtcGxhdGU/OiBUZW1wbGF0ZVJlZjx1bmtub3duPjtcclxuICBleHBhbmRlZFRlbXBsYXRlPzogVGVtcGxhdGVSZWY8dW5rbm93bj47XHJcbiAgZXhwYW5kZWREYXRhPzogdW5rbm93bjtcclxuICBleHBhbmRBc1RhYmxlPzogYm9vbGVhbjtcclxufVxyXG5cclxuZXhwb3J0IGNsYXNzIERhdGFUYWJsZUl0ZW0gZXh0ZW5kcyBJYm1UYWJsZUl0ZW0ge1xyXG4gIGNvbnN0cnVjdG9yKG9wdGlvbnM6IE9wdGlvbnMpIHtcclxuICAgIHN1cGVyKG9wdGlvbnMpO1xyXG4gIH1cclxufVxyXG4iXX0=
@@ -0,0 +1,4 @@
1
+ import { TableModel as IbmTableModel } from "carbon-components-angular/table";
2
+ export class DataTableModel extends IbmTableModel {
3
+ }
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS10YWJsZS1tb2RlbC5jbGFzcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2Rlc2lnbi1zeXN0ZW0vc3JjL2xpYi9kYXRhLXRhYmxlL2RhdGEtdGFibGUtbW9kZWwuY2xhc3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsSUFBSSxhQUFhLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUU5RSxNQUFNLE9BQU8sY0FBZSxTQUFRLGFBQWE7Q0FBRyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRhYmxlTW9kZWwgYXMgSWJtVGFibGVNb2RlbCB9IGZyb20gXCJjYXJib24tY29tcG9uZW50cy1hbmd1bGFyL3RhYmxlXCI7XHJcblxyXG5leHBvcnQgY2xhc3MgRGF0YVRhYmxlTW9kZWwgZXh0ZW5kcyBJYm1UYWJsZU1vZGVsIHt9XHJcbiJdfQ==
@@ -0,0 +1,15 @@
1
+ import { Component } from "@angular/core";
2
+ import { TableToolbarContent as IbmTableToolbarContent } from "carbon-components-angular/table";
3
+ import * as i0 from "@angular/core";
4
+ export class DataTableToolbarContentComponent extends IbmTableToolbarContent {
5
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DataTableToolbarContentComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
6
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DataTableToolbarContentComponent, selector: "tlp-data-table-toolbar-content", usesInheritance: true, ngImport: i0, template: ` <ng-content></ng-content> `, isInline: true });
7
+ }
8
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DataTableToolbarContentComponent, decorators: [{
9
+ type: Component,
10
+ args: [{
11
+ selector: "tlp-data-table-toolbar-content",
12
+ template: ` <ng-content></ng-content> `,
13
+ }]
14
+ }] });
15
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS10YWJsZS10b29sYmFyLWNvbnRlbnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vZGVzaWduLXN5c3RlbS9zcmMvbGliL2RhdGEtdGFibGUvZGF0YS10YWJsZS10b29sYmFyLWNvbnRlbnQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLG1CQUFtQixJQUFJLHNCQUFzQixFQUFFLE1BQU0saUNBQWlDLENBQUM7O0FBTWhHLE1BQU0sT0FBTyxnQ0FBaUMsU0FBUSxzQkFBc0I7d0dBQS9ELGdDQUFnQzs0RkFBaEMsZ0NBQWdDLDZGQUZqQyw2QkFBNkI7OzRGQUU1QixnQ0FBZ0M7a0JBSjVDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGdDQUFnQztvQkFDMUMsUUFBUSxFQUFFLDZCQUE2QjtpQkFDeEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBUYWJsZVRvb2xiYXJDb250ZW50IGFzIElibVRhYmxlVG9vbGJhckNvbnRlbnQgfSBmcm9tIFwiY2FyYm9uLWNvbXBvbmVudHMtYW5ndWxhci90YWJsZVwiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6IFwidGxwLWRhdGEtdGFibGUtdG9vbGJhci1jb250ZW50XCIsXHJcbiAgdGVtcGxhdGU6IGAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PiBgLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgRGF0YVRhYmxlVG9vbGJhckNvbnRlbnRDb21wb25lbnQgZXh0ZW5kcyBJYm1UYWJsZVRvb2xiYXJDb250ZW50IHt9XHJcbiJdfQ==
@@ -0,0 +1,26 @@
1
+ import { Component, Input } from "@angular/core";
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "carbon-components-angular/table";
4
+ export class DataTableToolbarComponent {
5
+ model;
6
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DataTableToolbarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
7
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DataTableToolbarComponent, selector: "tlp-data-table-toolbar", inputs: { model: "model" }, ngImport: i0, template: `
8
+ <ibm-table-toolbar [model]="model!">
9
+ <ng-content></ng-content>
10
+ </ibm-table-toolbar>
11
+ `, isInline: true, dependencies: [{ kind: "component", type: i1.TableToolbar, selector: "cds-table-toolbar, ibm-table-toolbar", inputs: ["model", "batchText", "ariaLabel", "cancelText", "size"], outputs: ["cancel"] }] });
12
+ }
13
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DataTableToolbarComponent, decorators: [{
14
+ type: Component,
15
+ args: [{
16
+ selector: "tlp-data-table-toolbar",
17
+ template: `
18
+ <ibm-table-toolbar [model]="model!">
19
+ <ng-content></ng-content>
20
+ </ibm-table-toolbar>
21
+ `,
22
+ }]
23
+ }], propDecorators: { model: [{
24
+ type: Input
25
+ }] } });
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS10YWJsZS10b29sYmFyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2Rlc2lnbi1zeXN0ZW0vc3JjL2xpYi9kYXRhLXRhYmxlL2RhdGEtdGFibGUtdG9vbGJhci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQVdqRCxNQUFNLE9BQU8seUJBQXlCO0lBQzNCLEtBQUssQ0FBa0I7d0dBRHJCLHlCQUF5Qjs0RkFBekIseUJBQXlCLDBGQU4xQjs7OztHQUlUOzs0RkFFVSx5QkFBeUI7a0JBUnJDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHdCQUF3QjtvQkFDbEMsUUFBUSxFQUFFOzs7O0dBSVQ7aUJBQ0Y7OEJBRVUsS0FBSztzQkFBYixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IERhdGFUYWJsZU1vZGVsIH0gZnJvbSBcIi4vZGF0YS10YWJsZS1tb2RlbC5jbGFzc1wiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6IFwidGxwLWRhdGEtdGFibGUtdG9vbGJhclwiLFxyXG4gIHRlbXBsYXRlOiBgXHJcbiAgICA8aWJtLXRhYmxlLXRvb2xiYXIgW21vZGVsXT1cIm1vZGVsIVwiPlxyXG4gICAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XHJcbiAgICA8L2libS10YWJsZS10b29sYmFyPlxyXG4gIGAsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBEYXRhVGFibGVUb29sYmFyQ29tcG9uZW50IHtcclxuICBASW5wdXQoKSBtb2RlbD86IERhdGFUYWJsZU1vZGVsO1xyXG59XHJcbiJdfQ==
@@ -0,0 +1,76 @@
1
+ import { Component, EventEmitter, Input, Output } from "@angular/core";
2
+ import { DataTableModel } from "./data-table-model.class";
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "carbon-components-angular/table";
5
+ export class DataTableComponent {
6
+ model = new DataTableModel();
7
+ showSelectionColumn = false;
8
+ sortable = true;
9
+ striped = true;
10
+ stickyHeader = false;
11
+ size = "md";
12
+ sort = new EventEmitter();
13
+ selectAll = new EventEmitter();
14
+ deselectAll = new EventEmitter();
15
+ selectRow = new EventEmitter();
16
+ deselectRow = new EventEmitter();
17
+ rowClick = new EventEmitter();
18
+ doSort(index) {
19
+ if (!this.sort.observed) {
20
+ // no observers. do the simple sort
21
+ if (this.model.header[index].sorted) {
22
+ // already sorted. flip sorting direction
23
+ this.model.header[index].ascending =
24
+ this.model.header[index].descending;
25
+ }
26
+ this.model.sort(index);
27
+ }
28
+ this.sort.emit(index);
29
+ }
30
+ onSelectAll(model) {
31
+ this.selectAll.emit(model);
32
+ }
33
+ onDeselectAll(model) {
34
+ this.deselectAll.emit(model);
35
+ }
36
+ onSelectRow(event) {
37
+ this.selectRow.emit(event);
38
+ }
39
+ onDeselectRow(event) {
40
+ this.deselectRow.emit(event);
41
+ }
42
+ onRowClick(index) {
43
+ this.rowClick.emit(index);
44
+ }
45
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DataTableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
46
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DataTableComponent, selector: "tlp-data-table", inputs: { model: "model", showSelectionColumn: "showSelectionColumn", sortable: "sortable", striped: "striped", stickyHeader: "stickyHeader", size: "size" }, outputs: { sort: "sort", selectAll: "selectAll", deselectAll: "deselectAll", selectRow: "selectRow", deselectRow: "deselectRow", rowClick: "rowClick" }, ngImport: i0, template: "<div class=\"table-wrapper\">\r\n <ibm-table\r\n [model]=\"model\"\r\n [showSelectionColumn]=\"showSelectionColumn\"\r\n [sortable]=\"sortable\"\r\n [striped]=\"striped\"\r\n [stickyHeader]=\"stickyHeader\"\r\n [size]=\"size\"\r\n (sort)=\"doSort($event)\"\r\n (selectAll)=\"onSelectAll($event)\"\r\n (deselectAll)=\"onDeselectAll($event)\"\r\n (selectRow)=\"onSelectRow($event)\"\r\n (deselectRow)=\"onDeselectRow($event)\"\r\n (rowClick)=\"onRowClick($event)\"\r\n ></ibm-table>\r\n</div>\r\n", styles: ["::ng-deep .bx--data-table--sort th{padding-left:0}::ng-deep .bx--table-toolbar{padding-bottom:.5rem}::ng-deep .bx--toolbar-content{column-gap:.5rem}.table-wrapper{overflow-x:auto}\n"], dependencies: [{ kind: "component", type: i1.Table, selector: "cds-table, ibm-table", inputs: ["ariaLabelledby", "ariaDescribedby", "model", "size", "skeleton", "isDataGrid", "sortable", "noBorder", "showExpandAllToggle", "showSelectionColumn", "enableSingleSelect", "scrollLoadDistance", "expandButtonAriaLabel", "sortDescendingLabel", "sortAscendingLabel", "translations", "striped", "stickyHeader", "footerTemplate", "selectionLabelColumn"], outputs: ["sort", "selectAll", "deselectAll", "selectRow", "deselectRow", "rowClick", "scrollLoad"] }] });
47
+ }
48
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DataTableComponent, decorators: [{
49
+ type: Component,
50
+ args: [{ selector: "tlp-data-table", template: "<div class=\"table-wrapper\">\r\n <ibm-table\r\n [model]=\"model\"\r\n [showSelectionColumn]=\"showSelectionColumn\"\r\n [sortable]=\"sortable\"\r\n [striped]=\"striped\"\r\n [stickyHeader]=\"stickyHeader\"\r\n [size]=\"size\"\r\n (sort)=\"doSort($event)\"\r\n (selectAll)=\"onSelectAll($event)\"\r\n (deselectAll)=\"onDeselectAll($event)\"\r\n (selectRow)=\"onSelectRow($event)\"\r\n (deselectRow)=\"onDeselectRow($event)\"\r\n (rowClick)=\"onRowClick($event)\"\r\n ></ibm-table>\r\n</div>\r\n", styles: ["::ng-deep .bx--data-table--sort th{padding-left:0}::ng-deep .bx--table-toolbar{padding-bottom:.5rem}::ng-deep .bx--toolbar-content{column-gap:.5rem}.table-wrapper{overflow-x:auto}\n"] }]
51
+ }], propDecorators: { model: [{
52
+ type: Input
53
+ }], showSelectionColumn: [{
54
+ type: Input
55
+ }], sortable: [{
56
+ type: Input
57
+ }], striped: [{
58
+ type: Input
59
+ }], stickyHeader: [{
60
+ type: Input
61
+ }], size: [{
62
+ type: Input
63
+ }], sort: [{
64
+ type: Output
65
+ }], selectAll: [{
66
+ type: Output
67
+ }], deselectAll: [{
68
+ type: Output
69
+ }], selectRow: [{
70
+ type: Output
71
+ }], deselectRow: [{
72
+ type: Output
73
+ }], rowClick: [{
74
+ type: Output
75
+ }] } });
76
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS10YWJsZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9kZXNpZ24tc3lzdGVtL3NyYy9saWIvZGF0YS10YWJsZS9kYXRhLXRhYmxlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL2Rlc2lnbi1zeXN0ZW0vc3JjL2xpYi9kYXRhLXRhYmxlL2RhdGEtdGFibGUuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN2RSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sMEJBQTBCLENBQUM7OztBQU8xRCxNQUFNLE9BQU8sa0JBQWtCO0lBQ3BCLEtBQUssR0FBbUIsSUFBSSxjQUFjLEVBQUUsQ0FBQztJQUM3QyxtQkFBbUIsR0FBRyxLQUFLLENBQUM7SUFDNUIsUUFBUSxHQUFHLElBQUksQ0FBQztJQUNoQixPQUFPLEdBQUcsSUFBSSxDQUFDO0lBQ2YsWUFBWSxHQUFHLEtBQUssQ0FBQztJQUNyQixJQUFJLEdBQXVCLElBQUksQ0FBQztJQUUvQixJQUFJLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztJQUVsQyxTQUFTLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztJQUN2QyxXQUFXLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztJQUN6QyxTQUFTLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztJQUN2QyxXQUFXLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztJQUV6QyxRQUFRLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztJQUVoRCxNQUFNLENBQUMsS0FBYTtRQUNsQixJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUN4QixtQ0FBbUM7WUFDbkMsSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxNQUFNLEVBQUUsQ0FBQztnQkFDcEMseUNBQXlDO2dCQUN6QyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxTQUFTO29CQUNoQyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxVQUFVLENBQUM7WUFDeEMsQ0FBQztZQUNELElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3pCLENBQUM7UUFFRCxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUN4QixDQUFDO0lBRUQsV0FBVyxDQUFDLEtBQWE7UUFDdkIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDN0IsQ0FBQztJQUVELGFBQWEsQ0FBQyxLQUFhO1FBQ3pCLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQy9CLENBQUM7SUFFRCxXQUFXLENBQUMsS0FBYTtRQUN2QixJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUM3QixDQUFDO0lBRUQsYUFBYSxDQUFDLEtBQWE7UUFDekIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDL0IsQ0FBQztJQUVELFVBQVUsQ0FBQyxLQUFhO1FBQ3RCLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzVCLENBQUM7d0dBakRVLGtCQUFrQjs0RkFBbEIsa0JBQWtCLDZXQ1IvQixzaEJBZ0JBOzs0RkRSYSxrQkFBa0I7a0JBTDlCLFNBQVM7K0JBQ0UsZ0JBQWdCOzhCQUtqQixLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csbUJBQW1CO3NCQUEzQixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLO2dCQUNHLFlBQVk7c0JBQXBCLEtBQUs7Z0JBQ0csSUFBSTtzQkFBWixLQUFLO2dCQUVJLElBQUk7c0JBQWIsTUFBTTtnQkFFRyxTQUFTO3NCQUFsQixNQUFNO2dCQUNHLFdBQVc7c0JBQXBCLE1BQU07Z0JBQ0csU0FBUztzQkFBbEIsTUFBTTtnQkFDRyxXQUFXO3NCQUFwQixNQUFNO2dCQUVHLFFBQVE7c0JBQWpCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IERhdGFUYWJsZU1vZGVsIH0gZnJvbSBcIi4vZGF0YS10YWJsZS1tb2RlbC5jbGFzc1wiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6IFwidGxwLWRhdGEtdGFibGVcIixcclxuICB0ZW1wbGF0ZVVybDogXCIuL2RhdGEtdGFibGUuY29tcG9uZW50Lmh0bWxcIixcclxuICBzdHlsZVVybHM6IFtcIi4vZGF0YS10YWJsZS5jb21wb25lbnQuc2Nzc1wiXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIERhdGFUYWJsZUNvbXBvbmVudCB7XHJcbiAgQElucHV0KCkgbW9kZWw6IERhdGFUYWJsZU1vZGVsID0gbmV3IERhdGFUYWJsZU1vZGVsKCk7XHJcbiAgQElucHV0KCkgc2hvd1NlbGVjdGlvbkNvbHVtbiA9IGZhbHNlO1xyXG4gIEBJbnB1dCgpIHNvcnRhYmxlID0gdHJ1ZTtcclxuICBASW5wdXQoKSBzdHJpcGVkID0gdHJ1ZTtcclxuICBASW5wdXQoKSBzdGlja3lIZWFkZXIgPSBmYWxzZTtcclxuICBASW5wdXQoKSBzaXplOiBcInNtXCIgfCBcIm1kXCIgfCBcImxnXCIgPSBcIm1kXCI7XHJcblxyXG4gIEBPdXRwdXQoKSBzb3J0ID0gbmV3IEV2ZW50RW1pdHRlcjxudW1iZXI+KCk7XHJcblxyXG4gIEBPdXRwdXQoKSBzZWxlY3RBbGwgPSBuZXcgRXZlbnRFbWl0dGVyPE9iamVjdD4oKTtcclxuICBAT3V0cHV0KCkgZGVzZWxlY3RBbGwgPSBuZXcgRXZlbnRFbWl0dGVyPE9iamVjdD4oKTtcclxuICBAT3V0cHV0KCkgc2VsZWN0Um93ID0gbmV3IEV2ZW50RW1pdHRlcjxPYmplY3Q+KCk7XHJcbiAgQE91dHB1dCgpIGRlc2VsZWN0Um93ID0gbmV3IEV2ZW50RW1pdHRlcjxPYmplY3Q+KCk7XHJcblxyXG4gIEBPdXRwdXQoKSByb3dDbGljayA9IG5ldyBFdmVudEVtaXR0ZXI8bnVtYmVyPigpO1xyXG5cclxuICBkb1NvcnQoaW5kZXg6IG51bWJlcikge1xyXG4gICAgaWYgKCF0aGlzLnNvcnQub2JzZXJ2ZWQpIHtcclxuICAgICAgLy8gbm8gb2JzZXJ2ZXJzLiBkbyB0aGUgc2ltcGxlIHNvcnRcclxuICAgICAgaWYgKHRoaXMubW9kZWwuaGVhZGVyW2luZGV4XS5zb3J0ZWQpIHtcclxuICAgICAgICAvLyBhbHJlYWR5IHNvcnRlZC4gZmxpcCBzb3J0aW5nIGRpcmVjdGlvblxyXG4gICAgICAgIHRoaXMubW9kZWwuaGVhZGVyW2luZGV4XS5hc2NlbmRpbmcgPVxyXG4gICAgICAgICAgdGhpcy5tb2RlbC5oZWFkZXJbaW5kZXhdLmRlc2NlbmRpbmc7XHJcbiAgICAgIH1cclxuICAgICAgdGhpcy5tb2RlbC5zb3J0KGluZGV4KTtcclxuICAgIH1cclxuXHJcbiAgICB0aGlzLnNvcnQuZW1pdChpbmRleCk7XHJcbiAgfVxyXG5cclxuICBvblNlbGVjdEFsbChtb2RlbDogT2JqZWN0KSB7XHJcbiAgICB0aGlzLnNlbGVjdEFsbC5lbWl0KG1vZGVsKTtcclxuICB9XHJcblxyXG4gIG9uRGVzZWxlY3RBbGwobW9kZWw6IE9iamVjdCkge1xyXG4gICAgdGhpcy5kZXNlbGVjdEFsbC5lbWl0KG1vZGVsKTtcclxuICB9XHJcblxyXG4gIG9uU2VsZWN0Um93KGV2ZW50OiBPYmplY3QpIHtcclxuICAgIHRoaXMuc2VsZWN0Um93LmVtaXQoZXZlbnQpO1xyXG4gIH1cclxuXHJcbiAgb25EZXNlbGVjdFJvdyhldmVudDogT2JqZWN0KSB7XHJcbiAgICB0aGlzLmRlc2VsZWN0Um93LmVtaXQoZXZlbnQpO1xyXG4gIH1cclxuXHJcbiAgb25Sb3dDbGljayhpbmRleDogbnVtYmVyKSB7XHJcbiAgICB0aGlzLnJvd0NsaWNrLmVtaXQoaW5kZXgpO1xyXG4gIH1cclxufVxyXG4iLCI8ZGl2IGNsYXNzPVwidGFibGUtd3JhcHBlclwiPlxyXG4gIDxpYm0tdGFibGVcclxuICAgIFttb2RlbF09XCJtb2RlbFwiXHJcbiAgICBbc2hvd1NlbGVjdGlvbkNvbHVtbl09XCJzaG93U2VsZWN0aW9uQ29sdW1uXCJcclxuICAgIFtzb3J0YWJsZV09XCJzb3J0YWJsZVwiXHJcbiAgICBbc3RyaXBlZF09XCJzdHJpcGVkXCJcclxuICAgIFtzdGlja3lIZWFkZXJdPVwic3RpY2t5SGVhZGVyXCJcclxuICAgIFtzaXplXT1cInNpemVcIlxyXG4gICAgKHNvcnQpPVwiZG9Tb3J0KCRldmVudClcIlxyXG4gICAgKHNlbGVjdEFsbCk9XCJvblNlbGVjdEFsbCgkZXZlbnQpXCJcclxuICAgIChkZXNlbGVjdEFsbCk9XCJvbkRlc2VsZWN0QWxsKCRldmVudClcIlxyXG4gICAgKHNlbGVjdFJvdyk9XCJvblNlbGVjdFJvdygkZXZlbnQpXCJcclxuICAgIChkZXNlbGVjdFJvdyk9XCJvbkRlc2VsZWN0Um93KCRldmVudClcIlxyXG4gICAgKHJvd0NsaWNrKT1cIm9uUm93Q2xpY2soJGV2ZW50KVwiXHJcbiAgPjwvaWJtLXRhYmxlPlxyXG48L2Rpdj5cclxuIl19
@@ -0,0 +1,114 @@
1
+ import { Component, Input } from "@angular/core";
2
+ import { NG_VALUE_ACCESSOR } from "@angular/forms";
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/common";
5
+ import * as i2 from "carbon-components-angular/datepicker";
6
+ export class DatepickerComponent {
7
+ disabled = false;
8
+ invalid = false;
9
+ invalidText = "";
10
+ range = false;
11
+ /** Set to `true` to display the invalid state for the second datepicker input. */
12
+ rangeInvalid = false;
13
+ /** Value displayed if the second datepicker input is in an invalid state. */
14
+ rangeInvalidText = "";
15
+ /**
16
+ * Format of the displayed date
17
+ *
18
+ * @see https://flatpickr.js.org/formatting/
19
+ */
20
+ dateFormat = "d/m/Y";
21
+ /** Language of the calendar panel. Doesn't affect the format of the displayed date */
22
+ language = "es";
23
+ label = "";
24
+ rangeLabel = "";
25
+ placeholder = "";
26
+ size = "md";
27
+ /** Forces the width to be same as calendar panel, making it more visually aligned */
28
+ fixedWidth = false;
29
+ /** When setting it to `true`, make sure to provide a `dateFormat` with time, so the time value is tracked */
30
+ enableTime = false;
31
+ value = [];
32
+ isTouched = false;
33
+ _onChangeCallback;
34
+ _onTouchCallback;
35
+ handleChange(value) {
36
+ this._onChangeCallback?.(value);
37
+ }
38
+ handleTouch(event) {
39
+ if (!this.isTouched) {
40
+ this.isTouched = true;
41
+ this._onTouchCallback?.(event);
42
+ }
43
+ }
44
+ // NgModel passes null for "no value" or for the initial value before change detection runs
45
+ // Carbon throws "Cannot read properties of null (reading '0')" if the initial value is null and the user changes the date
46
+ writeValue(value) {
47
+ if (!value) {
48
+ this.value = [];
49
+ }
50
+ else if (value instanceof Date) {
51
+ // support unwrapped Date instance as value even though Carbon doesn't support it as it is a very common usage
52
+ this.value = [value];
53
+ }
54
+ else {
55
+ this.value = value;
56
+ }
57
+ }
58
+ registerOnChange(fn) {
59
+ this._onChangeCallback = fn;
60
+ }
61
+ registerOnTouched(fn) {
62
+ this._onTouchCallback = fn;
63
+ }
64
+ setDisabledState(isDisabled) {
65
+ this.disabled = isDisabled;
66
+ }
67
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DatepickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
68
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DatepickerComponent, selector: "tlp-datepicker", inputs: { disabled: "disabled", invalid: "invalid", invalidText: "invalidText", range: "range", rangeInvalid: "rangeInvalid", rangeInvalidText: "rangeInvalidText", dateFormat: "dateFormat", language: "language", label: "label", rangeLabel: "rangeLabel", placeholder: "placeholder", size: "size", fixedWidth: "fixedWidth", enableTime: "enableTime" }, providers: [
69
+ {
70
+ provide: NG_VALUE_ACCESSOR,
71
+ multi: true,
72
+ useExisting: DatepickerComponent,
73
+ },
74
+ ], ngImport: i0, template: "<ibm-date-picker\r\n [ngClass]=\"{ disabled: disabled, expand: !fixedWidth }\"\r\n [range]=\"range\"\r\n [disabled]=\"disabled\"\r\n [invalid]=\"invalid\"\r\n [invalidText]=\"invalidText\"\r\n [rangeInvalid]=\"rangeInvalid\"\r\n [rangeInvalidText]=\"rangeInvalidText\"\r\n [label]=\"label\"\r\n [rangeLabel]=\"rangeLabel\"\r\n [placeholder]=\"placeholder\"\r\n [value]=\"value\"\r\n (valueChange)=\"handleChange($event)\"\r\n [dateFormat]=\"dateFormat\"\r\n [language]=\"language\"\r\n [size]=\"size\"\r\n [flatpickrOptions]=\"{\r\n enableTime, \r\n disableMobile: true\r\n }\"\r\n ><!-- // [!] DON'T extract `flatpickrOptions` to a method or getter, else the calendar won't open -->\r\n</ibm-date-picker>\r\n", styles: ["::ng-deep .bx--date-picker__input{border:1px solid #003c69;border-radius:4px;padding:0 .5rem;--cds-field: #ffffff}::ng-deep .bx--date-picker__input:focus{border-color:#287eff}::ng-deep .bx--date-picker__input:disabled{--cds-field: #f4f4f4;border:1px solid #afafaf}::ng-deep .bx--date-picker__input:disabled:hover{border-bottom:1px solid #afafaf}::ng-deep .bx--date-picker__calendar{--cds-field-01: var(--cds-ui-01);--cds-ui-01: #ffffff;--cds-highlight: var(--cds-layer-accent, #d0e2ff);border-radius:4px}::ng-deep .bx--date-picker__day{--cds-ui-01: var(--cds-layer-accent, #d0e2ff)}::ng-deep .bx--date-picker__day:hover{--cds-hover-ui: var(--cds-layer-accent, #d0e2ff)}::ng-deep .bx--date-picker__day.flatpickr-day.endRange:hover{outline:none}:host ::ng-deep .disabled{--cds-text-02: #afafaf}.expand ::ng-deep .bx--date-picker--range .bx--date-picker-container,.expand ::ng-deep .bx--date-picker--range .bx--date-picker__input{width:100%}.expand ::ng-deep .bx--date-picker-container{width:100%}.expand ::ng-deep .bx--date-picker.bx--date-picker--single .bx--date-picker__input{width:100%}.expand ::ng-deep .bx--date-picker{width:100%}::ng-deep .dayContainer{justify-content:initial}::ng-deep .flatpickr-calendar.open{height:auto}::ng-deep .flatpickr-calendar.hasTime .flatpickr-time{height:2.5rem;border-top:1px solid #e6e6e6;display:flex;gap:4px;align-items:center;width:100%;justify-content:center}::ng-deep .flatpickr-calendar.hasTime .flatpickr-time .arrowUp{top:0}::ng-deep .flatpickr-calendar.hasTime .flatpickr-time .arrowDown{top:unset;bottom:0}::ng-deep .flatpickr-calendar.hasTime .flatpickr-time .numInput{border:1px solid #e6e6e6;border-radius:3px}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i2.DatePicker, selector: "cds-date-picker, ibm-date-picker", inputs: ["range", "dateFormat", "language", "label", "helperText", "rangeHelperText", "rangeLabel", "placeholder", "ariaLabel", "inputPattern", "id", "value", "theme", "disabled", "readonly", "invalid", "invalidText", "warn", "warnText", "size", "rangeInvalid", "rangeInvalidText", "rangeWarn", "rangeWarnText", "skeleton", "plugins", "flatpickrOptions"], outputs: ["valueChange", "onClose"] }] });
75
+ }
76
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DatepickerComponent, decorators: [{
77
+ type: Component,
78
+ args: [{ selector: "tlp-datepicker", providers: [
79
+ {
80
+ provide: NG_VALUE_ACCESSOR,
81
+ multi: true,
82
+ useExisting: DatepickerComponent,
83
+ },
84
+ ], template: "<ibm-date-picker\r\n [ngClass]=\"{ disabled: disabled, expand: !fixedWidth }\"\r\n [range]=\"range\"\r\n [disabled]=\"disabled\"\r\n [invalid]=\"invalid\"\r\n [invalidText]=\"invalidText\"\r\n [rangeInvalid]=\"rangeInvalid\"\r\n [rangeInvalidText]=\"rangeInvalidText\"\r\n [label]=\"label\"\r\n [rangeLabel]=\"rangeLabel\"\r\n [placeholder]=\"placeholder\"\r\n [value]=\"value\"\r\n (valueChange)=\"handleChange($event)\"\r\n [dateFormat]=\"dateFormat\"\r\n [language]=\"language\"\r\n [size]=\"size\"\r\n [flatpickrOptions]=\"{\r\n enableTime, \r\n disableMobile: true\r\n }\"\r\n ><!-- // [!] DON'T extract `flatpickrOptions` to a method or getter, else the calendar won't open -->\r\n</ibm-date-picker>\r\n", styles: ["::ng-deep .bx--date-picker__input{border:1px solid #003c69;border-radius:4px;padding:0 .5rem;--cds-field: #ffffff}::ng-deep .bx--date-picker__input:focus{border-color:#287eff}::ng-deep .bx--date-picker__input:disabled{--cds-field: #f4f4f4;border:1px solid #afafaf}::ng-deep .bx--date-picker__input:disabled:hover{border-bottom:1px solid #afafaf}::ng-deep .bx--date-picker__calendar{--cds-field-01: var(--cds-ui-01);--cds-ui-01: #ffffff;--cds-highlight: var(--cds-layer-accent, #d0e2ff);border-radius:4px}::ng-deep .bx--date-picker__day{--cds-ui-01: var(--cds-layer-accent, #d0e2ff)}::ng-deep .bx--date-picker__day:hover{--cds-hover-ui: var(--cds-layer-accent, #d0e2ff)}::ng-deep .bx--date-picker__day.flatpickr-day.endRange:hover{outline:none}:host ::ng-deep .disabled{--cds-text-02: #afafaf}.expand ::ng-deep .bx--date-picker--range .bx--date-picker-container,.expand ::ng-deep .bx--date-picker--range .bx--date-picker__input{width:100%}.expand ::ng-deep .bx--date-picker-container{width:100%}.expand ::ng-deep .bx--date-picker.bx--date-picker--single .bx--date-picker__input{width:100%}.expand ::ng-deep .bx--date-picker{width:100%}::ng-deep .dayContainer{justify-content:initial}::ng-deep .flatpickr-calendar.open{height:auto}::ng-deep .flatpickr-calendar.hasTime .flatpickr-time{height:2.5rem;border-top:1px solid #e6e6e6;display:flex;gap:4px;align-items:center;width:100%;justify-content:center}::ng-deep .flatpickr-calendar.hasTime .flatpickr-time .arrowUp{top:0}::ng-deep .flatpickr-calendar.hasTime .flatpickr-time .arrowDown{top:unset;bottom:0}::ng-deep .flatpickr-calendar.hasTime .flatpickr-time .numInput{border:1px solid #e6e6e6;border-radius:3px}\n"] }]
85
+ }], propDecorators: { disabled: [{
86
+ type: Input
87
+ }], invalid: [{
88
+ type: Input
89
+ }], invalidText: [{
90
+ type: Input
91
+ }], range: [{
92
+ type: Input
93
+ }], rangeInvalid: [{
94
+ type: Input
95
+ }], rangeInvalidText: [{
96
+ type: Input
97
+ }], dateFormat: [{
98
+ type: Input
99
+ }], language: [{
100
+ type: Input
101
+ }], label: [{
102
+ type: Input
103
+ }], rangeLabel: [{
104
+ type: Input
105
+ }], placeholder: [{
106
+ type: Input
107
+ }], size: [{
108
+ type: Input
109
+ }], fixedWidth: [{
110
+ type: Input
111
+ }], enableTime: [{
112
+ type: Input
113
+ }] } });
114
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"","sources":["../../../../../design-system/src/lib/datepicker/datepicker.component.ts","../../../../../design-system/src/lib/datepicker/datepicker.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;;;;AAiBzE,MAAM,OAAO,mBAAmB;IACrB,QAAQ,GAAG,KAAK,CAAC;IACjB,OAAO,GAAG,KAAK,CAAC;IAChB,WAAW,GAAG,EAAE,CAAC;IACjB,KAAK,GAAG,KAAK,CAAC;IACvB,kFAAkF;IACzE,YAAY,GAAG,KAAK,CAAC;IAC9B,6EAA6E;IACpE,gBAAgB,GAAG,EAAE,CAAC;IAC/B;;;;OAIG;IACM,UAAU,GAAG,OAAO,CAAC;IAC9B,sFAAsF;IAC7E,QAAQ,GAUN,IAAI,CAAC;IACP,KAAK,GAAG,EAAE,CAAC;IACX,UAAU,GAAG,EAAE,CAAC;IAChB,WAAW,GAAG,EAAE,CAAC;IACjB,IAAI,GAAuB,IAAI,CAAC;IACzC,qFAAqF;IAC5E,UAAU,GAAG,KAAK,CAAC;IAC5B,6GAA6G;IACpG,UAAU,GAAG,KAAK,CAAC;IAE5B,KAAK,GAAU,EAAE,CAAC;IAClB,SAAS,GAAG,KAAK,CAAC;IAElB,iBAAiB,CAAuC;IACxD,gBAAgB,CAAuC;IAEvD,YAAY,CAAC,KAAY;QACvB,IAAI,CAAC,iBAAiB,EAAE,CAAC,KAAK,CAAC,CAAC;IAClC,CAAC;IAED,WAAW,CAAC,KAAY;QACtB,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC;YACpB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;YACtB,IAAI,CAAC,gBAAgB,EAAE,CAAC,KAAK,CAAC,CAAC;QACjC,CAAC;IACH,CAAC;IAED,2FAA2F;IAC3F,0HAA0H;IAC1H,UAAU,CAAC,KAAmB;QAC5B,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;QAClB,CAAC;aAAM,IAAI,KAAK,YAAY,IAAI,EAAE,CAAC;YACjC,8GAA8G;YAC9G,IAAI,CAAC,KAAK,GAAG,CAAC,KAAK,CAAC,CAAC;QACvB,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACrB,CAAC;IACH,CAAC;IAED,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAC;IAC9B,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;IAC7B,CAAC;IAED,gBAAgB,CAAC,UAAmB;QAClC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;IAC7B,CAAC;wGA5EU,mBAAmB;4FAAnB,mBAAmB,uYARnB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,KAAK,EAAE,IAAI;gBACX,WAAW,EAAE,mBAAmB;aACjC;SACF,0BChBH,+tBAsBA;;4FDJa,mBAAmB;kBAZ/B,SAAS;+BACE,gBAAgB,aAGf;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,KAAK,EAAE,IAAI;4BACX,WAAW,qBAAqB;yBACjC;qBACF;8BAGQ,QAAQ;sBAAhB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBAEG,YAAY;sBAApB,KAAK;gBAEG,gBAAgB;sBAAxB,KAAK;gBAMG,UAAU;sBAAlB,KAAK;gBAEG,QAAQ;sBAAhB,KAAK;gBAWG,KAAK;sBAAb,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBAEG,UAAU;sBAAlB,KAAK;gBAEG,UAAU;sBAAlB,KAAK","sourcesContent":["import { Component, Input } from \"@angular/core\";\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\r\n\r\ntype Value = [] | [Date] | [Date, Date];\r\nexport type DatepickerValue = Value; // for public-api, must have component prefix\r\n\r\n@Component({\r\n  selector: \"tlp-datepicker\",\r\n  templateUrl: \"./datepicker.component.html\",\r\n  styleUrls: [\"./datepicker.component.scss\"],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: DatepickerComponent,\r\n    },\r\n  ],\r\n})\r\nexport class DatepickerComponent implements ControlValueAccessor {\r\n  @Input() disabled = false;\r\n  @Input() invalid = false;\r\n  @Input() invalidText = \"\";\r\n  @Input() range = false;\r\n  /** Set to `true` to display the invalid state for the second datepicker input. */\r\n  @Input() rangeInvalid = false;\r\n  /** Value displayed if the second datepicker input is in an invalid state. */\r\n  @Input() rangeInvalidText = \"\";\r\n  /**\r\n   * Format of the displayed date\r\n   *\r\n   * @see https://flatpickr.js.org/formatting/\r\n   */\r\n  @Input() dateFormat = \"d/m/Y\";\r\n  /** Language of the calendar panel. Doesn't affect the format of the displayed date */\r\n  @Input() language:\r\n    | \"en\"\r\n    | \"de\"\r\n    | \"fi\"\r\n    | \"ja\"\r\n    | \"zh\"\r\n    | \"es\"\r\n    | \"fr\"\r\n    | \"it\"\r\n    | \"ko\"\r\n    | \"pt\" = \"es\";\r\n  @Input() label = \"\";\r\n  @Input() rangeLabel = \"\";\r\n  @Input() placeholder = \"\";\r\n  @Input() size: \"sm\" | \"md\" | \"lg\" = \"md\";\r\n  /** Forces the width to be same as calendar panel, making it more visually aligned */\r\n  @Input() fixedWidth = false;\r\n  /** When setting it to `true`, make sure to provide a `dateFormat` with time, so the time value is tracked */\r\n  @Input() enableTime = false;\r\n\r\n  value: Value = [];\r\n  isTouched = false;\r\n\r\n  _onChangeCallback: ((value: Value) => void) | undefined;\r\n  _onTouchCallback: ((event: Event) => void) | undefined;\r\n\r\n  handleChange(value: Value) {\r\n    this._onChangeCallback?.(value);\r\n  }\r\n\r\n  handleTouch(event: Event) {\r\n    if (!this.isTouched) {\r\n      this.isTouched = true;\r\n      this._onTouchCallback?.(event);\r\n    }\r\n  }\r\n\r\n  // NgModel passes null for \"no value\" or for the initial value before change detection runs\r\n  // Carbon throws \"Cannot read properties of null (reading '0')\" if the initial value is null and the user changes the date\r\n  writeValue(value: Value | null): void {\r\n    if (!value) {\r\n      this.value = [];\r\n    } else if (value instanceof Date) {\r\n      // support unwrapped Date instance as value even though Carbon doesn't support it as it is a very common usage\r\n      this.value = [value];\r\n    } else {\r\n      this.value = value;\r\n    }\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this._onChangeCallback = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this._onTouchCallback = fn;\r\n  }\r\n\r\n  setDisabledState(isDisabled: boolean) {\r\n    this.disabled = isDisabled;\r\n  }\r\n}\r\n","<ibm-date-picker\r\n  [ngClass]=\"{ disabled: disabled, expand: !fixedWidth }\"\r\n  [range]=\"range\"\r\n  [disabled]=\"disabled\"\r\n  [invalid]=\"invalid\"\r\n  [invalidText]=\"invalidText\"\r\n  [rangeInvalid]=\"rangeInvalid\"\r\n  [rangeInvalidText]=\"rangeInvalidText\"\r\n  [label]=\"label\"\r\n  [rangeLabel]=\"rangeLabel\"\r\n  [placeholder]=\"placeholder\"\r\n  [value]=\"value\"\r\n  (valueChange)=\"handleChange($event)\"\r\n  [dateFormat]=\"dateFormat\"\r\n  [language]=\"language\"\r\n  [size]=\"size\"\r\n  [flatpickrOptions]=\"{\r\n    enableTime, \r\n    disableMobile: true\r\n  }\"\r\n  ><!-- // [!] DON'T extract `flatpickrOptions` to a method or getter, else the calendar won't open -->\r\n</ibm-date-picker>\r\n"]}