@join-x5/react-data-grid 1.1.1-nightly → 1.1.2-nightly

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (86) hide show
  1. package/dist/DataGrid.d.ts +3 -0
  2. package/dist/DataGrid.es.js +67 -0
  3. package/dist/DataGrid.es.js.map +1 -0
  4. package/dist/DataGridContext.d.ts +10 -0
  5. package/dist/DataGridContext.es.js +23 -0
  6. package/dist/DataGridContext.es.js.map +1 -0
  7. package/dist/Table/index.d.ts +25 -0
  8. package/dist/Table/index.es.js +93 -0
  9. package/dist/Table/index.es.js.map +1 -0
  10. package/dist/Table/types.d.ts +3 -0
  11. package/dist/TableBody/index.d.ts +11 -0
  12. package/dist/TableBody/index.es.js +26 -0
  13. package/dist/TableBody/index.es.js.map +1 -0
  14. package/dist/TableCell/hook.d.ts +4 -0
  15. package/dist/TableCell/hook.es.js +42 -0
  16. package/dist/TableCell/hook.es.js.map +1 -0
  17. package/dist/TableCell/index.d.ts +9 -0
  18. package/dist/TableCell/index.es.js +234 -0
  19. package/dist/TableCell/index.es.js.map +1 -0
  20. package/dist/TableCell/types.d.ts +46 -0
  21. package/dist/TableDropdown/index.d.ts +8 -0
  22. package/dist/TableDropdown/index.es.js +26 -0
  23. package/dist/TableDropdown/index.es.js.map +1 -0
  24. package/dist/TableHead/index.d.ts +6 -0
  25. package/dist/TableHead/index.es.js +31 -0
  26. package/dist/TableHead/index.es.js.map +1 -0
  27. package/dist/TableHeadCell/index.d.ts +14 -0
  28. package/dist/TableHeadCell/index.es.js +146 -0
  29. package/dist/TableHeadCell/index.es.js.map +1 -0
  30. package/dist/TableHeadCell/types.d.ts +37 -0
  31. package/dist/TableHeadCell/types.es.js +5 -0
  32. package/dist/TableHeadCell/types.es.js.map +1 -0
  33. package/dist/TableHeadRow/index.d.ts +3 -0
  34. package/dist/TableHeadRow/index.es.js +14 -0
  35. package/dist/TableHeadRow/index.es.js.map +1 -0
  36. package/dist/TableHeadRow/types.d.ts +2 -0
  37. package/dist/TableInputCell/button.d.ts +8 -0
  38. package/dist/TableInputCell/button.es.js +30 -0
  39. package/dist/TableInputCell/button.es.js.map +1 -0
  40. package/dist/TableInputCell/checkbox.d.ts +11 -0
  41. package/dist/TableInputCell/checkbox.es.js +32 -0
  42. package/dist/TableInputCell/checkbox.es.js.map +1 -0
  43. package/dist/TableInputCell/date.d.ts +18 -0
  44. package/dist/TableInputCell/date.es.js +40 -0
  45. package/dist/TableInputCell/date.es.js.map +1 -0
  46. package/dist/TableInputCell/dropdown.d.ts +19 -0
  47. package/dist/TableInputCell/dropdown.es.js +40 -0
  48. package/dist/TableInputCell/dropdown.es.js.map +1 -0
  49. package/dist/TableInputCell/expanding.d.ts +11 -0
  50. package/dist/TableInputCell/expanding.es.js +58 -0
  51. package/dist/TableInputCell/expanding.es.js.map +1 -0
  52. package/dist/TableInputCell/hook.d.ts +611 -0
  53. package/dist/TableInputCell/hook.es.js +52 -0
  54. package/dist/TableInputCell/hook.es.js.map +1 -0
  55. package/dist/TableInputCell/icon.d.ts +8 -0
  56. package/dist/TableInputCell/icon.es.js +30 -0
  57. package/dist/TableInputCell/icon.es.js.map +1 -0
  58. package/dist/TableInputCell/index.d.ts +10 -0
  59. package/dist/TableInputCell/label.d.ts +8 -0
  60. package/dist/TableInputCell/label.es.js +30 -0
  61. package/dist/TableInputCell/label.es.js.map +1 -0
  62. package/dist/TableInputCell/switch.d.ts +11 -0
  63. package/dist/TableInputCell/switch.es.js +32 -0
  64. package/dist/TableInputCell/switch.es.js.map +1 -0
  65. package/dist/TableInputCell/text.d.ts +22 -0
  66. package/dist/TableInputCell/text.es.js +91 -0
  67. package/dist/TableInputCell/text.es.js.map +1 -0
  68. package/dist/TableInputCell/textarea.d.ts +23 -0
  69. package/dist/TableInputCell/textarea.es.js +83 -0
  70. package/dist/TableInputCell/textarea.es.js.map +1 -0
  71. package/dist/TableInputCell/types.d.ts +4 -0
  72. package/dist/TableRow/index.d.ts +5 -0
  73. package/dist/TableRow/index.es.js +25 -0
  74. package/dist/TableRow/index.es.js.map +1 -0
  75. package/dist/TableRow/types.d.ts +2 -0
  76. package/dist/hook.d.ts +3 -0
  77. package/dist/hook.es.js +23 -0
  78. package/dist/hook.es.js.map +1 -0
  79. package/dist/index.cjs +2 -0
  80. package/dist/index.cjs.map +1 -0
  81. package/dist/index.d.ts +10 -0
  82. package/dist/index.es.js +72 -0
  83. package/dist/index.es.js.map +1 -0
  84. package/dist/types.d.ts +54 -0
  85. package/package.json +1 -1
  86. package/dist/tsconfig.tsbuildinfo +0 -1
