sales-frontend-components 0.0.51 → 0.0.53

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