@impartner/design-components 1.1.2 → 1.2.0

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 (60) hide show
  1. package/esm2020/lib/pagination/pagination.component.mjs +51 -20
  2. package/esm2020/lib/pagination/pagination.module.mjs +8 -4
  3. package/esm2020/lib/table/components/bulk-actions/bulk-actions.component.mjs +11 -0
  4. package/esm2020/lib/table/components/column-heading/column-heading.component.mjs +38 -0
  5. package/esm2020/lib/table/components/index.mjs +3 -0
  6. package/esm2020/lib/table/constants/index.mjs +3 -0
  7. package/esm2020/lib/table/constants/public-table.constants.mjs +2 -0
  8. package/esm2020/lib/table/constants/table.constants.mjs +24 -0
  9. package/esm2020/lib/table/containers/index.mjs +2 -0
  10. package/esm2020/lib/table/containers/table.component.mjs +386 -0
  11. package/esm2020/lib/table/directives/index.mjs +3 -0
  12. package/esm2020/lib/table/directives/table-inject-component.directive.mjs +46 -0
  13. package/esm2020/lib/table/directives/table.directive.mjs +35 -0
  14. package/esm2020/lib/table/enumerations/index.mjs +2 -0
  15. package/esm2020/lib/table/enumerations/table-column-type.mjs +20 -0
  16. package/esm2020/lib/table/helpers/index.mjs +2 -0
  17. package/esm2020/lib/table/helpers/table-theme.helper.mjs +31 -0
  18. package/esm2020/lib/table/index.mjs +8 -3
  19. package/esm2020/lib/table/interfaces/cell-renderer.interface.mjs +2 -0
  20. package/esm2020/lib/table/interfaces/custom-cell-renderer-components.type.mjs +2 -0
  21. package/esm2020/lib/table/interfaces/index.mjs +9 -0
  22. package/esm2020/lib/table/interfaces/sort-by-payload.interface.mjs +2 -0
  23. package/esm2020/lib/table/interfaces/table-cell-option.interface.mjs +2 -0
  24. package/esm2020/lib/table/interfaces/table-column-def.interface.mjs +2 -0
  25. package/esm2020/lib/table/interfaces/table-event-payload.interface.mjs +2 -0
  26. package/esm2020/lib/table/interfaces/table-row-item.interface.mjs +2 -0
  27. package/esm2020/lib/table/table.module.mjs +76 -7
  28. package/fesm2015/impartner-design-components.mjs +3605 -2986
  29. package/fesm2015/impartner-design-components.mjs.map +1 -1
  30. package/fesm2020/impartner-design-components.mjs +3002 -2387
  31. package/fesm2020/impartner-design-components.mjs.map +1 -1
  32. package/lib/pagination/pagination.component.d.ts +18 -3
  33. package/lib/pagination/pagination.module.d.ts +2 -1
  34. package/lib/table/components/bulk-actions/bulk-actions.component.d.ts +5 -0
  35. package/lib/table/components/column-heading/column-heading.component.d.ts +14 -0
  36. package/lib/table/components/index.d.ts +2 -0
  37. package/lib/table/constants/index.d.ts +2 -0
  38. package/lib/table/constants/public-table.constants.d.ts +1 -0
  39. package/lib/table/constants/table.constants.d.ts +10 -0
  40. package/lib/table/containers/index.d.ts +1 -0
  41. package/lib/table/containers/table.component.d.ts +127 -0
  42. package/lib/table/directives/index.d.ts +2 -0
  43. package/lib/table/directives/table-inject-component.directive.d.ts +16 -0
  44. package/lib/table/{table.component.d.ts → directives/table.directive.d.ts} +4 -4
  45. package/lib/table/enumerations/index.d.ts +1 -0
  46. package/lib/table/enumerations/table-column-type.d.ts +18 -0
  47. package/lib/table/helpers/index.d.ts +1 -0
  48. package/lib/table/helpers/table-theme.helper.d.ts +7 -0
  49. package/lib/table/index.d.ts +7 -2
  50. package/lib/table/interfaces/cell-renderer.interface.d.ts +6 -0
  51. package/lib/table/interfaces/custom-cell-renderer-components.type.d.ts +3 -0
  52. package/lib/table/interfaces/index.d.ts +8 -0
  53. package/lib/table/interfaces/sort-by-payload.interface.d.ts +5 -0
  54. package/lib/table/interfaces/table-cell-option.interface.d.ts +4 -0
  55. package/lib/table/interfaces/table-column-def.interface.d.ts +22 -0
  56. package/lib/table/interfaces/table-event-payload.interface.d.ts +6 -0
  57. package/lib/table/interfaces/table-row-item.interface.d.ts +9 -0
  58. package/lib/table/table.module.d.ts +15 -3
  59. package/package.json +3 -2
  60. package/esm2020/lib/table/table.component.mjs +0 -33
