@tipp/ui 1.6.2 → 1.6.4
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/app/index.cjs +10 -9
- package/dist/app/index.cjs.map +1 -1
- package/dist/app/index.js +5 -5
- package/dist/app/platform/edit-coaching-time.cjs +10 -9
- package/dist/app/platform/edit-coaching-time.cjs.map +1 -1
- package/dist/app/platform/edit-coaching-time.js +2 -2
- package/dist/app/platform/edit-service-type.cjs +1 -0
- package/dist/app/platform/edit-service-type.cjs.map +1 -1
- package/dist/app/platform/edit-service-type.js +1 -1
- package/dist/app/platform/goal-manage-card-edit.cjs +10 -9
- package/dist/app/platform/goal-manage-card-edit.cjs.map +1 -1
- package/dist/app/platform/goal-manage-card-edit.js +2 -2
- package/dist/app/platform/on-offline-radio-card.cjs +1 -0
- package/dist/app/platform/on-offline-radio-card.cjs.map +1 -1
- package/dist/app/platform/on-offline-radio-card.js +1 -1
- package/dist/app/platform/reservation-card.cjs +10 -9
- package/dist/app/platform/reservation-card.cjs.map +1 -1
- package/dist/app/platform/reservation-card.js +2 -2
- package/dist/app/platform/session-card.cjs +10 -9
- package/dist/app/platform/session-card.cjs.map +1 -1
- package/dist/app/platform/session-card.js +3 -3
- package/dist/chunk-2QEZ6DBT.js +174 -0
- package/dist/chunk-2QEZ6DBT.js.map +1 -0
- package/dist/chunk-2SQMC4TN.js +145 -0
- package/dist/chunk-2SQMC4TN.js.map +1 -0
- package/dist/chunk-353HNJAP.js +145 -0
- package/dist/chunk-353HNJAP.js.map +1 -0
- package/dist/chunk-3G52XX3T.js +61 -0
- package/dist/chunk-3G52XX3T.js.map +1 -0
- package/dist/chunk-3HBRMWRE.js +68 -0
- package/dist/chunk-3HBRMWRE.js.map +1 -0
- package/dist/chunk-3M4GZWUL.js +145 -0
- package/dist/chunk-3M4GZWUL.js.map +1 -0
- package/dist/chunk-3P2UV2HY.js +174 -0
- package/dist/chunk-3P2UV2HY.js.map +1 -0
- package/dist/chunk-3WXI5VST.js +30 -0
- package/dist/chunk-3WXI5VST.js.map +1 -0
- package/dist/chunk-4D44QFD4.js +145 -0
- package/dist/chunk-4D44QFD4.js.map +1 -0
- package/dist/chunk-4SRB2JGG.js +145 -0
- package/dist/chunk-4SRB2JGG.js.map +1 -0
- package/dist/chunk-4XZXHNQA.js +277 -0
- package/dist/chunk-4XZXHNQA.js.map +1 -0
- package/dist/chunk-53KFWDFN.js +165 -0
- package/dist/chunk-53KFWDFN.js.map +1 -0
- package/dist/chunk-565JTDWV.js +174 -0
- package/dist/chunk-565JTDWV.js.map +1 -0
- package/dist/chunk-5NDV65WP.js +277 -0
- package/dist/chunk-5NDV65WP.js.map +1 -0
- package/dist/chunk-5OYS2OKG.js +277 -0
- package/dist/chunk-5OYS2OKG.js.map +1 -0
- package/dist/chunk-5SYAWM2J.js +145 -0
- package/dist/chunk-5SYAWM2J.js.map +1 -0
- package/dist/chunk-634N5KDS.js +145 -0
- package/dist/chunk-634N5KDS.js.map +1 -0
- package/dist/chunk-6GQZY7J6.js +145 -0
- package/dist/chunk-6GQZY7J6.js.map +1 -0
- package/dist/chunk-6O47MKHG.js +59 -0
- package/dist/chunk-6O47MKHG.js.map +1 -0
- package/dist/chunk-6OF6INLJ.js +58 -0
- package/dist/chunk-6OF6INLJ.js.map +1 -0
- package/dist/chunk-7DBQG6FA.js +145 -0
- package/dist/chunk-7DBQG6FA.js.map +1 -0
- package/dist/chunk-7LINYMFH.js +277 -0
- package/dist/chunk-7LINYMFH.js.map +1 -0
- package/dist/chunk-AEJHHUKD.js +277 -0
- package/dist/chunk-AEJHHUKD.js.map +1 -0
- package/dist/chunk-ANOBDXLK.js +145 -0
- package/dist/chunk-ANOBDXLK.js.map +1 -0
- package/dist/chunk-AYQLLMMQ.js +174 -0
- package/dist/chunk-AYQLLMMQ.js.map +1 -0
- package/dist/chunk-B2X3OUFM.js +174 -0
- package/dist/chunk-B2X3OUFM.js.map +1 -0
- package/dist/chunk-BVM3C67I.js +145 -0
- package/dist/chunk-BVM3C67I.js.map +1 -0
- package/dist/chunk-CC3SLQKS.js +277 -0
- package/dist/chunk-CC3SLQKS.js.map +1 -0
- package/dist/chunk-CHEJMC5J.js +145 -0
- package/dist/chunk-CHEJMC5J.js.map +1 -0
- package/dist/chunk-CXZUXX6K.js +145 -0
- package/dist/chunk-CXZUXX6K.js.map +1 -0
- package/dist/chunk-DBWQSDFG.js +277 -0
- package/dist/chunk-DBWQSDFG.js.map +1 -0
- package/dist/chunk-DFF763H4.js +174 -0
- package/dist/chunk-DFF763H4.js.map +1 -0
- package/dist/chunk-DRILOPLH.js +174 -0
- package/dist/chunk-DRILOPLH.js.map +1 -0
- package/dist/chunk-ECFVOZ7R.js +45 -0
- package/dist/chunk-ECFVOZ7R.js.map +1 -0
- package/dist/chunk-FMNGEHNP.js +145 -0
- package/dist/chunk-FMNGEHNP.js.map +1 -0
- package/dist/chunk-FPPYHMJU.js +277 -0
- package/dist/chunk-FPPYHMJU.js.map +1 -0
- package/dist/chunk-GOYM3P23.js +350 -0
- package/dist/chunk-GOYM3P23.js.map +1 -0
- package/dist/chunk-H3VZ3RQL.js +174 -0
- package/dist/chunk-H3VZ3RQL.js.map +1 -0
- package/dist/chunk-HBQMCMWF.js +145 -0
- package/dist/chunk-HBQMCMWF.js.map +1 -0
- package/dist/chunk-HDH4MIIQ.js +277 -0
- package/dist/chunk-HDH4MIIQ.js.map +1 -0
- package/dist/chunk-IFO7TKDA.js +145 -0
- package/dist/chunk-IFO7TKDA.js.map +1 -0
- package/dist/chunk-IG2ATEEB.js +174 -0
- package/dist/chunk-IG2ATEEB.js.map +1 -0
- package/dist/chunk-J4KWOBHT.js +145 -0
- package/dist/chunk-J4KWOBHT.js.map +1 -0
- package/dist/chunk-KFETGCEX.js +145 -0
- package/dist/chunk-KFETGCEX.js.map +1 -0
- package/dist/chunk-KQKIN46G.js +174 -0
- package/dist/chunk-KQKIN46G.js.map +1 -0
- package/dist/chunk-LNDB3S2Q.js +277 -0
- package/dist/chunk-LNDB3S2Q.js.map +1 -0
- package/dist/chunk-LYSYLJJK.js +145 -0
- package/dist/chunk-LYSYLJJK.js.map +1 -0
- package/dist/chunk-M3YBNPMG.js +145 -0
- package/dist/chunk-M3YBNPMG.js.map +1 -0
- package/dist/chunk-MB7HYG3I.js +277 -0
- package/dist/chunk-MB7HYG3I.js.map +1 -0
- package/dist/chunk-ME7AX2H2.js +145 -0
- package/dist/chunk-ME7AX2H2.js.map +1 -0
- package/dist/chunk-MRWYYJSI.js +51 -0
- package/dist/chunk-MRWYYJSI.js.map +1 -0
- package/dist/chunk-N6363EGO.js +145 -0
- package/dist/chunk-N6363EGO.js.map +1 -0
- package/dist/chunk-NDEVRMNL.js +145 -0
- package/dist/chunk-NDEVRMNL.js.map +1 -0
- package/dist/chunk-NKRSPSPT.js +145 -0
- package/dist/chunk-NKRSPSPT.js.map +1 -0
- package/dist/chunk-NWEUZLYW.js +103 -0
- package/dist/chunk-NWEUZLYW.js.map +1 -0
- package/dist/chunk-ODQOSBF2.js +60 -0
- package/dist/chunk-ODQOSBF2.js.map +1 -0
- package/dist/chunk-OSPGUZX5.js +59 -0
- package/dist/chunk-OSPGUZX5.js.map +1 -0
- package/dist/chunk-OYQY63G2.js +145 -0
- package/dist/chunk-OYQY63G2.js.map +1 -0
- package/dist/chunk-P35E3HXT.js +277 -0
- package/dist/chunk-P35E3HXT.js.map +1 -0
- package/dist/chunk-P7ZBNADY.js +145 -0
- package/dist/chunk-P7ZBNADY.js.map +1 -0
- package/dist/chunk-PGDXTFXD.js +174 -0
- package/dist/chunk-PGDXTFXD.js.map +1 -0
- package/dist/chunk-PGEEWD2H.js +277 -0
- package/dist/chunk-PGEEWD2H.js.map +1 -0
- package/dist/chunk-PWAYLJCR.js +145 -0
- package/dist/chunk-PWAYLJCR.js.map +1 -0
- package/dist/chunk-Q2DZYZUN.js +68 -0
- package/dist/chunk-Q2DZYZUN.js.map +1 -0
- package/dist/chunk-QQP4NBZW.js +145 -0
- package/dist/chunk-QQP4NBZW.js.map +1 -0
- package/dist/chunk-QW2IVXVR.js +277 -0
- package/dist/chunk-QW2IVXVR.js.map +1 -0
- package/dist/chunk-R2WEU26M.js +72 -0
- package/dist/chunk-R2WEU26M.js.map +1 -0
- package/dist/chunk-RMF722Q6.js +145 -0
- package/dist/chunk-RMF722Q6.js.map +1 -0
- package/dist/chunk-RNHTWNC2.js +174 -0
- package/dist/chunk-RNHTWNC2.js.map +1 -0
- package/dist/chunk-RYCVEMMJ.js +145 -0
- package/dist/chunk-RYCVEMMJ.js.map +1 -0
- package/dist/chunk-SA42J4ZG.js +145 -0
- package/dist/chunk-SA42J4ZG.js.map +1 -0
- package/dist/chunk-SFA2TOSB.js +63 -0
- package/dist/chunk-SFA2TOSB.js.map +1 -0
- package/dist/chunk-SM6SXBY5.js +52 -0
- package/dist/chunk-SM6SXBY5.js.map +1 -0
- package/dist/chunk-SREIWTXV.js +63 -0
- package/dist/chunk-SREIWTXV.js.map +1 -0
- package/dist/chunk-TMWL3OVB.js +145 -0
- package/dist/chunk-TMWL3OVB.js.map +1 -0
- package/dist/chunk-UEQFUV4U.js +277 -0
- package/dist/chunk-UEQFUV4U.js.map +1 -0
- package/dist/chunk-ULKJUADJ.js +277 -0
- package/dist/chunk-ULKJUADJ.js.map +1 -0
- package/dist/chunk-USXYABCR.js +145 -0
- package/dist/chunk-USXYABCR.js.map +1 -0
- package/dist/chunk-VKM4NDSR.js +145 -0
- package/dist/chunk-VKM4NDSR.js.map +1 -0
- package/dist/chunk-VUJG7OIQ.js +63 -0
- package/dist/chunk-VUJG7OIQ.js.map +1 -0
- package/dist/chunk-W7C6PIK6.js +59 -0
- package/dist/chunk-W7C6PIK6.js.map +1 -0
- package/dist/chunk-WJP3A2PA.js +145 -0
- package/dist/chunk-WJP3A2PA.js.map +1 -0
- package/dist/chunk-WJV4RXCT.js +145 -0
- package/dist/chunk-WJV4RXCT.js.map +1 -0
- package/dist/chunk-X2WAJFMZ.js +277 -0
- package/dist/chunk-X2WAJFMZ.js.map +1 -0
- package/dist/chunk-XAX4QDNL.js +277 -0
- package/dist/chunk-XAX4QDNL.js.map +1 -0
- package/dist/chunk-XDMGHIKI.js +145 -0
- package/dist/chunk-XDMGHIKI.js.map +1 -0
- package/dist/chunk-XM3BH772.js +277 -0
- package/dist/chunk-XM3BH772.js.map +1 -0
- package/dist/chunk-YIDQROUZ.js +277 -0
- package/dist/chunk-YIDQROUZ.js.map +1 -0
- package/dist/index.cjs +10 -9
- package/dist/index.cjs.map +1 -1
- package/dist/index.css +8 -0
- package/dist/index.css.map +1 -1
- package/dist/index.js +5 -5
- package/dist/molecules/date-picker/date-picker-button.cjs +10 -9
- package/dist/molecules/date-picker/date-picker-button.cjs.map +1 -1
- package/dist/molecules/date-picker/date-picker-button.js +1 -1
- package/dist/molecules/index.cjs +10 -9
- package/dist/molecules/index.cjs.map +1 -1
- package/dist/molecules/index.js +1 -1
- package/package.json +4 -3
- package/src/molecules/date-picker/date-picker-button.tsx +11 -10
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
import {
|
|
2
|
+
DatePickerButton
|
|
3
|
+
} from "./chunk-3HBRMWRE.js";
|
|
4
|
+
import {
|
|
5
|
+
Form
|
|
6
|
+
} from "./chunk-PYR4SVP5.js";
|
|
7
|
+
import {
|
|
8
|
+
TextArea
|
|
9
|
+
} from "./chunk-EW6OPYEW.js";
|
|
10
|
+
import {
|
|
11
|
+
TextField
|
|
12
|
+
} from "./chunk-VOQU7ZOV.js";
|
|
13
|
+
import {
|
|
14
|
+
Card
|
|
15
|
+
} from "./chunk-2ZQK7NTN.js";
|
|
16
|
+
import {
|
|
17
|
+
Flex
|
|
18
|
+
} from "./chunk-25HMMI7R.js";
|
|
19
|
+
import {
|
|
20
|
+
Button
|
|
21
|
+
} from "./chunk-U7JPP7WJ.js";
|
|
22
|
+
import {
|
|
23
|
+
__spreadValues
|
|
24
|
+
} from "./chunk-N552FDTV.js";
|
|
25
|
+
|
|
26
|
+
// src/app/platform/goal-manage-card-edit.tsx
|
|
27
|
+
import { useCallback, useState } from "react";
|
|
28
|
+
import { format } from "date-fns";
|
|
29
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
30
|
+
var initialValues = {
|
|
31
|
+
goal: "",
|
|
32
|
+
effect: "",
|
|
33
|
+
huddle: "",
|
|
34
|
+
dueDate: void 0
|
|
35
|
+
};
|
|
36
|
+
var dummyFn = () => {
|
|
37
|
+
};
|
|
38
|
+
function GoalManageCardEdit(props) {
|
|
39
|
+
const { defaultValues, errors } = props;
|
|
40
|
+
const [values, setValues] = useState(defaultValues || initialValues);
|
|
41
|
+
const onChange = useCallback(
|
|
42
|
+
(v) => {
|
|
43
|
+
var _a;
|
|
44
|
+
setValues((prev) => __spreadValues(__spreadValues({}, prev), v));
|
|
45
|
+
(_a = props.onChange) == null ? void 0 : _a.call(props, v);
|
|
46
|
+
},
|
|
47
|
+
[props]
|
|
48
|
+
);
|
|
49
|
+
const onClickInit = useCallback(() => {
|
|
50
|
+
var _a;
|
|
51
|
+
setValues(initialValues);
|
|
52
|
+
(_a = props.onChange) == null ? void 0 : _a.call(props, defaultValues || initialValues);
|
|
53
|
+
}, [defaultValues, props]);
|
|
54
|
+
const onClickSubmit = useCallback(() => {
|
|
55
|
+
var _a;
|
|
56
|
+
(_a = props.onSubmit) == null ? void 0 : _a.call(props, values);
|
|
57
|
+
}, [props, values]);
|
|
58
|
+
return /* @__PURE__ */ jsx(Card, { style: { width: "100%" }, children: /* @__PURE__ */ jsxs(Form.Root, { onSubmit: dummyFn, children: [
|
|
59
|
+
/* @__PURE__ */ jsxs(Flex, { direction: "column", gap: "5", children: [
|
|
60
|
+
/* @__PURE__ */ jsxs(Form.Field, { name: "title", children: [
|
|
61
|
+
/* @__PURE__ */ jsx(Form.Label, { children: "\uC774\uBC88 \uCF54\uCE6D\uC758 \uBAA9\uD45C\uB294 \uC544\uB798\uC640 \uAC19\uC2B5\uB2C8\uB2E4" }),
|
|
62
|
+
/* @__PURE__ */ jsx(
|
|
63
|
+
TextField.Root,
|
|
64
|
+
{
|
|
65
|
+
error: Boolean(errors == null ? void 0 : errors.goal),
|
|
66
|
+
onChange: (e) => {
|
|
67
|
+
onChange({ goal: e.target.value });
|
|
68
|
+
},
|
|
69
|
+
placeholder: "\uC774\uBC88 \uCF54\uCE6D \uACFC\uC815\uC758 \uBAA9\uD45C\uB97C \uD55C \uBB38\uC7A5\uC73C\uB85C \uC801\uC5B4\uC8FC\uC138\uC694",
|
|
70
|
+
value: values.goal
|
|
71
|
+
}
|
|
72
|
+
),
|
|
73
|
+
/* @__PURE__ */ jsx(Form.Message, { forceMatch: Boolean(errors == null ? void 0 : errors.goal), children: errors == null ? void 0 : errors.goal })
|
|
74
|
+
] }),
|
|
75
|
+
/* @__PURE__ */ jsxs(Form.Field, { name: "effect", children: [
|
|
76
|
+
/* @__PURE__ */ jsx(Form.Label, { children: "\uAE30\uB300\uD6A8\uACFC" }),
|
|
77
|
+
/* @__PURE__ */ jsx(
|
|
78
|
+
TextArea,
|
|
79
|
+
{
|
|
80
|
+
error: Boolean(errors == null ? void 0 : errors.effect),
|
|
81
|
+
onChange: (e) => {
|
|
82
|
+
onChange({ effect: e.target.value });
|
|
83
|
+
},
|
|
84
|
+
placeholder: "\uC608\uC2DC : \uD300\uC6D0\uB4E4\uACFC \uB354 \uCE5C\uBC00\uD574\uC9C0\uACE0, \uD300\uC6D0\uB4E4\uC5D0 \uB300\uD55C \uC774\uD574\uB3C4\uAC00 \uC313\uC774\uBA70 \uB354 \uD6A8\uC728\uC801\uC778 \uC778\uC7AC\uAD00\uB9AC\uB97C \uC704\uD55C \uAD00\uACC4\uD615\uC131\uC774 \uAC00\uB2A5\uD574\uC9D1\uB2C8\uB2E4.",
|
|
85
|
+
resize: "vertical",
|
|
86
|
+
value: values.effect
|
|
87
|
+
}
|
|
88
|
+
),
|
|
89
|
+
/* @__PURE__ */ jsx(Form.Message, { forceMatch: Boolean(errors == null ? void 0 : errors.effect), children: errors == null ? void 0 : errors.effect })
|
|
90
|
+
] }),
|
|
91
|
+
/* @__PURE__ */ jsxs(Form.Field, { name: "huddle", children: [
|
|
92
|
+
/* @__PURE__ */ jsx(Form.Label, { children: "\uBC29\uD574\uC694\uC18C" }),
|
|
93
|
+
/* @__PURE__ */ jsx(
|
|
94
|
+
TextArea,
|
|
95
|
+
{
|
|
96
|
+
error: Boolean(errors == null ? void 0 : errors.huddle),
|
|
97
|
+
onChange: (e) => {
|
|
98
|
+
onChange({ huddle: e.target.value });
|
|
99
|
+
},
|
|
100
|
+
placeholder: `- \uAC11\uC790\uAE30 \uC7A1\uD788\uB294 \uBBF8\uD305\uB4E4
|
|
101
|
+
- MZ \uC138\uB300\uC640\uC758 \uC790\uC5F0\uC2A4\uB7FD\uC9C0 \uC54A\uC740 \uC18C\uD1B5
|
|
102
|
+
- \uB300\uD654\uC5D0\uC11C \uCC38\uC744\uC131 \uBD80\uC871`,
|
|
103
|
+
resize: "vertical",
|
|
104
|
+
value: values.huddle
|
|
105
|
+
}
|
|
106
|
+
),
|
|
107
|
+
/* @__PURE__ */ jsx(Form.Message, { forceMatch: Boolean(errors == null ? void 0 : errors.huddle), children: errors == null ? void 0 : errors.huddle })
|
|
108
|
+
] }),
|
|
109
|
+
/* @__PURE__ */ jsxs(Form.Field, { name: "dueDate", children: [
|
|
110
|
+
/* @__PURE__ */ jsx(Form.Label, { children: "\uBAA9\uD45C \uB2EC\uC131 \uAE30\uD55C\uC740 \uB2E4\uC74C\uACFC \uAC19\uC2B5\uB2C8\uB2E4" }),
|
|
111
|
+
/* @__PURE__ */ jsx(
|
|
112
|
+
DatePickerButton,
|
|
113
|
+
{
|
|
114
|
+
format: (v) => format(v, "yyyy\uB144 MM\uC6D4 dd\uC77C"),
|
|
115
|
+
onChange: (date) => {
|
|
116
|
+
date && onChange({ dueDate: date });
|
|
117
|
+
},
|
|
118
|
+
placeholder: "YYYY\uB144 MM\uC6D4 DD\uC77C",
|
|
119
|
+
selected: values.dueDate
|
|
120
|
+
}
|
|
121
|
+
),
|
|
122
|
+
/* @__PURE__ */ jsx(Form.Message, { forceMatch: Boolean(errors == null ? void 0 : errors.dueDate), children: errors == null ? void 0 : errors.dueDate })
|
|
123
|
+
] })
|
|
124
|
+
] }),
|
|
125
|
+
/* @__PURE__ */ jsxs(Flex, { gap: "3", justify: "end", width: "100%", children: [
|
|
126
|
+
/* @__PURE__ */ jsx(
|
|
127
|
+
Button,
|
|
128
|
+
{
|
|
129
|
+
color: "gray",
|
|
130
|
+
onClick: onClickInit,
|
|
131
|
+
size: "small",
|
|
132
|
+
type: "button",
|
|
133
|
+
variant: "outline",
|
|
134
|
+
children: "\uCD08\uAE30\uD654\uD558\uAE30"
|
|
135
|
+
}
|
|
136
|
+
),
|
|
137
|
+
/* @__PURE__ */ jsx(Button, { onClick: onClickSubmit, size: "small", type: "button", children: "\uC800\uC7A5\uD558\uAE30" })
|
|
138
|
+
] })
|
|
139
|
+
] }) });
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
export {
|
|
143
|
+
GoalManageCardEdit
|
|
144
|
+
};
|
|
145
|
+
//# sourceMappingURL=chunk-NKRSPSPT.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/app/platform/goal-manage-card-edit.tsx"],"sourcesContent":["import React, { useCallback, useState } from 'react';\nimport { format } from 'date-fns';\nimport { Button, Card, Flex, Form, TextArea, TextField } from '../../atoms';\nimport { DatePickerButton } from '../../molecules';\n\ninterface Values {\n goal?: string;\n effect?: string;\n huddle?: string;\n dueDate?: Date;\n}\n\ninterface GoalManageCardEditProps {\n onChange?: (values: Partial<Values>) => void;\n defaultValues?: Values;\n errors?: { [key in keyof Values]: string };\n onSubmit?: (values: Values) => void;\n}\n\nconst initialValues: Values = {\n goal: '',\n effect: '',\n huddle: '',\n dueDate: undefined,\n};\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function -- dummy용 함수\nconst dummyFn = (): void => {};\n\nexport function GoalManageCardEdit(\n props: GoalManageCardEditProps\n): React.ReactElement {\n const { defaultValues, errors } = props;\n const [values, setValues] = useState(defaultValues || initialValues);\n\n const onChange = useCallback(\n (v: Partial<Values>) => {\n setValues((prev) => ({ ...prev, ...v }));\n props.onChange?.(v);\n },\n [props]\n );\n\n const onClickInit = useCallback(() => {\n setValues(initialValues);\n props.onChange?.(defaultValues || initialValues);\n }, [defaultValues, props]);\n\n const onClickSubmit = useCallback(() => {\n props.onSubmit?.(values);\n }, [props, values]);\n\n return (\n <Card style={{ width: '100%' }}>\n <Form.Root onSubmit={dummyFn}>\n <Flex direction=\"column\" gap=\"5\">\n <Form.Field name=\"title\">\n <Form.Label>이번 코칭의 목표는 아래와 같습니다</Form.Label>\n <TextField.Root\n error={Boolean(errors?.goal)}\n onChange={(e) => {\n onChange({ goal: e.target.value });\n }}\n placeholder=\"이번 코칭 과정의 목표를 한 문장으로 적어주세요\"\n value={values.goal}\n />\n <Form.Message forceMatch={Boolean(errors?.goal)}>\n {errors?.goal}\n </Form.Message>\n </Form.Field>\n\n <Form.Field name=\"effect\">\n <Form.Label>기대효과</Form.Label>\n <TextArea\n error={Boolean(errors?.effect)}\n onChange={(e) => {\n onChange({ effect: e.target.value });\n }}\n placeholder=\"예시 : 팀원들과 더 친밀해지고, 팀원들에 대한 이해도가 쌓이며 더 효율적인 인재관리를 위한 관계형성이 가능해집니다.\"\n resize=\"vertical\"\n value={values.effect}\n />\n <Form.Message forceMatch={Boolean(errors?.effect)}>\n {errors?.effect}\n </Form.Message>\n </Form.Field>\n\n <Form.Field name=\"huddle\">\n <Form.Label>방해요소</Form.Label>\n <TextArea\n error={Boolean(errors?.huddle)}\n onChange={(e) => {\n onChange({ huddle: e.target.value });\n }}\n placeholder={`- 갑자기 잡히는 미팅들\n- MZ 세대와의 자연스럽지 않은 소통\n- 대화에서 참을성 부족`}\n resize=\"vertical\"\n value={values.huddle}\n />\n <Form.Message forceMatch={Boolean(errors?.huddle)}>\n {errors?.huddle}\n </Form.Message>\n </Form.Field>\n\n <Form.Field name=\"dueDate\">\n <Form.Label>목표 달성 기한은 다음과 같습니다</Form.Label>\n <DatePickerButton\n format={(v) => format(v, 'yyyy년 MM월 dd일')}\n onChange={(date) => {\n date && onChange({ dueDate: date });\n }}\n placeholder=\"YYYY년 MM월 DD일\"\n selected={values.dueDate}\n />\n <Form.Message forceMatch={Boolean(errors?.dueDate)}>\n {errors?.dueDate}\n </Form.Message>\n </Form.Field>\n </Flex>\n\n <Flex gap=\"3\" justify=\"end\" width=\"100%\">\n <Button\n color=\"gray\"\n onClick={onClickInit}\n size=\"small\"\n type=\"button\"\n variant=\"outline\"\n >\n 초기화하기\n </Button>\n <Button onClick={onClickSubmit} size=\"small\" type=\"button\">\n 저장하기\n </Button>\n </Flex>\n </Form.Root>\n </Card>\n );\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
import {
|
|
2
|
+
toast
|
|
3
|
+
} from "./chunk-CYYWMYE7.js";
|
|
4
|
+
import {
|
|
5
|
+
DataList
|
|
6
|
+
} from "./chunk-VTJZMOSP.js";
|
|
7
|
+
import {
|
|
8
|
+
Button
|
|
9
|
+
} from "./chunk-U7JPP7WJ.js";
|
|
10
|
+
|
|
11
|
+
// src/app/platform/userInfos/utils.tsx
|
|
12
|
+
import { format } from "date-fns";
|
|
13
|
+
import { CopyIcon } from "@radix-ui/react-icons";
|
|
14
|
+
import { Fragment, jsx, jsxs } from "react/jsx-runtime";
|
|
15
|
+
var infoList = [
|
|
16
|
+
{ label: "\uC774\uB984", getValue: (customer) => customer == null ? void 0 : customer.username },
|
|
17
|
+
{ label: "\uC131\uBCC4", getValue: (customer) => customer == null ? void 0 : customer.gender },
|
|
18
|
+
{
|
|
19
|
+
label: "\uC0DD\uB144\uC6D4\uC77C",
|
|
20
|
+
getValue: (customer) => (customer == null ? void 0 : customer.birthdate) && format(customer.birthdate, "yyyy.MM.dd")
|
|
21
|
+
},
|
|
22
|
+
{ label: "\uBD80\uC11C", getValue: (customer) => customer == null ? void 0 : customer.team },
|
|
23
|
+
{ label: "\uC9C1\uCC45", getValue: (customer) => customer == null ? void 0 : customer.position },
|
|
24
|
+
{ label: "\uC9C1\uAE09", getValue: (customer) => customer == null ? void 0 : customer.level },
|
|
25
|
+
{ label: "\uC774\uBA54\uC77C", getValue: (customer) => customer == null ? void 0 : customer.email, copyable: true },
|
|
26
|
+
{
|
|
27
|
+
label: "\uC804\uD654\uBC88\uD638",
|
|
28
|
+
getValue: (customer) => customer == null ? void 0 : customer.phone,
|
|
29
|
+
render: (value) => {
|
|
30
|
+
return value == null ? void 0 : value.replace(/[^0-9]/g, "").replace(/^(\d{2,3})(\d{3,4})(\d{4})$/, `$1-$2-$3`);
|
|
31
|
+
},
|
|
32
|
+
copyable: true
|
|
33
|
+
}
|
|
34
|
+
];
|
|
35
|
+
var sessionStatusChecker = (value, session) => {
|
|
36
|
+
if ((session == null ? void 0 : session.state) === "inProgress") {
|
|
37
|
+
return value;
|
|
38
|
+
}
|
|
39
|
+
return "-";
|
|
40
|
+
};
|
|
41
|
+
var sessionList = [
|
|
42
|
+
{
|
|
43
|
+
label: "\uC9C4\uD589\uC911\uC778 \uC138\uC158",
|
|
44
|
+
getValue: (session) => {
|
|
45
|
+
return sessionStatusChecker(
|
|
46
|
+
`${(session == null ? void 0 : session.currentSession) || "-"}\uD68C\uCC28/${(session == null ? void 0 : session.totalSession) || "-"}\uD68C\uCC28`,
|
|
47
|
+
session
|
|
48
|
+
);
|
|
49
|
+
}
|
|
50
|
+
},
|
|
51
|
+
{
|
|
52
|
+
label: "\uB2E4\uC74C \uC138\uC158 \uC77C\uC2DC",
|
|
53
|
+
getValue: (session) => sessionStatusChecker(
|
|
54
|
+
(session == null ? void 0 : session.nextSessionDate) ? format(session.nextSessionDate, "yyyy\uB144 MM\uC6D4 dd\uC77C HH\uC2DC mm\uBD84") : "-",
|
|
55
|
+
session
|
|
56
|
+
)
|
|
57
|
+
},
|
|
58
|
+
{
|
|
59
|
+
label: "\uB2E4\uC74C \uC138\uC158 \uCC38\uC5EC \uBC29\uC2DD",
|
|
60
|
+
getValue: (session) => sessionStatusChecker((session == null ? void 0 : session.nextSessionType) || "-", session)
|
|
61
|
+
},
|
|
62
|
+
{
|
|
63
|
+
label: "\uCF54\uCE6D \uB9CC\uB8CC \uAE30\uD55C",
|
|
64
|
+
getValue: (session) => (session == null ? void 0 : session.expiredAt) ? format(session.expiredAt, "yyyy\uB144 MM\uC6D4 dd\uC77C") : "-"
|
|
65
|
+
}
|
|
66
|
+
];
|
|
67
|
+
var renderItem = (info, data) => {
|
|
68
|
+
const value = info.getValue(data);
|
|
69
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
70
|
+
info.render ? info.render(value) : value || "-",
|
|
71
|
+
info.copyable && value ? /* @__PURE__ */ jsx(CopyButton, { value }) : null
|
|
72
|
+
] });
|
|
73
|
+
};
|
|
74
|
+
var renderDataListItem = (info, data) => {
|
|
75
|
+
return /* @__PURE__ */ jsxs(DataList.Item, { children: [
|
|
76
|
+
/* @__PURE__ */ jsx(DataList.Label, { children: info.label }),
|
|
77
|
+
/* @__PURE__ */ jsx(DataList.Value, { children: renderItem(info, data) })
|
|
78
|
+
] }, info.label);
|
|
79
|
+
};
|
|
80
|
+
function CopyButton(props) {
|
|
81
|
+
return /* @__PURE__ */ jsx(
|
|
82
|
+
Button,
|
|
83
|
+
{
|
|
84
|
+
color: "gray",
|
|
85
|
+
onClick: () => {
|
|
86
|
+
void navigator.clipboard.writeText(props.value);
|
|
87
|
+
toast.success("\uBCF5\uC0AC\uB418\uC5C8\uC2B5\uB2C8\uB2E4.");
|
|
88
|
+
},
|
|
89
|
+
style: { marginLeft: "0", marginTop: "0" },
|
|
90
|
+
variant: "transparent",
|
|
91
|
+
children: /* @__PURE__ */ jsx(CopyIcon, {})
|
|
92
|
+
}
|
|
93
|
+
);
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
export {
|
|
97
|
+
infoList,
|
|
98
|
+
sessionList,
|
|
99
|
+
renderItem,
|
|
100
|
+
renderDataListItem,
|
|
101
|
+
CopyButton
|
|
102
|
+
};
|
|
103
|
+
//# sourceMappingURL=chunk-NWEUZLYW.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/app/platform/userInfos/utils.tsx"],"sourcesContent":["import type { ProjectStatus } from '@tipp/biz-utils';\nimport { format } from 'date-fns';\nimport { CopyIcon } from '@radix-ui/react-icons';\nimport { Button, DataList, toast } from '../../../atoms';\n\nexport interface CoachingCustomerInfoProps {\n customer?: Customer;\n session?: Session;\n children?: React.ReactElement;\n badge?: React.ReactElement;\n}\n\nexport interface Customer {\n username?: string;\n email?: string;\n gender?: string;\n birthdate?: Date;\n phone?: string;\n company?: string;\n team?: string;\n position?: string;\n level: string;\n}\n\nexport interface Session {\n state?: ProjectStatus;\n totalSession?: number;\n currentSession?: number;\n nextSessionDate?: Date;\n nextSessionType?: string;\n expiredAt?: Date;\n}\n\nexport interface DataListItems<T> {\n label: string;\n getValue: (original?: T) => string | undefined;\n copyable?: boolean;\n render?: (value?: string) => React.ReactNode;\n}\n\nexport const infoList: DataListItems<Customer>[] = [\n { label: '이름', getValue: (customer) => customer?.username },\n { label: '성별', getValue: (customer) => customer?.gender },\n {\n label: '생년월일',\n getValue: (customer) =>\n customer?.birthdate && format(customer.birthdate, 'yyyy.MM.dd'),\n },\n { label: '부서', getValue: (customer) => customer?.team },\n { label: '직책', getValue: (customer) => customer?.position },\n { label: '직급', getValue: (customer) => customer?.level },\n { label: '이메일', getValue: (customer) => customer?.email, copyable: true },\n {\n label: '전화번호',\n getValue: (customer) => customer?.phone,\n render: (value) => {\n // 핸드폰 전화번호 형식으로 변환\n return (\n value\n ?.replace(/[^0-9]/g, '')\n // eslint-disable-next-line prefer-named-capture-group -- target es 변경하기 전이라서 이대로 둠\n .replace(/^(\\d{2,3})(\\d{3,4})(\\d{4})$/, `$1-$2-$3`)\n );\n },\n copyable: true,\n },\n];\n\nconst sessionStatusChecker = <T,>(value: T, session?: Session): T | string => {\n if (session?.state === 'inProgress') {\n return value;\n }\n return '-';\n};\n\nexport const sessionList: DataListItems<Session>[] = [\n {\n label: '진행중인 세션',\n getValue: (session) => {\n return sessionStatusChecker(\n `${session?.currentSession || '-'}회차/${session?.totalSession || '-'}회차`,\n session\n );\n },\n },\n {\n label: '다음 세션 일시',\n getValue: (session) =>\n sessionStatusChecker(\n session?.nextSessionDate\n ? format(session.nextSessionDate, 'yyyy년 MM월 dd일 HH시 mm분')\n : '-',\n session\n ),\n },\n {\n label: '다음 세션 참여 방식',\n getValue: (session) =>\n sessionStatusChecker(session?.nextSessionType || '-', session),\n },\n {\n label: '코칭 만료 기한',\n getValue: (session) =>\n session?.expiredAt ? format(session.expiredAt, 'yyyy년 MM월 dd일') : '-',\n },\n];\n\nexport const renderItem = <T extends object>(\n info: DataListItems<T>,\n data?: T\n): JSX.Element => {\n const value = info.getValue(data);\n return (\n <>\n {info.render ? info.render(value) : value || '-'}\n {info.copyable && value ? <CopyButton value={value} /> : null}\n </>\n );\n};\n\nexport const renderDataListItem = <T extends object>(\n info: DataListItems<T>,\n data?: T\n): React.ReactElement => {\n return (\n <DataList.Item key={info.label}>\n <DataList.Label>{info.label}</DataList.Label>\n <DataList.Value>{renderItem(info, data)}</DataList.Value>\n </DataList.Item>\n );\n};\n\nexport function CopyButton(props: { value: string }): JSX.Element {\n return (\n <Button\n color=\"gray\"\n onClick={() => {\n void navigator.clipboard.writeText(props.value);\n toast.success('복사되었습니다.');\n }}\n style={{ marginLeft: '0', marginTop: '0' }}\n variant=\"transparent\"\n >\n <CopyIcon />\n </Button>\n );\n}\n"],"mappings":";;;;;;;;;;;AACA,SAAS,cAAc;AACvB,SAAS,gBAAgB;AA+GrB,mBAE4B,KAF5B;AAzEG,IAAM,WAAsC;AAAA,EACjD,EAAE,OAAO,gBAAM,UAAU,CAAC,aAAa,qCAAU,SAAS;AAAA,EAC1D,EAAE,OAAO,gBAAM,UAAU,CAAC,aAAa,qCAAU,OAAO;AAAA,EACxD;AAAA,IACE,OAAO;AAAA,IACP,UAAU,CAAC,cACT,qCAAU,cAAa,OAAO,SAAS,WAAW,YAAY;AAAA,EAClE;AAAA,EACA,EAAE,OAAO,gBAAM,UAAU,CAAC,aAAa,qCAAU,KAAK;AAAA,EACtD,EAAE,OAAO,gBAAM,UAAU,CAAC,aAAa,qCAAU,SAAS;AAAA,EAC1D,EAAE,OAAO,gBAAM,UAAU,CAAC,aAAa,qCAAU,MAAM;AAAA,EACvD,EAAE,OAAO,sBAAO,UAAU,CAAC,aAAa,qCAAU,OAAO,UAAU,KAAK;AAAA,EACxE;AAAA,IACE,OAAO;AAAA,IACP,UAAU,CAAC,aAAa,qCAAU;AAAA,IAClC,QAAQ,CAAC,UAAU;AAEjB,aACE,+BACI,QAAQ,WAAW,IAEpB,QAAQ,+BAA+B;AAAA,IAE9C;AAAA,IACA,UAAU;AAAA,EACZ;AACF;AAEA,IAAM,uBAAuB,CAAK,OAAU,YAAkC;AAC5E,OAAI,mCAAS,WAAU,cAAc;AACnC,WAAO;AAAA,EACT;AACA,SAAO;AACT;AAEO,IAAM,cAAwC;AAAA,EACnD;AAAA,IACE,OAAO;AAAA,IACP,UAAU,CAAC,YAAY;AACrB,aAAO;AAAA,QACL,IAAG,mCAAS,mBAAkB,GAAG,iBAAM,mCAAS,iBAAgB,GAAG;AAAA,QACnE;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAAA,EACA;AAAA,IACE,OAAO;AAAA,IACP,UAAU,CAAC,YACT;AAAA,OACE,mCAAS,mBACL,OAAO,QAAQ,iBAAiB,gDAAuB,IACvD;AAAA,MACJ;AAAA,IACF;AAAA,EACJ;AAAA,EACA;AAAA,IACE,OAAO;AAAA,IACP,UAAU,CAAC,YACT,sBAAqB,mCAAS,oBAAmB,KAAK,OAAO;AAAA,EACjE;AAAA,EACA;AAAA,IACE,OAAO;AAAA,IACP,UAAU,CAAC,aACT,mCAAS,aAAY,OAAO,QAAQ,WAAW,8BAAe,IAAI;AAAA,EACtE;AACF;AAEO,IAAM,aAAa,CACxB,MACA,SACgB;AAChB,QAAM,QAAQ,KAAK,SAAS,IAAI;AAChC,SACE,iCACG;AAAA,SAAK,SAAS,KAAK,OAAO,KAAK,IAAI,SAAS;AAAA,IAC5C,KAAK,YAAY,QAAQ,oBAAC,cAAW,OAAc,IAAK;AAAA,KAC3D;AAEJ;AAEO,IAAM,qBAAqB,CAChC,MACA,SACuB;AACvB,SACE,qBAAC,SAAS,MAAT,EACC;AAAA,wBAAC,SAAS,OAAT,EAAgB,eAAK,OAAM;AAAA,IAC5B,oBAAC,SAAS,OAAT,EAAgB,qBAAW,MAAM,IAAI,GAAE;AAAA,OAFtB,KAAK,KAGzB;AAEJ;AAEO,SAAS,WAAW,OAAuC;AAChE,SACE;AAAA,IAAC;AAAA;AAAA,MACC,OAAM;AAAA,MACN,SAAS,MAAM;AACb,aAAK,UAAU,UAAU,UAAU,MAAM,KAAK;AAC9C,cAAM,QAAQ,6CAAU;AAAA,MAC1B;AAAA,MACA,OAAO,EAAE,YAAY,KAAK,WAAW,IAAI;AAAA,MACzC,SAAQ;AAAA,MAER,8BAAC,YAAS;AAAA;AAAA,EACZ;AAEJ;","names":[]}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import {
|
|
2
|
+
DatePicker
|
|
3
|
+
} from "./chunk-GGYG5EKG.js";
|
|
4
|
+
import {
|
|
5
|
+
Box
|
|
6
|
+
} from "./chunk-4Y5BEXVN.js";
|
|
7
|
+
import {
|
|
8
|
+
Flex
|
|
9
|
+
} from "./chunk-25HMMI7R.js";
|
|
10
|
+
import {
|
|
11
|
+
Button
|
|
12
|
+
} from "./chunk-U7JPP7WJ.js";
|
|
13
|
+
import {
|
|
14
|
+
CalendarIcon
|
|
15
|
+
} from "./chunk-OXXF2CUB.js";
|
|
16
|
+
import {
|
|
17
|
+
__objRest,
|
|
18
|
+
__spreadProps,
|
|
19
|
+
__spreadValues
|
|
20
|
+
} from "./chunk-N552FDTV.js";
|
|
21
|
+
|
|
22
|
+
// src/molecules/date-picker/date-picker-button.tsx
|
|
23
|
+
import { useMemo } from "react";
|
|
24
|
+
import { format } from "date-fns";
|
|
25
|
+
import clsx from "clsx";
|
|
26
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
27
|
+
function DatePickerButton(props) {
|
|
28
|
+
const _a = props, { size, placeholder, format: formatProps, disabled } = _a, rest = __objRest(_a, ["size", "placeholder", "format", "disabled"]);
|
|
29
|
+
const buttonProps = useMemo(() => {
|
|
30
|
+
const variant = "outline";
|
|
31
|
+
const color = "gray";
|
|
32
|
+
const baseButtonProps = { size, color, variant };
|
|
33
|
+
return { size, color, variant };
|
|
34
|
+
}, [size]);
|
|
35
|
+
const selectFormat = useMemo(() => {
|
|
36
|
+
if (formatProps)
|
|
37
|
+
return formatProps;
|
|
38
|
+
return (date) => date ? format(date, "yyyy\uB144 MM\uC6D4 dd\uC77C") : placeholder;
|
|
39
|
+
}, [formatProps, placeholder]);
|
|
40
|
+
const className = useMemo(() => {
|
|
41
|
+
return clsx("date-picker-button", disabled && "disabled");
|
|
42
|
+
}, [disabled]);
|
|
43
|
+
return /* @__PURE__ */ jsx(Box, { p: "0", width: "100%", children: /* @__PURE__ */ jsx(
|
|
44
|
+
DatePicker,
|
|
45
|
+
__spreadProps(__spreadValues({
|
|
46
|
+
customInput: /* @__PURE__ */ jsx(Button, __spreadProps(__spreadValues({ className, type: "button" }, buttonProps), { children: /* @__PURE__ */ jsxs(Flex, { align: "center", gap: "3", justify: "between", width: "100%", children: [
|
|
47
|
+
rest.selected ? selectFormat(rest.selected) : placeholder,
|
|
48
|
+
/* @__PURE__ */ jsx(CalendarIcon, {})
|
|
49
|
+
] }) })),
|
|
50
|
+
wrapperClassName: "full-width"
|
|
51
|
+
}, rest), {
|
|
52
|
+
disabled
|
|
53
|
+
})
|
|
54
|
+
) });
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
export {
|
|
58
|
+
DatePickerButton
|
|
59
|
+
};
|
|
60
|
+
//# sourceMappingURL=chunk-ODQOSBF2.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/molecules/date-picker/date-picker-button.tsx"],"sourcesContent":["import React, { useMemo } from 'react';\nimport { format } from 'date-fns';\nimport type { ButtonProps } from '../../atoms';\nimport { Box, Button, Flex } from '../../atoms';\nimport { CalendarIcon } from '../../icon';\nimport type { DatePickerProps } from '.';\nimport { DatePicker } from '.';\nimport clsx from 'clsx';\n\nexport type DatePickerButtonProps = DatePickerProps & {\n placeholder?: React.ReactNode;\n format?: (date: Date) => string;\n size?: ButtonProps['size'];\n};\n\nexport function DatePickerButton(\n props: DatePickerButtonProps\n): React.ReactElement {\n const { size, placeholder, format: formatProps, disabled, ...rest } = props;\n\n const buttonProps = useMemo(() => {\n const variant: ButtonProps['variant'] = 'outline';\n const color: ButtonProps['color'] = 'gray';\n\n const baseButtonProps = { size, color, variant };\n\n return { size, color, variant };\n }, [size]);\n\n const selectFormat = useMemo(() => {\n if (formatProps) return formatProps;\n return (date?: Date) =>\n date ? format(date, 'yyyy년 MM월 dd일') : placeholder;\n }, [formatProps, placeholder]);\n\n const className = useMemo(() => {\n return clsx('date-picker-button', disabled && 'disabled');\n }, [disabled]);\n\n return (\n <Box p=\"0\" width=\"100%\">\n <DatePicker\n customInput={\n <Button className={className} type=\"button\" {...buttonProps}>\n <Flex align=\"center\" gap=\"3\" justify=\"between\" width=\"100%\">\n {rest.selected ? selectFormat(rest.selected) : placeholder}\n <CalendarIcon />\n </Flex>\n </Button>\n }\n wrapperClassName=\"full-width\"\n {...rest}\n disabled={disabled}\n />\n </Box>\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAAA,SAAgB,eAAe;AAC/B,SAAS,cAAc;AAMvB,OAAO,UAAU;AAqCL,SAEE,KAFF;AA7BL,SAAS,iBACd,OACoB;AACpB,QAAsE,YAA9D,QAAM,aAAa,QAAQ,aAAa,SAlBlD,IAkBwE,IAAT,iBAAS,IAAT,CAArD,QAAM,eAAa,UAAqB;AAEhD,QAAM,cAAc,QAAQ,MAAM;AAChC,UAAM,UAAkC;AACxC,UAAM,QAA8B;AAEpC,UAAM,kBAAkB,EAAE,MAAM,OAAO,QAAQ;AAE/C,WAAO,EAAE,MAAM,OAAO,QAAQ;AAAA,EAChC,GAAG,CAAC,IAAI,CAAC;AAET,QAAM,eAAe,QAAQ,MAAM;AACjC,QAAI;AAAa,aAAO;AACxB,WAAO,CAAC,SACN,OAAO,OAAO,MAAM,8BAAe,IAAI;AAAA,EAC3C,GAAG,CAAC,aAAa,WAAW,CAAC;AAE7B,QAAM,YAAY,QAAQ,MAAM;AAC9B,WAAO,KAAK,sBAAsB,YAAY,UAAU;AAAA,EAC1D,GAAG,CAAC,QAAQ,CAAC;AAEb,SACE,oBAAC,OAAI,GAAE,KAAI,OAAM,QACf;AAAA,IAAC;AAAA;AAAA,MACC,aACE,oBAAC,uCAAO,WAAsB,MAAK,YAAa,cAA/C,EACC,+BAAC,QAAK,OAAM,UAAS,KAAI,KAAI,SAAQ,WAAU,OAAM,QAClD;AAAA,aAAK,WAAW,aAAa,KAAK,QAAQ,IAAI;AAAA,QAC/C,oBAAC,gBAAa;AAAA,SAChB,IACF;AAAA,MAEF,kBAAiB;AAAA,OACb,OAVL;AAAA,MAWC;AAAA;AAAA,EACF,GACF;AAEJ;","names":[]}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import {
|
|
2
|
+
DatePicker
|
|
3
|
+
} from "./chunk-GGYG5EKG.js";
|
|
4
|
+
import {
|
|
5
|
+
Box
|
|
6
|
+
} from "./chunk-4Y5BEXVN.js";
|
|
7
|
+
import {
|
|
8
|
+
Flex
|
|
9
|
+
} from "./chunk-25HMMI7R.js";
|
|
10
|
+
import {
|
|
11
|
+
Button
|
|
12
|
+
} from "./chunk-U7JPP7WJ.js";
|
|
13
|
+
import {
|
|
14
|
+
CalendarIcon
|
|
15
|
+
} from "./chunk-OXXF2CUB.js";
|
|
16
|
+
import {
|
|
17
|
+
__objRest,
|
|
18
|
+
__spreadProps,
|
|
19
|
+
__spreadValues
|
|
20
|
+
} from "./chunk-N552FDTV.js";
|
|
21
|
+
|
|
22
|
+
// src/molecules/date-picker/date-picker-button.tsx
|
|
23
|
+
import { useMemo } from "react";
|
|
24
|
+
import { format } from "date-fns";
|
|
25
|
+
import clsx from "clsx";
|
|
26
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
27
|
+
function DatePickerButton(props) {
|
|
28
|
+
const _a = props, { size, placeholder, format: formatProps, disabled } = _a, rest = __objRest(_a, ["size", "placeholder", "format", "disabled"]);
|
|
29
|
+
const buttonProps = useMemo(() => {
|
|
30
|
+
const variant = "outline";
|
|
31
|
+
const color = "gray";
|
|
32
|
+
return { size, color, variant };
|
|
33
|
+
}, [size]);
|
|
34
|
+
const selectFormat = useMemo(() => {
|
|
35
|
+
if (formatProps)
|
|
36
|
+
return formatProps;
|
|
37
|
+
return (date) => date ? format(date, "yyyy\uB144 MM\uC6D4 dd\uC77C") : placeholder;
|
|
38
|
+
}, [formatProps, placeholder]);
|
|
39
|
+
const className = useMemo(() => {
|
|
40
|
+
return clsx("date-picker-button", disabled && "disabled");
|
|
41
|
+
}, [disabled]);
|
|
42
|
+
return /* @__PURE__ */ jsx(Box, { p: "0", width: "100%", children: /* @__PURE__ */ jsx(
|
|
43
|
+
DatePicker,
|
|
44
|
+
__spreadProps(__spreadValues({
|
|
45
|
+
customInput: /* @__PURE__ */ jsx(Button, __spreadProps(__spreadValues({ className, type: "button" }, buttonProps), { children: /* @__PURE__ */ jsxs(Flex, { align: "center", gap: "3", justify: "between", width: "100%", children: [
|
|
46
|
+
rest.selected ? selectFormat(rest.selected) : placeholder,
|
|
47
|
+
/* @__PURE__ */ jsx(CalendarIcon, {})
|
|
48
|
+
] }) })),
|
|
49
|
+
wrapperClassName: "full-width"
|
|
50
|
+
}, rest), {
|
|
51
|
+
disabled
|
|
52
|
+
})
|
|
53
|
+
) });
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
export {
|
|
57
|
+
DatePickerButton
|
|
58
|
+
};
|
|
59
|
+
//# sourceMappingURL=chunk-OSPGUZX5.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/molecules/date-picker/date-picker-button.tsx"],"sourcesContent":["import React, { useMemo } from 'react';\nimport { format } from 'date-fns';\nimport clsx from 'clsx';\nimport type { ButtonProps } from '../../atoms';\nimport { Box, Button, Flex } from '../../atoms';\nimport { CalendarIcon } from '../../icon';\nimport type { DatePickerProps } from '.';\nimport { DatePicker } from '.';\n\nexport type DatePickerButtonProps = DatePickerProps & {\n placeholder?: React.ReactNode;\n format?: (date: Date) => string;\n size?: ButtonProps['size'];\n};\n\nexport function DatePickerButton(\n props: DatePickerButtonProps\n): React.ReactElement {\n const { size, placeholder, format: formatProps, disabled, ...rest } = props;\n\n const buttonProps = useMemo(() => {\n const variant: ButtonProps['variant'] = 'outline';\n const color: ButtonProps['color'] = 'gray';\n return { size, color, variant };\n }, [size]);\n\n const selectFormat = useMemo(() => {\n if (formatProps) return formatProps;\n return (date?: Date) =>\n date ? format(date, 'yyyy년 MM월 dd일') : placeholder;\n }, [formatProps, placeholder]);\n\n const className = useMemo(() => {\n return clsx('date-picker-button', disabled && 'disabled');\n }, [disabled]);\n\n return (\n <Box p=\"0\" width=\"100%\">\n <DatePicker\n customInput={\n <Button className={className} type=\"button\" {...buttonProps}>\n <Flex align=\"center\" gap=\"3\" justify=\"between\" width=\"100%\">\n {rest.selected ? selectFormat(rest.selected) : placeholder}\n <CalendarIcon />\n </Flex>\n </Button>\n }\n wrapperClassName=\"full-width\"\n {...rest}\n disabled={disabled}\n />\n </Box>\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAAA,SAAgB,eAAe;AAC/B,SAAS,cAAc;AACvB,OAAO,UAAU;AAuCL,SAEE,KAFF;AA1BL,SAAS,iBACd,OACoB;AACpB,QAAsE,YAA9D,QAAM,aAAa,QAAQ,aAAa,SAlBlD,IAkBwE,IAAT,iBAAS,IAAT,CAArD,QAAM,eAAa,UAAqB;AAEhD,QAAM,cAAc,QAAQ,MAAM;AAChC,UAAM,UAAkC;AACxC,UAAM,QAA8B;AACpC,WAAO,EAAE,MAAM,OAAO,QAAQ;AAAA,EAChC,GAAG,CAAC,IAAI,CAAC;AAET,QAAM,eAAe,QAAQ,MAAM;AACjC,QAAI;AAAa,aAAO;AACxB,WAAO,CAAC,SACN,OAAO,OAAO,MAAM,8BAAe,IAAI;AAAA,EAC3C,GAAG,CAAC,aAAa,WAAW,CAAC;AAE7B,QAAM,YAAY,QAAQ,MAAM;AAC9B,WAAO,KAAK,sBAAsB,YAAY,UAAU;AAAA,EAC1D,GAAG,CAAC,QAAQ,CAAC;AAEb,SACE,oBAAC,OAAI,GAAE,KAAI,OAAM,QACf;AAAA,IAAC;AAAA;AAAA,MACC,aACE,oBAAC,uCAAO,WAAsB,MAAK,YAAa,cAA/C,EACC,+BAAC,QAAK,OAAM,UAAS,KAAI,KAAI,SAAQ,WAAU,OAAM,QAClD;AAAA,aAAK,WAAW,aAAa,KAAK,QAAQ,IAAI;AAAA,QAC/C,oBAAC,gBAAa;AAAA,SAChB,IACF;AAAA,MAEF,kBAAiB;AAAA,OACb,OAVL;AAAA,MAWC;AAAA;AAAA,EACF,GACF;AAEJ;","names":[]}
|
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
import {
|
|
2
|
+
DatePickerButton
|
|
3
|
+
} from "./chunk-6OF6INLJ.js";
|
|
4
|
+
import {
|
|
5
|
+
Form
|
|
6
|
+
} from "./chunk-PYR4SVP5.js";
|
|
7
|
+
import {
|
|
8
|
+
TextArea
|
|
9
|
+
} from "./chunk-EW6OPYEW.js";
|
|
10
|
+
import {
|
|
11
|
+
TextField
|
|
12
|
+
} from "./chunk-VOQU7ZOV.js";
|
|
13
|
+
import {
|
|
14
|
+
Card
|
|
15
|
+
} from "./chunk-2ZQK7NTN.js";
|
|
16
|
+
import {
|
|
17
|
+
Flex
|
|
18
|
+
} from "./chunk-25HMMI7R.js";
|
|
19
|
+
import {
|
|
20
|
+
Button
|
|
21
|
+
} from "./chunk-U7JPP7WJ.js";
|
|
22
|
+
import {
|
|
23
|
+
__spreadValues
|
|
24
|
+
} from "./chunk-N552FDTV.js";
|
|
25
|
+
|
|
26
|
+
// src/app/platform/goal-manage-card-edit.tsx
|
|
27
|
+
import { useCallback, useState } from "react";
|
|
28
|
+
import { format } from "date-fns";
|
|
29
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
30
|
+
var initialValues = {
|
|
31
|
+
goal: "",
|
|
32
|
+
effect: "",
|
|
33
|
+
huddle: "",
|
|
34
|
+
dueDate: void 0
|
|
35
|
+
};
|
|
36
|
+
var dummyFn = () => {
|
|
37
|
+
};
|
|
38
|
+
function GoalManageCardEdit(props) {
|
|
39
|
+
const { defaultValues, errors } = props;
|
|
40
|
+
const [values, setValues] = useState(defaultValues || initialValues);
|
|
41
|
+
const onChange = useCallback(
|
|
42
|
+
(v) => {
|
|
43
|
+
var _a;
|
|
44
|
+
setValues((prev) => __spreadValues(__spreadValues({}, prev), v));
|
|
45
|
+
(_a = props.onChange) == null ? void 0 : _a.call(props, v);
|
|
46
|
+
},
|
|
47
|
+
[props]
|
|
48
|
+
);
|
|
49
|
+
const onClickInit = useCallback(() => {
|
|
50
|
+
var _a;
|
|
51
|
+
setValues(initialValues);
|
|
52
|
+
(_a = props.onChange) == null ? void 0 : _a.call(props, defaultValues || initialValues);
|
|
53
|
+
}, [defaultValues, props]);
|
|
54
|
+
const onClickSubmit = useCallback(() => {
|
|
55
|
+
var _a;
|
|
56
|
+
(_a = props.onSubmit) == null ? void 0 : _a.call(props, values);
|
|
57
|
+
}, [props, values]);
|
|
58
|
+
return /* @__PURE__ */ jsx(Card, { style: { width: "100%" }, children: /* @__PURE__ */ jsxs(Form.Root, { onSubmit: dummyFn, children: [
|
|
59
|
+
/* @__PURE__ */ jsxs(Flex, { direction: "column", gap: "5", children: [
|
|
60
|
+
/* @__PURE__ */ jsxs(Form.Field, { name: "title", children: [
|
|
61
|
+
/* @__PURE__ */ jsx(Form.Label, { children: "\uC774\uBC88 \uCF54\uCE6D\uC758 \uBAA9\uD45C\uB294 \uC544\uB798\uC640 \uAC19\uC2B5\uB2C8\uB2E4" }),
|
|
62
|
+
/* @__PURE__ */ jsx(
|
|
63
|
+
TextField.Root,
|
|
64
|
+
{
|
|
65
|
+
error: Boolean(errors == null ? void 0 : errors.goal),
|
|
66
|
+
onChange: (e) => {
|
|
67
|
+
onChange({ goal: e.target.value });
|
|
68
|
+
},
|
|
69
|
+
placeholder: "\uC774\uBC88 \uCF54\uCE6D \uACFC\uC815\uC758 \uBAA9\uD45C\uB97C \uD55C \uBB38\uC7A5\uC73C\uB85C \uC801\uC5B4\uC8FC\uC138\uC694",
|
|
70
|
+
value: values.goal
|
|
71
|
+
}
|
|
72
|
+
),
|
|
73
|
+
/* @__PURE__ */ jsx(Form.Message, { forceMatch: Boolean(errors == null ? void 0 : errors.goal), children: errors == null ? void 0 : errors.goal })
|
|
74
|
+
] }),
|
|
75
|
+
/* @__PURE__ */ jsxs(Form.Field, { name: "effect", children: [
|
|
76
|
+
/* @__PURE__ */ jsx(Form.Label, { children: "\uAE30\uB300\uD6A8\uACFC" }),
|
|
77
|
+
/* @__PURE__ */ jsx(
|
|
78
|
+
TextArea,
|
|
79
|
+
{
|
|
80
|
+
error: Boolean(errors == null ? void 0 : errors.effect),
|
|
81
|
+
onChange: (e) => {
|
|
82
|
+
onChange({ effect: e.target.value });
|
|
83
|
+
},
|
|
84
|
+
placeholder: "\uC608\uC2DC : \uD300\uC6D0\uB4E4\uACFC \uB354 \uCE5C\uBC00\uD574\uC9C0\uACE0, \uD300\uC6D0\uB4E4\uC5D0 \uB300\uD55C \uC774\uD574\uB3C4\uAC00 \uC313\uC774\uBA70 \uB354 \uD6A8\uC728\uC801\uC778 \uC778\uC7AC\uAD00\uB9AC\uB97C \uC704\uD55C \uAD00\uACC4\uD615\uC131\uC774 \uAC00\uB2A5\uD574\uC9D1\uB2C8\uB2E4.",
|
|
85
|
+
resize: "vertical",
|
|
86
|
+
value: values.effect
|
|
87
|
+
}
|
|
88
|
+
),
|
|
89
|
+
/* @__PURE__ */ jsx(Form.Message, { forceMatch: Boolean(errors == null ? void 0 : errors.effect), children: errors == null ? void 0 : errors.effect })
|
|
90
|
+
] }),
|
|
91
|
+
/* @__PURE__ */ jsxs(Form.Field, { name: "huddle", children: [
|
|
92
|
+
/* @__PURE__ */ jsx(Form.Label, { children: "\uBC29\uD574\uC694\uC18C" }),
|
|
93
|
+
/* @__PURE__ */ jsx(
|
|
94
|
+
TextArea,
|
|
95
|
+
{
|
|
96
|
+
error: Boolean(errors == null ? void 0 : errors.huddle),
|
|
97
|
+
onChange: (e) => {
|
|
98
|
+
onChange({ huddle: e.target.value });
|
|
99
|
+
},
|
|
100
|
+
placeholder: `- \uAC11\uC790\uAE30 \uC7A1\uD788\uB294 \uBBF8\uD305\uB4E4
|
|
101
|
+
- MZ \uC138\uB300\uC640\uC758 \uC790\uC5F0\uC2A4\uB7FD\uC9C0 \uC54A\uC740 \uC18C\uD1B5
|
|
102
|
+
- \uB300\uD654\uC5D0\uC11C \uCC38\uC744\uC131 \uBD80\uC871`,
|
|
103
|
+
resize: "vertical",
|
|
104
|
+
value: values.huddle
|
|
105
|
+
}
|
|
106
|
+
),
|
|
107
|
+
/* @__PURE__ */ jsx(Form.Message, { forceMatch: Boolean(errors == null ? void 0 : errors.huddle), children: errors == null ? void 0 : errors.huddle })
|
|
108
|
+
] }),
|
|
109
|
+
/* @__PURE__ */ jsxs(Form.Field, { name: "dueDate", children: [
|
|
110
|
+
/* @__PURE__ */ jsx(Form.Label, { children: "\uBAA9\uD45C \uB2EC\uC131 \uAE30\uD55C\uC740 \uB2E4\uC74C\uACFC \uAC19\uC2B5\uB2C8\uB2E4" }),
|
|
111
|
+
/* @__PURE__ */ jsx(
|
|
112
|
+
DatePickerButton,
|
|
113
|
+
{
|
|
114
|
+
format: (v) => format(v, "yyyy\uB144 MM\uC6D4 dd\uC77C"),
|
|
115
|
+
onChange: (date) => {
|
|
116
|
+
date && onChange({ dueDate: date });
|
|
117
|
+
},
|
|
118
|
+
placeholder: "YYYY\uB144 MM\uC6D4 DD\uC77C",
|
|
119
|
+
selected: values.dueDate
|
|
120
|
+
}
|
|
121
|
+
),
|
|
122
|
+
/* @__PURE__ */ jsx(Form.Message, { forceMatch: Boolean(errors == null ? void 0 : errors.dueDate), children: errors == null ? void 0 : errors.dueDate })
|
|
123
|
+
] })
|
|
124
|
+
] }),
|
|
125
|
+
/* @__PURE__ */ jsxs(Flex, { gap: "3", justify: "end", width: "100%", children: [
|
|
126
|
+
/* @__PURE__ */ jsx(
|
|
127
|
+
Button,
|
|
128
|
+
{
|
|
129
|
+
color: "gray",
|
|
130
|
+
onClick: onClickInit,
|
|
131
|
+
size: "small",
|
|
132
|
+
type: "button",
|
|
133
|
+
variant: "outline",
|
|
134
|
+
children: "\uCD08\uAE30\uD654\uD558\uAE30"
|
|
135
|
+
}
|
|
136
|
+
),
|
|
137
|
+
/* @__PURE__ */ jsx(Button, { onClick: onClickSubmit, size: "small", type: "button", children: "\uC800\uC7A5\uD558\uAE30" })
|
|
138
|
+
] })
|
|
139
|
+
] }) });
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
export {
|
|
143
|
+
GoalManageCardEdit
|
|
144
|
+
};
|
|
145
|
+
//# sourceMappingURL=chunk-OYQY63G2.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/app/platform/goal-manage-card-edit.tsx"],"sourcesContent":["import React, { useCallback, useState } from 'react';\nimport { format } from 'date-fns';\nimport { Button, Card, Flex, Form, TextArea, TextField } from '../../atoms';\nimport { DatePickerButton } from '../../molecules';\n\ninterface Values {\n goal?: string;\n effect?: string;\n huddle?: string;\n dueDate?: Date;\n}\n\ninterface GoalManageCardEditProps {\n onChange?: (values: Partial<Values>) => void;\n defaultValues?: Values;\n errors?: { [key in keyof Values]: string };\n onSubmit?: (values: Values) => void;\n}\n\nconst initialValues: Values = {\n goal: '',\n effect: '',\n huddle: '',\n dueDate: undefined,\n};\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function -- dummy용 함수\nconst dummyFn = (): void => {};\n\nexport function GoalManageCardEdit(\n props: GoalManageCardEditProps\n): React.ReactElement {\n const { defaultValues, errors } = props;\n const [values, setValues] = useState(defaultValues || initialValues);\n\n const onChange = useCallback(\n (v: Partial<Values>) => {\n setValues((prev) => ({ ...prev, ...v }));\n props.onChange?.(v);\n },\n [props]\n );\n\n const onClickInit = useCallback(() => {\n setValues(initialValues);\n props.onChange?.(defaultValues || initialValues);\n }, [defaultValues, props]);\n\n const onClickSubmit = useCallback(() => {\n props.onSubmit?.(values);\n }, [props, values]);\n\n return (\n <Card style={{ width: '100%' }}>\n <Form.Root onSubmit={dummyFn}>\n <Flex direction=\"column\" gap=\"5\">\n <Form.Field name=\"title\">\n <Form.Label>이번 코칭의 목표는 아래와 같습니다</Form.Label>\n <TextField.Root\n error={Boolean(errors?.goal)}\n onChange={(e) => {\n onChange({ goal: e.target.value });\n }}\n placeholder=\"이번 코칭 과정의 목표를 한 문장으로 적어주세요\"\n value={values.goal}\n />\n <Form.Message forceMatch={Boolean(errors?.goal)}>\n {errors?.goal}\n </Form.Message>\n </Form.Field>\n\n <Form.Field name=\"effect\">\n <Form.Label>기대효과</Form.Label>\n <TextArea\n error={Boolean(errors?.effect)}\n onChange={(e) => {\n onChange({ effect: e.target.value });\n }}\n placeholder=\"예시 : 팀원들과 더 친밀해지고, 팀원들에 대한 이해도가 쌓이며 더 효율적인 인재관리를 위한 관계형성이 가능해집니다.\"\n resize=\"vertical\"\n value={values.effect}\n />\n <Form.Message forceMatch={Boolean(errors?.effect)}>\n {errors?.effect}\n </Form.Message>\n </Form.Field>\n\n <Form.Field name=\"huddle\">\n <Form.Label>방해요소</Form.Label>\n <TextArea\n error={Boolean(errors?.huddle)}\n onChange={(e) => {\n onChange({ huddle: e.target.value });\n }}\n placeholder={`- 갑자기 잡히는 미팅들\n- MZ 세대와의 자연스럽지 않은 소통\n- 대화에서 참을성 부족`}\n resize=\"vertical\"\n value={values.huddle}\n />\n <Form.Message forceMatch={Boolean(errors?.huddle)}>\n {errors?.huddle}\n </Form.Message>\n </Form.Field>\n\n <Form.Field name=\"dueDate\">\n <Form.Label>목표 달성 기한은 다음과 같습니다</Form.Label>\n <DatePickerButton\n format={(v) => format(v, 'yyyy년 MM월 dd일')}\n onChange={(date) => {\n date && onChange({ dueDate: date });\n }}\n placeholder=\"YYYY년 MM월 DD일\"\n selected={values.dueDate}\n />\n <Form.Message forceMatch={Boolean(errors?.dueDate)}>\n {errors?.dueDate}\n </Form.Message>\n </Form.Field>\n </Flex>\n\n <Flex gap=\"3\" justify=\"end\" width=\"100%\">\n <Button\n color=\"gray\"\n onClick={onClickInit}\n size=\"small\"\n type=\"button\"\n variant=\"outline\"\n >\n 초기화하기\n </Button>\n <Button onClick={onClickSubmit} size=\"small\" type=\"button\">\n 저장하기\n </Button>\n </Flex>\n </Form.Root>\n </Card>\n );\n}\n"],"mappings":"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","names":[]}
|