util.js 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. Object.defineProperty(exports, "__esModule", {
  4. value: true
  5. });
  6. exports.convertChildrenToColumns = convertChildrenToColumns;
  7. exports.getColumnKey = getColumnKey;
  8. exports.getColumnPos = getColumnPos;
  9. exports.renderColumnTitle = renderColumnTitle;
  10. var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
  11. var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
  12. var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
  13. var _vue = require("vue");
  14. var _propsUtil = require("../_util/props-util");
  15. var _excluded = ["default"];
  16. function getColumnKey(column, defaultKey) {
  17. if ('key' in column && column.key !== undefined && column.key !== null) {
  18. return column.key;
  19. }
  20. if (column.dataIndex) {
  21. return Array.isArray(column.dataIndex) ? column.dataIndex.join('.') : column.dataIndex;
  22. }
  23. return defaultKey;
  24. }
  25. function getColumnPos(index, pos) {
  26. return pos ? "".concat(pos, "-").concat(index) : "".concat(index);
  27. }
  28. function renderColumnTitle(title, props) {
  29. if (typeof title === 'function') {
  30. return title(props);
  31. }
  32. return title;
  33. }
  34. function convertChildrenToColumns() {
  35. var elements = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
  36. var flattenElements = (0, _propsUtil.flattenChildren)(elements);
  37. var columns = [];
  38. flattenElements.forEach(function (element) {
  39. var _element$props, _element$props2, _element$type;
  40. if (!element) {
  41. return;
  42. }
  43. var key = element.key;
  44. var style = ((_element$props = element.props) === null || _element$props === void 0 ? void 0 : _element$props.style) || {};
  45. var cls = ((_element$props2 = element.props) === null || _element$props2 === void 0 ? void 0 : _element$props2.class) || '';
  46. var props = element.props || {};
  47. for (var _i = 0, _Object$entries = Object.entries(props); _i < _Object$entries.length; _i++) {
  48. var _Object$entries$_i = (0, _slicedToArray2.default)(_Object$entries[_i], 2),
  49. k = _Object$entries$_i[0],
  50. v = _Object$entries$_i[1];
  51. props[(0, _vue.camelize)(k)] = v;
  52. }
  53. var _ref = element.children || {},
  54. children = _ref.default,
  55. restSlots = (0, _objectWithoutProperties2.default)(_ref, _excluded);
  56. var column = (0, _objectSpread2.default)((0, _objectSpread2.default)((0, _objectSpread2.default)({}, restSlots), props), {}, {
  57. style: style,
  58. class: cls
  59. });
  60. if (key) {
  61. column.key = key;
  62. }
  63. if ((_element$type = element.type) !== null && _element$type !== void 0 && _element$type.__ANT_TABLE_COLUMN_GROUP) {
  64. column.children = convertChildrenToColumns(typeof children === 'function' ? children() : children);
  65. } else {
  66. var _element$children;
  67. var customRender = (_element$children = element.children) === null || _element$children === void 0 ? void 0 : _element$children.default;
  68. column.customRender = column.customRender || customRender;
  69. }
  70. columns.push(column);
  71. });
  72. return columns;
  73. }