Header.js 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. Object.defineProperty(exports, "__esModule", {
  4. value: true
  5. });
  6. exports.default = void 0;
  7. var _vue = require("vue");
  8. var _classNames = _interopRequireDefault(require("../../_util/classNames"));
  9. var _TableContext = require("../context/TableContext");
  10. var _HeaderRow = _interopRequireDefault(require("./HeaderRow"));
  11. function parseHeaderRows(rootColumns) {
  12. var rows = [];
  13. function fillRowCells(columns, colIndex) {
  14. var rowIndex = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0;
  15. // Init rows
  16. rows[rowIndex] = rows[rowIndex] || [];
  17. var currentColIndex = colIndex;
  18. var colSpans = columns.filter(Boolean).map(function (column) {
  19. var cell = {
  20. key: column.key,
  21. class: (0, _classNames.default)(column.className, column.class),
  22. // children: column.title,
  23. column: column,
  24. colStart: currentColIndex
  25. };
  26. var colSpan = 1;
  27. var subColumns = column.children;
  28. if (subColumns && subColumns.length > 0) {
  29. colSpan = fillRowCells(subColumns, currentColIndex, rowIndex + 1).reduce(function (total, count) {
  30. return total + count;
  31. }, 0);
  32. cell.hasSubColumns = true;
  33. }
  34. if ('colSpan' in column) {
  35. colSpan = column.colSpan;
  36. }
  37. if ('rowSpan' in column) {
  38. cell.rowSpan = column.rowSpan;
  39. }
  40. cell.colSpan = colSpan;
  41. cell.colEnd = cell.colStart + colSpan - 1;
  42. rows[rowIndex].push(cell);
  43. currentColIndex += colSpan;
  44. return colSpan;
  45. });
  46. return colSpans;
  47. }
  48. // Generate `rows` cell data
  49. fillRowCells(rootColumns, 0);
  50. // Handle `rowSpan`
  51. var rowCount = rows.length;
  52. var _loop = function _loop(rowIndex) {
  53. rows[rowIndex].forEach(function (cell) {
  54. if (!('rowSpan' in cell) && !cell.hasSubColumns) {
  55. // eslint-disable-next-line no-param-reassign
  56. cell.rowSpan = rowCount - rowIndex;
  57. }
  58. });
  59. };
  60. for (var rowIndex = 0; rowIndex < rowCount; rowIndex += 1) {
  61. _loop(rowIndex);
  62. }
  63. return rows;
  64. }
  65. var _default2 = (0, _vue.defineComponent)({
  66. name: 'Header',
  67. inheritAttrs: false,
  68. props: ['columns', 'flattenColumns', 'stickyOffsets', 'customHeaderRow'],
  69. setup: function setup(props) {
  70. var tableContext = (0, _TableContext.useInjectTable)();
  71. var rows = (0, _vue.computed)(function () {
  72. return parseHeaderRows(props.columns);
  73. });
  74. return function () {
  75. var prefixCls = tableContext.prefixCls,
  76. getComponent = tableContext.getComponent;
  77. var stickyOffsets = props.stickyOffsets,
  78. flattenColumns = props.flattenColumns,
  79. customHeaderRow = props.customHeaderRow;
  80. var WrapperComponent = getComponent(['header', 'wrapper'], 'thead');
  81. var trComponent = getComponent(['header', 'row'], 'tr');
  82. var thComponent = getComponent(['header', 'cell'], 'th');
  83. return (0, _vue.createVNode)(WrapperComponent, {
  84. "class": "".concat(prefixCls, "-thead")
  85. }, {
  86. default: function _default() {
  87. return [rows.value.map(function (row, rowIndex) {
  88. var rowNode = (0, _vue.createVNode)(_HeaderRow.default, {
  89. "key": rowIndex,
  90. "flattenColumns": flattenColumns,
  91. "cells": row,
  92. "stickyOffsets": stickyOffsets,
  93. "rowComponent": trComponent,
  94. "cellComponent": thComponent,
  95. "customHeaderRow": customHeaderRow,
  96. "index": rowIndex
  97. }, null);
  98. return rowNode;
  99. })];
  100. }
  101. });
  102. };
  103. }
  104. });
  105. exports.default = _default2;