sales-frontend-components 0.0.51 → 0.0.52

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.esm.js CHANGED
@@ -1,11 +1,94 @@
1
- import { jsxs, jsx } from 'react/jsx-runtime';
2
- import { flexRender, useReactTable, getSortedRowModel, getCoreRowModel, getPaginationRowModel } from '@tanstack/react-table';
3
- import { Table, DatePicker, SegmentGroup, FormField, Icon } from 'sales-frontend-design-system';
4
- import styles from './data-table/data-table.module.scss';
5
- import React, { useState, useEffect, useRef, useCallback } from 'react';
1
+ import { jsx, jsxs } from 'react/jsx-runtime';
6
2
  import { useController } from 'react-hook-form';
7
- import styles$1 from './step-indicator/step-indicator.module.scss';
8
- import styles$2 from './camera/camera.module.scss';
3
+ import { DatePicker, SegmentGroup, FormField, Icon } from 'sales-frontend-design-system';
4
+ import React, { useState, useEffect, useRef, useCallback } from 'react';
5
+ import styles from './step-indicator/step-indicator.module.scss';
6
+ import styles$1 from './camera/camera.module.scss';
7
+
8
+ const FormDatePicker = ({
9
+ name,
10
+ control,
11
+ disabled,
12
+ ...props
13
+ }) => {
14
+ const { field, fieldState } = useController({ name, control, disabled });
15
+ const baseProps = {
16
+ ...props,
17
+ id: field.name,
18
+ defaultValue: field.value,
19
+ disabled: field.disabled,
20
+ error: fieldState.invalid,
21
+ onBlur: field.onBlur
22
+ };
23
+ return /* @__PURE__ */ jsx(DatePicker, { ...baseProps });
24
+ };
25
+
26
+ const FormSegmentGroup = ({
27
+ name,
28
+ control,
29
+ disabled,
30
+ ...props
31
+ }) => {
32
+ const { field, fieldState } = useController({ name, control, disabled });
33
+ return /* @__PURE__ */ jsx(
34
+ SegmentGroup,
35
+ {
36
+ ...props,
37
+ tabIndex: 0,
38
+ id: field.name,
39
+ ref: field.ref,
40
+ defaultValue: field.value,
41
+ disabled: field.disabled,
42
+ error: fieldState.invalid,
43
+ onBlur: field.onBlur,
44
+ onValueChange: (selected) => {
45
+ field.onChange(selected);
46
+ props.onValueChange?.(selected);
47
+ }
48
+ }
49
+ );
50
+ };
51
+
52
+ const FormTextField = ({
53
+ name,
54
+ control,
55
+ disabled,
56
+ error,
57
+ onBlur,
58
+ onChange,
59
+ rootProps,
60
+ ...props
61
+ }) => {
62
+ const { field, fieldState } = useController({ name, control, disabled });
63
+ return /* @__PURE__ */ jsx(
64
+ FormField.TextField,
65
+ {
66
+ ...props,
67
+ id: field.name,
68
+ size: "medium",
69
+ autoComplete: "off",
70
+ name: field.name,
71
+ value: field.value ?? "",
72
+ disabled: field.disabled,
73
+ error: fieldState.invalid || error,
74
+ onChange: (e) => {
75
+ field.onChange(e);
76
+ onChange?.(e);
77
+ },
78
+ onBlur: (e) => {
79
+ field.onBlur();
80
+ onBlur?.(e);
81
+ },
82
+ rootProps: {
83
+ ...rootProps,
84
+ onClear: () => {
85
+ field.onChange("");
86
+ rootProps?.onClear?.();
87
+ }
88
+ }
89
+ }
90
+ );
91
+ };
9
92
 
