@join-x5/react-data-grid 1.4.0 → 1.4.1

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.
@@ -1,23 +1,23 @@
1
1
  "use client";
2
- import { jsx as Z, jsxs as a } from "@emotion/react/jsx-runtime";
3
- import W from "@emotion/styled/base";
4
- import r from "react";
5
- import { flexRender as M } from "@tanstack/react-table";
6
- import { SizeTokenValue as C, forwardRef as n, useRefMerge as j } from "@join-x5/react-theme";
7
- import { EditOnIcon as T } from "@join-x5/react-icons";
8
- import { ColumnArea as B } from "@join-x5/react-data-grid-settings";
9
- import { useDataGridTableCell as E } from "./hook.es.js";
10
- function o() {
2
+ import { jsx as G, jsxs as s } from "@emotion/react/jsx-runtime";
3
+ import d from "@emotion/styled/base";
4
+ import U from "react";
5
+ import { flexRender as D } from "@tanstack/react-table";
6
+ import { SizeTokenValue as c, forwardRef as n, useRefMerge as Q } from "@join-x5/react-theme";
7
+ import { EditOnIcon as O } from "@join-x5/react-icons";
8
+ import { ColumnArea as t } from "@join-x5/react-data-grid-settings";
9
+ import { useDataGridTableCell as r } from "./hook.es.js";
10
+ function R() {
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 P = {
14
- [C.XXSmall]: 8,
15
- [C.XSmall]: 8,
16
- [C.Small]: 8,
17
- [C.Medium]: 12,
18
- [C.Large]: 12,
19
- [C.XLarge]: 12
20
- }, f = /* @__PURE__ */ W("td", process.env.NODE_ENV === "production" ? {
13
+ const M = {
14
+ [c.XXSmall]: 8,
15
+ [c.XSmall]: 8,
16
+ [c.Small]: 8,
17
+ [c.Medium]: 12,
18
+ [c.Large]: 12,
19
+ [c.XLarge]: 12
20
+ }, j = /* @__PURE__ */ d("td", process.env.NODE_ENV === "production" ? {
21
21
  target: "e1enoxlq3"
22
22
  } : {
23
23
  target: "e1enoxlq3",
@@ -26,7 +26,7 @@ const P = {
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-", B.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-", B.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) => ({
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-", t.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-", t.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) => ({
@@ -53,7 +53,7 @@ const P = {
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"]} */")), K = /* @__PURE__ */ W("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  &[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" ? {
57
57
  target: "e1enoxlq2"
58
58
  } : {
59
59
  target: "e1enoxlq2",
@@ -64,8 +64,8 @@ const P = {
64
64
  } : {
65
65
  name: "15dbgh0",
66
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: o
68
- }), q = /* @__PURE__ */ W("div", process.env.NODE_ENV === "production" ? {
67
+ toString: R
68
+ }), E = /* @__PURE__ */ d("div", process.env.NODE_ENV === "production" ? {
69
69
  target: "e1enoxlq1"
70
70
  } : {
71
71
  target: "e1enoxlq1",
@@ -76,8 +76,8 @@ const P = {
76
76
  } : {
77
77
  name: "q5vyh6",
78
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: o
80
- }), _ = /* @__PURE__ */ W("div", process.env.NODE_ENV === "production" ? {
79
+ toString: R
80
+ }), P = /* @__PURE__ */ d("div", process.env.NODE_ENV === "production" ? {
81
81
  target: "e1enoxlq0"
82
82
  } : {
83
83
  target: "e1enoxlq0",
@@ -85,150 +85,137 @@ const P = {
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"]} */")), $ = n((I, G) => {
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) => {
89
89
  const {
90
- children: c,
91
- style: X,
92
- isMultiline: u,
93
- whiteSpace: m,
94
- wordBreak: i = "break-word",
95
- ...V
90
+ children: b,
91
+ style: Z,
92
+ isMultiline: W,
93
+ whiteSpace: u,
94
+ wordBreak: m = "break-word",
95
+ ...i
96
96
  } = I, x = {
97
- ...V,
97
+ ...i,
98
98
  style: {
99
- whiteSpace: m,
100
- wordBreak: i,
101
- ...X
99
+ whiteSpace: u,
100
+ wordBreak: m,
101
+ ...Z
102
102
  },
103
103
  "data-content": !0,
104
- "data-is-multiline": u ? !0 : void 0
104
+ "data-is-multiline": W ? !0 : void 0
105
105
  };
106
- return /* @__PURE__ */ Z(q, { ref: G, ...x, children: c });
107
- }), II = n((I, G) => {
108
- const c = j(G), {
109
- children: X,
110
- isDisabled: u,
111
- isRowHover: m,
112
- isRowSelected: i,
113
- isBordered: V,
106
+ return /* @__PURE__ */ G(E, { ref: l, ...x, children: b });
107
+ }), K = n((I, l) => {
108
+ const b = Q(l), {
109
+ children: Z,
110
+ isDisabled: W,
111
+ isRowHover: u,
112
+ isRowSelected: m,
113
+ isBordered: i,
114
114
  isShadowed: x,
115
- isFocused: h,
116
- isActive: e,
117
- isResizing: N,
118
- isLastFixed: L,
119
- error: t,
120
- textAlign: v,
121
- writingMode: F,
122
- verticalAlign: p,
123
- padding: S,
124
- userSelect: k = "none",
125
- startAdornment: w,
126
- endAdornment: z,
127
- size: Y = C.Medium,
128
- columnArea: U = B.Default,
129
- ...D
130
- } = I, Q = {
131
- ...D,
132
- onKeyDown: (l) => {
133
- var s, R, H, y;
134
- (s = I.onKeyDown) == null || s.call(I, l);
135
- const J = l.code === "Enter" || l.code === "NumpadEnter";
136
- if (J) {
137
- const g = (R = c.current) == null ? void 0 : R.querySelector("[data-action]");
138
- J && g && g.click();
115
+ isFocused: H,
116
+ isActive: a,
117
+ isResizing: y,
118
+ isLastFixed: o,
119
+ error: V,
120
+ textAlign: h,
121
+ writingMode: e,
122
+ verticalAlign: N,
123
+ padding: L,
124
+ userSelect: v = "none",
125
+ startAdornment: p,
126
+ endAdornment: F,
127
+ size: B = c.Medium,
128
+ columnArea: S = t.Default,
129
+ ...k
130
+ } = I, w = {
131
+ ...k,
132
+ onKeyDown: (A) => {
133
+ I.onKeyDown?.(A);
134
+ const Y = A.code === "Enter" || A.code === "NumpadEnter";
135
+ if (Y) {
136
+ const g = b.current?.querySelector("[data-action]");
137
+ Y && g && g.click();
139
138
  return;
140
139
  }
141
- if (l.code === "Escape") {
142
- (H = c.current) == null || H.blur();
140
+ if (A.code === "Escape") {
141
+ b.current?.blur();
143
142
  return;
144
143
  }
145
- if (l.code === "ArrowUp" || l.code === "ArrowDown" || l.code === "ArrowLeft" || l.code === "ArrowRight") {
146
- const g = (y = c.current) == null ? void 0 : y.parentElement, d = Array.from(g == null ? void 0 : g.childNodes).indexOf(c.current);
147
- switch (l.code) {
144
+ if (A.code === "ArrowUp" || A.code === "ArrowDown" || A.code === "ArrowLeft" || A.code === "ArrowRight") {
145
+ const g = b.current?.parentElement, X = Array.from(g?.childNodes).indexOf(b.current);
146
+ switch (A.code) {
148
147
  case "ArrowUp":
149
148
  case "ArrowDown":
150
149
  {
151
- const b = l.code === "ArrowUp" ? g == null ? void 0 : g.previousElementSibling : g == null ? void 0 : g.nextElementSibling;
152
- if ((g == null ? void 0 : g.nodeName) === (b == null ? void 0 : b.nodeName)) {
153
- const A = b == null ? void 0 : b.children[d];
154
- A == null || A.focus();
155
- }
150
+ const C = A.code === "ArrowUp" ? g?.previousElementSibling : g?.nextElementSibling;
151
+ g?.nodeName === C?.nodeName && C?.children[X]?.focus();
156
152
  }
157
153
  break;
158
154
  case "ArrowLeft":
159
- if (d > 0) {
160
- const b = g == null ? void 0 : g.children[d - 1];
161
- b == null || b.focus();
162
- } else {
163
- const b = g == null ? void 0 : g.previousElementSibling;
164
- if ((g == null ? void 0 : g.nodeName) === (b == null ? void 0 : b.nodeName)) {
165
- const A = b.lastElementChild;
166
- A == null || A.focus();
167
- }
155
+ if (X > 0)
156
+ g?.children[X - 1]?.focus();
157
+ else {
158
+ const C = g?.previousElementSibling;
159
+ g?.nodeName === C?.nodeName && C.lastElementChild?.focus();
168
160
  }
169
161
  break;
170
162
  case "ArrowRight":
171
- if (d < (g == null ? void 0 : g.children.length) - 1) {
172
- const b = g == null ? void 0 : g.children[d + 1];
173
- b == null || b.focus();
174
- } else {
175
- const b = g == null ? void 0 : g.nextElementSibling;
176
- if ((g == null ? void 0 : g.nodeName) === (b == null ? void 0 : b.nodeName)) {
177
- const A = b.firstElementChild;
178
- A == null || A.focus();
179
- }
163
+ if (X < g?.children.length - 1)
164
+ g?.children[X + 1]?.focus();
165
+ else {
166
+ const C = g?.nextElementSibling;
167
+ g?.nodeName === C?.nodeName && C.firstElementChild?.focus();
180
168
  }
181
169
  break;
182
170
  }
183
171
  }
184
172
  },
185
173
  style: {
186
- verticalAlign: p,
187
- textAlign: v,
188
- writingMode: F,
189
- userSelect: k,
190
- padding: S ?? P[Y],
174
+ verticalAlign: N,
175
+ textAlign: h,
176
+ writingMode: e,
177
+ userSelect: v,
178
+ padding: L ?? M[B],
191
179
  ...I.style
192
180
  },
193
181
  "data-cell": !0,
194
- "data-disabled": u ? !0 : void 0,
195
- "data-focused": h ? !0 : void 0,
196
- "data-error": t ? !0 : void 0,
197
- "data-row-hover": m ? !0 : void 0,
198
- "data-row-selected": i ? !0 : void 0,
199
- "data-bordered": V ? !0 : void 0,
182
+ "data-disabled": W ? !0 : void 0,
183
+ "data-focused": H ? !0 : void 0,
184
+ "data-error": V ? !0 : void 0,
185
+ "data-row-hover": u ? !0 : void 0,
186
+ "data-row-selected": m ? !0 : void 0,
187
+ "data-bordered": i ? !0 : void 0,
200
188
  "data-shadowed": x ? !0 : void 0,
201
- "data-resizing": N ? !0 : void 0,
202
- "data-active": e ? !0 : void 0,
203
- "data-last-fixed": L ? !0 : void 0,
204
- [`data-${Y.toLowerCase()}`]: !0,
205
- [`data-${U.toLowerCase()}`]: !0
206
- }, O = typeof t == "string" ? /* @__PURE__ */ Z(_, { children: t }) : null;
207
- return /* @__PURE__ */ a(f, { ref: c, tabIndex: 0, ...Q, children: [
208
- /* @__PURE__ */ a(K, { children: [
209
- w,
210
- X,
211
- z,
212
- /* @__PURE__ */ Z(T, { "data-edit-icon": !0, size: C.Small })
189
+ "data-resizing": y ? !0 : void 0,
190
+ "data-active": a ? !0 : void 0,
191
+ "data-last-fixed": o ? !0 : void 0,
192
+ [`data-${B.toLowerCase()}`]: !0,
193
+ [`data-${S.toLowerCase()}`]: !0
194
+ }, z = typeof V == "string" ? /* @__PURE__ */ G(P, { children: V }) : null;
195
+ return /* @__PURE__ */ s(j, { ref: b, tabIndex: 0, ...w, children: [
196
+ /* @__PURE__ */ s(T, { children: [
197
+ p,
198
+ Z,
199
+ F,
200
+ /* @__PURE__ */ G(O, { "data-edit-icon": !0, size: c.Small })
213
201
  ] }),
214
- O
202
+ z
215
203
  ] });
216
- }), gI = n((I, G) => {
217
- const c = E(I.cell), X = {
218
- isMultiline: c.isMultiline,
219
- whiteSpace: c.whiteSpace,
220
- wordBreak: c.wordBreak
204
+ }), q = n((I, l) => {
205
+ const b = r(I.cell), Z = {
206
+ isMultiline: b.isMultiline,
207
+ whiteSpace: b.whiteSpace,
208
+ wordBreak: b.wordBreak
221
209
  };
222
- return /* @__PURE__ */ Z(II, { ref: G, ...c, children: /* @__PURE__ */ Z($, { ...X, children: I.children }) });
223
- }), WI = (I) => {
224
- var c;
225
- const G = M(I.column.columnDef.cell, I.getContext());
226
- return (c = I.column.columnDef.meta) != null && c.isCustom ? /* @__PURE__ */ Z(r.Fragment, { children: G }, I.id) : /* @__PURE__ */ Z(gI, { cell: I, children: G }, I.id);
210
+ return /* @__PURE__ */ G(K, { ref: l, ...b, children: /* @__PURE__ */ G(f, { ...Z, children: I.children }) });
211
+ }), GI = (I) => {
212
+ const l = D(I.column.columnDef.cell, I.getContext());
213
+ return I.column.columnDef.meta?.isCustom ? /* @__PURE__ */ G(U.Fragment, { children: l }, I.id) : /* @__PURE__ */ G(q, { cell: I, children: l }, I.id);
227
214
  };
228
215
  export {
229
- gI as DataGridTableCell,
230
- II as TableCell,
231
- $ as TableCellContent,
232
- WI as getDataGridTableCell
216
+ q as DataGridTableCell,
217
+ K as TableCell,
218
+ f as TableCellContent,
219
+ GI as getDataGridTableCell
233
220
  };
234
221
  //# sourceMappingURL=index.es.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.es.js","sources":["../../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"],"names":["white","p3","children","style","isMultiline","whiteSpace","rest","wordBreak","undefined","isDisabled","isRowHover","isRowSelected","isBordered","isShadowed","isFocused","isActive","isResizing","isLastFixed","error","textAlign","writingMode","verticalAlign","padding","startAdornment","endAdornment","Medium","Default","props","ref","code","nextFocus","focus","prevSibling","lastCell","nextSibling","firstCell","userSelect","caption"],"mappings":";;;;;;;;;AAAa;AAAA;AAAA;AAgBb;AAAoD;AACxB;AACD;AACD;AACC;AACD;AAE1B;AAEU;AAAA;AAAA;AAAA;AAAA;AAQI;AACwB;AAEOA;AAE3C;AAuCc;AACsC;AAElD;AAIY;AACsC;AAElD;AAeY;AAEZ;AARc;AACsC;AAElD;AASU;AACwC;AAEpD;AAmBY;AACQ;AACuBA;AAE3C;AAkBY;AACQ;AACuBA;AAE3C;AAQY;AACsC;AAEPA;AACvB;AAEpB;AAgEW;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAOF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAYA;AAAA;AAAA;AAAA;AAAA;AAKC;AACgBC;AAG5B;AAOA;AAAM;AAACC;AAAUC;AAAOC;AAAaC;AAAwB;AAAiBC;AAEzD;AAChBA;AAEI;AACLD;AACAE;AAEGJ;AAAAA;AAGW;AAC0BK;AAG5C;AAKF;AAGE;AAEM;AACJN;AAEAO;AACAC;AACAC;AACAC;AACAC;AACAC;AACAC;AACAC;AACAC;AACAC;AAEAC;AACAC;AACAC;AACAC;AACa;AAEbC;AACAC;AAEsBC;AACEC;AAErBpB;AAuEa;AACbA;;AApEHqB;AAEA;AAEA;AACE;AAEA;AAIA;AAAA;AAGF;AACEC;AACA;AAAA;AAGF;AACE;AAGA;AAAUC;AACH;AAEH;AACE;AAIA;AACE;AAEAC;AAAWC;AACb;AAEF;AAAA;AAGA;AACE;AACAC;AAAaD;AAEb;AACA;AACE;AACAE;AAAUF;AACZ;AAEF;AAAA;AAEA;AACE;AACAG;AAAaH;AAEb;AACA;AACE;AACAI;AAAWJ;AACb;AAEF;AAAA;AAAA;AAEN;AACF;AAOS;AACLV;AACAF;AACAC;AACAgB;AAEoC;AAE3BjC;AAAAA;AAGE;AACwBK;AACFA;AACNA;AACSA;AACMA;AACPA;AACAA;AACAA;AACJA;AACOA;AAER;AACM;AAKxC;AAEI;AACGe;AAAAA;AACArB;AACAsB;AACqD;AACxD;AACCa;AAGP;AAII;AAEqB;AACMjC;AACDC;AACDE;AAGzB;AAKF;;AAIA;AAEA;AASF;;;;;;;"}
1
+ {"version":3,"file":"index.es.js","sources":["../../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"],"names":["white","p3","children","style","isMultiline","whiteSpace","rest","wordBreak","undefined","isDisabled","isRowHover","isRowSelected","isBordered","isShadowed","isFocused","isActive","isResizing","isLastFixed","error","textAlign","writingMode","verticalAlign","padding","startAdornment","endAdornment","Medium","Default","props","ref","code","focus","prevSibling","nextSibling","userSelect","caption"],"mappings":";;;;;;;;;AAAa;AAAA;AAAA;AAgBb;AAAoD;AACxB;AACD;AACD;AACC;AACD;AAE1B;AAEU;AAAA;AAAA;AAAA;AAAA;AAQI;AACwB;AAEOA;AAE3C;AAuCc;AACsC;AAElD;AAIY;AACsC;AAElD;AAeY;AAEZ;AARc;AACsC;AAElD;AASU;AACwC;AAEpD;AAmBY;AACQ;AACuBA;AAE3C;AAkBY;AACQ;AACuBA;AAE3C;AAQY;AACsC;AAEPA;AACvB;AAEpB;AAgEW;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAOF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAYA;AAAA;AAAA;AAAA;AAAA;AAKC;AACgBC;AAG5B;AAOA;AAAM;AAACC;AAAUC;AAAOC;AAAaC;AAAwB;AAAiBC;AAEzD;AAChBA;AAEI;AACLD;AACAE;AAEGJ;AAAAA;AAGW;AAC0BK;AAG5C;AAKF;AAGE;AAEM;AACJN;AAEAO;AACAC;AACAC;AACAC;AACAC;AACAC;AACAC;AACAC;AACAC;AACAC;AAEAC;AACAC;AACAC;AACAC;AACa;AAEbC;AACAC;AAEsBC;AACEC;AAErBpB;AAuEa;AACbA;AApEHqB;AAEA;AAEA;AACE;AAEA;AAIA;AAAA;AAGF;AACEC;AACA;AAAA;AAGF;AACE;AAGA;AAAUC;AACH;AAEH;AACE;AAIA;AAGaC;AAGf;AAAA;AAGA;AAEEC;AAAaD;AAEb;AACA;AAEYA;AAGd;AAAA;AAEA;AAEEE;AAAaF;AAEb;AACA;AAEaA;AAGf;AAAA;AAAA;AAEN;AACF;AAOS;AACLT;AACAF;AACAC;AACAa;AAEoC;AAE3B9B;AAAAA;AAGE;AACwBK;AACFA;AACNA;AACSA;AACMA;AACPA;AACAA;AACAA;AACJA;AACOA;AAER;AACM;AAKxC;AAEI;AACGe;AAAAA;AACArB;AACAsB;AACqD;AACxD;AACCU;AAGP;AAII;AAEqB;AACM9B;AACDC;AACDE;AAGzB;AAKF;AAIA;AAEA;AASF;;;;;;;"}