@@ -0,0 +1,146 @@
1
+ "use client";
2
+ import { jsxs as B, jsx as Z } from "@emotion/react/jsx-runtime";
3
+ import A from "@emotion/styled/base";
4
+ import { useState as D, useContext as z } from "react";
5
+ import { flexRender as w } from "@tanstack/react-table";
6
+ import { SizeTokenValue as l, forwardRef as Q, useRefMerge as O } from "@join-x5/react-theme";
7
+ import { ColumnArea as d } from "@join-x5/react-data-grid-settings";
8
+ import { DataGridContext as j } from "../DataGridContext.es.js";
9
+ import { areaProps as r } from "../TableCell/hook.es.js";
10
+ import { TableHeadCellVariant as i } from "./types.es.js";
11
+ function t() {
12
+ 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).";
13
+ }
14
+ const E = /* @__PURE__ */ A("div", process.env.NODE_ENV === "production" ? {
15
+ target: "e1rrcx343"
16
+ } : {
17
+ target: "e1rrcx343",
18
+ label: "TableHeadCellResizer"
19
+ })("display:flex;position:absolute;align-items:center;justify-content:center;top:0;right:-5px;width:10px;height:100%;cursor:col-resize;z-index:1;::before{content:'';display:block;width:3px;height:24px;border-radius:8px;user-select:none;pointer-events:none;opacity:0;background-color:", (g) => g.theme.colors.accent[80], ";}&[data-resizing]::before{opacity:1;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/sadykovsd/join-x5/packages/data-grid/src/TableHeadCell/index.tsx"],"names":[],"mappings":"AAoB8C","file":"/home/sadykovsd/join-x5/packages/data-grid/src/TableHeadCell/index.tsx","sourcesContent":["'use client';\n\nimport {useContext, useState} from 'react';\nimport styled from '@emotion/styled';\nimport {flexRender} from '@tanstack/react-table';\n\nimport {forwardRef, SizeTokenValue, useRefMerge} from '@join-x5/react-theme';\nimport {ColumnArea} from '@join-x5/react-data-grid-settings';\n\nimport {DataGridContext} from 'DataGridContext';\n\nimport {areaProps} from 'TableCell/hook';\n\nimport {TableHeadCellVariant} from './types';\n\nimport type {KeyboardEventHandler, MouseEventHandler} from 'react';\nimport type {Header} from '@tanstack/react-table';\nimport type {FRC} from '@join-x5/react-theme';\nimport type {TableHeadCellProps} from './types';\n\nexport const TableHeadCellResizer = styled.div`\n  display: flex;\n  position: absolute;\n  align-items: center;\n  justify-content: center;\n  top: 0;\n  right: -5px;\n  width: 10px;\n  height: 100%;\n  cursor: col-resize;\n  z-index: 1;\n\n  ::before {\n    content: '';\n    display: block;\n    width: 3px;\n    height: 24px;\n    border-radius: 8px;\n    user-select: none;\n    pointer-events: none;\n    opacity: 0;\n\n    background-color: ${props => props.theme.colors.accent[80]};\n  }\n\n  &[data-resizing]::before {\n    opacity: 1;\n  }\n`;\n\nconst Cell = styled.th`\n  position: relative;\n  box-sizing: border-box;\n\n  ${props => ({\n    color: props.theme.colors.grey[100],\n    backgroundColor: props.theme.colors.white,\n\n    '--border-color': props.theme.colors.grey[10],\n  })};\n\n  &[data-${SizeTokenValue.Large.toLocaleLowerCase()}] {\n    padding: 12px;\n    min-height: 44px;\n\n    &[data-${TableHeadCellVariant.Checkbox.toLocaleLowerCase()}] {\n      padding: 14px 12px;\n\n      &[data-has-end-adornment] {\n        padding-right: 8px;\n      }\n    }\n\n    ${props => props.theme.typography.h4}\n  }\n\n  &[data-${SizeTokenValue.Medium.toLocaleLowerCase()}] {\n    padding: 12px;\n    min-height: 40px;\n\n    &[data-${TableHeadCellVariant.Checkbox.toLocaleLowerCase()}] {\n      padding: 12px;\n\n      &[data-has-end-adornment] {\n        padding-right: 8px;\n      }\n    }\n\n    ${props => props.theme.typography.h5}\n  }\n\n  &[data-${SizeTokenValue.Small.toLocaleLowerCase()}] {\n    padding: 8px;\n    min-height: 32px;\n\n    ${props => props.theme.typography.h5}\n  }\n\n  &[data-shadowed] {\n    filter: drop-shadow(8px 0px 8px rgba(80, 86, 94, 0.08));\n\n    &::before {\n      border-bottom-width: 0;\n    }\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  :hover {\n    ${props => ({\n      backgroundColor: props.theme.colors.grey[10],\n\n      '--border-color': props.theme.colors.grey[20],\n    })}\n  }\n\n  &[data-has-active] {\n    cursor: pointer;\n\n    &[data-active],\n    :active {\n      ${props => ({\n        backgroundColor: props.theme.colors.grey[30],\n\n        '--border-color': 'transparent',\n      })}\n    }\n  }\n\n  :focus {\n    outline: none;\n  }\n\n  &[data-disabled] {\n    :hover {\n      ${props => ({\n        backgroundColor: props.theme.colors.grey[10],\n\n        '--border-color': props.theme.colors.grey[20],\n      })}\n    }\n\n    ${props => ({\n      color: props.theme.colors.grey[40],\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 2px 0;\n    border-style: solid;\n    border-color: var(--border-color);\n  }\n\n  ::after {\n    content: '';\n    display: block;\n    position: absolute;\n    box-sizing: border-box;\n    top: calc(50% - 8px);\n    right: 0;\n    width: 2px;\n    height: 16px;\n    user-select: none;\n    pointer-events: none;\n    background-color: var(--border-color, transparent);\n  }\n\n  &[data-bordered] {\n    ::before {\n      border-width: 0 1px 2px 0;\n    }\n\n    :last-of-type::before {\n      border-width: 0 0 2px 0;\n    }\n\n    ::after {\n      display: none;\n    }\n  }\n\n  :last-of-type::after {\n    display: none;\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  flex-grow: 1;\n`;\n\nexport const TableHeadCell: FRC<HTMLTableCellElement, TableHeadCellProps> = forwardRef((props, baseRef) => {\n  const {\n    children,\n\n    isDisabled,\n    isActive,\n    isBordered,\n    isLastFixed,\n    isShadowed,\n\n    writingMode,\n    verticalAlign = 'top',\n    textAlign = 'left',\n    userSelect = 'none',\n\n    startAdornment,\n    endAdornment,\n    resizer,\n    dropdown: Dropdown,\n\n    variant = TableHeadCellVariant.Default,\n    size = SizeTokenValue.Medium,\n    columnArea = ColumnArea.Default,\n\n    ...rest\n  } = props;\n\n  const ref = useRefMerge(baseRef);\n  const [isDropdownOpen, setIsDropdownOpen] = useState<boolean>(false);\n\n  const onKeyDown: KeyboardEventHandler<HTMLTableCellElement> = e => {\n    if (e.code === 'Escape') {\n      e.currentTarget.blur();\n    }\n\n    if (e.code === 'Enter' || e.code === 'NumpadEnter') {\n      e.currentTarget.click();\n    }\n\n    props.onKeyDown?.(e);\n  };\n\n  const onClick: MouseEventHandler<HTMLTableCellElement> = e => {\n    if (Dropdown && !isDropdownOpen) {\n      setIsDropdownOpen(true);\n    }\n\n    props.onClick?.(e);\n  };\n\n  const dropdown = Dropdown ? <Dropdown targetRef={ref} isOpen={isDropdownOpen} setIsOpen={setIsDropdownOpen} /> : null;\n  const hasActive = !!props.onClick || !!Dropdown || !!isActive;\n\n  const cellProps = {\n    ...rest,\n\n    onClick,\n    onKeyDown,\n\n    style: {\n      verticalAlign,\n      textAlign,\n      writingMode,\n      userSelect,\n\n      ...props.style,\n    },\n\n    'data-cell': true,\n    'data-disabled': isDisabled ? true : undefined,\n    'data-active': isActive || isDropdownOpen ? true : undefined,\n    'data-bordered': isBordered ? true : undefined,\n    'data-shadowed': isShadowed ? true : undefined,\n    'data-has-active': hasActive ? true : undefined,\n    'data-has-end-adornment': endAdornment ? true : undefined,\n    'data-last-fixed': isLastFixed ? true : undefined,\n\n    [`data-${size.toLowerCase()}`]: true,\n    [`data-${variant.toLowerCase()}`]: true,\n    [`data-${columnArea.toLowerCase()}`]: true,\n  };\n\n  return (\n    <Cell ref={ref} tabIndex={0} {...cellProps}>\n      <Container>\n        {startAdornment}\n        <Content>{children}</Content>\n        {endAdornment}\n      </Container>\n      {resizer}\n      {dropdown}\n    </Cell>\n  );\n});\n\ntype DataGridTableHeadCellProps = {\n  header: Header<unknown, unknown>;\n};\n\nexport const DataGridTableHeadCell: React.FC<DataGridTableHeadCellProps> = ({header}) => {\n  const context = useContext(DataGridContext);\n\n  const resizer = (() => {\n    if (header.column.getCanResize() === false) {\n      return null;\n    }\n\n    return (\n      <TableHeadCellResizer\n        onDoubleClick={() => header.column.resetSize()}\n        onMouseDown={header.getResizeHandler()}\n        onTouchStart={header.getResizeHandler()}\n        data-resizing={header.column.getIsResizing() ? true : undefined}\n      />\n    );\n  })();\n\n  const content = header.isPlaceholder ? null : flexRender(header.column.columnDef.header, header.getContext());\n\n  const resultProps: TableHeadCellProps = {\n    resizer,\n\n    qa: context.qa,\n    isBordered: context.isBordered,\n    isShadowed: context.isShadowed,\n    size: context.size,\n    verticalAlign: context.verticalAlign,\n\n    colSpan: header.colSpan,\n    rowSpan: header.rowSpan,\n\n    style: {\n      width: `calc(var(--header-${header?.id}-size) * 1px)`,\n    },\n  };\n\n  areaProps(header.column, resultProps);\n\n  if (context.headCellProps) {\n    Object.assign(\n      resultProps,\n      context.headCellProps instanceof Function ? context.headCellProps(header) : context.headCellProps\n    );\n  }\n\n  return (\n    <TableHeadCell key={header.id} {...resultProps}>\n      {content}\n    </TableHeadCell>\n  );\n};\n\nexport const getDataGridTableHeadCell = (header: DataGridTableHeadCellProps['header']) => {\n  return <DataGridTableHeadCell key={header.id} header={header} />;\n};\n\nexport * from './types';\n"]} */")), U = /* @__PURE__ */ A("th", process.env.NODE_ENV === "production" ? {
20
+ target: "e1rrcx342"
21
+ } : {
22
+ target: "e1rrcx342",
23
+ label: "Cell"
24
+ })("position:relative;box-sizing:border-box;", (g) => ({
25
+ color: g.theme.colors.grey[100],
26
+ backgroundColor: g.theme.colors.white,
27
+ "--border-color": g.theme.colors.grey[10]
28
+ }), ";&[data-", l.Large.toLocaleLowerCase(), "]{padding:12px;min-height:44px;", (g) => g.theme.typography.h4, ";&[data-", i.Checkbox.toLocaleLowerCase(), "]{padding:14px 12px;&[data-has-end-adornment]{padding-right:8px;}}}&[data-", l.Medium.toLocaleLowerCase(), "]{padding:12px;min-height:40px;", (g) => g.theme.typography.h5, ";&[data-", i.Checkbox.toLocaleLowerCase(), "]{padding:12px;&[data-has-end-adornment]{padding-right:8px;}}}&[data-", l.Small.toLocaleLowerCase(), "]{padding:8px;min-height:32px;", (g) => g.theme.typography.h5, ";}&[data-shadowed]{filter:drop-shadow(8px 0px 8px rgba(80, 86, 94, 0.08));&::before{border-bottom-width:0;}}&[data-", d.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-", d.FixedRight.toLocaleLowerCase(), "]{position:sticky;z-index:1;&[data-shadowed][data-last-fixed]{filter:drop-shadow(-8px 0px 8px rgba(80, 86, 94, 0.08));}}:hover{", (g) => ({
29
+ backgroundColor: g.theme.colors.grey[10],
30
+ "--border-color": g.theme.colors.grey[20]
31
+ }), ";}&[data-has-active]{cursor:pointer;&[data-active],:active{", (g) => ({
32
+ backgroundColor: g.theme.colors.grey[30],
33
+ "--border-color": "transparent"
34
+ }), ";}}:focus{outline:none;}&[data-disabled]{", (g) => ({
35
+ color: g.theme.colors.grey[40]
36
+ }), ";:hover{", (g) => ({
37
+ backgroundColor: g.theme.colors.grey[10],
38
+ "--border-color": g.theme.colors.grey[20]
39
+ }), ";}}::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 2px 0;border-style:solid;border-color:var(--border-color);}::after{content:'';display:block;position:absolute;box-sizing:border-box;top:calc(50% - 8px);right:0;width:2px;height:16px;user-select:none;pointer-events:none;background-color:var(--border-color, transparent);}&[data-bordered]{::before{border-width:0 1px 2px 0;}:last-of-type::before{border-width:0 0 2px 0;}::after{display:none;}}:last-of-type::after{display:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/sadykovsd/join-x5/packages/data-grid/src/TableHeadCell/index.tsx"],"names":[],"mappings":"AAkDsB","file":"/home/sadykovsd/join-x5/packages/data-grid/src/TableHeadCell/index.tsx","sourcesContent":["'use client';\n\nimport {useContext, useState} from 'react';\nimport styled from '@emotion/styled';\nimport {flexRender} from '@tanstack/react-table';\n\nimport {forwardRef, SizeTokenValue, useRefMerge} from '@join-x5/react-theme';\nimport {ColumnArea} from '@join-x5/react-data-grid-settings';\n\nimport {DataGridContext} from 'DataGridContext';\n\nimport {areaProps} from 'TableCell/hook';\n\nimport {TableHeadCellVariant} from './types';\n\nimport type {KeyboardEventHandler, MouseEventHandler} from 'react';\nimport type {Header} from '@tanstack/react-table';\nimport type {FRC} from '@join-x5/react-theme';\nimport type {TableHeadCellProps} from './types';\n\nexport const TableHeadCellResizer = styled.div`\n  display: flex;\n  position: absolute;\n  align-items: center;\n  justify-content: center;\n  top: 0;\n  right: -5px;\n  width: 10px;\n  height: 100%;\n  cursor: col-resize;\n  z-index: 1;\n\n  ::before {\n    content: '';\n    display: block;\n    width: 3px;\n    height: 24px;\n    border-radius: 8px;\n    user-select: none;\n    pointer-events: none;\n    opacity: 0;\n\n    background-color: ${props => props.theme.colors.accent[80]};\n  }\n\n  &[data-resizing]::before {\n    opacity: 1;\n  }\n`;\n\nconst Cell = styled.th`\n  position: relative;\n  box-sizing: border-box;\n\n  ${props => ({\n    color: props.theme.colors.grey[100],\n    backgroundColor: props.theme.colors.white,\n\n    '--border-color': props.theme.colors.grey[10],\n  })};\n\n  &[data-${SizeTokenValue.Large.toLocaleLowerCase()}] {\n    padding: 12px;\n    min-height: 44px;\n\n    &[data-${TableHeadCellVariant.Checkbox.toLocaleLowerCase()}] {\n      padding: 14px 12px;\n\n      &[data-has-end-adornment] {\n        padding-right: 8px;\n      }\n    }\n\n    ${props => props.theme.typography.h4}\n  }\n\n  &[data-${SizeTokenValue.Medium.toLocaleLowerCase()}] {\n    padding: 12px;\n    min-height: 40px;\n\n    &[data-${TableHeadCellVariant.Checkbox.toLocaleLowerCase()}] {\n      padding: 12px;\n\n      &[data-has-end-adornment] {\n        padding-right: 8px;\n      }\n    }\n\n    ${props => props.theme.typography.h5}\n  }\n\n  &[data-${SizeTokenValue.Small.toLocaleLowerCase()}] {\n    padding: 8px;\n    min-height: 32px;\n\n    ${props => props.theme.typography.h5}\n  }\n\n  &[data-shadowed] {\n    filter: drop-shadow(8px 0px 8px rgba(80, 86, 94, 0.08));\n\n    &::before {\n      border-bottom-width: 0;\n    }\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  :hover {\n    ${props => ({\n      backgroundColor: props.theme.colors.grey[10],\n\n      '--border-color': props.theme.colors.grey[20],\n    })}\n  }\n\n  &[data-has-active] {\n    cursor: pointer;\n\n    &[data-active],\n    :active {\n      ${props => ({\n        backgroundColor: props.theme.colors.grey[30],\n\n        '--border-color': 'transparent',\n      })}\n    }\n  }\n\n  :focus {\n    outline: none;\n  }\n\n  &[data-disabled] {\n    :hover {\n      ${props => ({\n        backgroundColor: props.theme.colors.grey[10],\n\n        '--border-color': props.theme.colors.grey[20],\n      })}\n    }\n\n    ${props => ({\n      color: props.theme.colors.grey[40],\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 2px 0;\n    border-style: solid;\n    border-color: var(--border-color);\n  }\n\n  ::after {\n    content: '';\n    display: block;\n    position: absolute;\n    box-sizing: border-box;\n    top: calc(50% - 8px);\n    right: 0;\n    width: 2px;\n    height: 16px;\n    user-select: none;\n    pointer-events: none;\n    background-color: var(--border-color, transparent);\n  }\n\n  &[data-bordered] {\n    ::before {\n      border-width: 0 1px 2px 0;\n    }\n\n    :last-of-type::before {\n      border-width: 0 0 2px 0;\n    }\n\n    ::after {\n      display: none;\n    }\n  }\n\n  :last-of-type::after {\n    display: none;\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  flex-grow: 1;\n`;\n\nexport const TableHeadCell: FRC<HTMLTableCellElement, TableHeadCellProps> = forwardRef((props, baseRef) => {\n  const {\n    children,\n\n    isDisabled,\n    isActive,\n    isBordered,\n    isLastFixed,\n    isShadowed,\n\n    writingMode,\n    verticalAlign = 'top',\n    textAlign = 'left',\n    userSelect = 'none',\n\n    startAdornment,\n    endAdornment,\n    resizer,\n    dropdown: Dropdown,\n\n    variant = TableHeadCellVariant.Default,\n    size = SizeTokenValue.Medium,\n    columnArea = ColumnArea.Default,\n\n    ...rest\n  } = props;\n\n  const ref = useRefMerge(baseRef);\n  const [isDropdownOpen, setIsDropdownOpen] = useState<boolean>(false);\n\n  const onKeyDown: KeyboardEventHandler<HTMLTableCellElement> = e => {\n    if (e.code === 'Escape') {\n      e.currentTarget.blur();\n    }\n\n    if (e.code === 'Enter' || e.code === 'NumpadEnter') {\n      e.currentTarget.click();\n    }\n\n    props.onKeyDown?.(e);\n  };\n\n  const onClick: MouseEventHandler<HTMLTableCellElement> = e => {\n    if (Dropdown && !isDropdownOpen) {\n      setIsDropdownOpen(true);\n    }\n\n    props.onClick?.(e);\n  };\n\n  const dropdown = Dropdown ? <Dropdown targetRef={ref} isOpen={isDropdownOpen} setIsOpen={setIsDropdownOpen} /> : null;\n  const hasActive = !!props.onClick || !!Dropdown || !!isActive;\n\n  const cellProps = {\n    ...rest,\n\n    onClick,\n    onKeyDown,\n\n    style: {\n      verticalAlign,\n      textAlign,\n      writingMode,\n      userSelect,\n\n      ...props.style,\n    },\n\n    'data-cell': true,\n    'data-disabled': isDisabled ? true : undefined,\n    'data-active': isActive || isDropdownOpen ? true : undefined,\n    'data-bordered': isBordered ? true : undefined,\n    'data-shadowed': isShadowed ? true : undefined,\n    'data-has-active': hasActive ? true : undefined,\n    'data-has-end-adornment': endAdornment ? true : undefined,\n    'data-last-fixed': isLastFixed ? true : undefined,\n\n    [`data-${size.toLowerCase()}`]: true,\n    [`data-${variant.toLowerCase()}`]: true,\n    [`data-${columnArea.toLowerCase()}`]: true,\n  };\n\n  return (\n    <Cell ref={ref} tabIndex={0} {...cellProps}>\n      <Container>\n        {startAdornment}\n        <Content>{children}</Content>\n        {endAdornment}\n      </Container>\n      {resizer}\n      {dropdown}\n    </Cell>\n  );\n});\n\ntype DataGridTableHeadCellProps = {\n  header: Header<unknown, unknown>;\n};\n\nexport const DataGridTableHeadCell: React.FC<DataGridTableHeadCellProps> = ({header}) => {\n  const context = useContext(DataGridContext);\n\n  const resizer = (() => {\n    if (header.column.getCanResize() === false) {\n      return null;\n    }\n\n    return (\n      <TableHeadCellResizer\n        onDoubleClick={() => header.column.resetSize()}\n        onMouseDown={header.getResizeHandler()}\n        onTouchStart={header.getResizeHandler()}\n        data-resizing={header.column.getIsResizing() ? true : undefined}\n      />\n    );\n  })();\n\n  const content = header.isPlaceholder ? null : flexRender(header.column.columnDef.header, header.getContext());\n\n  const resultProps: TableHeadCellProps = {\n    resizer,\n\n    qa: context.qa,\n    isBordered: context.isBordered,\n    isShadowed: context.isShadowed,\n    size: context.size,\n    verticalAlign: context.verticalAlign,\n\n    colSpan: header.colSpan,\n    rowSpan: header.rowSpan,\n\n    style: {\n      width: `calc(var(--header-${header?.id}-size) * 1px)`,\n    },\n  };\n\n  areaProps(header.column, resultProps);\n\n  if (context.headCellProps) {\n    Object.assign(\n      resultProps,\n      context.headCellProps instanceof Function ? context.headCellProps(header) : context.headCellProps\n    );\n  }\n\n  return (\n    <TableHeadCell key={header.id} {...resultProps}>\n      {content}\n    </TableHeadCell>\n  );\n};\n\nexport const getDataGridTableHeadCell = (header: DataGridTableHeadCellProps['header']) => {\n  return <DataGridTableHeadCell key={header.id} header={header} />;\n};\n\nexport * from './types';\n"]} */")), T = /* @__PURE__ */ A("div", process.env.NODE_ENV === "production" ? {
40
+ target: "e1rrcx341"
41
+ } : {
42
+ target: "e1rrcx341",
43
+ label: "Container"
44
+ })(process.env.NODE_ENV === "production" ? {
45
+ name: "15dbgh0",
46
+ styles: "display:flex;position:relative;box-sizing:border-box;gap:8px"
47
+ } : {
48
+ name: "15dbgh0",
49
+ 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/TableHeadCell/index.tsx"],"names":[],"mappings":"AAoN4B","file":"/home/sadykovsd/join-x5/packages/data-grid/src/TableHeadCell/index.tsx","sourcesContent":["'use client';\n\nimport {useContext, useState} from 'react';\nimport styled from '@emotion/styled';\nimport {flexRender} from '@tanstack/react-table';\n\nimport {forwardRef, SizeTokenValue, useRefMerge} from '@join-x5/react-theme';\nimport {ColumnArea} from '@join-x5/react-data-grid-settings';\n\nimport {DataGridContext} from 'DataGridContext';\n\nimport {areaProps} from 'TableCell/hook';\n\nimport {TableHeadCellVariant} from './types';\n\nimport type {KeyboardEventHandler, MouseEventHandler} from 'react';\nimport type {Header} from '@tanstack/react-table';\nimport type {FRC} from '@join-x5/react-theme';\nimport type {TableHeadCellProps} from './types';\n\nexport const TableHeadCellResizer = styled.div`\n  display: flex;\n  position: absolute;\n  align-items: center;\n  justify-content: center;\n  top: 0;\n  right: -5px;\n  width: 10px;\n  height: 100%;\n  cursor: col-resize;\n  z-index: 1;\n\n  ::before {\n    content: '';\n    display: block;\n    width: 3px;\n    height: 24px;\n    border-radius: 8px;\n    user-select: none;\n    pointer-events: none;\n    opacity: 0;\n\n    background-color: ${props => props.theme.colors.accent[80]};\n  }\n\n  &[data-resizing]::before {\n    opacity: 1;\n  }\n`;\n\nconst Cell = styled.th`\n  position: relative;\n  box-sizing: border-box;\n\n  ${props => ({\n    color: props.theme.colors.grey[100],\n    backgroundColor: props.theme.colors.white,\n\n    '--border-color': props.theme.colors.grey[10],\n  })};\n\n  &[data-${SizeTokenValue.Large.toLocaleLowerCase()}] {\n    padding: 12px;\n    min-height: 44px;\n\n    &[data-${TableHeadCellVariant.Checkbox.toLocaleLowerCase()}] {\n      padding: 14px 12px;\n\n      &[data-has-end-adornment] {\n        padding-right: 8px;\n      }\n    }\n\n    ${props => props.theme.typography.h4}\n  }\n\n  &[data-${SizeTokenValue.Medium.toLocaleLowerCase()}] {\n    padding: 12px;\n    min-height: 40px;\n\n    &[data-${TableHeadCellVariant.Checkbox.toLocaleLowerCase()}] {\n      padding: 12px;\n\n      &[data-has-end-adornment] {\n        padding-right: 8px;\n      }\n    }\n\n    ${props => props.theme.typography.h5}\n  }\n\n  &[data-${SizeTokenValue.Small.toLocaleLowerCase()}] {\n    padding: 8px;\n    min-height: 32px;\n\n    ${props => props.theme.typography.h5}\n  }\n\n  &[data-shadowed] {\n    filter: drop-shadow(8px 0px 8px rgba(80, 86, 94, 0.08));\n\n    &::before {\n      border-bottom-width: 0;\n    }\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  :hover {\n    ${props => ({\n      backgroundColor: props.theme.colors.grey[10],\n\n      '--border-color': props.theme.colors.grey[20],\n    })}\n  }\n\n  &[data-has-active] {\n    cursor: pointer;\n\n    &[data-active],\n    :active {\n      ${props => ({\n        backgroundColor: props.theme.colors.grey[30],\n\n        '--border-color': 'transparent',\n      })}\n    }\n  }\n\n  :focus {\n    outline: none;\n  }\n\n  &[data-disabled] {\n    :hover {\n      ${props => ({\n        backgroundColor: props.theme.colors.grey[10],\n\n        '--border-color': props.theme.colors.grey[20],\n      })}\n    }\n\n    ${props => ({\n      color: props.theme.colors.grey[40],\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 2px 0;\n    border-style: solid;\n    border-color: var(--border-color);\n  }\n\n  ::after {\n    content: '';\n    display: block;\n    position: absolute;\n    box-sizing: border-box;\n    top: calc(50% - 8px);\n    right: 0;\n    width: 2px;\n    height: 16px;\n    user-select: none;\n    pointer-events: none;\n    background-color: var(--border-color, transparent);\n  }\n\n  &[data-bordered] {\n    ::before {\n      border-width: 0 1px 2px 0;\n    }\n\n    :last-of-type::before {\n      border-width: 0 0 2px 0;\n    }\n\n    ::after {\n      display: none;\n    }\n  }\n\n  :last-of-type::after {\n    display: none;\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  flex-grow: 1;\n`;\n\nexport const TableHeadCell: FRC<HTMLTableCellElement, TableHeadCellProps> = forwardRef((props, baseRef) => {\n  const {\n    children,\n\n    isDisabled,\n    isActive,\n    isBordered,\n    isLastFixed,\n    isShadowed,\n\n    writingMode,\n    verticalAlign = 'top',\n    textAlign = 'left',\n    userSelect = 'none',\n\n    startAdornment,\n    endAdornment,\n    resizer,\n    dropdown: Dropdown,\n\n    variant = TableHeadCellVariant.Default,\n    size = SizeTokenValue.Medium,\n    columnArea = ColumnArea.Default,\n\n    ...rest\n  } = props;\n\n  const ref = useRefMerge(baseRef);\n  const [isDropdownOpen, setIsDropdownOpen] = useState<boolean>(false);\n\n  const onKeyDown: KeyboardEventHandler<HTMLTableCellElement> = e => {\n    if (e.code === 'Escape') {\n      e.currentTarget.blur();\n    }\n\n    if (e.code === 'Enter' || e.code === 'NumpadEnter') {\n      e.currentTarget.click();\n    }\n\n    props.onKeyDown?.(e);\n  };\n\n  const onClick: MouseEventHandler<HTMLTableCellElement> = e => {\n    if (Dropdown && !isDropdownOpen) {\n      setIsDropdownOpen(true);\n    }\n\n    props.onClick?.(e);\n  };\n\n  const dropdown = Dropdown ? <Dropdown targetRef={ref} isOpen={isDropdownOpen} setIsOpen={setIsDropdownOpen} /> : null;\n  const hasActive = !!props.onClick || !!Dropdown || !!isActive;\n\n  const cellProps = {\n    ...rest,\n\n    onClick,\n    onKeyDown,\n\n    style: {\n      verticalAlign,\n      textAlign,\n      writingMode,\n      userSelect,\n\n      ...props.style,\n    },\n\n    'data-cell': true,\n    'data-disabled': isDisabled ? true : undefined,\n    'data-active': isActive || isDropdownOpen ? true : undefined,\n    'data-bordered': isBordered ? true : undefined,\n    'data-shadowed': isShadowed ? true : undefined,\n    'data-has-active': hasActive ? true : undefined,\n    'data-has-end-adornment': endAdornment ? true : undefined,\n    'data-last-fixed': isLastFixed ? true : undefined,\n\n    [`data-${size.toLowerCase()}`]: true,\n    [`data-${variant.toLowerCase()}`]: true,\n    [`data-${columnArea.toLowerCase()}`]: true,\n  };\n\n  return (\n    <Cell ref={ref} tabIndex={0} {...cellProps}>\n      <Container>\n        {startAdornment}\n        <Content>{children}</Content>\n        {endAdornment}\n      </Container>\n      {resizer}\n      {dropdown}\n    </Cell>\n  );\n});\n\ntype DataGridTableHeadCellProps = {\n  header: Header<unknown, unknown>;\n};\n\nexport const DataGridTableHeadCell: React.FC<DataGridTableHeadCellProps> = ({header}) => {\n  const context = useContext(DataGridContext);\n\n  const resizer = (() => {\n    if (header.column.getCanResize() === false) {\n      return null;\n    }\n\n    return (\n      <TableHeadCellResizer\n        onDoubleClick={() => header.column.resetSize()}\n        onMouseDown={header.getResizeHandler()}\n        onTouchStart={header.getResizeHandler()}\n        data-resizing={header.column.getIsResizing() ? true : undefined}\n      />\n    );\n  })();\n\n  const content = header.isPlaceholder ? null : flexRender(header.column.columnDef.header, header.getContext());\n\n  const resultProps: TableHeadCellProps = {\n    resizer,\n\n    qa: context.qa,\n    isBordered: context.isBordered,\n    isShadowed: context.isShadowed,\n    size: context.size,\n    verticalAlign: context.verticalAlign,\n\n    colSpan: header.colSpan,\n    rowSpan: header.rowSpan,\n\n    style: {\n      width: `calc(var(--header-${header?.id}-size) * 1px)`,\n    },\n  };\n\n  areaProps(header.column, resultProps);\n\n  if (context.headCellProps) {\n    Object.assign(\n      resultProps,\n      context.headCellProps instanceof Function ? context.headCellProps(header) : context.headCellProps\n    );\n  }\n\n  return (\n    <TableHeadCell key={header.id} {...resultProps}>\n      {content}\n    </TableHeadCell>\n  );\n};\n\nexport const getDataGridTableHeadCell = (header: DataGridTableHeadCellProps['header']) => {\n  return <DataGridTableHeadCell key={header.id} header={header} />;\n};\n\nexport * from './types';\n"]} */",
50
+ toString: t
51
+ }), M = /* @__PURE__ */ A("div", process.env.NODE_ENV === "production" ? {
52
+ target: "e1rrcx340"
53
+ } : {
54
+ target: "e1rrcx340",
55
+ label: "Content"
56
+ })(process.env.NODE_ENV === "production" ? {
57
+ name: "1ff36h2",
58
+ styles: "flex-grow:1"
59
+ } : {
60
+ name: "1ff36h2",
61
+ styles: "flex-grow:1/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/sadykovsd/join-x5/packages/data-grid/src/TableHeadCell/index.tsx"],"names":[],"mappings":"AA2N0B","file":"/home/sadykovsd/join-x5/packages/data-grid/src/TableHeadCell/index.tsx","sourcesContent":["'use client';\n\nimport {useContext, useState} from 'react';\nimport styled from '@emotion/styled';\nimport {flexRender} from '@tanstack/react-table';\n\nimport {forwardRef, SizeTokenValue, useRefMerge} from '@join-x5/react-theme';\nimport {ColumnArea} from '@join-x5/react-data-grid-settings';\n\nimport {DataGridContext} from 'DataGridContext';\n\nimport {areaProps} from 'TableCell/hook';\n\nimport {TableHeadCellVariant} from './types';\n\nimport type {KeyboardEventHandler, MouseEventHandler} from 'react';\nimport type {Header} from '@tanstack/react-table';\nimport type {FRC} from '@join-x5/react-theme';\nimport type {TableHeadCellProps} from './types';\n\nexport const TableHeadCellResizer = styled.div`\n  display: flex;\n  position: absolute;\n  align-items: center;\n  justify-content: center;\n  top: 0;\n  right: -5px;\n  width: 10px;\n  height: 100%;\n  cursor: col-resize;\n  z-index: 1;\n\n  ::before {\n    content: '';\n    display: block;\n    width: 3px;\n    height: 24px;\n    border-radius: 8px;\n    user-select: none;\n    pointer-events: none;\n    opacity: 0;\n\n    background-color: ${props => props.theme.colors.accent[80]};\n  }\n\n  &[data-resizing]::before {\n    opacity: 1;\n  }\n`;\n\nconst Cell = styled.th`\n  position: relative;\n  box-sizing: border-box;\n\n  ${props => ({\n    color: props.theme.colors.grey[100],\n    backgroundColor: props.theme.colors.white,\n\n    '--border-color': props.theme.colors.grey[10],\n  })};\n\n  &[data-${SizeTokenValue.Large.toLocaleLowerCase()}] {\n    padding: 12px;\n    min-height: 44px;\n\n    &[data-${TableHeadCellVariant.Checkbox.toLocaleLowerCase()}] {\n      padding: 14px 12px;\n\n      &[data-has-end-adornment] {\n        padding-right: 8px;\n      }\n    }\n\n    ${props => props.theme.typography.h4}\n  }\n\n  &[data-${SizeTokenValue.Medium.toLocaleLowerCase()}] {\n    padding: 12px;\n    min-height: 40px;\n\n    &[data-${TableHeadCellVariant.Checkbox.toLocaleLowerCase()}] {\n      padding: 12px;\n\n      &[data-has-end-adornment] {\n        padding-right: 8px;\n      }\n    }\n\n    ${props => props.theme.typography.h5}\n  }\n\n  &[data-${SizeTokenValue.Small.toLocaleLowerCase()}] {\n    padding: 8px;\n    min-height: 32px;\n\n    ${props => props.theme.typography.h5}\n  }\n\n  &[data-shadowed] {\n    filter: drop-shadow(8px 0px 8px rgba(80, 86, 94, 0.08));\n\n    &::before {\n      border-bottom-width: 0;\n    }\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  :hover {\n    ${props => ({\n      backgroundColor: props.theme.colors.grey[10],\n\n      '--border-color': props.theme.colors.grey[20],\n    })}\n  }\n\n  &[data-has-active] {\n    cursor: pointer;\n\n    &[data-active],\n    :active {\n      ${props => ({\n        backgroundColor: props.theme.colors.grey[30],\n\n        '--border-color': 'transparent',\n      })}\n    }\n  }\n\n  :focus {\n    outline: none;\n  }\n\n  &[data-disabled] {\n    :hover {\n      ${props => ({\n        backgroundColor: props.theme.colors.grey[10],\n\n        '--border-color': props.theme.colors.grey[20],\n      })}\n    }\n\n    ${props => ({\n      color: props.theme.colors.grey[40],\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 2px 0;\n    border-style: solid;\n    border-color: var(--border-color);\n  }\n\n  ::after {\n    content: '';\n    display: block;\n    position: absolute;\n    box-sizing: border-box;\n    top: calc(50% - 8px);\n    right: 0;\n    width: 2px;\n    height: 16px;\n    user-select: none;\n    pointer-events: none;\n    background-color: var(--border-color, transparent);\n  }\n\n  &[data-bordered] {\n    ::before {\n      border-width: 0 1px 2px 0;\n    }\n\n    :last-of-type::before {\n      border-width: 0 0 2px 0;\n    }\n\n    ::after {\n      display: none;\n    }\n  }\n\n  :last-of-type::after {\n    display: none;\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  flex-grow: 1;\n`;\n\nexport const TableHeadCell: FRC<HTMLTableCellElement, TableHeadCellProps> = forwardRef((props, baseRef) => {\n  const {\n    children,\n\n    isDisabled,\n    isActive,\n    isBordered,\n    isLastFixed,\n    isShadowed,\n\n    writingMode,\n    verticalAlign = 'top',\n    textAlign = 'left',\n    userSelect = 'none',\n\n    startAdornment,\n    endAdornment,\n    resizer,\n    dropdown: Dropdown,\n\n    variant = TableHeadCellVariant.Default,\n    size = SizeTokenValue.Medium,\n    columnArea = ColumnArea.Default,\n\n    ...rest\n  } = props;\n\n  const ref = useRefMerge(baseRef);\n  const [isDropdownOpen, setIsDropdownOpen] = useState<boolean>(false);\n\n  const onKeyDown: KeyboardEventHandler<HTMLTableCellElement> = e => {\n    if (e.code === 'Escape') {\n      e.currentTarget.blur();\n    }\n\n    if (e.code === 'Enter' || e.code === 'NumpadEnter') {\n      e.currentTarget.click();\n    }\n\n    props.onKeyDown?.(e);\n  };\n\n  const onClick: MouseEventHandler<HTMLTableCellElement> = e => {\n    if (Dropdown && !isDropdownOpen) {\n      setIsDropdownOpen(true);\n    }\n\n    props.onClick?.(e);\n  };\n\n  const dropdown = Dropdown ? <Dropdown targetRef={ref} isOpen={isDropdownOpen} setIsOpen={setIsDropdownOpen} /> : null;\n  const hasActive = !!props.onClick || !!Dropdown || !!isActive;\n\n  const cellProps = {\n    ...rest,\n\n    onClick,\n    onKeyDown,\n\n    style: {\n      verticalAlign,\n      textAlign,\n      writingMode,\n      userSelect,\n\n      ...props.style,\n    },\n\n    'data-cell': true,\n    'data-disabled': isDisabled ? true : undefined,\n    'data-active': isActive || isDropdownOpen ? true : undefined,\n    'data-bordered': isBordered ? true : undefined,\n    'data-shadowed': isShadowed ? true : undefined,\n    'data-has-active': hasActive ? true : undefined,\n    'data-has-end-adornment': endAdornment ? true : undefined,\n    'data-last-fixed': isLastFixed ? true : undefined,\n\n    [`data-${size.toLowerCase()}`]: true,\n    [`data-${variant.toLowerCase()}`]: true,\n    [`data-${columnArea.toLowerCase()}`]: true,\n  };\n\n  return (\n    <Cell ref={ref} tabIndex={0} {...cellProps}>\n      <Container>\n        {startAdornment}\n        <Content>{children}</Content>\n        {endAdornment}\n      </Container>\n      {resizer}\n      {dropdown}\n    </Cell>\n  );\n});\n\ntype DataGridTableHeadCellProps = {\n  header: Header<unknown, unknown>;\n};\n\nexport const DataGridTableHeadCell: React.FC<DataGridTableHeadCellProps> = ({header}) => {\n  const context = useContext(DataGridContext);\n\n  const resizer = (() => {\n    if (header.column.getCanResize() === false) {\n      return null;\n    }\n\n    return (\n      <TableHeadCellResizer\n        onDoubleClick={() => header.column.resetSize()}\n        onMouseDown={header.getResizeHandler()}\n        onTouchStart={header.getResizeHandler()}\n        data-resizing={header.column.getIsResizing() ? true : undefined}\n      />\n    );\n  })();\n\n  const content = header.isPlaceholder ? null : flexRender(header.column.columnDef.header, header.getContext());\n\n  const resultProps: TableHeadCellProps = {\n    resizer,\n\n    qa: context.qa,\n    isBordered: context.isBordered,\n    isShadowed: context.isShadowed,\n    size: context.size,\n    verticalAlign: context.verticalAlign,\n\n    colSpan: header.colSpan,\n    rowSpan: header.rowSpan,\n\n    style: {\n      width: `calc(var(--header-${header?.id}-size) * 1px)`,\n    },\n  };\n\n  areaProps(header.column, resultProps);\n\n  if (context.headCellProps) {\n    Object.assign(\n      resultProps,\n      context.headCellProps instanceof Function ? context.headCellProps(header) : context.headCellProps\n    );\n  }\n\n  return (\n    <TableHeadCell key={header.id} {...resultProps}>\n      {content}\n    </TableHeadCell>\n  );\n};\n\nexport const getDataGridTableHeadCell = (header: DataGridTableHeadCellProps['header']) => {\n  return <DataGridTableHeadCell key={header.id} header={header} />;\n};\n\nexport * from './types';\n"]} */",
62
+ toString: t
63
+ }), f = Q((g, I) => {
64
+ const {
65
+ children: X,
66
+ isDisabled: u,
67
+ isActive: c,
68
+ isBordered: a,
69
+ isLastFixed: R,
70
+ isShadowed: e,
71
+ writingMode: Y,
72
+ verticalAlign: n = "top",
73
+ textAlign: y = "left",
74
+ userSelect: o = "none",
75
+ startAdornment: F,
76
+ endAdornment: V,
77
+ resizer: h,
78
+ dropdown: C,
79
+ variant: J = i.Default,
80
+ size: H = l.Medium,
81
+ columnArea: s = d.Default,
82
+ ...k
83
+ } = g, x = O(I), [W, m] = D(!1), N = (b) => {
84
+ var G;
85
+ b.code === "Escape" && b.currentTarget.blur(), (b.code === "Enter" || b.code === "NumpadEnter") && b.currentTarget.click(), (G = g.onKeyDown) == null || G.call(g, b);
86
+ }, p = (b) => {
87
+ var G;
88
+ C && !W && m(!0), (G = g.onClick) == null || G.call(g, b);
89
+ }, v = C ? /* @__PURE__ */ Z(C, { targetRef: x, isOpen: W, setIsOpen: m }) : null, S = !!g.onClick || !!C || !!c, L = {
90
+ ...k,
91
+ onClick: p,
92
+ onKeyDown: N,
93
+ style: {
94
+ verticalAlign: n,
95
+ textAlign: y,
96
+ writingMode: Y,
97
+ userSelect: o,
98
+ ...g.style
99
+ },
100
+ "data-cell": !0,
101
+ "data-disabled": u ? !0 : void 0,
102
+ "data-active": c || W ? !0 : void 0,
103
+ "data-bordered": a ? !0 : void 0,
104
+ "data-shadowed": e ? !0 : void 0,
105
+ "data-has-active": S ? !0 : void 0,
106
+ "data-has-end-adornment": V ? !0 : void 0,
107
+ "data-last-fixed": R ? !0 : void 0,
108
+ [`data-${H.toLowerCase()}`]: !0,
109
+ [`data-${J.toLowerCase()}`]: !0,
110
+ [`data-${s.toLowerCase()}`]: !0
111
+ };
112
+ return /* @__PURE__ */ B(U, { ref: x, tabIndex: 0, ...L, children: [
113
+ /* @__PURE__ */ B(T, { children: [
114
+ F,
115
+ /* @__PURE__ */ Z(M, { children: X }),
116
+ V
117
+ ] }),
118
+ h,
119
+ v
120
+ ] });
121
+ }), P = ({
122
+ header: g
123
+ }) => {
124
+ const I = z(j), X = g.column.getCanResize() === !1 ? null : /* @__PURE__ */ Z(E, { onDoubleClick: () => g.column.resetSize(), onMouseDown: g.getResizeHandler(), onTouchStart: g.getResizeHandler(), "data-resizing": g.column.getIsResizing() ? !0 : void 0 }), u = g.isPlaceholder ? null : w(g.column.columnDef.header, g.getContext()), c = {
125
+ resizer: X,
126
+ qa: I.qa,
127
+ isBordered: I.isBordered,
128
+ isShadowed: I.isShadowed,
129
+ size: I.size,
130
+ verticalAlign: I.verticalAlign,
131
+ colSpan: g.colSpan,
132
+ rowSpan: g.rowSpan,
133
+ style: {
134
+ width: `calc(var(--header-${g == null ? void 0 : g.id}-size) * 1px)`
135
+ }
136
+ };
137
+ return r(g.column, c), I.headCellProps && Object.assign(c, I.headCellProps instanceof Function ? I.headCellProps(g) : I.headCellProps), /* @__PURE__ */ Z(f, { ...c, children: u }, g.id);
138
+ }, Zg = (g) => /* @__PURE__ */ Z(P, { header: g }, g.id);
139
+ export {
140
+ P as DataGridTableHeadCell,
141
+ f as TableHeadCell,
142
+ E as TableHeadCellResizer,
143
+ i as TableHeadCellVariant,
144
+ Zg as getDataGridTableHeadCell
145
+ };
146
+ //# sourceMappingURL=index.es.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.es.js","sources":["../../src/TableHeadCell/index.tsx"],"sourcesContent":["'use client';\n\nimport {useContext, useState} from 'react';\nimport styled from '@emotion/styled';\nimport {flexRender} from '@tanstack/react-table';\n\nimport {forwardRef, SizeTokenValue, useRefMerge} from '@join-x5/react-theme';\nimport {ColumnArea} from '@join-x5/react-data-grid-settings';\n\nimport {DataGridContext} from 'DataGridContext';\n\nimport {areaProps} from 'TableCell/hook';\n\nimport {TableHeadCellVariant} from './types';\n\nimport type {KeyboardEventHandler, MouseEventHandler} from 'react';\nimport type {Header} from '@tanstack/react-table';\nimport type {FRC} from '@join-x5/react-theme';\nimport type {TableHeadCellProps} from './types';\n\nexport const TableHeadCellResizer = styled.div`\n display: flex;\n position: absolute;\n align-items: center;\n justify-content: center;\n top: 0;\n right: -5px;\n width: 10px;\n height: 100%;\n cursor: col-resize;\n z-index: 1;\n\n ::before {\n content: '';\n display: block;\n width: 3px;\n height: 24px;\n border-radius: 8px;\n user-select: none;\n pointer-events: none;\n opacity: 0;\n\n background-color: ${props => props.theme.colors.accent[80]};\n }\n\n &[data-resizing]::before {\n opacity: 1;\n }\n`;\n\nconst Cell = styled.th`\n position: relative;\n box-sizing: border-box;\n\n ${props => ({\n color: props.theme.colors.grey[100],\n backgroundColor: props.theme.colors.white,\n\n '--border-color': props.theme.colors.grey[10],\n })};\n\n &[data-${SizeTokenValue.Large.toLocaleLowerCase()}] {\n padding: 12px;\n min-height: 44px;\n\n &[data-${TableHeadCellVariant.Checkbox.toLocaleLowerCase()}] {\n padding: 14px 12px;\n\n &[data-has-end-adornment] {\n padding-right: 8px;\n }\n }\n\n ${props => props.theme.typography.h4}\n }\n\n &[data-${SizeTokenValue.Medium.toLocaleLowerCase()}] {\n padding: 12px;\n min-height: 40px;\n\n &[data-${TableHeadCellVariant.Checkbox.toLocaleLowerCase()}] {\n padding: 12px;\n\n &[data-has-end-adornment] {\n padding-right: 8px;\n }\n }\n\n ${props => props.theme.typography.h5}\n }\n\n &[data-${SizeTokenValue.Small.toLocaleLowerCase()}] {\n padding: 8px;\n min-height: 32px;\n\n ${props => props.theme.typography.h5}\n }\n\n &[data-shadowed] {\n filter: drop-shadow(8px 0px 8px rgba(80, 86, 94, 0.08));\n\n &::before {\n border-bottom-width: 0;\n }\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 :hover {\n ${props => ({\n backgroundColor: props.theme.colors.grey[10],\n\n '--border-color': props.theme.colors.grey[20],\n })}\n }\n\n &[data-has-active] {\n cursor: pointer;\n\n &[data-active],\n :active {\n ${props => ({\n backgroundColor: props.theme.colors.grey[30],\n\n '--border-color': 'transparent',\n })}\n }\n }\n\n :focus {\n outline: none;\n }\n\n &[data-disabled] {\n :hover {\n ${props => ({\n backgroundColor: props.theme.colors.grey[10],\n\n '--border-color': props.theme.colors.grey[20],\n })}\n }\n\n ${props => ({\n color: props.theme.colors.grey[40],\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 2px 0;\n border-style: solid;\n border-color: var(--border-color);\n }\n\n ::after {\n content: '';\n display: block;\n position: absolute;\n box-sizing: border-box;\n top: calc(50% - 8px);\n right: 0;\n width: 2px;\n height: 16px;\n user-select: none;\n pointer-events: none;\n background-color: var(--border-color, transparent);\n }\n\n &[data-bordered] {\n ::before {\n border-width: 0 1px 2px 0;\n }\n\n :last-of-type::before {\n border-width: 0 0 2px 0;\n }\n\n ::after {\n display: none;\n }\n }\n\n :last-of-type::after {\n display: none;\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 flex-grow: 1;\n`;\n\nexport const TableHeadCell: FRC<HTMLTableCellElement, TableHeadCellProps> = forwardRef((props, baseRef) => {\n const {\n children,\n\n isDisabled,\n isActive,\n isBordered,\n isLastFixed,\n isShadowed,\n\n writingMode,\n verticalAlign = 'top',\n textAlign = 'left',\n userSelect = 'none',\n\n startAdornment,\n endAdornment,\n resizer,\n dropdown: Dropdown,\n\n variant = TableHeadCellVariant.Default,\n size = SizeTokenValue.Medium,\n columnArea = ColumnArea.Default,\n\n ...rest\n } = props;\n\n const ref = useRefMerge(baseRef);\n const [isDropdownOpen, setIsDropdownOpen] = useState<boolean>(false);\n\n const onKeyDown: KeyboardEventHandler<HTMLTableCellElement> = e => {\n if (e.code === 'Escape') {\n e.currentTarget.blur();\n }\n\n if (e.code === 'Enter' || e.code === 'NumpadEnter') {\n e.currentTarget.click();\n }\n\n props.onKeyDown?.(e);\n };\n\n const onClick: MouseEventHandler<HTMLTableCellElement> = e => {\n if (Dropdown && !isDropdownOpen) {\n setIsDropdownOpen(true);\n }\n\n props.onClick?.(e);\n };\n\n const dropdown = Dropdown ? <Dropdown targetRef={ref} isOpen={isDropdownOpen} setIsOpen={setIsDropdownOpen} /> : null;\n const hasActive = !!props.onClick || !!Dropdown || !!isActive;\n\n const cellProps = {\n ...rest,\n\n onClick,\n onKeyDown,\n\n style: {\n verticalAlign,\n textAlign,\n writingMode,\n userSelect,\n\n ...props.style,\n },\n\n 'data-cell': true,\n 'data-disabled': isDisabled ? true : undefined,\n 'data-active': isActive || isDropdownOpen ? true : undefined,\n 'data-bordered': isBordered ? true : undefined,\n 'data-shadowed': isShadowed ? true : undefined,\n 'data-has-active': hasActive ? true : undefined,\n 'data-has-end-adornment': endAdornment ? true : undefined,\n 'data-last-fixed': isLastFixed ? true : undefined,\n\n [`data-${size.toLowerCase()}`]: true,\n [`data-${variant.toLowerCase()}`]: true,\n [`data-${columnArea.toLowerCase()}`]: true,\n };\n\n return (\n <Cell ref={ref} tabIndex={0} {...cellProps}>\n <Container>\n {startAdornment}\n <Content>{children}</Content>\n {endAdornment}\n </Container>\n {resizer}\n {dropdown}\n </Cell>\n );\n});\n\ntype DataGridTableHeadCellProps = {\n header: Header<unknown, unknown>;\n};\n\nexport const DataGridTableHeadCell: React.FC<DataGridTableHeadCellProps> = ({header}) => {\n const context = useContext(DataGridContext);\n\n const resizer = (() => {\n if (header.column.getCanResize() === false) {\n return null;\n }\n\n return (\n <TableHeadCellResizer\n onDoubleClick={() => header.column.resetSize()}\n onMouseDown={header.getResizeHandler()}\n onTouchStart={header.getResizeHandler()}\n data-resizing={header.column.getIsResizing() ? true : undefined}\n />\n );\n })();\n\n const content = header.isPlaceholder ? null : flexRender(header.column.columnDef.header, header.getContext());\n\n const resultProps: TableHeadCellProps = {\n resizer,\n\n qa: context.qa,\n isBordered: context.isBordered,\n isShadowed: context.isShadowed,\n size: context.size,\n verticalAlign: context.verticalAlign,\n\n colSpan: header.colSpan,\n rowSpan: header.rowSpan,\n\n style: {\n width: `calc(var(--header-${header?.id}-size) * 1px)`,\n },\n };\n\n areaProps(header.column, resultProps);\n\n if (context.headCellProps) {\n Object.assign(\n resultProps,\n context.headCellProps instanceof Function ? context.headCellProps(header) : context.headCellProps\n );\n }\n\n return (\n <TableHeadCell key={header.id} {...resultProps}>\n {content}\n </TableHeadCell>\n );\n};\n\nexport const getDataGridTableHeadCell = (header: DataGridTableHeadCellProps['header']) => {\n return <DataGridTableHeadCell key={header.id} header={header} />;\n};\n\nexport * from './types';\n"],"names":["white","children","isDisabled","isActive","isBordered","isLastFixed","isShadowed","writingMode","startAdornment","endAdornment","resizer","Dropdown","Default","Medium","rest","e","onClick","onKeyDown","verticalAlign","textAlign","userSelect","style","undefined","dropdown","context","qa","size","colSpan","rowSpan","header"],"mappings":";;;;;;;;;;AAAa;AAAA;AAAA;AAoBN;AAA0B;AAAA;AAAA;AAAA;AAAA;AA8BvB;AAAA;AAAA;AAAA;AAAA;AAII;AACwB;AACEA;AAGtC;AAkEc;AACiC;AAG7C;AAQc;AACiC;AAG7C;AAiBU;AAEZ;AATc;AACiC;AAG7C;AAyDS;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAOF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAKL;AAAA;AACJC;AAEAC;AACAC;AACAC;AACAC;AACAC;AAEAC;AACgB;AACJ;AACC;AAEbC;AACAC;AACAC;AACUC;AAEqBC;AACTC;AACED;AAErBE;;AAOCC;AAQcA;;AAIdJ;AAIYI;AAMA;AACbD;AAEHE;AACAC;AAEO;AACLC;AACAC;AACAZ;AACAa;AAESC;AACX;AAEa;AACwBC;AACcA;AACdA;AACAA;AACCA;AACUA;AACRA;AAER;AACG;AACG;AAGxC;AAEI;AACGd;AAAAA;AACkB;AAClBC;AACH;AACCC;AACAa;AAGP;AAM4E;AAAO;AAC3EC;AAmBkC;AACtCd;AAEYe;AACQrB;AACAE;AACNoB;AACSR;AAEPS;AACAC;AAET;AACiC;AAAA;AAIhCC;AAcZ;;;;;;;;"}
@@ -0,0 +1,37 @@
1
+ import { SizeTokenValue, CSSProperties, QA } from '@join-x5/react-theme';
2
+ import { ColumnArea } from '@join-x5/react-data-grid-settings';
3
+ import { ReactNode, ThHTMLAttributes } from 'react';
4
+ import { DropdownProps } from '@join-x5/react';
5
+ export declare enum TableHeadCellVariant {
6
+ Default = "default",
7
+ Checkbox = "checkbox"
8
+ }
9
+ export type TableHeadCellProps = {
10
+ /** Размер */
11
+ size?: SizeTokenValue | `${SizeTokenValue}`;
12
+ /** Вариант */
13
+ variant?: TableHeadCellVariant | `${TableHeadCellVariant}`;
14
+ /** Установка состояния "Отключен" */
15
+ isDisabled?: boolean;
16
+ /** Установка состояния "Активен" */
17
+ isActive?: boolean;
18
+ /** С границей */
19
+ isBordered?: boolean;
20
+ /** Показывать тень вместо границы, в закрепленных столбцах и шапке */
21
+ isShadowed?: boolean;
22
+ /** Расположение колонки */
23
+ columnArea?: ColumnArea;
24
+ /** Последняя закрепленная колонка
25
+ *
26
+ * Добавляет тень в зависимости от `columnArea`
27
+ */
28
+ isLastFixed?: boolean;
29
+ /** Иконка | Контент слева */
30
+ startAdornment?: ReactNode;
31
+ /** Иконка | Контент справа */
32
+ endAdornment?: ReactNode;
33
+ /** Контрол смены размера */
34
+ resizer?: ReactNode;
35
+ /** Контент дропдауна */
36
+ dropdown?: React.FC<DropdownProps>;
37
+ } & QA & Pick<CSSProperties, 'verticalAlign' | 'textAlign' | 'writingMode' | 'userSelect'> & ThHTMLAttributes<HTMLTableCellElement>;
@@ -0,0 +1,5 @@
1
+ var e = /* @__PURE__ */ ((c) => (c.Default = "default", c.Checkbox = "checkbox", c))(e || {});
2
+ export {
3
+ e as TableHeadCellVariant
4
+ };
5
+ //# sourceMappingURL=types.es.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.es.js","sources":["../../src/TableHeadCell/types.ts"],"sourcesContent":["// eslint-disable-next-line @typescript-eslint/consistent-type-imports\nimport {SizeTokenValue} from '@join-x5/react-theme';\n// eslint-disable-next-line @typescript-eslint/consistent-type-imports\nimport {ColumnArea} from '@join-x5/react-data-grid-settings';\n\nimport type {ReactNode, ThHTMLAttributes} from 'react';\nimport type {CSSProperties, QA} from '@join-x5/react-theme';\nimport type {DropdownProps} from '@join-x5/react';\n\nexport enum TableHeadCellVariant {\n Default = 'default',\n Checkbox = 'checkbox',\n}\n\nexport type TableHeadCellProps = {\n /** Размер */\n size?: SizeTokenValue;\n\n /** Вариант */\n variant?: TableHeadCellVariant;\n\n /** Установка состояния \"Отключен\" */\n isDisabled?: boolean;\n /** Установка состояния \"Активен\" */\n isActive?: boolean;\n /** С границей */\n isBordered?: boolean;\n /** Показывать тень вместо границы, в закрепленных столбцах и шапке */\n isShadowed?: boolean;\n\n /** Расположение колонки */\n columnArea?: ColumnArea;\n /** Последняя закрепленная колонка\n *\n * Добавляет тень в зависимости от `columnArea`\n */\n isLastFixed?: boolean;\n\n /** Иконка | Контент слева */\n startAdornment?: ReactNode;\n /** Иконка | Контент справа */\n endAdornment?: ReactNode;\n\n /** Контрол смены размера */\n resizer?: ReactNode;\n\n /** Контент дропдауна */\n dropdown?: React.FC<DropdownProps>;\n} & QA &\n Pick<CSSProperties, 'verticalAlign' | 'textAlign' | 'writingMode' | 'userSelect'> &\n ThHTMLAttributes<HTMLTableCellElement>;\n"],"names":["TableHeadCellVariant","Default","Checkbox"],"mappings":"AASYA,IAAAA,sBAAAA,OACVC,EAAAA,UAAU,WACVC,EAAAA,WAAW,YAFDF,IAAAA,KAAAA,CAAAA,CAAAA;"}
@@ -0,0 +1,3 @@
1
+ import { FRC } from '@join-x5/react-theme';
2
+ import { TableHeadRowProps } from './types';
3
+ export declare const TableHeadRow: FRC<HTMLTableRowElement, TableHeadRowProps>;
@@ -0,0 +1,14 @@
1
+ "use client";
2
+ import { jsx as c } from "@emotion/react/jsx-runtime";
3
+ import l from "@emotion/styled/base";
4
+ import { forwardRef as t } from "@join-x5/react-theme";
5
+ const n = /* @__PURE__ */ l("tr", process.env.NODE_ENV === "production" ? {
6
+ target: "evhjk970"
7
+ } : {
8
+ target: "evhjk970",
9
+ label: "Container"
10
+ })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3NhZHlrb3ZzZC9qb2luLXg1L3BhY2thZ2VzL2RhdGEtZ3JpZC9zcmMvVGFibGVIZWFkUm93L2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFTMkIiLCJmaWxlIjoiL2hvbWUvc2FkeWtvdnNkL2pvaW4teDUvcGFja2FnZXMvZGF0YS1ncmlkL3NyYy9UYWJsZUhlYWRSb3cvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnO1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmltcG9ydCB7Zm9yd2FyZFJlZn0gZnJvbSAnQGpvaW4teDUvcmVhY3QtdGhlbWUnO1xuXG5pbXBvcnQgdHlwZSB7RlJDfSBmcm9tICdAam9pbi14NS9yZWFjdC10aGVtZSc7XG5pbXBvcnQgdHlwZSB7VGFibGVIZWFkUm93UHJvcHN9IGZyb20gJy4vdHlwZXMnO1xuXG5jb25zdCBDb250YWluZXIgPSBzdHlsZWQudHJgYDtcblxuZXhwb3J0IGNvbnN0IFRhYmxlSGVhZFJvdzogRlJDPEhUTUxUYWJsZVJvd0VsZW1lbnQsIFRhYmxlSGVhZFJvd1Byb3BzPiA9IGZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcbiAgcmV0dXJuIDxDb250YWluZXIgcmVmPXtyZWZ9IHsuLi5wcm9wc30gLz47XG59KTtcbiJdfQ== */"), e = t((Z, b) => /* @__PURE__ */ c(n, { ref: b, ...Z }));
11
+ export {
12
+ e as TableHeadRow
13
+ };
14
+ //# sourceMappingURL=index.es.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.es.js","sources":["../../src/TableHeadRow/index.tsx"],"sourcesContent":["'use client';\n\nimport styled from '@emotion/styled';\n\nimport {forwardRef} from '@join-x5/react-theme';\n\nimport type {FRC} from '@join-x5/react-theme';\nimport type {TableHeadRowProps} from './types';\n\nconst Container = styled.tr``;\n\nexport const TableHeadRow: FRC<HTMLTableRowElement, TableHeadRowProps> = forwardRef((props, ref) => {\n return <Container ref={ref} {...props} />;\n});\n"],"names":[],"mappings":";;;;AASA;AAAe;AAAA;AAAA;AAAA;AAAA;;;;"}
@@ -0,0 +1,2 @@
1
+ import { HTMLAttributes } from 'react';
2
+ export type TableHeadRowProps = HTMLAttributes<HTMLTableRowElement>;
@@ -0,0 +1,8 @@
1
+ import { FRC, PropsWithChildren } from '@join-x5/react-theme';
2
+ import { DataGridTableCellProps, TableCellProps } from '../TableCell';
3
+ type DefaultAny = any;
4
+ type TButtonCell = FRC<HTMLTableCellElement, TableCellProps>;
5
+ export declare const ButtonCell: TButtonCell;
6
+ export type DataGridButtonCellProps<T = DefaultAny, V = DefaultAny> = DataGridTableCellProps<T, V> & PropsWithChildren;
7
+ export declare const DataGridButtonCell: FRC<HTMLTableCellElement, DataGridButtonCellProps>;
8
+ export {};
@@ -0,0 +1,30 @@
1
+ "use client";
2
+ import { jsx as n } from "@emotion/react/jsx-runtime";
3
+ import { SizeTokenValue as e, forwardRef as a } from "@join-x5/react-theme";
4
+ import { TableCell as m } from "../TableCell/index.es.js";
5
+ import { useDataGridInputCell as s } from "./hook.es.js";
6
+ const d = {
7
+ [e.XXSmall]: 4,
8
+ [e.XSmall]: 4,
9
+ [e.Small]: 4,
10
+ [e.Medium]: 8,
11
+ [e.Large]: 6,
12
+ [e.XLarge]: 6
13
+ }, c = a((l, r) => {
14
+ const {
15
+ padding: t = d[l.size ?? e.Medium],
16
+ ...o
17
+ } = l;
18
+ return /* @__PURE__ */ n(m, { ref: r, padding: t, ...o });
19
+ }), C = a((l, r) => {
20
+ const {
21
+ cell: t,
22
+ children: o
23
+ } = l, i = s(t);
24
+ return /* @__PURE__ */ n(c, { ref: r, ...i, children: o });
25
+ });
26
+ export {
27
+ c as ButtonCell,
28
+ C as DataGridButtonCell
29
+ };
30
+ //# sourceMappingURL=button.es.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"button.es.js","sources":["../../src/TableInputCell/button.tsx"],"sourcesContent":["'use client';\n\nimport {forwardRef, SizeTokenValue} from '@join-x5/react-theme';\n\nimport {TableCell} from '../TableCell';\n\nimport {useDataGridInputCell} from './hook';\n\nimport type {FRC, PropsWithChildren, CSSProperties} from '@join-x5/react-theme';\nimport type {DataGridTableCellProps, TableCellProps} from '../TableCell';\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\ntype DefaultAny = any;\n\ntype TButtonCell = FRC<HTMLTableCellElement, TableCellProps>;\n\nconst sizePadding: Record<SizeTokenValue, CSSProperties['padding']> = {\n [SizeTokenValue.XXSmall]: 4,\n [SizeTokenValue.XSmall]: 4,\n [SizeTokenValue.Small]: 4,\n [SizeTokenValue.Medium]: 8,\n [SizeTokenValue.Large]: 6,\n [SizeTokenValue.XLarge]: 6,\n};\n\nexport const ButtonCell: TButtonCell = forwardRef((props, ref) => {\n const {padding = sizePadding[props.size ?? SizeTokenValue.Medium], ...rest} = props;\n\n return <TableCell ref={ref} padding={padding} {...rest} />;\n});\n\nexport type DataGridButtonCellProps<T = DefaultAny, V = DefaultAny> = DataGridTableCellProps<T, V> & PropsWithChildren;\n\nexport const DataGridButtonCell: FRC<HTMLTableCellElement, DataGridButtonCellProps> = forwardRef((props, ref) => {\n const {cell, children} = props;\n\n const cellProps = useDataGridInputCell(cell);\n\n return (\n <ButtonCell ref={ref} {...cellProps}>\n {children}\n </ButtonCell>\n );\n});\n"],"names":["rest","cell","children"],"mappings":";;;;;AAgBA;AAAsE;AAC1C;AACD;AACD;AACC;AACD;AAE1B;AAGQ;AAAA;AAA0D;AAAMA;AAEtE;AACF;AAKQ;AAAA;AAACC;AAAMC;AAIb;AAKF;;;;;"}
@@ -0,0 +1,11 @@
1
+ import { FRC } from '@join-x5/react-theme';
2
+ import { CheckboxProps } from '@join-x5/react';
3
+ import { DataGridTableCellProps, TableCellProps } from '../TableCell';
4
+ type DefaultAny = any;
5
+ type TCheckboxCell = FRC<HTMLTableCellElement, {
6
+ inputProps: CheckboxProps;
7
+ } & Omit<TableCellProps, 'value' | 'onChange'>>;
8
+ export declare const CheckboxCell: TCheckboxCell;
9
+ export type DataGridCheckboxCellProps<T = DefaultAny, V = DefaultAny> = CheckboxProps & DataGridTableCellProps<T, V>;
10
+ export declare const DataGridCheckboxCell: FRC<HTMLTableCellElement, DataGridCheckboxCellProps>;
11
+ export {};
@@ -0,0 +1,32 @@
1
+ "use client";
2
+ import { jsx as a } from "@emotion/react/jsx-runtime";
3
+ import { SizeTokenValue as e, forwardRef as n } from "@join-x5/react-theme";
4
+ import { Checkbox as s } from "@join-x5/react";
5
+ import { TableCell as d } from "../TableCell/index.es.js";
6
+ import { useDataGridInputCell as m } from "./hook.es.js";
7
+ const c = {
8
+ [e.XXSmall]: 8,
9
+ [e.XSmall]: 8,
10
+ [e.Small]: 8,
11
+ [e.Medium]: 12,
12
+ [e.Large]: 14,
13
+ [e.XLarge]: 14
14
+ }, p = n((r, t) => {
15
+ const {
16
+ inputProps: o,
17
+ padding: l = c[r.size ?? e.Medium],
18
+ ...i
19
+ } = r;
20
+ return /* @__PURE__ */ a(d, { ref: t, padding: l, ...i, children: /* @__PURE__ */ a(s, { "data-action": !0, tabIndex: -1, disabled: r.isDisabled, ...o }) });
21
+ }), g = n((r, t) => {
22
+ const {
23
+ cell: o,
24
+ ...l
25
+ } = r, i = m(o);
26
+ return /* @__PURE__ */ a(p, { ref: t, ...i, inputProps: l });
27
+ });
28
+ export {
29
+ p as CheckboxCell,
30
+ g as DataGridCheckboxCell
31
+ };
32
+ //# sourceMappingURL=checkbox.es.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"checkbox.es.js","sources":["../../src/TableInputCell/checkbox.tsx"],"sourcesContent":["'use client';\n\nimport {forwardRef, SizeTokenValue} from '@join-x5/react-theme';\nimport {Checkbox} from '@join-x5/react';\n\nimport {TableCell} from '../TableCell';\n\nimport {useDataGridInputCell} from './hook';\n\nimport type {FRC} from '@join-x5/react-theme';\nimport type {CheckboxProps} from '@join-x5/react';\nimport type {DataGridTableCellProps, TableCellProps} from '../TableCell';\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\ntype DefaultAny = any;\n\ntype TCheckboxCell = FRC<\n HTMLTableCellElement,\n {\n inputProps: CheckboxProps;\n } & Omit<TableCellProps, 'value' | 'onChange'>\n>;\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]: 14,\n [SizeTokenValue.XLarge]: 14,\n};\n\nexport const CheckboxCell: TCheckboxCell = forwardRef((props, ref) => {\n const {inputProps, padding = sizePadding[props.size ?? SizeTokenValue.Medium], ...rest} = props;\n\n return (\n <TableCell ref={ref} padding={padding} {...rest}>\n <Checkbox data-action tabIndex={-1} disabled={props.isDisabled} {...inputProps} />\n </TableCell>\n );\n});\n\nexport type DataGridCheckboxCellProps<T = DefaultAny, V = DefaultAny> = CheckboxProps & DataGridTableCellProps<T, V>;\n\nexport const DataGridCheckboxCell: FRC<HTMLTableCellElement, DataGridCheckboxCellProps> = forwardRef((props, ref) => {\n const {cell, ...rest} = props;\n\n const cellProps = useDataGridInputCell(cell);\n\n const inputProps = rest as CheckboxProps;\n\n return <CheckboxCell ref={ref} {...cellProps} inputProps={inputProps} />;\n});\n"],"names":["inputProps","rest","cell"],"mappings":";;;;;;AAuBA;AAAoD;AACxB;AACD;AACD;AACC;AACD;AAE1B;AAGQ;AAAA;AAACA;AAAqE;AAAMC;AAElF;AAKF;AAKQ;AAAA;AAACC;AAASD;AAMhB;AACF;;;;;"}
@@ -0,0 +1,18 @@
1
+ import { Cell as ReactTableCell } from '@tanstack/react-table';
2
+ import { FRC } from '@join-x5/react-theme';
3
+ import { DataGridTableCellProps, TableCellProps } from '../TableCell';
4
+ import { ColumnDefTemplate } from './types';
5
+ import { CalendarValue, DatepickerProps } from '@join-x5/react';
6
+ type DefaultAny = any;
7
+ type TDateCell = FRC<HTMLTableCellElement, {
8
+ inputProps: DatepickerProps;
9
+ } & Omit<TableCellProps, 'value' | 'onChange'>>;
10
+ export declare const DateCell: TDateCell;
11
+ export type DataGridDateCellProps<T = DefaultAny, V = DefaultAny> = {
12
+ getValue: (cell: ReactTableCell<T, V>) => CalendarValue;
13
+ onChange: (cell: ReactTableCell<T, V>, newValue: CalendarValue) => void;
14
+ } & Omit<DatepickerProps, 'value' | 'onChange'> & DataGridTableCellProps<T, V>;
15
+ export declare const DataGridDateCell: FRC<HTMLTableCellElement, DataGridDateCellProps>;
16
+ export type GetDataGridDateCellArgs<T = DefaultAny, V = DefaultAny> = Omit<DataGridDateCellProps<T, V>, 'cell'>;
17
+ export declare const getDataGridDateCell: <T, V>(args: GetDataGridDateCellArgs<T, V>) => ColumnDefTemplate<T, V>;
18
+ export {};
@@ -0,0 +1,40 @@
1
+ "use client";
2
+ import { jsx as a } from "@emotion/react/jsx-runtime";
3
+ import { forwardRef as C } from "@join-x5/react-theme";
4
+ import { Datepicker as f } from "@join-x5/react";
5
+ import { TableCell as v } from "../TableCell/index.es.js";
6
+ import { useDataGridInputCell as b } from "./hook.es.js";
7
+ const o = C(({
8
+ inputProps: c,
9
+ ...e
10
+ }, l) => {
11
+ const d = (i) => {
12
+ var t;
13
+ (t = e.setIsActive) == null || t.call(e, i);
14
+ };
15
+ return /* @__PURE__ */ a(v, { ref: l, padding: 0, ...e, onKeyDown: (i) => {
16
+ var n, m;
17
+ (n = e.onKeyDown) == null || n.call(e, i);
18
+ const t = i.code === "Enter" || i.code === "NumpadEnter";
19
+ !e.isDisabled && !e.isActive && t && ((m = e.setIsActive) == null || m.call(e, !0));
20
+ }, onClick: (i) => {
21
+ var t, n;
22
+ (t = e.onClick) == null || t.call(e, i), !e.isDisabled && !e.isActive && ((n = e.setIsActive) == null || n.call(e, !0));
23
+ }, children: /* @__PURE__ */ a(f, { isTable: !0, size: e.size, disabled: e.isDisabled, isOpen: e.isActive, setIsOpen: d, ...c }) });
24
+ }), s = C((c, e) => {
25
+ const {
26
+ cell: l,
27
+ getValue: d,
28
+ onChange: D,
29
+ ...u
30
+ } = c, i = b(l), t = u;
31
+ return t.value = d(l), t.onChange = (n) => D(l, n), /* @__PURE__ */ a(o, { ref: e, ...i, inputProps: t });
32
+ }), h = (c) => ({
33
+ cell: e
34
+ }) => /* @__PURE__ */ a(s, { cell: e, ...c }, e.id);
35
+ export {
36
+ s as DataGridDateCell,
37
+ o as DateCell,
38
+ h as getDataGridDateCell
39
+ };
40
+ //# sourceMappingURL=date.es.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"date.es.js","sources":["../../src/TableInputCell/date.tsx"],"sourcesContent":["'use client';\n\nimport {forwardRef} from '@join-x5/react-theme';\nimport {Datepicker} from '@join-x5/react';\n\nimport {TableCell} from '../TableCell';\n\nimport {useDataGridInputCell} from './hook';\n\nimport type {KeyboardEventHandler, MouseEventHandler} from 'react';\nimport type {Cell as ReactTableCell} from '@tanstack/react-table';\nimport type {FRC} from '@join-x5/react-theme';\nimport type {DataGridTableCellProps, TableCellProps} from '../TableCell';\nimport type {ColumnDefTemplate} from './types';\nimport type {CalendarValue, DatepickerProps} from '@join-x5/react';\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\ntype DefaultAny = any;\n\ntype TDateCell = FRC<\n HTMLTableCellElement,\n {\n inputProps: DatepickerProps;\n } & Omit<TableCellProps, 'value' | 'onChange'>\n>;\n\nexport const DateCell: TDateCell = forwardRef(({inputProps, ...props}, ref) => {\n const setIsOpen: DatepickerProps['setIsOpen'] = newIsOpen => {\n props.setIsActive?.(newIsOpen);\n };\n\n const onClick: MouseEventHandler<HTMLTableCellElement> = e => {\n props.onClick?.(e);\n\n if (!props.isDisabled && !props.isActive) {\n props.setIsActive?.(true);\n }\n };\n\n const onKeyDown: KeyboardEventHandler<HTMLTableCellElement> = e => {\n props.onKeyDown?.(e);\n\n const isEnterCode = e.code === 'Enter' || e.code === 'NumpadEnter';\n\n if (!props.isDisabled && !props.isActive && isEnterCode) {\n props.setIsActive?.(true);\n }\n };\n\n return (\n <TableCell ref={ref} padding={0} {...props} onKeyDown={onKeyDown} onClick={onClick}>\n <Datepicker\n isTable\n size={props.size}\n disabled={props.isDisabled}\n isOpen={props.isActive}\n setIsOpen={setIsOpen}\n {...inputProps}\n />\n </TableCell>\n );\n});\n\nexport type DataGridDateCellProps<T = DefaultAny, V = DefaultAny> = {\n getValue: (cell: ReactTableCell<T, V>) => CalendarValue;\n onChange: (cell: ReactTableCell<T, V>, newValue: CalendarValue) => void;\n} & Omit<DatepickerProps, 'value' | 'onChange'> &\n DataGridTableCellProps<T, V>;\n\nexport const DataGridDateCell: FRC<HTMLTableCellElement, DataGridDateCellProps> = forwardRef((props, ref) => {\n const {cell, getValue, onChange, ...rest} = props;\n\n const cellProps = useDataGridInputCell(cell);\n\n const inputProps = rest as DatepickerProps;\n inputProps.value = getValue(cell);\n inputProps.onChange = newValue => onChange(cell, newValue);\n\n return <DateCell ref={ref} {...cellProps} inputProps={inputProps} />;\n});\n\nexport type GetDataGridDateCellArgs<T = DefaultAny, V = DefaultAny> = Omit<DataGridDateCellProps<T, V>, 'cell'>;\n\nexport const getDataGridDateCell = <T, V>(args: GetDataGridDateCellArgs<T, V>): ColumnDefTemplate<T, V> => {\n return ({cell}) => <DataGridDateCell key={cell.id} cell={cell} {...args} />;\n};\n"],"names":["DateCell","inputProps","props","newIsOpen","cell","getValue","onChange","rest","value"],"mappings":";;;;;;AA0BaA;AAAkC;AAACC;AAAoB;AAClE;;AACEC;AAAoBC;AAsBpB;;AAVAD;AAEA;AAEA;AACsB;;AAbtBA;AAGsB;AA0B1B;AASQ;AAAA;AAACE;AAAMC;AAAUC;AAAaC;AAKzBC;AAIb;AAKU;AAACJ;;;;;;"}
@@ -0,0 +1,19 @@
1
+ import { ChangeEvent } from 'react';
2
+ import { Cell as ReactTableCell } from '@tanstack/react-table';
3
+ import { FRC } from '@join-x5/react-theme';
4
+ import { SelectOption, SelectProps } from '@join-x5/react';
5
+ import { DataGridTableCellProps, TableCellProps } from '../TableCell';
6
+ import { ColumnDefTemplate } from './types';
7
+ type DefaultAny = any;
8
+ type TDropdownCell = FRC<HTMLTableCellElement, {
9
+ inputProps: SelectProps;
10
+ } & Omit<TableCellProps, 'value' | 'onChange'>>;
11
+ export declare const DropdownCell: TDropdownCell;
12
+ export type DataGridDropdownCellProps<T = DefaultAny, V = DefaultAny, O = unknown> = {
13
+ getValue: (cell: ReactTableCell<T, V>) => SelectProps['value'];
14
+ onChange: (cell: ReactTableCell<T, V>, newValue: SelectProps['value'], option?: SelectOption<O>, event?: ChangeEvent<HTMLInputElement>) => void;
15
+ } & Omit<SelectProps, 'value' | 'onChange'> & DataGridTableCellProps<T, V>;
16
+ export declare const DataGridDropdownCell: FRC<HTMLTableCellElement, DataGridDropdownCellProps>;
17
+ export type GetDataGridDropdownCellArgs<T = DefaultAny, V = DefaultAny> = Omit<DataGridDropdownCellProps<T, V>, 'cell'>;
18
+ export declare const getDataGridDropdownCell: <T, V>(args: GetDataGridDropdownCellArgs<T, V>) => ColumnDefTemplate<T, V>;
19
+ export {};
@@ -0,0 +1,40 @@
1
+ "use client";
2
+ import { jsx as d } from "@emotion/react/jsx-runtime";
3
+ import { forwardRef as m } from "@join-x5/react-theme";
4
+ import { Select as C } from "@join-x5/react";
5
+ import { TableCell as f } from "../TableCell/index.es.js";
6
+ import { useDataGridInputCell as v } from "./hook.es.js";
7
+ const w = m(({
8
+ inputProps: l,
9
+ ...e
10
+ }, c) => {
11
+ const a = (i) => {
12
+ var t;
13
+ (t = e.setIsActive) == null || t.call(e, i);
14
+ };
15
+ return /* @__PURE__ */ d(f, { ref: c, padding: 0, ...e, onKeyDown: (i) => {
16
+ var n, D;
17
+ (n = e.onKeyDown) == null || n.call(e, i);
18
+ const t = i.code === "Enter" || i.code === "NumpadEnter";
19
+ !e.isDisabled && !e.isActive && t && ((D = e.setIsActive) == null || D.call(e, !0));
20
+ }, onClick: (i) => {
21
+ var t, n;
22
+ (t = e.onClick) == null || t.call(e, i), !e.isDisabled && !e.isActive && ((n = e.setIsActive) == null || n.call(e, !0));
23
+ }, children: /* @__PURE__ */ d(C, { isTable: !0, size: e.size, disabled: e.isDisabled, isOpen: e.isActive, setIsOpen: a, ...l }) });
24
+ }), b = m((l, e) => {
25
+ const {
26
+ cell: c,
27
+ getValue: a,
28
+ onChange: o,
29
+ ...u
30
+ } = l, i = v(c), t = u;
31
+ return t.value = a(c), t.onChange = (...n) => o(c, ...n), /* @__PURE__ */ d(w, { ref: e, ...i, inputProps: t });
32
+ }), k = (l) => ({
33
+ cell: e
34
+ }) => /* @__PURE__ */ d(b, { cell: e, ...l }, e.id);
35
+ export {
36
+ b as DataGridDropdownCell,
37
+ w as DropdownCell,
38
+ k as getDataGridDropdownCell
39
+ };
40
+ //# sourceMappingURL=dropdown.es.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dropdown.es.js","sources":["../../src/TableInputCell/dropdown.tsx"],"sourcesContent":["'use client';\n\nimport {forwardRef} from '@join-x5/react-theme';\nimport {Select} from '@join-x5/react';\n\nimport {TableCell} from '../TableCell';\n\nimport {useDataGridInputCell} from './hook';\n\nimport type {ChangeEvent, KeyboardEventHandler, MouseEventHandler} from 'react';\nimport type {Cell as ReactTableCell} from '@tanstack/react-table';\nimport type {FRC} from '@join-x5/react-theme';\nimport type {DatepickerProps, SelectOption, SelectProps} from '@join-x5/react';\nimport type {DataGridTableCellProps, TableCellProps} from '../TableCell';\nimport type {ColumnDefTemplate} from './types';\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\ntype DefaultAny = any;\n\ntype TDropdownCell = FRC<\n HTMLTableCellElement,\n {\n inputProps: SelectProps;\n } & Omit<TableCellProps, 'value' | 'onChange'>\n>;\n\nexport const DropdownCell: TDropdownCell = forwardRef(({inputProps, ...props}, ref) => {\n const setIsOpen: DatepickerProps['setIsOpen'] = newIsOpen => {\n props.setIsActive?.(newIsOpen);\n };\n\n const onClick: MouseEventHandler<HTMLTableCellElement> = e => {\n props.onClick?.(e);\n\n if (!props.isDisabled && !props.isActive) {\n props.setIsActive?.(true);\n }\n };\n\n const onKeyDown: KeyboardEventHandler<HTMLTableCellElement> = e => {\n props.onKeyDown?.(e);\n\n const isEnterCode = e.code === 'Enter' || e.code === 'NumpadEnter';\n\n if (!props.isDisabled && !props.isActive && isEnterCode) {\n props.setIsActive?.(true);\n }\n };\n\n return (\n <TableCell ref={ref} padding={0} {...props} onKeyDown={onKeyDown} onClick={onClick}>\n <Select\n isTable\n size={props.size}\n disabled={props.isDisabled}\n isOpen={props.isActive}\n setIsOpen={setIsOpen}\n {...inputProps}\n />\n </TableCell>\n );\n});\n\nexport type DataGridDropdownCellProps<T = DefaultAny, V = DefaultAny, O = unknown> = {\n getValue: (cell: ReactTableCell<T, V>) => SelectProps['value'];\n onChange: (\n cell: ReactTableCell<T, V>,\n newValue: SelectProps['value'],\n option?: SelectOption<O>,\n event?: ChangeEvent<HTMLInputElement>\n ) => void;\n} & Omit<SelectProps, 'value' | 'onChange'> &\n DataGridTableCellProps<T, V>;\n\nexport const DataGridDropdownCell: FRC<HTMLTableCellElement, DataGridDropdownCellProps> = forwardRef((props, ref) => {\n const {cell, getValue, onChange, ...rest} = props;\n\n const cellProps = useDataGridInputCell(cell);\n\n const inputProps = rest as SelectProps;\n inputProps.value = getValue(cell);\n inputProps.onChange = (...args) => onChange(cell, ...args);\n\n return <DropdownCell ref={ref} {...cellProps} inputProps={inputProps} />;\n});\n\nexport type GetDataGridDropdownCellArgs<T = DefaultAny, V = DefaultAny> = Omit<DataGridDropdownCellProps<T, V>, 'cell'>;\n\nexport const getDataGridDropdownCell = <T, V>(args: GetDataGridDropdownCellArgs<T, V>): ColumnDefTemplate<T, V> => {\n return ({cell}) => <DataGridDropdownCell key={cell.id} cell={cell} {...args} />;\n};\n"],"names":["DropdownCell","inputProps","props","newIsOpen","cell","getValue","onChange","rest","value"],"mappings":";;;;;;AA0BaA;AAA0C;AAACC;AAAoB;AAC1E;;AACEC;AAAoBC;AAsBpB;;AAVAD;AAEA;AAEA;AACsB;;AAbtBA;AAGsB;AA0B1B;AAcQ;AAAA;AAACE;AAAMC;AAAUC;AAAaC;AAKzBC;AAIb;AAKU;AAACJ;;;;;;"}
@@ -0,0 +1,11 @@
1
+ import { FRC, PropsWithChildren } from '@join-x5/react-theme';
2
+ import { DataGridTableCellProps, TableCellProps } from '../TableCell';
3
+ type DefaultAny = any;
4
+ type TExpandingCell = FRC<HTMLTableCellElement, {
5
+ depth: number;
6
+ isParent?: boolean;
7
+ } & TableCellProps>;
8
+ export declare const ExpandingCell: TExpandingCell;
9
+ export type DataGridExpandingCellProps<T = DefaultAny, V = DefaultAny> = DataGridTableCellProps<T, V> & PropsWithChildren;
10
+ export declare const DataGridExpandingCell: FRC<HTMLTableCellElement, DataGridExpandingCellProps>;
11
+ export {};