@rivet-health/design-system 37.10.1 → 37.10.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/table/simple-table/simple-table.component.mjs +21 -3
- package/fesm2015/rivet-health-design-system.mjs +21 -2
- package/fesm2015/rivet-health-design-system.mjs.map +1 -1
- package/fesm2020/rivet-health-design-system.mjs +20 -2
- package/fesm2020/rivet-health-design-system.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -34,13 +34,31 @@ export class SimpleTableComponent {
|
|
|
34
34
|
});
|
|
35
35
|
}
|
|
36
36
|
});
|
|
37
|
-
const
|
|
37
|
+
const cellSpanData = dataCells.map(dataCell => {
|
|
38
38
|
const element = dataCell.elementRef.nativeElement;
|
|
39
39
|
return {
|
|
40
40
|
rowspan: parseInt(element.getAttribute('rowspan') || '1', 10),
|
|
41
41
|
colspan: parseInt(element.getAttribute('colspan') || '1', 10),
|
|
42
42
|
};
|
|
43
|
-
})
|
|
43
|
+
});
|
|
44
|
+
// When there are no header cells, calculate totalColumns from the first <tr>
|
|
45
|
+
let totalColumns = headerCells.length;
|
|
46
|
+
if (totalColumns === 0 && dataCells.length > 0) {
|
|
47
|
+
const firstRow = dataCells.first?.elementRef.nativeElement.parentElement;
|
|
48
|
+
if (firstRow) {
|
|
49
|
+
// Count td elements in the first row and sum their colspans
|
|
50
|
+
const cellsInFirstRow = Array.from(firstRow.querySelectorAll('td[riv-simple-table-cell]'));
|
|
51
|
+
totalColumns = cellsInFirstRow.reduce((sum, cell) => {
|
|
52
|
+
const colspan = parseInt(cell.getAttribute('colspan') || '1', 10);
|
|
53
|
+
return sum + colspan;
|
|
54
|
+
}, 0);
|
|
55
|
+
}
|
|
56
|
+
// Fallback to 1 if we couldn't determine
|
|
57
|
+
if (totalColumns === 0) {
|
|
58
|
+
totalColumns = 1;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
const getCellCoordinates = createCellCoordinateCalculator(cellSpanData, totalColumns);
|
|
44
62
|
const maxRow = Math.max(...dataCells.map((_, i) => getCellCoordinates(i).end.row));
|
|
45
63
|
dataCells.forEach((dataCell, cellIndex) => {
|
|
46
64
|
const bounds = getCellCoordinates(cellIndex);
|
|
@@ -82,4 +100,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
82
100
|
type: ContentChildren,
|
|
83
101
|
args: [SimpleTableCellComponent, { descendants: true }]
|
|
84
102
|
}] } });
|
|
85
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"simple-table.component.js","sourceRoot":"","sources":["../../../../../../projects/riv/src/lib/table/simple-table/simple-table.component.ts","../../../../../../projects/riv/src/lib/table/simple-table/simple-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentChecked,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  ContentChildren,\n  QueryList,\n  TemplateRef,\n} from '@angular/core';\nimport { RivTable } from '../table/state';\nimport { createCellCoordinateCalculator } from './coordinate-helper';\nimport { SimpleTableCellComponent } from './simple-table-cell.component';\nimport { SimpleTableHeaderCellComponent } from './simple-table-header-cell.component';\n\n@Component({\n  selector: 'riv-simple-table',\n  templateUrl: './simple-table.component.html',\n  styleUrls: ['./simple-table.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SimpleTableComponent implements AfterContentChecked {\n  @ContentChild('header')\n  headerTemplate?: TemplateRef<void>;\n\n  @ContentChildren(SimpleTableHeaderCellComponent, { descendants: true })\n  private headerCells?: QueryList<SimpleTableHeaderCellComponent>;\n\n  @ContentChildren(SimpleTableCellComponent, { descendants: true })\n  private dataCells?: QueryList<SimpleTableCellComponent>;\n\n  ngAfterContentChecked() {\n    this.setCellProperties();\n  }\n\n  private setCellProperties() {\n    const { headerCells, dataCells } = this;\n    if (!headerCells || !dataCells) return;\n\n    let runningWidthTotal = 0;\n    headerCells.forEach((headerCell, i) => {\n      const { dataType } = headerCell;\n      if (!dataType) {\n        const allowedTypes = RivTable.ColumnDataTypes.join(', ');\n        throw new Error(\n          `Each header cell must define an appropriate dataType, one of ${allowedTypes}`,\n        );\n      }\n\n      const newAlignment = RivTable.getColumnAlignment(dataType, i === 0);\n      const newLeftPinOffset = runningWidthTotal;\n      runningWidthTotal += headerCell.width;\n\n      const changed =\n        headerCell.alignment != newAlignment ||\n        headerCell.leftPinOffset != newLeftPinOffset;\n      headerCell.alignment = newAlignment;\n      headerCell.leftPinOffset = newLeftPinOffset;\n\n      // Only mark for check when changed to prevent infinite cycles\n      if (changed) {\n        queueMicrotask(() => {\n          headerCell.cdr.markForCheck();\n        });\n      }\n    });\n\n    const getCellCoordinates = createCellCoordinateCalculator(\n      dataCells.map(dataCell => {\n        const element = dataCell.elementRef.nativeElement;\n        return {\n          rowspan: parseInt(element.getAttribute('rowspan') || '1', 10),\n          colspan: parseInt(element.getAttribute('colspan') || '1', 10),\n        };\n      }),\n      headerCells.length,\n    );\n\n    const maxRow = Math.max(\n      ...dataCells.map((_, i) => getCellCoordinates(i).end.row),\n    );\n\n    dataCells.forEach((dataCell, cellIndex) => {\n      const bounds = getCellCoordinates(cellIndex);\n\n      const headerCell = headerCells.get(bounds.start.col);\n      let changed = false;\n      if (headerCell) {\n        changed =\n          dataCell.alignment != headerCell.alignment ||\n          dataCell.pinned != headerCell.pinned ||\n          dataCell.leftPinOffset != headerCell.leftPinOffset;\n\n        dataCell.alignment = headerCell.alignment;\n        dataCell.pinned = headerCell.pinned;\n        dataCell.leftPinOffset = headerCell.leftPinOffset;\n      }\n\n      const newIsLastRow = bounds.end.row === maxRow;\n      changed = changed || dataCell.isLastRow != newIsLastRow;\n      dataCell.isLastRow = newIsLastRow;\n\n      // Only mark for check when changed to prevent infinite cycles\n      if (changed) {\n        queueMicrotask(() => {\n          dataCell.cdr.markForCheck();\n        });\n      }\n    });\n  }\n}\n","<header *ngIf=\"headerTemplate\">\n  <ng-container *ngTemplateOutlet=\"headerTemplate\"></ng-container>\n</header>\n<div class=\"container\">\n  <table>\n    <ng-content></ng-content>\n  </table>\n</div>\n"]}
|
|
103
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"simple-table.component.js","sourceRoot":"","sources":["../../../../../../projects/riv/src/lib/table/simple-table/simple-table.component.ts","../../../../../../projects/riv/src/lib/table/simple-table/simple-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentChecked,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  ContentChildren,\n  QueryList,\n  TemplateRef,\n} from '@angular/core';\nimport { RivTable } from '../table/state';\nimport { createCellCoordinateCalculator } from './coordinate-helper';\nimport { SimpleTableCellComponent } from './simple-table-cell.component';\nimport { SimpleTableHeaderCellComponent } from './simple-table-header-cell.component';\n\n@Component({\n  selector: 'riv-simple-table',\n  templateUrl: './simple-table.component.html',\n  styleUrls: ['./simple-table.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SimpleTableComponent implements AfterContentChecked {\n  @ContentChild('header')\n  headerTemplate?: TemplateRef<void>;\n\n  @ContentChildren(SimpleTableHeaderCellComponent, { descendants: true })\n  private headerCells?: QueryList<SimpleTableHeaderCellComponent>;\n\n  @ContentChildren(SimpleTableCellComponent, { descendants: true })\n  private dataCells?: QueryList<SimpleTableCellComponent>;\n\n  ngAfterContentChecked() {\n    this.setCellProperties();\n  }\n\n  private setCellProperties() {\n    const { headerCells, dataCells } = this;\n    if (!headerCells || !dataCells) return;\n\n    let runningWidthTotal = 0;\n    headerCells.forEach((headerCell, i) => {\n      const { dataType } = headerCell;\n      if (!dataType) {\n        const allowedTypes = RivTable.ColumnDataTypes.join(', ');\n        throw new Error(\n          `Each header cell must define an appropriate dataType, one of ${allowedTypes}`,\n        );\n      }\n\n      const newAlignment = RivTable.getColumnAlignment(dataType, i === 0);\n      const newLeftPinOffset = runningWidthTotal;\n      runningWidthTotal += headerCell.width;\n\n      const changed =\n        headerCell.alignment != newAlignment ||\n        headerCell.leftPinOffset != newLeftPinOffset;\n      headerCell.alignment = newAlignment;\n      headerCell.leftPinOffset = newLeftPinOffset;\n\n      // Only mark for check when changed to prevent infinite cycles\n      if (changed) {\n        queueMicrotask(() => {\n          headerCell.cdr.markForCheck();\n        });\n      }\n    });\n\n    const cellSpanData = dataCells.map(dataCell => {\n      const element = dataCell.elementRef.nativeElement;\n      return {\n        rowspan: parseInt(element.getAttribute('rowspan') || '1', 10),\n        colspan: parseInt(element.getAttribute('colspan') || '1', 10),\n      };\n    });\n\n    // When there are no header cells, calculate totalColumns from the first <tr>\n    let totalColumns = headerCells.length;\n    if (totalColumns === 0 && dataCells.length > 0) {\n      const firstRow = dataCells.first?.elementRef.nativeElement.parentElement;\n      if (firstRow) {\n        // Count td elements in the first row and sum their colspans\n        const cellsInFirstRow = Array.from(\n          firstRow.querySelectorAll('td[riv-simple-table-cell]'),\n        );\n        totalColumns = cellsInFirstRow.reduce((sum, cell) => {\n          const colspan = parseInt(cell.getAttribute('colspan') || '1', 10);\n          return sum + colspan;\n        }, 0);\n      }\n      // Fallback to 1 if we couldn't determine\n      if (totalColumns === 0) {\n        totalColumns = 1;\n      }\n    }\n\n    const getCellCoordinates = createCellCoordinateCalculator(\n      cellSpanData,\n      totalColumns,\n    );\n\n    const maxRow = Math.max(\n      ...dataCells.map((_, i) => getCellCoordinates(i).end.row),\n    );\n\n    dataCells.forEach((dataCell, cellIndex) => {\n      const bounds = getCellCoordinates(cellIndex);\n\n      const headerCell = headerCells.get(bounds.start.col);\n      let changed = false;\n      if (headerCell) {\n        changed =\n          dataCell.alignment != headerCell.alignment ||\n          dataCell.pinned != headerCell.pinned ||\n          dataCell.leftPinOffset != headerCell.leftPinOffset;\n\n        dataCell.alignment = headerCell.alignment;\n        dataCell.pinned = headerCell.pinned;\n        dataCell.leftPinOffset = headerCell.leftPinOffset;\n      }\n\n      const newIsLastRow = bounds.end.row === maxRow;\n      changed = changed || dataCell.isLastRow != newIsLastRow;\n      dataCell.isLastRow = newIsLastRow;\n\n      // Only mark for check when changed to prevent infinite cycles\n      if (changed) {\n        queueMicrotask(() => {\n          dataCell.cdr.markForCheck();\n        });\n      }\n    });\n  }\n}\n","<header *ngIf=\"headerTemplate\">\n  <ng-container *ngTemplateOutlet=\"headerTemplate\"></ng-container>\n</header>\n<div class=\"container\">\n  <table>\n    <ng-content></ng-content>\n  </table>\n</div>\n"]}
|
|
@@ -7184,6 +7184,7 @@ class SimpleTableComponent {
|
|
|
7184
7184
|
this.setCellProperties();
|
|
7185
7185
|
}
|
|
7186
7186
|
setCellProperties() {
|
|
7187
|
+
var _a;
|
|
7187
7188
|
const { headerCells, dataCells } = this;
|
|
7188
7189
|
if (!headerCells || !dataCells)
|
|
7189
7190
|
return;
|
|
@@ -7208,13 +7209,31 @@ class SimpleTableComponent {
|
|
|
7208
7209
|
});
|
|
7209
7210
|
}
|
|
7210
7211
|
});
|
|
7211
|
-
const
|
|
7212
|
+
const cellSpanData = dataCells.map(dataCell => {
|
|
7212
7213
|
const element = dataCell.elementRef.nativeElement;
|
|
7213
7214
|
return {
|
|
7214
7215
|
rowspan: parseInt(element.getAttribute('rowspan') || '1', 10),
|
|
7215
7216
|
colspan: parseInt(element.getAttribute('colspan') || '1', 10),
|
|
7216
7217
|
};
|
|
7217
|
-
})
|
|
7218
|
+
});
|
|
7219
|
+
// When there are no header cells, calculate totalColumns from the first <tr>
|
|
7220
|
+
let totalColumns = headerCells.length;
|
|
7221
|
+
if (totalColumns === 0 && dataCells.length > 0) {
|
|
7222
|
+
const firstRow = (_a = dataCells.first) === null || _a === void 0 ? void 0 : _a.elementRef.nativeElement.parentElement;
|
|
7223
|
+
if (firstRow) {
|
|
7224
|
+
// Count td elements in the first row and sum their colspans
|
|
7225
|
+
const cellsInFirstRow = Array.from(firstRow.querySelectorAll('td[riv-simple-table-cell]'));
|
|
7226
|
+
totalColumns = cellsInFirstRow.reduce((sum, cell) => {
|
|
7227
|
+
const colspan = parseInt(cell.getAttribute('colspan') || '1', 10);
|
|
7228
|
+
return sum + colspan;
|
|
7229
|
+
}, 0);
|
|
7230
|
+
}
|
|
7231
|
+
// Fallback to 1 if we couldn't determine
|
|
7232
|
+
if (totalColumns === 0) {
|
|
7233
|
+
totalColumns = 1;
|
|
7234
|
+
}
|
|
7235
|
+
}
|
|
7236
|
+
const getCellCoordinates = createCellCoordinateCalculator(cellSpanData, totalColumns);
|
|
7218
7237
|
const maxRow = Math.max(...dataCells.map((_, i) => getCellCoordinates(i).end.row));
|
|
7219
7238
|
dataCells.forEach((dataCell, cellIndex) => {
|
|
7220
7239
|
const bounds = getCellCoordinates(cellIndex);
|