@join-x5/react-data-grid 1.5.2 → 1.5.3
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/dist/DataGrid.es.js +50 -48
- package/dist/DataGrid.es.js.map +1 -1
- package/dist/DataGridContext.d.ts +1 -1
- package/dist/DataGridContext.es.js.map +1 -1
- package/dist/TableCell/hook.es.js +5 -4
- package/dist/TableCell/hook.es.js.map +1 -1
- package/dist/TableCell/index.es.js +98 -96
- package/dist/TableCell/index.es.js.map +1 -1
- package/dist/TableCell/types.d.ts +5 -0
- package/dist/TableHeadCell/index.es.js +86 -86
- package/dist/TableHeadCell/index.es.js.map +1 -1
- package/dist/TableInputCell/hook.d.ts +2 -0
- package/dist/TableRow/index.es.js +5 -5
- package/dist/TableRow/index.es.js.map +1 -1
- package/dist/index.cjs +1 -1
- package/dist/index.cjs.map +1 -1
- package/dist/types.d.ts +1 -1
- package/package.json +8 -8
|
@@ -1,23 +1,23 @@
|
|
|
1
1
|
"use client";
|
|
2
|
-
import { jsx as
|
|
3
|
-
import
|
|
2
|
+
import { jsx as l, jsxs as H } from "@emotion/react/jsx-runtime";
|
|
3
|
+
import X from "@emotion/styled/base";
|
|
4
4
|
import U from "react";
|
|
5
|
-
import { flexRender as
|
|
6
|
-
import { SizeTokenValue as c, forwardRef as
|
|
5
|
+
import { flexRender as r } from "@tanstack/react-table";
|
|
6
|
+
import { SizeTokenValue as c, forwardRef as B, useRefMerge as Q } from "@join-x5/react-theme";
|
|
7
7
|
import { EditOnIcon as O } from "@join-x5/react-icons";
|
|
8
|
-
import { ColumnArea as
|
|
9
|
-
import { useDataGridTableCell as
|
|
10
|
-
function
|
|
8
|
+
import { ColumnArea as V } from "@join-x5/react-data-grid-settings";
|
|
9
|
+
import { useDataGridTableCell as M } from "./hook.es.js";
|
|
10
|
+
function y() {
|
|
11
11
|
return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
|
|
12
12
|
}
|
|
13
|
-
const
|
|
13
|
+
const j = {
|
|
14
14
|
[c.XXSmall]: 8,
|
|
15
15
|
[c.XSmall]: 8,
|
|
16
16
|
[c.Small]: 8,
|
|
17
17
|
[c.Medium]: 12,
|
|
18
18
|
[c.Large]: 12,
|
|
19
19
|
[c.XLarge]: 12
|
|
20
|
-
},
|
|
20
|
+
}, T = /* @__PURE__ */ X("td", process.env.NODE_ENV === "production" ? {
|
|
21
21
|
target: "e1enoxlq3"
|
|
22
22
|
} : {
|
|
23
23
|
target: "e1enoxlq3",
|
|
@@ -26,7 +26,7 @@ const M = {
|
|
|
26
26
|
color: I.theme.colors.grey[100],
|
|
27
27
|
"--background-color": I.theme.colors.white,
|
|
28
28
|
"--border-color": I.theme.colors.grey[10]
|
|
29
|
-
}), ";&[data-", c.Large.toLocaleLowerCase(), "]{min-height:44px;", (I) => I.theme.typography.p1compact, ";}&[data-", c.Medium.toLocaleLowerCase(), "]{min-height:40px;", (I) => I.theme.typography.p2, ";}&[data-", c.Small.toLocaleLowerCase(), "]{min-height:32px;", (I) => I.theme.typography.p2, ";}&[data-",
|
|
29
|
+
}), ";&[data-", c.Large.toLocaleLowerCase(), "]{min-height:44px;", (I) => I.theme.typography.p1compact, ";}&[data-", c.Medium.toLocaleLowerCase(), "]{min-height:40px;", (I) => I.theme.typography.p2, ";}&[data-", c.Small.toLocaleLowerCase(), "]{min-height:32px;", (I) => I.theme.typography.p2, ";}&[data-", V.FixedLeft.toLocaleLowerCase(), "]{position:sticky;z-index:1;&[data-shadowed][data-last-fixed]{filter:drop-shadow(8px 0px 8px rgba(80, 86, 94, 0.08));}}&[data-", V.FixedRight.toLocaleLowerCase(), "]{position:sticky;z-index:1;&[data-shadowed][data-last-fixed]{filter:drop-shadow(-8px 0px 8px rgba(80, 86, 94, 0.08));}}&[data-row-hover]{", (I) => ({
|
|
30
30
|
"--background-color": I.theme.colors.grey[10],
|
|
31
31
|
"--border-color": I.theme.colors.grey[20]
|
|
32
32
|
}), ";}:hover{", (I) => ({
|
|
@@ -40,7 +40,7 @@ const M = {
|
|
|
40
40
|
}), ";}}&[data-row-selected]{", (I) => ({
|
|
41
41
|
"--background-color": I.theme.colors.accent[10],
|
|
42
42
|
"--border-color": I.theme.colors.accent[20]
|
|
43
|
-
}), ";}&[data-focused],:focus{
|
|
43
|
+
}), ";}:focus{outline:none;}&[data-focused],:focus:not([data-no-focus]){", (I) => ({
|
|
44
44
|
"--border-color": "transparent",
|
|
45
45
|
"--background-color": I.theme.colors.white,
|
|
46
46
|
"--outline-color": I.theme.colors.accent[90]
|
|
@@ -53,7 +53,7 @@ const M = {
|
|
|
53
53
|
"--background-color": I.theme.colors.white,
|
|
54
54
|
"--border-color": "transparent",
|
|
55
55
|
"--outline-color": I.theme.colors.additional.red[80]
|
|
56
|
-
}), ";::after{display:block;}}::before{content:'';display:block;position:absolute;box-sizing:border-box;top:0;left:0;width:100%;height:100%;user-select:none;pointer-events:none;border-width:0 0 1px 0;border-style:solid;border-color:var(--border-color);}&[data-bordered]{::before{border-width:0 1px 1px 0;}:last-of-type::before{border-width:0 0 1px 0;}}&[data-resizing]{border-right:1px solid ", (I) => I.theme.colors.accent[20], ";}::after{content:'';display:none;position:absolute;box-sizing:border-box;top:0;left:0;width:100%;height:100%;user-select:none;pointer-events:none;border-width:2px;border-style:solid;border-radius:4px;border-color:var(--outline-color, transparent);}[data-edit-icon]{display:none;position:absolute;visibility:hidden;right:0;top:0;background-color:var(--background-color, transparent);}&[data-editable] [data-edit-icon]{display:block;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/sadykovsd/join-x5/packages/data-grid/src/TableCell/index.tsx"],"names":[],"mappings":"AAyBsB","file":"/home/sadykovsd/join-x5/packages/data-grid/src/TableCell/index.tsx","sourcesContent":["'use client';\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport {flexRender} from '@tanstack/react-table';\n\nimport {forwardRef, SizeTokenValue, useRefMerge} from '@join-x5/react-theme';\nimport {EditOnIcon} from '@join-x5/react-icons';\nimport {ColumnArea} from '@join-x5/react-data-grid-settings';\n\nimport {useDataGridTableCell} from './hook';\n\nimport type {HTMLAttributes, KeyboardEventHandler} from 'react';\nimport type {FRC, PropsWithChildren} from '@join-x5/react-theme';\nimport type {DataGridTableCellProps, TableCellProps} from './types';\n\nconst sizePadding: Record<SizeTokenValue, number> = {\n  [SizeTokenValue.XXSmall]: 8,\n  [SizeTokenValue.XSmall]: 8,\n  [SizeTokenValue.Small]: 8,\n  [SizeTokenValue.Medium]: 12,\n  [SizeTokenValue.Large]: 12,\n  [SizeTokenValue.XLarge]: 12,\n};\n\nconst Cell = styled.td`\n  position: relative;\n  box-sizing: border-box;\n  height: 1px;\n  border-radius: 0;\n  border-spacing: 0;\n  background-color: var(--background-color, transparent);\n\n  ${props => ({\n    color: props.theme.colors.grey[100],\n\n    '--background-color': props.theme.colors.white,\n    '--border-color': props.theme.colors.grey[10],\n  })};\n\n  &[data-${SizeTokenValue.Large.toLocaleLowerCase()}] {\n    min-height: 44px;\n\n    ${props => props.theme.typography.p1compact}\n  }\n\n  &[data-${SizeTokenValue.Medium.toLocaleLowerCase()}] {\n    min-height: 40px;\n\n    ${props => props.theme.typography.p2}\n  }\n\n  &[data-${SizeTokenValue.Small.toLocaleLowerCase()}] {\n    min-height: 32px;\n\n    ${props => props.theme.typography.p2}\n  }\n\n  &[data-${ColumnArea.FixedLeft.toLocaleLowerCase()}] {\n    position: sticky;\n    z-index: 1;\n\n    &[data-shadowed][data-last-fixed] {\n      filter: drop-shadow(8px 0px 8px rgba(80, 86, 94, 0.08));\n    }\n  }\n\n  &[data-${ColumnArea.FixedRight.toLocaleLowerCase()}] {\n    position: sticky;\n    z-index: 1;\n\n    &[data-shadowed][data-last-fixed] {\n      filter: drop-shadow(-8px 0px 8px rgba(80, 86, 94, 0.08));\n    }\n  }\n\n  &[data-row-hover] {\n    ${props => ({\n      '--background-color': props.theme.colors.grey[10],\n      '--border-color': props.theme.colors.grey[20],\n    })}\n  }\n\n  :hover {\n    ${props => ({\n      '--background-color': props.theme.colors.grey[10],\n      '--border-color': props.theme.colors.grey[40],\n    })}\n  }\n\n  :not([data-disabled]):hover::before {\n    border-width: 1px;\n  }\n\n  &[data-disabled] {\n    :hover {\n      ${props => ({\n        '--background-color': props.theme.colors.grey[10],\n        '--border-color': props.theme.colors.grey[20],\n      })}\n    }\n\n    ${props => ({\n      color: props.theme.colors.grey[40],\n    })}\n  }\n\n  &[data-row-selected] {\n    ${props => ({\n      '--background-color': props.theme.colors.accent[10],\n      '--border-color': props.theme.colors.accent[20],\n    })}\n  }\n\n  &[data-focused],\n  :focus {\n    outline: none;\n\n    ::before {\n      display: none;\n    }\n\n    ::after {\n      display: block;\n    }\n\n    [data-edit-icon] {\n      visibility: visible;\n    }\n\n    ${props => ({\n      '--border-color': 'transparent',\n      '--background-color': props.theme.colors.white,\n      '--outline-color': props.theme.colors.accent[90],\n    })}\n  }\n\n  &[data-active] {\n    outline: none;\n\n    ::before {\n      display: none;\n    }\n\n    ::after {\n      display: block;\n    }\n\n    [data-edit-icon] {\n      visibility: hidden;\n    }\n\n    ${props => ({\n      '--border-color': 'transparent',\n      '--background-color': props.theme.colors.white,\n      '--outline-color': props.theme.colors.accent[90],\n    })}\n  }\n\n  &[data-error] {\n    ::after {\n      display: block;\n    }\n\n    ${props => ({\n      caretColor: props.theme.colors.additional.red[80],\n\n      '--background-color': props.theme.colors.white,\n      '--border-color': 'transparent',\n      '--outline-color': props.theme.colors.additional.red[80],\n    })}\n  }\n\n  ::before {\n    content: '';\n    display: block;\n    position: absolute;\n    box-sizing: border-box;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%;\n    user-select: none;\n    pointer-events: none;\n    border-width: 0 0 1px 0;\n    border-style: solid;\n    border-color: var(--border-color);\n  }\n\n  &[data-bordered] {\n    ::before {\n      border-width: 0 1px 1px 0;\n    }\n\n    :last-of-type::before {\n      border-width: 0 0 1px 0;\n    }\n  }\n\n  &[data-resizing] {\n    border-right: 1px solid ${props => props.theme.colors.accent[20]};\n  }\n\n  ::after {\n    content: '';\n    display: none;\n    position: absolute;\n    box-sizing: border-box;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%;\n    user-select: none;\n    pointer-events: none;\n    border-width: 2px;\n    border-style: solid;\n    border-radius: 4px;\n    border-color: var(--outline-color, transparent);\n  }\n\n  [data-edit-icon] {\n    display: none;\n    position: absolute;\n    visibility: hidden;\n    right: 0;\n    top: 0;\n    background-color: var(--background-color, transparent);\n  }\n\n  &[data-editable] [data-edit-icon] {\n    display: block;\n  }\n`;\n\nconst Container = styled.div`\n  display: flex;\n  position: relative;\n  box-sizing: border-box;\n  gap: 8px;\n`;\n\nconst Content = styled.div`\n  position: relative;\n  flex-grow: 1;\n  word-break: break-word;\n\n  :not([data-is-multiline]) {\n    overflow: hidden;\n    text-overflow: ellipsis;\n    white-space: nowrap;\n  }\n`;\n\nconst Caption = styled.div`\n  padding: 4px 0 0;\n  width: 100%;\n  word-break: break-all;\n\n  ${props => ({\n    ...props.theme.typography.p3,\n\n    color: props.theme.colors.additional.red[80],\n  })}\n`;\n\ntype TableCellContentProps = Partial<Pick<TableCellProps, 'children' | 'isMultiline' | 'whiteSpace' | 'wordBreak'>> &\n  HTMLAttributes<HTMLDivElement>;\n\nexport const TableCellContent: FRC<HTMLDivElement, TableCellContentProps> = forwardRef((props, ref) => {\n  const {children, style, isMultiline, whiteSpace, wordBreak = 'break-word', ...rest} = props;\n\n  const contentProps = {\n    ...rest,\n\n    style: {\n      whiteSpace,\n      wordBreak,\n\n      ...style,\n    },\n\n    'data-content': true,\n    'data-is-multiline': isMultiline ? true : undefined,\n  };\n\n  return (\n    <Content ref={ref} {...contentProps}>\n      {children}\n    </Content>\n  );\n});\n\nexport const TableCell: FRC<HTMLTableCellElement, TableCellProps> = forwardRef((props, baseRef) => {\n  const ref = useRefMerge(baseRef);\n\n  const {\n    children,\n\n    isDisabled,\n    isRowHover,\n    isRowSelected,\n    isBordered,\n    isShadowed,\n    isFocused,\n    isActive,\n    isResizing,\n    isLastFixed,\n    error,\n\n    textAlign,\n    writingMode,\n    verticalAlign,\n    padding,\n    userSelect = 'none',\n\n    startAdornment,\n    endAdornment,\n\n    size = SizeTokenValue.Medium,\n    columnArea = ColumnArea.Default,\n\n    ...rest\n  } = props;\n\n  const onKeyDown: KeyboardEventHandler<HTMLTableCellElement> = e => {\n    props.onKeyDown?.(e);\n\n    const isEnterCode = e.code === 'Enter' || e.code === 'NumpadEnter';\n\n    if (isEnterCode) {\n      const child = ref.current?.querySelector('[data-action]') as HTMLElement;\n\n      if (isEnterCode && child) {\n        child.click();\n      }\n\n      return;\n    }\n\n    if (e.code === 'Escape') {\n      ref.current?.blur();\n      return;\n    }\n\n    if (e.code === 'ArrowUp' || e.code === 'ArrowDown' || e.code === 'ArrowLeft' || e.code === 'ArrowRight') {\n      const parent = ref.current?.parentElement as HTMLElement;\n      const curIndex = Array.from(parent?.childNodes).indexOf(ref.current as HTMLElement);\n\n      switch (e.code) {\n        case 'ArrowUp':\n        case 'ArrowDown':\n          {\n            const sibling = (\n              e.code === 'ArrowUp' ? parent?.previousElementSibling : parent?.nextElementSibling\n            ) as HTMLElement;\n\n            if (parent?.nodeName === sibling?.nodeName) {\n              const nextFocus = sibling?.children[curIndex] as HTMLElement;\n\n              nextFocus?.focus();\n            }\n          }\n          break;\n\n        case 'ArrowLeft':\n          if (curIndex > 0) {\n            const prevSibling = parent?.children[curIndex - 1] as HTMLElement;\n            prevSibling?.focus();\n          } else {\n            const prevRow = parent?.previousElementSibling as HTMLElement;\n            if (parent?.nodeName === prevRow?.nodeName) {\n              const lastCell = prevRow.lastElementChild as HTMLElement;\n              lastCell?.focus();\n            }\n          }\n          break;\n        case 'ArrowRight':\n          if (curIndex < parent?.children.length - 1) {\n            const nextSibling = parent?.children[curIndex + 1] as HTMLElement;\n            nextSibling?.focus();\n          } else {\n            const nextRow = parent?.nextElementSibling as HTMLElement;\n            if (parent?.nodeName === nextRow?.nodeName) {\n              const firstCell = nextRow.firstElementChild as HTMLElement;\n              firstCell?.focus();\n            }\n          }\n          break;\n      }\n    }\n  };\n\n  const cellProps = {\n    ...rest,\n\n    onKeyDown,\n\n    style: {\n      verticalAlign,\n      textAlign,\n      writingMode,\n      userSelect,\n\n      padding: padding ?? sizePadding[size],\n\n      ...props.style,\n    },\n\n    'data-cell': true,\n    'data-disabled': isDisabled ? true : undefined,\n    'data-focused': isFocused ? true : undefined,\n    'data-error': error ? true : undefined,\n    'data-row-hover': isRowHover ? true : undefined,\n    'data-row-selected': isRowSelected ? true : undefined,\n    'data-bordered': isBordered ? true : undefined,\n    'data-shadowed': isShadowed ? true : undefined,\n    'data-resizing': isResizing ? true : undefined,\n    'data-active': isActive ? true : undefined,\n    'data-last-fixed': isLastFixed ? true : undefined,\n\n    [`data-${size.toLowerCase()}`]: true,\n    [`data-${columnArea.toLowerCase()}`]: true,\n  };\n\n  const caption = typeof error === 'string' ? <Caption>{error}</Caption> : null;\n\n  return (\n    <Cell ref={ref} tabIndex={0} {...cellProps}>\n      <Container>\n        {startAdornment}\n        {children}\n        {endAdornment}\n        <EditOnIcon data-edit-icon size={SizeTokenValue.Small} />\n      </Container>\n      {caption}\n    </Cell>\n  );\n});\n\nexport const DataGridTableCell: FRC<HTMLTableCellElement, DataGridTableCellProps & PropsWithChildren> = forwardRef(\n  (props, ref) => {\n    const resultProps = useDataGridTableCell(props.cell);\n\n    const contentProps = {\n      isMultiline: resultProps.isMultiline,\n      whiteSpace: resultProps.whiteSpace,\n      wordBreak: resultProps.wordBreak,\n    };\n\n    return (\n      <TableCell ref={ref} {...resultProps}>\n        <TableCellContent {...contentProps}>{props.children}</TableCellContent>\n      </TableCell>\n    );\n  }\n);\n\nexport const getDataGridTableCell = (cell: DataGridTableCellProps['cell']) => {\n  const content = flexRender(cell.column.columnDef.cell, cell.getContext());\n\n  if (cell.column.columnDef.meta?.isCustom) {\n    return <React.Fragment key={cell.id}>{content}</React.Fragment>;\n  }\n\n  return (\n    <DataGridTableCell key={cell.id} cell={cell}>\n      {content}\n    </DataGridTableCell>\n  );\n};\n\nexport * from './types';\n"]} */")), T = /* @__PURE__ */ d("div", process.env.NODE_ENV === "production" ? {
|
|
56
|
+
}), ";::after{display:block;}}::before{content:'';display:block;position:absolute;box-sizing:border-box;top:0;left:0;width:100%;height:100%;user-select:none;pointer-events:none;border-width:0 0 1px 0;border-style:solid;border-color:var(--border-color);}&[data-bordered]{::before{border-width:0 1px 1px 0;}:last-of-type::before{border-width:0 0 1px 0;}}&[data-resizing]{border-right:1px solid ", (I) => I.theme.colors.accent[20], ";}::after{content:'';display:none;position:absolute;box-sizing:border-box;top:0;left:0;width:100%;height:100%;user-select:none;pointer-events:none;border-width:2px;border-style:solid;border-radius:4px;border-color:var(--outline-color, transparent);}[data-edit-icon]{display:none;position:absolute;visibility:hidden;right:0;top:0;background-color:var(--background-color, transparent);}&[data-editable] [data-edit-icon]{display:block;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/sadykovsd/join-x5/packages/data-grid/src/TableCell/index.tsx"],"names":[],"mappings":"AAyBsB","file":"/home/sadykovsd/join-x5/packages/data-grid/src/TableCell/index.tsx","sourcesContent":["'use client';\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport {flexRender} from '@tanstack/react-table';\n\nimport {forwardRef, SizeTokenValue, useRefMerge} from '@join-x5/react-theme';\nimport {EditOnIcon} from '@join-x5/react-icons';\nimport {ColumnArea} from '@join-x5/react-data-grid-settings';\n\nimport {useDataGridTableCell} from './hook';\n\nimport type {HTMLAttributes, KeyboardEventHandler} from 'react';\nimport type {FRC, PropsWithChildren} from '@join-x5/react-theme';\nimport type {DataGridTableCellProps, TableCellProps} from './types';\n\nconst sizePadding: Record<SizeTokenValue, number> = {\n  [SizeTokenValue.XXSmall]: 8,\n  [SizeTokenValue.XSmall]: 8,\n  [SizeTokenValue.Small]: 8,\n  [SizeTokenValue.Medium]: 12,\n  [SizeTokenValue.Large]: 12,\n  [SizeTokenValue.XLarge]: 12,\n};\n\nconst Cell = styled.td`\n  position: relative;\n  box-sizing: border-box;\n  height: 1px;\n  border-radius: 0;\n  border-spacing: 0;\n  background-color: var(--background-color, transparent);\n\n  ${props => ({\n    color: props.theme.colors.grey[100],\n\n    '--background-color': props.theme.colors.white,\n    '--border-color': props.theme.colors.grey[10],\n  })};\n\n  &[data-${SizeTokenValue.Large.toLocaleLowerCase()}] {\n    min-height: 44px;\n\n    ${props => props.theme.typography.p1compact}\n  }\n\n  &[data-${SizeTokenValue.Medium.toLocaleLowerCase()}] {\n    min-height: 40px;\n\n    ${props => props.theme.typography.p2}\n  }\n\n  &[data-${SizeTokenValue.Small.toLocaleLowerCase()}] {\n    min-height: 32px;\n\n    ${props => props.theme.typography.p2}\n  }\n\n  &[data-${ColumnArea.FixedLeft.toLocaleLowerCase()}] {\n    position: sticky;\n    z-index: 1;\n\n    &[data-shadowed][data-last-fixed] {\n      filter: drop-shadow(8px 0px 8px rgba(80, 86, 94, 0.08));\n    }\n  }\n\n  &[data-${ColumnArea.FixedRight.toLocaleLowerCase()}] {\n    position: sticky;\n    z-index: 1;\n\n    &[data-shadowed][data-last-fixed] {\n      filter: drop-shadow(-8px 0px 8px rgba(80, 86, 94, 0.08));\n    }\n  }\n\n  &[data-row-hover] {\n    ${props => ({\n      '--background-color': props.theme.colors.grey[10],\n      '--border-color': props.theme.colors.grey[20],\n    })}\n  }\n\n  :hover {\n    ${props => ({\n      '--background-color': props.theme.colors.grey[10],\n      '--border-color': props.theme.colors.grey[40],\n    })}\n  }\n\n  :not([data-disabled]):hover::before {\n    border-width: 1px;\n  }\n\n  &[data-disabled] {\n    :hover {\n      ${props => ({\n        '--background-color': props.theme.colors.grey[10],\n        '--border-color': props.theme.colors.grey[20],\n      })}\n    }\n\n    ${props => ({\n      color: props.theme.colors.grey[40],\n    })}\n  }\n\n  &[data-row-selected] {\n    ${props => ({\n      '--background-color': props.theme.colors.accent[10],\n      '--border-color': props.theme.colors.accent[20],\n    })}\n  }\n\n  :focus {\n    outline: none;\n  }\n\n  &[data-focused],\n  :focus:not([data-no-focus]) {\n    ::before {\n      display: none;\n    }\n\n    ::after {\n      display: block;\n    }\n\n    [data-edit-icon] {\n      visibility: visible;\n    }\n\n    ${props => ({\n      '--border-color': 'transparent',\n      '--background-color': props.theme.colors.white,\n      '--outline-color': props.theme.colors.accent[90],\n    })}\n  }\n\n  &[data-active] {\n    outline: none;\n\n    ::before {\n      display: none;\n    }\n\n    ::after {\n      display: block;\n    }\n\n    [data-edit-icon] {\n      visibility: hidden;\n    }\n\n    ${props => ({\n      '--border-color': 'transparent',\n      '--background-color': props.theme.colors.white,\n      '--outline-color': props.theme.colors.accent[90],\n    })}\n  }\n\n  &[data-error] {\n    ::after {\n      display: block;\n    }\n\n    ${props => ({\n      caretColor: props.theme.colors.additional.red[80],\n\n      '--background-color': props.theme.colors.white,\n      '--border-color': 'transparent',\n      '--outline-color': props.theme.colors.additional.red[80],\n    })}\n  }\n\n  ::before {\n    content: '';\n    display: block;\n    position: absolute;\n    box-sizing: border-box;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%;\n    user-select: none;\n    pointer-events: none;\n    border-width: 0 0 1px 0;\n    border-style: solid;\n    border-color: var(--border-color);\n  }\n\n  &[data-bordered] {\n    ::before {\n      border-width: 0 1px 1px 0;\n    }\n\n    :last-of-type::before {\n      border-width: 0 0 1px 0;\n    }\n  }\n\n  &[data-resizing] {\n    border-right: 1px solid ${props => props.theme.colors.accent[20]};\n  }\n\n  ::after {\n    content: '';\n    display: none;\n    position: absolute;\n    box-sizing: border-box;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%;\n    user-select: none;\n    pointer-events: none;\n    border-width: 2px;\n    border-style: solid;\n    border-radius: 4px;\n    border-color: var(--outline-color, transparent);\n  }\n\n  [data-edit-icon] {\n    display: none;\n    position: absolute;\n    visibility: hidden;\n    right: 0;\n    top: 0;\n    background-color: var(--background-color, transparent);\n  }\n\n  &[data-editable] [data-edit-icon] {\n    display: block;\n  }\n`;\n\nconst Container = styled.div`\n  display: flex;\n  position: relative;\n  box-sizing: border-box;\n  gap: 8px;\n`;\n\nconst Content = styled.div`\n  position: relative;\n  flex-grow: 1;\n  word-break: break-word;\n\n  :not([data-is-multiline]) {\n    overflow: hidden;\n    text-overflow: ellipsis;\n    white-space: nowrap;\n  }\n`;\n\nconst Caption = styled.div`\n  padding: 4px 0 0;\n  width: 100%;\n  word-break: break-all;\n\n  ${props => ({\n    ...props.theme.typography.p3,\n\n    color: props.theme.colors.additional.red[80],\n  })}\n`;\n\ntype TableCellContentProps = Partial<Pick<TableCellProps, 'children' | 'isMultiline' | 'whiteSpace' | 'wordBreak'>> &\n  HTMLAttributes<HTMLDivElement>;\n\nexport const TableCellContent: FRC<HTMLDivElement, TableCellContentProps> = forwardRef((props, ref) => {\n  const {children, style, isMultiline, whiteSpace, wordBreak = 'break-word', ...rest} = props;\n\n  const contentProps = {\n    ...rest,\n\n    style: {\n      whiteSpace,\n      wordBreak,\n\n      ...style,\n    },\n\n    'data-content': true,\n    'data-is-multiline': isMultiline ? true : undefined,\n  };\n\n  return (\n    <Content ref={ref} {...contentProps}>\n      {children}\n    </Content>\n  );\n});\n\nexport const TableCell: FRC<HTMLTableCellElement, TableCellProps> = forwardRef((props, baseRef) => {\n  const ref = useRefMerge(baseRef);\n\n  const {\n    children,\n\n    isDisabled,\n    isRowHover,\n    isRowSelected,\n    isBordered,\n    isShadowed,\n    isNoFocus,\n    isFocused,\n    isActive,\n    isResizing,\n    isLastFixed,\n    error,\n\n    textAlign,\n    writingMode,\n    verticalAlign,\n    padding,\n    userSelect = 'none',\n\n    startAdornment,\n    endAdornment,\n\n    size = SizeTokenValue.Medium,\n    columnArea = ColumnArea.Default,\n\n    ...rest\n  } = props;\n\n  const onKeyDown: KeyboardEventHandler<HTMLTableCellElement> = e => {\n    props.onKeyDown?.(e);\n\n    const isEnterCode = e.code === 'Enter' || e.code === 'NumpadEnter';\n\n    if (isEnterCode) {\n      const child = ref.current?.querySelector('[data-action]') as HTMLElement;\n\n      if (isEnterCode && child) {\n        child.click();\n      }\n\n      return;\n    }\n\n    if (e.code === 'Escape') {\n      ref.current?.blur();\n      return;\n    }\n\n    const isNavigation =\n      e.code === 'ArrowUp' || e.code === 'ArrowDown' || e.code === 'ArrowLeft' || e.code === 'ArrowRight';\n\n    if (isNavigation && !isNoFocus) {\n      const parent = ref.current?.parentElement as HTMLElement;\n      const curIndex = Array.from(parent?.childNodes).indexOf(ref.current as HTMLElement);\n\n      switch (e.code) {\n        case 'ArrowUp':\n        case 'ArrowDown':\n          {\n            const sibling = (\n              e.code === 'ArrowUp' ? parent?.previousElementSibling : parent?.nextElementSibling\n            ) as HTMLElement;\n\n            if (parent?.nodeName === sibling?.nodeName) {\n              const nextFocus = sibling?.children[curIndex] as HTMLElement;\n\n              nextFocus?.focus();\n            }\n          }\n          break;\n\n        case 'ArrowLeft':\n          if (curIndex > 0) {\n            const prevSibling = parent?.children[curIndex - 1] as HTMLElement;\n            prevSibling?.focus();\n          } else {\n            const prevRow = parent?.previousElementSibling as HTMLElement;\n            if (parent?.nodeName === prevRow?.nodeName) {\n              const lastCell = prevRow.lastElementChild as HTMLElement;\n              lastCell?.focus();\n            }\n          }\n          break;\n        case 'ArrowRight':\n          if (curIndex < parent?.children.length - 1) {\n            const nextSibling = parent?.children[curIndex + 1] as HTMLElement;\n            nextSibling?.focus();\n          } else {\n            const nextRow = parent?.nextElementSibling as HTMLElement;\n            if (parent?.nodeName === nextRow?.nodeName) {\n              const firstCell = nextRow.firstElementChild as HTMLElement;\n              firstCell?.focus();\n            }\n          }\n          break;\n      }\n    }\n  };\n\n  const cellProps = {\n    ...rest,\n\n    onKeyDown,\n\n    style: {\n      verticalAlign,\n      textAlign,\n      writingMode,\n      userSelect,\n\n      padding: padding ?? sizePadding[size],\n\n      ...props.style,\n    },\n\n    'data-cell': true,\n    'data-disabled': isDisabled ? true : undefined,\n    'data-focused': isFocused ? true : undefined,\n    'data-error': error ? true : undefined,\n    'data-row-hover': isRowHover ? true : undefined,\n    'data-row-selected': isRowSelected ? true : undefined,\n    'data-bordered': isBordered ? true : undefined,\n    'data-shadowed': isShadowed ? true : undefined,\n    'data-no-focus': isNoFocus ? true : undefined,\n    'data-resizing': isResizing ? true : undefined,\n    'data-active': isActive ? true : undefined,\n    'data-last-fixed': isLastFixed ? true : undefined,\n\n    [`data-${size.toLowerCase()}`]: true,\n    [`data-${columnArea.toLowerCase()}`]: true,\n  };\n\n  const caption = typeof error === 'string' ? <Caption>{error}</Caption> : null;\n\n  return (\n    <Cell ref={ref} tabIndex={0} {...cellProps}>\n      <Container>\n        {startAdornment}\n        {children}\n        {endAdornment}\n        <EditOnIcon data-edit-icon size={SizeTokenValue.Small} />\n      </Container>\n      {caption}\n    </Cell>\n  );\n});\n\nexport const DataGridTableCell: FRC<HTMLTableCellElement, DataGridTableCellProps & PropsWithChildren> = forwardRef(\n  (props, ref) => {\n    const resultProps = useDataGridTableCell(props.cell);\n\n    const contentProps = {\n      isMultiline: resultProps.isMultiline,\n      whiteSpace: resultProps.whiteSpace,\n      wordBreak: resultProps.wordBreak,\n    };\n\n    return (\n      <TableCell ref={ref} {...resultProps}>\n        <TableCellContent {...contentProps}>{props.children}</TableCellContent>\n      </TableCell>\n    );\n  }\n);\n\nexport const getDataGridTableCell = (cell: DataGridTableCellProps['cell']) => {\n  const content = flexRender(cell.column.columnDef.cell, cell.getContext());\n\n  if (cell.column.columnDef.meta?.isCustom) {\n    return <React.Fragment key={cell.id}>{content}</React.Fragment>;\n  }\n\n  return (\n    <DataGridTableCell key={cell.id} cell={cell}>\n      {content}\n    </DataGridTableCell>\n  );\n};\n\nexport * from './types';\n"]} */")), E = /* @__PURE__ */ X("div", process.env.NODE_ENV === "production" ? {
|
|
57
57
|
target: "e1enoxlq2"
|
|
58
58
|
} : {
|
|
59
59
|
target: "e1enoxlq2",
|
|
@@ -63,9 +63,9 @@ const M = {
|
|
|
63
63
|
styles: "display:flex;position:relative;box-sizing:border-box;gap:8px"
|
|
64
64
|
} : {
|
|
65
65
|
name: "15dbgh0",
|
|
66
|
-
styles: "display:flex;position:relative;box-sizing:border-box;gap:8px/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/sadykovsd/join-x5/packages/data-grid/src/TableCell/index.tsx"],"names":[],"mappings":"AA0O4B","file":"/home/sadykovsd/join-x5/packages/data-grid/src/TableCell/index.tsx","sourcesContent":["'use client';\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport {flexRender} from '@tanstack/react-table';\n\nimport {forwardRef, SizeTokenValue, useRefMerge} from '@join-x5/react-theme';\nimport {EditOnIcon} from '@join-x5/react-icons';\nimport {ColumnArea} from '@join-x5/react-data-grid-settings';\n\nimport {useDataGridTableCell} from './hook';\n\nimport type {HTMLAttributes, KeyboardEventHandler} from 'react';\nimport type {FRC, PropsWithChildren} from '@join-x5/react-theme';\nimport type {DataGridTableCellProps, TableCellProps} from './types';\n\nconst sizePadding: Record<SizeTokenValue, number> = {\n  [SizeTokenValue.XXSmall]: 8,\n  [SizeTokenValue.XSmall]: 8,\n  [SizeTokenValue.Small]: 8,\n  [SizeTokenValue.Medium]: 12,\n  [SizeTokenValue.Large]: 12,\n  [SizeTokenValue.XLarge]: 12,\n};\n\nconst Cell = styled.td`\n  position: relative;\n  box-sizing: border-box;\n  height: 1px;\n  border-radius: 0;\n  border-spacing: 0;\n  background-color: var(--background-color, transparent);\n\n  ${props => ({\n    color: props.theme.colors.grey[100],\n\n    '--background-color': props.theme.colors.white,\n    '--border-color': props.theme.colors.grey[10],\n  })};\n\n  &[data-${SizeTokenValue.Large.toLocaleLowerCase()}] {\n    min-height: 44px;\n\n    ${props => props.theme.typography.p1compact}\n  }\n\n  &[data-${SizeTokenValue.Medium.toLocaleLowerCase()}] {\n    min-height: 40px;\n\n    ${props => props.theme.typography.p2}\n  }\n\n  &[data-${SizeTokenValue.Small.toLocaleLowerCase()}] {\n    min-height: 32px;\n\n    ${props => props.theme.typography.p2}\n  }\n\n  &[data-${ColumnArea.FixedLeft.toLocaleLowerCase()}] {\n    position: sticky;\n    z-index: 1;\n\n    &[data-shadowed][data-last-fixed] {\n      filter: drop-shadow(8px 0px 8px rgba(80, 86, 94, 0.08));\n    }\n  }\n\n  &[data-${ColumnArea.FixedRight.toLocaleLowerCase()}] {\n    position: sticky;\n    z-index: 1;\n\n    &[data-shadowed][data-last-fixed] {\n      filter: drop-shadow(-8px 0px 8px rgba(80, 86, 94, 0.08));\n    }\n  }\n\n  &[data-row-hover] {\n    ${props => ({\n      '--background-color': props.theme.colors.grey[10],\n      '--border-color': props.theme.colors.grey[20],\n    })}\n  }\n\n  :hover {\n    ${props => ({\n      '--background-color': props.theme.colors.grey[10],\n      '--border-color': props.theme.colors.grey[40],\n    })}\n  }\n\n  :not([data-disabled]):hover::before {\n    border-width: 1px;\n  }\n\n  &[data-disabled] {\n    :hover {\n      ${props => ({\n        '--background-color': props.theme.colors.grey[10],\n        '--border-color': props.theme.colors.grey[20],\n      })}\n    }\n\n    ${props => ({\n      color: props.theme.colors.grey[40],\n    })}\n  }\n\n  &[data-row-selected] {\n    ${props => ({\n      '--background-color': props.theme.colors.accent[10],\n      '--border-color': props.theme.colors.accent[20],\n    })}\n  }\n\n  &[data-focused],\n  :focus {\n    outline: none;\n\n    ::before {\n      display: none;\n    }\n\n    ::after {\n      display: block;\n    }\n\n    [data-edit-icon] {\n      visibility: visible;\n    }\n\n    ${props => ({\n      '--border-color': 'transparent',\n      '--background-color': props.theme.colors.white,\n      '--outline-color': props.theme.colors.accent[90],\n    })}\n  }\n\n  &[data-active] {\n    outline: none;\n\n    ::before {\n      display: none;\n    }\n\n    ::after {\n      display: block;\n    }\n\n    [data-edit-icon] {\n      visibility: hidden;\n    }\n\n    ${props => ({\n      '--border-color': 'transparent',\n      '--background-color': props.theme.colors.white,\n      '--outline-color': props.theme.colors.accent[90],\n    })}\n  }\n\n  &[data-error] {\n    ::after {\n      display: block;\n    }\n\n    ${props => ({\n      caretColor: props.theme.colors.additional.red[80],\n\n      '--background-color': props.theme.colors.white,\n      '--border-color': 'transparent',\n      '--outline-color': props.theme.colors.additional.red[80],\n    })}\n  }\n\n  ::before {\n    content: '';\n    display: block;\n    position: absolute;\n    box-sizing: border-box;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%;\n    user-select: none;\n    pointer-events: none;\n    border-width: 0 0 1px 0;\n    border-style: solid;\n    border-color: var(--border-color);\n  }\n\n  &[data-bordered] {\n    ::before {\n      border-width: 0 1px 1px 0;\n    }\n\n    :last-of-type::before {\n      border-width: 0 0 1px 0;\n    }\n  }\n\n  &[data-resizing] {\n    border-right: 1px solid ${props => props.theme.colors.accent[20]};\n  }\n\n  ::after {\n    content: '';\n    display: none;\n    position: absolute;\n    box-sizing: border-box;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%;\n    user-select: none;\n    pointer-events: none;\n    border-width: 2px;\n    border-style: solid;\n    border-radius: 4px;\n    border-color: var(--outline-color, transparent);\n  }\n\n  [data-edit-icon] {\n    display: none;\n    position: absolute;\n    visibility: hidden;\n    right: 0;\n    top: 0;\n    background-color: var(--background-color, transparent);\n  }\n\n  &[data-editable] [data-edit-icon] {\n    display: block;\n  }\n`;\n\nconst Container = styled.div`\n  display: flex;\n  position: relative;\n  box-sizing: border-box;\n  gap: 8px;\n`;\n\nconst Content = styled.div`\n  position: relative;\n  flex-grow: 1;\n  word-break: break-word;\n\n  :not([data-is-multiline]) {\n    overflow: hidden;\n    text-overflow: ellipsis;\n    white-space: nowrap;\n  }\n`;\n\nconst Caption = styled.div`\n  padding: 4px 0 0;\n  width: 100%;\n  word-break: break-all;\n\n  ${props => ({\n    ...props.theme.typography.p3,\n\n    color: props.theme.colors.additional.red[80],\n  })}\n`;\n\ntype TableCellContentProps = Partial<Pick<TableCellProps, 'children' | 'isMultiline' | 'whiteSpace' | 'wordBreak'>> &\n  HTMLAttributes<HTMLDivElement>;\n\nexport const TableCellContent: FRC<HTMLDivElement, TableCellContentProps> = forwardRef((props, ref) => {\n  const {children, style, isMultiline, whiteSpace, wordBreak = 'break-word', ...rest} = props;\n\n  const contentProps = {\n    ...rest,\n\n    style: {\n      whiteSpace,\n      wordBreak,\n\n      ...style,\n    },\n\n    'data-content': true,\n    'data-is-multiline': isMultiline ? true : undefined,\n  };\n\n  return (\n    <Content ref={ref} {...contentProps}>\n      {children}\n    </Content>\n  );\n});\n\nexport const TableCell: FRC<HTMLTableCellElement, TableCellProps> = forwardRef((props, baseRef) => {\n  const ref = useRefMerge(baseRef);\n\n  const {\n    children,\n\n    isDisabled,\n    isRowHover,\n    isRowSelected,\n    isBordered,\n    isShadowed,\n    isFocused,\n    isActive,\n    isResizing,\n    isLastFixed,\n    error,\n\n    textAlign,\n    writingMode,\n    verticalAlign,\n    padding,\n    userSelect = 'none',\n\n    startAdornment,\n    endAdornment,\n\n    size = SizeTokenValue.Medium,\n    columnArea = ColumnArea.Default,\n\n    ...rest\n  } = props;\n\n  const onKeyDown: KeyboardEventHandler<HTMLTableCellElement> = e => {\n    props.onKeyDown?.(e);\n\n    const isEnterCode = e.code === 'Enter' || e.code === 'NumpadEnter';\n\n    if (isEnterCode) {\n      const child = ref.current?.querySelector('[data-action]') as HTMLElement;\n\n      if (isEnterCode && child) {\n        child.click();\n      }\n\n      return;\n    }\n\n    if (e.code === 'Escape') {\n      ref.current?.blur();\n      return;\n    }\n\n    if (e.code === 'ArrowUp' || e.code === 'ArrowDown' || e.code === 'ArrowLeft' || e.code === 'ArrowRight') {\n      const parent = ref.current?.parentElement as HTMLElement;\n      const curIndex = Array.from(parent?.childNodes).indexOf(ref.current as HTMLElement);\n\n      switch (e.code) {\n        case 'ArrowUp':\n        case 'ArrowDown':\n          {\n            const sibling = (\n              e.code === 'ArrowUp' ? parent?.previousElementSibling : parent?.nextElementSibling\n            ) as HTMLElement;\n\n            if (parent?.nodeName === sibling?.nodeName) {\n              const nextFocus = sibling?.children[curIndex] as HTMLElement;\n\n              nextFocus?.focus();\n            }\n          }\n          break;\n\n        case 'ArrowLeft':\n          if (curIndex > 0) {\n            const prevSibling = parent?.children[curIndex - 1] as HTMLElement;\n            prevSibling?.focus();\n          } else {\n            const prevRow = parent?.previousElementSibling as HTMLElement;\n            if (parent?.nodeName === prevRow?.nodeName) {\n              const lastCell = prevRow.lastElementChild as HTMLElement;\n              lastCell?.focus();\n            }\n          }\n          break;\n        case 'ArrowRight':\n          if (curIndex < parent?.children.length - 1) {\n            const nextSibling = parent?.children[curIndex + 1] as HTMLElement;\n            nextSibling?.focus();\n          } else {\n            const nextRow = parent?.nextElementSibling as HTMLElement;\n            if (parent?.nodeName === nextRow?.nodeName) {\n              const firstCell = nextRow.firstElementChild as HTMLElement;\n              firstCell?.focus();\n            }\n          }\n          break;\n      }\n    }\n  };\n\n  const cellProps = {\n    ...rest,\n\n    onKeyDown,\n\n    style: {\n      verticalAlign,\n      textAlign,\n      writingMode,\n      userSelect,\n\n      padding: padding ?? sizePadding[size],\n\n      ...props.style,\n    },\n\n    'data-cell': true,\n    'data-disabled': isDisabled ? true : undefined,\n    'data-focused': isFocused ? true : undefined,\n    'data-error': error ? true : undefined,\n    'data-row-hover': isRowHover ? true : undefined,\n    'data-row-selected': isRowSelected ? true : undefined,\n    'data-bordered': isBordered ? true : undefined,\n    'data-shadowed': isShadowed ? true : undefined,\n    'data-resizing': isResizing ? true : undefined,\n    'data-active': isActive ? true : undefined,\n    'data-last-fixed': isLastFixed ? true : undefined,\n\n    [`data-${size.toLowerCase()}`]: true,\n    [`data-${columnArea.toLowerCase()}`]: true,\n  };\n\n  const caption = typeof error === 'string' ? <Caption>{error}</Caption> : null;\n\n  return (\n    <Cell ref={ref} tabIndex={0} {...cellProps}>\n      <Container>\n        {startAdornment}\n        {children}\n        {endAdornment}\n        <EditOnIcon data-edit-icon size={SizeTokenValue.Small} />\n      </Container>\n      {caption}\n    </Cell>\n  );\n});\n\nexport const DataGridTableCell: FRC<HTMLTableCellElement, DataGridTableCellProps & PropsWithChildren> = forwardRef(\n  (props, ref) => {\n    const resultProps = useDataGridTableCell(props.cell);\n\n    const contentProps = {\n      isMultiline: resultProps.isMultiline,\n      whiteSpace: resultProps.whiteSpace,\n      wordBreak: resultProps.wordBreak,\n    };\n\n    return (\n      <TableCell ref={ref} {...resultProps}>\n        <TableCellContent {...contentProps}>{props.children}</TableCellContent>\n      </TableCell>\n    );\n  }\n);\n\nexport const getDataGridTableCell = (cell: DataGridTableCellProps['cell']) => {\n  const content = flexRender(cell.column.columnDef.cell, cell.getContext());\n\n  if (cell.column.columnDef.meta?.isCustom) {\n    return <React.Fragment key={cell.id}>{content}</React.Fragment>;\n  }\n\n  return (\n    <DataGridTableCell key={cell.id} cell={cell}>\n      {content}\n    </DataGridTableCell>\n  );\n};\n\nexport * from './types';\n"]} */",
|
|
67
|
-
toString:
|
|
68
|
-
}),
|
|
66
|
+
styles: "display:flex;position:relative;box-sizing:border-box;gap:8px/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/sadykovsd/join-x5/packages/data-grid/src/TableCell/index.tsx"],"names":[],"mappings":"AA4O4B","file":"/home/sadykovsd/join-x5/packages/data-grid/src/TableCell/index.tsx","sourcesContent":["'use client';\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport {flexRender} from '@tanstack/react-table';\n\nimport {forwardRef, SizeTokenValue, useRefMerge} from '@join-x5/react-theme';\nimport {EditOnIcon} from '@join-x5/react-icons';\nimport {ColumnArea} from '@join-x5/react-data-grid-settings';\n\nimport {useDataGridTableCell} from './hook';\n\nimport type {HTMLAttributes, KeyboardEventHandler} from 'react';\nimport type {FRC, PropsWithChildren} from '@join-x5/react-theme';\nimport type {DataGridTableCellProps, TableCellProps} from './types';\n\nconst sizePadding: Record<SizeTokenValue, number> = {\n  [SizeTokenValue.XXSmall]: 8,\n  [SizeTokenValue.XSmall]: 8,\n  [SizeTokenValue.Small]: 8,\n  [SizeTokenValue.Medium]: 12,\n  [SizeTokenValue.Large]: 12,\n  [SizeTokenValue.XLarge]: 12,\n};\n\nconst Cell = styled.td`\n  position: relative;\n  box-sizing: border-box;\n  height: 1px;\n  border-radius: 0;\n  border-spacing: 0;\n  background-color: var(--background-color, transparent);\n\n  ${props => ({\n    color: props.theme.colors.grey[100],\n\n    '--background-color': props.theme.colors.white,\n    '--border-color': props.theme.colors.grey[10],\n  })};\n\n  &[data-${SizeTokenValue.Large.toLocaleLowerCase()}] {\n    min-height: 44px;\n\n    ${props => props.theme.typography.p1compact}\n  }\n\n  &[data-${SizeTokenValue.Medium.toLocaleLowerCase()}] {\n    min-height: 40px;\n\n    ${props => props.theme.typography.p2}\n  }\n\n  &[data-${SizeTokenValue.Small.toLocaleLowerCase()}] {\n    min-height: 32px;\n\n    ${props => props.theme.typography.p2}\n  }\n\n  &[data-${ColumnArea.FixedLeft.toLocaleLowerCase()}] {\n    position: sticky;\n    z-index: 1;\n\n    &[data-shadowed][data-last-fixed] {\n      filter: drop-shadow(8px 0px 8px rgba(80, 86, 94, 0.08));\n    }\n  }\n\n  &[data-${ColumnArea.FixedRight.toLocaleLowerCase()}] {\n    position: sticky;\n    z-index: 1;\n\n    &[data-shadowed][data-last-fixed] {\n      filter: drop-shadow(-8px 0px 8px rgba(80, 86, 94, 0.08));\n    }\n  }\n\n  &[data-row-hover] {\n    ${props => ({\n      '--background-color': props.theme.colors.grey[10],\n      '--border-color': props.theme.colors.grey[20],\n    })}\n  }\n\n  :hover {\n    ${props => ({\n      '--background-color': props.theme.colors.grey[10],\n      '--border-color': props.theme.colors.grey[40],\n    })}\n  }\n\n  :not([data-disabled]):hover::before {\n    border-width: 1px;\n  }\n\n  &[data-disabled] {\n    :hover {\n      ${props => ({\n        '--background-color': props.theme.colors.grey[10],\n        '--border-color': props.theme.colors.grey[20],\n      })}\n    }\n\n    ${props => ({\n      color: props.theme.colors.grey[40],\n    })}\n  }\n\n  &[data-row-selected] {\n    ${props => ({\n      '--background-color': props.theme.colors.accent[10],\n      '--border-color': props.theme.colors.accent[20],\n    })}\n  }\n\n  :focus {\n    outline: none;\n  }\n\n  &[data-focused],\n  :focus:not([data-no-focus]) {\n    ::before {\n      display: none;\n    }\n\n    ::after {\n      display: block;\n    }\n\n    [data-edit-icon] {\n      visibility: visible;\n    }\n\n    ${props => ({\n      '--border-color': 'transparent',\n      '--background-color': props.theme.colors.white,\n      '--outline-color': props.theme.colors.accent[90],\n    })}\n  }\n\n  &[data-active] {\n    outline: none;\n\n    ::before {\n      display: none;\n    }\n\n    ::after {\n      display: block;\n    }\n\n    [data-edit-icon] {\n      visibility: hidden;\n    }\n\n    ${props => ({\n      '--border-color': 'transparent',\n      '--background-color': props.theme.colors.white,\n      '--outline-color': props.theme.colors.accent[90],\n    })}\n  }\n\n  &[data-error] {\n    ::after {\n      display: block;\n    }\n\n    ${props => ({\n      caretColor: props.theme.colors.additional.red[80],\n\n      '--background-color': props.theme.colors.white,\n      '--border-color': 'transparent',\n      '--outline-color': props.theme.colors.additional.red[80],\n    })}\n  }\n\n  ::before {\n    content: '';\n    display: block;\n    position: absolute;\n    box-sizing: border-box;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%;\n    user-select: none;\n    pointer-events: none;\n    border-width: 0 0 1px 0;\n    border-style: solid;\n    border-color: var(--border-color);\n  }\n\n  &[data-bordered] {\n    ::before {\n      border-width: 0 1px 1px 0;\n    }\n\n    :last-of-type::before {\n      border-width: 0 0 1px 0;\n    }\n  }\n\n  &[data-resizing] {\n    border-right: 1px solid ${props => props.theme.colors.accent[20]};\n  }\n\n  ::after {\n    content: '';\n    display: none;\n    position: absolute;\n    box-sizing: border-box;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%;\n    user-select: none;\n    pointer-events: none;\n    border-width: 2px;\n    border-style: solid;\n    border-radius: 4px;\n    border-color: var(--outline-color, transparent);\n  }\n\n  [data-edit-icon] {\n    display: none;\n    position: absolute;\n    visibility: hidden;\n    right: 0;\n    top: 0;\n    background-color: var(--background-color, transparent);\n  }\n\n  &[data-editable] [data-edit-icon] {\n    display: block;\n  }\n`;\n\nconst Container = styled.div`\n  display: flex;\n  position: relative;\n  box-sizing: border-box;\n  gap: 8px;\n`;\n\nconst Content = styled.div`\n  position: relative;\n  flex-grow: 1;\n  word-break: break-word;\n\n  :not([data-is-multiline]) {\n    overflow: hidden;\n    text-overflow: ellipsis;\n    white-space: nowrap;\n  }\n`;\n\nconst Caption = styled.div`\n  padding: 4px 0 0;\n  width: 100%;\n  word-break: break-all;\n\n  ${props => ({\n    ...props.theme.typography.p3,\n\n    color: props.theme.colors.additional.red[80],\n  })}\n`;\n\ntype TableCellContentProps = Partial<Pick<TableCellProps, 'children' | 'isMultiline' | 'whiteSpace' | 'wordBreak'>> &\n  HTMLAttributes<HTMLDivElement>;\n\nexport const TableCellContent: FRC<HTMLDivElement, TableCellContentProps> = forwardRef((props, ref) => {\n  const {children, style, isMultiline, whiteSpace, wordBreak = 'break-word', ...rest} = props;\n\n  const contentProps = {\n    ...rest,\n\n    style: {\n      whiteSpace,\n      wordBreak,\n\n      ...style,\n    },\n\n    'data-content': true,\n    'data-is-multiline': isMultiline ? true : undefined,\n  };\n\n  return (\n    <Content ref={ref} {...contentProps}>\n      {children}\n    </Content>\n  );\n});\n\nexport const TableCell: FRC<HTMLTableCellElement, TableCellProps> = forwardRef((props, baseRef) => {\n  const ref = useRefMerge(baseRef);\n\n  const {\n    children,\n\n    isDisabled,\n    isRowHover,\n    isRowSelected,\n    isBordered,\n    isShadowed,\n    isNoFocus,\n    isFocused,\n    isActive,\n    isResizing,\n    isLastFixed,\n    error,\n\n    textAlign,\n    writingMode,\n    verticalAlign,\n    padding,\n    userSelect = 'none',\n\n    startAdornment,\n    endAdornment,\n\n    size = SizeTokenValue.Medium,\n    columnArea = ColumnArea.Default,\n\n    ...rest\n  } = props;\n\n  const onKeyDown: KeyboardEventHandler<HTMLTableCellElement> = e => {\n    props.onKeyDown?.(e);\n\n    const isEnterCode = e.code === 'Enter' || e.code === 'NumpadEnter';\n\n    if (isEnterCode) {\n      const child = ref.current?.querySelector('[data-action]') as HTMLElement;\n\n      if (isEnterCode && child) {\n        child.click();\n      }\n\n      return;\n    }\n\n    if (e.code === 'Escape') {\n      ref.current?.blur();\n      return;\n    }\n\n    const isNavigation =\n      e.code === 'ArrowUp' || e.code === 'ArrowDown' || e.code === 'ArrowLeft' || e.code === 'ArrowRight';\n\n    if (isNavigation && !isNoFocus) {\n      const parent = ref.current?.parentElement as HTMLElement;\n      const curIndex = Array.from(parent?.childNodes).indexOf(ref.current as HTMLElement);\n\n      switch (e.code) {\n        case 'ArrowUp':\n        case 'ArrowDown':\n          {\n            const sibling = (\n              e.code === 'ArrowUp' ? parent?.previousElementSibling : parent?.nextElementSibling\n            ) as HTMLElement;\n\n            if (parent?.nodeName === sibling?.nodeName) {\n              const nextFocus = sibling?.children[curIndex] as HTMLElement;\n\n              nextFocus?.focus();\n            }\n          }\n          break;\n\n        case 'ArrowLeft':\n          if (curIndex > 0) {\n            const prevSibling = parent?.children[curIndex - 1] as HTMLElement;\n            prevSibling?.focus();\n          } else {\n            const prevRow = parent?.previousElementSibling as HTMLElement;\n            if (parent?.nodeName === prevRow?.nodeName) {\n              const lastCell = prevRow.lastElementChild as HTMLElement;\n              lastCell?.focus();\n            }\n          }\n          break;\n        case 'ArrowRight':\n          if (curIndex < parent?.children.length - 1) {\n            const nextSibling = parent?.children[curIndex + 1] as HTMLElement;\n            nextSibling?.focus();\n          } else {\n            const nextRow = parent?.nextElementSibling as HTMLElement;\n            if (parent?.nodeName === nextRow?.nodeName) {\n              const firstCell = nextRow.firstElementChild as HTMLElement;\n              firstCell?.focus();\n            }\n          }\n          break;\n      }\n    }\n  };\n\n  const cellProps = {\n    ...rest,\n\n    onKeyDown,\n\n    style: {\n      verticalAlign,\n      textAlign,\n      writingMode,\n      userSelect,\n\n      padding: padding ?? sizePadding[size],\n\n      ...props.style,\n    },\n\n    'data-cell': true,\n    'data-disabled': isDisabled ? true : undefined,\n    'data-focused': isFocused ? true : undefined,\n    'data-error': error ? true : undefined,\n    'data-row-hover': isRowHover ? true : undefined,\n    'data-row-selected': isRowSelected ? true : undefined,\n    'data-bordered': isBordered ? true : undefined,\n    'data-shadowed': isShadowed ? true : undefined,\n    'data-no-focus': isNoFocus ? true : undefined,\n    'data-resizing': isResizing ? true : undefined,\n    'data-active': isActive ? true : undefined,\n    'data-last-fixed': isLastFixed ? true : undefined,\n\n    [`data-${size.toLowerCase()}`]: true,\n    [`data-${columnArea.toLowerCase()}`]: true,\n  };\n\n  const caption = typeof error === 'string' ? <Caption>{error}</Caption> : null;\n\n  return (\n    <Cell ref={ref} tabIndex={0} {...cellProps}>\n      <Container>\n        {startAdornment}\n        {children}\n        {endAdornment}\n        <EditOnIcon data-edit-icon size={SizeTokenValue.Small} />\n      </Container>\n      {caption}\n    </Cell>\n  );\n});\n\nexport const DataGridTableCell: FRC<HTMLTableCellElement, DataGridTableCellProps & PropsWithChildren> = forwardRef(\n  (props, ref) => {\n    const resultProps = useDataGridTableCell(props.cell);\n\n    const contentProps = {\n      isMultiline: resultProps.isMultiline,\n      whiteSpace: resultProps.whiteSpace,\n      wordBreak: resultProps.wordBreak,\n    };\n\n    return (\n      <TableCell ref={ref} {...resultProps}>\n        <TableCellContent {...contentProps}>{props.children}</TableCellContent>\n      </TableCell>\n    );\n  }\n);\n\nexport const getDataGridTableCell = (cell: DataGridTableCellProps['cell']) => {\n  const content = flexRender(cell.column.columnDef.cell, cell.getContext());\n\n  if (cell.column.columnDef.meta?.isCustom) {\n    return <React.Fragment key={cell.id}>{content}</React.Fragment>;\n  }\n\n  return (\n    <DataGridTableCell key={cell.id} cell={cell}>\n      {content}\n    </DataGridTableCell>\n  );\n};\n\nexport * from './types';\n"]} */",
|
|
67
|
+
toString: y
|
|
68
|
+
}), P = /* @__PURE__ */ X("div", process.env.NODE_ENV === "production" ? {
|
|
69
69
|
target: "e1enoxlq1"
|
|
70
70
|
} : {
|
|
71
71
|
target: "e1enoxlq1",
|
|
@@ -75,9 +75,9 @@ const M = {
|
|
|
75
75
|
styles: "position:relative;flex-grow:1;word-break:break-word;:not([data-is-multiline]){overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}"
|
|
76
76
|
} : {
|
|
77
77
|
name: "q5vyh6",
|
|
78
|
-
styles: "position:relative;flex-grow:1;word-break:break-word;:not([data-is-multiline]){overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/sadykovsd/join-x5/packages/data-grid/src/TableCell/index.tsx"],"names":[],"mappings":"AAiP0B","file":"/home/sadykovsd/join-x5/packages/data-grid/src/TableCell/index.tsx","sourcesContent":["'use client';\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport {flexRender} from '@tanstack/react-table';\n\nimport {forwardRef, SizeTokenValue, useRefMerge} from '@join-x5/react-theme';\nimport {EditOnIcon} from '@join-x5/react-icons';\nimport {ColumnArea} from '@join-x5/react-data-grid-settings';\n\nimport {useDataGridTableCell} from './hook';\n\nimport type {HTMLAttributes, KeyboardEventHandler} from 'react';\nimport type {FRC, PropsWithChildren} from '@join-x5/react-theme';\nimport type {DataGridTableCellProps, TableCellProps} from './types';\n\nconst sizePadding: Record<SizeTokenValue, number> = {\n  [SizeTokenValue.XXSmall]: 8,\n  [SizeTokenValue.XSmall]: 8,\n  [SizeTokenValue.Small]: 8,\n  [SizeTokenValue.Medium]: 12,\n  [SizeTokenValue.Large]: 12,\n  [SizeTokenValue.XLarge]: 12,\n};\n\nconst Cell = styled.td`\n  position: relative;\n  box-sizing: border-box;\n  height: 1px;\n  border-radius: 0;\n  border-spacing: 0;\n  background-color: var(--background-color, transparent);\n\n  ${props => ({\n    color: props.theme.colors.grey[100],\n\n    '--background-color': props.theme.colors.white,\n    '--border-color': props.theme.colors.grey[10],\n  })};\n\n  &[data-${SizeTokenValue.Large.toLocaleLowerCase()}] {\n    min-height: 44px;\n\n    ${props => props.theme.typography.p1compact}\n  }\n\n  &[data-${SizeTokenValue.Medium.toLocaleLowerCase()}] {\n    min-height: 40px;\n\n    ${props => props.theme.typography.p2}\n  }\n\n  &[data-${SizeTokenValue.Small.toLocaleLowerCase()}] {\n    min-height: 32px;\n\n    ${props => props.theme.typography.p2}\n  }\n\n  &[data-${ColumnArea.FixedLeft.toLocaleLowerCase()}] {\n    position: sticky;\n    z-index: 1;\n\n    &[data-shadowed][data-last-fixed] {\n      filter: drop-shadow(8px 0px 8px rgba(80, 86, 94, 0.08));\n    }\n  }\n\n  &[data-${ColumnArea.FixedRight.toLocaleLowerCase()}] {\n    position: sticky;\n    z-index: 1;\n\n    &[data-shadowed][data-last-fixed] {\n      filter: drop-shadow(-8px 0px 8px rgba(80, 86, 94, 0.08));\n    }\n  }\n\n  &[data-row-hover] {\n    ${props => ({\n      '--background-color': props.theme.colors.grey[10],\n      '--border-color': props.theme.colors.grey[20],\n    })}\n  }\n\n  :hover {\n    ${props => ({\n      '--background-color': props.theme.colors.grey[10],\n      '--border-color': props.theme.colors.grey[40],\n    })}\n  }\n\n  :not([data-disabled]):hover::before {\n    border-width: 1px;\n  }\n\n  &[data-disabled] {\n    :hover {\n      ${props => ({\n        '--background-color': props.theme.colors.grey[10],\n        '--border-color': props.theme.colors.grey[20],\n      })}\n    }\n\n    ${props => ({\n      color: props.theme.colors.grey[40],\n    })}\n  }\n\n  &[data-row-selected] {\n    ${props => ({\n      '--background-color': props.theme.colors.accent[10],\n      '--border-color': props.theme.colors.accent[20],\n    })}\n  }\n\n  &[data-focused],\n  :focus {\n    outline: none;\n\n    ::before {\n      display: none;\n    }\n\n    ::after {\n      display: block;\n    }\n\n    [data-edit-icon] {\n      visibility: visible;\n    }\n\n    ${props => ({\n      '--border-color': 'transparent',\n      '--background-color': props.theme.colors.white,\n      '--outline-color': props.theme.colors.accent[90],\n    })}\n  }\n\n  &[data-active] {\n    outline: none;\n\n    ::before {\n      display: none;\n    }\n\n    ::after {\n      display: block;\n    }\n\n    [data-edit-icon] {\n      visibility: hidden;\n    }\n\n    ${props => ({\n      '--border-color': 'transparent',\n      '--background-color': props.theme.colors.white,\n      '--outline-color': props.theme.colors.accent[90],\n    })}\n  }\n\n  &[data-error] {\n    ::after {\n      display: block;\n    }\n\n    ${props => ({\n      caretColor: props.theme.colors.additional.red[80],\n\n      '--background-color': props.theme.colors.white,\n      '--border-color': 'transparent',\n      '--outline-color': props.theme.colors.additional.red[80],\n    })}\n  }\n\n  ::before {\n    content: '';\n    display: block;\n    position: absolute;\n    box-sizing: border-box;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%;\n    user-select: none;\n    pointer-events: none;\n    border-width: 0 0 1px 0;\n    border-style: solid;\n    border-color: var(--border-color);\n  }\n\n  &[data-bordered] {\n    ::before {\n      border-width: 0 1px 1px 0;\n    }\n\n    :last-of-type::before {\n      border-width: 0 0 1px 0;\n    }\n  }\n\n  &[data-resizing] {\n    border-right: 1px solid ${props => props.theme.colors.accent[20]};\n  }\n\n  ::after {\n    content: '';\n    display: none;\n    position: absolute;\n    box-sizing: border-box;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%;\n    user-select: none;\n    pointer-events: none;\n    border-width: 2px;\n    border-style: solid;\n    border-radius: 4px;\n    border-color: var(--outline-color, transparent);\n  }\n\n  [data-edit-icon] {\n    display: none;\n    position: absolute;\n    visibility: hidden;\n    right: 0;\n    top: 0;\n    background-color: var(--background-color, transparent);\n  }\n\n  &[data-editable] [data-edit-icon] {\n    display: block;\n  }\n`;\n\nconst Container = styled.div`\n  display: flex;\n  position: relative;\n  box-sizing: border-box;\n  gap: 8px;\n`;\n\nconst Content = styled.div`\n  position: relative;\n  flex-grow: 1;\n  word-break: break-word;\n\n  :not([data-is-multiline]) {\n    overflow: hidden;\n    text-overflow: ellipsis;\n    white-space: nowrap;\n  }\n`;\n\nconst Caption = styled.div`\n  padding: 4px 0 0;\n  width: 100%;\n  word-break: break-all;\n\n  ${props => ({\n    ...props.theme.typography.p3,\n\n    color: props.theme.colors.additional.red[80],\n  })}\n`;\n\ntype TableCellContentProps = Partial<Pick<TableCellProps, 'children' | 'isMultiline' | 'whiteSpace' | 'wordBreak'>> &\n  HTMLAttributes<HTMLDivElement>;\n\nexport const TableCellContent: FRC<HTMLDivElement, TableCellContentProps> = forwardRef((props, ref) => {\n  const {children, style, isMultiline, whiteSpace, wordBreak = 'break-word', ...rest} = props;\n\n  const contentProps = {\n    ...rest,\n\n    style: {\n      whiteSpace,\n      wordBreak,\n\n      ...style,\n    },\n\n    'data-content': true,\n    'data-is-multiline': isMultiline ? true : undefined,\n  };\n\n  return (\n    <Content ref={ref} {...contentProps}>\n      {children}\n    </Content>\n  );\n});\n\nexport const TableCell: FRC<HTMLTableCellElement, TableCellProps> = forwardRef((props, baseRef) => {\n  const ref = useRefMerge(baseRef);\n\n  const {\n    children,\n\n    isDisabled,\n    isRowHover,\n    isRowSelected,\n    isBordered,\n    isShadowed,\n    isFocused,\n    isActive,\n    isResizing,\n    isLastFixed,\n    error,\n\n    textAlign,\n    writingMode,\n    verticalAlign,\n    padding,\n    userSelect = 'none',\n\n    startAdornment,\n    endAdornment,\n\n    size = SizeTokenValue.Medium,\n    columnArea = ColumnArea.Default,\n\n    ...rest\n  } = props;\n\n  const onKeyDown: KeyboardEventHandler<HTMLTableCellElement> = e => {\n    props.onKeyDown?.(e);\n\n    const isEnterCode = e.code === 'Enter' || e.code === 'NumpadEnter';\n\n    if (isEnterCode) {\n      const child = ref.current?.querySelector('[data-action]') as HTMLElement;\n\n      if (isEnterCode && child) {\n        child.click();\n      }\n\n      return;\n    }\n\n    if (e.code === 'Escape') {\n      ref.current?.blur();\n      return;\n    }\n\n    if (e.code === 'ArrowUp' || e.code === 'ArrowDown' || e.code === 'ArrowLeft' || e.code === 'ArrowRight') {\n      const parent = ref.current?.parentElement as HTMLElement;\n      const curIndex = Array.from(parent?.childNodes).indexOf(ref.current as HTMLElement);\n\n      switch (e.code) {\n        case 'ArrowUp':\n        case 'ArrowDown':\n          {\n            const sibling = (\n              e.code === 'ArrowUp' ? parent?.previousElementSibling : parent?.nextElementSibling\n            ) as HTMLElement;\n\n            if (parent?.nodeName === sibling?.nodeName) {\n              const nextFocus = sibling?.children[curIndex] as HTMLElement;\n\n              nextFocus?.focus();\n            }\n          }\n          break;\n\n        case 'ArrowLeft':\n          if (curIndex > 0) {\n            const prevSibling = parent?.children[curIndex - 1] as HTMLElement;\n            prevSibling?.focus();\n          } else {\n            const prevRow = parent?.previousElementSibling as HTMLElement;\n            if (parent?.nodeName === prevRow?.nodeName) {\n              const lastCell = prevRow.lastElementChild as HTMLElement;\n              lastCell?.focus();\n            }\n          }\n          break;\n        case 'ArrowRight':\n          if (curIndex < parent?.children.length - 1) {\n            const nextSibling = parent?.children[curIndex + 1] as HTMLElement;\n            nextSibling?.focus();\n          } else {\n            const nextRow = parent?.nextElementSibling as HTMLElement;\n            if (parent?.nodeName === nextRow?.nodeName) {\n              const firstCell = nextRow.firstElementChild as HTMLElement;\n              firstCell?.focus();\n            }\n          }\n          break;\n      }\n    }\n  };\n\n  const cellProps = {\n    ...rest,\n\n    onKeyDown,\n\n    style: {\n      verticalAlign,\n      textAlign,\n      writingMode,\n      userSelect,\n\n      padding: padding ?? sizePadding[size],\n\n      ...props.style,\n    },\n\n    'data-cell': true,\n    'data-disabled': isDisabled ? true : undefined,\n    'data-focused': isFocused ? true : undefined,\n    'data-error': error ? true : undefined,\n    'data-row-hover': isRowHover ? true : undefined,\n    'data-row-selected': isRowSelected ? true : undefined,\n    'data-bordered': isBordered ? true : undefined,\n    'data-shadowed': isShadowed ? true : undefined,\n    'data-resizing': isResizing ? true : undefined,\n    'data-active': isActive ? true : undefined,\n    'data-last-fixed': isLastFixed ? true : undefined,\n\n    [`data-${size.toLowerCase()}`]: true,\n    [`data-${columnArea.toLowerCase()}`]: true,\n  };\n\n  const caption = typeof error === 'string' ? <Caption>{error}</Caption> : null;\n\n  return (\n    <Cell ref={ref} tabIndex={0} {...cellProps}>\n      <Container>\n        {startAdornment}\n        {children}\n        {endAdornment}\n        <EditOnIcon data-edit-icon size={SizeTokenValue.Small} />\n      </Container>\n      {caption}\n    </Cell>\n  );\n});\n\nexport const DataGridTableCell: FRC<HTMLTableCellElement, DataGridTableCellProps & PropsWithChildren> = forwardRef(\n  (props, ref) => {\n    const resultProps = useDataGridTableCell(props.cell);\n\n    const contentProps = {\n      isMultiline: resultProps.isMultiline,\n      whiteSpace: resultProps.whiteSpace,\n      wordBreak: resultProps.wordBreak,\n    };\n\n    return (\n      <TableCell ref={ref} {...resultProps}>\n        <TableCellContent {...contentProps}>{props.children}</TableCellContent>\n      </TableCell>\n    );\n  }\n);\n\nexport const getDataGridTableCell = (cell: DataGridTableCellProps['cell']) => {\n  const content = flexRender(cell.column.columnDef.cell, cell.getContext());\n\n  if (cell.column.columnDef.meta?.isCustom) {\n    return <React.Fragment key={cell.id}>{content}</React.Fragment>;\n  }\n\n  return (\n    <DataGridTableCell key={cell.id} cell={cell}>\n      {content}\n    </DataGridTableCell>\n  );\n};\n\nexport * from './types';\n"]} */",
|
|
79
|
-
toString:
|
|
80
|
-
}),
|
|
78
|
+
styles: "position:relative;flex-grow:1;word-break:break-word;:not([data-is-multiline]){overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/sadykovsd/join-x5/packages/data-grid/src/TableCell/index.tsx"],"names":[],"mappings":"AAmP0B","file":"/home/sadykovsd/join-x5/packages/data-grid/src/TableCell/index.tsx","sourcesContent":["'use client';\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport {flexRender} from '@tanstack/react-table';\n\nimport {forwardRef, SizeTokenValue, useRefMerge} from '@join-x5/react-theme';\nimport {EditOnIcon} from '@join-x5/react-icons';\nimport {ColumnArea} from '@join-x5/react-data-grid-settings';\n\nimport {useDataGridTableCell} from './hook';\n\nimport type {HTMLAttributes, KeyboardEventHandler} from 'react';\nimport type {FRC, PropsWithChildren} from '@join-x5/react-theme';\nimport type {DataGridTableCellProps, TableCellProps} from './types';\n\nconst sizePadding: Record<SizeTokenValue, number> = {\n  [SizeTokenValue.XXSmall]: 8,\n  [SizeTokenValue.XSmall]: 8,\n  [SizeTokenValue.Small]: 8,\n  [SizeTokenValue.Medium]: 12,\n  [SizeTokenValue.Large]: 12,\n  [SizeTokenValue.XLarge]: 12,\n};\n\nconst Cell = styled.td`\n  position: relative;\n  box-sizing: border-box;\n  height: 1px;\n  border-radius: 0;\n  border-spacing: 0;\n  background-color: var(--background-color, transparent);\n\n  ${props => ({\n    color: props.theme.colors.grey[100],\n\n    '--background-color': props.theme.colors.white,\n    '--border-color': props.theme.colors.grey[10],\n  })};\n\n  &[data-${SizeTokenValue.Large.toLocaleLowerCase()}] {\n    min-height: 44px;\n\n    ${props => props.theme.typography.p1compact}\n  }\n\n  &[data-${SizeTokenValue.Medium.toLocaleLowerCase()}] {\n    min-height: 40px;\n\n    ${props => props.theme.typography.p2}\n  }\n\n  &[data-${SizeTokenValue.Small.toLocaleLowerCase()}] {\n    min-height: 32px;\n\n    ${props => props.theme.typography.p2}\n  }\n\n  &[data-${ColumnArea.FixedLeft.toLocaleLowerCase()}] {\n    position: sticky;\n    z-index: 1;\n\n    &[data-shadowed][data-last-fixed] {\n      filter: drop-shadow(8px 0px 8px rgba(80, 86, 94, 0.08));\n    }\n  }\n\n  &[data-${ColumnArea.FixedRight.toLocaleLowerCase()}] {\n    position: sticky;\n    z-index: 1;\n\n    &[data-shadowed][data-last-fixed] {\n      filter: drop-shadow(-8px 0px 8px rgba(80, 86, 94, 0.08));\n    }\n  }\n\n  &[data-row-hover] {\n    ${props => ({\n      '--background-color': props.theme.colors.grey[10],\n      '--border-color': props.theme.colors.grey[20],\n    })}\n  }\n\n  :hover {\n    ${props => ({\n      '--background-color': props.theme.colors.grey[10],\n      '--border-color': props.theme.colors.grey[40],\n    })}\n  }\n\n  :not([data-disabled]):hover::before {\n    border-width: 1px;\n  }\n\n  &[data-disabled] {\n    :hover {\n      ${props => ({\n        '--background-color': props.theme.colors.grey[10],\n        '--border-color': props.theme.colors.grey[20],\n      })}\n    }\n\n    ${props => ({\n      color: props.theme.colors.grey[40],\n    })}\n  }\n\n  &[data-row-selected] {\n    ${props => ({\n      '--background-color': props.theme.colors.accent[10],\n      '--border-color': props.theme.colors.accent[20],\n    })}\n  }\n\n  :focus {\n    outline: none;\n  }\n\n  &[data-focused],\n  :focus:not([data-no-focus]) {\n    ::before {\n      display: none;\n    }\n\n    ::after {\n      display: block;\n    }\n\n    [data-edit-icon] {\n      visibility: visible;\n    }\n\n    ${props => ({\n      '--border-color': 'transparent',\n      '--background-color': props.theme.colors.white,\n      '--outline-color': props.theme.colors.accent[90],\n    })}\n  }\n\n  &[data-active] {\n    outline: none;\n\n    ::before {\n      display: none;\n    }\n\n    ::after {\n      display: block;\n    }\n\n    [data-edit-icon] {\n      visibility: hidden;\n    }\n\n    ${props => ({\n      '--border-color': 'transparent',\n      '--background-color': props.theme.colors.white,\n      '--outline-color': props.theme.colors.accent[90],\n    })}\n  }\n\n  &[data-error] {\n    ::after {\n      display: block;\n    }\n\n    ${props => ({\n      caretColor: props.theme.colors.additional.red[80],\n\n      '--background-color': props.theme.colors.white,\n      '--border-color': 'transparent',\n      '--outline-color': props.theme.colors.additional.red[80],\n    })}\n  }\n\n  ::before {\n    content: '';\n    display: block;\n    position: absolute;\n    box-sizing: border-box;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%;\n    user-select: none;\n    pointer-events: none;\n    border-width: 0 0 1px 0;\n    border-style: solid;\n    border-color: var(--border-color);\n  }\n\n  &[data-bordered] {\n    ::before {\n      border-width: 0 1px 1px 0;\n    }\n\n    :last-of-type::before {\n      border-width: 0 0 1px 0;\n    }\n  }\n\n  &[data-resizing] {\n    border-right: 1px solid ${props => props.theme.colors.accent[20]};\n  }\n\n  ::after {\n    content: '';\n    display: none;\n    position: absolute;\n    box-sizing: border-box;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%;\n    user-select: none;\n    pointer-events: none;\n    border-width: 2px;\n    border-style: solid;\n    border-radius: 4px;\n    border-color: var(--outline-color, transparent);\n  }\n\n  [data-edit-icon] {\n    display: none;\n    position: absolute;\n    visibility: hidden;\n    right: 0;\n    top: 0;\n    background-color: var(--background-color, transparent);\n  }\n\n  &[data-editable] [data-edit-icon] {\n    display: block;\n  }\n`;\n\nconst Container = styled.div`\n  display: flex;\n  position: relative;\n  box-sizing: border-box;\n  gap: 8px;\n`;\n\nconst Content = styled.div`\n  position: relative;\n  flex-grow: 1;\n  word-break: break-word;\n\n  :not([data-is-multiline]) {\n    overflow: hidden;\n    text-overflow: ellipsis;\n    white-space: nowrap;\n  }\n`;\n\nconst Caption = styled.div`\n  padding: 4px 0 0;\n  width: 100%;\n  word-break: break-all;\n\n  ${props => ({\n    ...props.theme.typography.p3,\n\n    color: props.theme.colors.additional.red[80],\n  })}\n`;\n\ntype TableCellContentProps = Partial<Pick<TableCellProps, 'children' | 'isMultiline' | 'whiteSpace' | 'wordBreak'>> &\n  HTMLAttributes<HTMLDivElement>;\n\nexport const TableCellContent: FRC<HTMLDivElement, TableCellContentProps> = forwardRef((props, ref) => {\n  const {children, style, isMultiline, whiteSpace, wordBreak = 'break-word', ...rest} = props;\n\n  const contentProps = {\n    ...rest,\n\n    style: {\n      whiteSpace,\n      wordBreak,\n\n      ...style,\n    },\n\n    'data-content': true,\n    'data-is-multiline': isMultiline ? true : undefined,\n  };\n\n  return (\n    <Content ref={ref} {...contentProps}>\n      {children}\n    </Content>\n  );\n});\n\nexport const TableCell: FRC<HTMLTableCellElement, TableCellProps> = forwardRef((props, baseRef) => {\n  const ref = useRefMerge(baseRef);\n\n  const {\n    children,\n\n    isDisabled,\n    isRowHover,\n    isRowSelected,\n    isBordered,\n    isShadowed,\n    isNoFocus,\n    isFocused,\n    isActive,\n    isResizing,\n    isLastFixed,\n    error,\n\n    textAlign,\n    writingMode,\n    verticalAlign,\n    padding,\n    userSelect = 'none',\n\n    startAdornment,\n    endAdornment,\n\n    size = SizeTokenValue.Medium,\n    columnArea = ColumnArea.Default,\n\n    ...rest\n  } = props;\n\n  const onKeyDown: KeyboardEventHandler<HTMLTableCellElement> = e => {\n    props.onKeyDown?.(e);\n\n    const isEnterCode = e.code === 'Enter' || e.code === 'NumpadEnter';\n\n    if (isEnterCode) {\n      const child = ref.current?.querySelector('[data-action]') as HTMLElement;\n\n      if (isEnterCode && child) {\n        child.click();\n      }\n\n      return;\n    }\n\n    if (e.code === 'Escape') {\n      ref.current?.blur();\n      return;\n    }\n\n    const isNavigation =\n      e.code === 'ArrowUp' || e.code === 'ArrowDown' || e.code === 'ArrowLeft' || e.code === 'ArrowRight';\n\n    if (isNavigation && !isNoFocus) {\n      const parent = ref.current?.parentElement as HTMLElement;\n      const curIndex = Array.from(parent?.childNodes).indexOf(ref.current as HTMLElement);\n\n      switch (e.code) {\n        case 'ArrowUp':\n        case 'ArrowDown':\n          {\n            const sibling = (\n              e.code === 'ArrowUp' ? parent?.previousElementSibling : parent?.nextElementSibling\n            ) as HTMLElement;\n\n            if (parent?.nodeName === sibling?.nodeName) {\n              const nextFocus = sibling?.children[curIndex] as HTMLElement;\n\n              nextFocus?.focus();\n            }\n          }\n          break;\n\n        case 'ArrowLeft':\n          if (curIndex > 0) {\n            const prevSibling = parent?.children[curIndex - 1] as HTMLElement;\n            prevSibling?.focus();\n          } else {\n            const prevRow = parent?.previousElementSibling as HTMLElement;\n            if (parent?.nodeName === prevRow?.nodeName) {\n              const lastCell = prevRow.lastElementChild as HTMLElement;\n              lastCell?.focus();\n            }\n          }\n          break;\n        case 'ArrowRight':\n          if (curIndex < parent?.children.length - 1) {\n            const nextSibling = parent?.children[curIndex + 1] as HTMLElement;\n            nextSibling?.focus();\n          } else {\n            const nextRow = parent?.nextElementSibling as HTMLElement;\n            if (parent?.nodeName === nextRow?.nodeName) {\n              const firstCell = nextRow.firstElementChild as HTMLElement;\n              firstCell?.focus();\n            }\n          }\n          break;\n      }\n    }\n  };\n\n  const cellProps = {\n    ...rest,\n\n    onKeyDown,\n\n    style: {\n      verticalAlign,\n      textAlign,\n      writingMode,\n      userSelect,\n\n      padding: padding ?? sizePadding[size],\n\n      ...props.style,\n    },\n\n    'data-cell': true,\n    'data-disabled': isDisabled ? true : undefined,\n    'data-focused': isFocused ? true : undefined,\n    'data-error': error ? true : undefined,\n    'data-row-hover': isRowHover ? true : undefined,\n    'data-row-selected': isRowSelected ? true : undefined,\n    'data-bordered': isBordered ? true : undefined,\n    'data-shadowed': isShadowed ? true : undefined,\n    'data-no-focus': isNoFocus ? true : undefined,\n    'data-resizing': isResizing ? true : undefined,\n    'data-active': isActive ? true : undefined,\n    'data-last-fixed': isLastFixed ? true : undefined,\n\n    [`data-${size.toLowerCase()}`]: true,\n    [`data-${columnArea.toLowerCase()}`]: true,\n  };\n\n  const caption = typeof error === 'string' ? <Caption>{error}</Caption> : null;\n\n  return (\n    <Cell ref={ref} tabIndex={0} {...cellProps}>\n      <Container>\n        {startAdornment}\n        {children}\n        {endAdornment}\n        <EditOnIcon data-edit-icon size={SizeTokenValue.Small} />\n      </Container>\n      {caption}\n    </Cell>\n  );\n});\n\nexport const DataGridTableCell: FRC<HTMLTableCellElement, DataGridTableCellProps & PropsWithChildren> = forwardRef(\n  (props, ref) => {\n    const resultProps = useDataGridTableCell(props.cell);\n\n    const contentProps = {\n      isMultiline: resultProps.isMultiline,\n      whiteSpace: resultProps.whiteSpace,\n      wordBreak: resultProps.wordBreak,\n    };\n\n    return (\n      <TableCell ref={ref} {...resultProps}>\n        <TableCellContent {...contentProps}>{props.children}</TableCellContent>\n      </TableCell>\n    );\n  }\n);\n\nexport const getDataGridTableCell = (cell: DataGridTableCellProps['cell']) => {\n  const content = flexRender(cell.column.columnDef.cell, cell.getContext());\n\n  if (cell.column.columnDef.meta?.isCustom) {\n    return <React.Fragment key={cell.id}>{content}</React.Fragment>;\n  }\n\n  return (\n    <DataGridTableCell key={cell.id} cell={cell}>\n      {content}\n    </DataGridTableCell>\n  );\n};\n\nexport * from './types';\n"]} */",
|
|
79
|
+
toString: y
|
|
80
|
+
}), f = /* @__PURE__ */ X("div", process.env.NODE_ENV === "production" ? {
|
|
81
81
|
target: "e1enoxlq0"
|
|
82
82
|
} : {
|
|
83
83
|
target: "e1enoxlq0",
|
|
@@ -85,137 +85,139 @@ const M = {
|
|
|
85
85
|
})("padding:4px 0 0;width:100%;word-break:break-all;", (I) => ({
|
|
86
86
|
...I.theme.typography.p3,
|
|
87
87
|
color: I.theme.colors.additional.red[80]
|
|
88
|
-
}), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/sadykovsd/join-x5/packages/data-grid/src/TableCell/index.tsx"],"names":[],"mappings":"AA6P0B","file":"/home/sadykovsd/join-x5/packages/data-grid/src/TableCell/index.tsx","sourcesContent":["'use client';\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport {flexRender} from '@tanstack/react-table';\n\nimport {forwardRef, SizeTokenValue, useRefMerge} from '@join-x5/react-theme';\nimport {EditOnIcon} from '@join-x5/react-icons';\nimport {ColumnArea} from '@join-x5/react-data-grid-settings';\n\nimport {useDataGridTableCell} from './hook';\n\nimport type {HTMLAttributes, KeyboardEventHandler} from 'react';\nimport type {FRC, PropsWithChildren} from '@join-x5/react-theme';\nimport type {DataGridTableCellProps, TableCellProps} from './types';\n\nconst sizePadding: Record<SizeTokenValue, number> = {\n  [SizeTokenValue.XXSmall]: 8,\n  [SizeTokenValue.XSmall]: 8,\n  [SizeTokenValue.Small]: 8,\n  [SizeTokenValue.Medium]: 12,\n  [SizeTokenValue.Large]: 12,\n  [SizeTokenValue.XLarge]: 12,\n};\n\nconst Cell = styled.td`\n  position: relative;\n  box-sizing: border-box;\n  height: 1px;\n  border-radius: 0;\n  border-spacing: 0;\n  background-color: var(--background-color, transparent);\n\n  ${props => ({\n    color: props.theme.colors.grey[100],\n\n    '--background-color': props.theme.colors.white,\n    '--border-color': props.theme.colors.grey[10],\n  })};\n\n  &[data-${SizeTokenValue.Large.toLocaleLowerCase()}] {\n    min-height: 44px;\n\n    ${props => props.theme.typography.p1compact}\n  }\n\n  &[data-${SizeTokenValue.Medium.toLocaleLowerCase()}] {\n    min-height: 40px;\n\n    ${props => props.theme.typography.p2}\n  }\n\n  &[data-${SizeTokenValue.Small.toLocaleLowerCase()}] {\n    min-height: 32px;\n\n    ${props => props.theme.typography.p2}\n  }\n\n  &[data-${ColumnArea.FixedLeft.toLocaleLowerCase()}] {\n    position: sticky;\n    z-index: 1;\n\n    &[data-shadowed][data-last-fixed] {\n      filter: drop-shadow(8px 0px 8px rgba(80, 86, 94, 0.08));\n    }\n  }\n\n  &[data-${ColumnArea.FixedRight.toLocaleLowerCase()}] {\n    position: sticky;\n    z-index: 1;\n\n    &[data-shadowed][data-last-fixed] {\n      filter: drop-shadow(-8px 0px 8px rgba(80, 86, 94, 0.08));\n    }\n  }\n\n  &[data-row-hover] {\n    ${props => ({\n      '--background-color': props.theme.colors.grey[10],\n      '--border-color': props.theme.colors.grey[20],\n    })}\n  }\n\n  :hover {\n    ${props => ({\n      '--background-color': props.theme.colors.grey[10],\n      '--border-color': props.theme.colors.grey[40],\n    })}\n  }\n\n  :not([data-disabled]):hover::before {\n    border-width: 1px;\n  }\n\n  &[data-disabled] {\n    :hover {\n      ${props => ({\n        '--background-color': props.theme.colors.grey[10],\n        '--border-color': props.theme.colors.grey[20],\n      })}\n    }\n\n    ${props => ({\n      color: props.theme.colors.grey[40],\n    })}\n  }\n\n  &[data-row-selected] {\n    ${props => ({\n      '--background-color': props.theme.colors.accent[10],\n      '--border-color': props.theme.colors.accent[20],\n    })}\n  }\n\n  &[data-focused],\n  :focus {\n    outline: none;\n\n    ::before {\n      display: none;\n    }\n\n    ::after {\n      display: block;\n    }\n\n    [data-edit-icon] {\n      visibility: visible;\n    }\n\n    ${props => ({\n      '--border-color': 'transparent',\n      '--background-color': props.theme.colors.white,\n      '--outline-color': props.theme.colors.accent[90],\n    })}\n  }\n\n  &[data-active] {\n    outline: none;\n\n    ::before {\n      display: none;\n    }\n\n    ::after {\n      display: block;\n    }\n\n    [data-edit-icon] {\n      visibility: hidden;\n    }\n\n    ${props => ({\n      '--border-color': 'transparent',\n      '--background-color': props.theme.colors.white,\n      '--outline-color': props.theme.colors.accent[90],\n    })}\n  }\n\n  &[data-error] {\n    ::after {\n      display: block;\n    }\n\n    ${props => ({\n      caretColor: props.theme.colors.additional.red[80],\n\n      '--background-color': props.theme.colors.white,\n      '--border-color': 'transparent',\n      '--outline-color': props.theme.colors.additional.red[80],\n    })}\n  }\n\n  ::before {\n    content: '';\n    display: block;\n    position: absolute;\n    box-sizing: border-box;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%;\n    user-select: none;\n    pointer-events: none;\n    border-width: 0 0 1px 0;\n    border-style: solid;\n    border-color: var(--border-color);\n  }\n\n  &[data-bordered] {\n    ::before {\n      border-width: 0 1px 1px 0;\n    }\n\n    :last-of-type::before {\n      border-width: 0 0 1px 0;\n    }\n  }\n\n  &[data-resizing] {\n    border-right: 1px solid ${props => props.theme.colors.accent[20]};\n  }\n\n  ::after {\n    content: '';\n    display: none;\n    position: absolute;\n    box-sizing: border-box;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%;\n    user-select: none;\n    pointer-events: none;\n    border-width: 2px;\n    border-style: solid;\n    border-radius: 4px;\n    border-color: var(--outline-color, transparent);\n  }\n\n  [data-edit-icon] {\n    display: none;\n    position: absolute;\n    visibility: hidden;\n    right: 0;\n    top: 0;\n    background-color: var(--background-color, transparent);\n  }\n\n  &[data-editable] [data-edit-icon] {\n    display: block;\n  }\n`;\n\nconst Container = styled.div`\n  display: flex;\n  position: relative;\n  box-sizing: border-box;\n  gap: 8px;\n`;\n\nconst Content = styled.div`\n  position: relative;\n  flex-grow: 1;\n  word-break: break-word;\n\n  :not([data-is-multiline]) {\n    overflow: hidden;\n    text-overflow: ellipsis;\n    white-space: nowrap;\n  }\n`;\n\nconst Caption = styled.div`\n  padding: 4px 0 0;\n  width: 100%;\n  word-break: break-all;\n\n  ${props => ({\n    ...props.theme.typography.p3,\n\n    color: props.theme.colors.additional.red[80],\n  })}\n`;\n\ntype TableCellContentProps = Partial<Pick<TableCellProps, 'children' | 'isMultiline' | 'whiteSpace' | 'wordBreak'>> &\n  HTMLAttributes<HTMLDivElement>;\n\nexport const TableCellContent: FRC<HTMLDivElement, TableCellContentProps> = forwardRef((props, ref) => {\n  const {children, style, isMultiline, whiteSpace, wordBreak = 'break-word', ...rest} = props;\n\n  const contentProps = {\n    ...rest,\n\n    style: {\n      whiteSpace,\n      wordBreak,\n\n      ...style,\n    },\n\n    'data-content': true,\n    'data-is-multiline': isMultiline ? true : undefined,\n  };\n\n  return (\n    <Content ref={ref} {...contentProps}>\n      {children}\n    </Content>\n  );\n});\n\nexport const TableCell: FRC<HTMLTableCellElement, TableCellProps> = forwardRef((props, baseRef) => {\n  const ref = useRefMerge(baseRef);\n\n  const {\n    children,\n\n    isDisabled,\n    isRowHover,\n    isRowSelected,\n    isBordered,\n    isShadowed,\n    isFocused,\n    isActive,\n    isResizing,\n    isLastFixed,\n    error,\n\n    textAlign,\n    writingMode,\n    verticalAlign,\n    padding,\n    userSelect = 'none',\n\n    startAdornment,\n    endAdornment,\n\n    size = SizeTokenValue.Medium,\n    columnArea = ColumnArea.Default,\n\n    ...rest\n  } = props;\n\n  const onKeyDown: KeyboardEventHandler<HTMLTableCellElement> = e => {\n    props.onKeyDown?.(e);\n\n    const isEnterCode = e.code === 'Enter' || e.code === 'NumpadEnter';\n\n    if (isEnterCode) {\n      const child = ref.current?.querySelector('[data-action]') as HTMLElement;\n\n      if (isEnterCode && child) {\n        child.click();\n      }\n\n      return;\n    }\n\n    if (e.code === 'Escape') {\n      ref.current?.blur();\n      return;\n    }\n\n    if (e.code === 'ArrowUp' || e.code === 'ArrowDown' || e.code === 'ArrowLeft' || e.code === 'ArrowRight') {\n      const parent = ref.current?.parentElement as HTMLElement;\n      const curIndex = Array.from(parent?.childNodes).indexOf(ref.current as HTMLElement);\n\n      switch (e.code) {\n        case 'ArrowUp':\n        case 'ArrowDown':\n          {\n            const sibling = (\n              e.code === 'ArrowUp' ? parent?.previousElementSibling : parent?.nextElementSibling\n            ) as HTMLElement;\n\n            if (parent?.nodeName === sibling?.nodeName) {\n              const nextFocus = sibling?.children[curIndex] as HTMLElement;\n\n              nextFocus?.focus();\n            }\n          }\n          break;\n\n        case 'ArrowLeft':\n          if (curIndex > 0) {\n            const prevSibling = parent?.children[curIndex - 1] as HTMLElement;\n            prevSibling?.focus();\n          } else {\n            const prevRow = parent?.previousElementSibling as HTMLElement;\n            if (parent?.nodeName === prevRow?.nodeName) {\n              const lastCell = prevRow.lastElementChild as HTMLElement;\n              lastCell?.focus();\n            }\n          }\n          break;\n        case 'ArrowRight':\n          if (curIndex < parent?.children.length - 1) {\n            const nextSibling = parent?.children[curIndex + 1] as HTMLElement;\n            nextSibling?.focus();\n          } else {\n            const nextRow = parent?.nextElementSibling as HTMLElement;\n            if (parent?.nodeName === nextRow?.nodeName) {\n              const firstCell = nextRow.firstElementChild as HTMLElement;\n              firstCell?.focus();\n            }\n          }\n          break;\n      }\n    }\n  };\n\n  const cellProps = {\n    ...rest,\n\n    onKeyDown,\n\n    style: {\n      verticalAlign,\n      textAlign,\n      writingMode,\n      userSelect,\n\n      padding: padding ?? sizePadding[size],\n\n      ...props.style,\n    },\n\n    'data-cell': true,\n    'data-disabled': isDisabled ? true : undefined,\n    'data-focused': isFocused ? true : undefined,\n    'data-error': error ? true : undefined,\n    'data-row-hover': isRowHover ? true : undefined,\n    'data-row-selected': isRowSelected ? true : undefined,\n    'data-bordered': isBordered ? true : undefined,\n    'data-shadowed': isShadowed ? true : undefined,\n    'data-resizing': isResizing ? true : undefined,\n    'data-active': isActive ? true : undefined,\n    'data-last-fixed': isLastFixed ? true : undefined,\n\n    [`data-${size.toLowerCase()}`]: true,\n    [`data-${columnArea.toLowerCase()}`]: true,\n  };\n\n  const caption = typeof error === 'string' ? <Caption>{error}</Caption> : null;\n\n  return (\n    <Cell ref={ref} tabIndex={0} {...cellProps}>\n      <Container>\n        {startAdornment}\n        {children}\n        {endAdornment}\n        <EditOnIcon data-edit-icon size={SizeTokenValue.Small} />\n      </Container>\n      {caption}\n    </Cell>\n  );\n});\n\nexport const DataGridTableCell: FRC<HTMLTableCellElement, DataGridTableCellProps & PropsWithChildren> = forwardRef(\n  (props, ref) => {\n    const resultProps = useDataGridTableCell(props.cell);\n\n    const contentProps = {\n      isMultiline: resultProps.isMultiline,\n      whiteSpace: resultProps.whiteSpace,\n      wordBreak: resultProps.wordBreak,\n    };\n\n    return (\n      <TableCell ref={ref} {...resultProps}>\n        <TableCellContent {...contentProps}>{props.children}</TableCellContent>\n      </TableCell>\n    );\n  }\n);\n\nexport const getDataGridTableCell = (cell: DataGridTableCellProps['cell']) => {\n  const content = flexRender(cell.column.columnDef.cell, cell.getContext());\n\n  if (cell.column.columnDef.meta?.isCustom) {\n    return <React.Fragment key={cell.id}>{content}</React.Fragment>;\n  }\n\n  return (\n    <DataGridTableCell key={cell.id} cell={cell}>\n      {content}\n    </DataGridTableCell>\n  );\n};\n\nexport * from './types';\n"]} */")), f = n((I, l) => {
|
|
88
|
+
}), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/sadykovsd/join-x5/packages/data-grid/src/TableCell/index.tsx"],"names":[],"mappings":"AA+P0B","file":"/home/sadykovsd/join-x5/packages/data-grid/src/TableCell/index.tsx","sourcesContent":["'use client';\n\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport {flexRender} from '@tanstack/react-table';\n\nimport {forwardRef, SizeTokenValue, useRefMerge} from '@join-x5/react-theme';\nimport {EditOnIcon} from '@join-x5/react-icons';\nimport {ColumnArea} from '@join-x5/react-data-grid-settings';\n\nimport {useDataGridTableCell} from './hook';\n\nimport type {HTMLAttributes, KeyboardEventHandler} from 'react';\nimport type {FRC, PropsWithChildren} from '@join-x5/react-theme';\nimport type {DataGridTableCellProps, TableCellProps} from './types';\n\nconst sizePadding: Record<SizeTokenValue, number> = {\n  [SizeTokenValue.XXSmall]: 8,\n  [SizeTokenValue.XSmall]: 8,\n  [SizeTokenValue.Small]: 8,\n  [SizeTokenValue.Medium]: 12,\n  [SizeTokenValue.Large]: 12,\n  [SizeTokenValue.XLarge]: 12,\n};\n\nconst Cell = styled.td`\n  position: relative;\n  box-sizing: border-box;\n  height: 1px;\n  border-radius: 0;\n  border-spacing: 0;\n  background-color: var(--background-color, transparent);\n\n  ${props => ({\n    color: props.theme.colors.grey[100],\n\n    '--background-color': props.theme.colors.white,\n    '--border-color': props.theme.colors.grey[10],\n  })};\n\n  &[data-${SizeTokenValue.Large.toLocaleLowerCase()}] {\n    min-height: 44px;\n\n    ${props => props.theme.typography.p1compact}\n  }\n\n  &[data-${SizeTokenValue.Medium.toLocaleLowerCase()}] {\n    min-height: 40px;\n\n    ${props => props.theme.typography.p2}\n  }\n\n  &[data-${SizeTokenValue.Small.toLocaleLowerCase()}] {\n    min-height: 32px;\n\n    ${props => props.theme.typography.p2}\n  }\n\n  &[data-${ColumnArea.FixedLeft.toLocaleLowerCase()}] {\n    position: sticky;\n    z-index: 1;\n\n    &[data-shadowed][data-last-fixed] {\n      filter: drop-shadow(8px 0px 8px rgba(80, 86, 94, 0.08));\n    }\n  }\n\n  &[data-${ColumnArea.FixedRight.toLocaleLowerCase()}] {\n    position: sticky;\n    z-index: 1;\n\n    &[data-shadowed][data-last-fixed] {\n      filter: drop-shadow(-8px 0px 8px rgba(80, 86, 94, 0.08));\n    }\n  }\n\n  &[data-row-hover] {\n    ${props => ({\n      '--background-color': props.theme.colors.grey[10],\n      '--border-color': props.theme.colors.grey[20],\n    })}\n  }\n\n  :hover {\n    ${props => ({\n      '--background-color': props.theme.colors.grey[10],\n      '--border-color': props.theme.colors.grey[40],\n    })}\n  }\n\n  :not([data-disabled]):hover::before {\n    border-width: 1px;\n  }\n\n  &[data-disabled] {\n    :hover {\n      ${props => ({\n        '--background-color': props.theme.colors.grey[10],\n        '--border-color': props.theme.colors.grey[20],\n      })}\n    }\n\n    ${props => ({\n      color: props.theme.colors.grey[40],\n    })}\n  }\n\n  &[data-row-selected] {\n    ${props => ({\n      '--background-color': props.theme.colors.accent[10],\n      '--border-color': props.theme.colors.accent[20],\n    })}\n  }\n\n  :focus {\n    outline: none;\n  }\n\n  &[data-focused],\n  :focus:not([data-no-focus]) {\n    ::before {\n      display: none;\n    }\n\n    ::after {\n      display: block;\n    }\n\n    [data-edit-icon] {\n      visibility: visible;\n    }\n\n    ${props => ({\n      '--border-color': 'transparent',\n      '--background-color': props.theme.colors.white,\n      '--outline-color': props.theme.colors.accent[90],\n    })}\n  }\n\n  &[data-active] {\n    outline: none;\n\n    ::before {\n      display: none;\n    }\n\n    ::after {\n      display: block;\n    }\n\n    [data-edit-icon] {\n      visibility: hidden;\n    }\n\n    ${props => ({\n      '--border-color': 'transparent',\n      '--background-color': props.theme.colors.white,\n      '--outline-color': props.theme.colors.accent[90],\n    })}\n  }\n\n  &[data-error] {\n    ::after {\n      display: block;\n    }\n\n    ${props => ({\n      caretColor: props.theme.colors.additional.red[80],\n\n      '--background-color': props.theme.colors.white,\n      '--border-color': 'transparent',\n      '--outline-color': props.theme.colors.additional.red[80],\n    })}\n  }\n\n  ::before {\n    content: '';\n    display: block;\n    position: absolute;\n    box-sizing: border-box;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%;\n    user-select: none;\n    pointer-events: none;\n    border-width: 0 0 1px 0;\n    border-style: solid;\n    border-color: var(--border-color);\n  }\n\n  &[data-bordered] {\n    ::before {\n      border-width: 0 1px 1px 0;\n    }\n\n    :last-of-type::before {\n      border-width: 0 0 1px 0;\n    }\n  }\n\n  &[data-resizing] {\n    border-right: 1px solid ${props => props.theme.colors.accent[20]};\n  }\n\n  ::after {\n    content: '';\n    display: none;\n    position: absolute;\n    box-sizing: border-box;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%;\n    user-select: none;\n    pointer-events: none;\n    border-width: 2px;\n    border-style: solid;\n    border-radius: 4px;\n    border-color: var(--outline-color, transparent);\n  }\n\n  [data-edit-icon] {\n    display: none;\n    position: absolute;\n    visibility: hidden;\n    right: 0;\n    top: 0;\n    background-color: var(--background-color, transparent);\n  }\n\n  &[data-editable] [data-edit-icon] {\n    display: block;\n  }\n`;\n\nconst Container = styled.div`\n  display: flex;\n  position: relative;\n  box-sizing: border-box;\n  gap: 8px;\n`;\n\nconst Content = styled.div`\n  position: relative;\n  flex-grow: 1;\n  word-break: break-word;\n\n  :not([data-is-multiline]) {\n    overflow: hidden;\n    text-overflow: ellipsis;\n    white-space: nowrap;\n  }\n`;\n\nconst Caption = styled.div`\n  padding: 4px 0 0;\n  width: 100%;\n  word-break: break-all;\n\n  ${props => ({\n    ...props.theme.typography.p3,\n\n    color: props.theme.colors.additional.red[80],\n  })}\n`;\n\ntype TableCellContentProps = Partial<Pick<TableCellProps, 'children' | 'isMultiline' | 'whiteSpace' | 'wordBreak'>> &\n  HTMLAttributes<HTMLDivElement>;\n\nexport const TableCellContent: FRC<HTMLDivElement, TableCellContentProps> = forwardRef((props, ref) => {\n  const {children, style, isMultiline, whiteSpace, wordBreak = 'break-word', ...rest} = props;\n\n  const contentProps = {\n    ...rest,\n\n    style: {\n      whiteSpace,\n      wordBreak,\n\n      ...style,\n    },\n\n    'data-content': true,\n    'data-is-multiline': isMultiline ? true : undefined,\n  };\n\n  return (\n    <Content ref={ref} {...contentProps}>\n      {children}\n    </Content>\n  );\n});\n\nexport const TableCell: FRC<HTMLTableCellElement, TableCellProps> = forwardRef((props, baseRef) => {\n  const ref = useRefMerge(baseRef);\n\n  const {\n    children,\n\n    isDisabled,\n    isRowHover,\n    isRowSelected,\n    isBordered,\n    isShadowed,\n    isNoFocus,\n    isFocused,\n    isActive,\n    isResizing,\n    isLastFixed,\n    error,\n\n    textAlign,\n    writingMode,\n    verticalAlign,\n    padding,\n    userSelect = 'none',\n\n    startAdornment,\n    endAdornment,\n\n    size = SizeTokenValue.Medium,\n    columnArea = ColumnArea.Default,\n\n    ...rest\n  } = props;\n\n  const onKeyDown: KeyboardEventHandler<HTMLTableCellElement> = e => {\n    props.onKeyDown?.(e);\n\n    const isEnterCode = e.code === 'Enter' || e.code === 'NumpadEnter';\n\n    if (isEnterCode) {\n      const child = ref.current?.querySelector('[data-action]') as HTMLElement;\n\n      if (isEnterCode && child) {\n        child.click();\n      }\n\n      return;\n    }\n\n    if (e.code === 'Escape') {\n      ref.current?.blur();\n      return;\n    }\n\n    const isNavigation =\n      e.code === 'ArrowUp' || e.code === 'ArrowDown' || e.code === 'ArrowLeft' || e.code === 'ArrowRight';\n\n    if (isNavigation && !isNoFocus) {\n      const parent = ref.current?.parentElement as HTMLElement;\n      const curIndex = Array.from(parent?.childNodes).indexOf(ref.current as HTMLElement);\n\n      switch (e.code) {\n        case 'ArrowUp':\n        case 'ArrowDown':\n          {\n            const sibling = (\n              e.code === 'ArrowUp' ? parent?.previousElementSibling : parent?.nextElementSibling\n            ) as HTMLElement;\n\n            if (parent?.nodeName === sibling?.nodeName) {\n              const nextFocus = sibling?.children[curIndex] as HTMLElement;\n\n              nextFocus?.focus();\n            }\n          }\n          break;\n\n        case 'ArrowLeft':\n          if (curIndex > 0) {\n            const prevSibling = parent?.children[curIndex - 1] as HTMLElement;\n            prevSibling?.focus();\n          } else {\n            const prevRow = parent?.previousElementSibling as HTMLElement;\n            if (parent?.nodeName === prevRow?.nodeName) {\n              const lastCell = prevRow.lastElementChild as HTMLElement;\n              lastCell?.focus();\n            }\n          }\n          break;\n        case 'ArrowRight':\n          if (curIndex < parent?.children.length - 1) {\n            const nextSibling = parent?.children[curIndex + 1] as HTMLElement;\n            nextSibling?.focus();\n          } else {\n            const nextRow = parent?.nextElementSibling as HTMLElement;\n            if (parent?.nodeName === nextRow?.nodeName) {\n              const firstCell = nextRow.firstElementChild as HTMLElement;\n              firstCell?.focus();\n            }\n          }\n          break;\n      }\n    }\n  };\n\n  const cellProps = {\n    ...rest,\n\n    onKeyDown,\n\n    style: {\n      verticalAlign,\n      textAlign,\n      writingMode,\n      userSelect,\n\n      padding: padding ?? sizePadding[size],\n\n      ...props.style,\n    },\n\n    'data-cell': true,\n    'data-disabled': isDisabled ? true : undefined,\n    'data-focused': isFocused ? true : undefined,\n    'data-error': error ? true : undefined,\n    'data-row-hover': isRowHover ? true : undefined,\n    'data-row-selected': isRowSelected ? true : undefined,\n    'data-bordered': isBordered ? true : undefined,\n    'data-shadowed': isShadowed ? true : undefined,\n    'data-no-focus': isNoFocus ? true : undefined,\n    'data-resizing': isResizing ? true : undefined,\n    'data-active': isActive ? true : undefined,\n    'data-last-fixed': isLastFixed ? true : undefined,\n\n    [`data-${size.toLowerCase()}`]: true,\n    [`data-${columnArea.toLowerCase()}`]: true,\n  };\n\n  const caption = typeof error === 'string' ? <Caption>{error}</Caption> : null;\n\n  return (\n    <Cell ref={ref} tabIndex={0} {...cellProps}>\n      <Container>\n        {startAdornment}\n        {children}\n        {endAdornment}\n        <EditOnIcon data-edit-icon size={SizeTokenValue.Small} />\n      </Container>\n      {caption}\n    </Cell>\n  );\n});\n\nexport const DataGridTableCell: FRC<HTMLTableCellElement, DataGridTableCellProps & PropsWithChildren> = forwardRef(\n  (props, ref) => {\n    const resultProps = useDataGridTableCell(props.cell);\n\n    const contentProps = {\n      isMultiline: resultProps.isMultiline,\n      whiteSpace: resultProps.whiteSpace,\n      wordBreak: resultProps.wordBreak,\n    };\n\n    return (\n      <TableCell ref={ref} {...resultProps}>\n        <TableCellContent {...contentProps}>{props.children}</TableCellContent>\n      </TableCell>\n    );\n  }\n);\n\nexport const getDataGridTableCell = (cell: DataGridTableCellProps['cell']) => {\n  const content = flexRender(cell.column.columnDef.cell, cell.getContext());\n\n  if (cell.column.columnDef.meta?.isCustom) {\n    return <React.Fragment key={cell.id}>{content}</React.Fragment>;\n  }\n\n  return (\n    <DataGridTableCell key={cell.id} cell={cell}>\n      {content}\n    </DataGridTableCell>\n  );\n};\n\nexport * from './types';\n"]} */")), K = B((I, G) => {
|
|
89
89
|
const {
|
|
90
90
|
children: b,
|
|
91
91
|
style: Z,
|
|
92
|
-
isMultiline:
|
|
92
|
+
isMultiline: d,
|
|
93
93
|
whiteSpace: u,
|
|
94
|
-
wordBreak:
|
|
95
|
-
...
|
|
94
|
+
wordBreak: i = "break-word",
|
|
95
|
+
...m
|
|
96
96
|
} = I, x = {
|
|
97
|
-
...
|
|
97
|
+
...m,
|
|
98
98
|
style: {
|
|
99
99
|
whiteSpace: u,
|
|
100
|
-
wordBreak:
|
|
100
|
+
wordBreak: i,
|
|
101
101
|
...Z
|
|
102
102
|
},
|
|
103
103
|
"data-content": !0,
|
|
104
|
-
"data-is-multiline":
|
|
104
|
+
"data-is-multiline": d ? !0 : void 0
|
|
105
105
|
};
|
|
106
|
-
return /* @__PURE__ */
|
|
107
|
-
}),
|
|
108
|
-
const b = Q(
|
|
106
|
+
return /* @__PURE__ */ l(P, { ref: G, ...x, children: b });
|
|
107
|
+
}), q = B((I, G) => {
|
|
108
|
+
const b = Q(G), {
|
|
109
109
|
children: Z,
|
|
110
|
-
isDisabled:
|
|
110
|
+
isDisabled: d,
|
|
111
111
|
isRowHover: u,
|
|
112
|
-
isRowSelected:
|
|
113
|
-
isBordered:
|
|
112
|
+
isRowSelected: i,
|
|
113
|
+
isBordered: m,
|
|
114
114
|
isShadowed: x,
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
115
|
+
isNoFocus: J,
|
|
116
|
+
isFocused: h,
|
|
117
|
+
isActive: e,
|
|
118
|
+
isResizing: o,
|
|
119
|
+
isLastFixed: s,
|
|
120
|
+
error: t,
|
|
121
|
+
textAlign: a,
|
|
122
|
+
writingMode: N,
|
|
123
|
+
verticalAlign: v,
|
|
124
|
+
padding: p,
|
|
125
|
+
userSelect: F = "none",
|
|
126
|
+
startAdornment: L,
|
|
127
|
+
endAdornment: k,
|
|
128
|
+
size: n = c.Medium,
|
|
129
|
+
columnArea: z = V.Default,
|
|
130
|
+
...S
|
|
130
131
|
} = I, w = {
|
|
131
|
-
...
|
|
132
|
-
onKeyDown: (
|
|
133
|
-
I.onKeyDown?.(
|
|
134
|
-
const Y =
|
|
132
|
+
...S,
|
|
133
|
+
onKeyDown: (C) => {
|
|
134
|
+
I.onKeyDown?.(C);
|
|
135
|
+
const Y = C.code === "Enter" || C.code === "NumpadEnter";
|
|
135
136
|
if (Y) {
|
|
136
137
|
const g = b.current?.querySelector("[data-action]");
|
|
137
138
|
Y && g && g.click();
|
|
138
139
|
return;
|
|
139
140
|
}
|
|
140
|
-
if (
|
|
141
|
+
if (C.code === "Escape") {
|
|
141
142
|
b.current?.blur();
|
|
142
143
|
return;
|
|
143
144
|
}
|
|
144
|
-
if (
|
|
145
|
-
const g = b.current?.parentElement,
|
|
146
|
-
switch (
|
|
145
|
+
if ((C.code === "ArrowUp" || C.code === "ArrowDown" || C.code === "ArrowLeft" || C.code === "ArrowRight") && !J) {
|
|
146
|
+
const g = b.current?.parentElement, W = Array.from(g?.childNodes).indexOf(b.current);
|
|
147
|
+
switch (C.code) {
|
|
147
148
|
case "ArrowUp":
|
|
148
149
|
case "ArrowDown":
|
|
149
150
|
{
|
|
150
|
-
const
|
|
151
|
-
g?.nodeName ===
|
|
151
|
+
const A = C.code === "ArrowUp" ? g?.previousElementSibling : g?.nextElementSibling;
|
|
152
|
+
g?.nodeName === A?.nodeName && A?.children[W]?.focus();
|
|
152
153
|
}
|
|
153
154
|
break;
|
|
154
155
|
case "ArrowLeft":
|
|
155
|
-
if (
|
|
156
|
-
g?.children[
|
|
156
|
+
if (W > 0)
|
|
157
|
+
g?.children[W - 1]?.focus();
|
|
157
158
|
else {
|
|
158
|
-
const
|
|
159
|
-
g?.nodeName ===
|
|
159
|
+
const A = g?.previousElementSibling;
|
|
160
|
+
g?.nodeName === A?.nodeName && A.lastElementChild?.focus();
|
|
160
161
|
}
|
|
161
162
|
break;
|
|
162
163
|
case "ArrowRight":
|
|
163
|
-
if (
|
|
164
|
-
g?.children[
|
|
164
|
+
if (W < g?.children.length - 1)
|
|
165
|
+
g?.children[W + 1]?.focus();
|
|
165
166
|
else {
|
|
166
|
-
const
|
|
167
|
-
g?.nodeName ===
|
|
167
|
+
const A = g?.nextElementSibling;
|
|
168
|
+
g?.nodeName === A?.nodeName && A.firstElementChild?.focus();
|
|
168
169
|
}
|
|
169
170
|
break;
|
|
170
171
|
}
|
|
171
172
|
}
|
|
172
173
|
},
|
|
173
174
|
style: {
|
|
174
|
-
verticalAlign:
|
|
175
|
-
textAlign:
|
|
176
|
-
writingMode:
|
|
177
|
-
userSelect:
|
|
178
|
-
padding:
|
|
175
|
+
verticalAlign: v,
|
|
176
|
+
textAlign: a,
|
|
177
|
+
writingMode: N,
|
|
178
|
+
userSelect: F,
|
|
179
|
+
padding: p ?? j[n],
|
|
179
180
|
...I.style
|
|
180
181
|
},
|
|
181
182
|
"data-cell": !0,
|
|
182
|
-
"data-disabled":
|
|
183
|
-
"data-focused":
|
|
184
|
-
"data-error":
|
|
183
|
+
"data-disabled": d ? !0 : void 0,
|
|
184
|
+
"data-focused": h ? !0 : void 0,
|
|
185
|
+
"data-error": t ? !0 : void 0,
|
|
185
186
|
"data-row-hover": u ? !0 : void 0,
|
|
186
|
-
"data-row-selected":
|
|
187
|
-
"data-bordered":
|
|
187
|
+
"data-row-selected": i ? !0 : void 0,
|
|
188
|
+
"data-bordered": m ? !0 : void 0,
|
|
188
189
|
"data-shadowed": x ? !0 : void 0,
|
|
189
|
-
"data-
|
|
190
|
-
"data-
|
|
191
|
-
"data-
|
|
192
|
-
|
|
193
|
-
[`data-${
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
190
|
+
"data-no-focus": J ? !0 : void 0,
|
|
191
|
+
"data-resizing": o ? !0 : void 0,
|
|
192
|
+
"data-active": e ? !0 : void 0,
|
|
193
|
+
"data-last-fixed": s ? !0 : void 0,
|
|
194
|
+
[`data-${n.toLowerCase()}`]: !0,
|
|
195
|
+
[`data-${z.toLowerCase()}`]: !0
|
|
196
|
+
}, D = typeof t == "string" ? /* @__PURE__ */ l(f, { children: t }) : null;
|
|
197
|
+
return /* @__PURE__ */ H(T, { ref: b, tabIndex: 0, ...w, children: [
|
|
198
|
+
/* @__PURE__ */ H(E, { children: [
|
|
199
|
+
L,
|
|
198
200
|
Z,
|
|
199
|
-
|
|
200
|
-
/* @__PURE__ */
|
|
201
|
+
k,
|
|
202
|
+
/* @__PURE__ */ l(O, { "data-edit-icon": !0, size: c.Small })
|
|
201
203
|
] }),
|
|
202
|
-
|
|
204
|
+
D
|
|
203
205
|
] });
|
|
204
|
-
}),
|
|
205
|
-
const b =
|
|
206
|
+
}), _ = B((I, G) => {
|
|
207
|
+
const b = M(I.cell), Z = {
|
|
206
208
|
isMultiline: b.isMultiline,
|
|
207
209
|
whiteSpace: b.whiteSpace,
|
|
208
210
|
wordBreak: b.wordBreak
|
|
209
211
|
};
|
|
210
|
-
return /* @__PURE__ */
|
|
211
|
-
}),
|
|
212
|
-
const
|
|
213
|
-
return I.column.columnDef.meta?.isCustom ? /* @__PURE__ */
|
|
212
|
+
return /* @__PURE__ */ l(q, { ref: G, ...b, children: /* @__PURE__ */ l(K, { ...Z, children: I.children }) });
|
|
213
|
+
}), WI = (I) => {
|
|
214
|
+
const G = r(I.column.columnDef.cell, I.getContext());
|
|
215
|
+
return I.column.columnDef.meta?.isCustom ? /* @__PURE__ */ l(U.Fragment, { children: G }, I.id) : /* @__PURE__ */ l(_, { cell: I, children: G }, I.id);
|
|
214
216
|
};
|
|
215
217
|
export {
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
218
|
+
_ as DataGridTableCell,
|
|
219
|
+
q as TableCell,
|
|
220
|
+
K as TableCellContent,
|
|
221
|
+
WI as getDataGridTableCell
|
|
220
222
|
};
|
|
221
223
|
//# sourceMappingURL=index.es.js.map
|