@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.
- 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 +10 -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,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 @@
|
|
|
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,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,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 {};
|