@@ -0,0 +1,386 @@
1
+ import { Component, ContentChild, EventEmitter, Host, Input, Optional, Output } from '@angular/core';
2
+ import { get as getNestedValue, set as setNestedValue } from 'lodash';
3
+ import { debounceTime } from 'rxjs/operators';
4
+ import { DEBOUNCE_TIME, SORT_COLUMN_INDEX } from '../constants/index';
5
+ import { TableColumnType } from '../enumerations/index';
6
+ import { TableThemeHelper } from '../helpers';
7
+ import { ComponentTheme } from '../../../types';
8
+ import { PaginationComponent } from '../../pagination';
9
+ import { TableBulkActionsComponent } from '../components';
10
+ import * as i0 from "@angular/core";
11
+ import * as i1 from "@angular/common";
12
+ import * as i2 from "../../branding";
13
+ import * as i3 from "../../branding/branded.directive";
14
+ import * as i4 from "../../icon/icon.component";
15
+ import * as i5 from "../../form-field/controls/checkbox/checkbox.component";
16
+ import * as i6 from "../../form-field/controls/select/option/select-option.component";
17
+ import * as i7 from "../../form-field/controls/select/select.component";
18
+ import * as i8 from "../../form-field/controls/input/input.directive";
19
+ import * as i9 from "@angular/forms";
20
+ import * as i10 from "../../spinner/spinner.component";
21
+ import * as i11 from "../../badge/badge.component";
22
+ import * as i12 from "../directives/table.directive";
23
+ import * as i13 from "../components/column-heading/column-heading.component";
24
+ import * as i14 from "../directives/table-inject-component.directive";
25
+ /**
26
+ * The `TableComponent` (`<impdc-table`) is a data table component.
27
+ * To use, import `TableModule` from `@impartner/design-components`.
28
+ */
29
+ export class TableComponent {
30
+ constructor(_datePipe, _percentPipe, _decmialPipe, _changeDetectorRef, _branded) {
31
+ this._datePipe = _datePipe;
32
+ this._percentPipe = _percentPipe;
33
+ this._decmialPipe = _decmialPipe;
34
+ this._changeDetectorRef = _changeDetectorRef;
35
+ this._branded = _branded;
36
+ /**
37
+ * Whether the table data is currently being loaded. The `<impdc-spinner>` will show if data is loading.
38
+ */
39
+ this.loading = false;
40
+ /**
41
+ * The visible columns of the table. Each `ITableColumnDef` defines properties regarding the display, formatting and interaction of the column's cells.
42
+ * Column/cell color precedence is:
43
+ * 1) `fieldColor` - allows an `ITableColumnDef` to delegate the responsibility of cell color to an `ITableRowItem` property.
44
+ * 2) `colorGetter`- allows an `ITableColumnDef` to delegate the responsibility of cell color to a function of the `ITableRowItem` determined by the developer.
45
+ * 3) `color` - a property of an `ITableColumnDef`.
46
+ */
47
+ this.columnDefs = [];
48
+ /**
49
+ * Whether the table is striped.
50
+ */
51
+ this.striped = true;
52
+ /**
53
+ * The placeholder text and empty value display text for `<impdc-select>` instances in cells with a `ITableColumnDef` `columnType` = `SingleSelect` or `MultiSelect`.
54
+ */
55
+ this.selectPlaceholder = '';
56
+ /**
57
+ * The `columnDefs` index of the currently sorted column.
58
+ */
59
+ this.sortColumnIndex = SORT_COLUMN_INDEX;
60
+ /**
61
+ * The direction of the currently sorted column.
62
+ */
63
+ this.sortDirection = 'asc';
64
+ /**
65
+ * The table row data as an array of `ITableRowItem`.
66
+ */
67
+ this.tableData = [];
68
+ /**
69
+ * Event emitted when one or multiple rows are selected. Emits `(string | number)[]` payload.
70
+ */
71
+ this.rowSelect = new EventEmitter();
72
+ /**
73
+ * Event emitted when a column is sorted. Emits `ISortByPayload` payload.
74
+ */
75
+ this.sortBy = new EventEmitter();
76
+ /**
77
+ * Event emitted when a row link is clicked. Emits `ITableEventPayload` payload.
78
+ */
79
+ this.linkClick = new EventEmitter();
80
+ /** @ignore */
81
+ this.paginationComponent = undefined;
82
+ /** @ignore */
83
+ this.bulkActions = undefined;
84
+ /**
85
+ * Event emitted when a row input value is changed. Emitted cells of `columnType` `SinglSelect`, `MultiSelect`, `Input`, `Boolean` or `Icon`.
86
+ * Not emitted if column definition property `disabled` = `true`. Emits `ITableEventPayload` payload.
87
+ */
88
+ this.inputChange = new EventEmitter();
89
+ /** @ignore */
90
+ this.cellType = TableColumnType;
91
+ /** @ignore */
92
+ this.allSelected = true;
93
+ /** @ignore */
94
+ this.branded = false;
95
+ this._canSelectRows = false;
96
+ this._canSelectAllRows = false;
97
+ this._selectedRowIds = [];
98
+ this._inputChange = new EventEmitter();
99
+ this.branded = _branded ? true : false;
100
+ this._inputChange
101
+ .pipe(debounceTime(DEBOUNCE_TIME))
102
+ .subscribe(this.inputChange);
103
+ }
104
+ /**
105
+ * Whether individual rows can be selected. Will be `true` if explicitly set to `true` or `canSelectAllRows` is `true`.
106
+ */
107
+ set canSelectRows(value) {
108
+ this._canSelectRows = value;
109
+ }
110
+ get canSelectRows() {
111
+ return this.canSelectAllRows || this._canSelectRows || !!this.bulkActions;
112
+ }
113
+ /**
114
+ * Whether all rows can be selected at once. Will be `true` if explicitly set to `true` or if `TableBulkActionsComponent` is content projected.
115
+ */
116
+ set canSelectAllRows(value) {
117
+ this._canSelectAllRows = value;
118
+ }
119
+ get canSelectAllRows() {
120
+ return this._canSelectAllRows || !!this.bulkActions;
121
+ }
122
+ /**
123
+ * An array of currently selected IDs from the `tableData` input. Array must be of type `(string | number)[]`.
124
+ */
125
+ set selectedRowIds(value) {
126
+ this._selectedRowIds = [...value];
127
+ }
128
+ get selectedRowIds() {
129
+ return [...this._selectedRowIds];
130
+ }
131
+ /** @ignore */
132
+ get someSelected() {
133
+ return (!!this._selectedRowIds &&
134
+ this._selectedRowIds.length > 0 &&
135
+ !!this.tableData &&
136
+ this.tableData.length > 0 &&
137
+ this._selectedRowIds.length < this.tableData.length);
138
+ }
139
+ /** @ignore */
140
+ get tableSpan() {
141
+ return this.canSelectRows
142
+ ? this.columnDefs.length + 1
143
+ : this.columnDefs.length;
144
+ }
145
+ ngOnChanges(changes) {
146
+ if (changes['selectedRowIds'] || changes['tableData']) {
147
+ if (!this.tableData ||
148
+ !this.tableData.length ||
149
+ !this.selectedRowIds ||
150
+ !this.selectedRowIds.length) {
151
+ this.allSelected = false;
152
+ }
153
+ else {
154
+ this.allSelected = this.selectedRowIds.length >= this.tableData.length;
155
+ }
156
+ }
157
+ }
158
+ getMailToValue(columnIndex, currentRow) {
159
+ const { columnType, truncated: truncated } = this._getColumnDefByIndex(columnIndex);
160
+ let value = this._getValue(columnIndex, currentRow);
161
+ if (columnType !== TableColumnType.Email) {
162
+ return String(value);
163
+ }
164
+ value = value ? `mailto:${value}` : value;
165
+ return String(value);
166
+ }
167
+ getStringValue(columnIndex, currentRow) {
168
+ const value = this.getValue(columnIndex, currentRow);
169
+ if (Array.isArray(value)) {
170
+ return value.join(';');
171
+ }
172
+ return String(value);
173
+ }
174
+ getValue(columnIndex, currentRow) {
175
+ const { columnType, truncated: truncated } = this._getColumnDefByIndex(columnIndex);
176
+ let value = this._getValue(columnIndex, currentRow);
177
+ switch (columnType) {
178
+ case TableColumnType.Decimal: {
179
+ value = this._decmialPipe.transform(Number(value) || 0) || '';
180
+ break;
181
+ }
182
+ case TableColumnType.Date: {
183
+ const date = new Date(String(value));
184
+ const validDate = date instanceof Date && !isNaN(date.getTime());
185
+ value = validDate
186
+ ? this._datePipe.transform(date, 'MM/dd/yyyy') || ''
187
+ : String(value);
188
+ break;
189
+ }
190
+ case TableColumnType.DateTime: {
191
+ const dateTime = new Date(String(value));
192
+ const validDateTime = dateTime instanceof Date && !isNaN(dateTime.getTime());
193
+ value = validDateTime
194
+ ? this._datePipe.transform(dateTime, 'MM/dd/yyyy h:mm:ss a') || ''
195
+ : String(value);
196
+ break;
197
+ }
198
+ case TableColumnType.Link: {
199
+ value = String(value).replace(/(^\w+:|^)\/\//, '');
200
+ break;
201
+ }
202
+ case TableColumnType.Percentage: {
203
+ value = this._percentPipe.transform(Number(value) || 0) || '';
204
+ break;
205
+ }
206
+ case TableColumnType.Url: {
207
+ if (!/(http(s?)):\/\//i.test(String(value))) {
208
+ value = `https://${value}`;
209
+ }
210
+ break;
211
+ }
212
+ case TableColumnType.Text: {
213
+ if (Array.isArray(value)) {
214
+ value = value.join('; ');
215
+ }
216
+ if (!truncated) {
217
+ return value;
218
+ }
219
+ const truncateString = (string = '', maxLength = truncated) => string.length > maxLength
220
+ ? `${string.substring(0, maxLength)}…`
221
+ : string;
222
+ !!truncated
223
+ ? (value = truncateString(String(value), truncated))
224
+ : value;
225
+ break;
226
+ }
227
+ case TableColumnType.MultiSelect:
228
+ if (typeof value === 'string') {
229
+ value = value.split(';')?.map(v => v.trim()) || [];
230
+ }
231
+ return value;
232
+ }
233
+ return String(value);
234
+ }
235
+ getRawValue(columnIndex, currentRow) {
236
+ const { field } = this._getColumnDefByIndex(columnIndex);
237
+ if (!field) {
238
+ return '';
239
+ }
240
+ return currentRow[field] || '';
241
+ }
242
+ getCellColor(columnDefinition, item) {
243
+ return TableThemeHelper.getCellColor(columnDefinition, item);
244
+ }
245
+ getTheme(columnDefinition, item) {
246
+ return (TableThemeHelper.getTheme(columnDefinition, item) ||
247
+ ComponentTheme.Primary);
248
+ }
249
+ isSortedColumn(columnIndex) {
250
+ return columnIndex === this.sortColumnIndex;
251
+ }
252
+ isRowSelected(id) {
253
+ return this.selectedRowIds.includes(id);
254
+ }
255
+ handleSelectAll(event) {
256
+ if (!this.canSelectAllRows || !this.tableData) {
257
+ return;
258
+ }
259
+ if (event.checked) {
260
+ this._selectedRowIds = this.tableData?.map(row => row.id) || [];
261
+ }
262
+ else {
263
+ this._selectedRowIds = [];
264
+ }
265
+ this._selectedRowIds.sort();
266
+ this.allSelected = this.selectedRowIds.length >= this.tableData.length;
267
+ this.rowSelect.emit(this.selectedRowIds);
268
+ }
269
+ handleSort(columnIndex) {
270
+ if (columnIndex === this.sortColumnIndex) {
271
+ this.sortDirection = this.sortDirection === 'asc' ? 'desc' : 'asc';
272
+ }
273
+ else {
274
+ this.sortColumnIndex = columnIndex;
275
+ this.sortDirection = 'asc';
276
+ }
277
+ const field = this._getColumnDefByIndex(columnIndex).field || '';
278
+ this.sortBy.emit({
279
+ columnIndex,
280
+ field,
281
+ direction: this.sortDirection
282
+ });
283
+ }
284
+ handleRowSelect(event, rowId) {
285
+ if (!this.canSelectRows) {
286
+ return;
287
+ }
288
+ if (event.checked && !this._selectedRowIds.includes(rowId)) {
289
+ this._selectedRowIds.push(rowId);
290
+ }
291
+ else if (!event.checked && this._selectedRowIds.includes(rowId)) {
292
+ const idx = this._selectedRowIds.indexOf(rowId);
293
+ if (idx > -1) {
294
+ this._selectedRowIds.splice(idx, 1);
295
+ }
296
+ }
297
+ if (this._selectedRowIds.length) {
298
+ this._selectedRowIds.sort();
299
+ }
300
+ this.allSelected = this.selectedRowIds.length >= this.tableData.length;
301
+ this.rowSelect.emit(this.selectedRowIds);
302
+ }
303
+ handleCellValueChange(columnIndex, rowIndex, value) {
304
+ const { field, columnType } = this._getColumnDefByIndex(columnIndex);
305
+ let currentValue = value;
306
+ if (columnType !== TableColumnType.Boolean && !Array.isArray(value)) {
307
+ currentValue = isNaN(Number(value)) ? value : Number(value);
308
+ }
309
+ const item = this.tableData[rowIndex];
310
+ setNestedValue(item, String(field), currentValue);
311
+ this._inputChange.emit({
312
+ columnIndex,
313
+ item,
314
+ value: currentValue
315
+ });
316
+ this._changeDetectorRef.detectChanges();
317
+ }
318
+ handleLinkClick(columnIndex, item) {
319
+ this.linkClick.emit({
320
+ item,
321
+ columnIndex
322
+ });
323
+ }
324
+ _getColumnDefByIndex(columnIndex) {
325
+ return this.columnDefs[columnIndex];
326
+ }
327
+ _getValue(columnIndex, currentRow) {
328
+ try {
329
+ const { field, valueGetter } = this._getColumnDefByIndex(columnIndex);
330
+ const value = valueGetter
331
+ ? valueGetter(currentRow)
332
+ : getNestedValue(currentRow, String(field), '');
333
+ return value || '';
334
+ }
335
+ catch (e) {
336
+ return '';
337
+ }
338
+ }
339
+ }
340
+ TableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TableComponent, deps: [{ token: i1.DatePipe }, { token: i1.PercentPipe }, { token: i1.DecimalPipe }, { token: i0.ChangeDetectorRef }, { token: i2.BrandedDirective, host: true, optional: true }], target: i0.ɵɵFactoryTarget.Component });
341
+ TableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: TableComponent, selector: "impdc-table", inputs: { loading: "loading", columnDefs: "columnDefs", striped: "striped", canSelectRows: "canSelectRows", canSelectAllRows: "canSelectAllRows", selectPlaceholder: "selectPlaceholder", sortColumnIndex: "sortColumnIndex", sortDirection: "sortDirection", tableData: "tableData", selectedRowIds: "selectedRowIds", customCellComponents: "customCellComponents" }, outputs: { rowSelect: "rowSelect", sortBy: "sortBy", linkClick: "linkClick", inputChange: "inputChange" }, queries: [{ propertyName: "paginationComponent", first: true, predicate: PaginationComponent, descendants: true }, { propertyName: "bulkActions", first: true, predicate: TableBulkActionsComponent, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<table impdcTable *ngIf=\"tableData\" [striped]=\"striped\">\n <thead>\n <tr *ngIf=\"!!bulkActions\">\n <th [attr.colspan]=\"tableSpan\" scope=\"col\" class=\"bulk-action-column\">\n <ng-content select=\"impdc-table-bulk-actions\"></ng-content>\n <ng-content select=\"[impdcTableBulkActions]\"></ng-content>\n </th>\n </tr>\n <tr>\n <th\n *ngIf=\"canSelectRows\"\n scope=\"col\"\n [ngClass]=\"{\n 'heading-below-bulk-actions': !!bulkActions\n }\">\n <div *ngIf=\"canSelectAllRows\">\n <impdc-checkbox\n ngModel\n [checked]=\"allSelected\"\n [indeterminate]=\"someSelected\"\n (change)=\"handleSelectAll($event)\"></impdc-checkbox>\n </div>\n </th>\n <th\n scope=\"col\"\n *ngFor=\"let columnDef of columnDefs; index as columnIndex\"\n [ngClass]=\"{\n 'sorted-column': isSortedColumn(columnIndex),\n 'sortable-column': columnDef.sorted,\n 'heading-below-bulk-actions': !!bulkActions\n }\"\n (click)=\"handleSort(columnIndex)\">\n <impdc-column-heading\n [isSortable]=\"columnDef.sorted || false\"\n [columnIndex]=\"columnIndex\"\n [sortColumnIndex]=\"sortColumnIndex\"\n [direction]=\"sortDirection\"\n [text]=\"columnDef.title\"\n (sort)=\"handleSort($event)\">\n </impdc-column-heading>\n </th>\n </tr>\n </thead>\n <tbody>\n <tr *ngIf=\"loading; else data\">\n <td [attr.colspan]=\"tableSpan\" class=\"data-loading\">\n <impdc-spinner></impdc-spinner>\n </td>\n </tr>\n <ng-template #data>\n <tr *ngIf=\"tableData.length === 0\">\n <td [attr.colspan]=\"tableSpan\" class=\"no-data\">\n <ng-content select=\"[noData]\"></ng-content>\n </td>\n </tr>\n <tr *ngFor=\"let row of tableData; index as rowIndex\">\n <td *ngIf=\"canSelectRows\">\n <div class=\"select-column\">\n <impdc-checkbox\n [ngModel]=\"isRowSelected(row.id)\"\n (change)=\"handleRowSelect($event, row.id)\"></impdc-checkbox>\n </div>\n </td>\n <td\n *ngFor=\"let columnDef of columnDefs; index as colIndex\"\n [ngClass]=\"{\n 'col-no-padding': !!columnDef.noPadding\n }\">\n <div [ngSwitch]=\"columnDef.columnType\">\n <span *ngSwitchCase=\"cellType.Badge\">\n <impdc-badge\n [text]=\"getStringValue(colIndex, row)\"\n [theme]=\"getTheme(columnDef, row)\">\n </impdc-badge>\n </span>\n <span\n *ngSwitchCase=\"cellType.Link\"\n class=\"cell-type-link\"\n (click)=\"handleLinkClick(colIndex, row)\">\n <a *ngIf=\"!branded\">\n {{ getValue(colIndex, row) }}\n </a>\n <a *ngIf=\"branded\" impdcBranded>\n {{ getValue(colIndex, row) }}\n </a>\n </span>\n <span *ngSwitchCase=\"cellType.Url\" class=\"cell-type-link\">\n <a\n *ngIf=\"!branded\"\n target=\"_blank\"\n [attr.href]=\"getValue(colIndex, row)\">\n {{ getValue(colIndex, row) }}\n </a>\n <a\n *ngIf=\"branded\"\n impdcBranded\n target=\"_blank\"\n [attr.href]=\"getValue(colIndex, row)\">\n {{ getValue(colIndex, row) }}\n </a>\n </span>\n <span *ngSwitchCase=\"cellType.Email\" class=\"cell-type-link\">\n <a\n *ngIf=\"!branded\"\n target=\"_blank\"\n [attr.href]=\"'mailto:' + getValue(colIndex, row)\">\n {{ getValue(colIndex, row) }}\n </a>\n <a\n *ngIf=\"branded\"\n impdcBranded\n [attr.href]=\"getMailToValue(colIndex, row)\">\n {{ getValue(colIndex, row) }}\n </a>\n </span>\n <span *ngSwitchCase=\"cellType.Input\">\n <input\n impdcInput\n type=\"text\"\n class=\"{{ getCellColor(columnDef, row) }}\"\n [ngModel]=\"getValue(colIndex, row)\"\n (ngModelChange)=\"\n handleCellValueChange(colIndex, rowIndex, $event)\n \" />\n </span>\n <span *ngSwitchCase=\"cellType.Boolean\">\n <span\n *ngIf=\"columnDef.disabled && getValue(colIndex, row) === 'true'\"\n impdc-icon\n name=\"check\"\n class=\"{{ getCellColor(columnDef, row) }}\"></span>\n <impdc-checkbox\n *ngIf=\"!columnDef.disabled\"\n [checked]=\"getValue(colIndex, row) === 'true'\"\n [isSwitch]=\"true\"\n (change)=\"\n handleCellValueChange(colIndex, rowIndex, $event.checked)\n \"></impdc-checkbox>\n </span>\n <span *ngSwitchCase=\"cellType.SingleSelect\">\n <impdc-select\n [ngModel]=\"getValue(colIndex, row)\"\n [disabled]=\"columnDef.disabled || false\"\n [placeholder]=\"selectPlaceholder\"\n (selectionChange)=\"\n handleCellValueChange(colIndex, rowIndex, $event.value)\n \">\n <impdc-select-option\n *ngIf=\"selectPlaceholder\"\n value\n [label]=\"selectPlaceholder\">\n </impdc-select-option>\n <impdc-select-option\n *ngFor=\"let value of columnDef.values || []\"\n [value]=\"value.value\"\n [label]=\"value.label\"></impdc-select-option>\n </impdc-select>\n </span>\n <span *ngSwitchCase=\"cellType.MultiSelect\">\n <impdc-select\n [ngModel]=\"getValue(colIndex, row)\"\n [disabled]=\"columnDef.disabled || false\"\n [placeholder]=\"selectPlaceholder\"\n multiple=\"true\"\n (selectionChange)=\"\n handleCellValueChange(colIndex, rowIndex, $event.value)\n \">\n <impdc-select-option\n *ngFor=\"let value of columnDef.values || []\"\n [value]=\"value.value\"\n [label]=\"value.label\"></impdc-select-option>\n </impdc-select>\n </span>\n <span\n *ngSwitchCase=\"cellType.CellRender\"\n class=\"{{ getCellColor(columnDef, row) }}\">\n <ng-template\n impdcTableInjectComponent\n [columnDef]=\"columnDef\"\n [rowItem]=\"row\"\n [customCellComponents]=\"customCellComponents || {}\"\n [value]=\"getRawValue(colIndex, row)\"></ng-template>\n </span>\n <span *ngSwitchCase=\"cellType.Icon\">\n <span\n impdc-icon\n [name]=\"columnDef.iconName\"\n class=\"{{ getCellColor(columnDef, row) }}\"></span>\n </span>\n <span *ngSwitchDefault class=\"{{ getCellColor(columnDef, row) }}\">\n {{ getValue(colIndex, row) }}\n </span>\n </div>\n </td>\n </tr>\n </ng-template>\n </tbody>\n <tfoot>\n <tr *ngIf=\"paginationComponent\">\n <td [attr.colspan]=\"tableSpan\">\n <ng-content\n select=\"impdc-pagination, div[impdc-pagination]\"></ng-content>\n </td>\n </tr>\n </tfoot>\n</table>\n", styles: [".bulk-action-container{display:flex;flex-direction:row;border:1px solid var(--impd-color-gray-200);border-top-left-radius:.6rem;border-top-right-radius:.6rem;border-bottom:0px}.bulk-action-container .bulk-action-checkbox{padding:1.6rem 2rem}.bulk-action-container .bulk-actions{display:flex;flex-direction:row;gap:.4rem}.col-no-padding{padding:0!important}.data-loading{height:var(--impd-size-80);vertical-align:middle;text-align:center}.no-data{vertical-align:middle;text-align:center}.select-row{display:flex;height:var(--impd-size-4);align-items:center;justify-items:end;border-radius:var(--impd-border-radius-default)}.heading-with-checkbox{padding-left:5px;padding-right:10px}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i1.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "directive", type: i3.BrandedDirective, selector: "[impdcBranded]" }, { kind: "component", type: i4.IconComponent, selector: "impdc-icon, [impdc-icon]", inputs: ["name", "theme", "size"] }, { kind: "component", type: i5.CheckboxComponent, selector: "impdc-checkbox", inputs: ["tabIndex", "id", "label", "description", "isSwitch", "switchIcons", "inline", "checked", "indeterminate", "disabled", "errorStateMatcher", "required"], outputs: ["change", "indeterminateChange"], exportAs: ["impdcCheckControl"] }, { kind: "component", type: i6.SelectOptionComponent, selector: "impdc-select-option", inputs: ["value", "label", "id", "disabled"], outputs: ["onSelectionChange"] }, { kind: "component", type: i7.SelectComponent, selector: "impdc-select", inputs: ["disabled", "tabIndex", "placeholder", "required", "multiple", "compareWith", "errorStateMatcher", "value", "id"], outputs: ["selectionChange", "valueChange"], exportAs: ["impdcSelect"] }, { kind: "directive", type: i8.InputDirective, selector: "input[impdcInput], textarea[impdcInput], select[impdcNativeSelect]", inputs: ["disabled", "id", "type", "required", "readonly", "errorStateMatcher", "value"], exportAs: ["impdcInput"] }, { kind: "directive", type: i9.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i9.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i9.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i10.SpinnerComponent, selector: "impdc-spinner, div[impdc-spinner]", inputs: ["accessibilityText"] }, { kind: "component", type: i11.BadgeComponent, selector: "impdc-badge, [impdc-badge]", inputs: ["text", "icon", "theme", "size", "hideBg", "rounded", "dismissable"], outputs: ["dismiss"] }, { kind: "directive", type: i12.TableDirective, selector: "table[impdcTable]", inputs: ["striped"] }, { kind: "component", type: i13.ColumnHeadingComponent, selector: "impdc-column-heading", inputs: ["isSortable", "columnIndex", "sortColumnIndex", "direction", "text"], outputs: ["sort"] }, { kind: "directive", type: i14.TableInjectComponentDirective, selector: "[impdcTableInjectComponent]", inputs: ["columnDef", "value", "rowItem", "customCellComponents"] }] });
342
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TableComponent, decorators: [{
343
+ type: Component,
344
+ args: [{ selector: 'impdc-table', template: "<table impdcTable *ngIf=\"tableData\" [striped]=\"striped\">\n <thead>\n <tr *ngIf=\"!!bulkActions\">\n <th [attr.colspan]=\"tableSpan\" scope=\"col\" class=\"bulk-action-column\">\n <ng-content select=\"impdc-table-bulk-actions\"></ng-content>\n <ng-content select=\"[impdcTableBulkActions]\"></ng-content>\n </th>\n </tr>\n <tr>\n <th\n *ngIf=\"canSelectRows\"\n scope=\"col\"\n [ngClass]=\"{\n 'heading-below-bulk-actions': !!bulkActions\n }\">\n <div *ngIf=\"canSelectAllRows\">\n <impdc-checkbox\n ngModel\n [checked]=\"allSelected\"\n [indeterminate]=\"someSelected\"\n (change)=\"handleSelectAll($event)\"></impdc-checkbox>\n </div>\n </th>\n <th\n scope=\"col\"\n *ngFor=\"let columnDef of columnDefs; index as columnIndex\"\n [ngClass]=\"{\n 'sorted-column': isSortedColumn(columnIndex),\n 'sortable-column': columnDef.sorted,\n 'heading-below-bulk-actions': !!bulkActions\n }\"\n (click)=\"handleSort(columnIndex)\">\n <impdc-column-heading\n [isSortable]=\"columnDef.sorted || false\"\n [columnIndex]=\"columnIndex\"\n [sortColumnIndex]=\"sortColumnIndex\"\n [direction]=\"sortDirection\"\n [text]=\"columnDef.title\"\n (sort)=\"handleSort($event)\">\n </impdc-column-heading>\n </th>\n </tr>\n </thead>\n <tbody>\n <tr *ngIf=\"loading; else data\">\n <td [attr.colspan]=\"tableSpan\" class=\"data-loading\">\n <impdc-spinner></impdc-spinner>\n </td>\n </tr>\n <ng-template #data>\n <tr *ngIf=\"tableData.length === 0\">\n <td [attr.colspan]=\"tableSpan\" class=\"no-data\">\n <ng-content select=\"[noData]\"></ng-content>\n </td>\n </tr>\n <tr *ngFor=\"let row of tableData; index as rowIndex\">\n <td *ngIf=\"canSelectRows\">\n <div class=\"select-column\">\n <impdc-checkbox\n [ngModel]=\"isRowSelected(row.id)\"\n (change)=\"handleRowSelect($event, row.id)\"></impdc-checkbox>\n </div>\n </td>\n <td\n *ngFor=\"let columnDef of columnDefs; index as colIndex\"\n [ngClass]=\"{\n 'col-no-padding': !!columnDef.noPadding\n }\">\n <div [ngSwitch]=\"columnDef.columnType\">\n <span *ngSwitchCase=\"cellType.Badge\">\n <impdc-badge\n [text]=\"getStringValue(colIndex, row)\"\n [theme]=\"getTheme(columnDef, row)\">\n </impdc-badge>\n </span>\n <span\n *ngSwitchCase=\"cellType.Link\"\n class=\"cell-type-link\"\n (click)=\"handleLinkClick(colIndex, row)\">\n <a *ngIf=\"!branded\">\n {{ getValue(colIndex, row) }}\n </a>\n <a *ngIf=\"branded\" impdcBranded>\n {{ getValue(colIndex, row) }}\n </a>\n </span>\n <span *ngSwitchCase=\"cellType.Url\" class=\"cell-type-link\">\n <a\n *ngIf=\"!branded\"\n target=\"_blank\"\n [attr.href]=\"getValue(colIndex, row)\">\n {{ getValue(colIndex, row) }}\n </a>\n <a\n *ngIf=\"branded\"\n impdcBranded\n target=\"_blank\"\n [attr.href]=\"getValue(colIndex, row)\">\n {{ getValue(colIndex, row) }}\n </a>\n </span>\n <span *ngSwitchCase=\"cellType.Email\" class=\"cell-type-link\">\n <a\n *ngIf=\"!branded\"\n target=\"_blank\"\n [attr.href]=\"'mailto:' + getValue(colIndex, row)\">\n {{ getValue(colIndex, row) }}\n </a>\n <a\n *ngIf=\"branded\"\n impdcBranded\n [attr.href]=\"getMailToValue(colIndex, row)\">\n {{ getValue(colIndex, row) }}\n </a>\n </span>\n <span *ngSwitchCase=\"cellType.Input\">\n <input\n impdcInput\n type=\"text\"\n class=\"{{ getCellColor(columnDef, row) }}\"\n [ngModel]=\"getValue(colIndex, row)\"\n (ngModelChange)=\"\n handleCellValueChange(colIndex, rowIndex, $event)\n \" />\n </span>\n <span *ngSwitchCase=\"cellType.Boolean\">\n <span\n *ngIf=\"columnDef.disabled && getValue(colIndex, row) === 'true'\"\n impdc-icon\n name=\"check\"\n class=\"{{ getCellColor(columnDef, row) }}\"></span>\n <impdc-checkbox\n *ngIf=\"!columnDef.disabled\"\n [checked]=\"getValue(colIndex, row) === 'true'\"\n [isSwitch]=\"true\"\n (change)=\"\n handleCellValueChange(colIndex, rowIndex, $event.checked)\n \"></impdc-checkbox>\n </span>\n <span *ngSwitchCase=\"cellType.SingleSelect\">\n <impdc-select\n [ngModel]=\"getValue(colIndex, row)\"\n [disabled]=\"columnDef.disabled || false\"\n [placeholder]=\"selectPlaceholder\"\n (selectionChange)=\"\n handleCellValueChange(colIndex, rowIndex, $event.value)\n \">\n <impdc-select-option\n *ngIf=\"selectPlaceholder\"\n value\n [label]=\"selectPlaceholder\">\n </impdc-select-option>\n <impdc-select-option\n *ngFor=\"let value of columnDef.values || []\"\n [value]=\"value.value\"\n [label]=\"value.label\"></impdc-select-option>\n </impdc-select>\n </span>\n <span *ngSwitchCase=\"cellType.MultiSelect\">\n <impdc-select\n [ngModel]=\"getValue(colIndex, row)\"\n [disabled]=\"columnDef.disabled || false\"\n [placeholder]=\"selectPlaceholder\"\n multiple=\"true\"\n (selectionChange)=\"\n handleCellValueChange(colIndex, rowIndex, $event.value)\n \">\n <impdc-select-option\n *ngFor=\"let value of columnDef.values || []\"\n [value]=\"value.value\"\n [label]=\"value.label\"></impdc-select-option>\n </impdc-select>\n </span>\n <span\n *ngSwitchCase=\"cellType.CellRender\"\n class=\"{{ getCellColor(columnDef, row) }}\">\n <ng-template\n impdcTableInjectComponent\n [columnDef]=\"columnDef\"\n [rowItem]=\"row\"\n [customCellComponents]=\"customCellComponents || {}\"\n [value]=\"getRawValue(colIndex, row)\"></ng-template>\n </span>\n <span *ngSwitchCase=\"cellType.Icon\">\n <span\n impdc-icon\n [name]=\"columnDef.iconName\"\n class=\"{{ getCellColor(columnDef, row) }}\"></span>\n </span>\n <span *ngSwitchDefault class=\"{{ getCellColor(columnDef, row) }}\">\n {{ getValue(colIndex, row) }}\n </span>\n </div>\n </td>\n </tr>\n </ng-template>\n </tbody>\n <tfoot>\n <tr *ngIf=\"paginationComponent\">\n <td [attr.colspan]=\"tableSpan\">\n <ng-content\n select=\"impdc-pagination, div[impdc-pagination]\"></ng-content>\n </td>\n </tr>\n </tfoot>\n</table>\n", styles: [".bulk-action-container{display:flex;flex-direction:row;border:1px solid var(--impd-color-gray-200);border-top-left-radius:.6rem;border-top-right-radius:.6rem;border-bottom:0px}.bulk-action-container .bulk-action-checkbox{padding:1.6rem 2rem}.bulk-action-container .bulk-actions{display:flex;flex-direction:row;gap:.4rem}.col-no-padding{padding:0!important}.data-loading{height:var(--impd-size-80);vertical-align:middle;text-align:center}.no-data{vertical-align:middle;text-align:center}.select-row{display:flex;height:var(--impd-size-4);align-items:center;justify-items:end;border-radius:var(--impd-border-radius-default)}.heading-with-checkbox{padding-left:5px;padding-right:10px}\n"] }]
345
+ }], ctorParameters: function () { return [{ type: i1.DatePipe }, { type: i1.PercentPipe }, { type: i1.DecimalPipe }, { type: i0.ChangeDetectorRef }, { type: i2.BrandedDirective, decorators: [{
346
+ type: Optional
347
+ }, {
348
+ type: Host
349
+ }] }]; }, propDecorators: { loading: [{
350
+ type: Input
351
+ }], columnDefs: [{
352
+ type: Input
353
+ }], striped: [{
354
+ type: Input
355
+ }], canSelectRows: [{
356
+ type: Input
357
+ }], canSelectAllRows: [{
358
+ type: Input
359
+ }], selectPlaceholder: [{
360
+ type: Input
361
+ }], sortColumnIndex: [{
362
+ type: Input
363
+ }], sortDirection: [{
364
+ type: Input
365
+ }], tableData: [{
366
+ type: Input
367
+ }], selectedRowIds: [{
368
+ type: Input
369
+ }], customCellComponents: [{
370
+ type: Input
371
+ }], rowSelect: [{
372
+ type: Output
373
+ }], sortBy: [{
374
+ type: Output
375
+ }], linkClick: [{
376
+ type: Output
377
+ }], paginationComponent: [{
378
+ type: ContentChild,
379
+ args: [PaginationComponent]
380
+ }], bulkActions: [{
381
+ type: ContentChild,
382
+ args: [TableBulkActionsComponent]
383
+ }], inputChange: [{
384
+ type: Output
385
+ }] } });
386
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../../projects/design-components/src/lib/table/containers/table.component.ts","../../../../../../../projects/design-components/src/lib/table/containers/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DatePipe, DecimalPipe, PercentPipe } from '@angular/common';\nimport {\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  EventEmitter,\n  Host,\n  Input,\n  OnChanges,\n  Optional,\n  Output,\n  SimpleChanges\n} from '@angular/core';\nimport { get as getNestedValue, set as setNestedValue } from 'lodash';\nimport { debounceTime } from 'rxjs/operators';\n\nimport { DEBOUNCE_TIME, SORT_COLUMN_INDEX } from '../constants/index';\nimport { TableColumnType } from '../enumerations/index';\nimport {\n  ICustomCellRendererComponents,\n  ISortByPayload,\n  ITableColumnDef,\n  ITableEventPayload,\n  ITableRowItem,\n  ITableRowItemValue,\n  ITableRowItemValueTypes\n} from '../interfaces/index';\nimport { CheckboxChangeEvent } from '../../form-field';\nimport { TableThemeHelper } from '../helpers';\nimport { ComponentTheme } from '../../../types';\nimport { BrandedDirective } from '../../branding';\nimport { PaginationComponent } from '../../pagination';\nimport { TableBulkActionsComponent } from '../components';\n\n/**\n * The `TableComponent` (`<impdc-table`) is a data table component.\n * To use, import `TableModule` from `@impartner/design-components`.\n */\n@Component({\n  selector: 'impdc-table',\n  styleUrls: ['./table.component.scss'],\n  templateUrl: './table.component.html'\n})\nexport class TableComponent implements OnChanges {\n  /**\n   * Whether the table data is currently being loaded. The `<impdc-spinner>` will show if data is loading.\n   */\n  @Input() public loading = false;\n\n  /**\n   * The visible columns of the table.  Each `ITableColumnDef` defines properties regarding the display, formatting and interaction of the column's cells.\n   * Column/cell color precedence is:\n   * 1) `fieldColor` - allows an `ITableColumnDef` to delegate the responsibility of cell color to an `ITableRowItem` property.\n   * 2) `colorGetter`- allows an `ITableColumnDef` to delegate the responsibility of cell color to a function of the `ITableRowItem` determined by the developer.\n   * 3) `color` - a property of an `ITableColumnDef`.\n   */\n  @Input() public columnDefs: ITableColumnDef[] = [];\n\n  /**\n   * Whether the table is striped.\n   */\n  @Input() public striped = true;\n\n  /**\n   * Whether individual rows can be selected. Will be `true` if explicitly set to `true` or `canSelectAllRows` is `true`.\n   */\n  @Input() public set canSelectRows(value: boolean) {\n    this._canSelectRows = value;\n  }\n  public get canSelectRows(): boolean {\n    return this.canSelectAllRows || this._canSelectRows || !!this.bulkActions;\n  }\n\n  /**\n   * Whether all rows can be selected at once. Will be `true` if explicitly set to `true` or if `TableBulkActionsComponent` is content projected.\n   */\n  @Input()\n  public set canSelectAllRows(value: boolean) {\n    this._canSelectAllRows = value;\n  }\n\n  public get canSelectAllRows(): boolean {\n    return this._canSelectAllRows || !!this.bulkActions;\n  }\n\n  /**\n   * The placeholder text and empty value display text for `<impdc-select>` instances in cells with a `ITableColumnDef` `columnType` = `SingleSelect` or `MultiSelect`.\n   */\n  @Input() public selectPlaceholder = '';\n\n  /**\n   * The `columnDefs` index of the currently sorted column.\n   */\n  @Input() public sortColumnIndex = SORT_COLUMN_INDEX;\n\n  /**\n   * The direction of the currently sorted column.\n   */\n  @Input() public sortDirection: 'asc' | 'desc' = 'asc';\n\n  /**\n   * The table row data as an array of `ITableRowItem`.\n   */\n  @Input() public tableData: ITableRowItem[] = [];\n\n  /**\n   * An array of currently selected IDs from the `tableData` input.  Array must be of type `(string | number)[]`.\n   */\n  @Input()\n  public set selectedRowIds(value: (string | number)[]) {\n    this._selectedRowIds = [...value];\n  }\n  public get selectedRowIds(): (string | number)[] {\n    return [...this._selectedRowIds];\n  }\n\n  /**\n   * The registered custom cell renderer components available to be used in the table instance.\n   * For a given `ITableColumnDef` in the `columnDefs` input, the `cellRendererComponent` property should be set to the key of the registered component in this input.\n   */\n  @Input() public customCellComponents?: ICustomCellRendererComponents;\n\n  /**\n   * Event emitted when one or multiple rows are selected. Emits `(string | number)[]` payload.\n   */\n  @Output() public readonly rowSelect = new EventEmitter<(string | number)[]>();\n\n  /**\n   * Event emitted when a column is sorted. Emits `ISortByPayload` payload.\n   */\n  @Output() public readonly sortBy = new EventEmitter<ISortByPayload>();\n\n  /**\n   * Event emitted when a row link is clicked. Emits `ITableEventPayload` payload.\n   */\n  @Output() public readonly linkClick = new EventEmitter<ITableEventPayload>();\n\n  /** @ignore */\n  @ContentChild(PaginationComponent)\n  public paginationComponent?: PaginationComponent = undefined;\n\n  /** @ignore */\n  @ContentChild(TableBulkActionsComponent)\n  public bulkActions?: TableBulkActionsComponent = undefined;\n\n  /**\n   * Event emitted when a row input value is changed. Emitted cells of `columnType` `SinglSelect`, `MultiSelect`, `Input`, `Boolean` or `Icon`.\n   * Not emitted if column definition property `disabled` = `true`. Emits `ITableEventPayload` payload.\n   */\n  @Output() public readonly inputChange =\n    new EventEmitter<ITableEventPayload>();\n\n  /** @ignore */\n  public cellType = TableColumnType;\n  /** @ignore */\n  public allSelected = true;\n  /** @ignore */\n  public get someSelected(): boolean {\n    return (\n      !!this._selectedRowIds &&\n      this._selectedRowIds.length > 0 &&\n      !!this.tableData &&\n      this.tableData.length > 0 &&\n      this._selectedRowIds.length < this.tableData.length\n    );\n  }\n  /** @ignore */\n  public readonly branded: boolean = false;\n\n  /** @ignore */\n  public get tableSpan(): number {\n    return this.canSelectRows\n      ? this.columnDefs.length + 1\n      : this.columnDefs.length;\n  }\n\n  private _canSelectRows = false;\n  private _canSelectAllRows = false;\n  private _selectedRowIds: (string | number)[] = [];\n  private readonly _inputChange = new EventEmitter<ITableEventPayload>();\n\n  constructor(\n    private readonly _datePipe: DatePipe,\n    private readonly _percentPipe: PercentPipe,\n    private readonly _decmialPipe: DecimalPipe,\n    private readonly _changeDetectorRef: ChangeDetectorRef,\n    @Optional() @Host() private _branded: BrandedDirective\n  ) {\n    this.branded = _branded ? true : false;\n    this._inputChange\n      .pipe(debounceTime(DEBOUNCE_TIME))\n      .subscribe(this.inputChange);\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['selectedRowIds'] || changes['tableData']) {\n      if (\n        !this.tableData ||\n        !this.tableData.length ||\n        !this.selectedRowIds ||\n        !this.selectedRowIds.length\n      ) {\n        this.allSelected = false;\n      } else {\n        this.allSelected = this.selectedRowIds.length >= this.tableData.length;\n      }\n    }\n  }\n\n  public getMailToValue(\n    columnIndex: number,\n    currentRow: ITableRowItem\n  ): string {\n    const { columnType, truncated: truncated } =\n      this._getColumnDefByIndex(columnIndex);\n    let value = this._getValue(columnIndex, currentRow);\n\n    if (columnType !== TableColumnType.Email) {\n      return String(value);\n    }\n    value = value ? `mailto:${value}` : value;\n\n    return String(value);\n  }\n\n  public getStringValue(\n    columnIndex: number,\n    currentRow: ITableRowItem\n  ): string {\n    const value = this.getValue(columnIndex, currentRow);\n\n    if (Array.isArray(value)) {\n      return value.join(';');\n    }\n\n    return String(value);\n  }\n\n  public getValue(\n    columnIndex: number,\n    currentRow: ITableRowItem\n  ): string | string[] {\n    const { columnType, truncated: truncated } =\n      this._getColumnDefByIndex(columnIndex);\n    let value = this._getValue(columnIndex, currentRow);\n\n    switch (columnType) {\n      case TableColumnType.Decimal: {\n        value = this._decmialPipe.transform(Number(value) || 0) || '';\n        break;\n      }\n      case TableColumnType.Date: {\n        const date = new Date(String(value));\n        const validDate = date instanceof Date && !isNaN(date.getTime());\n        value = validDate\n          ? this._datePipe.transform(date, 'MM/dd/yyyy') || ''\n          : String(value);\n        break;\n      }\n      case TableColumnType.DateTime: {\n        const dateTime = new Date(String(value));\n        const validDateTime =\n          dateTime instanceof Date && !isNaN(dateTime.getTime());\n        value = validDateTime\n          ? this._datePipe.transform(dateTime, 'MM/dd/yyyy h:mm:ss a') || ''\n          : String(value);\n        break;\n      }\n      case TableColumnType.Link: {\n        value = String(value).replace(/(^\\w+:|^)\\/\\//, '');\n        break;\n      }\n      case TableColumnType.Percentage: {\n        value = this._percentPipe.transform(Number(value) || 0) || '';\n        break;\n      }\n      case TableColumnType.Url: {\n        if (!/(http(s?)):\\/\\//i.test(String(value))) {\n          value = `https://${value}`;\n        }\n        break;\n      }\n      case TableColumnType.Text: {\n        if (Array.isArray(value)) {\n          value = value.join('; ');\n        }\n\n        if (!truncated) {\n          return value;\n        }\n\n        const truncateString = (string = '', maxLength = truncated) =>\n          string.length > maxLength\n            ? `${string.substring(0, maxLength)}…`\n            : string;\n\n        !!truncated\n          ? (value = truncateString(String(value), truncated))\n          : value;\n        break;\n      }\n      case TableColumnType.MultiSelect:\n        if (typeof value === 'string') {\n          value = value.split(';')?.map(v => v.trim()) || [];\n        }\n        return value;\n    }\n\n    return String(value);\n  }\n\n  public getRawValue(\n    columnIndex: number,\n    currentRow: ITableRowItem\n  ): ITableRowItemValueTypes<ITableRowItemValue> {\n    const { field } = this._getColumnDefByIndex(columnIndex);\n\n    if (!field) {\n      return '';\n    }\n\n    return currentRow[field] || '';\n  }\n\n  public getCellColor(\n    columnDefinition: ITableColumnDef,\n    item: ITableRowItem\n  ): string {\n    return TableThemeHelper.getCellColor(columnDefinition, item);\n  }\n\n  public getTheme(\n    columnDefinition: ITableColumnDef,\n    item: ITableRowItem\n  ): ComponentTheme {\n    return (\n      TableThemeHelper.getTheme(columnDefinition, item) ||\n      ComponentTheme.Primary\n    );\n  }\n\n  public isSortedColumn(columnIndex: number): boolean {\n    return columnIndex === this.sortColumnIndex;\n  }\n\n  public isRowSelected(id: string | number): boolean {\n    return this.selectedRowIds.includes(id);\n  }\n\n  public handleSelectAll(event: CheckboxChangeEvent): void {\n    if (!this.canSelectAllRows || !this.tableData) {\n      return;\n    }\n\n    if (event.checked) {\n      this._selectedRowIds = this.tableData?.map(row => row.id) || [];\n    } else {\n      this._selectedRowIds = [];\n    }\n\n    this._selectedRowIds.sort();\n    this.allSelected = this.selectedRowIds.length >= this.tableData.length;\n\n    this.rowSelect.emit(this.selectedRowIds);\n  }\n\n  public handleSort(columnIndex: number): void {\n    if (columnIndex === this.sortColumnIndex) {\n      this.sortDirection = this.sortDirection === 'asc' ? 'desc' : 'asc';\n    } else {\n      this.sortColumnIndex = columnIndex;\n      this.sortDirection = 'asc';\n    }\n\n    const field = this._getColumnDefByIndex(columnIndex).field || '';\n\n    this.sortBy.emit({\n      columnIndex,\n      field,\n      direction: this.sortDirection\n    });\n  }\n\n  public handleRowSelect(\n    event: CheckboxChangeEvent,\n    rowId: number | string\n  ): void {\n    if (!this.canSelectRows) {\n      return;\n    }\n\n    if (event.checked && !this._selectedRowIds.includes(rowId)) {\n      this._selectedRowIds.push(rowId);\n    } else if (!event.checked && this._selectedRowIds.includes(rowId)) {\n      const idx = this._selectedRowIds.indexOf(rowId);\n      if (idx > -1) {\n        this._selectedRowIds.splice(idx, 1);\n      }\n    }\n\n    if (this._selectedRowIds.length) {\n      this._selectedRowIds.sort();\n    }\n\n    this.allSelected = this.selectedRowIds.length >= this.tableData.length;\n    this.rowSelect.emit(this.selectedRowIds);\n  }\n\n  public handleCellValueChange(\n    columnIndex: number,\n    rowIndex: number,\n    value: string | number | boolean | string[]\n  ): void {\n    const { field, columnType } = this._getColumnDefByIndex(columnIndex);\n    let currentValue: string | number | boolean | string[] = value;\n\n    if (columnType !== TableColumnType.Boolean && !Array.isArray(value)) {\n      currentValue = isNaN(Number(value)) ? value : Number(value);\n    }\n    const item = this.tableData[rowIndex];\n\n    setNestedValue(item, String(field), currentValue);\n\n    this._inputChange.emit({\n      columnIndex,\n      item,\n      value: currentValue\n    });\n\n    this._changeDetectorRef.detectChanges();\n  }\n\n  public handleLinkClick(columnIndex: number, item: ITableRowItem): void {\n    this.linkClick.emit({\n      item,\n      columnIndex\n    });\n  }\n\n  private _getColumnDefByIndex(columnIndex: number): ITableColumnDef {\n    return this.columnDefs[columnIndex];\n  }\n\n  private _getValue(\n    columnIndex: number,\n    currentRow: ITableRowItem\n  ): string | string[] {\n    try {\n      const { field, valueGetter } = this._getColumnDefByIndex(columnIndex);\n\n      const value: string | string[] = valueGetter\n        ? valueGetter(currentRow)\n        : (getNestedValue(currentRow, String(field), '') as string | string[]);\n\n      return value || '';\n    } catch (e) {\n      return '';\n    }\n  }\n}\n","<table impdcTable *ngIf=\"tableData\" [striped]=\"striped\">\n  <thead>\n    <tr *ngIf=\"!!bulkActions\">\n      <th [attr.colspan]=\"tableSpan\" scope=\"col\" class=\"bulk-action-column\">\n        <ng-content select=\"impdc-table-bulk-actions\"></ng-content>\n        <ng-content select=\"[impdcTableBulkActions]\"></ng-content>\n      </th>\n    </tr>\n    <tr>\n      <th\n        *ngIf=\"canSelectRows\"\n        scope=\"col\"\n        [ngClass]=\"{\n          'heading-below-bulk-actions': !!bulkActions\n        }\">\n        <div *ngIf=\"canSelectAllRows\">\n          <impdc-checkbox\n            ngModel\n            [checked]=\"allSelected\"\n            [indeterminate]=\"someSelected\"\n            (change)=\"handleSelectAll($event)\"></impdc-checkbox>\n        </div>\n      </th>\n      <th\n        scope=\"col\"\n        *ngFor=\"let columnDef of columnDefs; index as columnIndex\"\n        [ngClass]=\"{\n          'sorted-column': isSortedColumn(columnIndex),\n          'sortable-column': columnDef.sorted,\n          'heading-below-bulk-actions': !!bulkActions\n        }\"\n        (click)=\"handleSort(columnIndex)\">\n        <impdc-column-heading\n          [isSortable]=\"columnDef.sorted || false\"\n          [columnIndex]=\"columnIndex\"\n          [sortColumnIndex]=\"sortColumnIndex\"\n          [direction]=\"sortDirection\"\n          [text]=\"columnDef.title\"\n          (sort)=\"handleSort($event)\">\n        </impdc-column-heading>\n      </th>\n    </tr>\n  </thead>\n  <tbody>\n    <tr *ngIf=\"loading; else data\">\n      <td [attr.colspan]=\"tableSpan\" class=\"data-loading\">\n        <impdc-spinner></impdc-spinner>\n      </td>\n    </tr>\n    <ng-template #data>\n      <tr *ngIf=\"tableData.length === 0\">\n        <td [attr.colspan]=\"tableSpan\" class=\"no-data\">\n          <ng-content select=\"[noData]\"></ng-content>\n        </td>\n      </tr>\n      <tr *ngFor=\"let row of tableData; index as rowIndex\">\n        <td *ngIf=\"canSelectRows\">\n          <div class=\"select-column\">\n            <impdc-checkbox\n              [ngModel]=\"isRowSelected(row.id)\"\n              (change)=\"handleRowSelect($event, row.id)\"></impdc-checkbox>\n          </div>\n        </td>\n        <td\n          *ngFor=\"let columnDef of columnDefs; index as colIndex\"\n          [ngClass]=\"{\n            'col-no-padding': !!columnDef.noPadding\n          }\">\n          <div [ngSwitch]=\"columnDef.columnType\">\n            <span *ngSwitchCase=\"cellType.Badge\">\n              <impdc-badge\n                [text]=\"getStringValue(colIndex, row)\"\n                [theme]=\"getTheme(columnDef, row)\">\n              </impdc-badge>\n            </span>\n            <span\n              *ngSwitchCase=\"cellType.Link\"\n              class=\"cell-type-link\"\n              (click)=\"handleLinkClick(colIndex, row)\">\n              <a *ngIf=\"!branded\">\n                {{ getValue(colIndex, row) }}\n              </a>\n              <a *ngIf=\"branded\" impdcBranded>\n                {{ getValue(colIndex, row) }}\n              </a>\n            </span>\n            <span *ngSwitchCase=\"cellType.Url\" class=\"cell-type-link\">\n              <a\n                *ngIf=\"!branded\"\n                target=\"_blank\"\n                [attr.href]=\"getValue(colIndex, row)\">\n                {{ getValue(colIndex, row) }}\n              </a>\n              <a\n                *ngIf=\"branded\"\n                impdcBranded\n                target=\"_blank\"\n                [attr.href]=\"getValue(colIndex, row)\">\n                {{ getValue(colIndex, row) }}\n              </a>\n            </span>\n            <span *ngSwitchCase=\"cellType.Email\" class=\"cell-type-link\">\n              <a\n                *ngIf=\"!branded\"\n                target=\"_blank\"\n                [attr.href]=\"'mailto:' + getValue(colIndex, row)\">\n                {{ getValue(colIndex, row) }}\n              </a>\n              <a\n                *ngIf=\"branded\"\n                impdcBranded\n                [attr.href]=\"getMailToValue(colIndex, row)\">\n                {{ getValue(colIndex, row) }}\n              </a>\n            </span>\n            <span *ngSwitchCase=\"cellType.Input\">\n              <input\n                impdcInput\n                type=\"text\"\n                class=\"{{ getCellColor(columnDef, row) }}\"\n                [ngModel]=\"getValue(colIndex, row)\"\n                (ngModelChange)=\"\n                  handleCellValueChange(colIndex, rowIndex, $event)\n                \" />\n            </span>\n            <span *ngSwitchCase=\"cellType.Boolean\">\n              <span\n                *ngIf=\"columnDef.disabled && getValue(colIndex, row) === 'true'\"\n                impdc-icon\n                name=\"check\"\n                class=\"{{ getCellColor(columnDef, row) }}\"></span>\n              <impdc-checkbox\n                *ngIf=\"!columnDef.disabled\"\n                [checked]=\"getValue(colIndex, row) === 'true'\"\n                [isSwitch]=\"true\"\n                (change)=\"\n                  handleCellValueChange(colIndex, rowIndex, $event.checked)\n                \"></impdc-checkbox>\n            </span>\n            <span *ngSwitchCase=\"cellType.SingleSelect\">\n              <impdc-select\n                [ngModel]=\"getValue(colIndex, row)\"\n                [disabled]=\"columnDef.disabled || false\"\n                [placeholder]=\"selectPlaceholder\"\n                (selectionChange)=\"\n                  handleCellValueChange(colIndex, rowIndex, $event.value)\n                \">\n                <impdc-select-option\n                  *ngIf=\"selectPlaceholder\"\n                  value\n                  [label]=\"selectPlaceholder\">\n                </impdc-select-option>\n                <impdc-select-option\n                  *ngFor=\"let value of columnDef.values || []\"\n                  [value]=\"value.value\"\n                  [label]=\"value.label\"></impdc-select-option>\n              </impdc-select>\n            </span>\n            <span *ngSwitchCase=\"cellType.MultiSelect\">\n              <impdc-select\n                [ngModel]=\"getValue(colIndex, row)\"\n                [disabled]=\"columnDef.disabled || false\"\n                [placeholder]=\"selectPlaceholder\"\n                multiple=\"true\"\n                (selectionChange)=\"\n                  handleCellValueChange(colIndex, rowIndex, $event.value)\n                \">\n                <impdc-select-option\n                  *ngFor=\"let value of columnDef.values || []\"\n                  [value]=\"value.value\"\n                  [label]=\"value.label\"></impdc-select-option>\n              </impdc-select>\n            </span>\n            <span\n              *ngSwitchCase=\"cellType.CellRender\"\n              class=\"{{ getCellColor(columnDef, row) }}\">\n              <ng-template\n                impdcTableInjectComponent\n                [columnDef]=\"columnDef\"\n                [rowItem]=\"row\"\n                [customCellComponents]=\"customCellComponents || {}\"\n                [value]=\"getRawValue(colIndex, row)\"></ng-template>\n            </span>\n            <span *ngSwitchCase=\"cellType.Icon\">\n              <span\n                impdc-icon\n                [name]=\"columnDef.iconName\"\n                class=\"{{ getCellColor(columnDef, row) }}\"></span>\n            </span>\n            <span *ngSwitchDefault class=\"{{ getCellColor(columnDef, row) }}\">\n              {{ getValue(colIndex, row) }}\n            </span>\n          </div>\n        </td>\n      </tr>\n    </ng-template>\n  </tbody>\n  <tfoot>\n    <tr *ngIf=\"paginationComponent\">\n      <td [attr.colspan]=\"tableSpan\">\n        <ng-content\n          select=\"impdc-pagination, div[impdc-pagination]\"></ng-content>\n      </td>\n    </tr>\n  </tfoot>\n</table>\n"]}
@@ -0,0 +1,3 @@
1
+ export * from './table-inject-component.directive';
2
+ export * from './table.directive';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZXNpZ24tY29tcG9uZW50cy9zcmMvbGliL3RhYmxlL2RpcmVjdGl2ZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxvQ0FBb0MsQ0FBQztBQUNuRCxjQUFjLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi90YWJsZS1pbmplY3QtY29tcG9uZW50LmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL3RhYmxlLmRpcmVjdGl2ZSc7XG4iXX0=
@@ -0,0 +1,46 @@
1
+ import { Directive, Input } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class TableInjectComponentDirective {
4
+ constructor(_viewContainerRef, _componentFactoryResolver) {
5
+ this._viewContainerRef = _viewContainerRef;
6
+ this._componentFactoryResolver = _componentFactoryResolver;
7
+ this.columnDef = { title: '' };
8
+ this.value = '';
9
+ this.rowItem = { id: 0 };
10
+ this.customCellComponents = {};
11
+ }
12
+ ngOnInit() {
13
+ this._renderCustomCell();
14
+ }
15
+ _renderCustomCell() {
16
+ const { cellRendererComponent, cellRendererParams } = this.columnDef;
17
+ if (!cellRendererComponent) {
18
+ return;
19
+ }
20
+ const item = this.rowItem;
21
+ const customCellComponent = this.customCellComponents[cellRendererComponent];
22
+ this._viewContainerRef.clear();
23
+ const componentFactory = this._componentFactoryResolver.resolveComponentFactory(customCellComponent);
24
+ const componentRef = this._viewContainerRef.createComponent(componentFactory);
25
+ componentRef.instance.value = this.value;
26
+ componentRef.instance.rowItem = item;
27
+ componentRef.instance.params = cellRendererParams;
28
+ }
29
+ }
30
+ TableInjectComponentDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TableInjectComponentDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.ComponentFactoryResolver }], target: i0.ɵɵFactoryTarget.Directive });
31
+ TableInjectComponentDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.12", type: TableInjectComponentDirective, selector: "[impdcTableInjectComponent]", inputs: { columnDef: "columnDef", value: "value", rowItem: "rowItem", customCellComponents: "customCellComponents" }, ngImport: i0 });
32
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TableInjectComponentDirective, decorators: [{
33
+ type: Directive,
34
+ args: [{
35
+ selector: '[impdcTableInjectComponent]'
36
+ }]
37
+ }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.ComponentFactoryResolver }]; }, propDecorators: { columnDef: [{
38
+ type: Input
39
+ }], value: [{
40
+ type: Input
41
+ }], rowItem: [{
42
+ type: Input
43
+ }], customCellComponents: [{
44
+ type: Input
45
+ }] } });
46
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtaW5qZWN0LWNvbXBvbmVudC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZXNpZ24tY29tcG9uZW50cy9zcmMvbGliL3RhYmxlL2RpcmVjdGl2ZXMvdGFibGUtaW5qZWN0LWNvbXBvbmVudC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUVMLFNBQVMsRUFDVCxLQUFLLEVBR04sTUFBTSxlQUFlLENBQUM7O0FBY3ZCLE1BQU0sT0FBTyw2QkFBNkI7SUFNeEMsWUFDbUIsaUJBQW1DLEVBQ25DLHlCQUFtRDtRQURuRCxzQkFBaUIsR0FBakIsaUJBQWlCLENBQWtCO1FBQ25DLDhCQUF5QixHQUF6Qix5QkFBeUIsQ0FBMEI7UUFQdEQsY0FBUyxHQUFvQixFQUFFLEtBQUssRUFBRSxFQUFFLEVBQUUsQ0FBQztRQUMzQyxVQUFLLEdBQWdELEVBQUUsQ0FBQztRQUN4RCxZQUFPLEdBQWtCLEVBQUUsRUFBRSxFQUFFLENBQUMsRUFBRSxDQUFDO1FBQ25DLHlCQUFvQixHQUFrQyxFQUFFLENBQUM7SUFLdEUsQ0FBQztJQUVHLFFBQVE7UUFDYixJQUFJLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztJQUMzQixDQUFDO0lBRU8saUJBQWlCO1FBQ3ZCLE1BQU0sRUFBRSxxQkFBcUIsRUFBRSxrQkFBa0IsRUFBRSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUM7UUFDckUsSUFBSSxDQUFDLHFCQUFxQixFQUFFO1lBQzFCLE9BQU87U0FDUjtRQUVELE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUM7UUFDMUIsTUFBTSxtQkFBbUIsR0FDdkIsSUFBSSxDQUFDLG9CQUFvQixDQUFDLHFCQUFxQixDQUFDLENBQUM7UUFFbkQsSUFBSSxDQUFDLGlCQUFpQixDQUFDLEtBQUssRUFBRSxDQUFDO1FBRS9CLE1BQU0sZ0JBQWdCLEdBQ3BCLElBQUksQ0FBQyx5QkFBeUIsQ0FBQyx1QkFBdUIsQ0FDcEQsbUJBQW1CLENBQ3BCLENBQUM7UUFDSixNQUFNLFlBQVksR0FDaEIsSUFBSSxDQUFDLGlCQUFpQixDQUFDLGVBQWUsQ0FBZ0IsZ0JBQWdCLENBQUMsQ0FBQztRQUUxRSxZQUFZLENBQUMsUUFBUSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDO1FBQ3pDLFlBQVksQ0FBQyxRQUFRLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQztRQUNyQyxZQUFZLENBQUMsUUFBUSxDQUFDLE1BQU0sR0FBRyxrQkFBa0IsQ0FBQztJQUNwRCxDQUFDOzsySEFyQ1UsNkJBQTZCOytHQUE3Qiw2QkFBNkI7NEZBQTdCLDZCQUE2QjtrQkFIekMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsNkJBQTZCO2lCQUN4Qzs4SUFFaUIsU0FBUztzQkFBeEIsS0FBSztnQkFDVSxLQUFLO3NCQUFwQixLQUFLO2dCQUNVLE9BQU87c0JBQXRCLEtBQUs7Z0JBQ1Usb0JBQW9CO3NCQUFuQyxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ29tcG9uZW50RmFjdG9yeVJlc29sdmVyLFxuICBEaXJlY3RpdmUsXG4gIElucHV0LFxuICBPbkluaXQsXG4gIFZpZXdDb250YWluZXJSZWZcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7XG4gIElDZWxsUmVuZGVyZXIsXG4gIElDdXN0b21DZWxsUmVuZGVyZXJDb21wb25lbnRzLFxuICBJVGFibGVDb2x1bW5EZWYsXG4gIElUYWJsZVJvd0l0ZW0sXG4gIElUYWJsZVJvd0l0ZW1WYWx1ZSxcbiAgSVRhYmxlUm93SXRlbVZhbHVlVHlwZXNcbn0gZnJvbSAnLi4vaW50ZXJmYWNlcy9pbmRleCc7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tpbXBkY1RhYmxlSW5qZWN0Q29tcG9uZW50XSdcbn0pXG5leHBvcnQgY2xhc3MgVGFibGVJbmplY3RDb21wb25lbnREaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKSBwdWJsaWMgY29sdW1uRGVmOiBJVGFibGVDb2x1bW5EZWYgPSB7IHRpdGxlOiAnJyB9O1xuICBASW5wdXQoKSBwdWJsaWMgdmFsdWU6IElUYWJsZVJvd0l0ZW1WYWx1ZVR5cGVzPElUYWJsZVJvd0l0ZW1WYWx1ZT4gPSAnJztcbiAgQElucHV0KCkgcHVibGljIHJvd0l0ZW06IElUYWJsZVJvd0l0ZW0gPSB7IGlkOiAwIH07XG4gIEBJbnB1dCgpIHB1YmxpYyBjdXN0b21DZWxsQ29tcG9uZW50czogSUN1c3RvbUNlbGxSZW5kZXJlckNvbXBvbmVudHMgPSB7fTtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIHJlYWRvbmx5IF92aWV3Q29udGFpbmVyUmVmOiBWaWV3Q29udGFpbmVyUmVmLFxuICAgIHByaXZhdGUgcmVhZG9ubHkgX2NvbXBvbmVudEZhY3RvcnlSZXNvbHZlcjogQ29tcG9uZW50RmFjdG9yeVJlc29sdmVyXG4gICkge31cblxuICBwdWJsaWMgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgdGhpcy5fcmVuZGVyQ3VzdG9tQ2VsbCgpO1xuICB9XG5cbiAgcHJpdmF0ZSBfcmVuZGVyQ3VzdG9tQ2VsbCgpOiB2b2lkIHtcbiAgICBjb25zdCB7IGNlbGxSZW5kZXJlckNvbXBvbmVudCwgY2VsbFJlbmRlcmVyUGFyYW1zIH0gPSB0aGlzLmNvbHVtbkRlZjtcbiAgICBpZiAoIWNlbGxSZW5kZXJlckNvbXBvbmVudCkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGNvbnN0IGl0ZW0gPSB0aGlzLnJvd0l0ZW07XG4gICAgY29uc3QgY3VzdG9tQ2VsbENvbXBvbmVudCA9XG4gICAgICB0aGlzLmN1c3RvbUNlbGxDb21wb25lbnRzW2NlbGxSZW5kZXJlckNvbXBvbmVudF07XG5cbiAgICB0aGlzLl92aWV3Q29udGFpbmVyUmVmLmNsZWFyKCk7XG5cbiAgICBjb25zdCBjb21wb25lbnRGYWN0b3J5ID1cbiAgICAgIHRoaXMuX2NvbXBvbmVudEZhY3RvcnlSZXNvbHZlci5yZXNvbHZlQ29tcG9uZW50RmFjdG9yeTxJQ2VsbFJlbmRlcmVyPihcbiAgICAgICAgY3VzdG9tQ2VsbENvbXBvbmVudFxuICAgICAgKTtcbiAgICBjb25zdCBjb21wb25lbnRSZWYgPVxuICAgICAgdGhpcy5fdmlld0NvbnRhaW5lclJlZi5jcmVhdGVDb21wb25lbnQ8SUNlbGxSZW5kZXJlcj4oY29tcG9uZW50RmFjdG9yeSk7XG5cbiAgICBjb21wb25lbnRSZWYuaW5zdGFuY2UudmFsdWUgPSB0aGlzLnZhbHVlO1xuICAgIGNvbXBvbmVudFJlZi5pbnN0YW5jZS5yb3dJdGVtID0gaXRlbTtcbiAgICBjb21wb25lbnRSZWYuaW5zdGFuY2UucGFyYW1zID0gY2VsbFJlbmRlcmVyUGFyYW1zO1xuICB9XG59XG4iXX0=
@@ -0,0 +1,35 @@
1
+ import { Directive, HostBinding, Input } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ /**
4
+ * The `TableDirective` (`<table impdcTable`) that adds Hex styling to a `table` element.
5
+ * To use, import `TableModule` or another module that imports and exports that module from `@impartner/design-components`.
6
+ */
7
+ export class TableDirective {
8
+ constructor() {
9
+ /**
10
+ * Stripes every other row in a slightly darker background color.
11
+ */
12
+ this.striped = false;
13
+ this.classTable = true;
14
+ }
15
+ get classTableStriped() {
16
+ return this.striped;
17
+ }
18
+ }
19
+ TableDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TableDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
20
+ TableDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.12", type: TableDirective, selector: "table[impdcTable]", inputs: { striped: "striped" }, host: { properties: { "class.table": "this.classTable", "class.table-striped": "this.classTableStriped" } }, ngImport: i0 });
21
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TableDirective, decorators: [{
22
+ type: Directive,
23
+ args: [{
24
+ selector: 'table[impdcTable]'
25
+ }]
26
+ }], propDecorators: { striped: [{
27
+ type: Input
28
+ }], classTable: [{
29
+ type: HostBinding,
30
+ args: ['class.table']
31
+ }], classTableStriped: [{
32
+ type: HostBinding,
33
+ args: ['class.table-striped']
34
+ }] } });
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGVzaWduLWNvbXBvbmVudHMvc3JjL2xpYi90YWJsZS9kaXJlY3RpdmVzL3RhYmxlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBRTlEOzs7R0FHRztBQUlILE1BQU0sT0FBTyxjQUFjO0lBSDNCO1FBSUU7O1dBRUc7UUFFSCxZQUFPLEdBQUcsS0FBSyxDQUFDO1FBRW9CLGVBQVUsR0FBRyxJQUFJLENBQUM7S0FLdkQ7SUFIQyxJQUFnRCxpQkFBaUI7UUFDL0QsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBQ3RCLENBQUM7OzRHQVhVLGNBQWM7Z0dBQWQsY0FBYzs0RkFBZCxjQUFjO2tCQUgxQixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxtQkFBbUI7aUJBQzlCOzhCQU1DLE9BQU87c0JBRE4sS0FBSztnQkFHOEIsVUFBVTtzQkFBN0MsV0FBVzt1QkFBQyxhQUFhO2dCQUVzQixpQkFBaUI7c0JBQWhFLFdBQVc7dUJBQUMscUJBQXFCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBIb3N0QmluZGluZywgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuLyoqXG4gKiBUaGUgYFRhYmxlRGlyZWN0aXZlYCAoYDx0YWJsZSBpbXBkY1RhYmxlYCkgdGhhdCBhZGRzIEhleCBzdHlsaW5nIHRvIGEgYHRhYmxlYCBlbGVtZW50LlxuICogVG8gdXNlLCBpbXBvcnQgYFRhYmxlTW9kdWxlYCBvciBhbm90aGVyIG1vZHVsZSB0aGF0IGltcG9ydHMgYW5kIGV4cG9ydHMgdGhhdCBtb2R1bGUgZnJvbSBgQGltcGFydG5lci9kZXNpZ24tY29tcG9uZW50c2AuXG4gKi9cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ3RhYmxlW2ltcGRjVGFibGVdJ1xufSlcbmV4cG9ydCBjbGFzcyBUYWJsZURpcmVjdGl2ZSB7XG4gIC8qKlxuICAgKiBTdHJpcGVzIGV2ZXJ5IG90aGVyIHJvdyBpbiBhIHNsaWdodGx5IGRhcmtlciBiYWNrZ3JvdW5kIGNvbG9yLlxuICAgKi9cbiAgQElucHV0KClcbiAgc3RyaXBlZCA9IGZhbHNlO1xuXG4gIEBIb3N0QmluZGluZygnY2xhc3MudGFibGUnKSBwcml2YXRlIGNsYXNzVGFibGUgPSB0cnVlO1xuXG4gIEBIb3N0QmluZGluZygnY2xhc3MudGFibGUtc3RyaXBlZCcpIHByaXZhdGUgZ2V0IGNsYXNzVGFibGVTdHJpcGVkKCkge1xuICAgIHJldHVybiB0aGlzLnN0cmlwZWQ7XG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1,2 @@
1
+ export * from './table-column-type';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZXNpZ24tY29tcG9uZW50cy9zcmMvbGliL3RhYmxlL2VudW1lcmF0aW9ucy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHFCQUFxQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi90YWJsZS1jb2x1bW4tdHlwZSc7XG4iXX0=