tgui-core 1.5.6 → 1.6.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,43 +1,45 @@
1
- import { jsx as m } from "react/jsx-runtime";
2
- import { classes as l } from "../common/react.js";
3
- import { computeBoxProps as p, computeBoxClassName as u } from "../common/ui.js";
1
+ import { jsx as l } from "react/jsx-runtime";
2
+ import { classes as p } from "../common/react.js";
3
+ import { computeBoxProps as u, computeBoxClassName as N } from "../common/ui.js";
4
4
  const f = /-o$/;
5
- function d(c) {
6
- const { name: s = "", size: o, spin: a, className: N, rotation: r, ...e } = c, n = e.style || {};
7
- o && (n.fontSize = `${o * 100}%`), r && (n.transform = `rotate(${r}deg)`), e.style = n;
8
- const x = p(e);
5
+ function m(o) {
6
+ const { name: s = "", size: a, spin: e, className: x, rotation: r, ...c } = o, n = c.style || {};
7
+ a && (n.fontSize = `${a * 100}%`), r && (n.transform = `rotate(${r}deg)`), c.style = n;
8
+ const I = u(c);
9
9
  let t = "";
10
10
  if (s.startsWith("tg-"))
11
11
  t = s;
12
12
  else {
13
- const I = f.test(s), i = s.replace(f, ""), S = !i.startsWith("fa-");
14
- t = I ? "far " : "fas ", S && (t += "fa-"), t += i, a && (t += " fa-spin");
13
+ const S = f.test(s), i = s.replace(f, ""), d = !i.startsWith("fa-");
14
+ t = S ? "far " : "fas ", d && (t += "fa-"), t += i, e && (t += " fa-spin");
15
15
  }
16
- return /* @__PURE__ */ m(
16
+ return /* @__PURE__ */ l(
17
17
  "i",
18
18
  {
19
- className: l([
19
+ className: p([
20
20
  "Icon",
21
21
  t,
22
- N,
23
- u(e)
22
+ x,
23
+ N(c)
24
24
  ]),
25
- ...x
25
+ ...I
26
26
  }
27
27
  );
28
28
  }
29
- function g(c) {
30
- const { className: s, children: o, ...a } = c;
31
- return /* @__PURE__ */ m(
29
+ function g(o) {
30
+ const { className: s, children: a, ...e } = o;
31
+ return /* @__PURE__ */ l(
32
32
  "span",
33
33
  {
34
- className: l(["IconStack", s, u(a)]),
35
- ...p(a),
36
- children: o
34
+ className: p(["IconStack", s, N(e)]),
35
+ ...u(e),
36
+ children: a
37
37
  }
38
38
  );
39
39
  }
40
- d.Stack = g;
40
+ ((o) => {
41
+ o.Stack = g;
42
+ })(m || (m = {}));
41
43
  export {
42
- d as Icon
44
+ m as Icon
43
45
  };
@@ -2,6 +2,7 @@ import { Placement } from '@popperjs/core';
2
2
  import { ReactNode } from 'react';
3
3
  import { BooleanLike } from '../common/react';
4
4
  import { BoxProps } from './Box';
5
+ import { Direction } from './DmIcon';
5
6
  type Props = Partial<{
6
7
  /** Asset cache. Example: `asset={['assetname32x32', thing.key]}` */
7
8
  asset: string[];
@@ -15,11 +16,11 @@ type Props = Partial<{
15
16
  */
16
17
  buttons: ReactNode;
17
18
  /**
18
- * Enables alternate layout for `buttons` container.
19
- * Without fluid, buttons will be on top and with `pointer-events: none`, useful for text info.
20
- * With fluid, buttons will be in "hamburger" style.
19
+ * Same as buttons, but. Have disabled pointer-events on content inside if non-fluid.
20
+ * Fluid version have humburger layout.
21
+ * Can be used with buttons prop.
21
22
  */
22
- buttonsAlt: boolean;
23
+ buttonsAlt: ReactNode;
23
24
  /** Content under image. Or on the right if fluid. */
24
25
  children: ReactNode;
25
26
  /** Applies a CSS class to the element. */
@@ -38,6 +39,8 @@ type Props = Partial<{
38
39
  dmIcon: string | null;
39
40
  /** Parameter `icon_state` of component `DmIcon`. */
40
41
  dmIconState: string | null;
42
+ /** Parameter `direction` of component `DmIcon`. */
43
+ dmDirection: Direction;
41
44
  /**
42
45
  * Changes the layout of the button, making it fill the entire horizontally available space.
43
46
  * Allows the use of `title`
@@ -45,7 +48,7 @@ type Props = Partial<{
45
48
  fluid: boolean;
46
49
  /** Parameter responsible for the size of the image, component and standard "stubs". */
47
50
  imageSize: number;
48
- /** Prop `src` of Image component. Example: `imageSrc={resolveAsset(thing.image}` */
51
+ /** Prop `src` of Image component. Example: `imageSrc={resolveAsset(thing.image)}` */
49
52
  imageSrc: string;
50
53
  /** Called when button is clicked with LMB. */
51
54
  onClick: (e: any) => void;
@@ -60,5 +63,11 @@ type Props = Partial<{
60
63
  /** Position of the tooltip. See [`Popper`](#Popper) for valid options. */
61
64
  tooltipPosition: Placement;
62
65
  }> & BoxProps;
66
+ /**
67
+ * Stylized button, with the ability to easily and simply insert any picture into it.
68
+ * - Without image, will be default question icon.
69
+ * - If an image is specified but for some reason cannot be displayed, there will be a spinner fallback until it is loaded.
70
+ * - Component has no **hover** effects, if `onClick` or `onRightClick` is not specified.
71
+ */
63
72
  export declare function ImageButton(props: Props): import("react/jsx-runtime").JSX.Element;
64
73
  export {};
@@ -1,135 +1,151 @@
1
- import { jsxs as g, jsx as t } from "react/jsx-runtime";
1
+ import { jsxs as I, jsx as t } from "react/jsx-runtime";
2
2
  import { classes as l } from "../common/react.js";
3
- import { computeBoxProps as A } from "../common/ui.js";
4
- import { DmIcon as D } from "./DmIcon.js";
5
- import { Icon as F } from "./Icon.js";
6
- import { Image as j } from "./Image.js";
7
- import { Stack as y } from "./Stack.js";
8
- import { Tooltip as z } from "./Tooltip.js";
9
- function H(N) {
3
+ import { computeBoxProps as S } from "../common/ui.js";
4
+ import { DmIcon as z } from "./DmIcon.js";
5
+ import { Icon as A } from "./Icon.js";
6
+ import { Image as D } from "./Image.js";
7
+ import { Stack as $ } from "./Stack.js";
8
+ import { Tooltip as E } from "./Tooltip.js";
9
+ function W(d) {
10
10
  const {
11
- asset: f,
12
- base64: r,
13
- buttons: m,
14
- buttonsAlt: h,
15
- children: i,
16
- className: k,
17
- color: e,
18
- disabled: a,
19
- dmFallback: I,
11
+ asset: u,
12
+ base64: c,
13
+ buttons: i,
14
+ buttonsAlt: p,
15
+ children: a,
16
+ className: N,
17
+ color: o,
18
+ disabled: r,
19
+ dmFallback: k,
20
20
  dmIcon: b,
21
21
  dmIconState: x,
22
- fluid: c,
23
- imageSize: o = 64,
24
- imageSrc: d,
25
- onClick: s,
26
- onRightClick: u,
27
- selected: B,
28
- title: C,
22
+ fluid: e,
23
+ imageSize: n = 64,
24
+ imageSrc: g,
25
+ onClick: m,
26
+ onRightClick: f,
27
+ selected: C,
28
+ title: B,
29
29
  tooltip: _,
30
30
  tooltipPosition: w,
31
31
  ...v
32
- } = N;
33
- function $(n, S) {
34
- return /* @__PURE__ */ t(y, { height: `${o}px`, width: `${o}px`, children: /* @__PURE__ */ t(y.Item, { grow: !0, textAlign: "center", align: "center", children: /* @__PURE__ */ t(
35
- F,
36
- {
37
- spin: S,
38
- name: n,
39
- color: "gray",
40
- style: { fontSize: `calc(${o}px * 0.75)` }
41
- }
42
- ) }) });
43
- }
44
- let p = /* @__PURE__ */ g(
32
+ } = d;
33
+ let h = /* @__PURE__ */ I(
45
34
  "div",
46
35
  {
47
36
  className: l([
48
37
  "container",
49
- m && "hasButtons",
50
- !s && !u && "noAction",
51
- B && "ImageButton--selected",
52
- a && "ImageButton--disabled",
53
- e && typeof e == "string" ? `ImageButton--color__${e}` : "ImageButton--color__default"
38
+ i || e && p && "hasButtons",
39
+ !m && !f && "noAction",
40
+ C && "ImageButton--selected",
41
+ r && "ImageButton--disabled",
42
+ o && typeof o == "string" ? `ImageButton--color__${o}` : "ImageButton--color__default"
54
43
  ]),
55
- tabIndex: a ? void 0 : 0,
56
- onClick: (n) => {
57
- !a && s && s(n);
44
+ tabIndex: r ? void 0 : 0,
45
+ onClick: (s) => {
46
+ !r && m && m(s);
58
47
  },
59
- onKeyDown: (n) => {
60
- n.key === "Enter" && !a && s && s(n);
48
+ onKeyDown: (s) => {
49
+ s.key === "Enter" && !r && m && m(s);
61
50
  },
62
- onContextMenu: (n) => {
63
- n.preventDefault(), !a && u && u(n);
51
+ onContextMenu: (s) => {
52
+ s.preventDefault(), !r && f && f(s);
64
53
  },
65
- style: { width: c ? "auto" : `calc(${o}px + 0.5em + 2px)` },
54
+ style: { width: e ? "auto" : `calc(${n}px + 0.5em + 2px)` },
66
55
  children: [
67
- /* @__PURE__ */ t("div", { className: "image", children: r || f || d ? /* @__PURE__ */ t(
68
- j,
56
+ /* @__PURE__ */ t("div", { className: "image", children: c || u || g ? /* @__PURE__ */ t(
57
+ D,
69
58
  {
70
- className: l(!r && !d && f || []),
71
- src: r ? `data:image/png;base64,${r}` : d,
72
- height: `${o}px`,
73
- width: `${o}px`
59
+ className: l(!c && !g && u || []),
60
+ src: c ? `data:image/png;base64,${c}` : g,
61
+ height: `${n}px`,
62
+ width: `${n}px`
74
63
  }
75
64
  ) : b && x ? /* @__PURE__ */ t(
76
- D,
65
+ z,
77
66
  {
78
67
  icon: b,
79
68
  icon_state: x,
80
- fallback: I || $("spinner", !0),
81
- height: `${o}px`,
82
- width: `${o}px`
69
+ fallback: k || /* @__PURE__ */ t(y, { icon: "spinner", spin: !0, size: n }),
70
+ height: `${n}px`,
71
+ width: `${n}px`
83
72
  }
84
- ) : $("question", !1) }),
85
- c ? /* @__PURE__ */ g("div", { className: "info", children: [
86
- C && /* @__PURE__ */ t("span", { className: l(["title", i && "divider"]), children: C }),
87
- i && /* @__PURE__ */ t("span", { className: "contentFluid", children: i })
88
- ] }) : i && /* @__PURE__ */ t(
73
+ ) : /* @__PURE__ */ t(y, { icon: "question" }) }),
74
+ e ? /* @__PURE__ */ I("div", { className: "info", children: [
75
+ B && /* @__PURE__ */ t("span", { className: l(["title", a && "divider"]), children: B }),
76
+ a && /* @__PURE__ */ t("span", { className: "contentFluid", children: a })
77
+ ] }) : a && /* @__PURE__ */ t(
89
78
  "span",
90
79
  {
91
80
  className: l([
92
81
  "content",
93
- B && "ImageButton--contentSelected",
94
- a && "ImageButton--contentDisabled",
95
- e && typeof e == "string" ? `ImageButton--contentColor__${e}` : "ImageButton--contentColor__default"
82
+ C && "ImageButton--contentSelected",
83
+ r && "ImageButton--contentDisabled",
84
+ o && typeof o == "string" ? `ImageButton--contentColor__${o}` : "ImageButton--contentColor__default"
96
85
  ]),
97
- children: i
86
+ children: a
98
87
  }
99
88
  )
100
89
  ]
101
90
  }
102
91
  );
103
- return _ && (p = /* @__PURE__ */ t(z, { content: _, position: w, children: p })), /* @__PURE__ */ g(
92
+ return _ && (h = /* @__PURE__ */ t(E, { content: _, position: w, children: h })), /* @__PURE__ */ I(
104
93
  "div",
105
94
  {
106
95
  className: l([
107
96
  "ImageButton",
108
- c && "ImageButton--fluid",
109
- k
97
+ e && "ImageButton--fluid",
98
+ N
110
99
  ]),
111
- ...A(v),
100
+ ...S(v),
112
101
  children: [
113
- p,
114
- m && /* @__PURE__ */ t(
102
+ h,
103
+ i && /* @__PURE__ */ t(
115
104
  "div",
116
105
  {
117
106
  className: l([
118
107
  "buttonsContainer",
119
- h && "buttonsAltContainer",
120
- !i && "buttonsEmpty",
121
- c && e && typeof e == "string" ? `ImageButton--buttonsContainerColor__${e}` : c && "ImageButton--buttonsContainerColor__default"
108
+ !a && "buttonsEmpty",
109
+ e && o && typeof o == "string" ? `ImageButton--buttonsContainerColor__${o}` : e && "ImageButton--buttonsContainerColor__default"
122
110
  ]),
123
111
  style: {
124
- width: h ? `calc(${o}px + 0.5em)` : "auto"
112
+ width: "auto"
125
113
  },
126
- children: m
114
+ children: i
115
+ }
116
+ ),
117
+ p && /* @__PURE__ */ t(
118
+ "div",
119
+ {
120
+ className: l([
121
+ "buttonsContainer",
122
+ "buttonsAltContainer",
123
+ !a && "buttonsEmpty",
124
+ e && o && typeof o == "string" ? `ImageButton--buttonsContainerColor__${o}` : e && "ImageButton--buttonsContainerColor__default"
125
+ ]),
126
+ style: {
127
+ width: `calc(${n}px + ${e ? 0 : 0.5}em)`,
128
+ maxWidth: e ? "auto" : `calc(${n}px + 0.5em)`
129
+ },
130
+ children: p
127
131
  }
128
132
  )
129
133
  ]
130
134
  }
131
135
  );
132
136
  }
137
+ function y(d) {
138
+ const { icon: u, spin: c = !1, size: i = 64 } = d;
139
+ return /* @__PURE__ */ t($, { height: `${i}px`, width: `${i}px`, children: /* @__PURE__ */ t($.Item, { grow: !0, textAlign: "center", align: "center", children: /* @__PURE__ */ t(
140
+ A,
141
+ {
142
+ spin: c,
143
+ name: u,
144
+ color: "gray",
145
+ style: { fontSize: `calc(${i}px * 0.75)` }
146
+ }
147
+ ) }) });
148
+ }
133
149
  export {
134
- H as ImageButton
150
+ W as ImageButton
135
151
  };
@@ -1,37 +1,6 @@
1
1
  import { PropsWithChildren, ReactNode } from 'react';
2
2
  import { BooleanLike } from '../common/react';
3
- /**
4
- * ## LabeledList
5
- * LabeledList is a continuous, vertical list of text and other content, where
6
- * every item is labeled.
7
- *
8
- * It works just like a two column table, where first column is labels, and
9
- * second column is content.
10
- *
11
- * @example
12
- * ```tsx
13
- * <LabeledList>
14
- * <LabeledList.Item label="Item">Content</LabeledList.Item>
15
- * </LabeledList>
16
- * ```
17
- *
18
- * If you want to have a button on the right side of an item (for example,
19
- * to perform some sort of action), there is a way to do that:
20
- *
21
- * @example
22
- * ```tsx
23
- * <LabeledList>
24
- * <LabeledList.Item label="Item" buttons={<Button>Click me!</Button>}>
25
- * Content
26
- * </LabeledList.Item>
27
- * </LabeledList>
28
- * ```
29
- */
30
3
  export declare function LabeledList(props: PropsWithChildren): import("react/jsx-runtime").JSX.Element;
31
- export declare namespace LabeledList {
32
- var Item: typeof LabeledListItem;
33
- var Divider: typeof LabeledListDivider;
34
- }
35
4
  type LabeledListItemProps = Partial<{
36
5
  /** Buttons to render aside the content. */
37
6
  buttons: ReactNode;
@@ -80,4 +49,38 @@ type LabeledListDividerProps = {
80
49
  size?: number;
81
50
  };
82
51
  declare function LabeledListDivider(props: LabeledListDividerProps): import("react/jsx-runtime").JSX.Element;
52
+ /**
53
+ * ## LabeledList
54
+ * LabeledList is a continuous, vertical list of text and other content, where
55
+ * every item is labeled.
56
+ *
57
+ * It works just like a two column table, where first column is labels, and
58
+ * second column is content.
59
+ *
60
+ * @example
61
+ * ```tsx
62
+ * <LabeledList>
63
+ * <LabeledList.Item label="Item">Content</LabeledList.Item>
64
+ * </LabeledList>
65
+ * ```
66
+ *
67
+ * If you want to have a button on the right side of an item (for example,
68
+ * to perform some sort of action), there is a way to do that:
69
+ *
70
+ * @example
71
+ * ```tsx
72
+ * <LabeledList>
73
+ * <LabeledList.Item label="Item" buttons={<Button>Click me!</Button>}>
74
+ * Content
75
+ * </LabeledList.Item>
76
+ * </LabeledList>
77
+ * ```
78
+ */
79
+ export declare namespace LabeledList {
80
+ /**
81
+ * Adds some empty space between LabeledList items.
82
+ */
83
+ const Divider: typeof LabeledListDivider;
84
+ const Item: typeof LabeledListItem;
85
+ }
83
86
  export {};
@@ -1,29 +1,29 @@
1
- import { jsx as e, jsxs as d } from "react/jsx-runtime";
1
+ import { jsx as l, jsxs as d } from "react/jsx-runtime";
2
2
  import { classes as c } from "../common/react.js";
3
3
  import { unit as g } from "../common/ui.js";
4
4
  import { Box as r } from "./Box.js";
5
5
  import { Divider as x } from "./Divider.js";
6
6
  import { Tooltip as N } from "./Tooltip.js";
7
- function b(l) {
8
- const { children: t } = l;
9
- return /* @__PURE__ */ e("table", { className: "LabeledList", children: /* @__PURE__ */ e("tbody", { children: t }) });
7
+ function b(e) {
8
+ const { children: t } = e;
9
+ return /* @__PURE__ */ l("table", { className: "LabeledList", children: /* @__PURE__ */ l("tbody", { children: t }) });
10
10
  }
11
- function v(l) {
11
+ function v(e) {
12
12
  const {
13
13
  className: t,
14
- label: a,
14
+ label: o,
15
15
  labelColor: m = "label",
16
16
  labelWrap: L,
17
17
  color: p,
18
18
  textAlign: _,
19
- buttons: o,
19
+ buttons: a,
20
20
  content: f,
21
21
  children: h,
22
22
  verticalAlign: s = "baseline",
23
23
  tooltip: n
24
- } = l;
24
+ } = e;
25
25
  let i;
26
- a && (i = a, typeof a == "string" && (i += ":")), n !== void 0 && (i = /* @__PURE__ */ e(N, { content: n, children: /* @__PURE__ */ e(
26
+ o && (i = o, typeof o == "string" && (i += ":")), n !== void 0 && (i = /* @__PURE__ */ l(N, { content: n, children: /* @__PURE__ */ l(
27
27
  r,
28
28
  {
29
29
  as: "span",
@@ -33,7 +33,7 @@ function v(l) {
33
33
  children: i
34
34
  }
35
35
  ) }));
36
- const u = /* @__PURE__ */ e(
36
+ const u = /* @__PURE__ */ l(
37
37
  r,
38
38
  {
39
39
  as: "td",
@@ -56,7 +56,7 @@ function v(l) {
56
56
  color: p,
57
57
  textAlign: _,
58
58
  className: "LabeledList__cell",
59
- colSpan: o ? void 0 : 2,
59
+ colSpan: a ? void 0 : 2,
60
60
  verticalAlign: s,
61
61
  children: [
62
62
  f,
@@ -64,13 +64,12 @@ function v(l) {
64
64
  ]
65
65
  }
66
66
  ),
67
- o && /* @__PURE__ */ e("td", { className: "LabeledList__cell LabeledList__buttons", children: o })
67
+ a && /* @__PURE__ */ l("td", { className: "LabeledList__cell LabeledList__buttons", children: a })
68
68
  ] });
69
69
  }
70
- b.Item = v;
71
- function y(l) {
72
- const t = l.size ? g(Math.max(0, l.size - 1)) : 0;
73
- return /* @__PURE__ */ e("tr", { className: "LabeledList__row", children: /* @__PURE__ */ e(
70
+ function y(e) {
71
+ const t = e.size ? g(Math.max(0, e.size - 1)) : 0;
72
+ return /* @__PURE__ */ l("tr", { className: "LabeledList__row", children: /* @__PURE__ */ l(
74
73
  "td",
75
74
  {
76
75
  colSpan: 3,
@@ -78,11 +77,13 @@ function y(l) {
78
77
  paddingTop: t,
79
78
  paddingBottom: t
80
79
  },
81
- children: /* @__PURE__ */ e(x, {})
80
+ children: /* @__PURE__ */ l(x, {})
82
81
  }
83
82
  ) });
84
83
  }
85
- b.Divider = y;
84
+ ((e) => {
85
+ e.Divider = y, e.Item = v;
86
+ })(b || (b = {}));
86
87
  export {
87
88
  b as LabeledList
88
89
  };
@@ -3,6 +3,24 @@ type Props = Partial<{
3
3
  /** Collapses table to the smallest possible size. */
4
4
  collapsing: boolean;
5
5
  }> & BoxProps;
6
+ export declare function Table(props: Props): import("react/jsx-runtime").JSX.Element;
7
+ type RowProps = Partial<{
8
+ /** Whether this is a header cell. */
9
+ header: boolean;
10
+ }> & BoxProps;
11
+ declare function TableRow(props: RowProps): import("react/jsx-runtime").JSX.Element;
12
+ type CellProps = Partial<{
13
+ /** Additional columns for this cell to expand, assuming there is room. */
14
+ colSpan: number;
15
+ /** Collapses table cell to the smallest possible size,
16
+ and stops any text inside from wrapping. */
17
+ collapsing: boolean;
18
+ /** Whether this is a header cell. */
19
+ header: boolean;
20
+ /** Rows for this cell to expand, assuming there is room. */
21
+ rowSpan: number;
22
+ }> & BoxProps;
23
+ declare function TableCell(props: CellProps): import("react/jsx-runtime").JSX.Element;
6
24
  /**
7
25
  * ## Table
8
26
  * A straight forward mapping to a standard html table, which is slightly
@@ -21,26 +39,16 @@ type Props = Partial<{
21
39
  * </Table>
22
40
  * ```
23
41
  */
24
- export declare function Table(props: Props): import("react/jsx-runtime").JSX.Element;
25
42
  export declare namespace Table {
26
- var Row: typeof TableRow;
27
- var Cell: typeof TableCell;
43
+ /**
44
+ * ## Table.Cell
45
+ * A straight forward mapping to `<td>` element.
46
+ */
47
+ const Cell: typeof TableCell;
48
+ /**
49
+ * ## Table.Row
50
+ * A straight forward mapping to `<tr>` element.
51
+ */
52
+ const Row: typeof TableRow;
28
53
  }
29
- type RowProps = Partial<{
30
- /** Whether this is a header cell. */
31
- header: boolean;
32
- }> & BoxProps;
33
- declare function TableRow(props: RowProps): import("react/jsx-runtime").JSX.Element;
34
- type CellProps = Partial<{
35
- /** Additional columns for this cell to expand, assuming there is room. */
36
- colSpan: number;
37
- /** Collapses table cell to the smallest possible size,
38
- and stops any text inside from wrapping. */
39
- collapsing: boolean;
40
- /** Whether this is a header cell. */
41
- header: boolean;
42
- /** Rows for this cell to expand, assuming there is room. */
43
- rowSpan: number;
44
- }> & BoxProps;
45
- declare function TableCell(props: CellProps): import("react/jsx-runtime").JSX.Element;
46
54
  export {};
@@ -17,7 +17,7 @@ function m(e) {
17
17
  }
18
18
  );
19
19
  }
20
- function i(e) {
20
+ function b(e) {
21
21
  const { className: l, header: a, ...s } = e;
22
22
  return /* @__PURE__ */ c(
23
23
  "tr",
@@ -32,9 +32,8 @@ function i(e) {
32
32
  }
33
33
  );
34
34
  }
35
- m.Row = i;
36
- function T(e) {
37
- const { className: l, collapsing: a, colSpan: s, header: o, ...b } = e;
35
+ function _(e) {
36
+ const { className: l, collapsing: a, colSpan: s, header: o, ...i } = e;
38
37
  return /* @__PURE__ */ c(
39
38
  "td",
40
39
  {
@@ -46,11 +45,13 @@ function T(e) {
46
45
  t(e)
47
46
  ]),
48
47
  colSpan: s,
49
- ...n(b)
48
+ ...n(i)
50
49
  }
51
50
  );
52
51
  }
53
- m.Cell = T;
52
+ ((e) => {
53
+ e.Cell = _, e.Row = b;
54
+ })(m || (m = {}));
54
55
  export {
55
56
  m as Table
56
57
  };
@@ -13,6 +13,22 @@ type Props = Partial<{
13
13
  /** Use a vertical configuration, where tabs will be stacked vertically. */
14
14
  vertical: boolean;
15
15
  }> & BoxProps;
16
+ export declare function Tabs(props: Props): import("react/jsx-runtime").JSX.Element;
17
+ type TabProps = Partial<{
18
+ /** Font awesome icon. @see https://fontawesome.com/v6/search?o=r&m=free */
19
+ icon: string;
20
+ /** Causes the icon to spin */
21
+ iconSpin: boolean;
22
+ /** Left slot content */
23
+ leftSlot: ReactNode;
24
+ /** Called when element is clicked */
25
+ onClick: (e?: any) => void;
26
+ /** Right slot content */
27
+ rightSlot: ReactNode;
28
+ /** Whether the tab is selected */
29
+ selected: boolean;
30
+ }> & BoxProps;
31
+ declare function TabItem(props: TabProps): import("react/jsx-runtime").JSX.Element;
16
32
  /**
17
33
  * ## Tabs
18
34
  * Tabs make it easy to explore and switch between different views.
@@ -71,22 +87,12 @@ type Props = Partial<{
71
87
  * </Section>
72
88
  * ```
73
89
  */
74
- export declare function Tabs(props: Props): import("react/jsx-runtime").JSX.Element;
75
90
  export declare namespace Tabs {
76
- var Tab: (props: TabProps) => import("react/jsx-runtime").JSX.Element;
91
+ /**
92
+ * ## Tabs.Tab
93
+ * An individual tab element. Tabs function like buttons, so they inherit
94
+ * a lot of `Button` props.
95
+ */
96
+ const Tab: typeof TabItem;
77
97
  }
78
- type TabProps = Partial<{
79
- /** Font awesome icon. */
80
- icon: string;
81
- /** Causes the icon to spin */
82
- iconSpin: boolean;
83
- /** Left slot content */
84
- leftSlot: ReactNode;
85
- /** Called when element is clicked */
86
- onClick: (e?: any) => void;
87
- /** Right slot content */
88
- rightSlot: ReactNode;
89
- /** Whether the tab is selected */
90
- selected: boolean;
91
- }> & BoxProps;
92
98
  export {};