10
93
  function getDefaultExportFromCjs (x) {
11
94
  return x && x.__esModule && Object.prototype.hasOwnProperty.call(x, 'default') ? x['default'] : x;
@@ -98,204 +181,7 @@ function requireBind () {
98
181
  var bindExports = requireBind();
99
182
  var classNames = /*@__PURE__*/getDefaultExportFromCjs(bindExports);
100
183
 
101
- const cx$2 = classNames.bind(styles);
102
- const DataTable = ({ table, isError, isLoading, msgText, ...props }) => {
103
- return /* @__PURE__ */ jsxs(
104
- Table,
105
- {
106
- ...props,
107
- selectable: true,
108
- style: {
109
- // minWidth: table.getCenterTotalSize() // 테이블 전체 너비를 컬럼 너비의 합으로 설정
110
- },
111
- children: [
112
- /* @__PURE__ */ jsx("thead", { children: table.getHeaderGroups().map((headerGroup) => /* @__PURE__ */ jsx("tr", { children: headerGroup.headers.map((header) => /* @__PURE__ */ jsxs(
113
- "th",
114
- {
115
- colSpan: header.colSpan,
116
- className: cx$2({
117
- "is-resizing": header.column.getIsResizing()
118
- // 3. 리사이징 중일 때 클래스 추가
119
- }),
120
- style: header.column.columnDef.size ? { width: header.getSize(), minWidth: header.getSize(), maxWidth: header.getSize() } : void 0,
121
- children: [
122
- header.isPlaceholder ? null : flexRender(header.column.columnDef.header, header.getContext()),
123
- header.column.getCanResize() && /* @__PURE__ */ jsx(
124
- "div",
125
- {
126
- onMouseDown: header.getResizeHandler(),
127
- onTouchStart: header.getResizeHandler(),
128
- className: cx$2("resize-handle")
129
- }
130
- )
131
- ]
132
- },
133
- header.id
134
- )) }, headerGroup.id)) }),
135
- /* @__PURE__ */ jsx("tbody", { children: !isLoading && !isError && table.getRowModel().rows.length > 0 ? table.getRowModel().rows.map((row) => (
136
- // TODO aria-disabled 스타일을 어떻게 적용할 것인지?
137
- /* @__PURE__ */ jsx("tr", { "aria-selected": row.getIsSelected(), children: row.getVisibleCells().map((cell) => /* @__PURE__ */ jsx(
138
- "td",
139
- {
140
- style: cell.column.columnDef.size ? {
141
- width: cell.column.getSize(),
142
- minWidth: cell.column.getSize(),
143
- maxWidth: cell.column.getSize()
144
- } : void 0,
145
- children: flexRender(cell.column.columnDef.cell, cell.getContext())
146
- },
147
- cell.id
148
- )) }, row.id)
149
- )) : /* @__PURE__ */ jsx("tr", { children: /* @__PURE__ */ jsx("td", { className: cx$2("feedback-cell"), colSpan: table.getVisibleLeafColumns().length, children: isLoading ? /* @__PURE__ */ jsx("div", { children: "Loading..." }) : /* @__PURE__ */ jsx("div", { children: msgText || (isError ? "Error" : "No data") }) }) }) })
150
- ]
151
- }
152
- );
153
- };
154
-
155
- const useTable = ({
156
- data,
157
- columns,
158
- defaultColumn = { size: 150, enableResizing: true },
159
- initialState,
160
- onSortingChange,
161
- enableRowSelection,
162
- enableColumnResizing,
163
- mode = "SSR",
164
- meta,
165
- debug
166
- }) => {
167
- const [sorting, setSorting] = React.useState(initialState?.sorting || []);
168
- const [rowSelection, setRowSelection] = useState(initialState?.rowSelection || {});
169
- const [pagination, setPagination] = React.useState(initialState?.pagination || {});
170
- const [columnVisibility, setColumnVisibility] = React.useState(initialState?.columnVisibility || {});
171
- const getOption = (mode2) => {
172
- if (mode2 === "SSR") {
173
- return {
174
- manualSorting: true,
175
- manualPagination: true,
176
- onSortingChange
177
- };
178
- } else {
179
- return {
180
- getPaginationRowModel: getPaginationRowModel(),
181
- onPaginationChange: setPagination,
182
- onSortingChange: setSorting
183
- };
184
- }
185
- };
186
- const table = useReactTable({
187
- meta,
188
- data,
189
- columns,
190
- columnResizeMode: "onChange",
191
- defaultColumn,
192
- enableColumnResizing,
193
- enableRowSelection,
194
- initialState,
195
- state: {
196
- sorting,
197
- rowSelection,
198
- pagination,
199
- columnVisibility
200
- },
201
- onRowSelectionChange: setRowSelection,
202
- onColumnVisibilityChange: setColumnVisibility,
203
- getCoreRowModel: getCoreRowModel(),
204
- getSortedRowModel: getSortedRowModel(),
205
- ...getOption(mode),
206
- debugTable: debug,
207
- debugHeaders: debug,
208
- debugColumns: debug
209
- });
210
- return table;
211
- };
212
-
213
- const FormDatePicker = ({
214
- name,
215
- control,
216
- disabled,
217
- ...props
218
- }) => {
219
- const { field, fieldState } = useController({ name, control, disabled });
220
- const baseProps = {
221
- ...props,
222
- id: field.name,
223
- defaultValue: field.value,
224
- disabled: field.disabled,
225
- error: fieldState.invalid,
226
- onBlur: field.onBlur
227
- };
228
- return /* @__PURE__ */ jsx(DatePicker, { ...baseProps });
229
- };
230
-
231
- const FormSegmentGroup = ({
232
- name,
233
- control,
234
- disabled,
235
- ...props
236
- }) => {
237
- const { field, fieldState } = useController({ name, control, disabled });
238
- return /* @__PURE__ */ jsx(
239
- SegmentGroup,
240
- {
241
- ...props,
242
- tabIndex: 0,
243
- id: field.name,
244
- ref: field.ref,
245
- defaultValue: field.value,
246
- disabled: field.disabled,
247
- error: fieldState.invalid,
248
- onBlur: field.onBlur,
249
- onValueChange: (selected) => {
250
- field.onChange(selected);
251
- props.onValueChange?.(selected);
252
- }
253
- }
254
- );
255
- };
256
-
257
- const FormTextField = ({
258
- name,
259
- control,
260
- disabled,
261
- error,
262
- onBlur,
263
- onChange,
264
- rootProps,
265
- ...props
266
- }) => {
267
- const { field, fieldState } = useController({ name, control, disabled });
268
- return /* @__PURE__ */ jsx(
269
- FormField.TextField,
270
- {
271
- ...props,
272
- id: field.name,
273
- size: "medium",
274
- autoComplete: "off",
275
- name: field.name,
276
- value: field.value ?? "",
277
- disabled: field.disabled,
278
- error: fieldState.invalid || error,
279
- onChange: (e) => {
280
- field.onChange(e);
281
- onChange?.(e);
282
- },
283
- onBlur: (e) => {
284
- field.onBlur();
285
- onBlur?.(e);
286
- },
287
- rootProps: {
288
- ...rootProps,
289
- onClear: () => {
290
- field.onChange("");
291
- rootProps?.onClear?.();
292
- }
293
- }
294
- }
295
- );
296
- };
297
-
298
- const cx$1 = classNames.bind(styles$1);
184
+ const cx$1 = classNames.bind(styles);
299
185
  const StepIndicator = ({
300
186
  items,
301
187
  onClickItem,
@@ -327,7 +213,7 @@ const StepIndicator = ({
327
213
  ] });
328
214
  };
329
215
 
330
- const cx = classNames.bind(styles$2);
216
+ const cx = classNames.bind(styles$1);
331
217
  function Attachment({
332
218
  photos,
333
219
  onAddPhoto,
@@ -836,5 +722,5 @@ function useCanvasPaint(paintProps = {}) {
836
722
 
837
723
  const testSignatureBase64Data = "";
838
724
 
839
- export { Attachment, DataTable, FormDatePicker, FormSegmentGroup, FormTextField, StepIndicator, resize, testSignatureBase64Data, useCamera, useCanvasPaint, useTable };
725
+ export { Attachment, FormDatePicker, FormSegmentGroup, FormTextField, StepIndicator, resize, testSignatureBase64Data, useCamera, useCanvasPaint };
840
726
  //# sourceMappingURL=index.esm.js.map