@join-x5/react-data-grid 1.1.1-nightly → 1.1.3-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.
- package/dist/DataGrid.d.ts +3 -0
- package/dist/DataGrid.es.js +67 -0
- package/dist/DataGrid.es.js.map +1 -0
- package/dist/DataGridContext.d.ts +10 -0
- package/dist/DataGridContext.es.js +23 -0
- package/dist/DataGridContext.es.js.map +1 -0
- package/dist/Table/index.d.ts +25 -0
- package/dist/Table/index.es.js +93 -0
- package/dist/Table/index.es.js.map +1 -0
- package/dist/Table/types.d.ts +3 -0
- package/dist/TableBody/index.d.ts +11 -0
- package/dist/TableBody/index.es.js +26 -0
- package/dist/TableBody/index.es.js.map +1 -0
- package/dist/TableCell/hook.d.ts +4 -0
- package/dist/TableCell/hook.es.js +42 -0
- package/dist/TableCell/hook.es.js.map +1 -0
- package/dist/TableCell/index.d.ts +9 -0
- package/dist/TableCell/index.es.js +234 -0
- package/dist/TableCell/index.es.js.map +1 -0
- package/dist/TableCell/types.d.ts +46 -0
- package/dist/TableDropdown/index.d.ts +8 -0
- package/dist/TableDropdown/index.es.js +26 -0
- package/dist/TableDropdown/index.es.js.map +1 -0
- package/dist/TableHead/index.d.ts +6 -0
- package/dist/TableHead/index.es.js +31 -0
- package/dist/TableHead/index.es.js.map +1 -0
- package/dist/TableHeadCell/index.d.ts +14 -0
- package/dist/TableHeadCell/index.es.js +146 -0
- package/dist/TableHeadCell/index.es.js.map +1 -0
- package/dist/TableHeadCell/types.d.ts +37 -0
- package/dist/TableHeadCell/types.es.js +5 -0
- package/dist/TableHeadCell/types.es.js.map +1 -0
- package/dist/TableHeadRow/index.d.ts +3 -0
- package/dist/TableHeadRow/index.es.js +14 -0
- package/dist/TableHeadRow/index.es.js.map +1 -0
- package/dist/TableHeadRow/types.d.ts +2 -0
- package/dist/TableInputCell/button.d.ts +8 -0
- package/dist/TableInputCell/button.es.js +30 -0
- package/dist/TableInputCell/button.es.js.map +1 -0
- package/dist/TableInputCell/checkbox.d.ts +11 -0
- package/dist/TableInputCell/checkbox.es.js +32 -0
- package/dist/TableInputCell/checkbox.es.js.map +1 -0
- package/dist/TableInputCell/date.d.ts +18 -0
- package/dist/TableInputCell/date.es.js +40 -0
- package/dist/TableInputCell/date.es.js.map +1 -0
- package/dist/TableInputCell/dropdown.d.ts +19 -0
- package/dist/TableInputCell/dropdown.es.js +40 -0
- package/dist/TableInputCell/dropdown.es.js.map +1 -0
- package/dist/TableInputCell/expanding.d.ts +11 -0
- package/dist/TableInputCell/expanding.es.js +58 -0
- package/dist/TableInputCell/expanding.es.js.map +1 -0
- package/dist/TableInputCell/hook.d.ts +611 -0
- package/dist/TableInputCell/hook.es.js +52 -0
- package/dist/TableInputCell/hook.es.js.map +1 -0
- package/dist/TableInputCell/icon.d.ts +8 -0
- package/dist/TableInputCell/icon.es.js +30 -0
- package/dist/TableInputCell/icon.es.js.map +1 -0
- package/dist/TableInputCell/index.d.ts +10 -0
- package/dist/TableInputCell/label.d.ts +8 -0
- package/dist/TableInputCell/label.es.js +30 -0
- package/dist/TableInputCell/label.es.js.map +1 -0
- package/dist/TableInputCell/switch.d.ts +11 -0
- package/dist/TableInputCell/switch.es.js +32 -0
- package/dist/TableInputCell/switch.es.js.map +1 -0
- package/dist/TableInputCell/text.d.ts +22 -0
- package/dist/TableInputCell/text.es.js +91 -0
- package/dist/TableInputCell/text.es.js.map +1 -0
- package/dist/TableInputCell/textarea.d.ts +23 -0
- package/dist/TableInputCell/textarea.es.js +83 -0
- package/dist/TableInputCell/textarea.es.js.map +1 -0
- package/dist/TableInputCell/types.d.ts +4 -0
- package/dist/TableRow/index.d.ts +5 -0
- package/dist/TableRow/index.es.js +25 -0
- package/dist/TableRow/index.es.js.map +1 -0
- package/dist/TableRow/types.d.ts +2 -0
- package/dist/hook.d.ts +3 -0
- package/dist/hook.es.js +23 -0
- package/dist/hook.es.js.map +1 -0
- package/dist/index.cjs +2 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.ts +11 -0
- package/dist/index.es.js +72 -0
- package/dist/index.es.js.map +1 -0
- package/dist/types.d.ts +54 -0
- package/package.json +1 -1
- package/dist/tsconfig.tsbuildinfo +0 -1
|
@@ -0,0 +1,234 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as Z, jsxs as e } from "@emotion/react/jsx-runtime";
|
|
3
|
+
import W from "@emotion/styled/base";
|
|
4
|
+
import j from "react";
|
|
5
|
+
import { flexRender as r } from "@tanstack/react-table";
|
|
6
|
+
import { SizeTokenValue as A, forwardRef as y, useRefMerge as T } from "@join-x5/react-theme";
|
|
7
|
+
import { EditOnIcon as E } from "@join-x5/react-icons";
|
|
8
|
+
import { ColumnArea as t } from "@join-x5/react-data-grid-settings";
|
|
9
|
+
import { useDataGridTableCell as M } from "./hook.es.js";
|
|
10
|
+
function h() {
|
|
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
|
+
}
|
|
13
|
+
const f = {
|
|
14
|
+
[A.XXSmall]: 8,
|
|
15
|
+
[A.XSmall]: 8,
|
|
16
|
+
[A.Small]: 8,
|
|
17
|
+
[A.Medium]: 12,
|
|
18
|
+
[A.Large]: 12,
|
|
19
|
+
[A.XLarge]: 12
|
|
20
|
+
}, P = /* @__PURE__ */ W("td", process.env.NODE_ENV === "production" ? {
|
|
21
|
+
target: "e1enoxlq3"
|
|
22
|
+
} : {
|
|
23
|
+
target: "e1enoxlq3",
|
|
24
|
+
label: "Cell"
|
|
25
|
+
})("position:relative;box-sizing:border-box;height:1px;background-color:var(--background-color, transparent);", (g) => ({
|
|
26
|
+
color: g.theme.colors.grey[100],
|
|
27
|
+
"--background-color": g.theme.colors.white,
|
|
28
|
+
"--border-color": g.theme.colors.grey[10]
|
|
29
|
+
}), ";&[data-", A.Large.toLocaleLowerCase(), "]{min-height:44px;", (g) => g.theme.typography.p1compact, ";}&[data-", A.Medium.toLocaleLowerCase(), "]{min-height:40px;", (g) => g.theme.typography.p2, ";}&[data-", A.Small.toLocaleLowerCase(), "]{min-height:32px;", (g) => g.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]{", (g) => ({
|
|
30
|
+
"--background-color": g.theme.colors.grey[10],
|
|
31
|
+
"--border-color": g.theme.colors.grey[20]
|
|
32
|
+
}), ";}:hover{", (g) => ({
|
|
33
|
+
"--background-color": g.theme.colors.grey[10],
|
|
34
|
+
"--border-color": g.theme.colors.grey[40]
|
|
35
|
+
}), ";}:not([data-disabled]):hover::before{border-width:1px;}&[data-disabled]{", (g) => ({
|
|
36
|
+
color: g.theme.colors.grey[40]
|
|
37
|
+
}), ";:hover{", (g) => ({
|
|
38
|
+
"--background-color": g.theme.colors.grey[10],
|
|
39
|
+
"--border-color": g.theme.colors.grey[20]
|
|
40
|
+
}), ";}}&[data-row-selected]{", (g) => ({
|
|
41
|
+
"--background-color": g.theme.colors.accent[10],
|
|
42
|
+
"--border-color": g.theme.colors.accent[20]
|
|
43
|
+
}), ";}&[data-focused],:focus{outline:none;", (g) => ({
|
|
44
|
+
"--border-color": "transparent",
|
|
45
|
+
"--background-color": g.theme.colors.white,
|
|
46
|
+
"--outline-color": g.theme.colors.accent[90]
|
|
47
|
+
}), ";::before{display:none;}::after{display:block;}[data-edit-icon]{visibility:visible;}}&[data-active]{outline:none;", (g) => ({
|
|
48
|
+
"--border-color": "transparent",
|
|
49
|
+
"--background-color": g.theme.colors.white,
|
|
50
|
+
"--outline-color": g.theme.colors.accent[90]
|
|
51
|
+
}), ";::before{display:none;}::after{display:block;}[data-edit-icon]{visibility:hidden;}}&[data-error]{", (g) => ({
|
|
52
|
+
caretColor: g.theme.colors.additional.red[80],
|
|
53
|
+
"--background-color": g.theme.colors.white,
|
|
54
|
+
"--border-color": "transparent",
|
|
55
|
+
"--outline-color": g.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 ", (g) => g.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  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 = 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" ? {
|
|
57
|
+
target: "e1enoxlq2"
|
|
58
|
+
} : {
|
|
59
|
+
target: "e1enoxlq2",
|
|
60
|
+
label: "Container"
|
|
61
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
62
|
+
name: "15dbgh0",
|
|
63
|
+
styles: "display:flex;position:relative;box-sizing:border-box;gap:8px"
|
|
64
|
+
} : {
|
|
65
|
+
name: "15dbgh0",
|
|
66
|
+
styles: "display:flex;position:relative;box-sizing:border-box;gap:8px/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/sadykovsd/join-x5/packages/data-grid/src/TableCell/index.tsx"],"names":[],"mappings":"AAwO4B","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  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 = 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: h
|
|
68
|
+
}), q = /* @__PURE__ */ W("div", process.env.NODE_ENV === "production" ? {
|
|
69
|
+
target: "e1enoxlq1"
|
|
70
|
+
} : {
|
|
71
|
+
target: "e1enoxlq1",
|
|
72
|
+
label: "Content"
|
|
73
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
74
|
+
name: "q5vyh6",
|
|
75
|
+
styles: "position:relative;flex-grow:1;word-break:break-word;:not([data-is-multiline]){overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}"
|
|
76
|
+
} : {
|
|
77
|
+
name: "q5vyh6",
|
|
78
|
+
styles: "position:relative;flex-grow:1;word-break:break-word;:not([data-is-multiline]){overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/sadykovsd/join-x5/packages/data-grid/src/TableCell/index.tsx"],"names":[],"mappings":"AA+O0B","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  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 = 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: h
|
|
80
|
+
}), _ = /* @__PURE__ */ W("div", process.env.NODE_ENV === "production" ? {
|
|
81
|
+
target: "e1enoxlq0"
|
|
82
|
+
} : {
|
|
83
|
+
target: "e1enoxlq0",
|
|
84
|
+
label: "Caption"
|
|
85
|
+
})("padding:4px 0 0;width:100%;word-break:break-all;", (g) => ({
|
|
86
|
+
...g.theme.typography.p3,
|
|
87
|
+
color: g.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":"AA2P0B","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  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 = 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"]} */")), $ = y((g, l) => {
|
|
89
|
+
const {
|
|
90
|
+
children: c,
|
|
91
|
+
style: d,
|
|
92
|
+
isMultiline: X,
|
|
93
|
+
whiteSpace: m,
|
|
94
|
+
wordBreak: x = "break-word",
|
|
95
|
+
...i
|
|
96
|
+
} = g, V = {
|
|
97
|
+
...i,
|
|
98
|
+
style: {
|
|
99
|
+
whiteSpace: m,
|
|
100
|
+
wordBreak: x,
|
|
101
|
+
...d
|
|
102
|
+
},
|
|
103
|
+
"data-content": !0,
|
|
104
|
+
"data-is-multiline": X ? !0 : void 0
|
|
105
|
+
};
|
|
106
|
+
return /* @__PURE__ */ Z(q, { ref: l, ...V, children: c });
|
|
107
|
+
}), gg = y((g, l) => {
|
|
108
|
+
const c = T(l), {
|
|
109
|
+
children: d,
|
|
110
|
+
isDisabled: X,
|
|
111
|
+
isRowHover: m,
|
|
112
|
+
isRowSelected: x,
|
|
113
|
+
isBordered: i,
|
|
114
|
+
isShadowed: V,
|
|
115
|
+
isFocused: o,
|
|
116
|
+
isActive: F,
|
|
117
|
+
isResizing: s,
|
|
118
|
+
isLastFixed: p,
|
|
119
|
+
error: B,
|
|
120
|
+
textAlign: v,
|
|
121
|
+
writingMode: N,
|
|
122
|
+
verticalAlign: L,
|
|
123
|
+
padding: z,
|
|
124
|
+
userSelect: S = "none",
|
|
125
|
+
startAdornment: D,
|
|
126
|
+
endAdornment: k,
|
|
127
|
+
size: R = A.Medium,
|
|
128
|
+
columnArea: w = t.Default,
|
|
129
|
+
...U
|
|
130
|
+
} = g, Q = {
|
|
131
|
+
...U,
|
|
132
|
+
onKeyDown: (G) => {
|
|
133
|
+
var J, Y, H, a;
|
|
134
|
+
(J = g.onKeyDown) == null || J.call(g, G);
|
|
135
|
+
const n = G.code === "Enter" || G.code === "NumpadEnter";
|
|
136
|
+
if (n) {
|
|
137
|
+
const I = (Y = c.current) == null ? void 0 : Y.querySelector("[data-action]");
|
|
138
|
+
n && I && I.click();
|
|
139
|
+
return;
|
|
140
|
+
}
|
|
141
|
+
if (G.code === "Escape") {
|
|
142
|
+
(H = c.current) == null || H.blur();
|
|
143
|
+
return;
|
|
144
|
+
}
|
|
145
|
+
if (G.code === "ArrowUp" || G.code === "ArrowDown" || G.code === "ArrowLeft" || G.code === "ArrowRight") {
|
|
146
|
+
const I = (a = c.current) == null ? void 0 : a.parentElement, u = Array.from(I == null ? void 0 : I.childNodes).indexOf(c.current);
|
|
147
|
+
switch (G.code) {
|
|
148
|
+
case "ArrowUp":
|
|
149
|
+
case "ArrowDown":
|
|
150
|
+
{
|
|
151
|
+
const b = G.code === "ArrowUp" ? I == null ? void 0 : I.previousElementSibling : I == null ? void 0 : I.nextElementSibling;
|
|
152
|
+
if ((I == null ? void 0 : I.nodeName) === (b == null ? void 0 : b.nodeName)) {
|
|
153
|
+
const C = b == null ? void 0 : b.children[u];
|
|
154
|
+
C == null || C.focus();
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
break;
|
|
158
|
+
case "ArrowLeft":
|
|
159
|
+
if (u > 0) {
|
|
160
|
+
const b = I == null ? void 0 : I.children[u - 1];
|
|
161
|
+
b == null || b.focus();
|
|
162
|
+
} else {
|
|
163
|
+
const b = I == null ? void 0 : I.previousElementSibling;
|
|
164
|
+
if ((I == null ? void 0 : I.nodeName) === (b == null ? void 0 : b.nodeName)) {
|
|
165
|
+
const C = b.lastElementChild;
|
|
166
|
+
C == null || C.focus();
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
break;
|
|
170
|
+
case "ArrowRight":
|
|
171
|
+
if (u < (I == null ? void 0 : I.children.length) - 1) {
|
|
172
|
+
const b = I == null ? void 0 : I.children[u + 1];
|
|
173
|
+
b == null || b.focus();
|
|
174
|
+
} else {
|
|
175
|
+
const b = I == null ? void 0 : I.nextElementSibling;
|
|
176
|
+
if ((I == null ? void 0 : I.nodeName) === (b == null ? void 0 : b.nodeName)) {
|
|
177
|
+
const C = b.firstElementChild;
|
|
178
|
+
C == null || C.focus();
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
break;
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
},
|
|
185
|
+
style: {
|
|
186
|
+
verticalAlign: L,
|
|
187
|
+
textAlign: v,
|
|
188
|
+
writingMode: N,
|
|
189
|
+
userSelect: S,
|
|
190
|
+
padding: z ?? f[R],
|
|
191
|
+
...g.style
|
|
192
|
+
},
|
|
193
|
+
"data-cell": !0,
|
|
194
|
+
"data-disabled": X ? !0 : void 0,
|
|
195
|
+
"data-focused": o ? !0 : void 0,
|
|
196
|
+
"data-error": B ? !0 : void 0,
|
|
197
|
+
"data-row-hover": m ? !0 : void 0,
|
|
198
|
+
"data-row-selected": x ? !0 : void 0,
|
|
199
|
+
"data-bordered": i ? !0 : void 0,
|
|
200
|
+
"data-shadowed": V ? !0 : void 0,
|
|
201
|
+
"data-resizing": s ? !0 : void 0,
|
|
202
|
+
"data-active": F ? !0 : void 0,
|
|
203
|
+
"data-last-fixed": p ? !0 : void 0,
|
|
204
|
+
[`data-${R.toLowerCase()}`]: !0,
|
|
205
|
+
[`data-${w.toLowerCase()}`]: !0
|
|
206
|
+
}, O = typeof B == "string" ? /* @__PURE__ */ Z(_, { children: B }) : null;
|
|
207
|
+
return /* @__PURE__ */ e(P, { ref: c, tabIndex: 0, ...Q, children: [
|
|
208
|
+
/* @__PURE__ */ e(K, { children: [
|
|
209
|
+
D,
|
|
210
|
+
d,
|
|
211
|
+
k,
|
|
212
|
+
/* @__PURE__ */ Z(E, { "data-edit-icon": !0, size: A.Small })
|
|
213
|
+
] }),
|
|
214
|
+
O
|
|
215
|
+
] });
|
|
216
|
+
}), Ig = y((g, l) => {
|
|
217
|
+
const c = M(g.cell), d = {
|
|
218
|
+
isMultiline: c.isMultiline,
|
|
219
|
+
whiteSpace: c.whiteSpace,
|
|
220
|
+
wordBreak: c.wordBreak
|
|
221
|
+
};
|
|
222
|
+
return /* @__PURE__ */ Z(gg, { ref: l, ...c, children: /* @__PURE__ */ Z($, { ...d, children: g.children }) });
|
|
223
|
+
}), Wg = (g) => {
|
|
224
|
+
var c;
|
|
225
|
+
const l = r(g.column.columnDef.cell, g.getContext());
|
|
226
|
+
return (c = g.column.columnDef.meta) != null && c.isCustom ? /* @__PURE__ */ Z(j.Fragment, { children: l }, g.id) : /* @__PURE__ */ Z(Ig, { cell: g, children: l }, g.id);
|
|
227
|
+
};
|
|
228
|
+
export {
|
|
229
|
+
Ig as DataGridTableCell,
|
|
230
|
+
gg as TableCell,
|
|
231
|
+
$ as TableCellContent,
|
|
232
|
+
Wg as getDataGridTableCell
|
|
233
|
+
};
|
|
234
|
+
//# sourceMappingURL=index.es.js.map
|
|
@@ -0,0 +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 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 = 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","ref","isDisabled","isRowHover","isRowSelected","isBordered","isShadowed","isFocused","isActive","isResizing","isLastFixed","error","textAlign","writingMode","verticalAlign","padding","startAdornment","endAdornment","Medium","Default","props","e","parent","nextFocus","focus","prevSibling","lastCell","nextSibling","firstCell","userSelect","caption","resultProps","content"],"mappings":";;;;;;;;;AAAa;AAAA;AAAA;AAgBb;AAAoD;AACxB;AACD;AACD;AACC;AACD;AAE1B;AAEU;AAAA;AAAA;AAAA;AAAA;AAMI;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;AAOM;AAAA;AAACC;AAAUC;AAAOC;AAAaC;AAAwB;AAAiBC;AAEzD;AAChBA;AAEI;AACLD;AACAE;AAEGJ;AACL;AAEgB;AAC0BK;AAG5C;AAKF;AAGQC;AAEA;AACJP;AAEAQ;AACAC;AACAC;AACAC;AACAC;AACAC;AACAC;AACAC;AACAC;AACAC;AAEAC;AACAC;AACAC;AACAC;AACa;AAEbC;AACAC;AAEsBC;AACEC;AAErBrB;AAuEa;AACbA;;AApEHsB;AAEA;AAEA;AACE;AAEA;AAIA;AAAA;AAGEC;AACFpB;AACA;AAAA;AAGEoB;AACIC;AAGN;AAAc;AACP;AAEH;AACE;AAIIA;AACIC;AAENA;AAAWC;AAAM;AAGrB;AAAA;AAGA;AACE;AACAC;AAAaD;AAEb;AACIF;AACF;AACAI;AAAUF;AAAM;AAGpB;AAAA;AAEA;AACE;AACAG;AAAaH;AAEb;AACIF;AACF;AACAM;AAAWJ;AAAM;AAGrB;AAAA;AAAA;AACJ;AAEJ;AAOS;AACLV;AACAF;AACAC;AACAgB;AAEoC;AAE3BlC;AACX;AAEa;AACwBK;AACFA;AACNA;AACSA;AACMA;AACPA;AACAA;AACAA;AACJA;AACOA;AAER;AACM;AAKxC;AAEI;AACGgB;AAAAA;AACAtB;AACAuB;AACqD;AACxD;AACCa;AAGP;AAIUC;AAEe;AACMnC;AACDC;AACDE;AAIvB;AAIJ;;AAIMiC;AAEN;AASF;;;;;;;"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { SizeTokenValue, CSSProperties, QA } from '@join-x5/react-theme';
|
|
2
|
+
import { ColumnArea } from '@join-x5/react-data-grid-settings';
|
|
3
|
+
import { Cell as ReactTableCell } from '@tanstack/react-table';
|
|
4
|
+
import { ReactNode, TdHTMLAttributes } from 'react';
|
|
5
|
+
type DefaultAny = any;
|
|
6
|
+
export type TableCellProps = {
|
|
7
|
+
/** Размер */
|
|
8
|
+
size?: SizeTokenValue | `${SizeTokenValue}`;
|
|
9
|
+
/** Установка состояния "Отключен" */
|
|
10
|
+
isDisabled?: boolean;
|
|
11
|
+
/** Установка состояния "В фокусе" */
|
|
12
|
+
isFocused?: boolean;
|
|
13
|
+
/** Установка состояния строки "Hover" */
|
|
14
|
+
isRowHover?: boolean;
|
|
15
|
+
/** Установка состояния строки "Выбрана" */
|
|
16
|
+
isRowSelected?: boolean;
|
|
17
|
+
/** Установка состояния "Изменение размера" */
|
|
18
|
+
isResizing?: boolean;
|
|
19
|
+
/** Расположение колонки */
|
|
20
|
+
columnArea?: ColumnArea;
|
|
21
|
+
/** Последняя закрепленная колонка
|
|
22
|
+
*
|
|
23
|
+
* Добавляет тень в зависимости от `columnArea`
|
|
24
|
+
*/
|
|
25
|
+
isLastFixed?: boolean;
|
|
26
|
+
/** Установка состояния "Активен" */
|
|
27
|
+
isActive?: boolean;
|
|
28
|
+
/** Обрабочик установки состояния "Активен" */
|
|
29
|
+
setIsActive?: (isActive: boolean) => void;
|
|
30
|
+
/** С границей */
|
|
31
|
+
isBordered?: boolean;
|
|
32
|
+
/** Многострочная */
|
|
33
|
+
isMultiline?: boolean;
|
|
34
|
+
/** Показывать тень вместо границы, в закрепленных столбцах и шапке */
|
|
35
|
+
isShadowed?: boolean;
|
|
36
|
+
/** Ошибка в поле */
|
|
37
|
+
error?: boolean | ReactNode;
|
|
38
|
+
/** Иконка | Контент слева */
|
|
39
|
+
startAdornment?: ReactNode;
|
|
40
|
+
/** Иконка | Контент справа */
|
|
41
|
+
endAdornment?: ReactNode;
|
|
42
|
+
} & QA & Pick<CSSProperties, 'padding' | 'verticalAlign' | 'textAlign' | 'writingMode' | 'userSelect' | 'wordBreak' | 'whiteSpace'> & TdHTMLAttributes<HTMLTableCellElement>;
|
|
43
|
+
export type DataGridTableCellProps<T = DefaultAny, V = DefaultAny> = {
|
|
44
|
+
cell: ReactTableCell<T, V>;
|
|
45
|
+
};
|
|
46
|
+
export {};
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export declare const TableDropdownHeader: import('@emotion/styled').StyledComponent<{
|
|
2
|
+
theme?: import('@emotion/react').Theme;
|
|
3
|
+
as?: React.ElementType;
|
|
4
|
+
}, import('react').DetailedHTMLProps<import('react').HTMLAttributes<HTMLDivElement>, HTMLDivElement>, {}>;
|
|
5
|
+
export declare const TableDropdownItem: import('@emotion/styled').StyledComponent<{
|
|
6
|
+
theme?: import('@emotion/react').Theme;
|
|
7
|
+
as?: React.ElementType;
|
|
8
|
+
}, import('react').DetailedHTMLProps<import('react').HTMLAttributes<HTMLDivElement>, HTMLDivElement>, {}>;
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import b from "@emotion/styled/base";
|
|
2
|
+
const g = /* @__PURE__ */ b("div", process.env.NODE_ENV === "production" ? {
|
|
3
|
+
target: "enkh3l21"
|
|
4
|
+
} : {
|
|
5
|
+
target: "enkh3l21",
|
|
6
|
+
label: "TableDropdownHeader"
|
|
7
|
+
})("padding:8px 12px 4px;user-select:none;", (c) => ({
|
|
8
|
+
...c.theme.typography.h6,
|
|
9
|
+
color: c.theme.colors.grey[70]
|
|
10
|
+
}), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3NhZHlrb3ZzZC9qb2luLXg1L3BhY2thZ2VzL2RhdGEtZ3JpZC9zcmMvVGFibGVEcm9wZG93bi9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRTZDIiwiZmlsZSI6Ii9ob21lL3NhZHlrb3ZzZC9qb2luLXg1L3BhY2thZ2VzL2RhdGEtZ3JpZC9zcmMvVGFibGVEcm9wZG93bi9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmV4cG9ydCBjb25zdCBUYWJsZURyb3Bkb3duSGVhZGVyID0gc3R5bGVkLmRpdmBcbiAgcGFkZGluZzogOHB4IDEycHggNHB4O1xuICB1c2VyLXNlbGVjdDogbm9uZTtcblxuICAke3Byb3BzID0+ICh7XG4gICAgLi4ucHJvcHMudGhlbWUudHlwb2dyYXBoeS5oNixcblxuICAgIGNvbG9yOiBwcm9wcy50aGVtZS5jb2xvcnMuZ3JleVs3MF0sXG4gIH0pfVxuYDtcblxuZXhwb3J0IGNvbnN0IFRhYmxlRHJvcGRvd25JdGVtID0gc3R5bGVkLmRpdmBcbiAgcGFkZGluZzogNnB4IDEycHg7XG4gIHVzZXItc2VsZWN0OiBub25lO1xuICBjdXJzb3I6IHBvaW50ZXI7XG5cbiAgJHtwcm9wcyA9PiAoe1xuICAgIC4uLnByb3BzLnRoZW1lLnR5cG9ncmFwaHkucDFjb21wYWN0LFxuXG4gICAgY29sb3I6IHByb3BzLnRoZW1lLmNvbG9ycy5ncmV5WzEwMF0sXG4gIH0pfVxuXG4gIDpob3ZlciB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5jb2xvcnMuZ3JleVsxMF19O1xuICB9XG5cbiAgJltkYXRhLWNoZWNrZWRdIHtcbiAgICAke3Byb3BzID0+ICh7XG4gICAgICBjb2xvcjogcHJvcHMudGhlbWUuY29sb3JzLndoaXRlLFxuICAgICAgYmFja2dyb3VuZENvbG9yOiBwcm9wcy50aGVtZS5jb2xvcnMuYWNjZW50WzkwXSxcbiAgICB9KX1cbiAgfVxuYDtcbiJdfQ== */")), o = /* @__PURE__ */ b("div", process.env.NODE_ENV === "production" ? {
|
|
11
|
+
target: "enkh3l20"
|
|
12
|
+
} : {
|
|
13
|
+
target: "enkh3l20",
|
|
14
|
+
label: "TableDropdownItem"
|
|
15
|
+
})("padding:6px 12px;user-select:none;cursor:pointer;", (c) => ({
|
|
16
|
+
...c.theme.typography.p1compact,
|
|
17
|
+
color: c.theme.colors.grey[100]
|
|
18
|
+
}), " :hover{background-color:", (c) => c.theme.colors.grey[10], ";}&[data-checked]{", (c) => ({
|
|
19
|
+
color: c.theme.colors.white,
|
|
20
|
+
backgroundColor: c.theme.colors.accent[90]
|
|
21
|
+
}), ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3NhZHlrb3ZzZC9qb2luLXg1L3BhY2thZ2VzL2RhdGEtZ3JpZC9zcmMvVGFibGVEcm9wZG93bi9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBYTJDIiwiZmlsZSI6Ii9ob21lL3NhZHlrb3ZzZC9qb2luLXg1L3BhY2thZ2VzL2RhdGEtZ3JpZC9zcmMvVGFibGVEcm9wZG93bi9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmV4cG9ydCBjb25zdCBUYWJsZURyb3Bkb3duSGVhZGVyID0gc3R5bGVkLmRpdmBcbiAgcGFkZGluZzogOHB4IDEycHggNHB4O1xuICB1c2VyLXNlbGVjdDogbm9uZTtcblxuICAke3Byb3BzID0+ICh7XG4gICAgLi4ucHJvcHMudGhlbWUudHlwb2dyYXBoeS5oNixcblxuICAgIGNvbG9yOiBwcm9wcy50aGVtZS5jb2xvcnMuZ3JleVs3MF0sXG4gIH0pfVxuYDtcblxuZXhwb3J0IGNvbnN0IFRhYmxlRHJvcGRvd25JdGVtID0gc3R5bGVkLmRpdmBcbiAgcGFkZGluZzogNnB4IDEycHg7XG4gIHVzZXItc2VsZWN0OiBub25lO1xuICBjdXJzb3I6IHBvaW50ZXI7XG5cbiAgJHtwcm9wcyA9PiAoe1xuICAgIC4uLnByb3BzLnRoZW1lLnR5cG9ncmFwaHkucDFjb21wYWN0LFxuXG4gICAgY29sb3I6IHByb3BzLnRoZW1lLmNvbG9ycy5ncmV5WzEwMF0sXG4gIH0pfVxuXG4gIDpob3ZlciB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5jb2xvcnMuZ3JleVsxMF19O1xuICB9XG5cbiAgJltkYXRhLWNoZWNrZWRdIHtcbiAgICAke3Byb3BzID0+ICh7XG4gICAgICBjb2xvcjogcHJvcHMudGhlbWUuY29sb3JzLndoaXRlLFxuICAgICAgYmFja2dyb3VuZENvbG9yOiBwcm9wcy50aGVtZS5jb2xvcnMuYWNjZW50WzkwXSxcbiAgICB9KX1cbiAgfVxuYDtcbiJdfQ== */"));
|
|
22
|
+
export {
|
|
23
|
+
g as TableDropdownHeader,
|
|
24
|
+
o as TableDropdownItem
|
|
25
|
+
};
|
|
26
|
+
//# sourceMappingURL=index.es.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.es.js","sources":["../../src/TableDropdown/index.tsx"],"sourcesContent":["import styled from '@emotion/styled';\n\nexport const TableDropdownHeader = styled.div`\n padding: 8px 12px 4px;\n user-select: none;\n\n ${props => ({\n ...props.theme.typography.h6,\n\n color: props.theme.colors.grey[70],\n })}\n`;\n\nexport const TableDropdownItem = styled.div`\n padding: 6px 12px;\n user-select: none;\n cursor: pointer;\n\n ${props => ({\n ...props.theme.typography.p1compact,\n\n color: props.theme.colors.grey[100],\n })}\n\n :hover {\n background-color: ${props => props.theme.colors.grey[10]};\n }\n\n &[data-checked] {\n ${props => ({\n color: props.theme.colors.white,\n backgroundColor: props.theme.colors.accent[90],\n })}\n }\n`;\n"],"names":["TableDropdownHeader","process","env","NODE_ENV","target","label","props","theme","typography","h6","color","colors","grey","TableDropdownItem","p1compact","white","backgroundColor","accent"],"mappings":";AAEO,MAAMA,6BAAmBC,QAAAC,IAAAC,aAAA,eAAA;AAAA,EAAAC,QAAA;AAAA,IAAA;AAAA,EAAAA,QAAA;AAAA,EAAAC,OAAA;AAAA,CAAA,EAAA,0CAI5BC,CAAUA,OAAA;AAAA,EACV,GAAGA,EAAMC,MAAMC,WAAWC;AAAAA,EAE1BC,OAAOJ,EAAMC,MAAMI,OAAOC,KAAK,EAAE;AACnC,IAAEX,OAAAA,QAAAC,IAAAC,aACH,eAAA,KAAA,0yCAAA,GAEYU,6BAAiBZ,QAAAC,IAAAC,aAAA,eAAA;AAAA,EAAAC,QAAA;AAAA,IAAA;AAAA,EAAAA,QAAA;AAAA,EAAAC,OAAA;AAAA,CAAA,EAAA,qDAK1BC,CAAUA,OAAA;AAAA,EACV,GAAGA,EAAMC,MAAMC,WAAWM;AAAAA,EAE1BJ,OAAOJ,EAAMC,MAAMI,OAAOC,KAAK,GAAG;AACpC,IAGsBN,6BAAAA,OAASA,EAAMC,MAAMI,OAAOC,KAAK,EAAE,GAAC,sBAItDN,CAAUA,OAAA;AAAA,EACVI,OAAOJ,EAAMC,MAAMI,OAAOI;AAAAA,EAC1BC,iBAAiBV,EAAMC,MAAMI,OAAOM,OAAO,EAAE;AAC/C,IAAEhB,QAAAA,QAAAC,IAAAC,aAEL,eAAA,KAAA,0yCAAA;"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { Table } from '@tanstack/react-table';
|
|
2
|
+
export declare const TableHead: import('@emotion/styled').StyledComponent<{
|
|
3
|
+
theme?: import('@emotion/react').Theme;
|
|
4
|
+
as?: React.ElementType;
|
|
5
|
+
}, import('react').DetailedHTMLProps<import('react').HTMLAttributes<HTMLTableSectionElement>, HTMLTableSectionElement>, {}>;
|
|
6
|
+
export declare const getDataGridTableHead: (table: Table<unknown>) => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as b } from "@emotion/react/jsx-runtime";
|
|
3
|
+
import n from "@emotion/styled/base";
|
|
4
|
+
import { useContext as i } from "react";
|
|
5
|
+
import { DataGridContext as o } from "../DataGridContext.es.js";
|
|
6
|
+
import { getDataGridTableHeadCell as a } from "../TableHeadCell/index.es.js";
|
|
7
|
+
import { TableHeadRow as l } from "../TableHeadRow/index.es.js";
|
|
8
|
+
function Z() {
|
|
9
|
+
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).";
|
|
10
|
+
}
|
|
11
|
+
const I = /* @__PURE__ */ n("thead", process.env.NODE_ENV === "production" ? {
|
|
12
|
+
target: "etxjaz80"
|
|
13
|
+
} : {
|
|
14
|
+
target: "etxjaz80",
|
|
15
|
+
label: "TableHead"
|
|
16
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
17
|
+
name: "2hn84s",
|
|
18
|
+
styles: "position:sticky;top:0;z-index:2"
|
|
19
|
+
} : {
|
|
20
|
+
name: "2hn84s",
|
|
21
|
+
styles: "position:sticky;top:0;z-index:2/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3NhZHlrb3ZzZC9qb2luLXg1L3BhY2thZ2VzL2RhdGEtZ3JpZC9zcmMvVGFibGVIZWFkL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFXcUMiLCJmaWxlIjoiL2hvbWUvc2FkeWtvdnNkL2pvaW4teDUvcGFja2FnZXMvZGF0YS1ncmlkL3NyYy9UYWJsZUhlYWQvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnO1xuXG5pbXBvcnQge3VzZUNvbnRleHR9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuaW1wb3J0IHtEYXRhR3JpZENvbnRleHR9IGZyb20gJ0RhdGFHcmlkQ29udGV4dCc7XG5pbXBvcnQge2dldERhdGFHcmlkVGFibGVIZWFkQ2VsbH0gZnJvbSAnVGFibGVIZWFkQ2VsbCc7XG5pbXBvcnQge1RhYmxlSGVhZFJvd30gZnJvbSAnVGFibGVIZWFkUm93JztcblxuaW1wb3J0IHR5cGUge1RhYmxlfSBmcm9tICdAdGFuc3RhY2svcmVhY3QtdGFibGUnO1xuXG5leHBvcnQgY29uc3QgVGFibGVIZWFkID0gc3R5bGVkLnRoZWFkYFxuICBwb3NpdGlvbjogc3RpY2t5O1xuICB0b3A6IDA7XG4gIHotaW5kZXg6IDI7XG5gO1xuXG50eXBlIERhdGFHcmlkVGFibGVIZWFkUHJvcHMgPSB7XG4gIHRhYmxlOiBUYWJsZTx1bmtub3duPjtcbn07XG5cbmNvbnN0IERhdGFHcmlkVGFibGVIZWFkOiBSZWFjdC5GQzxEYXRhR3JpZFRhYmxlSGVhZFByb3BzPiA9IHByb3BzID0+IHtcbiAgY29uc3QgY29udGV4dCA9IHVzZUNvbnRleHQoRGF0YUdyaWRDb250ZXh0KTtcblxuICBjb25zdCBjb250ZW50ID0gcHJvcHMudGFibGVcbiAgICAuZ2V0SGVhZGVyR3JvdXBzKClcbiAgICAubWFwKGhlYWRlckdyb3VwID0+IChcbiAgICAgIDxUYWJsZUhlYWRSb3cga2V5PXtoZWFkZXJHcm91cC5pZH0+XG4gICAgICAgIHtoZWFkZXJHcm91cC5oZWFkZXJzLm1hcChoZWFkZXIgPT4gZ2V0RGF0YUdyaWRUYWJsZUhlYWRDZWxsKGhlYWRlcikpfVxuICAgICAgPC9UYWJsZUhlYWRSb3c+XG4gICAgKSk7XG5cbiAgcmV0dXJuIDxUYWJsZUhlYWQgZGF0YS1xYT17YCR7Y29udGV4dC5xYX0taGVhZGB9Pntjb250ZW50fTwvVGFibGVIZWFkPjtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXREYXRhR3JpZFRhYmxlSGVhZCA9ICh0YWJsZTogVGFibGU8dW5rbm93bj4pID0+IHtcbiAgcmV0dXJuIDxEYXRhR3JpZFRhYmxlSGVhZCB0YWJsZT17dGFibGV9IC8+O1xufTtcbiJdfQ== */",
|
|
22
|
+
toString: Z
|
|
23
|
+
}), s = (t) => {
|
|
24
|
+
const e = i(o), G = t.table.getHeaderGroups().map((c) => /* @__PURE__ */ b(l, { children: c.headers.map((d) => a(d)) }, c.id));
|
|
25
|
+
return /* @__PURE__ */ b(I, { "data-qa": `${e.qa}-head`, children: G });
|
|
26
|
+
}, r = (t) => /* @__PURE__ */ b(s, { table: t });
|
|
27
|
+
export {
|
|
28
|
+
I as TableHead,
|
|
29
|
+
r as getDataGridTableHead
|
|
30
|
+
};
|
|
31
|
+
//# sourceMappingURL=index.es.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.es.js","sources":["../../src/TableHead/index.tsx"],"sourcesContent":["'use client';\n\nimport {useContext} from 'react';\nimport styled from '@emotion/styled';\n\nimport {DataGridContext} from 'DataGridContext';\nimport {getDataGridTableHeadCell} from 'TableHeadCell';\nimport {TableHeadRow} from 'TableHeadRow';\n\nimport type {Table} from '@tanstack/react-table';\n\nexport const TableHead = styled.thead`\n position: sticky;\n top: 0;\n z-index: 2;\n`;\n\ntype DataGridTableHeadProps = {\n table: Table<unknown>;\n};\n\nconst DataGridTableHead: React.FC<DataGridTableHeadProps> = props => {\n const context = useContext(DataGridContext);\n\n const content = props.table\n .getHeaderGroups()\n .map(headerGroup => (\n <TableHeadRow key={headerGroup.id}>\n {headerGroup.headers.map(header => getDataGridTableHeadCell(header))}\n </TableHeadRow>\n ));\n\n return <TableHead data-qa={`${context.qa}-head`}>{content}</TableHead>;\n};\n\nexport const getDataGridTableHead = (table: Table<unknown>) => {\n return <DataGridTableHead table={table} />;\n};\n"],"names":["context"],"mappings":";;;;;;;AAAa;AAAA;AAAA;AAWN;AAAe;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAWdA;AAUN;AACF;;;;;"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Header } from '@tanstack/react-table';
|
|
2
|
+
import { FRC } from '@join-x5/react-theme';
|
|
3
|
+
import { TableHeadCellProps } from './types';
|
|
4
|
+
export declare const TableHeadCellResizer: import('@emotion/styled').StyledComponent<{
|
|
5
|
+
theme?: import('@emotion/react').Theme;
|
|
6
|
+
as?: React.ElementType;
|
|
7
|
+
}, import('react').DetailedHTMLProps<import('react').HTMLAttributes<HTMLDivElement>, HTMLDivElement>, {}>;
|
|
8
|
+
export declare const TableHeadCell: FRC<HTMLTableCellElement, TableHeadCellProps>;
|
|
9
|
+
type DataGridTableHeadCellProps = {
|
|
10
|
+
header: Header<unknown, unknown>;
|
|
11
|
+
};
|
|
12
|
+
export declare const DataGridTableHeadCell: React.FC<DataGridTableHeadCellProps>;
|
|
13
|
+
export declare const getDataGridTableHeadCell: (header: DataGridTableHeadCellProps["header"]) => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
14
|
+
export * from './types';
|