@semcore/data-table 16.0.0-prerelease.13 → 16.0.0-prerelease.15

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 (151) hide show
  1. package/lib/cjs/Body.js +476 -0
  2. package/lib/cjs/Body.js.map +1 -0
  3. package/lib/cjs/DataTable.js +622 -0
  4. package/lib/cjs/DataTable.js.map +1 -0
  5. package/lib/cjs/Head.js +399 -0
  6. package/lib/cjs/Head.js.map +1 -0
  7. package/lib/cjs/components/Body/Body.js +216 -0
  8. package/lib/cjs/components/Body/Body.js.map +1 -0
  9. package/lib/cjs/components/Body/Body.types.js +2 -0
  10. package/lib/cjs/components/Body/Body.types.js.map +1 -0
  11. package/lib/cjs/components/Body/Cell.js +133 -0
  12. package/lib/cjs/components/Body/Cell.js.map +1 -0
  13. package/lib/cjs/components/Body/Cell.types.js +2 -0
  14. package/lib/cjs/components/Body/Cell.types.js.map +1 -0
  15. package/lib/cjs/components/Body/MergedCells.js +27 -0
  16. package/lib/cjs/components/Body/MergedCells.js.map +1 -0
  17. package/lib/cjs/components/Body/Row.js +212 -0
  18. package/lib/cjs/components/Body/Row.js.map +1 -0
  19. package/lib/cjs/components/Body/Row.types.js +2 -0
  20. package/lib/cjs/components/Body/Row.types.js.map +1 -0
  21. package/lib/cjs/components/Body/style.shadow.css +190 -0
  22. package/lib/cjs/components/DataTable/DataTable.js +565 -0
  23. package/lib/cjs/components/DataTable/DataTable.js.map +1 -0
  24. package/lib/cjs/components/DataTable/DataTable.types.js +2 -0
  25. package/lib/cjs/components/DataTable/DataTable.types.js.map +1 -0
  26. package/lib/cjs/components/DataTable/dataTable.shadow.css +14 -0
  27. package/lib/cjs/components/Head/Column.js +277 -0
  28. package/lib/cjs/components/Head/Column.js.map +1 -0
  29. package/lib/cjs/components/Head/Column.types.js +2 -0
  30. package/lib/cjs/components/Head/Column.types.js.map +1 -0
  31. package/lib/cjs/components/Head/Group.js +98 -0
  32. package/lib/cjs/components/Head/Group.js.map +1 -0
  33. package/lib/cjs/components/Head/Group.type.js +2 -0
  34. package/lib/cjs/components/Head/Group.type.js.map +1 -0
  35. package/lib/cjs/components/Head/Head.js +152 -0
  36. package/lib/cjs/components/Head/Head.js.map +1 -0
  37. package/lib/cjs/components/Head/Head.types.js +2 -0
  38. package/lib/cjs/components/Head/Head.types.js.map +1 -0
  39. package/lib/cjs/components/Head/style.shadow.css +165 -0
  40. package/lib/cjs/index.js +42 -0
  41. package/lib/cjs/index.js.map +1 -0
  42. package/lib/cjs/style/data-table.shadow.css +394 -0
  43. package/lib/cjs/style/scroll-shadows.shadow.css +11 -0
  44. package/lib/cjs/translations/__intergalactic-dynamic-locales.js +39 -0
  45. package/lib/cjs/translations/__intergalactic-dynamic-locales.js.map +1 -0
  46. package/lib/cjs/translations/de.json +3 -0
  47. package/lib/cjs/translations/en.json +5 -0
  48. package/lib/cjs/translations/es.json +3 -0
  49. package/lib/cjs/translations/fr.json +3 -0
  50. package/lib/cjs/translations/it.json +3 -0
  51. package/lib/cjs/translations/ja.json +3 -0
  52. package/lib/cjs/translations/ko.json +3 -0
  53. package/lib/cjs/translations/nl.json +3 -0
  54. package/lib/cjs/translations/pl.json +3 -0
  55. package/lib/cjs/translations/pt.json +3 -0
  56. package/lib/cjs/translations/sv.json +3 -0
  57. package/lib/cjs/translations/tr.json +3 -0
  58. package/lib/cjs/translations/vi.json +3 -0
  59. package/lib/cjs/translations/zh.json +3 -0
  60. package/lib/cjs/types.js +4 -0
  61. package/lib/cjs/types.js.map +1 -0
  62. package/lib/cjs/utils.js +66 -0
  63. package/lib/cjs/utils.js.map +1 -0
  64. package/lib/es6/Body.js +469 -0
  65. package/lib/es6/Body.js.map +1 -0
  66. package/lib/es6/DataTable.js +614 -0
  67. package/lib/es6/DataTable.js.map +1 -0
  68. package/lib/es6/Head.js +391 -0
  69. package/lib/es6/Head.js.map +1 -0
  70. package/lib/es6/components/Body/Body.js +209 -0
  71. package/lib/es6/components/Body/Body.js.map +1 -0
  72. package/lib/es6/components/Body/Body.types.js +2 -0
  73. package/lib/es6/components/Body/Body.types.js.map +1 -0
  74. package/lib/es6/components/Body/Cell.js +126 -0
  75. package/lib/es6/components/Body/Cell.js.map +1 -0
  76. package/lib/es6/components/Body/Cell.types.js +2 -0
  77. package/lib/es6/components/Body/Cell.types.js.map +1 -0
  78. package/lib/es6/components/Body/MergedCells.js +18 -0
  79. package/lib/es6/components/Body/MergedCells.js.map +1 -0
  80. package/lib/es6/components/Body/Row.js +205 -0
  81. package/lib/es6/components/Body/Row.js.map +1 -0
  82. package/lib/es6/components/Body/Row.types.js +2 -0
  83. package/lib/es6/components/Body/Row.types.js.map +1 -0
  84. package/lib/es6/components/Body/style.shadow.css +190 -0
  85. package/lib/es6/components/DataTable/DataTable.js +558 -0
  86. package/lib/es6/components/DataTable/DataTable.js.map +1 -0
  87. package/lib/es6/components/DataTable/DataTable.types.js +2 -0
  88. package/lib/es6/components/DataTable/DataTable.types.js.map +1 -0
  89. package/lib/es6/components/DataTable/dataTable.shadow.css +14 -0
  90. package/lib/es6/components/Head/Column.js +270 -0
  91. package/lib/es6/components/Head/Column.js.map +1 -0
  92. package/lib/es6/components/Head/Column.types.js +2 -0
  93. package/lib/es6/components/Head/Column.types.js.map +1 -0
  94. package/lib/es6/components/Head/Group.js +91 -0
  95. package/lib/es6/components/Head/Group.js.map +1 -0
  96. package/lib/es6/components/Head/Group.type.js +2 -0
  97. package/lib/es6/components/Head/Group.type.js.map +1 -0
  98. package/lib/es6/components/Head/Head.js +145 -0
  99. package/lib/es6/components/Head/Head.js.map +1 -0
  100. package/lib/es6/components/Head/Head.types.js +2 -0
  101. package/lib/es6/components/Head/Head.types.js.map +1 -0
  102. package/lib/es6/components/Head/style.shadow.css +165 -0
  103. package/lib/es6/index.js +5 -0
  104. package/lib/es6/index.js.map +1 -0
  105. package/lib/es6/style/data-table.shadow.css +394 -0
  106. package/lib/es6/style/scroll-shadows.shadow.css +11 -0
  107. package/lib/es6/translations/__intergalactic-dynamic-locales.js +31 -0
  108. package/lib/es6/translations/__intergalactic-dynamic-locales.js.map +1 -0
  109. package/lib/es6/translations/de.json +3 -0
  110. package/lib/es6/translations/en.json +5 -0
  111. package/lib/es6/translations/es.json +3 -0
  112. package/lib/es6/translations/fr.json +3 -0
  113. package/lib/es6/translations/it.json +3 -0
  114. package/lib/es6/translations/ja.json +3 -0
  115. package/lib/es6/translations/ko.json +3 -0
  116. package/lib/es6/translations/nl.json +3 -0
  117. package/lib/es6/translations/pl.json +3 -0
  118. package/lib/es6/translations/pt.json +3 -0
  119. package/lib/es6/translations/sv.json +3 -0
  120. package/lib/es6/translations/tr.json +3 -0
  121. package/lib/es6/translations/vi.json +3 -0
  122. package/lib/es6/translations/zh.json +3 -0
  123. package/lib/es6/types.js +2 -0
  124. package/lib/es6/types.js.map +1 -0
  125. package/lib/es6/utils.js +56 -0
  126. package/lib/es6/utils.js.map +1 -0
  127. package/lib/esm/components/Body/Body.mjs +1 -1
  128. package/lib/esm/components/Body/Row.mjs +1 -1
  129. package/lib/types/Body.d.ts +61 -0
  130. package/lib/types/DataTable.d.ts +205 -0
  131. package/lib/types/Head.d.ts +45 -0
  132. package/lib/types/components/Body/Body.d.ts +8 -0
  133. package/lib/types/components/Body/Body.types.d.ts +31 -0
  134. package/lib/types/components/Body/Cell.d.ts +3 -0
  135. package/lib/types/components/Body/Cell.types.d.ts +14 -0
  136. package/lib/types/components/Body/MergedCells.d.ts +10 -0
  137. package/lib/types/components/Body/Row.d.ts +3 -0
  138. package/lib/types/components/Body/Row.types.d.ts +24 -0
  139. package/lib/types/components/DataTable/DataTable.d.ts +9 -0
  140. package/lib/types/components/DataTable/DataTable.types.d.ts +50 -0
  141. package/lib/types/components/Head/Column.d.ts +26 -0
  142. package/lib/types/components/Head/Column.types.d.ts +80 -0
  143. package/lib/types/components/Head/Group.d.ts +12 -0
  144. package/lib/types/components/Head/Group.type.d.ts +10 -0
  145. package/lib/types/components/Head/Head.d.ts +8 -0
  146. package/lib/types/components/Head/Head.types.d.ts +26 -0
  147. package/lib/types/index.d.ts +4 -0
  148. package/lib/types/translations/__intergalactic-dynamic-locales.d.ts +46 -0
  149. package/lib/types/types.d.ts +73 -0
  150. package/lib/types/utils.d.ts +8 -0
  151. package/package.json +7 -6
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DataTable.types.js","names":[],"sources":["../../../../src/components/DataTable/DataTable.types.ts"],"sourcesContent":["import { Intergalactic } from '@semcore/core';\nimport { BoxProps } from '@semcore/base-components';\n\n/**\n * Datatable must have an accessible name (aria-table-name).\n * It should describe table content.\n */\ntype DataTableAriaProps = Intergalactic.RequireAtLeastOne<{\n 'aria-label'?: string;\n 'aria-labelledby'?: string;\n title?: string;\n}>;\n\nexport type SortDirection = 'asc' | 'desc';\nexport type DataTableSort<Column = string> = [sortBy: Column, sortDirection: SortDirection];\n\nexport type DTKey = string | symbol;\nexport type DTValue = string | number | boolean;\nexport type DataTableData = Array<Record<DTKey, any>>;\n\nexport type DTUse = 'primary' | 'secondary';\n\ntype Sizes = Pick<BoxProps, 'w' | 'wMax' | 'wMin' | 'h' | 'hMax' | 'hMin'>;\n\nexport type DataTableProps = DataTableAriaProps &\n Sizes & {\n /** Data for table */\n data: DataTableData;\n /** Count of total rows if table using virtual scroll. Needs for accessibility */\n totalRows?: number;\n\n /** Table theme according to visual hierarchy on the page\n * @default primary\n * */\n use?: DTUse;\n\n /** Active sort object */\n sort?: DataTableSort;\n /** Handler call when request will change sort */\n onSortChange?: (sort: DataTableSort, e?: React.SyntheticEvent) => void;\n\n /**\n *\n * @default auto\n */\n defaultGridTemplateColumnWidth?: 'auto' | '1fr';\n\n /**\n * Flag for compact view (less paddings)\n */\n compact?: boolean;\n\n /**\n * Flag for showing spinner on table body\n */\n loading?: boolean;\n\n children?: any;\n };\n\nexport type RowIndex = number;\nexport type ColIndex = number;\n"],"mappings":""}
@@ -0,0 +1,14 @@
1
+ SDataTable {
2
+ display: grid;
3
+ position: relative;
4
+ align-items: start;
5
+ min-width: fit-content;
6
+ }
7
+
8
+ SDataTable[gridTemplateColumns] {
9
+ grid-template-columns: var(--gridTemplateColumns);
10
+ }
11
+
12
+ SDataTable[gridTemplateAreas] {
13
+ grid-template-areas: var(--gridTemplateAreas);
14
+ }
@@ -0,0 +1,270 @@
1
+ import _objectSpread from "@babel/runtime/helpers/objectSpread2";
2
+ import _classCallCheck from "@babel/runtime/helpers/classCallCheck";
3
+ import _createClass from "@babel/runtime/helpers/createClass";
4
+ import _assertThisInitialized from "@babel/runtime/helpers/assertThisInitialized";
5
+ import _inherits from "@babel/runtime/helpers/inherits";
6
+ import _createSuper from "@babel/runtime/helpers/createSuper";
7
+ import _defineProperty from "@babel/runtime/helpers/defineProperty";
8
+ import { sstyled as _sstyled } from "@semcore/core";
9
+ import { assignProps as _assignProps } from "@semcore/core";
10
+ import * as React from 'react';
11
+ import { Component, Root, sstyled } from '@semcore/core';
12
+ import { Flex } from '@semcore/base-components';
13
+ import SortDesc from '@semcore/icon/SortDesc/m';
14
+ import SortAsc from '@semcore/icon/SortAsc/m';
15
+ /*__reshadow-styles__:"./style.shadow.css"*/
16
+ var style = ( /*__reshadow_css_start__*/_sstyled.insert( /*__inner_css_start__*/".___SHead_182z1_gg_{display:contents}.___SHead_182z1_gg_.__sticky_182z1_gg_>.___SColumn_182z1_gg_{position:sticky;top:0;z-index:1}.___SHead_182z1_gg_.__sticky_182z1_gg_ .___SGroup_182z1_gg_{top:0}.___SHead_182z1_gg_.__sticky_182z1_gg_ .___SGroupContainer_182z1_gg_>.___SColumn_182z1_gg_{position:sticky;top:40px;z-index:1}.___SHead_182z1_gg_.__compact_182z1_gg_ .___SColumn_182z1_gg_{padding:var(--intergalactic-spacing-3x, 12px) var(--intergalactic-spacing-2x, 8px)}.___SColumn_182z1_gg_,.___SGroup_182z1_gg_{display:flex;align-items:flex-start;font-size:var(--intergalactic-fs-100, 12px);color:var(--intergalactic-text-primary, #191b23);box-sizing:border-box;height:100%;position:relative;transition:width calc(var(--intergalactic-duration-extra-fast, 100)*1ms) ease-in-out,min-width calc(var(--intergalactic-duration-extra-fast, 100)*1ms) ease-in-out,max-width calc(var(--intergalactic-duration-extra-fast, 100)*1ms) ease-in-out}.___SGroup_182z1_gg_._use_primary_182z1_gg_{justify-content:center;padding:var(--intergalactic-spacing-3x, 12px);background-color:var(--intergalactic-table-th-primary-cell, #f4f5f9)}.___SGroup_182z1_gg_._use_secondary_182z1_gg_{justify-content:center;padding:var(--intergalactic-spacing-2x, 8px);background-color:var(--intergalactic-table-th-secondary-cell, #ffffff)}.___SGroup_182z1_gg_:has(.___SColumn_182z1_gg_.__visibleSort_182z1_gg_){background-color:var(--intergalactic-table-th-primary-cell-hover, #e0e1e9)}.___SColumn_182z1_gg_._borders_both_182z1_gg_,.___SColumn_182z1_gg_._borders_left_182z1_gg_,.___SGroup_182z1_gg_._borders_both_182z1_gg_,.___SGroup_182z1_gg_._borders_left_182z1_gg_{border-left:1px solid var(--intergalactic-border-secondary, #e0e1e9)}.___SColumn_182z1_gg_._borders_both_182z1_gg_,.___SColumn_182z1_gg_._borders_right_182z1_gg_,.___SGroup_182z1_gg_._borders_both_182z1_gg_,.___SGroup_182z1_gg_._borders_right_182z1_gg_{border-right:1px solid var(--intergalactic-border-secondary, #e0e1e9)}.___SColumn_182z1_gg_._use_primary_182z1_gg_{padding:var(--intergalactic-spacing-3x, 12px);border-bottom:1px solid var(--intergalactic-border-secondary, #e0e1e9);background-color:var(--intergalactic-table-th-primary-cell, #f4f5f9)}.___SColumn_182z1_gg_._use_primary_182z1_gg_ .___SSortWrapper_182z1_gg_::before{background:linear-gradient(270deg,var(--intergalactic-table-th-primary-cell-hover, #e0e1e9) 67.5%,rgba(224,225,233,0) 105%)}.___SColumn_182z1_gg_._use_primary_182z1_gg_.__visibleSort_182z1_gg_{background-color:var(--intergalactic-table-th-primary-cell-hover, #e0e1e9)}.___SColumn_182z1_gg_._use_primary_182z1_gg_.__visibleSort_182z1_gg_ .___SSortWrapper_182z1_gg_{flex-basis:calc(var(--intergalactic-spacing-1x, 4px) + 16px);opacity:1}.___SColumn_182z1_gg_._use_primary_182z1_gg_.__visibleSort_182z1_gg_ .___SSortButton_182z1_gg_,.___SColumn_182z1_gg_._use_primary_182z1_gg_.__visibleSort_182z1_gg_ .___SSortWrapper_182z1_gg_::before,.___SColumn_182z1_gg_._use_secondary_182z1_gg_.__visibleSort_182z1_gg_ .___SSortWrapper_182z1_gg_::before{display:flex;opacity:1}.___SColumn_182z1_gg_._use_secondary_182z1_gg_{padding:var(--intergalactic-spacing-2x, 8px);border-bottom:1px solid var(--intergalactic-border-table-accent, #a9abb6);background-color:var(--intergalactic-table-th-secondary-cell, #ffffff)}.___SColumn_182z1_gg_._use_secondary_182z1_gg_ .___SSortWrapper_182z1_gg_::before{background:linear-gradient(270deg,var(--intergalactic-table-th-secondary-cell, #ffffff) 67.5%,rgba(255,255,255,0) 105%)}.___SColumn_182z1_gg_._use_secondary_182z1_gg_.__visibleSort_182z1_gg_ .___SSortWrapper_182z1_gg_{flex-basis:calc(var(--intergalactic-spacing-1x, 4px) + 16px);opacity:1}.___SColumn_182z1_gg_._use_secondary_182z1_gg_.__visibleSort_182z1_gg_ .___SSortButton_182z1_gg_{display:flex;opacity:1}.___SColumn_182z1_gg_.__gridArea_182z1_gg_,.___SGroupTitle_182z1_gg_.__gridArea_182z1_gg_,.___SGroup_182z1_gg_.__gridArea_182z1_gg_{grid-area:var(--gridArea_182z1)}.___SHead_182z1_gg_ .___SColumn_182z1_gg_.__fixed_182z1_gg_,.___SHead_182z1_gg_ .___SGroup_182z1_gg_.__fixed_182z1_gg_,.___SHead_182z1_gg_.__sticky_182z1_gg_ .___SColumn_182z1_gg_.__fixed_182z1_gg_,.___SHead_182z1_gg_.__sticky_182z1_gg_ .___SGroup_182z1_gg_{position:sticky;z-index:2}@media (hover:hover){.___SColumn_182z1_gg_.__sortable_182z1_gg_:hover{cursor:pointer}}.___SSortWrapper_182z1_gg_{align-items:center;display:flex;flex-shrink:1;position:relative;flex-basis:0;min-height:16px;opacity:0;transition:all calc(var(--intergalactic-duration-extra-fast, 100)*1ms) ease-in-out}.___SSortButton_182z1_gg_,.___SSortWrapper_182z1_gg_:before{display:none;position:absolute;right:0;opacity:0;transition:opacity .3s ease}.___SSortWrapper_182z1_gg_:before{content:\"\";top:0;width:20px;height:100%}.___SSortButton_182z1_gg_{fill:var(--intergalactic-icon-secondary-neutral-hover-active, #878992);top:calc(-1*(1em*1.25 - 16px));margin-left:var(--intergalactic-spacing-1x, 4px)}" /*__inner_css_end__*/, "182z1_gg_") /*__reshadow_css_end__*/, {
17
+ "__SHead": "___SHead_182z1_gg_",
18
+ "_sticky": "__sticky_182z1_gg_",
19
+ "__SColumn": "___SColumn_182z1_gg_",
20
+ "__SGroup": "___SGroup_182z1_gg_",
21
+ "__SGroupContainer": "___SGroupContainer_182z1_gg_",
22
+ "_compact": "__compact_182z1_gg_",
23
+ "_use_primary": "_use_primary_182z1_gg_",
24
+ "_use_secondary": "_use_secondary_182z1_gg_",
25
+ "_visibleSort": "__visibleSort_182z1_gg_",
26
+ "_borders_both": "_borders_both_182z1_gg_",
27
+ "_borders_left": "_borders_left_182z1_gg_",
28
+ "_borders_right": "_borders_right_182z1_gg_",
29
+ "_gridArea": "__gridArea_182z1_gg_",
30
+ "__SGroupTitle": "___SGroupTitle_182z1_gg_",
31
+ "--gridArea": "--gridArea_182z1",
32
+ "_fixed": "__fixed_182z1_gg_",
33
+ "_sortable": "__sortable_182z1_gg_",
34
+ "__SSortWrapper": "___SSortWrapper_182z1_gg_",
35
+ "__SSortButton": "___SSortButton_182z1_gg_"
36
+ });
37
+ import { ButtonLink } from '@semcore/button';
38
+ import { getFocusableIn } from '@semcore/core/lib/utils/focus-lock/getFocusableIn';
39
+ import { SORT_ICON_WIDTH } from '../../Head';
40
+ import canUseDOM from '@semcore/core/lib/utils/canUseDOM';
41
+ var SORTING_ICON = {
42
+ desc: SortDesc,
43
+ asc: SortAsc
44
+ };
45
+ var ARIA_SORT = {
46
+ desc: 'descending',
47
+ asc: 'ascending'
48
+ };
49
+ var DEFAULT_DIRECTION = 'desc';
50
+ var reversedSortDirection = {
51
+ desc: 'asc',
52
+ asc: 'desc'
53
+ };
54
+ export var Column = /*#__PURE__*/function (_Component) {
55
+ _inherits(Column, _Component);
56
+ var _super = _createSuper(Column);
57
+ function Column() {
58
+ var _this;
59
+ _classCallCheck(this, Column);
60
+ for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
61
+ args[_key] = arguments[_key];
62
+ }
63
+ _this = _super.call.apply(_super, [this].concat(args));
64
+ _defineProperty(_assertThisInitialized(_this), "lockedCell", [null, false]);
65
+ _defineProperty(_assertThisInitialized(_this), "columnRef", /*#__PURE__*/React.createRef());
66
+ _defineProperty(_assertThisInitialized(_this), "sortWrapperRef", /*#__PURE__*/React.createRef());
67
+ _defineProperty(_assertThisInitialized(_this), "state", {
68
+ sortVisible: false
69
+ });
70
+ _defineProperty(_assertThisInitialized(_this), "calculateActiveColumnMinWidth", function () {
71
+ var node = _this.columnRef.current;
72
+ if (node) {
73
+ var _this$columnRef$curre, _this$columnRef$curre2;
74
+ var clonedColumn = document.createElement('div');
75
+ var computedStyle = window.getComputedStyle(node);
76
+ node.childNodes.forEach(function (node) {
77
+ if (_this.sortWrapperRef.current !== node) {
78
+ clonedColumn.append(node.cloneNode(true));
79
+ }
80
+ });
81
+ clonedColumn.style.setProperty('visibility', 'hidden', 'important');
82
+ var styles = ['display', 'flex', 'margin', 'padding', 'background', 'font-style', 'font-width', 'font-size', 'font-weight'];
83
+ styles.forEach(function (key) {
84
+ clonedColumn.style.setProperty(key, computedStyle.getPropertyValue(key), computedStyle.getPropertyPriority(key));
85
+ });
86
+ clonedColumn.style.setProperty('width', 'fit-content', 'important');
87
+ document.body.appendChild(clonedColumn);
88
+ var computedWidth = Math.ceil(clonedColumn.getBoundingClientRect().width);
89
+ document.body.removeChild(clonedColumn);
90
+ var defaultNodeWidth = (_this$columnRef$curre = (_this$columnRef$curre2 = _this.columnRef.current) === null || _this$columnRef$curre2 === void 0 ? void 0 : _this$columnRef$curre2.clientWidth) !== null && _this$columnRef$curre !== void 0 ? _this$columnRef$curre : 0;
91
+ if (computedWidth >= defaultNodeWidth) {
92
+ return defaultNodeWidth + SORT_ICON_WIDTH;
93
+ } else {
94
+ var freeSpace = defaultNodeWidth - computedWidth;
95
+ if (freeSpace < SORT_ICON_WIDTH) {
96
+ return computedWidth + SORT_ICON_WIDTH;
97
+ }
98
+ }
99
+ }
100
+ return null;
101
+ });
102
+ _defineProperty(_assertThisInitialized(_this), "handleMouseEnter", function () {
103
+ _this.setState({
104
+ sortVisible: true
105
+ });
106
+ });
107
+ _defineProperty(_assertThisInitialized(_this), "handleMouseLeave", function () {
108
+ _this.setState({
109
+ sortVisible: false
110
+ });
111
+ });
112
+ _defineProperty(_assertThisInitialized(_this), "handleBlur", function () {
113
+ _this.setState({
114
+ sortVisible: false
115
+ });
116
+ });
117
+ _defineProperty(_assertThisInitialized(_this), "handleSortClick", function (e) {
118
+ var _this$asProps = _this.asProps,
119
+ sort = _this$asProps.sort,
120
+ onSortChange = _this$asProps.onSortChange,
121
+ name = _this$asProps.name;
122
+ if (sort && onSortChange) {
123
+ var sortDirection = sort[0] === name ? reversedSortDirection[sort[1]] : DEFAULT_DIRECTION;
124
+ onSortChange([name, sortDirection], e);
125
+ }
126
+ });
127
+ _defineProperty(_assertThisInitialized(_this), "handleKeyDown", function (e) {
128
+ if (e.currentTarget === _this.lockedCell[0]) {
129
+ var focusableChildren = Array.from(_this.lockedCell[0].children).flatMap(function (node) {
130
+ return getFocusableIn(node);
131
+ });
132
+ if (_this.lockedCell[1]) {
133
+ if (e.key === 'Escape') {
134
+ var _this$lockedCell$;
135
+ (_this$lockedCell$ = _this.lockedCell[0]) === null || _this$lockedCell$ === void 0 ? void 0 : _this$lockedCell$.focus();
136
+ _this.lockedCell[1] = false;
137
+ }
138
+ if (e.key.startsWith('Arrow')) {
139
+ e.stopPropagation();
140
+ }
141
+ if (e.key === 'Tab') {
142
+ if (e.target === focusableChildren[0] && e.shiftKey) {
143
+ var _focusableChildren;
144
+ (_focusableChildren = focusableChildren[focusableChildren.length - 1]) === null || _focusableChildren === void 0 ? void 0 : _focusableChildren.focus();
145
+ e.preventDefault();
146
+ } else if (e.target === focusableChildren[focusableChildren.length - 1] && !e.shiftKey) {
147
+ var _focusableChildren$;
148
+ (_focusableChildren$ = focusableChildren[0]) === null || _focusableChildren$ === void 0 ? void 0 : _focusableChildren$.focus();
149
+ e.preventDefault();
150
+ }
151
+ }
152
+ } else if (e.key === 'Enter') {
153
+ var _focusableChildren$2;
154
+ _this.lockedCell[1] = true;
155
+ (_focusableChildren$2 = focusableChildren[0]) === null || _focusableChildren$2 === void 0 ? void 0 : _focusableChildren$2.focus();
156
+ } else if (e.key === 'Tab') {
157
+ var _this$lockedCell$2;
158
+ (_this$lockedCell$2 = _this.lockedCell[0]) === null || _this$lockedCell$2 === void 0 ? void 0 : _this$lockedCell$2.setAttribute('inert', '');
159
+ }
160
+ }
161
+ });
162
+ _defineProperty(_assertThisInitialized(_this), "handleFocusCell", function (e) {
163
+ var cellElement = e.currentTarget;
164
+ var target = e.target;
165
+ _this.setState({
166
+ sortVisible: true
167
+ }, function () {
168
+ if (target === cellElement) {
169
+ var focusableChildren = Array.from(cellElement.children).flatMap(function (node) {
170
+ return getFocusableIn(node);
171
+ });
172
+ if (focusableChildren.length === 1) {
173
+ focusableChildren[0].focus();
174
+ } else if (focusableChildren.length > 1) {
175
+ _this.lockedCell = [cellElement, false];
176
+ }
177
+ }
178
+ });
179
+ });
180
+ return _this;
181
+ }
182
+ _createClass(Column, [{
183
+ key: "componentDidUpdate",
184
+ value: function componentDidUpdate(prevProps) {
185
+ var _prevProps$sort, _this$asProps$sort;
186
+ if (this.asProps.changeSortSize && canUseDOM() && ((_prevProps$sort = prevProps.sort) === null || _prevProps$sort === void 0 ? void 0 : _prevProps$sort[0]) !== ((_this$asProps$sort = this.asProps.sort) === null || _this$asProps$sort === void 0 ? void 0 : _this$asProps$sort[0])) {
187
+ var _this$asProps$sort2, _this$asProps$sort3;
188
+ var _this$asProps2 = this.asProps,
189
+ tableRef = _this$asProps2.tableRef,
190
+ gridTemplateColumns = _this$asProps2.gridTemplateColumns,
191
+ columnIndex = _this$asProps2.columnIndex;
192
+ if (((_this$asProps$sort2 = this.asProps.sort) === null || _this$asProps$sort2 === void 0 ? void 0 : _this$asProps$sort2[0]) === this.asProps.name) {
193
+ var newWidth = this.calculateActiveColumnMinWidth();
194
+ setTimeout(function () {
195
+ if (tableRef.current && newWidth !== null) {
196
+ tableRef.current.style.setProperty('grid-template-columns', gridTemplateColumns.map(function (gtcWidth, index) {
197
+ if (index === columnIndex) {
198
+ return "".concat(newWidth, "px");
199
+ }
200
+ return gtcWidth;
201
+ }).join(' '));
202
+ }
203
+ });
204
+ } else if (((_this$asProps$sort3 = this.asProps.sort) === null || _this$asProps$sort3 === void 0 ? void 0 : _this$asProps$sort3[0]) !== this.asProps.name) {
205
+ setTimeout(function () {
206
+ if (tableRef.current) {
207
+ tableRef.current.style.setProperty('grid-template-columns', gridTemplateColumns.join(' '));
208
+ }
209
+ });
210
+ }
211
+ }
212
+ }
213
+ }, {
214
+ key: "render",
215
+ value: function render() {
216
+ var _ref = this.asProps,
217
+ _ref2;
218
+ var SColumn = Flex;
219
+ var SSortWrapper = 'div';
220
+ var SSortButton = ButtonLink;
221
+ var _this$asProps3 = this.asProps,
222
+ styles = _this$asProps3.styles,
223
+ sortable = _this$asProps3.sortable,
224
+ sort = _this$asProps3.sort,
225
+ uid = _this$asProps3.uid,
226
+ name = _this$asProps3.name,
227
+ parent = _this$asProps3.parent,
228
+ sortableColumnDescribeId = _this$asProps3.sortableColumnDescribeId;
229
+ var SSortIcon = sort ? SORTING_ICON[sort[1]] : SORTING_ICON['asc'];
230
+ var isSorted = (sort === null || sort === void 0 ? void 0 : sort[0]) === name;
231
+ var visibleSort = sortable && (this.state.sortVisible || isSorted);
232
+ var ariaDescribedBy = [];
233
+ if (isSorted) {
234
+ ariaDescribedBy.push(sortableColumnDescribeId);
235
+ }
236
+ if (parent) {
237
+ ariaDescribedBy.push("igc-table-".concat(uid, "-").concat(parent.name, "-group"));
238
+ }
239
+ var ariaSortValue = sort !== null && sort !== void 0 && sort[1] ? ARIA_SORT[sort[1]] : undefined;
240
+ return _ref2 = sstyled(styles), /*#__PURE__*/React.createElement(SColumn, _ref2.cn("SColumn", _objectSpread({}, _assignProps({
241
+ "ref": this.columnRef,
242
+ "role": 'columnheader',
243
+ "tabIndex": -1,
244
+ "onMouseEnter": this.handleMouseEnter,
245
+ "onMouseLeave": this.handleMouseLeave,
246
+ "onFocus": this.handleFocusCell,
247
+ "onBlur": this.handleBlur,
248
+ "onKeyDown": this.handleKeyDown,
249
+ "visibleSort": visibleSort,
250
+ "isSorted": isSorted,
251
+ "innerOutline": true,
252
+ "aria-describedby": ariaDescribedBy.length > 0 ? ariaDescribedBy.join(' ') : undefined,
253
+ "aria-sort": ariaSortValue,
254
+ "onClick": this.handleSortClick
255
+ }, _ref))), this.asProps.children, sortable && /*#__PURE__*/React.createElement(SSortWrapper, _ref2.cn("SSortWrapper", {
256
+ "ref": this.sortWrapperRef
257
+ }), /*#__PURE__*/React.createElement(SSortButton, _ref2.cn("SSortButton", {
258
+ "onClick": this.handleSortClick,
259
+ "aria-label": ariaSortValue,
260
+ "color": '--intergalactic-icon-primary-neutral'
261
+ }), /*#__PURE__*/React.createElement(SSortButton.Addon, {
262
+ tag: SSortIcon
263
+ }))));
264
+ }
265
+ }]);
266
+ return Column;
267
+ }(Component);
268
+ _defineProperty(Column, "displayName", 'Column');
269
+ _defineProperty(Column, "style", style);
270
+ //# sourceMappingURL=Column.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Column.js","names":["React","Component","Root","sstyled","Flex","SortDesc","SortAsc","style","_sstyled","insert","ButtonLink","getFocusableIn","SORT_ICON_WIDTH","canUseDOM","SORTING_ICON","desc","asc","ARIA_SORT","DEFAULT_DIRECTION","reversedSortDirection","Column","_Component","_inherits","_super","_createSuper","_this","_classCallCheck","_len","arguments","length","args","Array","_key","call","apply","concat","_defineProperty","_assertThisInitialized","createRef","sortVisible","node","columnRef","current","_this$columnRef$curre","_this$columnRef$curre2","clonedColumn","document","createElement","computedStyle","window","getComputedStyle","childNodes","forEach","sortWrapperRef","append","cloneNode","setProperty","styles","key","getPropertyValue","getPropertyPriority","body","appendChild","computedWidth","Math","ceil","getBoundingClientRect","width","removeChild","defaultNodeWidth","clientWidth","freeSpace","setState","e","_this$asProps","asProps","sort","onSortChange","name","sortDirection","currentTarget","lockedCell","focusableChildren","from","children","flatMap","_this$lockedCell$","focus","startsWith","stopPropagation","target","shiftKey","_focusableChildren","preventDefault","_focusableChildren$","_focusableChildren$2","_this$lockedCell$2","setAttribute","cellElement","_createClass","value","componentDidUpdate","prevProps","_prevProps$sort","_this$asProps$sort","changeSortSize","_this$asProps$sort2","_this$asProps$sort3","_this$asProps2","tableRef","gridTemplateColumns","columnIndex","newWidth","calculateActiveColumnMinWidth","setTimeout","map","gtcWidth","index","join","render","_ref","_ref2","SColumn","SSortWrapper","SSortButton","_this$asProps3","sortable","uid","parent","sortableColumnDescribeId","SSortIcon","isSorted","visibleSort","state","ariaDescribedBy","push","ariaSortValue","undefined","cn","_objectSpread","_assignProps","handleMouseEnter","handleMouseLeave","handleFocusCell","handleBlur","handleKeyDown","handleSortClick","Addon","tag"],"sources":["../../../../src/components/Head/Column.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Component, Root, sstyled } from '@semcore/core';\nimport { ColumnPropsInner, DataTableColumnProps } from './Column.types';\nimport { Flex } from '@semcore/base-components';\nimport SortDesc from '@semcore/icon/SortDesc/m';\nimport SortAsc from '@semcore/icon/SortAsc/m';\n\nimport style from './style.shadow.css';\nimport { ButtonLink } from '@semcore/button';\nimport type { SortDirection } from '../DataTable/DataTable.types';\nimport { getFocusableIn } from '@semcore/core/lib/utils/focus-lock/getFocusableIn';\nimport { SORT_ICON_WIDTH } from '../../Head';\nimport canUseDOM from '@semcore/core/lib/utils/canUseDOM';\n\nconst SORTING_ICON = {\n desc: SortDesc,\n asc: SortAsc,\n} as const;\n\nconst ARIA_SORT = {\n desc: 'descending',\n asc: 'ascending',\n} as const;\n\nconst DEFAULT_DIRECTION = 'desc';\n\nconst reversedSortDirection: { [direction in SortDirection]: SortDirection } = {\n desc: 'asc',\n asc: 'desc',\n};\n\ntype State = {\n sortVisible: boolean;\n};\n\nexport class Column extends Component<DataTableColumnProps, {}, {}, [], ColumnPropsInner> {\n static displayName = 'Column';\n static style = style;\n\n lockedCell: [HTMLElement | null, boolean] = [null, false];\n\n columnRef = React.createRef<HTMLDivElement>();\n sortWrapperRef = React.createRef<HTMLDivElement>();\n\n state: State = {\n sortVisible: false,\n };\n\n componentDidUpdate(prevProps: DataTableColumnProps & ColumnPropsInner): void {\n if (\n this.asProps.changeSortSize &&\n canUseDOM() &&\n prevProps.sort?.[0] !== this.asProps.sort?.[0]\n ) {\n const { tableRef, gridTemplateColumns, columnIndex } = this.asProps;\n\n if (this.asProps.sort?.[0] === this.asProps.name) {\n const newWidth = this.calculateActiveColumnMinWidth();\n\n setTimeout(() => {\n if (tableRef.current && newWidth !== null) {\n tableRef.current.style.setProperty(\n 'grid-template-columns',\n gridTemplateColumns\n .map((gtcWidth, index) => {\n if (index === columnIndex) {\n return `${newWidth}px`;\n }\n return gtcWidth;\n })\n .join(' '),\n );\n }\n });\n } else if (this.asProps.sort?.[0] !== this.asProps.name) {\n setTimeout(() => {\n if (tableRef.current) {\n tableRef.current.style.setProperty(\n 'grid-template-columns',\n gridTemplateColumns.join(' '),\n );\n }\n });\n }\n }\n }\n\n calculateActiveColumnMinWidth = (): number | null => {\n const node = this.columnRef.current;\n\n if (node) {\n const clonedColumn = document.createElement('div');\n const computedStyle = window.getComputedStyle(node);\n\n node.childNodes.forEach((node) => {\n if (this.sortWrapperRef.current !== node) {\n clonedColumn.append(node.cloneNode(true));\n }\n });\n\n clonedColumn.style.setProperty('visibility', 'hidden', 'important');\n\n const styles = [\n 'display',\n 'flex',\n 'margin',\n 'padding',\n 'background',\n 'font-style',\n 'font-width',\n 'font-size',\n 'font-weight',\n ];\n\n styles.forEach((key) => {\n clonedColumn.style.setProperty(\n key,\n computedStyle.getPropertyValue(key),\n computedStyle.getPropertyPriority(key),\n );\n });\n\n clonedColumn.style.setProperty('width', 'fit-content', 'important');\n\n document.body.appendChild(clonedColumn);\n\n const computedWidth = Math.ceil(clonedColumn.getBoundingClientRect().width);\n\n document.body.removeChild(clonedColumn);\n\n const defaultNodeWidth = this.columnRef.current?.clientWidth ?? 0;\n\n if (computedWidth >= defaultNodeWidth) {\n return defaultNodeWidth + SORT_ICON_WIDTH;\n } else {\n const freeSpace = defaultNodeWidth - computedWidth;\n\n if (freeSpace < SORT_ICON_WIDTH) {\n return computedWidth + SORT_ICON_WIDTH;\n }\n }\n }\n\n return null;\n };\n\n handleMouseEnter = () => {\n this.setState({ sortVisible: true });\n };\n\n handleMouseLeave = () => {\n this.setState({ sortVisible: false });\n };\n\n handleBlur = () => {\n this.setState({ sortVisible: false });\n };\n\n handleSortClick = (e: React.SyntheticEvent<HTMLButtonElement>) => {\n const { sort, onSortChange, name } = this.asProps;\n\n if (sort && onSortChange) {\n const sortDirection = sort[0] === name ? reversedSortDirection[sort[1]] : DEFAULT_DIRECTION;\n\n onSortChange([name, sortDirection], e);\n }\n };\n\n handleKeyDown = (e: React.KeyboardEvent) => {\n if (e.currentTarget === this.lockedCell[0]) {\n const focusableChildren = Array.from(this.lockedCell[0].children).flatMap((node) =>\n getFocusableIn(node as HTMLElement),\n );\n\n if (this.lockedCell[1]) {\n if (e.key === 'Escape') {\n this.lockedCell[0]?.focus();\n this.lockedCell[1] = false;\n }\n if (e.key.startsWith('Arrow')) {\n e.stopPropagation();\n }\n if (e.key === 'Tab') {\n if (e.target === focusableChildren[0] && e.shiftKey) {\n focusableChildren[focusableChildren.length - 1]?.focus();\n e.preventDefault();\n } else if (e.target === focusableChildren[focusableChildren.length - 1] && !e.shiftKey) {\n focusableChildren[0]?.focus();\n e.preventDefault();\n }\n }\n } else if (e.key === 'Enter') {\n this.lockedCell[1] = true;\n focusableChildren[0]?.focus();\n } else if (e.key === 'Tab') {\n this.lockedCell[0]?.setAttribute('inert', '');\n }\n }\n };\n\n handleFocusCell = (e: React.FocusEvent<HTMLElement, HTMLElement>) => {\n const cellElement = e.currentTarget;\n const target = e.target;\n\n this.setState({ sortVisible: true }, () => {\n if (target === cellElement) {\n const focusableChildren = Array.from(cellElement.children).flatMap((node) =>\n getFocusableIn(node as HTMLElement),\n );\n\n if (focusableChildren.length === 1) {\n focusableChildren[0].focus();\n } else if (focusableChildren.length > 1) {\n this.lockedCell = [cellElement, false];\n }\n }\n });\n };\n\n render() {\n const SColumn = Root;\n const SSortWrapper = 'div';\n const SSortButton = ButtonLink;\n const { styles, sortable, sort, uid, name, parent, sortableColumnDescribeId } = this.asProps;\n\n const SSortIcon = sort ? SORTING_ICON[sort[1]] : SORTING_ICON['asc'];\n const isSorted = sort?.[0] === name;\n const visibleSort = sortable && (this.state.sortVisible || isSorted);\n\n const ariaDescribedBy = [];\n if (isSorted) {\n ariaDescribedBy.push(sortableColumnDescribeId);\n }\n if (parent) {\n ariaDescribedBy.push(`igc-table-${uid}-${parent.name}-group`);\n }\n\n const ariaSortValue = sort?.[1] ? ARIA_SORT[sort[1]] : undefined;\n\n return sstyled(styles)(\n <SColumn\n render={Flex}\n ref={this.columnRef}\n role={'columnheader'}\n tabIndex={-1}\n onMouseEnter={this.handleMouseEnter}\n onMouseLeave={this.handleMouseLeave}\n onFocus={this.handleFocusCell}\n onBlur={this.handleBlur}\n onKeyDown={this.handleKeyDown}\n visibleSort={visibleSort}\n isSorted={isSorted}\n innerOutline\n aria-describedby={ariaDescribedBy.length > 0 ? ariaDescribedBy.join(' ') : undefined}\n aria-sort={ariaSortValue}\n onClick={this.handleSortClick}\n >\n {this.asProps.children}\n\n {sortable && (\n <SSortWrapper ref={this.sortWrapperRef}>\n <SSortButton\n onClick={this.handleSortClick}\n aria-label={ariaSortValue}\n color={'--intergalactic-icon-primary-neutral'}\n >\n <SSortButton.Addon tag={SSortIcon} />\n </SSortButton>\n </SSortWrapper>\n )}\n </SColumn>,\n );\n }\n}\n"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=Column.types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Column.types.js","names":[],"sources":["../../../../src/components/Head/Column.types.ts"],"sourcesContent":["import { DataTableProps, DTUse } from '../DataTable/DataTable.types';\nimport { Property } from 'csstype';\n\nexport type CommonColumnType = {\n /**\n * Name of column for mapping with data\n */\n name: string;\n /**\n * Flag to define column as sortable\n */\n sortable?: boolean;\n /**\n * Fixes column to some side of table\n */\n fixed?: 'left' | 'right';\n /**\n * Adds vertical border(s)\n */\n borders?: 'both' | 'left' | 'right';\n /**\n * It manages the `flex-wrap` property\n */\n flexWrap?: boolean;\n /**\n * It manages the `align-items` property\n */\n alignItems?: Property.AlignItems;\n /**\n * It manages the `align-content` property\n */\n alignContent?: Property.AlignContent;\n /**\n * CSS `justify-content` property\n */\n justifyContent?: Property.JustifyContent;\n};\n\nexport type DTColumn = CommonColumnType & {\n ref: React.RefCallback<HTMLElement> & { current: HTMLElement | null };\n /**\n * Width for grid-template-columns\n */\n gridColumnWidth: string;\n\n /**\n * Width of column by getBoundaryRect() value\n */\n calculatedWidth: number;\n /**\n * Height of column by getBoundaryRect() value\n */\n calculatedHeight: number;\n\n parent?: DTColumn;\n // children?: Array<Omit<DTColumn[], 'children'>>;\n\n gridArea?: string;\n};\n\nexport type DataTableColumnProps = CommonColumnType & {\n /**\n * Value for grid-template-columns for current column\n */\n gtcWidth?: string;\n\n /**\n * Flag for change column size if sorted by it\n */\n changeSortSize?: boolean;\n\n children?: React.ReactElement[];\n};\n\nexport type ColumnPropsInner = {\n use: DTUse;\n borders?: 'both' | 'left' | 'right';\n sort?: DataTableProps['sort'];\n onSortChange?: DataTableProps['onSortChange'];\n uid: string;\n parent?: DTColumn;\n sortableColumnDescribeId: string;\n columnIndex: number;\n tableRef: React.RefObject<HTMLElement>;\n gridTemplateColumns: string[];\n gridTemplateAreas: string[];\n};\n"],"mappings":""}
@@ -0,0 +1,91 @@
1
+ import _objectSpread from "@babel/runtime/helpers/objectSpread2";
2
+ import _classCallCheck from "@babel/runtime/helpers/classCallCheck";
3
+ import _createClass from "@babel/runtime/helpers/createClass";
4
+ import _assertThisInitialized from "@babel/runtime/helpers/assertThisInitialized";
5
+ import _inherits from "@babel/runtime/helpers/inherits";
6
+ import _createSuper from "@babel/runtime/helpers/createSuper";
7
+ import _defineProperty from "@babel/runtime/helpers/defineProperty";
8
+ import { sstyled as _sstyled } from "@semcore/core";
9
+ import { assignProps as _assignProps } from "@semcore/core";
10
+ import * as React from 'react';
11
+ import { Component, Root, sstyled } from '@semcore/core';
12
+ import { Box } from '@semcore/base-components';
13
+ /*__reshadow-styles__:"./style.shadow.css"*/
14
+ var style = ( /*__reshadow_css_start__*/_sstyled.insert( /*__inner_css_start__*/".___SHead_182z1_gg_{display:contents}.___SHead_182z1_gg_.__sticky_182z1_gg_>.___SColumn_182z1_gg_{position:sticky;top:0;z-index:1}.___SHead_182z1_gg_.__sticky_182z1_gg_ .___SGroup_182z1_gg_{top:0}.___SHead_182z1_gg_.__sticky_182z1_gg_ .___SGroupContainer_182z1_gg_>.___SColumn_182z1_gg_{position:sticky;top:40px;z-index:1}.___SHead_182z1_gg_.__compact_182z1_gg_ .___SColumn_182z1_gg_{padding:var(--intergalactic-spacing-3x, 12px) var(--intergalactic-spacing-2x, 8px)}.___SColumn_182z1_gg_,.___SGroup_182z1_gg_{display:flex;align-items:flex-start;font-size:var(--intergalactic-fs-100, 12px);color:var(--intergalactic-text-primary, #191b23);box-sizing:border-box;height:100%;position:relative;transition:width calc(var(--intergalactic-duration-extra-fast, 100)*1ms) ease-in-out,min-width calc(var(--intergalactic-duration-extra-fast, 100)*1ms) ease-in-out,max-width calc(var(--intergalactic-duration-extra-fast, 100)*1ms) ease-in-out}.___SGroup_182z1_gg_._use_primary_182z1_gg_{justify-content:center;padding:var(--intergalactic-spacing-3x, 12px);background-color:var(--intergalactic-table-th-primary-cell, #f4f5f9)}.___SGroup_182z1_gg_._use_secondary_182z1_gg_{justify-content:center;padding:var(--intergalactic-spacing-2x, 8px);background-color:var(--intergalactic-table-th-secondary-cell, #ffffff)}.___SGroup_182z1_gg_:has(.___SColumn_182z1_gg_.__visibleSort_182z1_gg_){background-color:var(--intergalactic-table-th-primary-cell-hover, #e0e1e9)}.___SColumn_182z1_gg_._borders_both_182z1_gg_,.___SColumn_182z1_gg_._borders_left_182z1_gg_,.___SGroup_182z1_gg_._borders_both_182z1_gg_,.___SGroup_182z1_gg_._borders_left_182z1_gg_{border-left:1px solid var(--intergalactic-border-secondary, #e0e1e9)}.___SColumn_182z1_gg_._borders_both_182z1_gg_,.___SColumn_182z1_gg_._borders_right_182z1_gg_,.___SGroup_182z1_gg_._borders_both_182z1_gg_,.___SGroup_182z1_gg_._borders_right_182z1_gg_{border-right:1px solid var(--intergalactic-border-secondary, #e0e1e9)}.___SColumn_182z1_gg_._use_primary_182z1_gg_{padding:var(--intergalactic-spacing-3x, 12px);border-bottom:1px solid var(--intergalactic-border-secondary, #e0e1e9);background-color:var(--intergalactic-table-th-primary-cell, #f4f5f9)}.___SColumn_182z1_gg_._use_primary_182z1_gg_ .___SSortWrapper_182z1_gg_::before{background:linear-gradient(270deg,var(--intergalactic-table-th-primary-cell-hover, #e0e1e9) 67.5%,rgba(224,225,233,0) 105%)}.___SColumn_182z1_gg_._use_primary_182z1_gg_.__visibleSort_182z1_gg_{background-color:var(--intergalactic-table-th-primary-cell-hover, #e0e1e9)}.___SColumn_182z1_gg_._use_primary_182z1_gg_.__visibleSort_182z1_gg_ .___SSortWrapper_182z1_gg_{flex-basis:calc(var(--intergalactic-spacing-1x, 4px) + 16px);opacity:1}.___SColumn_182z1_gg_._use_primary_182z1_gg_.__visibleSort_182z1_gg_ .___SSortButton_182z1_gg_,.___SColumn_182z1_gg_._use_primary_182z1_gg_.__visibleSort_182z1_gg_ .___SSortWrapper_182z1_gg_::before,.___SColumn_182z1_gg_._use_secondary_182z1_gg_.__visibleSort_182z1_gg_ .___SSortWrapper_182z1_gg_::before{display:flex;opacity:1}.___SColumn_182z1_gg_._use_secondary_182z1_gg_{padding:var(--intergalactic-spacing-2x, 8px);border-bottom:1px solid var(--intergalactic-border-table-accent, #a9abb6);background-color:var(--intergalactic-table-th-secondary-cell, #ffffff)}.___SColumn_182z1_gg_._use_secondary_182z1_gg_ .___SSortWrapper_182z1_gg_::before{background:linear-gradient(270deg,var(--intergalactic-table-th-secondary-cell, #ffffff) 67.5%,rgba(255,255,255,0) 105%)}.___SColumn_182z1_gg_._use_secondary_182z1_gg_.__visibleSort_182z1_gg_ .___SSortWrapper_182z1_gg_{flex-basis:calc(var(--intergalactic-spacing-1x, 4px) + 16px);opacity:1}.___SColumn_182z1_gg_._use_secondary_182z1_gg_.__visibleSort_182z1_gg_ .___SSortButton_182z1_gg_{display:flex;opacity:1}.___SColumn_182z1_gg_.__gridArea_182z1_gg_,.___SGroupTitle_182z1_gg_.__gridArea_182z1_gg_,.___SGroup_182z1_gg_.__gridArea_182z1_gg_{grid-area:var(--gridArea_182z1)}.___SHead_182z1_gg_ .___SColumn_182z1_gg_.__fixed_182z1_gg_,.___SHead_182z1_gg_ .___SGroup_182z1_gg_.__fixed_182z1_gg_,.___SHead_182z1_gg_.__sticky_182z1_gg_ .___SColumn_182z1_gg_.__fixed_182z1_gg_,.___SHead_182z1_gg_.__sticky_182z1_gg_ .___SGroup_182z1_gg_{position:sticky;z-index:2}@media (hover:hover){.___SColumn_182z1_gg_.__sortable_182z1_gg_:hover{cursor:pointer}}.___SSortWrapper_182z1_gg_{align-items:center;display:flex;flex-shrink:1;position:relative;flex-basis:0;min-height:16px;opacity:0;transition:all calc(var(--intergalactic-duration-extra-fast, 100)*1ms) ease-in-out}.___SSortButton_182z1_gg_,.___SSortWrapper_182z1_gg_:before{display:none;position:absolute;right:0;opacity:0;transition:opacity .3s ease}.___SSortWrapper_182z1_gg_:before{content:\"\";top:0;width:20px;height:100%}.___SSortButton_182z1_gg_{fill:var(--intergalactic-icon-secondary-neutral-hover-active, #878992);top:calc(-1*(1em*1.25 - 16px));margin-left:var(--intergalactic-spacing-1x, 4px)}" /*__inner_css_end__*/, "182z1_gg_") /*__reshadow_css_end__*/, {
15
+ "__SHead": "___SHead_182z1_gg_",
16
+ "_sticky": "__sticky_182z1_gg_",
17
+ "__SColumn": "___SColumn_182z1_gg_",
18
+ "__SGroup": "___SGroup_182z1_gg_",
19
+ "__SGroupContainer": "___SGroupContainer_182z1_gg_",
20
+ "_compact": "__compact_182z1_gg_",
21
+ "_use_primary": "_use_primary_182z1_gg_",
22
+ "_use_secondary": "_use_secondary_182z1_gg_",
23
+ "_visibleSort": "__visibleSort_182z1_gg_",
24
+ "_borders_both": "_borders_both_182z1_gg_",
25
+ "_borders_left": "_borders_left_182z1_gg_",
26
+ "_borders_right": "_borders_right_182z1_gg_",
27
+ "_gridArea": "__gridArea_182z1_gg_",
28
+ "__SGroupTitle": "___SGroupTitle_182z1_gg_",
29
+ "--gridArea": "--gridArea_182z1",
30
+ "_fixed": "__fixed_182z1_gg_",
31
+ "_sortable": "__sortable_182z1_gg_",
32
+ "__SSortWrapper": "___SSortWrapper_182z1_gg_",
33
+ "__SSortButton": "___SSortButton_182z1_gg_"
34
+ });
35
+ import getOriginChildren from '@semcore/core/lib/utils/getOriginChildren';
36
+ export var Group = /*#__PURE__*/function (_Component) {
37
+ _inherits(Group, _Component);
38
+ var _super = _createSuper(Group);
39
+ function Group() {
40
+ var _this;
41
+ _classCallCheck(this, Group);
42
+ for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
43
+ args[_key] = arguments[_key];
44
+ }
45
+ _this = _super.call.apply(_super, [this].concat(args));
46
+ _defineProperty(_assertThisInitialized(_this), "mounted", false);
47
+ return _this;
48
+ }
49
+ _createClass(Group, [{
50
+ key: "componentDidMount",
51
+ value: function componentDidMount() {
52
+ this.mounted = true;
53
+ this.forceUpdate();
54
+ }
55
+ }, {
56
+ key: "render",
57
+ value: function render() {
58
+ var _ref = this.asProps,
59
+ _ref2,
60
+ _children$,
61
+ _children;
62
+ var SGroupContainer = Box;
63
+ var SGroup = Box;
64
+ var _this$asProps = this.asProps,
65
+ styles = _this$asProps.styles,
66
+ Children = _this$asProps.Children,
67
+ title = _this$asProps.title,
68
+ fixed = _this$asProps.fixed,
69
+ fixedColumnsMap = _this$asProps.fixedColumnsMap;
70
+ var children = getOriginChildren(Children);
71
+ var firstName = (_children$ = children[0]) === null || _children$ === void 0 ? void 0 : _children$.props.name;
72
+ var lastName = (_children = children[children.length - 1]) === null || _children === void 0 ? void 0 : _children.props.name;
73
+ var style = {};
74
+ if (fixed === 'left' && firstName) {
75
+ style.left = fixedColumnsMap.get(firstName);
76
+ }
77
+ if (fixed === 'right') {
78
+ style.right = fixedColumnsMap.get(lastName);
79
+ }
80
+ return _ref2 = sstyled(styles), /*#__PURE__*/React.createElement(SGroupContainer, _ref2.cn("SGroupContainer", {
81
+ "display": 'contents'
82
+ }), this.mounted && /*#__PURE__*/React.createElement(SGroup, _ref2.cn("SGroup", _objectSpread({}, _assignProps({
83
+ "style": style
84
+ }, _ref))), title), /*#__PURE__*/React.createElement(Children, _ref2.cn("Children", {})));
85
+ }
86
+ }]);
87
+ return Group;
88
+ }(Component);
89
+ _defineProperty(Group, "displayName", 'Group');
90
+ _defineProperty(Group, "style", style);
91
+ //# sourceMappingURL=Group.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Group.js","names":["React","Component","Root","sstyled","Box","style","_sstyled","insert","getOriginChildren","Group","_Component","_inherits","_super","_createSuper","_this","_classCallCheck","_len","arguments","length","args","Array","_key","call","apply","concat","_defineProperty","_assertThisInitialized","_createClass","key","value","componentDidMount","mounted","forceUpdate","render","_ref","asProps","_ref2","_children$","_children","SGroupContainer","SGroup","_this$asProps","styles","Children","title","fixed","fixedColumnsMap","children","firstName","props","name","lastName","left","get","right","createElement","cn","_objectSpread","_assignProps"],"sources":["../../../../src/components/Head/Group.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Component, Root, sstyled } from '@semcore/core';\nimport { Box } from '@semcore/base-components';\n\nimport style from './style.shadow.css';\nimport { DataTableGroupProps, GroupPropsInner } from './Group.type';\nimport getOriginChildren from '@semcore/core/lib/utils/getOriginChildren';\n\nexport class Group extends Component<DataTableGroupProps, {}, {}, [], GroupPropsInner> {\n static displayName = 'Group';\n static style = style;\n\n mounted = false;\n\n componentDidMount() {\n this.mounted = true;\n this.forceUpdate();\n }\n\n render() {\n const SGroupContainer = Box;\n const SGroup = Root;\n const { styles, Children, title, fixed, fixedColumnsMap } = this.asProps;\n const children = getOriginChildren(Children);\n const firstName = children[0]?.props.name;\n const lastName = children[children.length - 1]?.props.name;\n\n const style: any = {};\n\n if (fixed === 'left' && firstName) {\n style.left = fixedColumnsMap.get(firstName);\n }\n if (fixed === 'right') {\n style.right = fixedColumnsMap.get(lastName);\n }\n\n return sstyled(styles)(\n <SGroupContainer display={'contents'}>\n {this.mounted && (\n <SGroup render={Box} style={style}>\n {title}\n </SGroup>\n )}\n <Children />\n </SGroupContainer>,\n );\n }\n}\n"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=Group.type.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Group.type.js","names":[],"sources":["../../../../src/components/Head/Group.type.ts"],"sourcesContent":["import { DTUse } from '../DataTable/DataTable.types';\n\nexport type DataTableGroupProps = {\n title: string;\n\n borders?: 'both' | 'left' | 'right';\n\n fixed?: 'left' | 'right';\n};\n\nexport type GroupPropsInner = {\n use: DTUse;\n fixedColumnsMap: Map<string, any>;\n};\n"],"mappings":""}
@@ -0,0 +1,145 @@
1
+ import _objectSpread from "@babel/runtime/helpers/objectSpread2";
2
+ import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
3
+ import _classCallCheck from "@babel/runtime/helpers/classCallCheck";
4
+ import _createClass from "@babel/runtime/helpers/createClass";
5
+ import _assertThisInitialized from "@babel/runtime/helpers/assertThisInitialized";
6
+ import _inherits from "@babel/runtime/helpers/inherits";
7
+ import _createSuper from "@babel/runtime/helpers/createSuper";
8
+ import _defineProperty from "@babel/runtime/helpers/defineProperty";
9
+ import { sstyled as _sstyled } from "@semcore/core";
10
+ import { assignProps as _assignProps } from "@semcore/core";
11
+ import * as React from 'react';
12
+ import { Component, createComponent, Root, sstyled } from '@semcore/core';
13
+ import { Box, ScreenReaderOnly } from '@semcore/base-components';
14
+ /*__reshadow-styles__:"./style.shadow.css"*/
15
+ var style = ( /*__reshadow_css_start__*/_sstyled.insert( /*__inner_css_start__*/".___SHead_182z1_gg_{display:contents}.___SHead_182z1_gg_.__sticky_182z1_gg_>.___SColumn_182z1_gg_{position:sticky;top:0;z-index:1}.___SHead_182z1_gg_.__sticky_182z1_gg_ .___SGroup_182z1_gg_{top:0}.___SHead_182z1_gg_.__sticky_182z1_gg_ .___SGroupContainer_182z1_gg_>.___SColumn_182z1_gg_{position:sticky;top:40px;z-index:1}.___SHead_182z1_gg_.__compact_182z1_gg_ .___SColumn_182z1_gg_{padding:var(--intergalactic-spacing-3x, 12px) var(--intergalactic-spacing-2x, 8px)}.___SColumn_182z1_gg_,.___SGroup_182z1_gg_{display:flex;align-items:flex-start;font-size:var(--intergalactic-fs-100, 12px);color:var(--intergalactic-text-primary, #191b23);box-sizing:border-box;height:100%;position:relative;transition:width calc(var(--intergalactic-duration-extra-fast, 100)*1ms) ease-in-out,min-width calc(var(--intergalactic-duration-extra-fast, 100)*1ms) ease-in-out,max-width calc(var(--intergalactic-duration-extra-fast, 100)*1ms) ease-in-out}.___SGroup_182z1_gg_._use_primary_182z1_gg_{justify-content:center;padding:var(--intergalactic-spacing-3x, 12px);background-color:var(--intergalactic-table-th-primary-cell, #f4f5f9)}.___SGroup_182z1_gg_._use_secondary_182z1_gg_{justify-content:center;padding:var(--intergalactic-spacing-2x, 8px);background-color:var(--intergalactic-table-th-secondary-cell, #ffffff)}.___SGroup_182z1_gg_:has(.___SColumn_182z1_gg_.__visibleSort_182z1_gg_){background-color:var(--intergalactic-table-th-primary-cell-hover, #e0e1e9)}.___SColumn_182z1_gg_._borders_both_182z1_gg_,.___SColumn_182z1_gg_._borders_left_182z1_gg_,.___SGroup_182z1_gg_._borders_both_182z1_gg_,.___SGroup_182z1_gg_._borders_left_182z1_gg_{border-left:1px solid var(--intergalactic-border-secondary, #e0e1e9)}.___SColumn_182z1_gg_._borders_both_182z1_gg_,.___SColumn_182z1_gg_._borders_right_182z1_gg_,.___SGroup_182z1_gg_._borders_both_182z1_gg_,.___SGroup_182z1_gg_._borders_right_182z1_gg_{border-right:1px solid var(--intergalactic-border-secondary, #e0e1e9)}.___SColumn_182z1_gg_._use_primary_182z1_gg_{padding:var(--intergalactic-spacing-3x, 12px);border-bottom:1px solid var(--intergalactic-border-secondary, #e0e1e9);background-color:var(--intergalactic-table-th-primary-cell, #f4f5f9)}.___SColumn_182z1_gg_._use_primary_182z1_gg_ .___SSortWrapper_182z1_gg_::before{background:linear-gradient(270deg,var(--intergalactic-table-th-primary-cell-hover, #e0e1e9) 67.5%,rgba(224,225,233,0) 105%)}.___SColumn_182z1_gg_._use_primary_182z1_gg_.__visibleSort_182z1_gg_{background-color:var(--intergalactic-table-th-primary-cell-hover, #e0e1e9)}.___SColumn_182z1_gg_._use_primary_182z1_gg_.__visibleSort_182z1_gg_ .___SSortWrapper_182z1_gg_{flex-basis:calc(var(--intergalactic-spacing-1x, 4px) + 16px);opacity:1}.___SColumn_182z1_gg_._use_primary_182z1_gg_.__visibleSort_182z1_gg_ .___SSortButton_182z1_gg_,.___SColumn_182z1_gg_._use_primary_182z1_gg_.__visibleSort_182z1_gg_ .___SSortWrapper_182z1_gg_::before,.___SColumn_182z1_gg_._use_secondary_182z1_gg_.__visibleSort_182z1_gg_ .___SSortWrapper_182z1_gg_::before{display:flex;opacity:1}.___SColumn_182z1_gg_._use_secondary_182z1_gg_{padding:var(--intergalactic-spacing-2x, 8px);border-bottom:1px solid var(--intergalactic-border-table-accent, #a9abb6);background-color:var(--intergalactic-table-th-secondary-cell, #ffffff)}.___SColumn_182z1_gg_._use_secondary_182z1_gg_ .___SSortWrapper_182z1_gg_::before{background:linear-gradient(270deg,var(--intergalactic-table-th-secondary-cell, #ffffff) 67.5%,rgba(255,255,255,0) 105%)}.___SColumn_182z1_gg_._use_secondary_182z1_gg_.__visibleSort_182z1_gg_ .___SSortWrapper_182z1_gg_{flex-basis:calc(var(--intergalactic-spacing-1x, 4px) + 16px);opacity:1}.___SColumn_182z1_gg_._use_secondary_182z1_gg_.__visibleSort_182z1_gg_ .___SSortButton_182z1_gg_{display:flex;opacity:1}.___SColumn_182z1_gg_.__gridArea_182z1_gg_,.___SGroupTitle_182z1_gg_.__gridArea_182z1_gg_,.___SGroup_182z1_gg_.__gridArea_182z1_gg_{grid-area:var(--gridArea_182z1)}.___SHead_182z1_gg_ .___SColumn_182z1_gg_.__fixed_182z1_gg_,.___SHead_182z1_gg_ .___SGroup_182z1_gg_.__fixed_182z1_gg_,.___SHead_182z1_gg_.__sticky_182z1_gg_ .___SColumn_182z1_gg_.__fixed_182z1_gg_,.___SHead_182z1_gg_.__sticky_182z1_gg_ .___SGroup_182z1_gg_{position:sticky;z-index:2}@media (hover:hover){.___SColumn_182z1_gg_.__sortable_182z1_gg_:hover{cursor:pointer}}.___SSortWrapper_182z1_gg_{align-items:center;display:flex;flex-shrink:1;position:relative;flex-basis:0;min-height:16px;opacity:0;transition:all calc(var(--intergalactic-duration-extra-fast, 100)*1ms) ease-in-out}.___SSortButton_182z1_gg_,.___SSortWrapper_182z1_gg_:before{display:none;position:absolute;right:0;opacity:0;transition:opacity .3s ease}.___SSortWrapper_182z1_gg_:before{content:\"\";top:0;width:20px;height:100%}.___SSortButton_182z1_gg_{fill:var(--intergalactic-icon-secondary-neutral-hover-active, #878992);top:calc(-1*(1em*1.25 - 16px));margin-left:var(--intergalactic-spacing-1x, 4px)}" /*__inner_css_end__*/, "182z1_gg_") /*__reshadow_css_end__*/, {
16
+ "__SHead": "___SHead_182z1_gg_",
17
+ "_sticky": "__sticky_182z1_gg_",
18
+ "__SColumn": "___SColumn_182z1_gg_",
19
+ "__SGroup": "___SGroup_182z1_gg_",
20
+ "__SGroupContainer": "___SGroupContainer_182z1_gg_",
21
+ "_compact": "__compact_182z1_gg_",
22
+ "_use_primary": "_use_primary_182z1_gg_",
23
+ "_use_secondary": "_use_secondary_182z1_gg_",
24
+ "_visibleSort": "__visibleSort_182z1_gg_",
25
+ "_borders_both": "_borders_both_182z1_gg_",
26
+ "_borders_left": "_borders_left_182z1_gg_",
27
+ "_borders_right": "_borders_right_182z1_gg_",
28
+ "_gridArea": "__gridArea_182z1_gg_",
29
+ "__SGroupTitle": "___SGroupTitle_182z1_gg_",
30
+ "--gridArea": "--gridArea_182z1",
31
+ "_fixed": "__fixed_182z1_gg_",
32
+ "_sortable": "__sortable_182z1_gg_",
33
+ "__SSortWrapper": "___SSortWrapper_182z1_gg_",
34
+ "__SSortButton": "___SSortButton_182z1_gg_"
35
+ });
36
+ import { Column } from './Column';
37
+ import { Group } from './Group';
38
+ import { getFixedStyle, getScrollOffsetValue } from '../../utils';
39
+ var HeadRoot = /*#__PURE__*/function (_Component) {
40
+ _inherits(HeadRoot, _Component);
41
+ var _super = _createSuper(HeadRoot);
42
+ function HeadRoot() {
43
+ var _this;
44
+ _classCallCheck(this, HeadRoot);
45
+ for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
46
+ args[_key] = arguments[_key];
47
+ }
48
+ _this = _super.call.apply(_super, [this].concat(args));
49
+ _defineProperty(_assertThisInitialized(_this), "fixedColumnsMap", new Map());
50
+ return _this;
51
+ }
52
+ _createClass(HeadRoot, [{
53
+ key: "sortableColumnDescribeId",
54
+ value: function sortableColumnDescribeId() {
55
+ var uid = this.asProps.uid;
56
+ return "".concat(uid, "-column-sortable-describer");
57
+ }
58
+ }, {
59
+ key: "getGroupProps",
60
+ value: function getGroupProps(_, index) {
61
+ var _this$asProps = this.asProps,
62
+ use = _this$asProps.use,
63
+ gridAreaGroupMap = _this$asProps.gridAreaGroupMap;
64
+ return {
65
+ use: use,
66
+ gridArea: gridAreaGroupMap.get(index),
67
+ fixedColumnsMap: this.fixedColumnsMap
68
+ };
69
+ }
70
+ }, {
71
+ key: "getColumnProps",
72
+ value: function getColumnProps(_, index) {
73
+ var _this$asProps2 = this.asProps,
74
+ use = _this$asProps2.use,
75
+ columns = _this$asProps2.columns,
76
+ sort = _this$asProps2.sort,
77
+ onSortChange = _this$asProps2.onSortChange,
78
+ tableRef = _this$asProps2.tableRef,
79
+ gridTemplateColumns = _this$asProps2.gridTemplateColumns,
80
+ gridTemplateAreas = _this$asProps2.gridTemplateAreas;
81
+ var column = columns[index];
82
+ var _getFixedStyle = getFixedStyle(column, columns),
83
+ _getFixedStyle2 = _slicedToArray(_getFixedStyle, 2),
84
+ name = _getFixedStyle2[0],
85
+ value = _getFixedStyle2[1];
86
+ var style = {};
87
+ if (name !== undefined && value !== undefined) {
88
+ style[name] = value;
89
+ this.fixedColumnsMap.set(column.name, value);
90
+ }
91
+ return {
92
+ use: use,
93
+ 'aria-colindex': index + 1,
94
+ ref: function ref(node) {
95
+ return column.ref(node);
96
+ },
97
+ style: style,
98
+ gridArea: column.gridArea,
99
+ fixed: column.fixed,
100
+ borders: column.borders,
101
+ sort: sort,
102
+ onSortChange: onSortChange,
103
+ parent: column.parent,
104
+ sortableColumnDescribeId: this.sortableColumnDescribeId(),
105
+ columnIndex: index,
106
+ tableRef: tableRef,
107
+ gridTemplateColumns: gridTemplateColumns,
108
+ gridTemplateAreas: gridTemplateAreas
109
+ };
110
+ }
111
+ }, {
112
+ key: "render",
113
+ value: function render() {
114
+ var _ref = this.asProps,
115
+ _ref2;
116
+ var SHead = Box;
117
+ var _this$asProps3 = this.asProps,
118
+ Children = _this$asProps3.Children,
119
+ styles = _this$asProps3.styles,
120
+ columns = _this$asProps3.columns,
121
+ tableRef = _this$asProps3.tableRef,
122
+ withScrollBar = _this$asProps3.withScrollBar,
123
+ getI18nText = _this$asProps3.getI18nText;
124
+ var _getScrollOffsetValue = getScrollOffsetValue(columns),
125
+ _getScrollOffsetValue2 = _slicedToArray(_getScrollOffsetValue, 2),
126
+ offsetLeftSum = _getScrollOffsetValue2[0],
127
+ offsetRightSum = _getScrollOffsetValue2[1];
128
+ return _ref2 = sstyled(styles), /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(SHead, _ref2.cn("SHead", _objectSpread({}, _assignProps({
129
+ "role": 'row',
130
+ "aria-rowindex": 1
131
+ }, _ref))), /*#__PURE__*/React.createElement(Children, _ref2.cn("Children", {}))), /*#__PURE__*/React.createElement(ScreenReaderOnly, _ref2.cn("ScreenReaderOnly", {
132
+ "aria-hidden": true,
133
+ "id": this.sortableColumnDescribeId()
134
+ }), getI18nText('sortableColumn')));
135
+ }
136
+ }]);
137
+ return HeadRoot;
138
+ }(Component);
139
+ _defineProperty(HeadRoot, "displayName", 'Head');
140
+ _defineProperty(HeadRoot, "style", style);
141
+ export var Head = createComponent(HeadRoot, {
142
+ Column: Column,
143
+ Group: Group
144
+ });
145
+ //# sourceMappingURL=Head.js.map