@tedi-design-system/react 18.0.0-rc.4 → 18.0.0-rc.5
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/_virtual/index.es13.js +2 -2
- package/_virtual/index.es14.js +2 -2
- package/bundle-stats.html +1 -1
- package/external/hoist-non-react-statics/external/react-is/cjs/react-is.development.cjs.js +1 -1
- package/external/hoist-non-react-statics/external/react-is/cjs/react-is.development.es.js +1 -1
- package/external/hoist-non-react-statics/external/react-is/cjs/react-is.production.min.cjs.js +1 -1
- package/external/hoist-non-react-statics/external/react-is/cjs/react-is.production.min.es.js +1 -1
- package/external/hoist-non-react-statics/external/react-is/index.cjs.js +1 -1
- package/external/hoist-non-react-statics/external/react-is/index.es.js +1 -1
- package/external/prop-types/external/react-is/cjs/react-is.development.cjs.js +1 -1
- package/external/prop-types/external/react-is/cjs/react-is.development.es.js +1 -1
- package/external/prop-types/external/react-is/cjs/react-is.production.min.cjs.js +1 -1
- package/external/prop-types/external/react-is/cjs/react-is.production.min.es.js +1 -1
- package/external/prop-types/external/react-is/index.cjs.js +1 -1
- package/external/prop-types/external/react-is/index.es.js +1 -1
- package/external/react-is/index.cjs.js +1 -1
- package/external/react-is/index.es.js +1 -1
- package/external/toposort/index.cjs.js +1 -1
- package/external/toposort/index.es.js +1 -1
- package/index.css +1 -1
- package/package.json +1 -1
- package/src/tedi/components/buttons/button-group/button-group.cjs.js +1 -1
- package/src/tedi/components/buttons/button-group/button-group.es.js +4 -4
- package/src/tedi/components/buttons/collapse/collapse.cjs.js +1 -1
- package/src/tedi/components/buttons/collapse/collapse.d.ts +15 -0
- package/src/tedi/components/buttons/collapse/collapse.es.js +55 -54
- package/src/tedi/components/content/table/index.d.ts +6 -0
- package/src/tedi/components/content/table/table-columns-menu/table-columns-menu.cjs.js +1 -0
- package/src/tedi/components/content/table/table-columns-menu/table-columns-menu.d.ts +15 -0
- package/src/tedi/components/content/table/table-columns-menu/table-columns-menu.es.js +37 -0
- package/src/tedi/components/content/table/table-context.cjs.js +1 -0
- package/src/tedi/components/content/table/table-context.d.ts +3 -0
- package/src/tedi/components/content/table/table-context.es.js +11 -0
- package/src/tedi/components/content/table/table-header-button/table-header-button.cjs.js +1 -0
- package/src/tedi/components/content/table/table-header-button/table-header-button.d.ts +51 -0
- package/src/tedi/components/content/table/table-header-button/table-header-button.es.js +42 -0
- package/src/tedi/components/content/table/table-header-button/table-header-button.module.scss.cjs.js +1 -0
- package/src/tedi/components/content/table/table-header-button/table-header-button.module.scss.es.js +7 -0
- package/src/tedi/components/content/table/table-toolbar/table-toolbar.cjs.js +1 -0
- package/src/tedi/components/content/table/table-toolbar/table-toolbar.d.ts +21 -0
- package/src/tedi/components/content/table/table-toolbar/table-toolbar.es.js +9 -0
- package/src/tedi/components/content/table/table.cjs.js +1 -0
- package/src/tedi/components/content/table/table.d.ts +519 -0
- package/src/tedi/components/content/table/table.es.js +856 -0
- package/src/tedi/components/content/table/table.module.scss.cjs.js +1 -0
- package/src/tedi/components/content/table/table.module.scss.es.js +54 -0
- package/src/tedi/components/content/table/use-table-persistence.cjs.js +1 -0
- package/src/tedi/components/content/table/use-table-persistence.d.ts +13 -0
- package/src/tedi/components/content/table/use-table-persistence.es.js +53 -0
- package/src/tedi/components/navigation/pagination/pagination.cjs.js +1 -1
- package/src/tedi/components/navigation/pagination/pagination.d.ts +7 -0
- package/src/tedi/components/navigation/pagination/pagination.es.js +132 -91
- package/src/tedi/components/navigation/pagination/pagination.module.scss.cjs.js +1 -1
- package/src/tedi/components/navigation/pagination/pagination.module.scss.es.js +7 -1
- package/src/tedi/components/navigation/pagination/pagination.types.d.ts +100 -0
- package/src/tedi/components/overlays/tooltip/tooltip.cjs.js +1 -1
- package/src/tedi/components/overlays/tooltip/tooltip.es.js +14 -6
- package/src/tedi/index.d.ts +1 -0
- package/src/tedi/providers/label-provider/labels-map.cjs.js +1 -1
- package/src/tedi/providers/label-provider/labels-map.d.ts +132 -6
- package/src/tedi/providers/label-provider/labels-map.es.js +146 -11
- package/tedi.cjs.js +1 -1
- package/tedi.es.js +193 -179
package/package.json
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const o=require("react/jsx-runtime"),g=require("../../../../../external/classnames/index.cjs.js"),_=require("react"),n=require("../../base/icon/icon.cjs.js"),x=require("../button/button.cjs.js"),r=require("./button-group.module.scss.cjs.js"),
|
|
1
|
+
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const o=require("react/jsx-runtime"),g=require("../../../../../external/classnames/index.cjs.js"),_=require("react"),n=require("../../base/icon/icon.cjs.js"),x=require("../button/button.cjs.js"),r=require("./button-group.module.scss.cjs.js"),C=require("../../../providers/label-provider/use-labels.cjs.js"),L=require("../../../helpers/hooks/use-breakpoint.cjs.js"),l=require("../../overlays/dropdown/dropdown.cjs.js"),b=k=>{const{getLabel:j}=C.useLabels(),{children:q,className:w,type:c="primary",onSelectionChange:i,stretch:v=!1,ariaLabel:I,size:f="default",enableMobileDropdown:A=!1,mobileBreakpoint:N="md",dropdownLabel:y=j("sidenav.submenu"),dropdownLabelMode:R="static"}=k,B=L.useBreakpoint(),D=L.isBreakpointBelow(B,N),m=_.Children.toArray(q).filter(e=>_.isValidElement(e)&&e.type===x.Button),s=m.find(e=>e.props.isActive),M=R==="static"?y:(s==null?void 0:s.props.children)??y,a=s==null?void 0:s.props.iconLeft,d=s==null?void 0:s.props.icon;return D&&A?o.jsxs(l.Dropdown,{width:"trigger",children:[o.jsx(l.Dropdown.Trigger,{children:o.jsxs(x.Button,{visualType:c,className:g.default(r.default["tedi-button-group__dropdown-trigger"],r.default[`tedi-button-group__dropdown-trigger--${c}`],w),noStyle:!0,fullWidth:!0,children:[a?o.jsx(n.Icon,{name:typeof a=="string"?a:a.name,color:"inherit"}):d?o.jsx(n.Icon,{name:typeof d=="string"?d:d.name,color:"inherit"}):o.jsx(n.Icon,{name:"menu",color:"inherit"}),M]})}),o.jsx(l.Dropdown.Content,{children:m.map((e,u)=>o.jsxs(l.Dropdown.Item,{index:u,active:e==null?void 0:e.props.isActive,disabled:e==null?void 0:e.props.disabled,onClick:t=>{var p,h;e.props.disabled||(t.type==="click"&&((h=(p=e.props).onClick)==null||h.call(p,t)),e.props.id&&(i==null||i(e.props.id)))},className:r.default["tedi-button-group__dropdown-item"],children:[e.props.iconLeft&&o.jsx(n.Icon,{name:typeof e.props.iconLeft=="string"?e.props.iconLeft:e.props.iconLeft.name,color:"inherit"}),e.props.children,e.props.iconRight&&o.jsx(n.Icon,{name:typeof e.props.iconRight=="string"?e.props.iconRight:e.props.iconRight.name,color:"inherit"}),e.props.isActive&&o.jsx("span",{className:"sr-only",children:j("button-group.selected")})]},e.props.id||u))})]}):o.jsx("div",{className:g.default(r.default["tedi-button-group"],r.default[`tedi-button-group--${c}`],{[r.default["tedi-button-group--stretch"]]:v},w),role:"group","aria-label":I,children:m.map(e=>_.cloneElement(e,{className:g.default(r.default["tedi-button-group__item"],{[r.default["tedi-button-group__item--active"]]:e.props.isActive,[r.default["tedi-button-group__item--disabled"]]:e.props.disabled,[r.default[`tedi-button-group__item--size-${f}`]]:f},e.props.className),size:f,"aria-pressed":!!e.props.isActive,onClick:u=>{var t,p;(p=(t=e.props).onClick)==null||p.call(t,u),e.props.id&&(i==null||i(e.props.id))}}))})};exports.ButtonGroup=b;exports.default=b;
|
|
@@ -4,11 +4,11 @@ import { Children as x, isValidElement as z, cloneElement as B } from "react";
|
|
|
4
4
|
import { Icon as a } from "../../base/icon/icon.es.js";
|
|
5
5
|
import { Button as k } from "../button/button.es.js";
|
|
6
6
|
import r from "./button-group.module.scss.es.js";
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
7
|
+
import { useLabels as D } from "../../../providers/label-provider/use-labels.es.js";
|
|
8
|
+
import { useBreakpoint as E, isBreakpointBelow as T } from "../../../helpers/hooks/use-breakpoint.es.js";
|
|
9
9
|
import { Dropdown as d } from "../../overlays/dropdown/dropdown.es.js";
|
|
10
10
|
const P = (N) => {
|
|
11
|
-
const { getLabel: _ } =
|
|
11
|
+
const { getLabel: _ } = D(), {
|
|
12
12
|
children: v,
|
|
13
13
|
className: h,
|
|
14
14
|
type: m = "primary",
|
|
@@ -20,7 +20,7 @@ const P = (N) => {
|
|
|
20
20
|
mobileBreakpoint: R = "md",
|
|
21
21
|
dropdownLabel: L = _("sidenav.submenu"),
|
|
22
22
|
dropdownLabelMode: C = "static"
|
|
23
|
-
} = N, M =
|
|
23
|
+
} = N, M = E(), $ = T(M, R), f = x.toArray(v).filter(
|
|
24
24
|
(o) => z(o) && o.type === k
|
|
25
25
|
), e = f.find((o) => o.props.isActive), j = C === "static" ? L : (e == null ? void 0 : e.props.children) ?? L, n = e == null ? void 0 : e.props.iconLeft, l = e == null ? void 0 : e.props.icon;
|
|
26
26
|
return $ && I ? /* @__PURE__ */ g(d, { width: "trigger", children: [
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const t=require("react/jsx-runtime"),n=require("../../../../../external/classnames/index.cjs.js"),_=require("react"),
|
|
1
|
+
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const t=require("react/jsx-runtime"),n=require("../../../../../external/classnames/index.cjs.js"),_=require("react"),H=require("../../../../../external/react-animate-height/dist/esm/index.cjs.js"),J=require("../../../providers/printing-provider/printing-provider.cjs.js"),Q=require("../../base/icon/icon.cjs.js"),U=require("../../base/typography/text/text.cjs.js"),V=require("../../misc/print/print.cjs.js"),e=require("./collapse.module.scss.cjs.js"),W=require("../../../helpers/hooks/use-breakpoint-props.cjs.js"),X=require("../../../providers/label-provider/use-labels.cjs.js"),N=require("../../layout/grid/row.cjs.js"),i=require("../../layout/grid/col.cjs.js"),P=x=>{const{getCurrentBreakpointProps:k}=W.useBreakpointProps(x.defaultServerBreakpoint),{getLabel:h}=X.useLabels(),{id:r,children:w,className:O,openText:j=h("open"),closeText:y=h("close"),hideCollapseText:$=!1,title:d,titleRowProps:S,defaultOpen:B,open:c,onToggle:u,arrowType:s="default",size:o="default",underline:M=!0,toggleLabel:g,iconOnly:R=!1,controlsId:v,inverted:T=!1,...L}=k(x),b=v!==void 0,p=`${r}__trigger`,f=`${r}__content`,D=`${r}__animate`,[C,E]=_.useState(()=>B),m=J.usePrint(),a=_.useMemo(()=>m||(c!==void 0?c:C),[m,c,C]),z=R===!0&&!d,K=T&&s!=="secondary",A=n.default(e.default["tedi-collapse"],o==="small"&&e.default["tedi-collapse--small"],a&&e.default["tedi-collapse--is-open"],z&&e.default["tedi-collapse--icon-only"],K&&e.default["tedi-collapse--inverted"],e.default[`tedi-collapse--arrow-${s}`],O),q=()=>{const l=!a;E(l),u==null||u(l)},F=l=>{(l.key==="Enter"||l.key===" ")&&!l.repeat&&(l.preventDefault(),q())},G=g||(a?y:j),I=_.useMemo(()=>t.jsx("div",{id:f,role:"region","aria-labelledby":p,className:e.default["tedi-collapse__content"],children:w}),[w,f,p]);return t.jsxs("div",{"data-name":"collapse",...L,className:A,children:[t.jsx("button",{id:p,type:"button","data-name":"collapse-trigger",className:e.default["tedi-collapse__title"],"aria-label":G,"aria-expanded":a,"aria-controls":b?v:f,onKeyDown:F,onClick:q,children:t.jsxs(N.Row,{justifyContent:"between",alignItems:"center",wrap:"nowrap",...S,element:"span",children:[d&&t.jsx(i.Col,{"aria-hidden":"true",children:d}),t.jsx(i.Col,{width:"auto",children:t.jsxs(N.Row,{element:"span",alignItems:"center",gutter:0,wrap:"nowrap",children:[t.jsx(V.Print,{visibility:"hide",children:t.jsx(i.Col,{width:"auto",className:n.default({"visually-hidden":$}),children:t.jsx(U.Text,{element:"span",className:n.default(e.default["tedi-collapse__text"],{[e.default["tedi-collapse__text--underline"]]:M}),children:a?y:j})})}),t.jsx(i.Col,{width:"auto",children:t.jsx("div",{className:n.default(e.default["tedi-collapse__icon-wrapper"],e.default[`tedi-collapse__icon-wrapper--${s}`],o==="small"&&e.default["tedi-collapse__icon-wrapper--small"]),children:t.jsx(Q.Icon,{className:n.default(e.default["tedi-collapse__icon"],e.default[`tedi-collapse__icon--${s}`],o==="small"&&e.default["tedi-collapse__icon--small"]),name:"expand_more",size:o==="small"||s==="secondary"?18:24})})})]})})]})}),!b&&(m?I:t.jsx(H.default,{id:D,duration:300,height:a?"auto":0,"data-testid":"collapse-inner",children:I}))]})};exports.Collapse=P;exports.default=P;
|
|
@@ -84,6 +84,21 @@ export interface CollapseProps extends BreakpointSupport<CollapseBreakpointProps
|
|
|
84
84
|
* If provided, overrides the default open/close text for the accessible name.
|
|
85
85
|
*/
|
|
86
86
|
toggleLabel?: string;
|
|
87
|
+
/**
|
|
88
|
+
* Use Collapse purely as a toggle trigger for content rendered elsewhere.
|
|
89
|
+
*
|
|
90
|
+
* When set, the toggle button's `aria-controls` points at the supplied id
|
|
91
|
+
* instead of Collapse's internal content panel, and the internal panel is
|
|
92
|
+
* **not rendered**. Useful when the disclosed region must live outside
|
|
93
|
+
* Collapse's DOM subtree (e.g. a table row whose details live in a
|
|
94
|
+
* sibling `<tr>`). The consumer is responsible for rendering the target
|
|
95
|
+
* element with the matching `id` and an appropriate `role` (typically
|
|
96
|
+
* `region`).
|
|
97
|
+
*
|
|
98
|
+
* When omitted (default), Collapse renders its own `children` inside a
|
|
99
|
+
* built-in `role="region"` panel.
|
|
100
|
+
*/
|
|
101
|
+
controlsId?: string;
|
|
87
102
|
}
|
|
88
103
|
export declare const Collapse: (props: CollapseProps) => JSX.Element;
|
|
89
104
|
export default Collapse;
|
|
@@ -1,57 +1,58 @@
|
|
|
1
1
|
import { jsx as t, jsxs as f } from "react/jsx-runtime";
|
|
2
2
|
import n from "../../../../../external/classnames/index.es.js";
|
|
3
3
|
import h from "react";
|
|
4
|
-
import
|
|
5
|
-
import { usePrint as
|
|
6
|
-
import { Icon as
|
|
7
|
-
import { Text as
|
|
8
|
-
import { Print as
|
|
4
|
+
import G from "../../../../../external/react-animate-height/dist/esm/index.es.js";
|
|
5
|
+
import { usePrint as J } from "../../../providers/printing-provider/printing-provider.es.js";
|
|
6
|
+
import { Icon as Q } from "../../base/icon/icon.es.js";
|
|
7
|
+
import { Text as U } from "../../base/typography/text/text.es.js";
|
|
8
|
+
import { Print as V } from "../../misc/print/print.es.js";
|
|
9
9
|
import e from "./collapse.module.scss.es.js";
|
|
10
|
-
import { useBreakpointProps as
|
|
11
|
-
import { useLabels as
|
|
12
|
-
import { Row as
|
|
10
|
+
import { useBreakpointProps as W } from "../../../helpers/hooks/use-breakpoint-props.es.js";
|
|
11
|
+
import { useLabels as X } from "../../../providers/label-provider/use-labels.es.js";
|
|
12
|
+
import { Row as P } from "../../layout/grid/row.es.js";
|
|
13
13
|
import { Col as s } from "../../layout/grid/col.es.js";
|
|
14
|
-
const
|
|
15
|
-
const { getCurrentBreakpointProps:
|
|
14
|
+
const pe = (w) => {
|
|
15
|
+
const { getCurrentBreakpointProps: $ } = W(w.defaultServerBreakpoint), { getLabel: y } = X(), {
|
|
16
16
|
id: r,
|
|
17
17
|
children: g,
|
|
18
|
-
className:
|
|
19
|
-
openText:
|
|
20
|
-
closeText:
|
|
21
|
-
hideCollapseText:
|
|
18
|
+
className: B,
|
|
19
|
+
openText: v = y("open"),
|
|
20
|
+
closeText: x = y("close"),
|
|
21
|
+
hideCollapseText: S = !1,
|
|
22
22
|
title: c,
|
|
23
|
-
titleRowProps:
|
|
24
|
-
defaultOpen:
|
|
23
|
+
titleRowProps: T,
|
|
24
|
+
defaultOpen: j,
|
|
25
25
|
open: d,
|
|
26
26
|
onToggle: p,
|
|
27
|
-
arrowType:
|
|
27
|
+
arrowType: a = "default",
|
|
28
28
|
size: i = "default",
|
|
29
|
-
underline:
|
|
30
|
-
toggleLabel:
|
|
31
|
-
iconOnly:
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
29
|
+
underline: D = !0,
|
|
30
|
+
toggleLabel: b,
|
|
31
|
+
iconOnly: E = !1,
|
|
32
|
+
controlsId: C,
|
|
33
|
+
inverted: L = !1,
|
|
34
|
+
...M
|
|
35
|
+
} = $(w), I = C !== void 0, m = `${r}__trigger`, u = `${r}__content`, R = `${r}__animate`, [N, z] = h.useState(() => j), _ = J(), o = h.useMemo(
|
|
35
36
|
() => _ || (d !== void 0 ? d : N),
|
|
36
37
|
[_, d, N]
|
|
37
|
-
),
|
|
38
|
+
), K = E === !0 && !c, A = L && a !== "secondary", H = n(
|
|
38
39
|
e["tedi-collapse"],
|
|
39
40
|
i === "small" && e["tedi-collapse--small"],
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
e[`tedi-collapse--arrow-${
|
|
44
|
-
|
|
45
|
-
),
|
|
46
|
-
const l = !
|
|
47
|
-
|
|
48
|
-
},
|
|
49
|
-
(l.key === "Enter" || l.key === " ") && !l.repeat && (l.preventDefault(),
|
|
50
|
-
},
|
|
41
|
+
o && e["tedi-collapse--is-open"],
|
|
42
|
+
K && e["tedi-collapse--icon-only"],
|
|
43
|
+
A && e["tedi-collapse--inverted"],
|
|
44
|
+
e[`tedi-collapse--arrow-${a}`],
|
|
45
|
+
B
|
|
46
|
+
), k = () => {
|
|
47
|
+
const l = !o;
|
|
48
|
+
z(l), p == null || p(l);
|
|
49
|
+
}, q = (l) => {
|
|
50
|
+
(l.key === "Enter" || l.key === " ") && !l.repeat && (l.preventDefault(), k());
|
|
51
|
+
}, F = b || (o ? x : v), O = h.useMemo(
|
|
51
52
|
() => /* @__PURE__ */ t("div", { id: u, role: "region", "aria-labelledby": m, className: e["tedi-collapse__content"], children: g }),
|
|
52
53
|
[g, u, m]
|
|
53
54
|
);
|
|
54
|
-
return /* @__PURE__ */ f("div", { "data-name": "collapse", ...
|
|
55
|
+
return /* @__PURE__ */ f("div", { "data-name": "collapse", ...M, className: H, children: [
|
|
55
56
|
/* @__PURE__ */ t(
|
|
56
57
|
"button",
|
|
57
58
|
{
|
|
@@ -59,22 +60,22 @@ const ce = (w) => {
|
|
|
59
60
|
type: "button",
|
|
60
61
|
"data-name": "collapse-trigger",
|
|
61
62
|
className: e["tedi-collapse__title"],
|
|
62
|
-
"aria-label":
|
|
63
|
-
"aria-expanded":
|
|
64
|
-
"aria-controls": u,
|
|
65
|
-
onKeyDown:
|
|
66
|
-
onClick:
|
|
67
|
-
children: /* @__PURE__ */ f(
|
|
63
|
+
"aria-label": F,
|
|
64
|
+
"aria-expanded": o,
|
|
65
|
+
"aria-controls": I ? C : u,
|
|
66
|
+
onKeyDown: q,
|
|
67
|
+
onClick: k,
|
|
68
|
+
children: /* @__PURE__ */ f(P, { justifyContent: "between", alignItems: "center", wrap: "nowrap", ...T, element: "span", children: [
|
|
68
69
|
c && /* @__PURE__ */ t(s, { "aria-hidden": "true", children: c }),
|
|
69
|
-
/* @__PURE__ */ t(s, { width: "auto", children: /* @__PURE__ */ f(
|
|
70
|
-
/* @__PURE__ */ t(
|
|
71
|
-
|
|
70
|
+
/* @__PURE__ */ t(s, { width: "auto", children: /* @__PURE__ */ f(P, { element: "span", alignItems: "center", gutter: 0, wrap: "nowrap", children: [
|
|
71
|
+
/* @__PURE__ */ t(V, { visibility: "hide", children: /* @__PURE__ */ t(s, { width: "auto", className: n({ "visually-hidden": S }), children: /* @__PURE__ */ t(
|
|
72
|
+
U,
|
|
72
73
|
{
|
|
73
74
|
element: "span",
|
|
74
75
|
className: n(e["tedi-collapse__text"], {
|
|
75
|
-
[e["tedi-collapse__text--underline"]]:
|
|
76
|
+
[e["tedi-collapse__text--underline"]]: D
|
|
76
77
|
}),
|
|
77
|
-
children:
|
|
78
|
+
children: o ? x : v
|
|
78
79
|
}
|
|
79
80
|
) }) }),
|
|
80
81
|
/* @__PURE__ */ t(s, { width: "auto", children: /* @__PURE__ */ t(
|
|
@@ -82,19 +83,19 @@ const ce = (w) => {
|
|
|
82
83
|
{
|
|
83
84
|
className: n(
|
|
84
85
|
e["tedi-collapse__icon-wrapper"],
|
|
85
|
-
e[`tedi-collapse__icon-wrapper--${
|
|
86
|
+
e[`tedi-collapse__icon-wrapper--${a}`],
|
|
86
87
|
i === "small" && e["tedi-collapse__icon-wrapper--small"]
|
|
87
88
|
),
|
|
88
89
|
children: /* @__PURE__ */ t(
|
|
89
|
-
|
|
90
|
+
Q,
|
|
90
91
|
{
|
|
91
92
|
className: n(
|
|
92
93
|
e["tedi-collapse__icon"],
|
|
93
|
-
e[`tedi-collapse__icon--${
|
|
94
|
+
e[`tedi-collapse__icon--${a}`],
|
|
94
95
|
i === "small" && e["tedi-collapse__icon--small"]
|
|
95
96
|
),
|
|
96
97
|
name: "expand_more",
|
|
97
|
-
size: i === "small" ||
|
|
98
|
+
size: i === "small" || a === "secondary" ? 18 : 24
|
|
98
99
|
}
|
|
99
100
|
)
|
|
100
101
|
}
|
|
@@ -103,10 +104,10 @@ const ce = (w) => {
|
|
|
103
104
|
] })
|
|
104
105
|
}
|
|
105
106
|
),
|
|
106
|
-
_ ?
|
|
107
|
+
!I && (_ ? O : /* @__PURE__ */ t(G, { id: R, duration: 300, height: o ? "auto" : 0, "data-testid": "collapse-inner", children: O }))
|
|
107
108
|
] });
|
|
108
109
|
};
|
|
109
110
|
export {
|
|
110
|
-
|
|
111
|
-
|
|
111
|
+
pe as Collapse,
|
|
112
|
+
pe as default
|
|
112
113
|
};
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export * from './table';
|
|
2
|
+
export * from './table-context';
|
|
3
|
+
export * from './use-table-persistence';
|
|
4
|
+
export * from './table-columns-menu/table-columns-menu';
|
|
5
|
+
export * from './table-header-button/table-header-button';
|
|
6
|
+
export * from './table-toolbar/table-toolbar';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=require("react/jsx-runtime"),x=require("../../../buttons/button/button.cjs.js"),m=require("../../../form/checkbox/checkbox.cjs.js"),j=require("../../../overlays/dropdown/dropdown.cjs.js"),q=require("../../../overlays/dropdown/dropdown-content/dropdown-content.cjs.js"),T=require("../../../overlays/dropdown/dropdown-item/dropdown-item.cjs.js"),f=require("../../../overlays/dropdown/dropdown-trigger/dropdown-trigger.cjs.js"),w=require("../table-context.cjs.js"),L=require("../../../../providers/label-provider/use-labels.cjs.js"),r=({triggerLabel:i,className:l})=>{const{table:d,id:c}=w.useTableContext(),{getLabel:a}=L.useLabels(),u=i??a("table.columns"),o=d.getAllLeafColumns().filter(e=>e.getCanHide()),b=o.filter(e=>e.getIsVisible()).length,g=e=>{const n=e.columnDef.header;return typeof n=="string"?n:e.id};return t.jsxs(j.Dropdown,{placement:"bottom-end",children:[t.jsx(f.DropdownTrigger,{children:t.jsx(x.Button,{type:"button",visualType:"neutral",iconLeft:"tune",className:l,children:u})}),t.jsx(q.DropdownContent,{children:o.map(e=>{const n=e.getIsVisible(),h=n&&b===1,s=`${c}-columns-menu-${e.id}`,p=g(e);return t.jsx(T.DropdownItem,{asChild:!0,closeOnSelect:!1,children:t.jsx("div",{onClick:C=>C.stopPropagation(),children:t.jsx(m.Checkbox,{id:s,name:s,label:p,value:e.id,checked:n,disabled:h,onChange:()=>e.toggleVisibility()})})},e.id)})})]})};r.displayName="Table.ColumnsMenu";exports.TableColumnsMenu=r;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export interface TableColumnsMenuProps {
|
|
2
|
+
/**
|
|
3
|
+
* Trigger label. Falls back to the localised `table.columns` label from
|
|
4
|
+
* `LabelProvider` when not provided.
|
|
5
|
+
*/
|
|
6
|
+
triggerLabel?: React.ReactNode;
|
|
7
|
+
/**
|
|
8
|
+
* Additional class name on the dropdown trigger button.
|
|
9
|
+
*/
|
|
10
|
+
className?: string;
|
|
11
|
+
}
|
|
12
|
+
export declare const TableColumnsMenu: {
|
|
13
|
+
({ triggerLabel, className }: TableColumnsMenuProps): import("react/jsx-runtime").JSX.Element;
|
|
14
|
+
displayName: string;
|
|
15
|
+
};
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { jsxs as h, jsx as t } from "react/jsx-runtime";
|
|
2
|
+
import { Button as g } from "../../../buttons/button/button.es.js";
|
|
3
|
+
import { Checkbox as C } from "../../../form/checkbox/checkbox.es.js";
|
|
4
|
+
import { Dropdown as L } from "../../../overlays/dropdown/dropdown.es.js";
|
|
5
|
+
import { DropdownContent as v } from "../../../overlays/dropdown/dropdown-content/dropdown-content.es.js";
|
|
6
|
+
import { DropdownItem as x } from "../../../overlays/dropdown/dropdown-item/dropdown-item.es.js";
|
|
7
|
+
import { DropdownTrigger as T } from "../../../overlays/dropdown/dropdown-trigger/dropdown-trigger.es.js";
|
|
8
|
+
import { useTableContext as y } from "../table-context.es.js";
|
|
9
|
+
import { useLabels as D } from "../../../../providers/label-provider/use-labels.es.js";
|
|
10
|
+
const V = ({ triggerLabel: n, className: s }) => {
|
|
11
|
+
const { table: l, id: a } = y(), { getLabel: d } = D(), m = n ?? d("table.columns"), i = l.getAllLeafColumns().filter((e) => e.getCanHide()), c = i.filter((e) => e.getIsVisible()).length, b = (e) => {
|
|
12
|
+
const o = e.columnDef.header;
|
|
13
|
+
return typeof o == "string" ? o : e.id;
|
|
14
|
+
};
|
|
15
|
+
return /* @__PURE__ */ h(L, { placement: "bottom-end", children: [
|
|
16
|
+
/* @__PURE__ */ t(T, { children: /* @__PURE__ */ t(g, { type: "button", visualType: "neutral", iconLeft: "tune", className: s, children: m }) }),
|
|
17
|
+
/* @__PURE__ */ t(v, { children: i.map((e) => {
|
|
18
|
+
const o = e.getIsVisible(), p = o && c === 1, r = `${a}-columns-menu-${e.id}`, u = b(e);
|
|
19
|
+
return /* @__PURE__ */ t(x, { asChild: !0, closeOnSelect: !1, children: /* @__PURE__ */ t("div", { onClick: (f) => f.stopPropagation(), children: /* @__PURE__ */ t(
|
|
20
|
+
C,
|
|
21
|
+
{
|
|
22
|
+
id: r,
|
|
23
|
+
name: r,
|
|
24
|
+
label: u,
|
|
25
|
+
value: e.id,
|
|
26
|
+
checked: o,
|
|
27
|
+
disabled: p,
|
|
28
|
+
onChange: () => e.toggleVisibility()
|
|
29
|
+
}
|
|
30
|
+
) }) }, e.id);
|
|
31
|
+
}) })
|
|
32
|
+
] });
|
|
33
|
+
};
|
|
34
|
+
V.displayName = "Table.ColumnsMenu";
|
|
35
|
+
export {
|
|
36
|
+
V as TableColumnsMenu
|
|
37
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=require("react"),n=t.createContext(null);function o(){const e=t.useContext(n);if(!e)throw new Error("TableContext missing — wrap the component in <Table>.");return e}exports.TableContext=n;exports.useTableContext=o;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { createContext as e, useContext as n } from "react";
|
|
2
|
+
const o = e(null);
|
|
3
|
+
function x() {
|
|
4
|
+
const t = n(o);
|
|
5
|
+
if (!t) throw new Error("TableContext missing — wrap the component in <Table>.");
|
|
6
|
+
return t;
|
|
7
|
+
}
|
|
8
|
+
export {
|
|
9
|
+
o as TableContext,
|
|
10
|
+
x as useTableContext
|
|
11
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const t=require("react/jsx-runtime"),m=require("../../../../../../external/classnames/index.cjs.js"),q=require("react"),h=require("../../../base/icon/icon.cjs.js"),a=require("./table-header-button.module.scss.cjs.js"),e=q.forwardRef(({icon:o,filled:r=!1,selected:u=!1,disabled:n,onClick:l,className:d,iconSize:s=18,type:i="button",children:c,...b},f)=>t.jsxs("button",{...b,ref:f,type:i,disabled:n,onClick:l,className:m.default(a.default["tedi-table-header-button"],{[a.default["tedi-table-header-button--selected"]]:u},d),children:[c,t.jsx(h.Icon,{name:o,filled:r,color:"inherit",size:s})]}));e.displayName="TableHeaderButton";exports.TableHeaderButton=e;exports.default=e;
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { default as React } from 'react';
|
|
2
|
+
import { IconSize } from '../../../base/icon/icon';
|
|
3
|
+
interface TableHeaderButtonBaseProps extends Omit<React.ButtonHTMLAttributes<HTMLButtonElement>, 'children' | 'aria-label'> {
|
|
4
|
+
/**
|
|
5
|
+
* Material icon name rendered inside the button (e.g. `unfold_more`,
|
|
6
|
+
* `arrow_downward`, `filter_alt`).
|
|
7
|
+
*/
|
|
8
|
+
icon: string;
|
|
9
|
+
/**
|
|
10
|
+
* Render the icon's "filled" variant. Pair with `selected` for a fully
|
|
11
|
+
* activated look (e.g. an applied filter).
|
|
12
|
+
* @default false
|
|
13
|
+
*/
|
|
14
|
+
filled?: boolean;
|
|
15
|
+
/**
|
|
16
|
+
* When `true`, the icon paints in the brand colour to indicate an active
|
|
17
|
+
* sort or filter at rest. Hover / focus / active states are still applied
|
|
18
|
+
* on top.
|
|
19
|
+
* @default false
|
|
20
|
+
*/
|
|
21
|
+
selected?: boolean;
|
|
22
|
+
/** Size of the icon, in pixels. @default 18 */
|
|
23
|
+
iconSize?: IconSize;
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* Accessibility-driven discriminated union enforcing WCAG SC 4.1.2 at compile
|
|
27
|
+
* time:
|
|
28
|
+
* - **Labelled** — `children` provide visible text (e.g. a sortable column
|
|
29
|
+
* header), which is the accessible name, so `aria-label` is optional.
|
|
30
|
+
* - **Icon-only** — no `children` (e.g. a filter trigger), so the button has
|
|
31
|
+
* nothing to announce; `aria-label` is required.
|
|
32
|
+
*/
|
|
33
|
+
type TableHeaderButtonLabelProps = {
|
|
34
|
+
/**
|
|
35
|
+
* Label rendered before the icon — the whole "text + icon" area becomes
|
|
36
|
+
* one clickable button (matching the Angular implementation).
|
|
37
|
+
*/
|
|
38
|
+
children: React.ReactNode;
|
|
39
|
+
/** Optional accessible name; the visible `children` already provide one. */
|
|
40
|
+
'aria-label'?: string;
|
|
41
|
+
} | {
|
|
42
|
+
children?: undefined;
|
|
43
|
+
/**
|
|
44
|
+
* Required accessible name — icon-only buttons have no visible text for
|
|
45
|
+
* screen readers to announce.
|
|
46
|
+
*/
|
|
47
|
+
'aria-label': string;
|
|
48
|
+
};
|
|
49
|
+
export type TableHeaderButtonProps = TableHeaderButtonBaseProps & TableHeaderButtonLabelProps;
|
|
50
|
+
export declare const TableHeaderButton: React.ForwardRefExoticComponent<TableHeaderButtonProps & React.RefAttributes<HTMLButtonElement>>;
|
|
51
|
+
export default TableHeaderButton;
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { jsxs as b, jsx as c } from "react/jsx-runtime";
|
|
2
|
+
import p from "../../../../../../external/classnames/index.es.js";
|
|
3
|
+
import { forwardRef as u } from "react";
|
|
4
|
+
import { Icon as h } from "../../../base/icon/icon.es.js";
|
|
5
|
+
import e from "./table-header-button.module.scss.es.js";
|
|
6
|
+
const x = u(
|
|
7
|
+
({
|
|
8
|
+
icon: t,
|
|
9
|
+
filled: o = !1,
|
|
10
|
+
selected: a = !1,
|
|
11
|
+
disabled: r,
|
|
12
|
+
onClick: s,
|
|
13
|
+
className: l,
|
|
14
|
+
iconSize: m = 18,
|
|
15
|
+
type: i = "button",
|
|
16
|
+
children: d,
|
|
17
|
+
...n
|
|
18
|
+
}, f) => /* @__PURE__ */ b(
|
|
19
|
+
"button",
|
|
20
|
+
{
|
|
21
|
+
...n,
|
|
22
|
+
ref: f,
|
|
23
|
+
type: i,
|
|
24
|
+
disabled: r,
|
|
25
|
+
onClick: s,
|
|
26
|
+
className: p(
|
|
27
|
+
e["tedi-table-header-button"],
|
|
28
|
+
{ [e["tedi-table-header-button--selected"]]: a },
|
|
29
|
+
l
|
|
30
|
+
),
|
|
31
|
+
children: [
|
|
32
|
+
d,
|
|
33
|
+
/* @__PURE__ */ c(h, { name: t, filled: o, color: "inherit", size: m })
|
|
34
|
+
]
|
|
35
|
+
}
|
|
36
|
+
)
|
|
37
|
+
);
|
|
38
|
+
x.displayName = "TableHeaderButton";
|
|
39
|
+
export {
|
|
40
|
+
x as TableHeaderButton,
|
|
41
|
+
x as default
|
|
42
|
+
};
|
package/src/tedi/components/content/table/table-header-button/table-header-button.module.scss.cjs.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e={"tedi-table-header-button":"tedi-table-header-button-b43c480a","tedi-table-header-button--selected":"tedi-table-header-button--selected-f428ec59"};exports.default=e;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const t=require("react/jsx-runtime"),o=require("../../../../../../external/classnames/index.cjs.js"),r=require("../table.module.scss.cjs.js"),e=({children:l,className:a})=>t.jsx("div",{className:o.default(r.default["tedi-table__toolbar"],a),children:l});e.displayName="Table.Toolbar";exports.TableToolbar=e;exports.default=e;
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { default as React } from 'react';
|
|
2
|
+
export interface TableToolbarProps {
|
|
3
|
+
/**
|
|
4
|
+
* Toolbar contents — typically Table sub-components like
|
|
5
|
+
* `<Table.ColumnsMenu />`, but any node is allowed.
|
|
6
|
+
*/
|
|
7
|
+
children?: React.ReactNode;
|
|
8
|
+
/**
|
|
9
|
+
* Additional class name on the toolbar wrapper.
|
|
10
|
+
*/
|
|
11
|
+
className?: string;
|
|
12
|
+
}
|
|
13
|
+
/**
|
|
14
|
+
* Optional slot rendered above the `<table>`. Hosts controls like
|
|
15
|
+
* `<Table.ColumnsMenu />`. Nothing clever — it just provides consistent spacing.
|
|
16
|
+
*/
|
|
17
|
+
export declare const TableToolbar: {
|
|
18
|
+
({ children, className }: TableToolbarProps): import("react/jsx-runtime").JSX.Element;
|
|
19
|
+
displayName: string;
|
|
20
|
+
};
|
|
21
|
+
export default TableToolbar;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { jsx as l } from "react/jsx-runtime";
|
|
2
|
+
import s from "../../../../../../external/classnames/index.es.js";
|
|
3
|
+
import e from "../table.module.scss.es.js";
|
|
4
|
+
const r = ({ children: a, className: o }) => /* @__PURE__ */ l("div", { className: s(e["tedi-table__toolbar"], o), children: a });
|
|
5
|
+
r.displayName = "Table.Toolbar";
|
|
6
|
+
export {
|
|
7
|
+
r as TableToolbar,
|
|
8
|
+
r as default
|
|
9
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const r=require("react/jsx-runtime"),ie=require("../../../../../external/@tanstack/react-table/build/lib/index.cjs.js"),I=require("../../../../../external/classnames/index.cjs.js"),i=require("react"),ft=require("../../base/icon/icon.cjs.js"),un=require("../../buttons/collapse/collapse.cjs.js"),gt=require("../../form/checkbox/checkbox.cjs.js"),gn=require("../../form/radio/radio.cjs.js"),fn=require("../../form/textfield/textfield.cjs.js"),o=require("./table.module.scss.cjs.js"),pn=require("./table-columns-menu/table-columns-menu.cjs.js"),mn=require("./table-context.cjs.js"),bn=require("./table-header-button/table-header-button.cjs.js"),hn=require("./table-toolbar/table-toolbar.cjs.js"),xn=require("./use-table-persistence.cjs.js"),wn=require("../../navigation/pagination/pagination.cjs.js"),Cn=require("../../../providers/label-provider/use-labels.cjs.js"),oe=require("../../../../../external/@tanstack/table-core/build/lib/index.cjs.js"),_n=(D,T)=>M=>{const v=M.index;if(v<0||v>=D.length)return 1;const N=T(D[v]);if(v>0&&T(D[v-1])===N)return 0;let E=1;for(let L=v+1;L<D.length&&T(D[L])===N;L++)E++;return E},pt="data-tedi-drag-handle",vn=({label:D,onHandlePointerDown:T,id:M,pickedUp:v,onKeyDown:N})=>r.jsx("button",{type:"button",id:M,className:I.default(o.default["tedi-table__drag-handle"],{[o.default["tedi-table__drag-handle--picked-up"]]:v}),"aria-label":D,"aria-pressed":v,onClick:E=>E.stopPropagation(),onMouseDown:T,onTouchStart:T,onKeyDown:N,[pt]:"",children:r.jsx(ft.Icon,{name:"drag_indicator",size:18,color:"inherit"})}),Sn=D=>{const{row:T,rowClassName:M,rowStyle:v,isActiveRow:N,clickable:E,onClick:L,onKeyDownHandler:_e,ariaRowIndex:ve,columnProps:Z,draggable:re,dragHandleLabel:se,dragHandlers:g,dragHandleId:Se,dragHandlePickedUp:Re,dragOverColumnId:de}=D;return r.jsx("tr",{className:M,style:v,draggable:re||void 0,onDragStart:g==null?void 0:g.onDragStart,onDragOver:g==null?void 0:g.onDragOver,onDragLeave:g==null?void 0:g.onDragLeave,onDragEnd:g==null?void 0:g.onDragEnd,onDrop:g==null?void 0:g.onDrop,onClick:E&&L?()=>L(T):void 0,onKeyDown:E?_e:void 0,tabIndex:E?0:void 0,role:E?"button":void 0,"aria-rowindex":ve,"aria-current":N?"true":void 0,children:T.getVisibleCells().map(O=>{var ce;const f=O.column.columnDef.meta,P=Z==null?void 0:Z(O.column.id),ee=re&&O.column.id===Ce,A=!!de&&O.column.id===de,B=(ce=f==null?void 0:f.rowSpan)==null?void 0:ce.call(f,O.row);return B===0?null:r.jsx("td",{rowSpan:B&&B>1?B:void 0,className:I.default(o.default["tedi-table__cell"],{[o.default[`tedi-table__cell--align-${f==null?void 0:f.align}`]]:f==null?void 0:f.align,[o.default[`tedi-table__cell--valign-${f==null?void 0:f.vAlign}`]]:f==null?void 0:f.vAlign,[o.default["tedi-table__cell--drag-handle"]]:ee,[o.default["tedi-table__cell--drag-over"]]:A},P==null?void 0:P.className),style:P==null?void 0:P.style,children:ee?r.jsx(vn,{label:se,onHandlePointerDown:(g==null?void 0:g.onHandlePointerDown)??(()=>{}),onKeyDown:g==null?void 0:g.onKeyDown,id:Se,pickedUp:Re}):ie.flexRender(O.column.columnDef.cell,O.getContext())},O.id)})})},Me="__select__",Be="__expand__",Ce="__drag__",ae=()=>!0,Rn={text:ae,select:ae,"multi-select":ae,"date-range":ae,"date-range-period":ae};function Dn(D){return Array.isArray(D.columns)}function mt(D){const{id:T,data:M,columns:v,size:N="medium",caption:E,state:L,defaultState:_e,onStateChange:ve,persist:Z,emptyState:re,emptyStateRole:se,className:g,children:Se,striped:Re=!1,verticalBorders:de=!1,borderless:O=!1,stickyFirstColumn:f=!1,stickyHeader:P=!1,maxHeight:ee,onRowClick:A,activeRowId:B,rowHover:ce,enableRowSelection:qe,selectionMode:De="multiple",highlightSelectedRows:ht=!0,enableColumnFilters:ye=!1,renderSubComponent:ue,getRowCanExpand:He,getSubRows:Ue,getRowId:xt,expandTrigger:ke="button",paginateExpandedRows:wt=!1,pagination:q,autoResetPageIndex:Ct=!0,manualPagination:U=!1,manualSorting:Ie=!1,manualFiltering:Te=!1,pageCount:Ke,rowCount:ge,checkboxProps:Ee,radioProps:Ve,collapseProps:Ge,rowProps:Ne,columnProps:H,reorderableRows:S=!1,onRowDrop:$,reorderableColumns:K=!1}=D,{getLabel:h}=Cn.useLabels(),We=re??h("table.no-data"),V=i.useRef(h);V.current=h;const _t=i.useId(),p=T??_t,x=i.useMemo(()=>q?q===!0?{pageSize:10,pageSizeOptions:[10,25,50],paginationProps:void 0}:{pageSize:q.pageSize??10,pageSizeOptions:q.pageSizeOptions===void 0?[10,25,50]:q.pageSizeOptions,paginationProps:q.paginationProps}:null,[q]),y=x!==null,vt=i.useMemo(()=>{const e=x==null?void 0:x.pageSizeOptions;return Array.isArray(e)&&e.length>0?e:void 0},[x]),[j,R]=xn.useTablePersistence({persist:Z,controlled:L,defaultState:_e,onStateChange:ve}),St=i.useCallback(e=>{R(n=>{const t=n.columnVisibility??{};return{columnVisibility:typeof e=="function"?e(t):e}})},[R]),Rt=i.useCallback(e=>{R(n=>{const t=n.rowSelection??{};return{rowSelection:typeof e=="function"?e(t):e}})},[R]),Dt=i.useCallback(e=>{R(n=>{const t=n.expanded??{};return{expanded:typeof e=="function"?e(t):e}})},[R]),yt=i.useCallback(e=>{R(n=>{const t=n.columnFilters??[];return{columnFilters:typeof e=="function"?e(t):e}})},[R]),kt=i.useCallback(e=>{R(n=>{const t=n.columnOrder??[];return{columnOrder:typeof e=="function"?e(t):e}})},[R]),It=i.useCallback(e=>{R(n=>{const t=n.sorting??[];return{sorting:typeof e=="function"?e(t):e}})},[R]),Tt=i.useCallback(e=>{R(n=>{const t=n.pagination??{pageIndex:0,pageSize:(x==null?void 0:x.pageSize)??10};return{pagination:typeof e=="function"?e(t):e}})},[R,x]),te=!!(ue||Ue),Xe=!!qe,Et=i.useMemo(()=>oe.getCoreRowModel(),[]),Nt=i.useMemo(()=>Te?void 0:oe.getFilteredRowModel(),[Te]),Ot=i.useMemo(()=>Ie?void 0:oe.getSortedRowModel(),[Ie]),$t=i.useMemo(()=>te?oe.getExpandedRowModel():void 0,[te]),jt=i.useMemo(()=>y&&!U?oe.getPaginationRowModel():void 0,[y,U]),Lt=i.useMemo(()=>{const e=[];if(S&&e.push({id:Ce,enableSorting:!1,enableHiding:!1,enableColumnFilter:!1,size:40,header:"",cell:()=>null}),Xe){const n=De==="single",t=`${p}-select`;e.push({id:Me,enableSorting:!1,enableHiding:!1,enableColumnFilter:!1,size:40,header:n?"":({table:l})=>r.jsx(gt.Checkbox,{...Ee,id:`${p}-select-all`,name:`${p}-select-all`,label:V.current("table.select-all",l.getIsAllPageRowsSelected()),hideLabel:!0,value:"all",checked:l.getIsAllPageRowsSelected(),indeterminate:l.getIsSomePageRowsSelected()&&!l.getIsAllPageRowsSelected(),onChange:(a,s)=>l.toggleAllPageRowsSelected(s)}),cell:({row:l})=>n?r.jsx(gn.Radio,{...Ve,id:`${p}-select-${l.id}`,name:t,label:V.current("table.select-row",l.getIsSelected()),hideLabel:!0,value:l.id,checked:l.getIsSelected(),disabled:!l.getCanSelect(),onChange:(a,s)=>{s&&l.toggleSelected(!0)}}):r.jsx(gt.Checkbox,{...Ee,id:`${p}-select-${l.id}`,name:`${p}-select-${l.id}`,label:V.current("table.select-row",l.getIsSelected()),hideLabel:!0,value:l.id,checked:l.getIsSelected(),disabled:!l.getCanSelect(),indeterminate:l.getIsSomeSelected(),onChange:(a,s)=>l.toggleSelected(s)})})}return te&&e.push({id:Be,enableSorting:!1,enableHiding:!1,enableColumnFilter:!1,size:40,header:"",cell:({row:n})=>{if(!n.getCanExpand())return null;const t=`${p}-sub-${n.id}`;return r.jsx("span",{onClick:l=>l.stopPropagation(),onKeyDown:l=>{(l.key==="Enter"||l.key===" ")&&l.stopPropagation()},children:r.jsx(un.Collapse,{iconOnly:!0,arrowType:ke==="row"?"default":"secondary",hideCollapseText:!0,...Ge,id:`${p}-expand-${n.id}`,controlsId:t,openText:V.current("table.expand-row"),closeText:V.current("table.collapse-row"),open:n.getIsExpanded(),onToggle:()=>n.toggleExpanded(),children:null})})}}),[...e,...v]},[v,Xe,De,te,ke,S,p,Ee,Ve,Ge]),Pt=i.useMemo(()=>({}),[]),At=i.useMemo(()=>({}),[]),Ft=i.useMemo(()=>[],[]),zt=i.useMemo(()=>[],[]),Mt=i.useMemo(()=>[],[]),Bt=i.useMemo(()=>({pageIndex:0,pageSize:(x==null?void 0:x.pageSize)??10}),[x]),c=ie.useReactTable({data:M,columns:Lt,state:{columnVisibility:j.columnVisibility,columnOrder:j.columnOrder??zt,rowSelection:j.rowSelection??Pt,expanded:j.expanded??At,columnFilters:j.columnFilters??Ft,sorting:j.sorting??Mt,pagination:y?j.pagination??Bt:void 0},enableRowSelection:qe,enableMultiRowSelection:De!=="single",enableColumnFilters:ye,autoResetPageIndex:Ct,paginateExpandedRows:y&&!U?wt:!0,manualPagination:U,manualSorting:Ie,manualFiltering:Te,pageCount:U&&Ke!==void 0?Ke:void 0,rowCount:U&&ge!==void 0?ge:void 0,getRowCanExpand:ue?He??(()=>!0):He,getSubRows:Ue,getRowId:xt,onColumnVisibilityChange:St,onColumnOrderChange:kt,onRowSelectionChange:Rt,onExpandedChange:Dt,onColumnFiltersChange:yt,onSortingChange:It,onPaginationChange:y?Tt:void 0,filterFns:Rn,getCoreRowModel:Et,getFilteredRowModel:Nt,getExpandedRowModel:$t,getSortedRowModel:Ot,getPaginationRowModel:jt}),qt=i.useMemo(()=>({table:c,size:N,id:p,state:j}),[c,N,p,j]),Ht=i.useCallback(e=>c.setPageIndex(e-1),[c]),Ut=i.useCallback(e=>c.setPageSize(e),[c]),Kt=c.getHeaderGroups().length>1,fe=ke==="row"&&te,Vt=ce??(!!A||fe),Gt=I.default(o.default["tedi-table"],o.default[`tedi-table--${N}`],{[o.default["tedi-table--striped"]]:Re,[o.default["tedi-table--vertical-borders"]]:de,[o.default["tedi-table--borderless"]]:O,[o.default["tedi-table--sticky-first-column"]]:f,[o.default["tedi-table--sticky-header"]]:P,[o.default["tedi-table--clickable-rows"]]:!!A||fe,[o.default["tedi-table--row-hover"]]:Vt,[o.default["tedi-table--has-pagination"]]:y,[o.default["tedi-table--grouped-headers"]]:Kt},g),w=c.getRowModel().rows,pe=c.getHeaderGroups(),Ye=c.getFooterGroups(),Je=c.getVisibleLeafColumns(),me=Je.length,Wt=Ye.some(e=>e.headers.some(n=>n.column.columnDef.footer!==void 0)),Qe=e=>!!A||fe&&e.getCanExpand(),Ze=e=>{fe&&e.getCanExpand()&&e.toggleExpanded(),A==null||A(e)},Xt=e=>n=>{Qe(e)&&n.target===n.currentTarget&&(n.key==="Enter"||n.key===" ")&&(n.preventDefault(),Ze(e))},et=pe.length+(ye?1:0),tt=c.getState().pagination,Yt=y?tt.pageIndex*tt.pageSize:0,Jt=y?ge??c.getFilteredRowModel().rows.length:w.length,Qt=y?et+Jt:void 0,[nt,Oe]=i.useState(null),[Zt,be]=i.useState(null),G=i.useRef(null),W=i.useRef(null),[lt,$e]=i.useState(null),[ot,he]=i.useState(null),X=i.useRef(null),Y=i.useRef(null),[at,je]=i.useState(null),xe=i.useRef([]),[it,Le]=i.useState(null),ne=i.useRef(-1),[en,F]=i.useState(""),we=i.useRef(null),[tn,rt]=i.useState(0),Pe=i.useMemo(()=>S?new Map(w.map(e=>[e.id,e.index])):new Map,[S,w]);i.useEffect(()=>{if(!S&&!K)return;const e=()=>{W.current=null,Y.current=null};return window.addEventListener("mouseup",e),window.addEventListener("touchend",e),()=>{window.removeEventListener("mouseup",e),window.removeEventListener("touchend",e)}},[S,K]);const nn=i.useCallback(e=>({onHandlePointerDown:()=>{W.current=e},onDragStart:n=>{if(W.current!==e){n.preventDefault();return}W.current=null,n.dataTransfer.effectAllowed="move";try{n.dataTransfer.setData("text/plain",e)}catch{}const t=n.currentTarget,l=t.closest("table");if(l){const a=t.getBoundingClientRect(),s=Array.from(t.children),u=document.createElement("div");u.style.cssText=`position:fixed;top:-10000px;left:0;width:${a.width}px;pointer-events:none;`;const b=document.createElement("table");b.className=l.className,b.style.cssText=`width:${a.width}px;table-layout:fixed;border-collapse:collapse;`;const C=document.createElement("tbody"),_=t.cloneNode(!0);_.classList.add(o.default["tedi-table__row--drag-preview"]);const d=Array.from(_.children);s.forEach((J,k)=>{const z=d[k];if(!z)return;const le=J.getBoundingClientRect();z.style.width=`${le.width}px`,z.style.minWidth=`${le.width}px`,z.style.maxWidth=`${le.width}px`}),C.appendChild(_),b.appendChild(C),u.appendChild(b),document.body.appendChild(u),n.dataTransfer.setDragImage(u,24,a.height/2),window.setTimeout(()=>u.remove(),0)}G.current=e,Oe(e)},onDragOver:n=>{!G.current||G.current===e||(n.preventDefault(),n.dataTransfer.dropEffect="move",be(e))},onDragLeave:()=>{be(n=>n===e?null:n)},onDragEnd:()=>{G.current=null,W.current=null,Oe(null),be(null)},onDrop:n=>{n.preventDefault();const t=G.current,l=e;if(G.current=null,W.current=null,Oe(null),be(null),!t||t===l)return;const a=Pe.get(t),s=Pe.get(l);a===void 0||s===void 0||$==null||$({fromId:t,toId:l,fromIndex:a,toIndex:s})}}),[Pe,$]),st=(e,n,t)=>{const l=e.slice(),[a]=l.splice(n,1);return l.splice(t,0,a),l},ln=i.useCallback(e=>({onHandlePointerDown:()=>{Y.current=e},onDragStart:n=>{if(Y.current!==e){n.preventDefault();return}Y.current=null,n.dataTransfer.effectAllowed="move";try{n.dataTransfer.setData("text/plain",e)}catch{}const t=n.currentTarget,l=t.getBoundingClientRect(),a=document.createElement("div");a.style.cssText=`position:fixed;top:-10000px;left:0;width:${l.width}px;pointer-events:none;`;const s=document.createElement("table"),u=t.closest("table");s.className=(u==null?void 0:u.className)??"",s.style.cssText=`width:${l.width}px;table-layout:fixed;border-collapse:collapse;`;const b=document.createElement("thead"),C=document.createElement("tr");C.className=o.default["tedi-table__row"];const _=t.cloneNode(!0);_.classList.add(o.default["tedi-table__header-cell--drag-preview"]),_.style.width=`${l.width}px`,C.appendChild(_),b.appendChild(C),s.appendChild(b),a.appendChild(s),document.body.appendChild(a),n.dataTransfer.setDragImage(a,l.width/2,l.height/2),window.setTimeout(()=>a.remove(),0),X.current=e,$e(e)},onDragOver:n=>{!X.current||X.current===e||(n.preventDefault(),n.dataTransfer.dropEffect="move",he(e))},onDragLeave:()=>{he(n=>n===e?null:n)},onDragEnd:()=>{X.current=null,Y.current=null,$e(null),he(null)},onDrop:n=>{n.preventDefault();const t=X.current,l=e;if(X.current=null,Y.current=null,$e(null),he(null),!t||t===l)return;const a=c.getState().columnOrder,s=a.length>0?a:c.getAllLeafColumns().map(C=>C.id),u=s.indexOf(t),b=s.indexOf(l);u<0||b<0||c.setColumnOrder(st(s,u,b))}}),[c]),on=e=>`${p}-col-reorder-${e}`,an=e=>`${p}-row-reorder-${e}`,dt=()=>c.getVisibleLeafColumns().filter(e=>!e.parent&&e.id!==Ce&&e.id!==Me&&e.id!==Be).map(e=>e.id),Ae=e=>{const n=c.getColumn(e),t=n==null?void 0:n.columnDef.meta;return(t==null?void 0:t.label)??(typeof(n==null?void 0:n.columnDef.header)=="string"?n.columnDef.header:e)},ct=(e,n)=>{const t=dt(),l=t.indexOf(n);if(l<0)return;const a=l+e;if(a<0||a>=t.length)return;const s=st(t,l,a),u=c.getState().columnOrder.length>0?[...c.getState().columnOrder]:c.getAllLeafColumns().map(d=>d.id),b=new Set(t);let C=0;const _=u.map(d=>b.has(d)?s[C++]:d);for(const d of s)_.includes(d)||_.push(d);c.setColumnOrder(_),F(h("table.reorder.move",Ae(n),a+1)),we.current={kind:"column",id:n},rt(d=>d+1)},rn=(e,n)=>{if(!K)return;const t=at;switch(e.key){case" ":case"Enter":if(e.preventDefault(),t===null)xe.current=[...c.getState().columnOrder??[]],je(n),F(h("table.reorder.pickup",Ae(n)));else{const l=dt().indexOf(t)+1;je(null),xe.current=[],F(h("table.reorder.drop",Ae(t),l))}break;case"Escape":t!==null&&(e.preventDefault(),c.setColumnOrder(xe.current),je(null),xe.current=[],F(h("table.reorder.cancel")));break;case"ArrowLeft":t!==null&&(e.preventDefault(),ct(-1,t));break;case"ArrowRight":t!==null&&(e.preventDefault(),ct(1,t));break}},ut=(e,n)=>{const t=w.findIndex(u=>u.original===n);if(t<0)return;const l=t+e;if(l<0||l>=w.length)return;const a=w[t],s=w[l];$==null||$({fromId:a.id,toId:s.id,fromIndex:a.index,toIndex:s.index}),F(h("table.row-reorder.move",l+1)),we.current={kind:"row",original:n},rt(u=>u+1)},sn=(e,n)=>{if(!S)return;const t=it;switch(e.key){case" ":case"Enter":if(e.preventDefault(),t===null)Le(n.original),ne.current=n.index,F(h("table.row-reorder.pickup",w.indexOf(n)+1));else{const l=w.findIndex(a=>a.original===t)+1;Le(null),ne.current=-1,F(h("table.row-reorder.drop",l))}break;case"Escape":if(t!==null){e.preventDefault();const l=w.findIndex(a=>a.original===t);if(l>=0&&ne.current>=0){const a=w[l];$==null||$({fromId:a.id,toId:a.id,fromIndex:a.index,toIndex:ne.current})}Le(null),ne.current=-1,F(h("table.row-reorder.cancel"))}break;case"ArrowUp":t!==null&&(e.preventDefault(),ut(-1,t));break;case"ArrowDown":t!==null&&(e.preventDefault(),ut(1,t));break}};return i.useEffect(()=>{var t;const e=we.current;if(!e)return;we.current=null;let n;if(e.kind==="column")n=`${p}-col-reorder-${e.id}`;else{const l=w.find(a=>a.original===e.original);n=l?`${p}-row-reorder-${l.id}`:null}n&&((t=document.getElementById(n))==null||t.focus())},[tn,w,p]),r.jsx(mn.TableContext.Provider,{value:qt,children:r.jsxs("div",{className:Gt,"data-name":"tedi-table",children:[Se,(S||K)&&r.jsx("div",{className:o.default["tedi-table__sr-only"],"aria-live":"polite","aria-atomic":"true",children:en}),r.jsx("div",{className:o.default["tedi-table__scroll"],style:ee!==void 0?{maxHeight:ee,overflowY:"auto"}:void 0,children:r.jsxs("table",{id:T,className:o.default["tedi-table__table"],"aria-rowcount":Qt,"aria-colcount":me>0?me:void 0,children:[E&&r.jsx("caption",{className:o.default["tedi-table__caption"],children:E}),r.jsxs("thead",{className:o.default["tedi-table__head"],children:[pe.map((e,n)=>r.jsx("tr",{className:o.default["tedi-table__row"],"aria-rowindex":y?n+1:void 0,children:e.headers.map(t=>{const l=t.subHeaders.length>0,a=!!t.column.parent,s=Dn(t.column.columnDef),u=!s&&!a;if(t.isPlaceholder&&!u||!t.isPlaceholder&&u&&n>0)return null;const b=u?pe.length-n:1,C=t.column.getIsSorted(),_=t.column.getCanSort()?C==="asc"?"ascending":C==="desc"?"descending":"none":void 0,d=t.column.columnDef.meta,J=(d==null?void 0:d.label)??(typeof t.column.columnDef.header=="string"?t.column.columnDef.header:void 0),k=H==null?void 0:H(t.column.id),z=t.column.getSize(),le=t.column.id===Ce||t.column.id===Me||t.column.id===Be,Q=K&&u&&!le,m=Q?ln(t.column.id):void 0,dn=Q&<===t.column.id,cn=Q&&ot===t.column.id&<!==t.column.id,Fe=Q&&at===t.column.id;return r.jsx("th",{colSpan:t.colSpan,rowSpan:b>1?b:void 0,draggable:Q||void 0,onDragStart:m==null?void 0:m.onDragStart,onDragOver:m==null?void 0:m.onDragOver,onDragLeave:m==null?void 0:m.onDragLeave,onDragEnd:m==null?void 0:m.onDragEnd,onDrop:m==null?void 0:m.onDrop,className:I.default(o.default["tedi-table__header-cell"],{[o.default["tedi-table__header-cell--group"]]:l,[o.default["tedi-table__header-cell--dragging"]]:dn,[o.default["tedi-table__header-cell--drag-over"]]:cn,[o.default["tedi-table__header-cell--picked-up"]]:Fe,[o.default[`tedi-table__cell--align-${d==null?void 0:d.align}`]]:d==null?void 0:d.align,[o.default[`tedi-table__cell--valign-${d==null?void 0:d.vAlign}`]]:d==null?void 0:d.vAlign},k==null?void 0:k.className),scope:"col","aria-sort":_,"aria-label":J??(s?void 0:t.column.id),style:z||k!=null&&k.style?{...z?{width:z}:null,...k==null?void 0:k.style}:void 0,children:Q&&m?r.jsxs("span",{className:o.default["tedi-table__header-cell-inner"],children:[r.jsx("button",{type:"button",id:on(t.column.id),className:I.default(o.default["tedi-table__drag-handle"],{[o.default["tedi-table__drag-handle--picked-up"]]:Fe}),"aria-label":h("table.drag-column",J??t.column.id),"aria-pressed":Fe,onClick:ze=>ze.stopPropagation(),onMouseDown:m.onHandlePointerDown,onTouchStart:m.onHandlePointerDown,onKeyDown:ze=>rn(ze,t.column.id),[pt]:"",children:r.jsx(ft.Icon,{name:"drag_indicator",size:18,color:"inherit"})}),ie.flexRender(t.column.columnDef.header,t.getContext())]}):ie.flexRender(t.column.columnDef.header,t.getContext())},t.id)})},e.id)),ye&&r.jsx("tr",{className:I.default(o.default["tedi-table__row"],o.default["tedi-table__row--filter"]),"aria-rowindex":y?pe.length+1:void 0,children:Je.map(e=>{const n=e.columnDef.meta,t=(n==null?void 0:n.label)??(typeof e.columnDef.header=="string"?e.columnDef.header:e.id),l=`${p}-filter-${e.id}`,a=H==null?void 0:H(e.id);return r.jsx("th",{className:I.default(o.default["tedi-table__header-cell"],a==null?void 0:a.className),style:a==null?void 0:a.style,scope:"col",children:e.getCanFilter()&&r.jsx(fn.TextField,{size:"small",placeholder:h("table.filter-placeholder"),...n==null?void 0:n.filterProps,id:l,name:l,label:h("table.filter-input",t),hideLabel:!0,value:e.getFilterValue()??"",onChange:s=>e.setFilterValue(s||void 0)})},e.id)})})]}),r.jsx("tbody",{className:o.default["tedi-table__body"],children:w.length===0?r.jsx("tr",{className:o.default["tedi-table__row"],children:r.jsx("td",{colSpan:Math.max(1,me),className:I.default(o.default["tedi-table__cell"],o.default["tedi-table__cell--placeholder"]),children:se?r.jsx("div",{role:se,children:We}):We})}):w.map((e,n)=>{const t=Qe(e),l=B!==void 0&&e.id===B,a=Ne==null?void 0:Ne(e),s=I.default(o.default["tedi-table__row"],{[o.default["tedi-table__row--selected"]]:ht&&e.getIsSelected(),[o.default["tedi-table__row--active"]]:l,[o.default["tedi-table__row--clickable"]]:t,[o.default["tedi-table__row--sub-row"]]:e.depth>0},a==null?void 0:a.className),u=y?et+Yt+n+1:void 0,b=`${p}-sub-${e.id}`,C=S&&nt===e.id,_=S&&Zt===e.id&&nt!==e.id,d=S&&it===e.original,J={row:e,rowClassName:I.default(s,{[o.default["tedi-table__row--dragging"]]:C,[o.default["tedi-table__row--drag-over"]]:_,[o.default["tedi-table__row--picked-up"]]:d}),rowStyle:a==null?void 0:a.style,isActiveRow:l,clickable:t,onClick:Ze,onKeyDownHandler:Xt(e),ariaRowIndex:u,columnProps:H,draggable:S,dragHandleLabel:h("table.drag-row"),dragHandlers:S?{...nn(e.id),onKeyDown:k=>sn(k,e)}:void 0,dragHandleId:S?an(e.id):void 0,dragHandlePickedUp:d,dragOverColumnId:K?ot:null};return r.jsxs(i.Fragment,{children:[r.jsx(Sn,{...J}),ue&&e.getIsExpanded()&&r.jsx("tr",{className:I.default(o.default["tedi-table__row"],o.default["tedi-table__row--sub-component"]),children:r.jsx("td",{id:b,role:"region","aria-label":h("table.row-details"),colSpan:Math.max(1,me),className:I.default(o.default["tedi-table__cell"],o.default["tedi-table__cell--sub-component"]),children:ue(e)})})]},e.id)})}),Wt&&r.jsx("tfoot",{className:o.default["tedi-table__foot"],children:Ye.map(e=>r.jsx("tr",{className:o.default["tedi-table__row"],children:e.headers.map(n=>{const t=n.column.columnDef.meta;return r.jsx("td",{colSpan:n.colSpan,className:I.default(o.default["tedi-table__cell"],o.default["tedi-table__cell--footer"],{[o.default[`tedi-table__cell--align-${t==null?void 0:t.align}`]]:t==null?void 0:t.align,[o.default[`tedi-table__cell--valign-${t==null?void 0:t.vAlign}`]]:t==null?void 0:t.vAlign}),children:n.isPlaceholder?null:ie.flexRender(n.column.columnDef.footer,n.getContext())},n.id)})},e.id))})]})}),y&&r.jsx("div",{className:o.default["tedi-table__pagination"],children:r.jsx(wn.Pagination,{...x==null?void 0:x.paginationProps,pageCount:Math.max(1,c.getPageCount()),page:c.getState().pagination.pageIndex+1,onPageChange:Ht,totalItems:ge??c.getFilteredRowModel().rows.length,pageSize:c.getState().pagination.pageSize,pageSizeOptions:vt,onPageSizeChange:Ut})})]})})}mt.displayName="Table";const bt=Object.assign(mt,{Toolbar:hn.TableToolbar,ColumnsMenu:pn.TableColumnsMenu,HeaderButton:bn.TableHeaderButton});exports.Table=bt;exports.default=bt;exports.groupRowSpan=_n;
|