@tipp/ui 1.1.4 → 1.1.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (47) hide show
  1. package/dist/atoms/drawer.cjs +13 -6
  2. package/dist/atoms/drawer.cjs.map +1 -1
  3. package/dist/atoms/drawer.js +1 -1
  4. package/dist/atoms/index.cjs +10 -6
  5. package/dist/atoms/index.cjs.map +1 -1
  6. package/dist/atoms/index.js +1 -1
  7. package/dist/chunk-43UXXKFO.js +31 -0
  8. package/dist/chunk-43UXXKFO.js.map +1 -0
  9. package/dist/chunk-6T66J7SC.js +31 -0
  10. package/dist/chunk-6T66J7SC.js.map +1 -0
  11. package/dist/chunk-74WGHMXE.js +38 -0
  12. package/dist/chunk-74WGHMXE.js.map +1 -0
  13. package/dist/chunk-76NU6HMD.js +54 -0
  14. package/dist/chunk-76NU6HMD.js.map +1 -0
  15. package/dist/chunk-D2XQUEVI.js +59 -0
  16. package/dist/chunk-D2XQUEVI.js.map +1 -0
  17. package/dist/chunk-G4CFKBVC.js +123 -0
  18. package/dist/chunk-G4CFKBVC.js.map +1 -0
  19. package/dist/chunk-RSZMFZ6O.js +54 -0
  20. package/dist/chunk-RSZMFZ6O.js.map +1 -0
  21. package/dist/chunk-TQGM4VHP.js +54 -0
  22. package/dist/chunk-TQGM4VHP.js.map +1 -0
  23. package/dist/chunk-W5VTZW3O.js +54 -0
  24. package/dist/chunk-W5VTZW3O.js.map +1 -0
  25. package/dist/chunk-WV7FE4LE.js +59 -0
  26. package/dist/chunk-WV7FE4LE.js.map +1 -0
  27. package/dist/chunk-X73G236I.js +50 -0
  28. package/dist/chunk-X73G236I.js.map +1 -0
  29. package/dist/chunk-YKJPZGZD.js +54 -0
  30. package/dist/chunk-YKJPZGZD.js.map +1 -0
  31. package/dist/chunk-YYQEUHIE.js +123 -0
  32. package/dist/chunk-YYQEUHIE.js.map +1 -0
  33. package/dist/index.cjs +10 -6
  34. package/dist/index.cjs.map +1 -1
  35. package/dist/index.d.cts +1 -0
  36. package/dist/index.d.ts +1 -0
  37. package/dist/index.js +4 -4
  38. package/dist/molecules/expand-table/index.js +1 -1
  39. package/dist/molecules/expand-table/row.js +1 -1
  40. package/dist/molecules/index.js +1 -1
  41. package/dist/molecules/navigation.js +1 -1
  42. package/dist/utils/index.d.cts +1 -0
  43. package/dist/utils/index.d.ts +1 -0
  44. package/dist/utils/scroll-to.d.cts +3 -0
  45. package/dist/utils/scroll-to.d.ts +3 -0
  46. package/package.json +1 -1
  47. package/src/atoms/drawer.tsx +5 -3
