@semcore/data-table 16.0.0-prerelease.14 → 16.0.0-prerelease.16
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/CHANGELOG.md +6 -0
- package/lib/cjs/components/Body/Body.types.js.map +1 -1
- package/lib/cjs/components/DataTable/DataTable.js +5 -5
- package/lib/cjs/components/DataTable/DataTable.js.map +1 -1
- package/lib/cjs/components/DataTable/DataTable.types.js.map +1 -1
- package/lib/cjs/components/Head/Column.js.map +1 -1
- package/lib/cjs/components/Head/Column.types.js.map +1 -1
- package/lib/cjs/components/Head/Head.js.map +1 -1
- package/lib/cjs/components/Head/Head.types.js.map +1 -1
- package/lib/cjs/index.js +7 -19
- package/lib/cjs/index.js.map +1 -1
- package/lib/es6/components/Body/Body.types.js.map +1 -1
- package/lib/es6/components/DataTable/DataTable.js +2 -3
- package/lib/es6/components/DataTable/DataTable.js.map +1 -1
- package/lib/es6/components/DataTable/DataTable.types.js.map +1 -1
- package/lib/es6/components/Head/Column.js.map +1 -1
- package/lib/es6/components/Head/Column.types.js.map +1 -1
- package/lib/es6/components/Head/Head.js.map +1 -1
- package/lib/es6/components/Head/Head.types.js.map +1 -1
- package/lib/es6/index.js +5 -4
- package/lib/es6/index.js.map +1 -1
- package/lib/esm/components/DataTable/DataTable.mjs +3 -3
- package/lib/esm/index.mjs +5 -6
- package/lib/types/Body.d.ts +1 -1
- package/lib/types/DataTable.d.ts +3 -3
- package/lib/types/components/Body/Body.types.d.ts +1 -0
- package/lib/types/components/DataTable/DataTable.d.ts +3 -3
- package/lib/types/components/DataTable/DataTable.types.d.ts +7 -5
- package/lib/types/components/Head/Column.d.ts +4 -2
- package/lib/types/components/Head/Column.types.d.ts +4 -4
- package/lib/types/components/Head/Head.types.d.ts +8 -4
- package/lib/types/index.d.ts +10 -4
- package/package.json +7 -6
- package/lib/esm/Body.mjs +0 -428
- package/lib/esm/DataTable.mjs +0 -582
package/CHANGELOG.md
CHANGED
|
@@ -8,6 +8,12 @@ CHANGELOG.md standards are inspired by [keepachangelog.com](https://keepachangel
|
|
|
8
8
|
|
|
9
9
|
- Major version.
|
|
10
10
|
|
|
11
|
+
## [4.49.2] - 2025-04-04
|
|
12
|
+
|
|
13
|
+
### Changed
|
|
14
|
+
|
|
15
|
+
- Version patch update due to children dependencies update (`@semcore/utils` [4.48.1 ~> 4.48.2], `@semcore/core` [2.39.1 ~> 2.39.2]).
|
|
16
|
+
|
|
11
17
|
## [4.49.1] - 2025-03-20
|
|
12
18
|
|
|
13
19
|
### Changed
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Body.types.js","names":[],"sources":["../../../../src/components/Body/Body.types.ts"],"sourcesContent":["import { DTRow } from './Row.types';\nimport { DTColumn } from '../Head/Column.types';\nimport { DTUse } from '../DataTable/DataTable.types';\n\ntype CellRenderProps = {\n name: string;\n row: DTRow;\n column: DTColumn;\n rowIndex: number;\n columnIndex: number;\n value: string | number | boolean;\n defaultRender: () => React.ReactNode;\n};\n\nexport type DataTableBodyProps = {\n // rows: DTRow[];\n // columns: DTColumn[];\n\n renderCell?: (props: CellRenderProps) => React.ReactNode;\n\n expandedRows?: number[];\n};\n\nexport type BodyPropsInner = {\n rows: DTRow[];\n columns: DTColumn[];\n use: DTUse;\n scrollRef: (ref: HTMLDivElement) => void;\n headerRows: number;\n compact: boolean;\n gridTemplateColumns: string[];\n gridTemplateAreas: string[];\n loading?: boolean;\n headerHeight: number;\n getI18nText: (key: string) => string;\n};\n"],"mappings":""}
|
|
1
|
+
{"version":3,"file":"Body.types.js","names":[],"sources":["../../../../src/components/Body/Body.types.ts"],"sourcesContent":["import { DTRow } from './Row.types';\nimport { DTColumn } from '../Head/Column.types';\nimport { DTUse } from '../DataTable/DataTable.types';\n\ntype CellRenderProps = {\n name: string;\n row: DTRow;\n column: DTColumn;\n rowIndex: number;\n columnIndex: number;\n value: string | number | boolean;\n defaultRender: () => React.ReactNode;\n};\n\nexport type DataTableBodyProps = {\n // rows: DTRow[];\n // columns: DTColumn[];\n\n renderCell?: (props: CellRenderProps) => React.ReactNode;\n\n expandedRows?: number[];\n\n virtualScroll?: boolean;\n};\n\nexport type BodyPropsInner = {\n rows: DTRow[];\n columns: DTColumn[];\n use: DTUse;\n scrollRef: (ref: HTMLDivElement) => void;\n headerRows: number;\n compact: boolean;\n gridTemplateColumns: string[];\n gridTemplateAreas: string[];\n loading?: boolean;\n headerHeight: number;\n getI18nText: (key: string) => string;\n};\n"],"mappings":""}
|
|
@@ -5,7 +5,7 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
|
|
|
5
5
|
Object.defineProperty(exports, "__esModule", {
|
|
6
6
|
value: true
|
|
7
7
|
});
|
|
8
|
-
exports.DataTable = exports.ACCORDION = void 0;
|
|
8
|
+
exports.ROW_GROUP = exports.DataTable = exports.ACCORDION = void 0;
|
|
9
9
|
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
|
|
10
10
|
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
11
11
|
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
@@ -26,7 +26,6 @@ var _findComponent = _interopRequireDefault(require("@semcore/core/lib/utils/fin
|
|
|
26
26
|
var _intergalacticDynamicLocales = require("../../translations/__intergalactic-dynamic-locales");
|
|
27
27
|
var _i18nEnhance = _interopRequireDefault(require("@semcore/core/lib/utils/enhances/i18nEnhance"));
|
|
28
28
|
var _uniqueID = _interopRequireDefault(require("@semcore/core/lib/utils/uniqueID"));
|
|
29
|
-
var _index = require("../../index");
|
|
30
29
|
var _MergedCells = require("../Body/MergedCells");
|
|
31
30
|
var _ref8 = require("@semcore/core/lib/utils/ref");
|
|
32
31
|
/*__reshadow-styles__:"./dataTable.shadow.css"*/
|
|
@@ -45,6 +44,8 @@ var scrollStyles = ( /*__reshadow_css_start__*/_core.sstyled.insert( /*__inner_c
|
|
|
45
44
|
});
|
|
46
45
|
var ACCORDION = Symbol('accordion');
|
|
47
46
|
exports.ACCORDION = ACCORDION;
|
|
47
|
+
var ROW_GROUP = Symbol('ROW_GROUP');
|
|
48
|
+
exports.ROW_GROUP = ROW_GROUP;
|
|
48
49
|
var DataTableRoot = /*#__PURE__*/function (_Component) {
|
|
49
50
|
(0, _inherits2["default"])(DataTableRoot, _Component);
|
|
50
51
|
var _super = (0, _createSuper2["default"])(DataTableRoot);
|
|
@@ -326,8 +327,7 @@ var DataTableRoot = /*#__PURE__*/function (_Component) {
|
|
|
326
327
|
wMin = _this$asProps3.wMin,
|
|
327
328
|
h = _this$asProps3.h,
|
|
328
329
|
hMax = _this$asProps3.hMax,
|
|
329
|
-
hMin = _this$asProps3.hMin
|
|
330
|
-
loading = _this$asProps3.loading;
|
|
330
|
+
hMin = _this$asProps3.hMin;
|
|
331
331
|
var _getScrollOffsetValue = (0, _utils.getScrollOffsetValue)(this.columns),
|
|
332
332
|
_getScrollOffsetValue2 = (0, _slicedToArray2["default"])(_getScrollOffsetValue, 2),
|
|
333
333
|
offsetLeftSum = _getScrollOffsetValue2[0],
|
|
@@ -518,7 +518,7 @@ var DataTableRoot = /*#__PURE__*/function (_Component) {
|
|
|
518
518
|
rowIndex++;
|
|
519
519
|
};
|
|
520
520
|
data.forEach(function (row, rowIndex) {
|
|
521
|
-
var groupedRows = row[
|
|
521
|
+
var groupedRows = row[ROW_GROUP];
|
|
522
522
|
if (groupedRows) {
|
|
523
523
|
groupedRows.forEach(function (childRow, index) {
|
|
524
524
|
if (index === 0) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DataTable.js","names":["_core","require","React","_interopRequireWildcard","_baseComponents","_Head","_Body","_useFocusLock","_syncScroll","_interopRequireDefault","_utils","_findComponent","_intergalacticDynamicLocales","_i18nEnhance","_uniqueID","_index","_MergedCells","_ref8","style","sstyled","insert","scrollStyles","ACCORDION","Symbol","exports","DataTableRoot","_Component","_inherits2","_super","_createSuper2","props","_this","_classCallCheck2","call","_defineProperty2","_assertThisInitialized2","createRef","Map","index","_this$tableRef$curren","tableRef","current","querySelector","concat","hasFocusable","columns","some","column","columnElement","ref","hasFocusableIn","rowIndex","colIndex","direction","_this$tableRef$curren2","_this$tableRef$curren3","hasFocusableInHeader","maxCol","length","maxRow","totalRows","currentRow","focusedCell","headerCells","querySelectorAll","currentCell","currentHeaderCell","item","changed","newRow","newCol","row","getRow","cell","HTMLElement","setAttribute","removeAttribute","headerCell","describedBy","getAttribute","focus","rowI","colI","dataset","groupedBy","changeFocusCell","e","key","setInert","preventDefault","relatedTarget","isFocusInside","currentTarget","lastInteraction","isKeyboard","_row","initFocusableCell","tableElement","syncScroll","scrollBodyRef","scrollHeadRef","calculateColumns","_createClass2","value","componentDidMount","forceUpdate","get","asProps","calculateRows","gridTemplateColumns","map","c","gridColumnWidth","gridTemplateAreas","name","getHeadProps","_this$asProps","use","compact","sort","onSortChange","getI18nText","uid","_this$gridSettings","gridSettings","Boolean","headerRef","gridAreaGroupMap","getBodyProps","_header$children","_this$asProps2","loading","rows","_this$gridSettings2","header","headerHeight","Array","from","children","reduce","maxHeight","col","rect","getBoundingClientRect","height","scrollRef","headerRows","parent","_this$tableRef$curren4","cells","forEach","render","_ref","_ref2","SDataTable","Box","_this$asProps3","Children","styles","w","wMax","wMin","h","hMax","hMin","_getScrollOffsetValue","getScrollOffsetValue","_getScrollOffsetValue2","_slicedToArray2","offsetLeftSum","offsetRightSum","_this$gridSettings3","Head","findComponent","Body","width","undefined","createElement","ScrollArea","cn","tableContainerRef","Container","tabIndex","_objectSpread2","assignProps","forkRef","handleKeyDown","handleMouseMove","handleFocus","handleBlur","join","Bar","orientation","_this2","_this$props","data","HeadComponent","hasGroup","columnIndex","groupIndex","gridColumnIndex","calculateGridTemplateColumn","bind","makeColumn","isFirst","isLast","_columnElement$props$","_ref3","_columnElement$props$2","leftBordersFromParent","borders","rightBordersFromParent","node","calculatedWidth","calculatedHeight","fixed","flexWrap","alignItems","alignContent","justifyContent","child","i","isValidElement","type","Column","gridArea","push","Group","childCount","count","initGridColumn","j","d","set","filter","_this3","addToRows","dtRow","Object","entries","acc","_ref4","_ref5","columnsToRow","split","columnsSplitter","MergedColumnsCell","groupedRows","ROW_GROUP","childRow","rowData","_ref6","_ref7","MergedRowsCell","_c$props$gtcWidth","gtcWidth","defaultGridTemplateColumnWidth","Component","uniqueIDEnhancement","i18nEnhance","localizedMessages","DataTable","createComponent"],"sources":["../../../../src/components/DataTable/DataTable.tsx"],"sourcesContent":["import * as React from 'react';\nimport {\n Component,\n createComponent,\n Intergalactic,\n lastInteraction,\n Root,\n sstyled,\n} from '@semcore/core';\nimport { Box, ScrollArea } from '@semcore/base-components';\n\nimport { DataTableProps, ColIndex, RowIndex, DataTableData, DTKey } from './DataTable.types';\nimport { Head } from '../Head/Head';\nimport { Body } from '../Body/Body';\nimport { DataTableColumnProps, DTColumn } from '../Head/Column.types';\n\nimport style from './dataTable.shadow.css';\nimport { DTRow } from '../Body/Row.types';\nimport { isFocusInside, hasFocusableIn } from '@semcore/core/lib/utils/use/useFocusLock';\n\nimport { ReactElement } from 'react';\nimport syncScroll from '@semcore/core/lib/utils/syncScroll';\nimport { getScrollOffsetValue } from '../../utils';\nimport findComponent from '@semcore/core/lib/utils/findComponent';\nimport { DataTableHeadProps, HeadPropsInner } from '../Head/Head.types';\nimport { BodyPropsInner } from '../Body/Body.types';\nimport { localizedMessages } from '../../translations/__intergalactic-dynamic-locales';\nimport i18nEnhance from '@semcore/core/lib/utils/enhances/i18nEnhance';\nimport uniqueIDEnhancement from '@semcore/core/lib/utils/uniqueID';\nimport { ROW_GROUP } from '../../index';\nimport { MergedColumnsCell, MergedRowsCell } from '../Body/MergedCells';\nimport { forkRef } from '@semcore/core/lib/utils/ref';\nimport scrollStyles from '../../style/scroll-shadows.shadow.css';\n\nexport const ACCORDION = Symbol('accordion');\n\nclass DataTableRoot extends Component<\n DataTableProps,\n {},\n {},\n typeof DataTableRoot.enhance,\n { use: DTRow }\n> {\n static displayName = 'DataTable';\n static style = style;\n\n static enhance = [uniqueIDEnhancement(), i18nEnhance(localizedMessages)] as const;\n\n static defaultProps = {\n use: 'primary',\n defaultGridTemplateColumnWidth: 'auto',\n h: 'auto',\n };\n\n private columnsSplitter = '/';\n\n private columns: DTColumn[] = [];\n\n private focusedCell: [RowIndex, ColIndex] = [-1, -1];\n\n private tableContainerRef = React.createRef<HTMLDivElement>();\n private tableRef = React.createRef<HTMLDivElement>();\n private headerRef = React.createRef<HTMLDivElement>();\n private scrollBodyRef: ReturnType<ReturnType<typeof syncScroll>>;\n private scrollHeadRef: ReturnType<ReturnType<typeof syncScroll>>;\n\n private gridAreaGroupMap = new Map<number, string>();\n\n constructor(props: DataTableProps) {\n super(props);\n\n const createRef = syncScroll();\n // first create body ref for master scroll\n this.scrollBodyRef = createRef('body');\n this.scrollHeadRef = createRef('head');\n\n this.columns = this.calculateColumns();\n }\n\n componentDidMount() {\n this.forceUpdate();\n }\n\n get totalRows() {\n const { totalRows } = this.asProps;\n\n return totalRows ?? this.calculateRows().length;\n }\n\n get gridSettings() {\n const gridTemplateColumns = this.columns.map((c) => c.gridColumnWidth);\n const gridTemplateAreas = this.columns.map((c) => c.name);\n\n return {\n gridTemplateColumns,\n gridTemplateAreas,\n };\n }\n\n getHeadProps(): HeadPropsInner {\n const { use, compact, sort, onSortChange, getI18nText, uid } = this.asProps;\n const { gridTemplateColumns, gridTemplateAreas } = this.gridSettings;\n\n return {\n columns: this.columns,\n use,\n tableRef: this.tableRef,\n compact: Boolean(compact),\n sort,\n onSortChange,\n getI18nText,\n uid,\n ref: this.headerRef,\n gridAreaGroupMap: this.gridAreaGroupMap,\n gridTemplateColumns,\n gridTemplateAreas,\n };\n }\n\n getBodyProps(): BodyPropsInner {\n const { use, compact, loading, getI18nText } = this.asProps;\n const rows = this.calculateRows();\n\n const { gridTemplateColumns, gridTemplateAreas } = this.gridSettings;\n const header = this.headerRef.current;\n const headerHeight = Array.from(header?.children ?? []).reduce((maxHeight, col) => {\n const rect = col.getBoundingClientRect();\n if (rect.height > maxHeight) {\n maxHeight = rect.height;\n }\n\n return maxHeight;\n }, 0);\n\n return {\n columns: this.columns,\n rows,\n use,\n scrollRef: this.scrollBodyRef,\n headerRows: this.columns.some((column) => Boolean(column.parent)) ? 2 : 1,\n compact: Boolean(compact),\n gridTemplateColumns,\n gridTemplateAreas,\n loading,\n headerHeight,\n getI18nText,\n };\n }\n\n setInert(value: boolean) {\n const cells = this.tableRef.current?.querySelectorAll<HTMLDivElement>(\n '[role=gridcell], [role=columnheader]',\n );\n\n cells?.forEach((cell) => {\n if (value === true) {\n cell.setAttribute('inert', '');\n } else {\n cell.removeAttribute('inert');\n }\n });\n }\n\n getRow = (index: number) => {\n return this.tableRef.current?.querySelector(`[aria-rowindex=\"${index + 1}\"]`);\n };\n\n hasFocusableInHeader = () => {\n const hasFocusable = this.columns.some((column) => {\n const columnElement = column.ref.current;\n\n return columnElement && hasFocusableIn(columnElement);\n });\n\n return hasFocusable;\n };\n\n changeFocusCell = (\n rowIndex: RowIndex,\n colIndex: ColIndex,\n direction?: 'up' | 'down' | 'left' | 'right',\n ) => {\n const hasFocusable = this.hasFocusableInHeader();\n\n const maxCol = this.columns.length - 1;\n const maxRow = this.totalRows;\n\n const currentRow = this.tableRef.current?.querySelector(\n `[aria-rowindex=\"${this.focusedCell[0] + 1}\"]`,\n );\n\n const headerCells = this.tableRef.current?.querySelectorAll('[role=columnheader]');\n const currentCell = currentRow?.querySelector(\n `[role=gridcell][aria-colindex='${this.focusedCell[1] + 1}']`,\n );\n const currentHeaderCell = headerCells?.item(this.focusedCell[1]);\n\n let changed = true;\n const newRow = this.focusedCell[0] + rowIndex;\n const newCol = this.focusedCell[1] + colIndex;\n\n if (\n ((hasFocusable && newRow < 0) || (!hasFocusable && newRow < 1) || newRow > maxRow) &&\n newRow !== this.focusedCell[0]\n ) {\n changed = false;\n }\n if ((newCol < 0 || newCol > maxCol) && newCol !== this.focusedCell[1]) {\n changed = false;\n }\n\n if (!changed) return;\n\n const row = this.getRow(newRow);\n const cell = row?.querySelector(\n `[role=gridcell][aria-colindex=\"${newCol + 1}\"], [role=columnheader][aria-colindex=\"${\n newCol + 1\n }\"]`,\n );\n\n if (cell instanceof HTMLElement && currentCell !== cell) {\n this.focusedCell = [newRow, newCol];\n\n currentCell?.setAttribute('inert', '');\n\n if (currentCell !== currentHeaderCell) {\n currentCell?.removeAttribute('aria-describedby');\n }\n\n const headerCell = headerCells?.item(newCol);\n const describedBy = headerCell?.getAttribute('aria-describedby');\n\n cell.removeAttribute('inert');\n if (headerCell !== cell && describedBy) {\n cell.setAttribute('aria-describedby', describedBy);\n }\n\n cell?.focus();\n\n if (newRow !== 0) {\n currentHeaderCell?.setAttribute('inert', '');\n const headerCell = headerCells?.item(newCol);\n\n headerCell?.removeAttribute('inert');\n }\n } else if (cell === null && currentCell instanceof HTMLElement) {\n let rowI = rowIndex;\n let colI = colIndex;\n\n if (direction === 'left' || direction === 'right') {\n // left/right\n if (currentCell.dataset.groupedBy === 'columns') {\n colI = direction === 'left' ? colI - 1 : colI + 1;\n } else {\n rowI = rowI - 1;\n }\n } else if (direction === 'up' || direction === 'down') {\n // top/bottom\n if (currentCell.dataset.groupedBy === 'rows') {\n rowI = direction === 'up' ? rowI - 1 : rowI + 1;\n } else {\n colI = colI - 1;\n }\n }\n this.changeFocusCell(rowI, colI, direction);\n }\n };\n\n handleKeyDown = (e: React.KeyboardEvent) => {\n switch (e.key) {\n case 'Tab': {\n this.setInert(true);\n break;\n }\n case 'ArrowLeft': {\n e.preventDefault();\n this.changeFocusCell(0, -1, 'left');\n break;\n }\n case 'ArrowRight': {\n e.preventDefault();\n this.changeFocusCell(0, 1, 'right');\n break;\n }\n case 'ArrowUp': {\n e.preventDefault();\n this.changeFocusCell(-1, 0, 'up');\n break;\n }\n case 'ArrowDown': {\n e.preventDefault();\n this.changeFocusCell(1, 0, 'down');\n break;\n }\n }\n };\n\n initFocusableCell = () => {\n const hasFocusable = this.hasFocusableInHeader();\n\n if (hasFocusable) {\n this.focusedCell = [0, 0];\n } else {\n this.focusedCell = [1, 0];\n }\n };\n\n handleFocus = (e: React.FocusEvent<HTMLElement, HTMLElement>) => {\n if (\n (!e.relatedTarget || !isFocusInside(e.currentTarget, e.relatedTarget)) &&\n lastInteraction.isKeyboard()\n ) {\n if (this.focusedCell[0] === -1 && this.focusedCell[1] === -1) {\n this.initFocusableCell();\n }\n\n this.setInert(true);\n\n let row = this.getRow(this.focusedCell[0]);\n\n if (!row) {\n this.initFocusableCell();\n row = this.getRow(this.focusedCell[0]);\n }\n\n const cell = row\n ?.querySelectorAll('[role=gridcell], [role=columnheader]')\n .item(this.focusedCell[1]);\n\n cell?.removeAttribute('inert');\n cell instanceof HTMLElement && cell.focus();\n\n e.currentTarget.setAttribute('tabIndex', '-1');\n }\n };\n\n handleBlur = (e: React.FocusEvent<HTMLElement, HTMLElement>) => {\n const relatedTarget = e.relatedTarget;\n const tableElement = this.tableRef.current;\n\n if (\n tableElement &&\n (!relatedTarget ||\n !isFocusInside(tableElement, relatedTarget) ||\n !lastInteraction.isKeyboard())\n ) {\n this.setInert(false);\n tableElement.setAttribute('tabIndex', '0');\n }\n };\n\n handleMouseMove = () => {\n this.setInert(false);\n };\n\n render() {\n const SDataTable = Root;\n const { Children, styles, w, wMax, wMin, h, hMax, hMin, loading } = this.asProps;\n\n const [offsetLeftSum, offsetRightSum] = getScrollOffsetValue(this.columns);\n const { gridTemplateColumns, gridTemplateAreas } = this.gridSettings;\n\n const Head = findComponent(Children, ['DataTable.Head']);\n const Body = findComponent(Children, ['DataTable.Body']);\n\n const width =\n w ??\n (this.columns.some((c) => c.gridColumnWidth === 'auto' || c.gridColumnWidth === '1fr')\n ? '100%'\n : undefined);\n\n return sstyled(styles)(\n <ScrollArea\n leftOffset={offsetLeftSum}\n rightOffset={offsetRightSum}\n w={width}\n wMax={wMax}\n wMin={wMin}\n h={h}\n hMax={hMax}\n hMin={hMin}\n shadow={true}\n container={this.tableContainerRef}\n styles={scrollStyles}\n >\n <ScrollArea.Container tabIndex={-1}>\n <SDataTable\n render={Box}\n ref={forkRef(this.tableRef, this.tableContainerRef)}\n role='grid'\n onKeyDown={this.handleKeyDown}\n onMouseMove={this.handleMouseMove}\n tabIndex={0}\n onFocus={this.handleFocus}\n onBlur={this.handleBlur}\n aria-rowcount={this.totalRows}\n aria-colcount={this.columns.length}\n gridTemplateColumns={gridTemplateColumns.join(' ')}\n gridTemplateAreas={gridTemplateAreas.join(' ')}\n w={'100%'}\n use:data={undefined}\n use:w={undefined}\n use:wMax={undefined}\n use:wMin={undefined}\n use:h={undefined}\n use:hMax={undefined}\n use:hMin={undefined}\n >\n {Body}\n {Head}\n </SDataTable>\n </ScrollArea.Container>\n\n <ScrollArea.Bar orientation='horizontal' />\n <ScrollArea.Bar orientation='vertical' />\n </ScrollArea>,\n );\n }\n\n private calculateColumns(): DTColumn[] {\n const { children, data } = this.props;\n const HeadComponent = findComponent(children, ['Head']) as ReactElement<DataTableHeadProps> & {\n props: { children: Array<ReactElement<DataTableColumnProps>> };\n };\n\n const hasGroup = findComponent(HeadComponent.props.children, ['Head.Group']) !== undefined;\n\n let columnIndex = 0;\n let groupIndex = 0;\n let gridColumnIndex = 1;\n\n const calculateGridTemplateColumn = this.calculateGridTemplateColumn.bind(this);\n\n const columns: DTColumn[] = [];\n\n const makeColumn = (\n columnElement: ReactElement<DataTableColumnProps>,\n parent?: any,\n isFirst?: boolean,\n isLast?: boolean,\n ): DTColumn => {\n const leftBordersFromParent =\n isFirst && (parent?.props.borders === 'both' || parent?.props.borders === 'left')\n ? 'left'\n : undefined;\n const rightBordersFromParent =\n isLast && (parent?.props.borders === 'both' || parent?.props.borders === 'right')\n ? 'right'\n : undefined;\n\n const column: DTColumn = {\n name: columnElement.props.name,\n // @ts-ignore\n ref: function (node: HTMLElement | null) {\n if (node) {\n const calculatedWidth = node.getBoundingClientRect().width;\n const calculatedHeight = node.getBoundingClientRect().height;\n column.calculatedWidth = calculatedWidth;\n column.calculatedHeight = calculatedHeight;\n }\n\n this.ref.current = node;\n },\n gridColumnWidth: calculateGridTemplateColumn(columnElement),\n fixed: columnElement.props.fixed ?? parent?.props.fixed,\n calculatedWidth: 0,\n calculatedHeight: 0,\n borders: columnElement.props.borders ?? leftBordersFromParent ?? rightBordersFromParent,\n parent,\n\n flexWrap: columnElement.props.flexWrap,\n alignItems: columnElement.props.alignItems,\n alignContent: columnElement.props.alignContent,\n justifyContent: columnElement.props.justifyContent,\n };\n\n // this.gridAreaColumnMap.set(\n // columnIndex,\n // `1 / ${gridColumnIndex} / ${hasGroup ? '3' : '2'} / ${gridColumnIndex + 1}`,\n // );\n // columnIndex++;\n // gridColumnIndex++;\n\n return column;\n // columns.push(column);\n };\n\n React.Children.forEach(HeadComponent.props.children, (child, i) => {\n if (!React.isValidElement(child)) return;\n\n if (child.type === Head.Column) {\n const col = makeColumn(child);\n\n col.gridArea = `1 / ${gridColumnIndex} / ${hasGroup ? '3' : '2'} / ${gridColumnIndex + 1}`;\n\n columnIndex++;\n gridColumnIndex++;\n\n columns.push(col);\n } else if (child.type === Head.Group) {\n const Group = child;\n const childCount = React.Children.count(child.props.children);\n\n const initGridColumn = gridColumnIndex;\n\n React.Children.forEach(child.props.children, (child, j) => {\n if (child?.type === Head.Column) {\n const isFirst = j === 0;\n const isLast = j === childCount - 1;\n const col = makeColumn(child, Group, isFirst, isLast);\n\n if (i === 0 && j === 0 && data.some((d) => d[ACCORDION])) {\n gridColumnIndex++;\n col.gridArea = `2 / ${gridColumnIndex - 1} / 3 / ${gridColumnIndex + 1}`;\n } else {\n col.gridArea = `2 / ${gridColumnIndex} / 3 / ${gridColumnIndex + 1}`;\n }\n\n col.gridArea = `2 / ${gridColumnIndex} / 3 / ${gridColumnIndex + 1}`;\n columnIndex++;\n gridColumnIndex++;\n\n columns.push(col);\n }\n });\n\n this.gridAreaGroupMap.set(groupIndex, `1 / ${initGridColumn} / 2 / ${gridColumnIndex}`);\n groupIndex++;\n }\n });\n\n return columns.filter(Boolean);\n\n // return Columns.map((c) => {\n // const column = {\n // name: c.props.name,\n // ref: (node: HTMLElement | null) => {\n // if (node) {\n // const calculatedWidth = node.getBoundingClientRect().width;\n // column.calculatedWidth = calculatedWidth;\n // }\n //\n // return { current: node };\n // },\n // gridColumnWidth: calculateGridTemplateColumn(c),\n // fixed: c.props.fixed,\n // calculatedWidth: 0,\n // };\n //\n // return column;\n // });\n\n // return columns;\n }\n\n private calculateRows(): DTRow[] {\n const { data } = this.asProps;\n\n const rows: DTRow[] = [];\n\n let rowIndex = 0;\n\n const addToRows = (row: Record<DTKey, any>) => {\n const dtRow = Object.entries(row).reduce<DTRow>((acc, [key, value]) => {\n const columnsToRow = key.split(this.columnsSplitter);\n\n if (columnsToRow.length === 1) {\n acc[key] = value;\n } else {\n acc[columnsToRow[0]] = new MergedColumnsCell(value, columnsToRow.length);\n }\n\n if (row[ACCORDION]) {\n acc[ACCORDION] = row[ACCORDION];\n }\n\n return acc;\n }, {});\n\n rows.push(dtRow);\n rowIndex++;\n };\n\n data.forEach((row, rowIndex) => {\n const groupedRows: DataTableData | undefined = row[ROW_GROUP];\n\n if (groupedRows) {\n groupedRows.forEach((childRow, index) => {\n if (index === 0) {\n const rowData = {\n ...childRow,\n ...Object.entries(row).reduce<DTRow>((acc, [key, value]) => {\n acc[key] = new MergedRowsCell(value, groupedRows.length);\n return acc;\n }, {}),\n };\n\n addToRows(rowData);\n } else {\n addToRows(childRow);\n }\n });\n } else {\n addToRows(row);\n }\n });\n\n return rows;\n }\n\n private calculateGridTemplateColumn(c: ReactElement<DataTableColumnProps>): string {\n return c.props.gtcWidth ?? (this.props.defaultGridTemplateColumnWidth as string);\n }\n}\n\nexport const DataTable = createComponent(DataTableRoot, {\n Head,\n Body,\n}) as Intergalactic.Component<'div', DataTableProps> & {\n Head: typeof Head;\n Body: typeof Body;\n};\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"DataTable.js","names":["_core","require","React","_interopRequireWildcard","_baseComponents","_Head","_Body","_useFocusLock","_syncScroll","_interopRequireDefault","_utils","_findComponent","_intergalacticDynamicLocales","_i18nEnhance","_uniqueID","_MergedCells","_ref8","style","sstyled","insert","scrollStyles","ACCORDION","Symbol","exports","ROW_GROUP","DataTableRoot","_Component","_inherits2","_super","_createSuper2","props","_this","_classCallCheck2","call","_defineProperty2","_assertThisInitialized2","createRef","Map","index","_this$tableRef$curren","tableRef","current","querySelector","concat","hasFocusable","columns","some","column","columnElement","ref","hasFocusableIn","rowIndex","colIndex","direction","_this$tableRef$curren2","_this$tableRef$curren3","hasFocusableInHeader","maxCol","length","maxRow","totalRows","currentRow","focusedCell","headerCells","querySelectorAll","currentCell","currentHeaderCell","item","changed","newRow","newCol","row","getRow","cell","HTMLElement","setAttribute","removeAttribute","headerCell","describedBy","getAttribute","focus","rowI","colI","dataset","groupedBy","changeFocusCell","e","key","setInert","preventDefault","relatedTarget","isFocusInside","currentTarget","lastInteraction","isKeyboard","_row","initFocusableCell","tableElement","syncScroll","scrollBodyRef","scrollHeadRef","calculateColumns","_createClass2","value","componentDidMount","forceUpdate","get","asProps","calculateRows","gridTemplateColumns","map","c","gridColumnWidth","gridTemplateAreas","name","getHeadProps","_this$asProps","use","compact","sort","onSortChange","getI18nText","uid","_this$gridSettings","gridSettings","Boolean","headerRef","gridAreaGroupMap","getBodyProps","_header$children","_this$asProps2","loading","rows","_this$gridSettings2","header","headerHeight","Array","from","children","reduce","maxHeight","col","rect","getBoundingClientRect","height","scrollRef","headerRows","parent","_this$tableRef$curren4","cells","forEach","render","_ref","_ref2","SDataTable","Box","_this$asProps3","Children","styles","w","wMax","wMin","h","hMax","hMin","_getScrollOffsetValue","getScrollOffsetValue","_getScrollOffsetValue2","_slicedToArray2","offsetLeftSum","offsetRightSum","_this$gridSettings3","Head","findComponent","Body","width","undefined","createElement","ScrollArea","cn","tableContainerRef","Container","tabIndex","_objectSpread2","assignProps","forkRef","handleKeyDown","handleMouseMove","handleFocus","handleBlur","join","Bar","orientation","_this2","_this$props","data","HeadComponent","hasGroup","columnIndex","groupIndex","gridColumnIndex","calculateGridTemplateColumn","bind","makeColumn","isFirst","isLast","_columnElement$props$","_ref3","_columnElement$props$2","leftBordersFromParent","borders","rightBordersFromParent","node","calculatedWidth","calculatedHeight","fixed","flexWrap","alignItems","alignContent","justifyContent","child","i","isValidElement","type","Column","gridArea","push","Group","childCount","count","initGridColumn","j","d","set","filter","_this3","addToRows","dtRow","Object","entries","acc","_ref4","_ref5","columnsToRow","split","columnsSplitter","MergedColumnsCell","groupedRows","childRow","rowData","_ref6","_ref7","MergedRowsCell","_c$props$gtcWidth","gtcWidth","defaultGridTemplateColumnWidth","Component","uniqueIDEnhancement","i18nEnhance","localizedMessages","DataTable","createComponent"],"sources":["../../../../src/components/DataTable/DataTable.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Component, createComponent, lastInteraction, Root, sstyled } from '@semcore/core';\nimport { Box, ScrollArea } from '@semcore/base-components';\n\nimport {\n DataTableProps,\n ColIndex,\n RowIndex,\n DataTableData,\n DTKey,\n DataTableType,\n} from './DataTable.types';\nimport { Head } from '../Head/Head';\nimport { Body } from '../Body/Body';\nimport { DataTableColumnProps, DTColumn } from '../Head/Column.types';\n\nimport style from './dataTable.shadow.css';\nimport { DTRow } from '../Body/Row.types';\nimport { isFocusInside, hasFocusableIn } from '@semcore/core/lib/utils/use/useFocusLock';\n\nimport { ReactElement } from 'react';\nimport syncScroll from '@semcore/core/lib/utils/syncScroll';\nimport { getScrollOffsetValue } from '../../utils';\nimport findComponent from '@semcore/core/lib/utils/findComponent';\nimport { DataTableHeadProps, HeadPropsInner } from '../Head/Head.types';\nimport { BodyPropsInner } from '../Body/Body.types';\nimport { localizedMessages } from '../../translations/__intergalactic-dynamic-locales';\nimport i18nEnhance from '@semcore/core/lib/utils/enhances/i18nEnhance';\nimport uniqueIDEnhancement from '@semcore/core/lib/utils/uniqueID';\nimport { MergedColumnsCell, MergedRowsCell } from '../Body/MergedCells';\nimport { forkRef } from '@semcore/core/lib/utils/ref';\nimport scrollStyles from '../../style/scroll-shadows.shadow.css';\n\nexport const ACCORDION = Symbol('accordion');\nexport const ROW_GROUP = Symbol('ROW_GROUP');\n\nclass DataTableRoot<D extends DataTableData> extends Component<\n DataTableProps<D>,\n {},\n {},\n typeof DataTableRoot.enhance,\n { use: DTRow }\n> {\n static displayName = 'DataTable';\n static style = style;\n\n static enhance = [uniqueIDEnhancement(), i18nEnhance(localizedMessages)] as const;\n\n static defaultProps = {\n use: 'primary',\n defaultGridTemplateColumnWidth: 'auto',\n h: 'auto',\n };\n\n private columnsSplitter = '/';\n\n private columns: DTColumn[] = [];\n\n private focusedCell: [RowIndex, ColIndex] = [-1, -1];\n\n private tableContainerRef = React.createRef<HTMLDivElement>();\n private tableRef = React.createRef<HTMLDivElement>();\n private headerRef = React.createRef<HTMLDivElement>();\n private scrollBodyRef: ReturnType<ReturnType<typeof syncScroll>>;\n private scrollHeadRef: ReturnType<ReturnType<typeof syncScroll>>;\n\n private gridAreaGroupMap = new Map<number, string>();\n\n constructor(props: DataTableProps<D>) {\n super(props);\n\n const createRef = syncScroll();\n // first create body ref for master scroll\n this.scrollBodyRef = createRef('body');\n this.scrollHeadRef = createRef('head');\n\n this.columns = this.calculateColumns();\n }\n\n componentDidMount() {\n this.forceUpdate();\n }\n\n get totalRows() {\n const { totalRows } = this.asProps;\n\n return totalRows ?? this.calculateRows().length;\n }\n\n get gridSettings() {\n const gridTemplateColumns = this.columns.map((c) => c.gridColumnWidth);\n const gridTemplateAreas = this.columns.map((c) => c.name);\n\n return {\n gridTemplateColumns,\n gridTemplateAreas,\n };\n }\n\n getHeadProps(): HeadPropsInner<D> {\n const { use, compact, sort, onSortChange, getI18nText, uid } = this.asProps;\n const { gridTemplateColumns, gridTemplateAreas } = this.gridSettings;\n\n return {\n columns: this.columns,\n use,\n tableRef: this.tableRef,\n compact: Boolean(compact),\n sort,\n onSortChange,\n getI18nText,\n uid,\n ref: this.headerRef,\n gridAreaGroupMap: this.gridAreaGroupMap,\n gridTemplateColumns,\n gridTemplateAreas,\n };\n }\n\n getBodyProps(): BodyPropsInner {\n const { use, compact, loading, getI18nText } = this.asProps;\n const rows = this.calculateRows();\n\n const { gridTemplateColumns, gridTemplateAreas } = this.gridSettings;\n const header = this.headerRef.current;\n const headerHeight = Array.from(header?.children ?? []).reduce((maxHeight, col) => {\n const rect = col.getBoundingClientRect();\n if (rect.height > maxHeight) {\n maxHeight = rect.height;\n }\n\n return maxHeight;\n }, 0);\n\n return {\n columns: this.columns,\n rows,\n use,\n scrollRef: this.scrollBodyRef,\n headerRows: this.columns.some((column) => Boolean(column.parent)) ? 2 : 1,\n compact: Boolean(compact),\n gridTemplateColumns,\n gridTemplateAreas,\n loading,\n headerHeight,\n getI18nText,\n };\n }\n\n setInert(value: boolean) {\n const cells = this.tableRef.current?.querySelectorAll<HTMLDivElement>(\n '[role=gridcell], [role=columnheader]',\n );\n\n cells?.forEach((cell) => {\n if (value === true) {\n cell.setAttribute('inert', '');\n } else {\n cell.removeAttribute('inert');\n }\n });\n }\n\n getRow = (index: number) => {\n return this.tableRef.current?.querySelector(`[aria-rowindex=\"${index + 1}\"]`);\n };\n\n hasFocusableInHeader = () => {\n const hasFocusable = this.columns.some((column) => {\n const columnElement = column.ref.current;\n\n return columnElement && hasFocusableIn(columnElement);\n });\n\n return hasFocusable;\n };\n\n changeFocusCell = (\n rowIndex: RowIndex,\n colIndex: ColIndex,\n direction?: 'up' | 'down' | 'left' | 'right',\n ) => {\n const hasFocusable = this.hasFocusableInHeader();\n\n const maxCol = this.columns.length - 1;\n const maxRow = this.totalRows;\n\n const currentRow = this.tableRef.current?.querySelector(\n `[aria-rowindex=\"${this.focusedCell[0] + 1}\"]`,\n );\n\n const headerCells = this.tableRef.current?.querySelectorAll('[role=columnheader]');\n const currentCell = currentRow?.querySelector(\n `[role=gridcell][aria-colindex='${this.focusedCell[1] + 1}']`,\n );\n const currentHeaderCell = headerCells?.item(this.focusedCell[1]);\n\n let changed = true;\n const newRow = this.focusedCell[0] + rowIndex;\n const newCol = this.focusedCell[1] + colIndex;\n\n if (\n ((hasFocusable && newRow < 0) || (!hasFocusable && newRow < 1) || newRow > maxRow) &&\n newRow !== this.focusedCell[0]\n ) {\n changed = false;\n }\n if ((newCol < 0 || newCol > maxCol) && newCol !== this.focusedCell[1]) {\n changed = false;\n }\n\n if (!changed) return;\n\n const row = this.getRow(newRow);\n const cell = row?.querySelector(\n `[role=gridcell][aria-colindex=\"${newCol + 1}\"], [role=columnheader][aria-colindex=\"${\n newCol + 1\n }\"]`,\n );\n\n if (cell instanceof HTMLElement && currentCell !== cell) {\n this.focusedCell = [newRow, newCol];\n\n currentCell?.setAttribute('inert', '');\n\n if (currentCell !== currentHeaderCell) {\n currentCell?.removeAttribute('aria-describedby');\n }\n\n const headerCell = headerCells?.item(newCol);\n const describedBy = headerCell?.getAttribute('aria-describedby');\n\n cell.removeAttribute('inert');\n if (headerCell !== cell && describedBy) {\n cell.setAttribute('aria-describedby', describedBy);\n }\n\n cell?.focus();\n\n if (newRow !== 0) {\n currentHeaderCell?.setAttribute('inert', '');\n const headerCell = headerCells?.item(newCol);\n\n headerCell?.removeAttribute('inert');\n }\n } else if (cell === null && currentCell instanceof HTMLElement) {\n let rowI = rowIndex;\n let colI = colIndex;\n\n if (direction === 'left' || direction === 'right') {\n // left/right\n if (currentCell.dataset.groupedBy === 'columns') {\n colI = direction === 'left' ? colI - 1 : colI + 1;\n } else {\n rowI = rowI - 1;\n }\n } else if (direction === 'up' || direction === 'down') {\n // top/bottom\n if (currentCell.dataset.groupedBy === 'rows') {\n rowI = direction === 'up' ? rowI - 1 : rowI + 1;\n } else {\n colI = colI - 1;\n }\n }\n this.changeFocusCell(rowI, colI, direction);\n }\n };\n\n handleKeyDown = (e: React.KeyboardEvent) => {\n switch (e.key) {\n case 'Tab': {\n this.setInert(true);\n break;\n }\n case 'ArrowLeft': {\n e.preventDefault();\n this.changeFocusCell(0, -1, 'left');\n break;\n }\n case 'ArrowRight': {\n e.preventDefault();\n this.changeFocusCell(0, 1, 'right');\n break;\n }\n case 'ArrowUp': {\n e.preventDefault();\n this.changeFocusCell(-1, 0, 'up');\n break;\n }\n case 'ArrowDown': {\n e.preventDefault();\n this.changeFocusCell(1, 0, 'down');\n break;\n }\n }\n };\n\n initFocusableCell = () => {\n const hasFocusable = this.hasFocusableInHeader();\n\n if (hasFocusable) {\n this.focusedCell = [0, 0];\n } else {\n this.focusedCell = [1, 0];\n }\n };\n\n handleFocus = (e: React.FocusEvent<HTMLElement, HTMLElement>) => {\n if (\n (!e.relatedTarget || !isFocusInside(e.currentTarget, e.relatedTarget)) &&\n lastInteraction.isKeyboard()\n ) {\n if (this.focusedCell[0] === -1 && this.focusedCell[1] === -1) {\n this.initFocusableCell();\n }\n\n this.setInert(true);\n\n let row = this.getRow(this.focusedCell[0]);\n\n if (!row) {\n this.initFocusableCell();\n row = this.getRow(this.focusedCell[0]);\n }\n\n const cell = row\n ?.querySelectorAll('[role=gridcell], [role=columnheader]')\n .item(this.focusedCell[1]);\n\n cell?.removeAttribute('inert');\n cell instanceof HTMLElement && cell.focus();\n\n e.currentTarget.setAttribute('tabIndex', '-1');\n }\n };\n\n handleBlur = (e: React.FocusEvent<HTMLElement, HTMLElement>) => {\n const relatedTarget = e.relatedTarget;\n const tableElement = this.tableRef.current;\n\n if (\n tableElement &&\n (!relatedTarget ||\n !isFocusInside(tableElement, relatedTarget) ||\n !lastInteraction.isKeyboard())\n ) {\n this.setInert(false);\n tableElement.setAttribute('tabIndex', '0');\n }\n };\n\n handleMouseMove = () => {\n this.setInert(false);\n };\n\n render() {\n const SDataTable = Root;\n const { Children, styles, w, wMax, wMin, h, hMax, hMin } = this.asProps;\n\n const [offsetLeftSum, offsetRightSum] = getScrollOffsetValue(this.columns);\n const { gridTemplateColumns, gridTemplateAreas } = this.gridSettings;\n\n const Head = findComponent(Children, ['DataTable.Head']);\n const Body = findComponent(Children, ['DataTable.Body']);\n\n const width =\n w ??\n (this.columns.some((c) => c.gridColumnWidth === 'auto' || c.gridColumnWidth === '1fr')\n ? '100%'\n : undefined);\n\n return sstyled(styles)(\n <ScrollArea\n leftOffset={offsetLeftSum}\n rightOffset={offsetRightSum}\n w={width}\n wMax={wMax}\n wMin={wMin}\n h={h}\n hMax={hMax}\n hMin={hMin}\n shadow={true}\n container={this.tableContainerRef}\n styles={scrollStyles}\n >\n <ScrollArea.Container tabIndex={-1}>\n <SDataTable\n render={Box}\n ref={forkRef(this.tableRef, this.tableContainerRef)}\n role='grid'\n onKeyDown={this.handleKeyDown}\n onMouseMove={this.handleMouseMove}\n tabIndex={0}\n onFocus={this.handleFocus}\n onBlur={this.handleBlur}\n aria-rowcount={this.totalRows}\n aria-colcount={this.columns.length}\n gridTemplateColumns={gridTemplateColumns.join(' ')}\n gridTemplateAreas={gridTemplateAreas.join(' ')}\n w={'100%'}\n use:data={undefined}\n use:w={undefined}\n use:wMax={undefined}\n use:wMin={undefined}\n use:h={undefined}\n use:hMax={undefined}\n use:hMin={undefined}\n >\n {Body}\n {Head}\n </SDataTable>\n </ScrollArea.Container>\n\n <ScrollArea.Bar orientation='horizontal' />\n <ScrollArea.Bar orientation='vertical' />\n </ScrollArea>,\n );\n }\n\n private calculateColumns(): DTColumn[] {\n const { children, data } = this.props;\n const HeadComponent = findComponent(children, ['Head']) as ReactElement<DataTableHeadProps> & {\n props: { children: Array<ReactElement<DataTableColumnProps>> };\n };\n\n const hasGroup = findComponent(HeadComponent.props.children, ['Head.Group']) !== undefined;\n\n let columnIndex = 0;\n let groupIndex = 0;\n let gridColumnIndex = 1;\n\n const calculateGridTemplateColumn = this.calculateGridTemplateColumn.bind(this);\n\n const columns: DTColumn[] = [];\n\n const makeColumn = (\n columnElement: ReactElement<DataTableColumnProps>,\n parent?: any,\n isFirst?: boolean,\n isLast?: boolean,\n ): DTColumn => {\n const leftBordersFromParent =\n isFirst && (parent?.props.borders === 'both' || parent?.props.borders === 'left')\n ? 'left'\n : undefined;\n const rightBordersFromParent =\n isLast && (parent?.props.borders === 'both' || parent?.props.borders === 'right')\n ? 'right'\n : undefined;\n\n const column: DTColumn = {\n name: columnElement.props.name,\n // @ts-ignore\n ref: function (node: HTMLElement | null) {\n if (node) {\n const calculatedWidth = node.getBoundingClientRect().width;\n const calculatedHeight = node.getBoundingClientRect().height;\n column.calculatedWidth = calculatedWidth;\n column.calculatedHeight = calculatedHeight;\n }\n\n this.ref.current = node;\n },\n gridColumnWidth: calculateGridTemplateColumn(columnElement),\n fixed: columnElement.props.fixed ?? parent?.props.fixed,\n calculatedWidth: 0,\n calculatedHeight: 0,\n borders: columnElement.props.borders ?? leftBordersFromParent ?? rightBordersFromParent,\n parent,\n\n flexWrap: columnElement.props.flexWrap,\n alignItems: columnElement.props.alignItems,\n alignContent: columnElement.props.alignContent,\n justifyContent: columnElement.props.justifyContent,\n };\n\n // this.gridAreaColumnMap.set(\n // columnIndex,\n // `1 / ${gridColumnIndex} / ${hasGroup ? '3' : '2'} / ${gridColumnIndex + 1}`,\n // );\n // columnIndex++;\n // gridColumnIndex++;\n\n return column;\n // columns.push(column);\n };\n\n React.Children.forEach(HeadComponent.props.children, (child, i) => {\n if (!React.isValidElement(child)) return;\n\n if (child.type === Head.Column) {\n const col = makeColumn(child);\n\n col.gridArea = `1 / ${gridColumnIndex} / ${hasGroup ? '3' : '2'} / ${gridColumnIndex + 1}`;\n\n columnIndex++;\n gridColumnIndex++;\n\n columns.push(col);\n } else if (child.type === Head.Group) {\n const Group = child;\n const childCount = React.Children.count(child.props.children);\n\n const initGridColumn = gridColumnIndex;\n\n React.Children.forEach(child.props.children, (child, j) => {\n if (child?.type === Head.Column) {\n const isFirst = j === 0;\n const isLast = j === childCount - 1;\n const col = makeColumn(child, Group, isFirst, isLast);\n\n if (i === 0 && j === 0 && data.some((d) => d[ACCORDION])) {\n gridColumnIndex++;\n col.gridArea = `2 / ${gridColumnIndex - 1} / 3 / ${gridColumnIndex + 1}`;\n } else {\n col.gridArea = `2 / ${gridColumnIndex} / 3 / ${gridColumnIndex + 1}`;\n }\n\n col.gridArea = `2 / ${gridColumnIndex} / 3 / ${gridColumnIndex + 1}`;\n columnIndex++;\n gridColumnIndex++;\n\n columns.push(col);\n }\n });\n\n this.gridAreaGroupMap.set(groupIndex, `1 / ${initGridColumn} / 2 / ${gridColumnIndex}`);\n groupIndex++;\n }\n });\n\n return columns.filter(Boolean);\n\n // return Columns.map((c) => {\n // const column = {\n // name: c.props.name,\n // ref: (node: HTMLElement | null) => {\n // if (node) {\n // const calculatedWidth = node.getBoundingClientRect().width;\n // column.calculatedWidth = calculatedWidth;\n // }\n //\n // return { current: node };\n // },\n // gridColumnWidth: calculateGridTemplateColumn(c),\n // fixed: c.props.fixed,\n // calculatedWidth: 0,\n // };\n //\n // return column;\n // });\n\n // return columns;\n }\n\n private calculateRows(): DTRow[] {\n const { data } = this.asProps;\n\n const rows: DTRow[] = [];\n\n let rowIndex = 0;\n\n const addToRows = (row: Record<DTKey, any>) => {\n const dtRow = Object.entries(row).reduce<DTRow>((acc, [key, value]) => {\n const columnsToRow = key.split(this.columnsSplitter);\n\n if (columnsToRow.length === 1) {\n acc[key] = value;\n } else {\n acc[columnsToRow[0]] = new MergedColumnsCell(value, columnsToRow.length);\n }\n\n if (row[ACCORDION]) {\n acc[ACCORDION] = row[ACCORDION];\n }\n\n return acc;\n }, {});\n\n rows.push(dtRow);\n rowIndex++;\n };\n\n data.forEach((row, rowIndex) => {\n const groupedRows: DataTableData | undefined = row[ROW_GROUP];\n\n if (groupedRows) {\n groupedRows.forEach((childRow, index) => {\n if (index === 0) {\n const rowData = {\n ...childRow,\n ...Object.entries(row).reduce<DTRow>((acc, [key, value]) => {\n acc[key] = new MergedRowsCell(value, groupedRows.length);\n return acc;\n }, {}),\n };\n\n addToRows(rowData);\n } else {\n addToRows(childRow);\n }\n });\n } else {\n addToRows(row);\n }\n });\n\n return rows;\n }\n\n private calculateGridTemplateColumn(c: ReactElement<DataTableColumnProps>): string {\n return c.props.gtcWidth ?? (this.props.defaultGridTemplateColumnWidth as string);\n }\n}\n\nexport const DataTable = createComponent(DataTableRoot, {\n Head,\n Body,\n}) as DataTableType & {\n Head: typeof Head;\n Body: typeof Body;\n};\n"],"mappings":"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"}
|
|
@@ -1 +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 =
|
|
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> = [sortBy: Column, sortDirection: SortDirection];\n\nexport type DataTableChangeSort<Column> = (\n sort: [sortBy: Column, sortDirection: SortDirection],\n e?: React.SyntheticEvent,\n) => void;\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<D extends DataTableData> = DataTableAriaProps &\n Sizes & {\n /** Data for table */\n data: D;\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<keyof D[0]>;\n /** Handler call when request will change sort */\n onSortChange?: DataTableChangeSort<keyof D[0]>;\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\nexport type DataTableType = (<Data extends DataTableData, Tag extends Intergalactic.Tag = 'div'>(\n props: Intergalactic.InternalTypings.ComponentProps<Tag, 'div', DataTableProps<Data>>,\n) => Intergalactic.InternalTypings.ComponentRenderingResults) &\n Intergalactic.InternalTypings.ComponentAdditive<'div', 'div', DataTableProps<any>>;\n"],"mappings":""}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Column.js","names":["_core","require","React","_interopRequireWildcard","_baseComponents","_m","_interopRequireDefault","_m2","_button","_getFocusableIn","_Head","_canUseDOM","style","sstyled","insert","SORTING_ICON","desc","SortDesc","asc","SortAsc","ARIA_SORT","DEFAULT_DIRECTION","reversedSortDirection","Column","_Component","_inherits2","_super","_createSuper2","_this","_classCallCheck2","_len","arguments","length","args","Array","_key","call","apply","concat","_defineProperty2","_assertThisInitialized2","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","SORT_ICON_WIDTH","freeSpace","setState","e","_this$asProps","asProps","sort","onSortChange","name","sortDirection","currentTarget","lockedCell","focusableChildren","from","children","flatMap","getFocusableIn","_this$lockedCell$","focus","startsWith","stopPropagation","target","shiftKey","_focusableChildren","preventDefault","_focusableChildren$","_focusableChildren$2","_this$lockedCell$2","setAttribute","cellElement","_createClass2","value","componentDidUpdate","prevProps","_prevProps$sort","_this$asProps$sort","changeSortSize","canUseDOM","_this$asProps$sort2","_this$asProps$sort3","_this$asProps2","tableRef","gridTemplateColumns","columnIndex","newWidth","calculateActiveColumnMinWidth","setTimeout","map","gtcWidth","index","join","render","_ref","_ref2","SColumn","Flex","SSortWrapper","SSortButton","ButtonLink","_this$asProps3","sortable","uid","parent","sortableColumnDescribeId","SSortIcon","isSorted","visibleSort","state","ariaDescribedBy","push","ariaSortValue","undefined","cn","_objectSpread2","assignProps","handleMouseEnter","handleMouseLeave","handleFocusCell","handleBlur","handleKeyDown","handleSortClick","Addon","tag","Component","exports"],"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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"}
|
|
1
|
+
{"version":3,"file":"Column.js","names":["_core","require","React","_interopRequireWildcard","_baseComponents","_m","_interopRequireDefault","_m2","_button","_getFocusableIn","_Head","_canUseDOM","style","sstyled","insert","SORTING_ICON","desc","SortDesc","asc","SortAsc","ARIA_SORT","DEFAULT_DIRECTION","reversedSortDirection","Column","_Component","_inherits2","_super","_createSuper2","_this","_classCallCheck2","_len","arguments","length","args","Array","_key","call","apply","concat","_defineProperty2","_assertThisInitialized2","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","SORT_ICON_WIDTH","freeSpace","setState","e","_this$asProps","asProps","sort","onSortChange","name","sortDirection","currentTarget","lockedCell","focusableChildren","from","children","flatMap","getFocusableIn","_this$lockedCell$","focus","startsWith","stopPropagation","target","shiftKey","_focusableChildren","preventDefault","_focusableChildren$","_focusableChildren$2","_this$lockedCell$2","setAttribute","cellElement","_createClass2","value","componentDidUpdate","prevProps","_prevProps$sort","_this$asProps$sort","changeSortSize","canUseDOM","_this$asProps$sort2","_this$asProps$sort3","_this$asProps2","tableRef","gridTemplateColumns","columnIndex","newWidth","calculateActiveColumnMinWidth","setTimeout","map","gtcWidth","index","join","render","_ref","_ref2","SColumn","Flex","SSortWrapper","SSortButton","ButtonLink","_this$asProps3","sortable","uid","parent","sortableColumnDescribeId","SSortIcon","isSorted","visibleSort","state","ariaDescribedBy","push","ariaSortValue","undefined","cn","_objectSpread2","assignProps","handleMouseEnter","handleMouseLeave","handleFocusCell","handleBlur","handleKeyDown","handleSortClick","Addon","tag","Component","exports"],"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 { DataTableData, 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<D extends DataTableData> extends Component<\n DataTableColumnProps,\n {},\n {},\n [],\n ColumnPropsInner<D>\n> {\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<D>): 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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"}
|
|
@@ -1 +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":""}
|
|
1
|
+
{"version":3,"file":"Column.types.js","names":[],"sources":["../../../../src/components/Head/Column.types.ts"],"sourcesContent":["import { DataTableData, 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<D extends DataTableData> = {\n use: DTUse;\n borders?: 'both' | 'left' | 'right';\n sort?: DataTableProps<D>['sort'];\n onSortChange?: DataTableProps<D>['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":""}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Head.js","names":["_core","require","React","_interopRequireWildcard","_baseComponents","_Column","_Group","_utils","style","sstyled","insert","HeadRoot","_Component","_inherits2","_super","_createSuper2","_this","_classCallCheck2","_len","arguments","length","args","Array","_key","call","apply","concat","_defineProperty2","_assertThisInitialized2","Map","_createClass2","key","value","sortableColumnDescribeId","uid","asProps","getGroupProps","_","index","_this$asProps","use","gridAreaGroupMap","gridArea","get","fixedColumnsMap","getColumnProps","_this$asProps2","columns","sort","onSortChange","tableRef","gridTemplateColumns","gridTemplateAreas","column","_getFixedStyle","getFixedStyle","_getFixedStyle2","_slicedToArray2","name","undefined","set","ref","node","fixed","borders","parent","columnIndex","render","_ref","_ref2","SHead","Box","_this$asProps3","Children","styles","withScrollBar","getI18nText","_getScrollOffsetValue","getScrollOffsetValue","_getScrollOffsetValue2","offsetLeftSum","offsetRightSum","createElement","Fragment","cn","_objectSpread2","assignProps","ScreenReaderOnly","Component","Head","createComponent","Column","Group","exports"],"sources":["../../../../src/components/Head/Head.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Component, createComponent, Intergalactic, Root, sstyled } from '@semcore/core';\nimport { DataTableHeadProps, HeadPropsInner } from './Head.types';\nimport { Box, ScreenReaderOnly
|
|
1
|
+
{"version":3,"file":"Head.js","names":["_core","require","React","_interopRequireWildcard","_baseComponents","_Column","_Group","_utils","style","sstyled","insert","HeadRoot","_Component","_inherits2","_super","_createSuper2","_this","_classCallCheck2","_len","arguments","length","args","Array","_key","call","apply","concat","_defineProperty2","_assertThisInitialized2","Map","_createClass2","key","value","sortableColumnDescribeId","uid","asProps","getGroupProps","_","index","_this$asProps","use","gridAreaGroupMap","gridArea","get","fixedColumnsMap","getColumnProps","_this$asProps2","columns","sort","onSortChange","tableRef","gridTemplateColumns","gridTemplateAreas","column","_getFixedStyle","getFixedStyle","_getFixedStyle2","_slicedToArray2","name","undefined","set","ref","node","fixed","borders","parent","columnIndex","render","_ref","_ref2","SHead","Box","_this$asProps3","Children","styles","withScrollBar","getI18nText","_getScrollOffsetValue","getScrollOffsetValue","_getScrollOffsetValue2","offsetLeftSum","offsetRightSum","createElement","Fragment","cn","_objectSpread2","assignProps","ScreenReaderOnly","Component","Head","createComponent","Column","Group","exports"],"sources":["../../../../src/components/Head/Head.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Component, createComponent, Intergalactic, Root, sstyled } from '@semcore/core';\nimport { DataTableHeadProps, HeadPropsInner } from './Head.types';\nimport { Box, ScreenReaderOnly } from '@semcore/base-components';\n\nimport style from './style.shadow.css';\nimport { Column } from './Column';\nimport { Group } from './Group';\nimport { DataTableColumnProps } from './Column.types';\nimport { getFixedStyle, getScrollOffsetValue } from '../../utils';\nimport { DataTableGroupProps } from './Group.type';\nimport { DataTableData } from '../DataTable/DataTable.types';\n\nclass HeadRoot<D extends DataTableData> extends Component<\n DataTableHeadProps,\n {},\n {},\n [],\n HeadPropsInner<D>\n> {\n static displayName = 'Head';\n static style = style;\n\n fixedColumnsMap = new Map<string, any>();\n\n sortableColumnDescribeId() {\n const { uid } = this.asProps;\n return `${uid}-column-sortable-describer`;\n }\n\n getGroupProps(_: any, index: number) {\n const { use, gridAreaGroupMap } = this.asProps;\n\n return {\n use,\n gridArea: gridAreaGroupMap.get(index),\n fixedColumnsMap: this.fixedColumnsMap,\n };\n }\n\n getColumnProps(_: any, index: number) {\n const { use, columns, sort, onSortChange, tableRef, gridTemplateColumns, gridTemplateAreas } =\n this.asProps;\n const column = columns[index];\n const [name, value] = getFixedStyle(column, columns);\n const style: any = {};\n\n if (name !== undefined && value !== undefined) {\n style[name] = value;\n\n this.fixedColumnsMap.set(column.name, value);\n }\n\n return {\n use,\n 'aria-colindex': index + 1,\n ref: (node: HTMLElement | null) => column.ref(node),\n style,\n gridArea: column.gridArea,\n fixed: column.fixed,\n borders: column.borders,\n sort,\n onSortChange,\n parent: column.parent,\n sortableColumnDescribeId: this.sortableColumnDescribeId(),\n columnIndex: index,\n tableRef,\n gridTemplateColumns,\n gridTemplateAreas,\n };\n }\n\n render() {\n const SHead = Root;\n const { Children, styles, columns, tableRef, withScrollBar, getI18nText } = this.asProps;\n const [offsetLeftSum, offsetRightSum] = getScrollOffsetValue(columns);\n\n return sstyled(styles)(\n <>\n <SHead render={Box} role='row' aria-rowindex={1}>\n <Children />\n </SHead>\n\n {/*{Boolean(withScrollBar) && tableRef.current && (*/}\n {/* <Box display={'contents'}>*/}\n {/* <ScrollArea.Bar*/}\n {/* orientation='horizontal'*/}\n {/* container={tableRef}*/}\n {/* top={'25px'}*/}\n {/* leftOffset={offsetLeftSum}*/}\n {/* rightOffset={offsetRightSum}*/}\n {/* />*/}\n {/* </Box>*/}\n {/*)}*/}\n\n <ScreenReaderOnly aria-hidden={true} id={this.sortableColumnDescribeId()}>\n {getI18nText('sortableColumn')}\n </ScreenReaderOnly>\n </>,\n );\n }\n}\n\nexport const Head = createComponent(HeadRoot, { Column, Group }) as Intergalactic.Component<\n 'div',\n DataTableHeadProps\n> & {\n Column: Intergalactic.Component<'div', DataTableColumnProps>;\n Group: Intergalactic.Component<'div', DataTableGroupProps>;\n};\n"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Head.types.js","names":[],"sources":["../../../../src/components/Head/Head.types.ts"],"sourcesContent":["import { DataTableData, DataTableProps, DTUse } from '../DataTable/DataTable.types';\nimport { DTColumn } from './Column.types';\n\nexport type DataTableHeadProps = {\n /**\n * Sticky header\n * @default false\n */\n sticky?: boolean;\n\n /** Enable scroll bar element in header */\n withScrollBar?: boolean;\n};\n\nexport type HeadPropsInner = {\n use: DTUse;\n tableRef: React.RefObject<HTMLElement>;\n columns: DTColumn[];\n compact: boolean;\n sort?: DataTableProps['sort'];\n onSortChange?: DataTableProps['onSortChange'];\n getI18nText: (key: string) => string;\n uid: string;\n ref: React.RefObject<HTMLDivElement>;\n\n gridAreaGroupMap: Map<number, string>;\n gridTemplateColumns: string[];\n gridTemplateAreas: string[];\n};\n"],"mappings":""}
|
|
1
|
+
{"version":3,"file":"Head.types.js","names":[],"sources":["../../../../src/components/Head/Head.types.ts"],"sourcesContent":["import { DataTableData, DataTableProps, DTUse } from '../DataTable/DataTable.types';\nimport { DTColumn } from './Column.types';\n\nexport type DataTableHeadProps = {\n /**\n * Sticky header\n * @default false\n */\n sticky?: boolean;\n\n /**\n * offset for sticky header\n */\n top?: number;\n\n /** Enable scroll bar element in header */\n withScrollBar?: boolean;\n};\n\nexport type HeadPropsInner<D extends DataTableData> = {\n use: DTUse;\n tableRef: React.RefObject<HTMLElement>;\n columns: DTColumn[];\n compact: boolean;\n sort?: DataTableProps<D>['sort'];\n onSortChange?: DataTableProps<D>['onSortChange'];\n getI18nText: (key: string) => string;\n uid: string;\n ref: React.RefObject<HTMLDivElement>;\n\n gridAreaGroupMap: Map<number, string>;\n gridTemplateColumns: string[];\n gridTemplateAreas: string[];\n};\n"],"mappings":""}
|
package/lib/cjs/index.js
CHANGED
|
@@ -1,13 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
|
|
4
3
|
Object.defineProperty(exports, "__esModule", {
|
|
5
4
|
value: true
|
|
6
5
|
});
|
|
7
|
-
var _exportNames = {
|
|
8
|
-
DataTable: true,
|
|
9
|
-
ACCORDION: true
|
|
10
|
-
};
|
|
11
6
|
Object.defineProperty(exports, "ACCORDION", {
|
|
12
7
|
enumerable: true,
|
|
13
8
|
get: function get() {
|
|
@@ -20,23 +15,16 @@ Object.defineProperty(exports, "DataTable", {
|
|
|
20
15
|
return _DataTable.DataTable;
|
|
21
16
|
}
|
|
22
17
|
});
|
|
23
|
-
Object.defineProperty(exports, "
|
|
18
|
+
Object.defineProperty(exports, "ROW_GROUP", {
|
|
24
19
|
enumerable: true,
|
|
25
20
|
get: function get() {
|
|
26
|
-
return
|
|
21
|
+
return _DataTable.ROW_GROUP;
|
|
27
22
|
}
|
|
28
23
|
});
|
|
24
|
+
exports.wrapDataTable = void 0;
|
|
29
25
|
var _DataTable = require("./components/DataTable/DataTable");
|
|
30
|
-
var
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
if (key in exports && exports[key] === _DataTable2[key]) return;
|
|
35
|
-
Object.defineProperty(exports, key, {
|
|
36
|
-
enumerable: true,
|
|
37
|
-
get: function get() {
|
|
38
|
-
return _DataTable2[key];
|
|
39
|
-
}
|
|
40
|
-
});
|
|
41
|
-
});
|
|
26
|
+
var wrapDataTable = function wrapDataTable(wrapper) {
|
|
27
|
+
return wrapper;
|
|
28
|
+
};
|
|
29
|
+
exports.wrapDataTable = wrapDataTable;
|
|
42
30
|
//# sourceMappingURL=index.js.map
|
package/lib/cjs/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["_DataTable","require","
|
|
1
|
+
{"version":3,"file":"index.js","names":["_DataTable","require","wrapDataTable","wrapper","exports"],"sources":["../../src/index.ts"],"sourcesContent":["import { DataTable, ACCORDION, ROW_GROUP } from './components/DataTable/DataTable';\nimport type { DataTableSort, DataTableType, DTKey } from './components/DataTable/DataTable.types';\nimport { Intergalactic } from '@semcore/core';\nimport React from 'react';\n\nconst wrapDataTable = <PropsExtending extends {}>(\n wrapper: (\n props: Intergalactic.InternalTypings.UntypeRefAndTag<\n Intergalactic.InternalTypings.ComponentPropsNesting<DataTableType>\n > &\n PropsExtending,\n ) => React.ReactNode,\n): DataTableType => wrapper as any;\n\nexport { DataTable, ACCORDION, ROW_GROUP, wrapDataTable };\nexport type { DataTableSort, DTKey };\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;AAAA,IAAAA,UAAA,GAAAC,OAAA;AAKA,IAAMC,aAAa,GAAG,SAAhBA,aAAaA,CACjBC,OAKoB;EAAA,OACFA,OAAO;AAAA,CAAO;AAACC,OAAA,CAAAF,aAAA,GAAAA,aAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Body.types.js","names":[],"sources":["../../../../src/components/Body/Body.types.ts"],"sourcesContent":["import { DTRow } from './Row.types';\nimport { DTColumn } from '../Head/Column.types';\nimport { DTUse } from '../DataTable/DataTable.types';\n\ntype CellRenderProps = {\n name: string;\n row: DTRow;\n column: DTColumn;\n rowIndex: number;\n columnIndex: number;\n value: string | number | boolean;\n defaultRender: () => React.ReactNode;\n};\n\nexport type DataTableBodyProps = {\n // rows: DTRow[];\n // columns: DTColumn[];\n\n renderCell?: (props: CellRenderProps) => React.ReactNode;\n\n expandedRows?: number[];\n};\n\nexport type BodyPropsInner = {\n rows: DTRow[];\n columns: DTColumn[];\n use: DTUse;\n scrollRef: (ref: HTMLDivElement) => void;\n headerRows: number;\n compact: boolean;\n gridTemplateColumns: string[];\n gridTemplateAreas: string[];\n loading?: boolean;\n headerHeight: number;\n getI18nText: (key: string) => string;\n};\n"],"mappings":""}
|
|
1
|
+
{"version":3,"file":"Body.types.js","names":[],"sources":["../../../../src/components/Body/Body.types.ts"],"sourcesContent":["import { DTRow } from './Row.types';\nimport { DTColumn } from '../Head/Column.types';\nimport { DTUse } from '../DataTable/DataTable.types';\n\ntype CellRenderProps = {\n name: string;\n row: DTRow;\n column: DTColumn;\n rowIndex: number;\n columnIndex: number;\n value: string | number | boolean;\n defaultRender: () => React.ReactNode;\n};\n\nexport type DataTableBodyProps = {\n // rows: DTRow[];\n // columns: DTColumn[];\n\n renderCell?: (props: CellRenderProps) => React.ReactNode;\n\n expandedRows?: number[];\n\n virtualScroll?: boolean;\n};\n\nexport type BodyPropsInner = {\n rows: DTRow[];\n columns: DTColumn[];\n use: DTUse;\n scrollRef: (ref: HTMLDivElement) => void;\n headerRows: number;\n compact: boolean;\n gridTemplateColumns: string[];\n gridTemplateAreas: string[];\n loading?: boolean;\n headerHeight: number;\n getI18nText: (key: string) => string;\n};\n"],"mappings":""}
|
|
@@ -29,7 +29,6 @@ import findComponent from '@semcore/core/lib/utils/findComponent';
|
|
|
29
29
|
import { localizedMessages } from '../../translations/__intergalactic-dynamic-locales';
|
|
30
30
|
import i18nEnhance from '@semcore/core/lib/utils/enhances/i18nEnhance';
|
|
31
31
|
import uniqueIDEnhancement from '@semcore/core/lib/utils/uniqueID';
|
|
32
|
-
import { ROW_GROUP } from '../../index';
|
|
33
32
|
import { MergedColumnsCell, MergedRowsCell } from '../Body/MergedCells';
|
|
34
33
|
import { forkRef } from '@semcore/core/lib/utils/ref';
|
|
35
34
|
/*__reshadow-styles__:"../../style/scroll-shadows.shadow.css"*/
|
|
@@ -39,6 +38,7 @@ var scrollStyles = ( /*__reshadow_css_start__*/_sstyled2.insert( /*__inner_css_s
|
|
|
39
38
|
"__SShadowVertical": "___SShadowVertical_1765z_gg_"
|
|
40
39
|
});
|
|
41
40
|
export var ACCORDION = Symbol('accordion');
|
|
41
|
+
export var ROW_GROUP = Symbol('ROW_GROUP');
|
|
42
42
|
var DataTableRoot = /*#__PURE__*/function (_Component) {
|
|
43
43
|
_inherits(DataTableRoot, _Component);
|
|
44
44
|
var _super = _createSuper(DataTableRoot);
|
|
@@ -320,8 +320,7 @@ var DataTableRoot = /*#__PURE__*/function (_Component) {
|
|
|
320
320
|
wMin = _this$asProps3.wMin,
|
|
321
321
|
h = _this$asProps3.h,
|
|
322
322
|
hMax = _this$asProps3.hMax,
|
|
323
|
-
hMin = _this$asProps3.hMin
|
|
324
|
-
loading = _this$asProps3.loading;
|
|
323
|
+
hMin = _this$asProps3.hMin;
|
|
325
324
|
var _getScrollOffsetValue = getScrollOffsetValue(this.columns),
|
|
326
325
|
_getScrollOffsetValue2 = _slicedToArray(_getScrollOffsetValue, 2),
|
|
327
326
|
offsetLeftSum = _getScrollOffsetValue2[0],
|