@tipp/ui 1.5.8 → 1.5.9
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 +17 -3
- package/dist/app/index.cjs.map +1 -1
- package/dist/app/index.d.cts +2 -2
- package/dist/app/index.d.ts +2 -2
- package/dist/app/index.js +25 -25
- package/dist/app/platform/edit-coaching-time.js +2 -2
- package/dist/app/platform/edit-service-type.js +2 -2
- package/dist/app/platform/goal-manage-card-edit.js +2 -2
- package/dist/app/platform/on-offline-radio-card.js +2 -2
- package/dist/app/platform/reservation-card.js +2 -2
- package/dist/app/platform/session-card.js +2 -2
- package/dist/app/platform/userInfos/coaching-customer-info/index.cjs +17 -3
- package/dist/app/platform/userInfos/coaching-customer-info/index.cjs.map +1 -1
- package/dist/app/platform/userInfos/coaching-customer-info/index.d.cts +1 -1
- package/dist/app/platform/userInfos/coaching-customer-info/index.d.ts +1 -1
- package/dist/app/platform/userInfos/coaching-customer-info/index.js +4 -4
- package/dist/app/platform/userInfos/coaching-customer-info/large.cjs +17 -3
- package/dist/app/platform/userInfos/coaching-customer-info/large.cjs.map +1 -1
- package/dist/app/platform/userInfos/coaching-customer-info/large.js +2 -2
- package/dist/app/platform/userInfos/coaching-customer-info/medium.cjs +17 -3
- package/dist/app/platform/userInfos/coaching-customer-info/medium.cjs.map +1 -1
- package/dist/app/platform/userInfos/coaching-customer-info/medium.js +2 -2
- package/dist/app/platform/userInfos/session-user-info-detail.cjs +17 -3
- package/dist/app/platform/userInfos/session-user-info-detail.cjs.map +1 -1
- package/dist/app/platform/userInfos/session-user-info-detail.js +2 -2
- package/dist/app/platform/userInfos/utils.cjs +17 -3
- package/dist/app/platform/userInfos/utils.cjs.map +1 -1
- package/dist/app/platform/userInfos/utils.js +1 -1
- package/dist/chunk-3BWQX4DB.js +30 -0
- package/dist/chunk-3BWQX4DB.js.map +1 -0
- package/dist/chunk-3TRGVGKR.js +59 -0
- package/dist/chunk-3TRGVGKR.js.map +1 -0
- package/dist/chunk-7AWHIUAV.js +30 -0
- package/dist/chunk-7AWHIUAV.js.map +1 -0
- package/dist/chunk-ANQDN6SW.js +30 -0
- package/dist/chunk-ANQDN6SW.js.map +1 -0
- package/dist/chunk-DUKKMCFP.js +30 -0
- package/dist/chunk-DUKKMCFP.js.map +1 -0
- package/dist/chunk-HDJWUUAZ.js +59 -0
- package/dist/chunk-HDJWUUAZ.js.map +1 -0
- package/dist/chunk-I5XSLBW2.js +103 -0
- package/dist/chunk-I5XSLBW2.js.map +1 -0
- package/dist/chunk-K7PSBABU.js +64 -0
- package/dist/chunk-K7PSBABU.js.map +1 -0
- package/dist/chunk-PAGVOUG2.js +64 -0
- package/dist/chunk-PAGVOUG2.js.map +1 -0
- package/dist/chunk-PEE4A2AC.js +76 -0
- package/dist/chunk-PEE4A2AC.js.map +1 -0
- package/dist/chunk-SVR5RJQJ.js +52 -0
- package/dist/chunk-SVR5RJQJ.js.map +1 -0
- package/dist/chunk-UXAD2OSK.js +30 -0
- package/dist/chunk-UXAD2OSK.js.map +1 -0
- package/dist/chunk-X3P223HR.js +76 -0
- package/dist/chunk-X3P223HR.js.map +1 -0
- package/dist/index.cjs +17 -3
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +2 -2
- package/dist/index.d.ts +2 -2
- package/dist/index.js +25 -25
- package/dist/molecules/index.js +2 -2
- package/package.json +2 -2
- package/src/app/platform/userInfos/coaching-customer-info/index.tsx +2 -0
- package/src/app/platform/userInfos/utils.tsx +21 -6
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/app/platform/userInfos/coaching-customer-info/small.tsx"],"sourcesContent":["import React, { useMemo } from 'react';\nimport {\n getColorFromProjectState,\n getTextFromProjectState,\n} from '@tipp/biz-utils';\nimport { Badge, Box, Flex, Grid, Heading, Typo } from '../../../../atoms';\nimport type { CoachingCustomerInfoProps } from '../utils';\n\nexport function CoachingCustomerInfoSmall({\n customer,\n session,\n children,\n}: CoachingCustomerInfoProps): React.ReactElement {\n const badgeColor = useMemo(() => {\n return getColorFromProjectState(session?.state);\n }, [session?.state]);\n\n const sessionText = useMemo(() => {\n return getTextFromProjectState(session?.state);\n }, [session?.state]);\n\n return (\n <Flex\n direction={{ initial: 'column', xs: 'row' }}\n gap=\"3\"\n justify=\"between\"\n >\n {/* 이름, 사명 */}\n <Box>\n <Grid align=\"center\" columns=\"auto auto 1fr\" gapX=\"3\">\n <Heading variant=\"heading3\">\n {customer?.username || '이름 없음'}\n </Heading>\n <Typo color=\"gray\" truncate variant=\"body\">\n {customer?.company}\n </Typo>\n <Box style={{ justifySelf: 'end' }}>\n <Badge color={badgeColor}>{sessionText}</Badge>\n </Box>\n </Grid>\n </Box>\n {children}\n </Flex>\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA,SAAgB,eAAe;AAC/B;AAAA,EACE;AAAA,EACA;AAAA,OACK;AAyBC,SACE,KADF;AArBD,SAAS,0BAA0B;AAAA,EACxC;AAAA,EACA;AAAA,EACA;AACF,GAAkD;AAChD,QAAM,aAAa,QAAQ,MAAM;AAC/B,WAAO,yBAAyB,mCAAS,KAAK;AAAA,EAChD,GAAG,CAAC,mCAAS,KAAK,CAAC;AAEnB,QAAM,cAAc,QAAQ,MAAM;AAChC,WAAO,wBAAwB,mCAAS,KAAK;AAAA,EAC/C,GAAG,CAAC,mCAAS,KAAK,CAAC;AAEnB,SACE;AAAA,IAAC;AAAA;AAAA,MACC,WAAW,EAAE,SAAS,UAAU,IAAI,MAAM;AAAA,MAC1C,KAAI;AAAA,MACJ,SAAQ;AAAA,MAGR;AAAA,4BAAC,OACC,+BAAC,QAAK,OAAM,UAAS,SAAQ,iBAAgB,MAAK,KAChD;AAAA,8BAAC,WAAQ,SAAQ,YACd,gDAAU,aAAY,6BACzB;AAAA,UACA,oBAAC,QAAK,OAAM,QAAO,UAAQ,MAAC,SAAQ,QACjC,+CAAU,SACb;AAAA,UACA,oBAAC,OAAI,OAAO,EAAE,aAAa,MAAM,GAC/B,8BAAC,SAAM,OAAO,YAAa,uBAAY,GACzC;AAAA,WACF,GACF;AAAA,QACC;AAAA;AAAA;AAAA,EACH;AAEJ;","names":[]}
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
import {
|
|
2
|
+
DataList
|
|
3
|
+
} from "./chunk-VTJZMOSP.js";
|
|
4
|
+
import {
|
|
5
|
+
toast
|
|
6
|
+
} from "./chunk-CYYWMYE7.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-I5XSLBW2.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}\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;AA8GrB,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,64 @@
|
|
|
1
|
+
import {
|
|
2
|
+
infoList,
|
|
3
|
+
renderDataListItem,
|
|
4
|
+
sessionList
|
|
5
|
+
} from "./chunk-I5XSLBW2.js";
|
|
6
|
+
import {
|
|
7
|
+
DataList
|
|
8
|
+
} from "./chunk-VTJZMOSP.js";
|
|
9
|
+
import {
|
|
10
|
+
Heading
|
|
11
|
+
} from "./chunk-HK224ADT.js";
|
|
12
|
+
import {
|
|
13
|
+
Separator
|
|
14
|
+
} from "./chunk-HYITAA4J.js";
|
|
15
|
+
import {
|
|
16
|
+
Card
|
|
17
|
+
} from "./chunk-2ZQK7NTN.js";
|
|
18
|
+
import {
|
|
19
|
+
Badge
|
|
20
|
+
} from "./chunk-EWD4AO5N.js";
|
|
21
|
+
import {
|
|
22
|
+
Box
|
|
23
|
+
} from "./chunk-4Y5BEXVN.js";
|
|
24
|
+
import {
|
|
25
|
+
Flex
|
|
26
|
+
} from "./chunk-25HMMI7R.js";
|
|
27
|
+
|
|
28
|
+
// src/app/platform/userInfos/coaching-customer-info/large.tsx
|
|
29
|
+
import { useMemo } from "react";
|
|
30
|
+
import {
|
|
31
|
+
getColorFromProjectState,
|
|
32
|
+
getTextFromProjectState
|
|
33
|
+
} from "@tipp/biz-utils";
|
|
34
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
35
|
+
function CoachingCustomerInfoLarge({
|
|
36
|
+
customer,
|
|
37
|
+
session,
|
|
38
|
+
children
|
|
39
|
+
}) {
|
|
40
|
+
const badgeColor = useMemo(() => {
|
|
41
|
+
return getColorFromProjectState(session == null ? void 0 : session.state);
|
|
42
|
+
}, [session == null ? void 0 : session.state]);
|
|
43
|
+
const sessionText = useMemo(() => {
|
|
44
|
+
return getTextFromProjectState(session == null ? void 0 : session.state);
|
|
45
|
+
}, [session == null ? void 0 : session.state]);
|
|
46
|
+
return /* @__PURE__ */ jsxs(Flex, { direction: "column", gap: "5", children: [
|
|
47
|
+
/* @__PURE__ */ jsxs(Box, { children: [
|
|
48
|
+
/* @__PURE__ */ jsxs(Flex, { align: "center", justify: "between", mb: "1", width: "100%", children: [
|
|
49
|
+
/* @__PURE__ */ jsx(Heading, { variant: "heading2", children: (customer == null ? void 0 : customer.username) || "\uC774\uB984 \uC5C6\uC74C" }),
|
|
50
|
+
/* @__PURE__ */ jsx(Badge, { color: badgeColor, children: sessionText })
|
|
51
|
+
] }),
|
|
52
|
+
/* @__PURE__ */ jsx(Heading, { truncate: true, variant: "heading4", weight: "regular", children: customer == null ? void 0 : customer.company })
|
|
53
|
+
] }),
|
|
54
|
+
children,
|
|
55
|
+
/* @__PURE__ */ jsx(Card, { size: "2", children: /* @__PURE__ */ jsx(DataList.Root, { children: sessionList.map((el) => renderDataListItem(el, session)) }) }),
|
|
56
|
+
/* @__PURE__ */ jsx(Separator, { size: "4" }),
|
|
57
|
+
/* @__PURE__ */ jsx(DataList.Root, { children: infoList.map((info) => renderDataListItem(info, customer)) })
|
|
58
|
+
] });
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
export {
|
|
62
|
+
CoachingCustomerInfoLarge
|
|
63
|
+
};
|
|
64
|
+
//# sourceMappingURL=chunk-K7PSBABU.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/app/platform/userInfos/coaching-customer-info/large.tsx"],"sourcesContent":["import React, { useMemo } from 'react';\nimport {\n getColorFromProjectState,\n getTextFromProjectState,\n} from '@tipp/biz-utils';\nimport {\n Badge,\n Box,\n Card,\n DataList,\n Flex,\n Heading,\n Separator,\n} from '../../../../atoms';\nimport type { CoachingCustomerInfoProps } from '../utils';\nimport { infoList, renderDataListItem, sessionList } from '../utils';\n\nexport function CoachingCustomerInfoLarge({\n customer,\n session,\n children,\n}: CoachingCustomerInfoProps): React.ReactElement {\n const badgeColor = useMemo(() => {\n return getColorFromProjectState(session?.state);\n }, [session?.state]);\n\n const sessionText = useMemo(() => {\n return getTextFromProjectState(session?.state);\n }, [session?.state]);\n\n return (\n <Flex direction=\"column\" gap=\"5\">\n {/* 이름, 사명 */}\n <Box>\n <Flex align=\"center\" justify=\"between\" mb=\"1\" width=\"100%\">\n <Heading variant=\"heading2\">\n {customer?.username || '이름 없음'}\n </Heading>\n <Badge color={badgeColor}>{sessionText}</Badge>\n </Flex>\n <Heading truncate variant=\"heading4\" weight=\"regular\">\n {customer?.company}\n </Heading>\n </Box>\n\n {children}\n\n {/* 세션 정보 */}\n <Card size=\"2\">\n <DataList.Root>\n {sessionList.map((el) => renderDataListItem(el, session))}\n </DataList.Root>\n </Card>\n\n {/* 회원 정보 */}\n <Separator size=\"4\" />\n <DataList.Root>\n {infoList.map((info) => renderDataListItem(info, customer))}\n </DataList.Root>\n </Flex>\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,SAAgB,eAAe;AAC/B;AAAA,EACE;AAAA,EACA;AAAA,OACK;AA8BC,SACE,KADF;AAjBD,SAAS,0BAA0B;AAAA,EACxC;AAAA,EACA;AAAA,EACA;AACF,GAAkD;AAChD,QAAM,aAAa,QAAQ,MAAM;AAC/B,WAAO,yBAAyB,mCAAS,KAAK;AAAA,EAChD,GAAG,CAAC,mCAAS,KAAK,CAAC;AAEnB,QAAM,cAAc,QAAQ,MAAM;AAChC,WAAO,wBAAwB,mCAAS,KAAK;AAAA,EAC/C,GAAG,CAAC,mCAAS,KAAK,CAAC;AAEnB,SACE,qBAAC,QAAK,WAAU,UAAS,KAAI,KAE3B;AAAA,yBAAC,OACC;AAAA,2BAAC,QAAK,OAAM,UAAS,SAAQ,WAAU,IAAG,KAAI,OAAM,QAClD;AAAA,4BAAC,WAAQ,SAAQ,YACd,gDAAU,aAAY,6BACzB;AAAA,QACA,oBAAC,SAAM,OAAO,YAAa,uBAAY;AAAA,SACzC;AAAA,MACA,oBAAC,WAAQ,UAAQ,MAAC,SAAQ,YAAW,QAAO,WACzC,+CAAU,SACb;AAAA,OACF;AAAA,IAEC;AAAA,IAGD,oBAAC,QAAK,MAAK,KACT,8BAAC,SAAS,MAAT,EACE,sBAAY,IAAI,CAAC,OAAO,mBAAmB,IAAI,OAAO,CAAC,GAC1D,GACF;AAAA,IAGA,oBAAC,aAAU,MAAK,KAAI;AAAA,IACpB,oBAAC,SAAS,MAAT,EACE,mBAAS,IAAI,CAAC,SAAS,mBAAmB,MAAM,QAAQ,CAAC,GAC5D;AAAA,KACF;AAEJ;","names":[]}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import {
|
|
2
|
+
infoList,
|
|
3
|
+
renderDataListItem,
|
|
4
|
+
sessionList
|
|
5
|
+
} from "./chunk-I5XSLBW2.js";
|
|
6
|
+
import {
|
|
7
|
+
DataList
|
|
8
|
+
} from "./chunk-VTJZMOSP.js";
|
|
9
|
+
import {
|
|
10
|
+
Heading
|
|
11
|
+
} from "./chunk-HK224ADT.js";
|
|
12
|
+
import {
|
|
13
|
+
Separator
|
|
14
|
+
} from "./chunk-HYITAA4J.js";
|
|
15
|
+
import {
|
|
16
|
+
Box
|
|
17
|
+
} from "./chunk-4Y5BEXVN.js";
|
|
18
|
+
import {
|
|
19
|
+
Flex
|
|
20
|
+
} from "./chunk-25HMMI7R.js";
|
|
21
|
+
import {
|
|
22
|
+
Card
|
|
23
|
+
} from "./chunk-2ZQK7NTN.js";
|
|
24
|
+
import {
|
|
25
|
+
Badge
|
|
26
|
+
} from "./chunk-EWD4AO5N.js";
|
|
27
|
+
|
|
28
|
+
// src/app/platform/userInfos/coaching-customer-info/large.tsx
|
|
29
|
+
import { useMemo } from "react";
|
|
30
|
+
import {
|
|
31
|
+
getColorFromProjectState,
|
|
32
|
+
getTextFromProjectState
|
|
33
|
+
} from "@tipp/biz-utils";
|
|
34
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
35
|
+
function CoachingCustomerInfoLarge({
|
|
36
|
+
customer,
|
|
37
|
+
session,
|
|
38
|
+
children
|
|
39
|
+
}) {
|
|
40
|
+
const badgeColor = useMemo(() => {
|
|
41
|
+
return getColorFromProjectState(session == null ? void 0 : session.state);
|
|
42
|
+
}, [session == null ? void 0 : session.state]);
|
|
43
|
+
const sessionText = useMemo(() => {
|
|
44
|
+
return getTextFromProjectState(session == null ? void 0 : session.state);
|
|
45
|
+
}, [session == null ? void 0 : session.state]);
|
|
46
|
+
return /* @__PURE__ */ jsxs(Flex, { direction: "column", gap: "5", children: [
|
|
47
|
+
/* @__PURE__ */ jsxs(Box, { children: [
|
|
48
|
+
/* @__PURE__ */ jsxs(Flex, { align: "center", justify: "between", mb: "1", width: "100%", children: [
|
|
49
|
+
/* @__PURE__ */ jsx(Heading, { variant: "heading2", children: (customer == null ? void 0 : customer.username) || "\uC774\uB984 \uC5C6\uC74C" }),
|
|
50
|
+
/* @__PURE__ */ jsx(Badge, { color: badgeColor, children: sessionText })
|
|
51
|
+
] }),
|
|
52
|
+
/* @__PURE__ */ jsx(Heading, { truncate: true, variant: "heading4", weight: "regular", children: customer == null ? void 0 : customer.company })
|
|
53
|
+
] }),
|
|
54
|
+
children,
|
|
55
|
+
/* @__PURE__ */ jsx(Card, { size: "2", children: /* @__PURE__ */ jsx(DataList.Root, { children: sessionList.map((el) => renderDataListItem(el, session)) }) }),
|
|
56
|
+
/* @__PURE__ */ jsx(Separator, { size: "4" }),
|
|
57
|
+
/* @__PURE__ */ jsx(DataList.Root, { children: infoList.map((info) => renderDataListItem(info, customer)) })
|
|
58
|
+
] });
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
export {
|
|
62
|
+
CoachingCustomerInfoLarge
|
|
63
|
+
};
|
|
64
|
+
//# sourceMappingURL=chunk-PAGVOUG2.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/app/platform/userInfos/coaching-customer-info/large.tsx"],"sourcesContent":["import React, { useMemo } from 'react';\nimport {\n getColorFromProjectState,\n getTextFromProjectState,\n} from '@tipp/biz-utils';\nimport {\n Badge,\n Box,\n Card,\n DataList,\n Flex,\n Heading,\n Separator,\n} from '../../../../atoms';\nimport type { CoachingCustomerInfoProps } from '../utils';\nimport { infoList, renderDataListItem, sessionList } from '../utils';\n\nexport function CoachingCustomerInfoLarge({\n customer,\n session,\n children,\n}: CoachingCustomerInfoProps): React.ReactElement {\n const badgeColor = useMemo(() => {\n return getColorFromProjectState(session?.state);\n }, [session?.state]);\n\n const sessionText = useMemo(() => {\n return getTextFromProjectState(session?.state);\n }, [session?.state]);\n\n return (\n <Flex direction=\"column\" gap=\"5\">\n {/* 이름, 사명 */}\n <Box>\n <Flex align=\"center\" justify=\"between\" mb=\"1\" width=\"100%\">\n <Heading variant=\"heading2\">\n {customer?.username || '이름 없음'}\n </Heading>\n <Badge color={badgeColor}>{sessionText}</Badge>\n </Flex>\n <Heading truncate variant=\"heading4\" weight=\"regular\">\n {customer?.company}\n </Heading>\n </Box>\n\n {children}\n\n {/* 세션 정보 */}\n <Card size=\"2\">\n <DataList.Root>\n {sessionList.map((el) => renderDataListItem(el, session))}\n </DataList.Root>\n </Card>\n\n {/* 회원 정보 */}\n <Separator size=\"4\" />\n <DataList.Root>\n {infoList.map((info) => renderDataListItem(info, customer))}\n </DataList.Root>\n </Flex>\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,SAAgB,eAAe;AAC/B;AAAA,EACE;AAAA,EACA;AAAA,OACK;AA8BC,SACE,KADF;AAjBD,SAAS,0BAA0B;AAAA,EACxC;AAAA,EACA;AAAA,EACA;AACF,GAAkD;AAChD,QAAM,aAAa,QAAQ,MAAM;AAC/B,WAAO,yBAAyB,mCAAS,KAAK;AAAA,EAChD,GAAG,CAAC,mCAAS,KAAK,CAAC;AAEnB,QAAM,cAAc,QAAQ,MAAM;AAChC,WAAO,wBAAwB,mCAAS,KAAK;AAAA,EAC/C,GAAG,CAAC,mCAAS,KAAK,CAAC;AAEnB,SACE,qBAAC,QAAK,WAAU,UAAS,KAAI,KAE3B;AAAA,yBAAC,OACC;AAAA,2BAAC,QAAK,OAAM,UAAS,SAAQ,WAAU,IAAG,KAAI,OAAM,QAClD;AAAA,4BAAC,WAAQ,SAAQ,YACd,gDAAU,aAAY,6BACzB;AAAA,QACA,oBAAC,SAAM,OAAO,YAAa,uBAAY;AAAA,SACzC;AAAA,MACA,oBAAC,WAAQ,UAAQ,MAAC,SAAQ,YAAW,QAAO,WACzC,+CAAU,SACb;AAAA,OACF;AAAA,IAEC;AAAA,IAGD,oBAAC,QAAK,MAAK,KACT,8BAAC,SAAS,MAAT,EACE,sBAAY,IAAI,CAAC,OAAO,mBAAmB,IAAI,OAAO,CAAC,GAC1D,GACF;AAAA,IAGA,oBAAC,aAAU,MAAK,KAAI;AAAA,IACpB,oBAAC,SAAS,MAAT,EACE,mBAAS,IAAI,CAAC,SAAS,mBAAmB,MAAM,QAAQ,CAAC,GAC5D;AAAA,KACF;AAEJ;","names":[]}
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import {
|
|
2
|
+
infoList,
|
|
3
|
+
renderDataListItem,
|
|
4
|
+
renderItem,
|
|
5
|
+
sessionList
|
|
6
|
+
} from "./chunk-I5XSLBW2.js";
|
|
7
|
+
import {
|
|
8
|
+
Grid
|
|
9
|
+
} from "./chunk-EGEQY3KT.js";
|
|
10
|
+
import {
|
|
11
|
+
DataList
|
|
12
|
+
} from "./chunk-VTJZMOSP.js";
|
|
13
|
+
import {
|
|
14
|
+
Heading
|
|
15
|
+
} from "./chunk-HK224ADT.js";
|
|
16
|
+
import {
|
|
17
|
+
Separator
|
|
18
|
+
} from "./chunk-HYITAA4J.js";
|
|
19
|
+
import {
|
|
20
|
+
Card
|
|
21
|
+
} from "./chunk-2ZQK7NTN.js";
|
|
22
|
+
import {
|
|
23
|
+
Badge
|
|
24
|
+
} from "./chunk-EWD4AO5N.js";
|
|
25
|
+
import {
|
|
26
|
+
Box
|
|
27
|
+
} from "./chunk-4Y5BEXVN.js";
|
|
28
|
+
import {
|
|
29
|
+
Typo
|
|
30
|
+
} from "./chunk-52MVZ6AN.js";
|
|
31
|
+
import {
|
|
32
|
+
Flex
|
|
33
|
+
} from "./chunk-25HMMI7R.js";
|
|
34
|
+
|
|
35
|
+
// src/app/platform/userInfos/coaching-customer-info/medium.tsx
|
|
36
|
+
import { useMemo } from "react";
|
|
37
|
+
import {
|
|
38
|
+
getColorFromProjectState,
|
|
39
|
+
getTextFromProjectState
|
|
40
|
+
} from "@tipp/biz-utils";
|
|
41
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
42
|
+
function CoachingCustomerInfoMedium({
|
|
43
|
+
customer,
|
|
44
|
+
session,
|
|
45
|
+
children
|
|
46
|
+
}) {
|
|
47
|
+
const badgeColor = useMemo(() => {
|
|
48
|
+
return getColorFromProjectState(session == null ? void 0 : session.state);
|
|
49
|
+
}, [session == null ? void 0 : session.state]);
|
|
50
|
+
const sessionText = useMemo(() => {
|
|
51
|
+
return getTextFromProjectState(session == null ? void 0 : session.state);
|
|
52
|
+
}, [session == null ? void 0 : session.state]);
|
|
53
|
+
return /* @__PURE__ */ jsxs(Flex, { direction: "column", gap: "5", children: [
|
|
54
|
+
/* @__PURE__ */ jsxs(Box, { children: [
|
|
55
|
+
/* @__PURE__ */ jsxs(Flex, { align: "center", justify: "between", mb: "1", width: "100%", children: [
|
|
56
|
+
/* @__PURE__ */ jsx(Heading, { variant: "heading2", children: (customer == null ? void 0 : customer.username) || "\uC774\uB984 \uC5C6\uC74C" }),
|
|
57
|
+
/* @__PURE__ */ jsx(Badge, { color: badgeColor, children: sessionText })
|
|
58
|
+
] }),
|
|
59
|
+
/* @__PURE__ */ jsx(Heading, { truncate: true, variant: "heading4", weight: "regular", children: customer == null ? void 0 : customer.company })
|
|
60
|
+
] }),
|
|
61
|
+
children,
|
|
62
|
+
/* @__PURE__ */ jsx(Card, { size: "2", children: /* @__PURE__ */ jsx(DataList.Root, { orientation: "vertical", children: sessionList.map((el) => renderDataListItem(el, session)) }) }),
|
|
63
|
+
/* @__PURE__ */ jsxs(Grid, { align: "center", columns: "auto 1fr", gap: "3", children: [
|
|
64
|
+
/* @__PURE__ */ jsx(Heading, { variant: "heading5", children: "\uACE0\uAC1D \uC815\uBCF4" }),
|
|
65
|
+
/* @__PURE__ */ jsx(Separator, { size: "4" })
|
|
66
|
+
] }),
|
|
67
|
+
/* @__PURE__ */ jsx(Flex, { direction: "column", gap: "4", children: infoList.map((el) => {
|
|
68
|
+
return /* @__PURE__ */ jsx(Typo, { children: renderItem(el, customer) }, el.label);
|
|
69
|
+
}) })
|
|
70
|
+
] });
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
export {
|
|
74
|
+
CoachingCustomerInfoMedium
|
|
75
|
+
};
|
|
76
|
+
//# sourceMappingURL=chunk-PEE4A2AC.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/app/platform/userInfos/coaching-customer-info/medium.tsx"],"sourcesContent":["import React, { useMemo } from 'react';\nimport {\n getColorFromProjectState,\n getTextFromProjectState,\n} from '@tipp/biz-utils';\nimport {\n Badge,\n Box,\n Card,\n DataList,\n Flex,\n Grid,\n Heading,\n Separator,\n Typo,\n} from '../../../../atoms';\nimport type { CoachingCustomerInfoProps } from '../utils';\nimport {\n infoList,\n renderDataListItem,\n renderItem,\n sessionList,\n} from '../utils';\n\nexport function CoachingCustomerInfoMedium({\n customer,\n session,\n children,\n}: CoachingCustomerInfoProps): React.ReactElement {\n const badgeColor = useMemo(() => {\n return getColorFromProjectState(session?.state);\n }, [session?.state]);\n\n const sessionText = useMemo(() => {\n return getTextFromProjectState(session?.state);\n }, [session?.state]);\n\n return (\n <Flex direction=\"column\" gap=\"5\">\n {/* 이름, 사명 */}\n <Box>\n <Flex align=\"center\" justify=\"between\" mb=\"1\" width=\"100%\">\n <Heading variant=\"heading2\">\n {customer?.username || '이름 없음'}\n </Heading>\n <Badge color={badgeColor}>{sessionText}</Badge>\n </Flex>\n <Heading truncate variant=\"heading4\" weight=\"regular\">\n {customer?.company}\n </Heading>\n </Box>\n\n {children}\n\n {/* 세션 정보 */}\n <Card size=\"2\">\n <DataList.Root orientation=\"vertical\">\n {sessionList.map((el) => renderDataListItem(el, session))}\n </DataList.Root>\n </Card>\n\n {/* 회원 정보 */}\n <Grid align=\"center\" columns=\"auto 1fr\" gap=\"3\">\n <Heading variant=\"heading5\">고객 정보</Heading>\n <Separator size=\"4\" />\n </Grid>\n <Flex direction=\"column\" gap=\"4\">\n {infoList.map((el) => {\n return <Typo key={el.label}>{renderItem(el, customer)}</Typo>;\n })}\n </Flex>\n </Flex>\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,SAAgB,eAAe;AAC/B;AAAA,EACE;AAAA,EACA;AAAA,OACK;AAqCC,SACE,KADF;AAjBD,SAAS,2BAA2B;AAAA,EACzC;AAAA,EACA;AAAA,EACA;AACF,GAAkD;AAChD,QAAM,aAAa,QAAQ,MAAM;AAC/B,WAAO,yBAAyB,mCAAS,KAAK;AAAA,EAChD,GAAG,CAAC,mCAAS,KAAK,CAAC;AAEnB,QAAM,cAAc,QAAQ,MAAM;AAChC,WAAO,wBAAwB,mCAAS,KAAK;AAAA,EAC/C,GAAG,CAAC,mCAAS,KAAK,CAAC;AAEnB,SACE,qBAAC,QAAK,WAAU,UAAS,KAAI,KAE3B;AAAA,yBAAC,OACC;AAAA,2BAAC,QAAK,OAAM,UAAS,SAAQ,WAAU,IAAG,KAAI,OAAM,QAClD;AAAA,4BAAC,WAAQ,SAAQ,YACd,gDAAU,aAAY,6BACzB;AAAA,QACA,oBAAC,SAAM,OAAO,YAAa,uBAAY;AAAA,SACzC;AAAA,MACA,oBAAC,WAAQ,UAAQ,MAAC,SAAQ,YAAW,QAAO,WACzC,+CAAU,SACb;AAAA,OACF;AAAA,IAEC;AAAA,IAGD,oBAAC,QAAK,MAAK,KACT,8BAAC,SAAS,MAAT,EAAc,aAAY,YACxB,sBAAY,IAAI,CAAC,OAAO,mBAAmB,IAAI,OAAO,CAAC,GAC1D,GACF;AAAA,IAGA,qBAAC,QAAK,OAAM,UAAS,SAAQ,YAAW,KAAI,KAC1C;AAAA,0BAAC,WAAQ,SAAQ,YAAW,uCAAK;AAAA,MACjC,oBAAC,aAAU,MAAK,KAAI;AAAA,OACtB;AAAA,IACA,oBAAC,QAAK,WAAU,UAAS,KAAI,KAC1B,mBAAS,IAAI,CAAC,OAAO;AACpB,aAAO,oBAAC,QAAqB,qBAAW,IAAI,QAAQ,KAAlC,GAAG,KAAiC;AAAA,IACxD,CAAC,GACH;AAAA,KACF;AAEJ;","names":[]}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import {
|
|
2
|
+
infoList,
|
|
3
|
+
renderDataListItem,
|
|
4
|
+
sessionList
|
|
5
|
+
} from "./chunk-I5XSLBW2.js";
|
|
6
|
+
import {
|
|
7
|
+
Grid
|
|
8
|
+
} from "./chunk-EGEQY3KT.js";
|
|
9
|
+
import {
|
|
10
|
+
DataList
|
|
11
|
+
} from "./chunk-VTJZMOSP.js";
|
|
12
|
+
import {
|
|
13
|
+
Heading
|
|
14
|
+
} from "./chunk-HK224ADT.js";
|
|
15
|
+
import {
|
|
16
|
+
Separator
|
|
17
|
+
} from "./chunk-HYITAA4J.js";
|
|
18
|
+
import {
|
|
19
|
+
Box
|
|
20
|
+
} from "./chunk-4Y5BEXVN.js";
|
|
21
|
+
import {
|
|
22
|
+
Flex
|
|
23
|
+
} from "./chunk-25HMMI7R.js";
|
|
24
|
+
|
|
25
|
+
// src/app/platform/userInfos/session-user-info-detail.tsx
|
|
26
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
27
|
+
function SectionWrapper({
|
|
28
|
+
title,
|
|
29
|
+
children
|
|
30
|
+
}) {
|
|
31
|
+
return /* @__PURE__ */ jsxs(Box, { children: [
|
|
32
|
+
/* @__PURE__ */ jsxs(Grid, { align: "center", columns: "auto 1fr", gap: "3", mb: "5", children: [
|
|
33
|
+
/* @__PURE__ */ jsx(Heading, { variant: "heading5", children: title }),
|
|
34
|
+
/* @__PURE__ */ jsx(Separator, { size: "4" })
|
|
35
|
+
] }),
|
|
36
|
+
children
|
|
37
|
+
] });
|
|
38
|
+
}
|
|
39
|
+
function SessionUserInfoDetail({
|
|
40
|
+
customer,
|
|
41
|
+
session
|
|
42
|
+
}) {
|
|
43
|
+
return /* @__PURE__ */ jsxs(Flex, { direction: "column", gap: "6", children: [
|
|
44
|
+
/* @__PURE__ */ jsx(SectionWrapper, { title: "\uC138\uC158 \uC815\uBCF4", children: /* @__PURE__ */ jsx(DataList.Root, { children: sessionList.map((info) => renderDataListItem(info, session)) }) }),
|
|
45
|
+
/* @__PURE__ */ jsx(SectionWrapper, { title: "\uD68C\uC6D0 \uC815\uBCF4", children: /* @__PURE__ */ jsx(DataList.Root, { children: infoList.map((info) => renderDataListItem(info, customer)) }) })
|
|
46
|
+
] });
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
export {
|
|
50
|
+
SessionUserInfoDetail
|
|
51
|
+
};
|
|
52
|
+
//# sourceMappingURL=chunk-SVR5RJQJ.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/app/platform/userInfos/session-user-info-detail.tsx"],"sourcesContent":["import React from 'react';\nimport { Box, DataList, Flex, Grid, Heading, Separator } from '../../../atoms';\nimport type { Customer, Session } from './utils';\nimport { infoList, renderDataListItem, sessionList } from './utils';\n\nexport interface SessionUserInfoDetailProps {\n customer: Customer;\n session: Session;\n}\n\nfunction SectionWrapper({\n title,\n children,\n}: {\n title: string;\n children: React.ReactElement;\n}): JSX.Element {\n return (\n <Box>\n <Grid align=\"center\" columns=\"auto 1fr\" gap=\"3\" mb=\"5\">\n <Heading variant=\"heading5\">{title}</Heading>\n\n <Separator size=\"4\" />\n </Grid>\n {children}\n </Box>\n );\n}\n\nexport function SessionUserInfoDetail({\n customer,\n session,\n}: SessionUserInfoDetailProps): React.ReactElement {\n return (\n <Flex direction=\"column\" gap=\"6\">\n <SectionWrapper title=\"세션 정보\">\n <DataList.Root>\n {sessionList.map((info) => renderDataListItem(info, session))}\n </DataList.Root>\n </SectionWrapper>\n\n <SectionWrapper title=\"회원 정보\">\n <DataList.Root>\n {infoList.map((info) => renderDataListItem(info, customer))}\n </DataList.Root>\n </SectionWrapper>\n </Flex>\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAmBM,SACE,KADF;AATN,SAAS,eAAe;AAAA,EACtB;AAAA,EACA;AACF,GAGgB;AACd,SACE,qBAAC,OACC;AAAA,yBAAC,QAAK,OAAM,UAAS,SAAQ,YAAW,KAAI,KAAI,IAAG,KACjD;AAAA,0BAAC,WAAQ,SAAQ,YAAY,iBAAM;AAAA,MAEnC,oBAAC,aAAU,MAAK,KAAI;AAAA,OACtB;AAAA,IACC;AAAA,KACH;AAEJ;AAEO,SAAS,sBAAsB;AAAA,EACpC;AAAA,EACA;AACF,GAAmD;AACjD,SACE,qBAAC,QAAK,WAAU,UAAS,KAAI,KAC3B;AAAA,wBAAC,kBAAe,OAAM,6BACpB,8BAAC,SAAS,MAAT,EACE,sBAAY,IAAI,CAAC,SAAS,mBAAmB,MAAM,OAAO,CAAC,GAC9D,GACF;AAAA,IAEA,oBAAC,kBAAe,OAAM,6BACpB,8BAAC,SAAS,MAAT,EACE,mBAAS,IAAI,CAAC,SAAS,mBAAmB,MAAM,QAAQ,CAAC,GAC5D,GACF;AAAA,KACF;AAEJ;","names":[]}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import {
|
|
2
|
+
CoachingCustomerInfoLarge
|
|
3
|
+
} from "./chunk-XNHVU6O4.js";
|
|
4
|
+
import {
|
|
5
|
+
CoachingCustomerInfoMedium
|
|
6
|
+
} from "./chunk-PYRUEPEW.js";
|
|
7
|
+
import {
|
|
8
|
+
CoachingCustomerInfoSmall
|
|
9
|
+
} from "./chunk-HDJWUUAZ.js";
|
|
10
|
+
import {
|
|
11
|
+
Box
|
|
12
|
+
} from "./chunk-4Y5BEXVN.js";
|
|
13
|
+
import {
|
|
14
|
+
__spreadValues
|
|
15
|
+
} from "./chunk-N552FDTV.js";
|
|
16
|
+
|
|
17
|
+
// src/app/platform/userInfos/coaching-customer-info/index.tsx
|
|
18
|
+
import { Fragment, jsx, jsxs } from "react/jsx-runtime";
|
|
19
|
+
function CoachingCustomerInfo(props) {
|
|
20
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
21
|
+
/* @__PURE__ */ jsx(Box, { display: { initial: "block", sm: "none", md: "none" }, children: /* @__PURE__ */ jsx(CoachingCustomerInfoSmall, __spreadValues({}, props)) }),
|
|
22
|
+
/* @__PURE__ */ jsx(Box, { display: { initial: "none", sm: "block", md: "none" }, children: /* @__PURE__ */ jsx(CoachingCustomerInfoMedium, __spreadValues({}, props)) }),
|
|
23
|
+
/* @__PURE__ */ jsx(Box, { display: { initial: "none", sm: "none", md: "block" }, children: /* @__PURE__ */ jsx(CoachingCustomerInfoLarge, __spreadValues({}, props)) })
|
|
24
|
+
] });
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
export {
|
|
28
|
+
CoachingCustomerInfo
|
|
29
|
+
};
|
|
30
|
+
//# sourceMappingURL=chunk-UXAD2OSK.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/app/platform/userInfos/coaching-customer-info/index.tsx"],"sourcesContent":["import React from 'react';\nimport { Box } from '../../../../atoms';\nimport type { CoachingCustomerInfoProps } from '../utils';\nimport { CoachingCustomerInfoSmall } from './small';\nimport { CoachingCustomerInfoMedium } from './medium';\nimport { CoachingCustomerInfoLarge } from './large';\n\nexport {\n CoachingCustomerInfoLarge,\n CoachingCustomerInfoMedium,\n CoachingCustomerInfoSmall,\n};\n\nexport { type CoachingCustomerInfoProps };\n\nexport function CoachingCustomerInfo(\n props: CoachingCustomerInfoProps\n): React.ReactElement {\n return (\n <>\n <Box display={{ initial: 'block', sm: 'none', md: 'none' }}>\n <CoachingCustomerInfoSmall {...props} />\n </Box>\n <Box display={{ initial: 'none', sm: 'block', md: 'none' }}>\n <CoachingCustomerInfoMedium {...props} />\n </Box>\n <Box display={{ initial: 'none', sm: 'none', md: 'block' }}>\n <CoachingCustomerInfoLarge {...props} />\n </Box>\n </>\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;AAmBI,mBAEI,KAFJ;AAJG,SAAS,qBACd,OACoB;AACpB,SACE,iCACE;AAAA,wBAAC,OAAI,SAAS,EAAE,SAAS,SAAS,IAAI,QAAQ,IAAI,OAAO,GACvD,8BAAC,8CAA8B,MAAO,GACxC;AAAA,IACA,oBAAC,OAAI,SAAS,EAAE,SAAS,QAAQ,IAAI,SAAS,IAAI,OAAO,GACvD,8BAAC,+CAA+B,MAAO,GACzC;AAAA,IACA,oBAAC,OAAI,SAAS,EAAE,SAAS,QAAQ,IAAI,QAAQ,IAAI,QAAQ,GACvD,8BAAC,8CAA8B,MAAO,GACxC;AAAA,KACF;AAEJ;","names":[]}
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import {
|
|
2
|
+
infoList,
|
|
3
|
+
renderDataListItem,
|
|
4
|
+
renderItem,
|
|
5
|
+
sessionList
|
|
6
|
+
} from "./chunk-I5XSLBW2.js";
|
|
7
|
+
import {
|
|
8
|
+
Grid
|
|
9
|
+
} from "./chunk-EGEQY3KT.js";
|
|
10
|
+
import {
|
|
11
|
+
DataList
|
|
12
|
+
} from "./chunk-VTJZMOSP.js";
|
|
13
|
+
import {
|
|
14
|
+
Heading
|
|
15
|
+
} from "./chunk-HK224ADT.js";
|
|
16
|
+
import {
|
|
17
|
+
Separator
|
|
18
|
+
} from "./chunk-HYITAA4J.js";
|
|
19
|
+
import {
|
|
20
|
+
Box
|
|
21
|
+
} from "./chunk-4Y5BEXVN.js";
|
|
22
|
+
import {
|
|
23
|
+
Typo
|
|
24
|
+
} from "./chunk-52MVZ6AN.js";
|
|
25
|
+
import {
|
|
26
|
+
Flex
|
|
27
|
+
} from "./chunk-25HMMI7R.js";
|
|
28
|
+
import {
|
|
29
|
+
Card
|
|
30
|
+
} from "./chunk-2ZQK7NTN.js";
|
|
31
|
+
import {
|
|
32
|
+
Badge
|
|
33
|
+
} from "./chunk-EWD4AO5N.js";
|
|
34
|
+
|
|
35
|
+
// src/app/platform/userInfos/coaching-customer-info/medium.tsx
|
|
36
|
+
import { useMemo } from "react";
|
|
37
|
+
import {
|
|
38
|
+
getColorFromProjectState,
|
|
39
|
+
getTextFromProjectState
|
|
40
|
+
} from "@tipp/biz-utils";
|
|
41
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
42
|
+
function CoachingCustomerInfoMedium({
|
|
43
|
+
customer,
|
|
44
|
+
session,
|
|
45
|
+
children
|
|
46
|
+
}) {
|
|
47
|
+
const badgeColor = useMemo(() => {
|
|
48
|
+
return getColorFromProjectState(session == null ? void 0 : session.state);
|
|
49
|
+
}, [session == null ? void 0 : session.state]);
|
|
50
|
+
const sessionText = useMemo(() => {
|
|
51
|
+
return getTextFromProjectState(session == null ? void 0 : session.state);
|
|
52
|
+
}, [session == null ? void 0 : session.state]);
|
|
53
|
+
return /* @__PURE__ */ jsxs(Flex, { direction: "column", gap: "5", children: [
|
|
54
|
+
/* @__PURE__ */ jsxs(Box, { children: [
|
|
55
|
+
/* @__PURE__ */ jsxs(Flex, { align: "center", justify: "between", mb: "1", width: "100%", children: [
|
|
56
|
+
/* @__PURE__ */ jsx(Heading, { variant: "heading2", children: (customer == null ? void 0 : customer.username) || "\uC774\uB984 \uC5C6\uC74C" }),
|
|
57
|
+
/* @__PURE__ */ jsx(Badge, { color: badgeColor, children: sessionText })
|
|
58
|
+
] }),
|
|
59
|
+
/* @__PURE__ */ jsx(Heading, { truncate: true, variant: "heading4", weight: "regular", children: customer == null ? void 0 : customer.company })
|
|
60
|
+
] }),
|
|
61
|
+
children,
|
|
62
|
+
/* @__PURE__ */ jsx(Card, { size: "2", children: /* @__PURE__ */ jsx(DataList.Root, { orientation: "vertical", children: sessionList.map((el) => renderDataListItem(el, session)) }) }),
|
|
63
|
+
/* @__PURE__ */ jsxs(Grid, { align: "center", columns: "auto 1fr", gap: "3", children: [
|
|
64
|
+
/* @__PURE__ */ jsx(Heading, { variant: "heading5", children: "\uACE0\uAC1D \uC815\uBCF4" }),
|
|
65
|
+
/* @__PURE__ */ jsx(Separator, { size: "4" })
|
|
66
|
+
] }),
|
|
67
|
+
/* @__PURE__ */ jsx(Flex, { direction: "column", gap: "4", children: infoList.map((el) => {
|
|
68
|
+
return /* @__PURE__ */ jsx(Typo, { children: renderItem(el, customer) }, el.label);
|
|
69
|
+
}) })
|
|
70
|
+
] });
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
export {
|
|
74
|
+
CoachingCustomerInfoMedium
|
|
75
|
+
};
|
|
76
|
+
//# sourceMappingURL=chunk-X3P223HR.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/app/platform/userInfos/coaching-customer-info/medium.tsx"],"sourcesContent":["import React, { useMemo } from 'react';\nimport {\n getColorFromProjectState,\n getTextFromProjectState,\n} from '@tipp/biz-utils';\nimport {\n Badge,\n Box,\n Card,\n DataList,\n Flex,\n Grid,\n Heading,\n Separator,\n Typo,\n} from '../../../../atoms';\nimport type { CoachingCustomerInfoProps } from '../utils';\nimport {\n infoList,\n renderDataListItem,\n renderItem,\n sessionList,\n} from '../utils';\n\nexport function CoachingCustomerInfoMedium({\n customer,\n session,\n children,\n}: CoachingCustomerInfoProps): React.ReactElement {\n const badgeColor = useMemo(() => {\n return getColorFromProjectState(session?.state);\n }, [session?.state]);\n\n const sessionText = useMemo(() => {\n return getTextFromProjectState(session?.state);\n }, [session?.state]);\n\n return (\n <Flex direction=\"column\" gap=\"5\">\n {/* 이름, 사명 */}\n <Box>\n <Flex align=\"center\" justify=\"between\" mb=\"1\" width=\"100%\">\n <Heading variant=\"heading2\">\n {customer?.username || '이름 없음'}\n </Heading>\n <Badge color={badgeColor}>{sessionText}</Badge>\n </Flex>\n <Heading truncate variant=\"heading4\" weight=\"regular\">\n {customer?.company}\n </Heading>\n </Box>\n\n {children}\n\n {/* 세션 정보 */}\n <Card size=\"2\">\n <DataList.Root orientation=\"vertical\">\n {sessionList.map((el) => renderDataListItem(el, session))}\n </DataList.Root>\n </Card>\n\n {/* 회원 정보 */}\n <Grid align=\"center\" columns=\"auto 1fr\" gap=\"3\">\n <Heading variant=\"heading5\">고객 정보</Heading>\n <Separator size=\"4\" />\n </Grid>\n <Flex direction=\"column\" gap=\"4\">\n {infoList.map((el) => {\n return <Typo key={el.label}>{renderItem(el, customer)}</Typo>;\n })}\n </Flex>\n </Flex>\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,SAAgB,eAAe;AAC/B;AAAA,EACE;AAAA,EACA;AAAA,OACK;AAqCC,SACE,KADF;AAjBD,SAAS,2BAA2B;AAAA,EACzC;AAAA,EACA;AAAA,EACA;AACF,GAAkD;AAChD,QAAM,aAAa,QAAQ,MAAM;AAC/B,WAAO,yBAAyB,mCAAS,KAAK;AAAA,EAChD,GAAG,CAAC,mCAAS,KAAK,CAAC;AAEnB,QAAM,cAAc,QAAQ,MAAM;AAChC,WAAO,wBAAwB,mCAAS,KAAK;AAAA,EAC/C,GAAG,CAAC,mCAAS,KAAK,CAAC;AAEnB,SACE,qBAAC,QAAK,WAAU,UAAS,KAAI,KAE3B;AAAA,yBAAC,OACC;AAAA,2BAAC,QAAK,OAAM,UAAS,SAAQ,WAAU,IAAG,KAAI,OAAM,QAClD;AAAA,4BAAC,WAAQ,SAAQ,YACd,gDAAU,aAAY,6BACzB;AAAA,QACA,oBAAC,SAAM,OAAO,YAAa,uBAAY;AAAA,SACzC;AAAA,MACA,oBAAC,WAAQ,UAAQ,MAAC,SAAQ,YAAW,QAAO,WACzC,+CAAU,SACb;AAAA,OACF;AAAA,IAEC;AAAA,IAGD,oBAAC,QAAK,MAAK,KACT,8BAAC,SAAS,MAAT,EAAc,aAAY,YACxB,sBAAY,IAAI,CAAC,OAAO,mBAAmB,IAAI,OAAO,CAAC,GAC1D,GACF;AAAA,IAGA,qBAAC,QAAK,OAAM,UAAS,SAAQ,YAAW,KAAI,KAC1C;AAAA,0BAAC,WAAQ,SAAQ,YAAW,uCAAK;AAAA,MACjC,oBAAC,aAAU,MAAK,KAAI;AAAA,OACtB;AAAA,IACA,oBAAC,QAAK,WAAU,UAAS,KAAI,KAC1B,mBAAS,IAAI,CAAC,OAAO;AACpB,aAAO,oBAAC,QAAqB,qBAAW,IAAI,QAAQ,KAAlC,GAAG,KAAiC;AAAA,IACxD,CAAC,GACH;AAAA,KACF;AAEJ;","names":[]}
|
package/dist/index.cjs
CHANGED
|
@@ -2848,18 +2848,32 @@ var infoList = [
|
|
|
2848
2848
|
copyable: true
|
|
2849
2849
|
}
|
|
2850
2850
|
];
|
|
2851
|
+
var sessionStatusChecker = (value, session) => {
|
|
2852
|
+
if ((session == null ? void 0 : session.state) === "inProgress") {
|
|
2853
|
+
return value;
|
|
2854
|
+
}
|
|
2855
|
+
return "-";
|
|
2856
|
+
};
|
|
2851
2857
|
var sessionList = [
|
|
2852
2858
|
{
|
|
2853
2859
|
label: "\uC9C4\uD589\uC911\uC778 \uC138\uC158",
|
|
2854
|
-
getValue: (session) =>
|
|
2860
|
+
getValue: (session) => {
|
|
2861
|
+
return sessionStatusChecker(
|
|
2862
|
+
`${(session == null ? void 0 : session.currentSession) || "-"}\uD68C\uCC28/${(session == null ? void 0 : session.totalSession) || "-"}\uD68C\uCC28`,
|
|
2863
|
+
session
|
|
2864
|
+
);
|
|
2865
|
+
}
|
|
2855
2866
|
},
|
|
2856
2867
|
{
|
|
2857
2868
|
label: "\uB2E4\uC74C \uC138\uC158 \uC77C\uC2DC",
|
|
2858
|
-
getValue: (session) => (
|
|
2869
|
+
getValue: (session) => sessionStatusChecker(
|
|
2870
|
+
(session == null ? void 0 : session.nextSessionDate) ? (0, import_date_fns2.format)(session.nextSessionDate, "yyyy\uB144 MM\uC6D4 dd\uC77C HH\uC2DC mm\uBD84") : "-",
|
|
2871
|
+
session
|
|
2872
|
+
)
|
|
2859
2873
|
},
|
|
2860
2874
|
{
|
|
2861
2875
|
label: "\uB2E4\uC74C \uC138\uC158 \uCC38\uC5EC \uBC29\uC2DD",
|
|
2862
|
-
getValue: (session) => (session == null ? void 0 : session.nextSessionType) || "-"
|
|
2876
|
+
getValue: (session) => sessionStatusChecker((session == null ? void 0 : session.nextSessionType) || "-", session)
|
|
2863
2877
|
},
|
|
2864
2878
|
{
|
|
2865
2879
|
label: "\uCF54\uCE6D \uB9CC\uB8CC \uAE30\uD55C",
|