@@ -0,0 +1,123 @@
1
+ import {
2
+ Row
3
+ } from "./chunk-JFKC7O5G.js";
4
+ import {
5
+ TriangleArrowUpIcon
6
+ } from "./chunk-NDUKDKGB.js";
7
+ import {
8
+ TriangleArrowDownIcon
9
+ } from "./chunk-BSTJBBEX.js";
10
+ import {
11
+ Flex
12
+ } from "./chunk-25HMMI7R.js";
13
+ import {
14
+ Typo
15
+ } from "./chunk-O3XTRD7R.js";
16
+
17
+ // src/molecules/expand-table/index.tsx
18
+ import {
19
+ flexRender,
20
+ getCoreRowModel,
21
+ useReactTable,
22
+ getSortedRowModel,
23
+ createColumnHelper
24
+ } from "@tanstack/react-table";
25
+ import { useMemo, useState } from "react";
26
+ import { jsx, jsxs } from "react/jsx-runtime";
27
+ function ExpandTable(props) {
28
+ const { data, columns, ExpandComp, placeholder, onRowClick, tableStyle } = props;
29
+ const defaultAlign = "left";
30
+ const [sorting, setSorting] = useState([]);
31
+ const { getRowModel, getHeaderGroups } = useReactTable({
32
+ data: data || [],
33
+ columns,
34
+ getCoreRowModel: getCoreRowModel(),
35
+ getSortedRowModel: getSortedRowModel(),
36
+ state: {
37
+ sorting
38
+ },
39
+ onSortingChange: setSorting
40
+ });
41
+ const gridColTemp = useMemo(() => {
42
+ return columns.map((col) => {
43
+ var _a;
44
+ if ((_a = col.meta) == null ? void 0 : _a.autoSize)
45
+ return "1fr";
46
+ return `${col.size || 150}px`;
47
+ }).join(" ");
48
+ }, [columns]);
49
+ const rowModels = getRowModel();
50
+ return /* @__PURE__ */ jsxs("div", { className: "expand-table", style: tableStyle, children: [
51
+ /* @__PURE__ */ jsx("div", { className: "thead", children: getHeaderGroups().map((headerGroup) => /* @__PURE__ */ jsx(
52
+ "div",
53
+ {
54
+ className: "tr",
55
+ style: { gridTemplateColumns: gridColTemp },
56
+ children: headerGroup.headers.map((header) => {
57
+ var _a;
58
+ const sortable = header.column.getCanSort();
59
+ const sortedState = header.column.getIsSorted();
60
+ const justifyContent = ((_a = header.column.columnDef.meta) == null ? void 0 : _a.align) || defaultAlign;
61
+ return /* @__PURE__ */ jsx("div", { className: `${justifyContent} th`, children: /* @__PURE__ */ jsxs(
62
+ "button",
63
+ {
64
+ onClick: header.column.getToggleSortingHandler(),
65
+ style: sortable ? { cursor: "pointer" } : void 0,
66
+ type: "button",
67
+ children: [
68
+ /* @__PURE__ */ jsx(Typo, { variant: "body", children: flexRender(
69
+ header.column.columnDef.header,
70
+ header.getContext()
71
+ ) }),
72
+ sortable ? /* @__PURE__ */ jsxs(
73
+ Flex,
74
+ {
75
+ direction: "column",
76
+ style: { marginLeft: "var(--space-2)" },
77
+ children: [
78
+ /* @__PURE__ */ jsx(
79
+ TriangleArrowUpIcon,
80
+ {
81
+ color: sortedState === "asc" ? "var(--iris-10)" : "var(--iris-6)"
82
+ }
83
+ ),
84
+ /* @__PURE__ */ jsx(
85
+ TriangleArrowDownIcon,
86
+ {
87
+ color: sortedState === "desc" ? "var(--iris-10)" : "var(--iris-6)"
88
+ }
89
+ )
90
+ ]
91
+ }
92
+ ) : null
93
+ ]
94
+ }
95
+ ) }, header.id);
96
+ })
97
+ },
98
+ headerGroup.id
99
+ )) }),
100
+ /* @__PURE__ */ jsxs("div", { className: "tbody", children: [
101
+ rowModels.rows.length === 0 && /* @__PURE__ */ jsx("div", { className: "tr", children: /* @__PURE__ */ jsx(Flex, { align: "center", justify: "center", children: placeholder || /* @__PURE__ */ jsx(Typo, { color: "gray", mb: "6", mt: "6", variant: "body", children: "\uB370\uC774\uD130\uAC00 \uC5C6\uC2B5\uB2C8\uB2E4" }) }) }, "expand_placeholder"),
102
+ rowModels.rows.map((row) => {
103
+ return /* @__PURE__ */ jsx(
104
+ Row,
105
+ {
106
+ ExpandComp,
107
+ defaultAlign,
108
+ gridColTemp,
109
+ onRowClick,
110
+ row
111
+ },
112
+ `row_${row.id}`
113
+ );
114
+ })
115
+ ] })
116
+ ] });
117
+ }
118
+
119
+ export {
120
+ createColumnHelper,
121
+ ExpandTable
122
+ };
123
+ //# sourceMappingURL=chunk-G4CFKBVC.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/molecules/expand-table/index.tsx"],"sourcesContent":["import type {\n ColumnDef,\n SortingState,\n RowData,\n Row as RowType,\n} from '@tanstack/react-table';\nimport type { CSSProperties } from 'react';\nimport {\n flexRender,\n getCoreRowModel,\n useReactTable,\n getSortedRowModel,\n createColumnHelper,\n} from '@tanstack/react-table';\nimport React, { useMemo, useState } from 'react';\nimport { Flex, Typo } from '../../atoms';\nimport { TriangleArrowDownIcon } from '../../icons/down';\nimport { TriangleArrowUpIcon } from '../../icons/up';\nimport { Row, type ExpandComp, type OnRowClick } from './row';\n\nexport type { ExpandComp, OnRowClick, ColumnDef, RowType as Row };\nexport { createColumnHelper };\n\nexport interface ExpandTableProps<Datum extends RowData> {\n /** 렌더할 데이터 배열 */\n data?: Datum[];\n /** 테이블 컬럼의 메타 데이터 */\n columns: ColumnDef<Datum>[];\n /** Row의 open이 true인 경우 하단의 collapse에 렌더할 컴포넌트 */\n ExpandComp?: ExpandComp<Datum>;\n /** 데이테가 없을 시 화면에 표시할 컴포넌트 */\n placeholder?: React.ReactNode;\n /** 행 클릭 시 실행할 콜백 */\n onRowClick?: OnRowClick<Datum>;\n rowStyle?: CSSProperties;\n tableStyle?: CSSProperties;\n}\n\nexport function ExpandTable<Datum extends RowData>(\n props: ExpandTableProps<Datum>\n): React.ReactNode {\n const { data, columns, ExpandComp, placeholder, onRowClick, tableStyle } =\n props;\n const defaultAlign = 'left';\n const [sorting, setSorting] = useState<SortingState>([]);\n const { getRowModel, getHeaderGroups } = useReactTable({\n data: data || [],\n columns,\n getCoreRowModel: getCoreRowModel(),\n getSortedRowModel: getSortedRowModel(),\n state: {\n sorting,\n },\n onSortingChange: setSorting,\n });\n\n const gridColTemp = useMemo<string>(() => {\n return columns\n .map((col) => {\n if (col.meta?.autoSize) return '1fr';\n return `${col.size || 150}px`;\n })\n .join(' ');\n }, [columns]);\n\n const rowModels = getRowModel();\n\n return (\n <div className=\"expand-table\" style={tableStyle}>\n <div className=\"thead\">\n {getHeaderGroups().map((headerGroup) => (\n <div\n className=\"tr\"\n key={headerGroup.id}\n style={{ gridTemplateColumns: gridColTemp }}\n >\n {headerGroup.headers.map((header) => {\n const sortable = header.column.getCanSort();\n const sortedState = header.column.getIsSorted();\n const justifyContent =\n header.column.columnDef.meta?.align || defaultAlign;\n\n return (\n <div className={`${justifyContent} th`} key={header.id}>\n <button\n onClick={header.column.getToggleSortingHandler()}\n style={sortable ? { cursor: 'pointer' } : undefined}\n type=\"button\"\n >\n <Typo variant=\"body\">\n {flexRender(\n header.column.columnDef.header,\n header.getContext()\n )}\n </Typo>\n {sortable ? (\n <Flex\n direction=\"column\"\n style={{ marginLeft: 'var(--space-2)' }}\n >\n <TriangleArrowUpIcon\n color={\n sortedState === 'asc'\n ? 'var(--iris-10)'\n : 'var(--iris-6)'\n }\n />\n <TriangleArrowDownIcon\n color={\n sortedState === 'desc'\n ? 'var(--iris-10)'\n : 'var(--iris-6)'\n }\n />\n </Flex>\n ) : null}\n </button>\n </div>\n );\n })}\n </div>\n ))}\n </div>\n <div className=\"tbody\">\n {/* 데이터가 없을 시 표시되는 노드 */}\n {rowModels.rows.length === 0 && (\n <div className=\"tr\" key=\"expand_placeholder\">\n <Flex align=\"center\" justify=\"center\">\n {placeholder || (\n <Typo color=\"gray\" mb=\"6\" mt=\"6\" variant=\"body\">\n 데이터가 없습니다\n </Typo>\n )}\n </Flex>\n </div>\n )}\n\n {/* 행을 렌더하는 로직 */}\n {rowModels.rows.map((row) => {\n return (\n <Row\n ExpandComp={ExpandComp}\n defaultAlign={defaultAlign}\n gridColTemp={gridColTemp}\n key={`row_${row.id}`}\n onRowClick={onRowClick}\n row={row}\n />\n );\n })}\n </div>\n </div>\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;AAOA;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,SAAgB,SAAS,gBAAgB;AA2ErB,cAOE,YAPF;AAnDb,SAAS,YACd,OACiB;AACjB,QAAM,EAAE,MAAM,SAAS,YAAY,aAAa,YAAY,WAAW,IACrE;AACF,QAAM,eAAe;AACrB,QAAM,CAAC,SAAS,UAAU,IAAI,SAAuB,CAAC,CAAC;AACvD,QAAM,EAAE,aAAa,gBAAgB,IAAI,cAAc;AAAA,IACrD,MAAM,QAAQ,CAAC;AAAA,IACf;AAAA,IACA,iBAAiB,gBAAgB;AAAA,IACjC,mBAAmB,kBAAkB;AAAA,IACrC,OAAO;AAAA,MACL;AAAA,IACF;AAAA,IACA,iBAAiB;AAAA,EACnB,CAAC;AAED,QAAM,cAAc,QAAgB,MAAM;AACxC,WAAO,QACJ,IAAI,CAAC,QAAQ;AA1DpB;AA2DQ,WAAI,SAAI,SAAJ,mBAAU;AAAU,eAAO;AAC/B,aAAO,GAAG,IAAI,QAAQ,GAAG;AAAA,IAC3B,CAAC,EACA,KAAK,GAAG;AAAA,EACb,GAAG,CAAC,OAAO,CAAC;AAEZ,QAAM,YAAY,YAAY;AAE9B,SACE,qBAAC,SAAI,WAAU,gBAAe,OAAO,YACnC;AAAA,wBAAC,SAAI,WAAU,SACZ,0BAAgB,EAAE,IAAI,CAAC,gBACtB;AAAA,MAAC;AAAA;AAAA,QACC,WAAU;AAAA,QAEV,OAAO,EAAE,qBAAqB,YAAY;AAAA,QAEzC,sBAAY,QAAQ,IAAI,CAAC,WAAW;AA5EjD;AA6Ec,gBAAM,WAAW,OAAO,OAAO,WAAW;AAC1C,gBAAM,cAAc,OAAO,OAAO,YAAY;AAC9C,gBAAM,mBACJ,YAAO,OAAO,UAAU,SAAxB,mBAA8B,UAAS;AAEzC,iBACE,oBAAC,SAAI,WAAW,GAAG,cAAc,OAC/B;AAAA,YAAC;AAAA;AAAA,cACC,SAAS,OAAO,OAAO,wBAAwB;AAAA,cAC/C,OAAO,WAAW,EAAE,QAAQ,UAAU,IAAI;AAAA,cAC1C,MAAK;AAAA,cAEL;AAAA,oCAAC,QAAK,SAAQ,QACX;AAAA,kBACC,OAAO,OAAO,UAAU;AAAA,kBACxB,OAAO,WAAW;AAAA,gBACpB,GACF;AAAA,gBACC,WACC;AAAA,kBAAC;AAAA;AAAA,oBACC,WAAU;AAAA,oBACV,OAAO,EAAE,YAAY,iBAAiB;AAAA,oBAEtC;AAAA;AAAA,wBAAC;AAAA;AAAA,0BACC,OACE,gBAAgB,QACZ,mBACA;AAAA;AAAA,sBAER;AAAA,sBACA;AAAA,wBAAC;AAAA;AAAA,0BACC,OACE,gBAAgB,SACZ,mBACA;AAAA;AAAA,sBAER;AAAA;AAAA;AAAA,gBACF,IACE;AAAA;AAAA;AAAA,UACN,KAjC2C,OAAO,EAkCpD;AAAA,QAEJ,CAAC;AAAA;AAAA,MA9CI,YAAY;AAAA,IA+CnB,CACD,GACH;AAAA,IACA,qBAAC,SAAI,WAAU,SAEZ;AAAA,gBAAU,KAAK,WAAW,KACzB,oBAAC,SAAI,WAAU,MACb,8BAAC,QAAK,OAAM,UAAS,SAAQ,UAC1B,yBACC,oBAAC,QAAK,OAAM,QAAO,IAAG,KAAI,IAAG,KAAI,SAAQ,QAAO,+DAEhD,GAEJ,KAPsB,oBAQxB;AAAA,MAID,UAAU,KAAK,IAAI,CAAC,QAAQ;AAC3B,eACE;AAAA,UAAC;AAAA;AAAA,YACC;AAAA,YACA;AAAA,YACA;AAAA,YAEA;AAAA,YACA;AAAA;AAAA,UAFK,OAAO,IAAI,EAAE;AAAA,QAGpB;AAAA,MAEJ,CAAC;AAAA,OACH;AAAA,KACF;AAEJ;","names":[]}
@@ -0,0 +1,54 @@
1
+ import {
2
+ ToastContainer
3
+ } from "./chunk-43UXXKFO.js";
4
+ import {
5
+ ThemeProvider
6
+ } from "./chunk-BVBX6IJ3.js";
7
+ import {
8
+ __objRest,
9
+ __spreadValues
10
+ } from "./chunk-N552FDTV.js";
11
+
12
+ // src/atoms/drawer.tsx
13
+ import { useEffect, useRef } from "react";
14
+ import * as Dialog from "@radix-ui/react-dialog";
15
+ import { jsx, jsxs } from "react/jsx-runtime";
16
+ function Root2(props) {
17
+ return /* @__PURE__ */ jsx(Dialog.Root, __spreadValues({}, props));
18
+ }
19
+ function Content2(props) {
20
+ const _a = props, { position = "right", className } = _a, rest = __objRest(_a, ["position", "className"]);
21
+ const containerRef = useRef(null);
22
+ useEffect(() => {
23
+ containerRef.current = document.getElementsByTagName("main")[0];
24
+ }, []);
25
+ return /* @__PURE__ */ jsx(Dialog.Portal, { container: containerRef.current, children: /* @__PURE__ */ jsxs(ThemeProvider, { children: [
26
+ /* @__PURE__ */ jsx(Dialog.Overlay, { className: "DrawerOverlay" }),
27
+ /* @__PURE__ */ jsx(
28
+ Dialog.Content,
29
+ __spreadValues({
30
+ className: `DrawerContent ${position} ${className || ""}`
31
+ }, rest)
32
+ ),
33
+ /* @__PURE__ */ jsx(ToastContainer, {})
34
+ ] }) });
35
+ }
36
+ function Trigger2(props) {
37
+ return /* @__PURE__ */ jsx(Dialog.Trigger, __spreadValues({ asChild: true }, props));
38
+ }
39
+ var Drawer = {
40
+ Root: Dialog.Root,
41
+ Trigger: Trigger2,
42
+ Content: Content2,
43
+ Close: Dialog.Close,
44
+ Title: Dialog.Title,
45
+ Description: Dialog.Description
46
+ };
47
+
48
+ export {
49
+ Root2 as Root,
50
+ Content2 as Content,
51
+ Trigger2 as Trigger,
52
+ Drawer
53
+ };
54
+ //# sourceMappingURL=chunk-RSZMFZ6O.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/atoms/drawer.tsx"],"sourcesContent":["import React, { useEffect, useRef } from 'react';\nimport * as Dialog from '@radix-ui/react-dialog';\nimport { ThemeProvider } from '../theme/theme-provider';\nimport { ToastContainer } from './toast';\n\nexport function Root(props: Dialog.DialogProps): React.ReactNode {\n return <Dialog.Root {...props} />;\n}\n\ntype ContentProps = Dialog.DialogContentProps & {\n /** Drawer가 붙는 위치, 기본값 right */\n position?: 'left' | 'right' | 'bottom' | 'top';\n};\n\nexport function Content(props: ContentProps): React.ReactNode {\n const { position = 'right', className, ...rest } = props;\n\n const containerRef = useRef<HTMLElement | null>(null);\n\n useEffect(() => {\n containerRef.current = document.getElementsByTagName('main')[0];\n }, []);\n\n return (\n <Dialog.Portal container={containerRef.current}>\n <ThemeProvider>\n <Dialog.Overlay className=\"DrawerOverlay\" />\n <Dialog.Content\n className={`DrawerContent ${position} ${className || ''}`}\n {...rest}\n />\n <ToastContainer />\n </ThemeProvider>\n </Dialog.Portal>\n );\n}\n\nexport function Trigger(props: Dialog.DialogTriggerProps): React.ReactNode {\n return <Dialog.Trigger asChild {...props} />;\n}\n\nexport const Drawer = {\n Root: Dialog.Root,\n Trigger,\n Content,\n Close: Dialog.Close,\n Title: Dialog.Title,\n Description: Dialog.Description,\n};\n"],"mappings":";;;;;;;;;;;;AAAA,SAAgB,WAAW,cAAc;AACzC,YAAY,YAAY;AAKf,cAmBH,YAnBG;AADF,SAASA,MAAK,OAA4C;AAC/D,SAAO,oBAAQ,aAAP,mBAAgB,MAAO;AACjC;AAOO,SAASC,SAAQ,OAAsC;AAC5D,QAAmD,YAA3C,aAAW,SAAS,UAf9B,IAeqD,IAAT,iBAAS,IAAT,CAAlC,YAAoB;AAE5B,QAAM,eAAe,OAA2B,IAAI;AAEpD,YAAU,MAAM;AACd,iBAAa,UAAU,SAAS,qBAAqB,MAAM,EAAE,CAAC;AAAA,EAChE,GAAG,CAAC,CAAC;AAEL,SACE,oBAAQ,eAAP,EAAc,WAAW,aAAa,SACrC,+BAAC,iBACC;AAAA,wBAAQ,gBAAP,EAAe,WAAU,iBAAgB;AAAA,IAC1C;AAAA,MAAQ;AAAA,MAAP;AAAA,QACC,WAAW,iBAAiB,QAAQ,IAAI,aAAa,EAAE;AAAA,SACnD;AAAA,IACN;AAAA,IACA,oBAAC,kBAAe;AAAA,KAClB,GACF;AAEJ;AAEO,SAASC,SAAQ,OAAmD;AACzE,SAAO,oBAAQ,gBAAP,iBAAe,SAAO,QAAK,MAAO;AAC5C;AAEO,IAAM,SAAS;AAAA,EACpB,MAAa;AAAA,EACb,SAAAA;AAAA,EACA,SAAAD;AAAA,EACA,OAAc;AAAA,EACd,OAAc;AAAA,EACd,aAAoB;AACtB;","names":["Root","Content","Trigger"]}
@@ -0,0 +1,54 @@
1
+ import {
2
+ ThemeProvider
3
+ } from "./chunk-BVBX6IJ3.js";
4
+ import {
5
+ ToastContainer
6
+ } from "./chunk-74WGHMXE.js";
7
+ import {
8
+ __objRest,
9
+ __spreadValues
10
+ } from "./chunk-N552FDTV.js";
11
+
12
+ // src/atoms/drawer.tsx
13
+ import { useEffect, useRef } from "react";
14
+ import * as Dialog from "@radix-ui/react-dialog";
15
+ import { jsx, jsxs } from "react/jsx-runtime";
16
+ function Root2(props) {
17
+ return /* @__PURE__ */ jsx(Dialog.Root, __spreadValues({}, props));
18
+ }
19
+ function Content2(props) {
20
+ const _a = props, { position = "right", className } = _a, rest = __objRest(_a, ["position", "className"]);
21
+ const containerRef = useRef(null);
22
+ useEffect(() => {
23
+ containerRef.current = document.getElementsByTagName("main")[0];
24
+ }, []);
25
+ return /* @__PURE__ */ jsx(Dialog.Portal, { container: containerRef.current, children: /* @__PURE__ */ jsxs(ThemeProvider, { children: [
26
+ /* @__PURE__ */ jsx(Dialog.Overlay, { className: "DrawerOverlay" }),
27
+ /* @__PURE__ */ jsx(
28
+ Dialog.Content,
29
+ __spreadValues({
30
+ className: `DrawerContent ${position} ${className || ""}`
31
+ }, rest)
32
+ ),
33
+ /* @__PURE__ */ jsx(ToastContainer, {})
34
+ ] }) });
35
+ }
36
+ function Trigger2(props) {
37
+ return /* @__PURE__ */ jsx(Dialog.Trigger, __spreadValues({ asChild: true }, props));
38
+ }
39
+ var Drawer = {
40
+ Root: Dialog.Root,
41
+ Trigger: Trigger2,
42
+ Content: Content2,
43
+ Close: Dialog.Close,
44
+ Title: Dialog.Title,
45
+ Description: Dialog.Description
46
+ };
47
+
48
+ export {
49
+ Root2 as Root,
50
+ Content2 as Content,
51
+ Trigger2 as Trigger,
52
+ Drawer
53
+ };
54
+ //# sourceMappingURL=chunk-TQGM4VHP.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/atoms/drawer.tsx"],"sourcesContent":["import React, { useEffect, useRef } from 'react';\nimport * as Dialog from '@radix-ui/react-dialog';\nimport { ThemeProvider } from '../theme/theme-provider';\nimport { ToastContainer } from './toast';\n\nexport function Root(props: Dialog.DialogProps): React.ReactNode {\n return <Dialog.Root {...props} />;\n}\n\ntype ContentProps = Dialog.DialogContentProps & {\n /** Drawer가 붙는 위치, 기본값 right */\n position?: 'left' | 'right' | 'bottom' | 'top';\n};\n\nexport function Content(props: ContentProps): React.ReactNode {\n const { position = 'right', className, ...rest } = props;\n\n const containerRef = useRef<HTMLElement | null>(null);\n\n useEffect(() => {\n containerRef.current = document.getElementsByTagName('main')[0];\n }, []);\n\n return (\n <Dialog.Portal container={containerRef.current}>\n <ThemeProvider>\n <Dialog.Overlay className=\"DrawerOverlay\" />\n <Dialog.Content\n className={`DrawerContent ${position} ${className || ''}`}\n {...rest}\n />\n <ToastContainer />\n </ThemeProvider>\n </Dialog.Portal>\n );\n}\n\nexport function Trigger(props: Dialog.DialogTriggerProps): React.ReactNode {\n return <Dialog.Trigger asChild {...props} />;\n}\n\nexport const Drawer = {\n Root: Dialog.Root,\n Trigger,\n Content,\n Close: Dialog.Close,\n Title: Dialog.Title,\n Description: Dialog.Description,\n};\n"],"mappings":";;;;;;;;;;;;AAAA,SAAgB,WAAW,cAAc;AACzC,YAAY,YAAY;AAKf,cAmBH,YAnBG;AADF,SAASA,MAAK,OAA4C;AAC/D,SAAO,oBAAQ,aAAP,mBAAgB,MAAO;AACjC;AAOO,SAASC,SAAQ,OAAsC;AAC5D,QAAmD,YAA3C,aAAW,SAAS,UAf9B,IAeqD,IAAT,iBAAS,IAAT,CAAlC,YAAoB;AAE5B,QAAM,eAAe,OAA2B,IAAI;AAEpD,YAAU,MAAM;AACd,iBAAa,UAAU,SAAS,qBAAqB,MAAM,EAAE,CAAC;AAAA,EAChE,GAAG,CAAC,CAAC;AAEL,SACE,oBAAQ,eAAP,EAAc,WAAW,aAAa,SACrC,+BAAC,iBACC;AAAA,wBAAQ,gBAAP,EAAe,WAAU,iBAAgB;AAAA,IAC1C;AAAA,MAAQ;AAAA,MAAP;AAAA,QACC,WAAW,iBAAiB,QAAQ,IAAI,aAAa,EAAE;AAAA,SACnD;AAAA,IACN;AAAA,IACA,oBAAC,kBAAe;AAAA,KAClB,GACF;AAEJ;AAEO,SAASC,SAAQ,OAAmD;AACzE,SAAO,oBAAQ,gBAAP,iBAAe,SAAO,QAAK,MAAO;AAC5C;AAEO,IAAM,SAAS;AAAA,EACpB,MAAa;AAAA,EACb,SAAAA;AAAA,EACA,SAAAD;AAAA,EACA,OAAc;AAAA,EACd,OAAc;AAAA,EACd,aAAoB;AACtB;","names":["Root","Content","Trigger"]}
@@ -0,0 +1,54 @@
1
+ import {
2
+ ToastContainer
3
+ } from "./chunk-74WGHMXE.js";
4
+ import {
5
+ ThemeProvider
6
+ } from "./chunk-BVBX6IJ3.js";
7
+ import {
8
+ __objRest,
9
+ __spreadValues
10
+ } from "./chunk-N552FDTV.js";
11
+
12
+ // src/atoms/drawer.tsx
13
+ import { useEffect, useRef } from "react";
14
+ import * as Dialog from "@radix-ui/react-dialog";
15
+ import { jsx, jsxs } from "react/jsx-runtime";
16
+ function Root2(props) {
17
+ return /* @__PURE__ */ jsx(Dialog.Root, __spreadValues({}, props));
18
+ }
19
+ function Content2(props) {
20
+ const _a = props, { position = "right", className } = _a, rest = __objRest(_a, ["position", "className"]);
21
+ const containerRef = useRef(null);
22
+ useEffect(() => {
23
+ containerRef.current = document.getElementsByTagName("main")[0];
24
+ }, []);
25
+ return /* @__PURE__ */ jsx(Dialog.Portal, { container: containerRef.current, children: /* @__PURE__ */ jsxs(ThemeProvider, { children: [
26
+ /* @__PURE__ */ jsx(Dialog.Overlay, { className: "DrawerOverlay" }),
27
+ /* @__PURE__ */ jsx(
28
+ Dialog.Content,
29
+ __spreadValues({
30
+ className: `DrawerContent ${position} ${className || ""}`
31
+ }, rest)
32
+ ),
33
+ /* @__PURE__ */ jsx(ToastContainer, {})
34
+ ] }) });
35
+ }
36
+ function Trigger2(props) {
37
+ return /* @__PURE__ */ jsx(Dialog.Trigger, __spreadValues({ asChild: true }, props));
38
+ }
39
+ var Drawer = {
40
+ Root: Dialog.Root,
41
+ Trigger: Trigger2,
42
+ Content: Content2,
43
+ Close: Dialog.Close,
44
+ Title: Dialog.Title,
45
+ Description: Dialog.Description
46
+ };
47
+
48
+ export {
49
+ Root2 as Root,
50
+ Content2 as Content,
51
+ Trigger2 as Trigger,
52
+ Drawer
53
+ };
54
+ //# sourceMappingURL=chunk-W5VTZW3O.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/atoms/drawer.tsx"],"sourcesContent":["import React, { useEffect, useRef } from 'react';\nimport * as Dialog from '@radix-ui/react-dialog';\nimport { ThemeProvider } from '../theme/theme-provider';\nimport { ToastContainer } from './toast';\n\nexport function Root(props: Dialog.DialogProps): React.ReactNode {\n return <Dialog.Root {...props} />;\n}\n\ntype ContentProps = Dialog.DialogContentProps & {\n /** Drawer가 붙는 위치, 기본값 right */\n position?: 'left' | 'right' | 'bottom' | 'top';\n};\n\nexport function Content(props: ContentProps): React.ReactNode {\n const { position = 'right', className, ...rest } = props;\n\n const containerRef = useRef<HTMLElement | null>(null);\n\n useEffect(() => {\n containerRef.current = document.getElementsByTagName('main')[0];\n }, []);\n\n return (\n <Dialog.Portal container={containerRef.current}>\n <ThemeProvider>\n <Dialog.Overlay className=\"DrawerOverlay\" />\n <Dialog.Content\n className={`DrawerContent ${position} ${className || ''}`}\n {...rest}\n />\n <ToastContainer />\n </ThemeProvider>\n </Dialog.Portal>\n );\n}\n\nexport function Trigger(props: Dialog.DialogTriggerProps): React.ReactNode {\n return <Dialog.Trigger asChild {...props} />;\n}\n\nexport const Drawer = {\n Root: Dialog.Root,\n Trigger,\n Content,\n Close: Dialog.Close,\n Title: Dialog.Title,\n Description: Dialog.Description,\n};\n"],"mappings":";;;;;;;;;;;;AAAA,SAAgB,WAAW,cAAc;AACzC,YAAY,YAAY;AAKf,cAmBH,YAnBG;AADF,SAASA,MAAK,OAA4C;AAC/D,SAAO,oBAAQ,aAAP,mBAAgB,MAAO;AACjC;AAOO,SAASC,SAAQ,OAAsC;AAC5D,QAAmD,YAA3C,aAAW,SAAS,UAf9B,IAeqD,IAAT,iBAAS,IAAT,CAAlC,YAAoB;AAE5B,QAAM,eAAe,OAA2B,IAAI;AAEpD,YAAU,MAAM;AACd,iBAAa,UAAU,SAAS,qBAAqB,MAAM,EAAE,CAAC;AAAA,EAChE,GAAG,CAAC,CAAC;AAEL,SACE,oBAAQ,eAAP,EAAc,WAAW,aAAa,SACrC,+BAAC,iBACC;AAAA,wBAAQ,gBAAP,EAAe,WAAU,iBAAgB;AAAA,IAC1C;AAAA,MAAQ;AAAA,MAAP;AAAA,QACC,WAAW,iBAAiB,QAAQ,IAAI,aAAa,EAAE;AAAA,SACnD;AAAA,IACN;AAAA,IACA,oBAAC,kBAAe;AAAA,KAClB,GACF;AAEJ;AAEO,SAASC,SAAQ,OAAmD;AACzE,SAAO,oBAAQ,gBAAP,iBAAe,SAAO,QAAK,MAAO;AAC5C;AAEO,IAAM,SAAS;AAAA,EACpB,MAAa;AAAA,EACb,SAAAA;AAAA,EACA,SAAAD;AAAA,EACA,OAAc;AAAA,EACd,OAAc;AAAA,EACd,aAAoB;AACtB;","names":["Root","Content","Trigger"]}
@@ -0,0 +1,59 @@
1
+ import {
2
+ ThemeProvider
3
+ } from "./chunk-BVBX6IJ3.js";
4
+ import {
5
+ ToastContainer
6
+ } from "./chunk-NJ2U2TVS.js";
7
+ import {
8
+ __objRest,
9
+ __spreadProps,
10
+ __spreadValues
11
+ } from "./chunk-N552FDTV.js";
12
+
13
+ // src/atoms/drawer.tsx
14
+ import { useEffect, useRef } from "react";
15
+ import * as Dialog from "@radix-ui/react-dialog";
16
+ import { jsx, jsxs } from "react/jsx-runtime";
17
+ function Root2(props) {
18
+ return /* @__PURE__ */ jsx(Dialog.Root, __spreadValues({}, props));
19
+ }
20
+ function Content2(props) {
21
+ const _a = props, { position = "right", className, children } = _a, rest = __objRest(_a, ["position", "className", "children"]);
22
+ const containerRef = useRef(null);
23
+ useEffect(() => {
24
+ containerRef.current = document.getElementsByTagName("main")[0];
25
+ }, []);
26
+ return /* @__PURE__ */ jsx(Dialog.Portal, { container: containerRef.current, children: /* @__PURE__ */ jsxs(ThemeProvider, { children: [
27
+ /* @__PURE__ */ jsx(Dialog.Overlay, { className: "DrawerOverlay" }),
28
+ /* @__PURE__ */ jsxs(
29
+ Dialog.Content,
30
+ __spreadProps(__spreadValues({
31
+ className: `DrawerContent ${position} ${className || ""}`
32
+ }, rest), {
33
+ children: [
34
+ /* @__PURE__ */ jsx(ToastContainer, {}),
35
+ children
36
+ ]
37
+ })
38
+ )
39
+ ] }) });
40
+ }
41
+ function Trigger2(props) {
42
+ return /* @__PURE__ */ jsx(Dialog.Trigger, __spreadValues({ asChild: true }, props));
43
+ }
44
+ var Drawer = {
45
+ Root: Dialog.Root,
46
+ Trigger: Trigger2,
47
+ Content: Content2,
48
+ Close: Dialog.Close,
49
+ Title: Dialog.Title,
50
+ Description: Dialog.Description
51
+ };
52
+
53
+ export {
54
+ Root2 as Root,
55
+ Content2 as Content,
56
+ Trigger2 as Trigger,
57
+ Drawer
58
+ };
59
+ //# sourceMappingURL=chunk-WV7FE4LE.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/atoms/drawer.tsx"],"sourcesContent":["import React, { useEffect, useRef } from 'react';\nimport * as Dialog from '@radix-ui/react-dialog';\nimport { ThemeProvider } from '../theme/theme-provider';\nimport { ToastContainer } from './toast';\n\nexport function Root(props: Dialog.DialogProps): React.ReactNode {\n return <Dialog.Root {...props} />;\n}\n\ntype ContentProps = Dialog.DialogContentProps & {\n /** Drawer가 붙는 위치, 기본값 right */\n position?: 'left' | 'right' | 'bottom' | 'top';\n};\n\nexport function Content(props: ContentProps): React.ReactNode {\n const { position = 'right', className, children, ...rest } = props;\n\n const containerRef = useRef<HTMLElement | null>(null);\n\n useEffect(() => {\n containerRef.current = document.getElementsByTagName('main')[0];\n }, []);\n\n return (\n <Dialog.Portal container={containerRef.current}>\n <ThemeProvider>\n <Dialog.Overlay className=\"DrawerOverlay\" />\n <Dialog.Content\n className={`DrawerContent ${position} ${className || ''}`}\n {...rest}\n >\n <ToastContainer />\n {children}\n </Dialog.Content>\n </ThemeProvider>\n </Dialog.Portal>\n );\n}\n\nexport function Trigger(props: Dialog.DialogTriggerProps): React.ReactNode {\n return <Dialog.Trigger asChild {...props} />;\n}\n\nexport const Drawer = {\n Root: Dialog.Root,\n Trigger,\n Content,\n Close: Dialog.Close,\n Title: Dialog.Title,\n Description: Dialog.Description,\n};\n"],"mappings":";;;;;;;;;;;;;AAAA,SAAgB,WAAW,cAAc;AACzC,YAAY,YAAY;AAKf,cAqBD,YArBC;AADF,SAASA,MAAK,OAA4C;AAC/D,SAAO,oBAAQ,aAAP,mBAAgB,MAAO;AACjC;AAOO,SAASC,SAAQ,OAAsC;AAC5D,QAA6D,YAArD,aAAW,SAAS,WAAW,SAfzC,IAe+D,IAAT,iBAAS,IAAT,CAA5C,YAAoB,aAAW;AAEvC,QAAM,eAAe,OAA2B,IAAI;AAEpD,YAAU,MAAM;AACd,iBAAa,UAAU,SAAS,qBAAqB,MAAM,EAAE,CAAC;AAAA,EAChE,GAAG,CAAC,CAAC;AAEL,SACE,oBAAQ,eAAP,EAAc,WAAW,aAAa,SACrC,+BAAC,iBACC;AAAA,wBAAQ,gBAAP,EAAe,WAAU,iBAAgB;AAAA,IAC1C;AAAA,MAAQ;AAAA,MAAP;AAAA,QACC,WAAW,iBAAiB,QAAQ,IAAI,aAAa,EAAE;AAAA,SACnD,OAFL;AAAA,QAIC;AAAA,8BAAC,kBAAe;AAAA,UACf;AAAA;AAAA;AAAA,IACH;AAAA,KACF,GACF;AAEJ;AAEO,SAASC,SAAQ,OAAmD;AACzE,SAAO,oBAAQ,gBAAP,iBAAe,SAAO,QAAK,MAAO;AAC5C;AAEO,IAAM,SAAS;AAAA,EACpB,MAAa;AAAA,EACb,SAAAA;AAAA,EACA,SAAAD;AAAA,EACA,OAAc;AAAA,EACd,OAAc;AAAA,EACd,aAAoB;AACtB;","names":["Root","Content","Trigger"]}
@@ -0,0 +1,50 @@
1
+ import {
2
+ ThemeProvider
3
+ } from "./chunk-BVBX6IJ3.js";
4
+ import {
5
+ __objRest,
6
+ __spreadValues
7
+ } from "./chunk-N552FDTV.js";
8
+
9
+ // src/atoms/drawer.tsx
10
+ import { useEffect, useRef } from "react";
11
+ import * as Dialog from "@radix-ui/react-dialog";
12
+ import { jsx, jsxs } from "react/jsx-runtime";
13
+ function Root2(props) {
14
+ return /* @__PURE__ */ jsx(Dialog.Root, __spreadValues({}, props));
15
+ }
16
+ function Content2(props) {
17
+ const _a = props, { position = "right", className } = _a, rest = __objRest(_a, ["position", "className"]);
18
+ const containerRef = useRef(null);
19
+ useEffect(() => {
20
+ containerRef.current = document.getElementsByTagName("main")[0];
21
+ }, []);
22
+ return /* @__PURE__ */ jsx(Dialog.Portal, { container: containerRef.current, children: /* @__PURE__ */ jsxs(ThemeProvider, { children: [
23
+ /* @__PURE__ */ jsx(Dialog.Overlay, { className: "DrawerOverlay" }),
24
+ /* @__PURE__ */ jsx(
25
+ Dialog.Content,
26
+ __spreadValues({
27
+ className: `DrawerContent ${position} ${className || ""}`
28
+ }, rest)
29
+ )
30
+ ] }) });
31
+ }
32
+ function Trigger2(props) {
33
+ return /* @__PURE__ */ jsx(Dialog.Trigger, __spreadValues({ asChild: true }, props));
34
+ }
35
+ var Drawer = {
36
+ Root: Dialog.Root,
37
+ Trigger: Trigger2,
38
+ Content: Content2,
39
+ Close: Dialog.Close,
40
+ Title: Dialog.Title,
41
+ Description: Dialog.Description
42
+ };
43
+
44
+ export {
45
+ Root2 as Root,
46
+ Content2 as Content,
47
+ Trigger2 as Trigger,
48
+ Drawer
49
+ };
50
+ //# sourceMappingURL=chunk-X73G236I.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/atoms/drawer.tsx"],"sourcesContent":["import React, { useEffect, useRef } from 'react';\nimport * as Dialog from '@radix-ui/react-dialog';\nimport { ThemeProvider } from '../theme/theme-provider';\nimport { ToastContainer } from './toast';\n\nexport function Root(props: Dialog.DialogProps): React.ReactNode {\n return <Dialog.Root {...props} />;\n}\n\ntype ContentProps = Dialog.DialogContentProps & {\n /** Drawer가 붙는 위치, 기본값 right */\n position?: 'left' | 'right' | 'bottom' | 'top';\n};\n\nexport function Content(props: ContentProps): React.ReactNode {\n const { position = 'right', className, ...rest } = props;\n\n const containerRef = useRef<HTMLElement | null>(null);\n\n useEffect(() => {\n containerRef.current = document.getElementsByTagName('main')[0];\n }, []);\n\n return (\n <Dialog.Portal container={containerRef.current}>\n <ThemeProvider>\n <Dialog.Overlay className=\"DrawerOverlay\" />\n <Dialog.Content\n className={`DrawerContent ${position} ${className || ''}`}\n {...rest}\n />\n {/* <ToastContainer /> */}\n </ThemeProvider>\n </Dialog.Portal>\n );\n}\n\nexport function Trigger(props: Dialog.DialogTriggerProps): React.ReactNode {\n return <Dialog.Trigger asChild {...props} />;\n}\n\nexport const Drawer = {\n Root: Dialog.Root,\n Trigger,\n Content,\n Close: Dialog.Close,\n Title: Dialog.Title,\n Description: Dialog.Description,\n};\n"],"mappings":";;;;;;;;;AAAA,SAAgB,WAAW,cAAc;AACzC,YAAY,YAAY;AAKf,cAmBH,YAnBG;AADF,SAASA,MAAK,OAA4C;AAC/D,SAAO,oBAAQ,aAAP,mBAAgB,MAAO;AACjC;AAOO,SAASC,SAAQ,OAAsC;AAC5D,QAAmD,YAA3C,aAAW,SAAS,UAf9B,IAeqD,IAAT,iBAAS,IAAT,CAAlC,YAAoB;AAE5B,QAAM,eAAe,OAA2B,IAAI;AAEpD,YAAU,MAAM;AACd,iBAAa,UAAU,SAAS,qBAAqB,MAAM,EAAE,CAAC;AAAA,EAChE,GAAG,CAAC,CAAC;AAEL,SACE,oBAAQ,eAAP,EAAc,WAAW,aAAa,SACrC,+BAAC,iBACC;AAAA,wBAAQ,gBAAP,EAAe,WAAU,iBAAgB;AAAA,IAC1C;AAAA,MAAQ;AAAA,MAAP;AAAA,QACC,WAAW,iBAAiB,QAAQ,IAAI,aAAa,EAAE;AAAA,SACnD;AAAA,IACN;AAAA,KAEF,GACF;AAEJ;AAEO,SAASC,SAAQ,OAAmD;AACzE,SAAO,oBAAQ,gBAAP,iBAAe,SAAO,QAAK,MAAO;AAC5C;AAEO,IAAM,SAAS;AAAA,EACpB,MAAa;AAAA,EACb,SAAAA;AAAA,EACA,SAAAD;AAAA,EACA,OAAc;AAAA,EACd,OAAc;AAAA,EACd,aAAoB;AACtB;","names":["Root","Content","Trigger"]}
@@ -0,0 +1,54 @@
1
+ import {
2
+ ToastContainer
3
+ } from "./chunk-6T66J7SC.js";
4
+ import {
5
+ ThemeProvider
6
+ } from "./chunk-BVBX6IJ3.js";
7
+ import {
8
+ __objRest,
9
+ __spreadValues
10
+ } from "./chunk-N552FDTV.js";
11
+
12
+ // src/atoms/drawer.tsx
13
+ import { useEffect, useRef } from "react";
14
+ import * as Dialog from "@radix-ui/react-dialog";
15
+ import { jsx, jsxs } from "react/jsx-runtime";
16
+ function Root2(props) {
17
+ return /* @__PURE__ */ jsx(Dialog.Root, __spreadValues({}, props));
18
+ }
19
+ function Content2(props) {
20
+ const _a = props, { position = "right", className } = _a, rest = __objRest(_a, ["position", "className"]);
21
+ const containerRef = useRef(null);
22
+ useEffect(() => {
23
+ containerRef.current = document.getElementsByTagName("main")[0];
24
+ }, []);
25
+ return /* @__PURE__ */ jsx(Dialog.Portal, { container: containerRef.current, children: /* @__PURE__ */ jsxs(ThemeProvider, { children: [
26
+ /* @__PURE__ */ jsx(Dialog.Overlay, { className: "DrawerOverlay" }),
27
+ /* @__PURE__ */ jsx(
28
+ Dialog.Content,
29
+ __spreadValues({
30
+ className: `DrawerContent ${position} ${className || ""}`
31
+ }, rest)
32
+ ),
33
+ /* @__PURE__ */ jsx(ToastContainer, {})
34
+ ] }) });
35
+ }
36
+ function Trigger2(props) {
37
+ return /* @__PURE__ */ jsx(Dialog.Trigger, __spreadValues({ asChild: true }, props));
38
+ }
39
+ var Drawer = {
40
+ Root: Dialog.Root,
41
+ Trigger: Trigger2,
42
+ Content: Content2,
43
+ Close: Dialog.Close,
44
+ Title: Dialog.Title,
45
+ Description: Dialog.Description
46
+ };
47
+
48
+ export {
49
+ Root2 as Root,
50
+ Content2 as Content,
51
+ Trigger2 as Trigger,
52
+ Drawer
53
+ };
54
+ //# sourceMappingURL=chunk-YKJPZGZD.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/atoms/drawer.tsx"],"sourcesContent":["import React, { useEffect, useRef } from 'react';\nimport * as Dialog from '@radix-ui/react-dialog';\nimport { ThemeProvider } from '../theme/theme-provider';\nimport { ToastContainer } from './toast';\n\nexport function Root(props: Dialog.DialogProps): React.ReactNode {\n return <Dialog.Root {...props} />;\n}\n\ntype ContentProps = Dialog.DialogContentProps & {\n /** Drawer가 붙는 위치, 기본값 right */\n position?: 'left' | 'right' | 'bottom' | 'top';\n};\n\nexport function Content(props: ContentProps): React.ReactNode {\n const { position = 'right', className, ...rest } = props;\n\n const containerRef = useRef<HTMLElement | null>(null);\n\n useEffect(() => {\n containerRef.current = document.getElementsByTagName('main')[0];\n }, []);\n\n return (\n <Dialog.Portal container={containerRef.current}>\n <ThemeProvider>\n <Dialog.Overlay className=\"DrawerOverlay\" />\n <Dialog.Content\n className={`DrawerContent ${position} ${className || ''}`}\n {...rest}\n />\n <ToastContainer />\n </ThemeProvider>\n </Dialog.Portal>\n );\n}\n\nexport function Trigger(props: Dialog.DialogTriggerProps): React.ReactNode {\n return <Dialog.Trigger asChild {...props} />;\n}\n\nexport const Drawer = {\n Root: Dialog.Root,\n Trigger,\n Content,\n Close: Dialog.Close,\n Title: Dialog.Title,\n Description: Dialog.Description,\n};\n"],"mappings":";;;;;;;;;;;;AAAA,SAAgB,WAAW,cAAc;AACzC,YAAY,YAAY;AAKf,cAmBH,YAnBG;AADF,SAASA,MAAK,OAA4C;AAC/D,SAAO,oBAAQ,aAAP,mBAAgB,MAAO;AACjC;AAOO,SAASC,SAAQ,OAAsC;AAC5D,QAAmD,YAA3C,aAAW,SAAS,UAf9B,IAeqD,IAAT,iBAAS,IAAT,CAAlC,YAAoB;AAE5B,QAAM,eAAe,OAA2B,IAAI;AAEpD,YAAU,MAAM;AACd,iBAAa,UAAU,SAAS,qBAAqB,MAAM,EAAE,CAAC;AAAA,EAChE,GAAG,CAAC,CAAC;AAEL,SACE,oBAAQ,eAAP,EAAc,WAAW,aAAa,SACrC,+BAAC,iBACC;AAAA,wBAAQ,gBAAP,EAAe,WAAU,iBAAgB;AAAA,IAC1C;AAAA,MAAQ;AAAA,MAAP;AAAA,QACC,WAAW,iBAAiB,QAAQ,IAAI,aAAa,EAAE;AAAA,SACnD;AAAA,IACN;AAAA,IACA,oBAAC,kBAAe;AAAA,KAClB,GACF;AAEJ;AAEO,SAASC,SAAQ,OAAmD;AACzE,SAAO,oBAAQ,gBAAP,iBAAe,SAAO,QAAK,MAAO;AAC5C;AAEO,IAAM,SAAS;AAAA,EACpB,MAAa;AAAA,EACb,SAAAA;AAAA,EACA,SAAAD;AAAA,EACA,OAAc;AAAA,EACd,OAAc;AAAA,EACd,aAAoB;AACtB;","names":["Root","Content","Trigger"]}
@@ -0,0 +1,123 @@
1
+ import {
2
+ Row
3
+ } from "./chunk-JFKC7O5G.js";
4
+ import {
5
+ TriangleArrowUpIcon
6
+ } from "./chunk-NDUKDKGB.js";
7
+ import {
8
+ Typo
9
+ } from "./chunk-O3XTRD7R.js";
10
+ import {
11
+ Flex
12
+ } from "./chunk-25HMMI7R.js";
13
+ import {
14
+ TriangleArrowDownIcon
15
+ } from "./chunk-BSTJBBEX.js";
16
+
17
+ // src/molecules/expand-table/index.tsx
18
+ import {
19
+ flexRender,
20
+ getCoreRowModel,
21
+ useReactTable,
22
+ getSortedRowModel,
23
+ createColumnHelper
24
+ } from "@tanstack/react-table";
25
+ import { useMemo, useState } from "react";
26
+ import { jsx, jsxs } from "react/jsx-runtime";
27
+ function ExpandTable(props) {
28
+ const { data, columns, ExpandComp, placeholder, onRowClick, tableStyle } = props;
29
+ const defaultAlign = "left";
30
+ const [sorting, setSorting] = useState([]);
31
+ const { getRowModel, getHeaderGroups } = useReactTable({
32
+ data: data || [],
33
+ columns,
34
+ getCoreRowModel: getCoreRowModel(),
35
+ getSortedRowModel: getSortedRowModel(),
36
+ state: {
37
+ sorting
38
+ },
39
+ onSortingChange: setSorting
40
+ });
41
+ const gridColTemp = useMemo(() => {
42
+ return columns.map((col) => {
43
+ var _a;
44
+ if ((_a = col.meta) == null ? void 0 : _a.autoSize)
45
+ return "1fr";
46
+ return `${col.size || 150}px`;
47
+ }).join(" ");
48
+ }, [columns]);
49
+ const rowModels = getRowModel();
50
+ return /* @__PURE__ */ jsxs("div", { className: "expand-table", style: tableStyle, children: [
51
+ /* @__PURE__ */ jsx("div", { className: "thead", children: getHeaderGroups().map((headerGroup) => /* @__PURE__ */ jsx(
52
+ "div",
53
+ {
54
+ className: "tr",
55
+ style: { gridTemplateColumns: gridColTemp },
56
+ children: headerGroup.headers.map((header) => {
57
+ var _a;
58
+ const sortable = header.column.getCanSort();
59
+ const sortedState = header.column.getIsSorted();
60
+ const justifyContent = ((_a = header.column.columnDef.meta) == null ? void 0 : _a.align) || defaultAlign;
61
+ return /* @__PURE__ */ jsx("div", { className: `${justifyContent} th`, children: /* @__PURE__ */ jsxs(
62
+ "button",
63
+ {
64
+ onClick: header.column.getToggleSortingHandler(),
65
+ style: sortable ? { cursor: "pointer" } : void 0,
66
+ type: "button",
67
+ children: [
68
+ /* @__PURE__ */ jsx(Typo, { variant: "body", children: flexRender(
69
+ header.column.columnDef.header,
70
+ header.getContext()
71
+ ) }),
72
+ sortable ? /* @__PURE__ */ jsxs(
73
+ Flex,
74
+ {
75
+ direction: "column",
76
+ style: { marginLeft: "var(--space-2)" },
77
+ children: [
78
+ /* @__PURE__ */ jsx(
79
+ TriangleArrowUpIcon,
80
+ {
81
+ color: sortedState === "asc" ? "var(--iris-10)" : "var(--iris-6)"
82
+ }
83
+ ),
84
+ /* @__PURE__ */ jsx(
85
+ TriangleArrowDownIcon,
86
+ {
87
+ color: sortedState === "desc" ? "var(--iris-10)" : "var(--iris-6)"
88
+ }
89
+ )
90
+ ]
91
+ }
92
+ ) : null
93
+ ]
94
+ }
95
+ ) }, header.id);
96
+ })
97
+ },
98
+ headerGroup.id
99
+ )) }),
100
+ /* @__PURE__ */ jsxs("div", { className: "tbody", children: [
101
+ rowModels.rows.length === 0 && /* @__PURE__ */ jsx("div", { className: "tr", children: /* @__PURE__ */ jsx(Flex, { align: "center", justify: "center", children: placeholder || /* @__PURE__ */ jsx(Typo, { color: "gray", mb: "6", mt: "6", variant: "body", children: "\uB370\uC774\uD130\uAC00 \uC5C6\uC2B5\uB2C8\uB2E4" }) }) }, "expand_placeholder"),
102
+ rowModels.rows.map((row) => {
103
+ return /* @__PURE__ */ jsx(
104
+ Row,
105
+ {
106
+ ExpandComp,
107
+ defaultAlign,
108
+ gridColTemp,
109
+ onRowClick,
110
+ row
111
+ },
112
+ `row_${row.id}`
113
+ );
114
+ })
115
+ ] })
116
+ ] });
117
+ }
118
+
119
+ export {
120
+ createColumnHelper,
121
+ ExpandTable
122
+ };
123
+ //# sourceMappingURL=chunk-YYQEUHIE.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/molecules/expand-table/index.tsx"],"sourcesContent":["import type {\n ColumnDef,\n SortingState,\n RowData,\n Row as RowType,\n} from '@tanstack/react-table';\nimport type { CSSProperties } from 'react';\nimport {\n flexRender,\n getCoreRowModel,\n useReactTable,\n getSortedRowModel,\n createColumnHelper,\n} from '@tanstack/react-table';\nimport React, { useMemo, useState } from 'react';\nimport { Flex, Typo } from '../../atoms';\nimport { TriangleArrowDownIcon } from '../../icons/down';\nimport { TriangleArrowUpIcon } from '../../icons/up';\nimport { Row, type ExpandComp, type OnRowClick } from './row';\n\nexport type { ExpandComp, OnRowClick, ColumnDef, RowType as Row };\nexport { createColumnHelper };\n\nexport interface ExpandTableProps<Datum extends RowData> {\n /** 렌더할 데이터 배열 */\n data?: Datum[];\n /** 테이블 컬럼의 메타 데이터 */\n columns: ColumnDef<Datum>[];\n /** Row의 open이 true인 경우 하단의 collapse에 렌더할 컴포넌트 */\n ExpandComp?: ExpandComp<Datum>;\n /** 데이테가 없을 시 화면에 표시할 컴포넌트 */\n placeholder?: React.ReactNode;\n /** 행 클릭 시 실행할 콜백 */\n onRowClick?: OnRowClick<Datum>;\n rowStyle?: CSSProperties;\n tableStyle?: CSSProperties;\n}\n\nexport function ExpandTable<Datum extends RowData>(\n props: ExpandTableProps<Datum>\n): React.ReactNode {\n const { data, columns, ExpandComp, placeholder, onRowClick, tableStyle } =\n props;\n const defaultAlign = 'left';\n const [sorting, setSorting] = useState<SortingState>([]);\n const { getRowModel, getHeaderGroups } = useReactTable({\n data: data || [],\n columns,\n getCoreRowModel: getCoreRowModel(),\n getSortedRowModel: getSortedRowModel(),\n state: {\n sorting,\n },\n onSortingChange: setSorting,\n });\n\n const gridColTemp = useMemo<string>(() => {\n return columns\n .map((col) => {\n if (col.meta?.autoSize) return '1fr';\n return `${col.size || 150}px`;\n })\n .join(' ');\n }, [columns]);\n\n const rowModels = getRowModel();\n\n return (\n <div className=\"expand-table\" style={tableStyle}>\n <div className=\"thead\">\n {getHeaderGroups().map((headerGroup) => (\n <div\n className=\"tr\"\n key={headerGroup.id}\n style={{ gridTemplateColumns: gridColTemp }}\n >\n {headerGroup.headers.map((header) => {\n const sortable = header.column.getCanSort();\n const sortedState = header.column.getIsSorted();\n const justifyContent =\n header.column.columnDef.meta?.align || defaultAlign;\n\n return (\n <div className={`${justifyContent} th`} key={header.id}>\n <button\n onClick={header.column.getToggleSortingHandler()}\n style={sortable ? { cursor: 'pointer' } : undefined}\n type=\"button\"\n >\n <Typo variant=\"body\">\n {flexRender(\n header.column.columnDef.header,\n header.getContext()\n )}\n </Typo>\n {sortable ? (\n <Flex\n direction=\"column\"\n style={{ marginLeft: 'var(--space-2)' }}\n >\n <TriangleArrowUpIcon\n color={\n sortedState === 'asc'\n ? 'var(--iris-10)'\n : 'var(--iris-6)'\n }\n />\n <TriangleArrowDownIcon\n color={\n sortedState === 'desc'\n ? 'var(--iris-10)'\n : 'var(--iris-6)'\n }\n />\n </Flex>\n ) : null}\n </button>\n </div>\n );\n })}\n </div>\n ))}\n </div>\n <div className=\"tbody\">\n {/* 데이터가 없을 시 표시되는 노드 */}\n {rowModels.rows.length === 0 && (\n <div className=\"tr\" key=\"expand_placeholder\">\n <Flex align=\"center\" justify=\"center\">\n {placeholder || (\n <Typo color=\"gray\" mb=\"6\" mt=\"6\" variant=\"body\">\n 데이터가 없습니다\n </Typo>\n )}\n </Flex>\n </div>\n )}\n\n {/* 행을 렌더하는 로직 */}\n {rowModels.rows.map((row) => {\n return (\n <Row\n ExpandComp={ExpandComp}\n defaultAlign={defaultAlign}\n gridColTemp={gridColTemp}\n key={`row_${row.id}`}\n onRowClick={onRowClick}\n row={row}\n />\n );\n })}\n </div>\n </div>\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;AAOA;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,SAAgB,SAAS,gBAAgB;AA2ErB,cAOE,YAPF;AAnDb,SAAS,YACd,OACiB;AACjB,QAAM,EAAE,MAAM,SAAS,YAAY,aAAa,YAAY,WAAW,IACrE;AACF,QAAM,eAAe;AACrB,QAAM,CAAC,SAAS,UAAU,IAAI,SAAuB,CAAC,CAAC;AACvD,QAAM,EAAE,aAAa,gBAAgB,IAAI,cAAc;AAAA,IACrD,MAAM,QAAQ,CAAC;AAAA,IACf;AAAA,IACA,iBAAiB,gBAAgB;AAAA,IACjC,mBAAmB,kBAAkB;AAAA,IACrC,OAAO;AAAA,MACL;AAAA,IACF;AAAA,IACA,iBAAiB;AAAA,EACnB,CAAC;AAED,QAAM,cAAc,QAAgB,MAAM;AACxC,WAAO,QACJ,IAAI,CAAC,QAAQ;AA1DpB;AA2DQ,WAAI,SAAI,SAAJ,mBAAU;AAAU,eAAO;AAC/B,aAAO,GAAG,IAAI,QAAQ,GAAG;AAAA,IAC3B,CAAC,EACA,KAAK,GAAG;AAAA,EACb,GAAG,CAAC,OAAO,CAAC;AAEZ,QAAM,YAAY,YAAY;AAE9B,SACE,qBAAC,SAAI,WAAU,gBAAe,OAAO,YACnC;AAAA,wBAAC,SAAI,WAAU,SACZ,0BAAgB,EAAE,IAAI,CAAC,gBACtB;AAAA,MAAC;AAAA;AAAA,QACC,WAAU;AAAA,QAEV,OAAO,EAAE,qBAAqB,YAAY;AAAA,QAEzC,sBAAY,QAAQ,IAAI,CAAC,WAAW;AA5EjD;AA6Ec,gBAAM,WAAW,OAAO,OAAO,WAAW;AAC1C,gBAAM,cAAc,OAAO,OAAO,YAAY;AAC9C,gBAAM,mBACJ,YAAO,OAAO,UAAU,SAAxB,mBAA8B,UAAS;AAEzC,iBACE,oBAAC,SAAI,WAAW,GAAG,cAAc,OAC/B;AAAA,YAAC;AAAA;AAAA,cACC,SAAS,OAAO,OAAO,wBAAwB;AAAA,cAC/C,OAAO,WAAW,EAAE,QAAQ,UAAU,IAAI;AAAA,cAC1C,MAAK;AAAA,cAEL;AAAA,oCAAC,QAAK,SAAQ,QACX;AAAA,kBACC,OAAO,OAAO,UAAU;AAAA,kBACxB,OAAO,WAAW;AAAA,gBACpB,GACF;AAAA,gBACC,WACC;AAAA,kBAAC;AAAA;AAAA,oBACC,WAAU;AAAA,oBACV,OAAO,EAAE,YAAY,iBAAiB;AAAA,oBAEtC;AAAA;AAAA,wBAAC;AAAA;AAAA,0BACC,OACE,gBAAgB,QACZ,mBACA;AAAA;AAAA,sBAER;AAAA,sBACA;AAAA,wBAAC;AAAA;AAAA,0BACC,OACE,gBAAgB,SACZ,mBACA;AAAA;AAAA,sBAER;AAAA;AAAA;AAAA,gBACF,IACE;AAAA;AAAA;AAAA,UACN,KAjC2C,OAAO,EAkCpD;AAAA,QAEJ,CAAC;AAAA;AAAA,MA9CI,YAAY;AAAA,IA+CnB,CACD,GACH;AAAA,IACA,qBAAC,SAAI,WAAU,SAEZ;AAAA,gBAAU,KAAK,WAAW,KACzB,oBAAC,SAAI,WAAU,MACb,8BAAC,QAAK,OAAM,UAAS,SAAQ,UAC1B,yBACC,oBAAC,QAAK,OAAM,QAAO,IAAG,KAAI,IAAG,KAAI,SAAQ,QAAO,+DAEhD,GAEJ,KAPsB,oBAQxB;AAAA,MAID,UAAU,KAAK,IAAI,CAAC,QAAQ;AAC3B,eACE;AAAA,UAAC;AAAA;AAAA,YACC;AAAA,YACA;AAAA,YACA;AAAA,YAEA;AAAA,YACA;AAAA;AAAA,UAFK,OAAO,IAAI,EAAE;AAAA,QAGpB;AAAA,MAEJ,CAAC;AAAA,OACH;AAAA,KACF;AAEJ;","names":[]}