sales-frontend-components 0.0.79 → 0.0.81
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.cjs.js +225 -99
- package/dist/index.cjs.js.map +1 -1
- package/dist/index.d.ts +12 -44
- package/dist/index.esm.js +226 -100
- package/dist/index.esm.js.map +1 -1
- package/dist/modal/pre-standard/job-search-modal/job-search-modal.module.scss +9 -0
- package/dist/modal/standard/address-search/select-address.module.scss +5 -1
- package/package.json +11 -11
package/dist/index.d.ts
CHANGED
|
@@ -2,7 +2,7 @@ import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
|
2
2
|
import { FieldValues, UseControllerProps } from 'react-hook-form';
|
|
3
3
|
import { CheckboxButtonProps, CheckboxProps, DatePickerSingleHtmlProps, DatePickerRangeHtmlProps, FormField, SegmentGroupHtmlProps, SelectProps, OptionProps } from 'sales-frontend-design-system';
|
|
4
4
|
import * as sales_frontend_api_method from 'sales-frontend-api/method';
|
|
5
|
-
import { OccupationResponseDto,
|
|
5
|
+
import { OccupationResponseDto, AddressStandardizationResponseDto, AddressResponseDto, OrganizationProfileResponse, EmployeeProfileResponseDto, CustomerSearchProps } from 'sales-frontend-api/method';
|
|
6
6
|
import * as React$1 from 'react';
|
|
7
7
|
import React__default from 'react';
|
|
8
8
|
|
|
@@ -176,23 +176,26 @@ declare function useCanvasPaint(paintProps?: PaintProps): {
|
|
|
176
176
|
*/
|
|
177
177
|
declare const testSignatureBase64Data = "";
|
|
178
178
|
|
|
179
|
-
interface FullAddress extends Address {
|
|
180
|
-
detail: string;
|
|
181
|
-
}
|
|
182
179
|
type Step = 'initial' | 'search-result' | 'detail-input';
|
|
180
|
+
interface AddressComponentProps extends AddressStandardizationResponseDto {
|
|
181
|
+
detailAddressInput: string;
|
|
182
|
+
}
|
|
183
183
|
|
|
184
184
|
interface Props {
|
|
185
|
-
setValue: (address:
|
|
185
|
+
setValue: (address: AddressComponentProps) => void;
|
|
186
186
|
onClose: () => void;
|
|
187
187
|
isOpen: boolean;
|
|
188
188
|
}
|
|
189
189
|
declare function useSearchAddress({ setValue, onClose, isOpen }: Props): {
|
|
190
|
+
addressStandardizationList: any;
|
|
191
|
+
selectedStandardizationAddress: AddressStandardizationResponseDto | undefined;
|
|
192
|
+
onStandardizationChange: (e: React__default.ChangeEvent<HTMLInputElement>) => void;
|
|
190
193
|
onAddressSearchClear: () => void;
|
|
191
194
|
onAddressSearchNext: () => void;
|
|
192
195
|
addressSearchKeyword: string;
|
|
193
|
-
addressSearchList:
|
|
196
|
+
addressSearchList: AddressResponseDto[];
|
|
194
197
|
addressSearchStep: Step;
|
|
195
|
-
selectedAddress:
|
|
198
|
+
selectedAddress: AddressResponseDto | undefined;
|
|
196
199
|
addressSearchOnValueChange: (e: React__default.ChangeEvent<HTMLInputElement>) => void;
|
|
197
200
|
nextButtonDisabled: boolean;
|
|
198
201
|
detailAddressInput: string;
|
|
@@ -204,7 +207,7 @@ declare function useSearchAddress({ setValue, onClose, isOpen }: Props): {
|
|
|
204
207
|
searchInput: string;
|
|
205
208
|
};
|
|
206
209
|
declare const useAddressComponent: () => {
|
|
207
|
-
fullAddress:
|
|
210
|
+
fullAddress: AddressComponentProps | undefined;
|
|
208
211
|
openModal: () => void;
|
|
209
212
|
AddressSearchComponent: () => react_jsx_runtime.JSX.Element;
|
|
210
213
|
};
|
|
@@ -261,42 +264,7 @@ interface JobSearchModalProps {
|
|
|
261
264
|
}
|
|
262
265
|
declare const JobSearchModal: React__default.FC<JobSearchModalProps>;
|
|
263
266
|
|
|
264
|
-
interface DspResponseCustomerListResponseDto {
|
|
265
|
-
/** @description 성공여부 */
|
|
266
|
-
isSuccess?: boolean;
|
|
267
|
-
/** @description 코드 */
|
|
268
|
-
code?: string;
|
|
269
|
-
/** @description 메시지 */
|
|
270
|
-
message?: string;
|
|
271
|
-
data?: CustomerListResponseDto;
|
|
272
|
-
pagination?: Pagination;
|
|
273
|
-
}
|
|
274
|
-
interface CustomerListResponseDto {
|
|
275
|
-
/** @description 고객목록 */
|
|
276
|
-
custList?: CustomerDto[];
|
|
277
|
-
/** @description 총 건수 */
|
|
278
|
-
totalCount?: string;
|
|
279
|
-
}
|
|
280
|
-
/** @description 고객정보 */
|
|
281
|
-
interface CustomerDto {
|
|
282
|
-
/** @description 고객ID */
|
|
283
|
-
customerId?: string;
|
|
284
|
-
/** @description 고객명 */
|
|
285
|
-
customerName?: string;
|
|
286
|
-
/** @description 기본주소 */
|
|
287
|
-
baseAddress?: string;
|
|
288
|
-
/** @description 상세주소 */
|
|
289
|
-
detailAddress?: string;
|
|
290
|
-
/** @description 생년월일(YYYYMMDD) */
|
|
291
|
-
birthDate?: string;
|
|
292
|
-
/** @description 성별코드 */
|
|
293
|
-
genderCode?: string;
|
|
294
|
-
}
|
|
295
|
-
interface CustomerSearchProps {
|
|
296
|
-
onSelect?: (customer: CustomerDto) => void;
|
|
297
|
-
}
|
|
298
|
-
|
|
299
267
|
declare const CustomerSearch: ({ onSelect }: CustomerSearchProps) => react_jsx_runtime.JSX.Element;
|
|
300
268
|
|
|
301
269
|
export { Attachment, BankStockSearchModal, CustomerSearch, EmployeeSearchModal, FormCheckbox, FormCheckboxButton, FormDatePicker, FormDateRangePicker, FormSearchJobField, FormSegmentGroup, FormSelect, FormTextField, JobSearchModal, OrganizationSearchModal, StepIndicator, resize, testSignatureBase64Data, useAddressComponent, useBankStockSearch, useCamera, useCanvasPaint, useJobVehicleSearchModal, useSearchAddress };
|
|
302
|
-
export type { AttachedPhoto, AttachmentProps, BankStockItem, BankStockSearchModalProps,
|
|
270
|
+
export type { AttachedPhoto, AttachmentProps, BankStockItem, BankStockSearchModalProps, DownloadProps, PaintProps, Pen, StepIndicatorProps, StepItem, cameraItemType, cameraOptions };
|
package/dist/index.esm.js
CHANGED
|
@@ -2,7 +2,7 @@ import { jsx, Fragment, jsxs } from 'react/jsx-runtime';
|
|
|
2
2
|
import { useController } from 'react-hook-form';
|
|
3
3
|
import { CheckboxButton, Checkbox, DatePicker, DateRangePicker, Accordion, Radio, Table, Button, FormField, Select, Tab, useModalState, Modal, SegmentGroup, ModalUtils, FormCore, RadioGroup, useDropDown, List, ListItem } from 'sales-frontend-design-system';
|
|
4
4
|
import React, { useState, useEffect, useRef, useCallback, useMemo } from 'react';
|
|
5
|
-
import { useSearchOccupationQuery,
|
|
5
|
+
import { useSearchOccupationDetailQuery, useSearchOccupationQuery, useSearchAddressQuery, useSearchPostalCodeQuery, useSearchAddressStandardizationQuery, useSearchOrganizationQuery, useSearchEmployeeProfileQuery, useSearchVehicleQuery, useSearchCustomerListQuery } from 'sales-frontend-api/method';
|
|
6
6
|
import { IconMainUiSearch, IconIllustCamera, IconGraphicsBankHsbc, IconGraphicsBankKebHana, IconGraphicsBankScJeil, IconGraphicsBankGyeongnam, IconGraphicsBankGwangju, IconGraphicsBankKukmin, IconGraphicsBankKiup, IconGraphicsBankJiyeokNonghyeop, IconGraphicsBankNhNonghyeop, IconGraphicsBankDaegu, IconGraphicsBankBusan, IconGraphicsBankSanlim, IconGraphicsBankSaneop, IconGraphicsBankSaemaulGeumgo, IconGraphicsBankSuhyeop, IconGraphicsBankSinhan, IconGraphicsBankSinhyeop, IconGraphicsBankOehwan, IconGraphicsBankWoori, IconGraphicsBankPost, IconGraphicsBankJeochuk, IconGraphicsBankJeonbuk, IconGraphicsBankJeju, IconGraphicsBankKakaoBank, IconGraphicsBankKBank, IconGraphicsBankHankookCity, IconGraphicsStockDbGeumyungTujajeungkwon, IconGraphicsStockKbJeungkwon, IconGraphicsStockNhWooriTujajeungkwon, IconGraphicsStockNhTujajeungkwon, IconGraphicsStockSkJeungkwon, IconGraphicsStockGyoboJeungkwon, IconGraphicsStockDaesinJeungkwon, IconGraphicsStockMeritzJeungkwon, IconGraphicsStockMiraeAssetJeungkwon, IconGraphicsStockBugukJeungkwon, IconGraphicsStockSamsungJeungkwon, IconGraphicsStockSinyeongJeungkwon, IconGraphicsStockSinhanTujajeungkwon, IconGraphicsStockYuantaJeungkwon, IconGraphicsStockYujinTujajeungkwon, IconGraphicsStockKiwoomJeungkwon, IconGraphicsStockHanaGeumyungTujajeungkwon, IconGraphicsStockHiTujajeungkwon, IconGraphicsStockHankookJeungkwonGeumyung, IconGraphicsStockHankookTujajeungkwon, IconGraphicsStockHanwhaTujajeungkwon, IconGraphicsStockHyundaiChaJeungkwon, IconGraphicsStockHochulEopsum, IconGraphicsFeedbackEmpty, IconIllustGrade, IconIllustJob, IconSubUiArrowRight, IconIllustVehicle } from 'sales-frontend-assets';
|
|
7
7
|
import styles from './modal/pre-standard/job-search-modal/job-search-modal.module.scss';
|
|
8
8
|
import styles$1 from './step-indicator/step-indicator.module.scss';
|
|
@@ -281,6 +281,73 @@ function JobSearchCategory({ filteredJobs, onJobSelect, searchTerm }) {
|
|
|
281
281
|
] }) });
|
|
282
282
|
}
|
|
283
283
|
|
|
284
|
+
function JobSearchDetail({ occupationTypeCode, occupationIndustryCode }) {
|
|
285
|
+
const { data: detail } = useSearchOccupationDetailQuery({
|
|
286
|
+
occupationIndustryCode,
|
|
287
|
+
occupationIndustryTypeCode: occupationTypeCode
|
|
288
|
+
});
|
|
289
|
+
if (!detail || !detail.data) {
|
|
290
|
+
return null;
|
|
291
|
+
}
|
|
292
|
+
const {
|
|
293
|
+
/** @description 직종해설내용 */
|
|
294
|
+
occupationExplanationContent,
|
|
295
|
+
/** @description 직업예시명 */
|
|
296
|
+
occupationExampleName,
|
|
297
|
+
/** @description 위험등급명 */
|
|
298
|
+
riskGradeName,
|
|
299
|
+
/** @description 위험등급코드 */
|
|
300
|
+
riskGradeCode,
|
|
301
|
+
/** @description 상해위험등급코드명 */
|
|
302
|
+
injuryRiskGradeCodeName,
|
|
303
|
+
/** @description 상해위험등급코드 */
|
|
304
|
+
injuryRiskGradeCode,
|
|
305
|
+
/** @description 입원등급코드명 */
|
|
306
|
+
hospitalizationGradeCodeName,
|
|
307
|
+
/** @description 입원등급코드 */
|
|
308
|
+
hospitalizationGradeCode,
|
|
309
|
+
/** @description 상해직종코드 */
|
|
310
|
+
injuryOccupationCode
|
|
311
|
+
} = detail.data;
|
|
312
|
+
return /* @__PURE__ */ jsx(Fragment, { children: /* @__PURE__ */ jsx(Table, { variant: "horizontal", children: /* @__PURE__ */ jsxs("tbody", { children: [
|
|
313
|
+
/* @__PURE__ */ jsxs("tr", { children: [
|
|
314
|
+
/* @__PURE__ */ jsx("th", { className: "px-small", children: "\uC9C1\uC885 \uD574\uC124" }),
|
|
315
|
+
/* @__PURE__ */ jsx("td", { className: "px-small", children: occupationExplanationContent })
|
|
316
|
+
] }),
|
|
317
|
+
/* @__PURE__ */ jsxs("tr", { children: [
|
|
318
|
+
/* @__PURE__ */ jsx("th", { className: "px-small", children: "\uC9C1\uC885 \uC608\uC2DC" }),
|
|
319
|
+
/* @__PURE__ */ jsx("td", { className: "px-small", children: occupationExampleName })
|
|
320
|
+
] }),
|
|
321
|
+
/* @__PURE__ */ jsxs("tr", { children: [
|
|
322
|
+
/* @__PURE__ */ jsx("th", { className: "px-small", children: "\uC704\uD5D8 \uB4F1\uAE09" }),
|
|
323
|
+
/* @__PURE__ */ jsxs("td", { className: "px-small", children: [
|
|
324
|
+
riskGradeName,
|
|
325
|
+
"(",
|
|
326
|
+
riskGradeCode,
|
|
327
|
+
")"
|
|
328
|
+
] })
|
|
329
|
+
] }),
|
|
330
|
+
/* @__PURE__ */ jsxs("tr", { children: [
|
|
331
|
+
/* @__PURE__ */ jsx("th", { className: "px-small", children: "\uC785\uC6D0 \uB4F1\uAE09" }),
|
|
332
|
+
/* @__PURE__ */ jsxs("td", { className: "px-small", children: [
|
|
333
|
+
hospitalizationGradeCodeName,
|
|
334
|
+
"(",
|
|
335
|
+
hospitalizationGradeCode,
|
|
336
|
+
")"
|
|
337
|
+
] })
|
|
338
|
+
] }),
|
|
339
|
+
/* @__PURE__ */ jsxs("tr", { children: [
|
|
340
|
+
/* @__PURE__ */ jsx("th", { className: "px-small", children: "\uC0C1\uD574 \uB4F1\uAE09" }),
|
|
341
|
+
/* @__PURE__ */ jsxs("td", { className: "px-small", children: [
|
|
342
|
+
injuryRiskGradeCodeName,
|
|
343
|
+
"(",
|
|
344
|
+
injuryRiskGradeCode,
|
|
345
|
+
")"
|
|
346
|
+
] })
|
|
347
|
+
] })
|
|
348
|
+
] }) }) });
|
|
349
|
+
}
|
|
350
|
+
|
|
284
351
|
const cx$d = classNames.bind(styles);
|
|
285
352
|
function JobSearchFavorite({ filteredJobs, onJobSelect }) {
|
|
286
353
|
return /* @__PURE__ */ jsx(Fragment, { children: /* @__PURE__ */ jsxs("div", { className: cx$d("popular-jobs"), children: [
|
|
@@ -306,7 +373,13 @@ function JobSearchFavorite({ filteredJobs, onJobSelect }) {
|
|
|
306
373
|
]
|
|
307
374
|
}
|
|
308
375
|
) }),
|
|
309
|
-
/* @__PURE__ */ jsx(Accordion.Content, { variant: "text", children:
|
|
376
|
+
/* @__PURE__ */ jsx(Accordion.Content, { variant: "text", children: /* @__PURE__ */ jsx(
|
|
377
|
+
JobSearchDetail,
|
|
378
|
+
{
|
|
379
|
+
occupationTypeCode: job.occupationTypeCode || "",
|
|
380
|
+
occupationIndustryCode: job.occupationIndustryCode
|
|
381
|
+
}
|
|
382
|
+
) })
|
|
310
383
|
]
|
|
311
384
|
},
|
|
312
385
|
`item-${job.occupationIndustryCode}-${index}`
|
|
@@ -339,22 +412,13 @@ function JobSearchResult({ filteredJobs, onJobSelect, searchTerm }) {
|
|
|
339
412
|
children: highlightOnSearchKeyword$1(job.occupationIndustryName, searchTerm)
|
|
340
413
|
}
|
|
341
414
|
) }) }),
|
|
342
|
-
/* @__PURE__ */ jsx(Accordion.Content, { variant: "text", children: /* @__PURE__ */ jsx(
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
/* @__PURE__ */ jsxs("tr", { children: [
|
|
350
|
-
/* @__PURE__ */ jsx("th", { children: "\uD5E4\uB354 2" }),
|
|
351
|
-
/* @__PURE__ */ jsx("td", { className: "pl-24 pr-16", colSpan: 3, children: /* @__PURE__ */ jsxs("p", { className: "d-flex-center-center", children: [
|
|
352
|
-
"2\uD589 1\uBC88\uC9F8 ",
|
|
353
|
-
/* @__PURE__ */ jsx("span", { className: "flex-1 pipe-left", children: "\uC11C\uBE0C\uD14D\uC2A4\uD2B8" }),
|
|
354
|
-
/* @__PURE__ */ jsx(Button, { variant: "neutral", size: "xsmall", appearance: "outline", children: "\uBC84\uD2BC\uBA85" })
|
|
355
|
-
] }) })
|
|
356
|
-
] })
|
|
357
|
-
] }) }) })
|
|
415
|
+
/* @__PURE__ */ jsx(Accordion.Content, { variant: "text", children: /* @__PURE__ */ jsx(
|
|
416
|
+
JobSearchDetail,
|
|
417
|
+
{
|
|
418
|
+
occupationTypeCode: job.occupationTypeCode || "",
|
|
419
|
+
occupationIndustryCode: job.occupationIndustryCode
|
|
420
|
+
}
|
|
421
|
+
) })
|
|
358
422
|
]
|
|
359
423
|
},
|
|
360
424
|
job.occupationIndustryCode
|
|
@@ -1388,7 +1452,7 @@ const testSignatureBase64Data = "
|
|
|
1388
1452
|
const cx$8 = classNames.bind(styles$3);
|
|
1389
1453
|
const { InputBox: InputBox$1, Input: Input$1 } = FormCore;
|
|
1390
1454
|
const AddressSearchInitialText = () => {
|
|
1391
|
-
return /* @__PURE__ */ jsxs("div", { children: [
|
|
1455
|
+
return /* @__PURE__ */ jsxs("div", { className: cx$8("search-result-list"), children: [
|
|
1392
1456
|
/* @__PURE__ */ jsx("p", { className: cx$8("guide-title"), children: "\uC774\uB807\uAC8C \uAC80\uC0C9\uD574 \uBCF4\uC138\uC694." }),
|
|
1393
1457
|
/* @__PURE__ */ jsxs("ul", { className: cx$8("guide"), children: [
|
|
1394
1458
|
/* @__PURE__ */ jsx("li", { children: "\uB3C4\uB85C\uBA85/\uC9C0\uBA85\uACFC \uAC74\uBB3C\uBC88\uD638\uB97C \uD568\uAED8 \uC785\uB825\uD574\uC8FC\uC138\uC694" }),
|
|
@@ -1406,38 +1470,36 @@ const AddressSearchResult = ({
|
|
|
1406
1470
|
searchKeyword,
|
|
1407
1471
|
selectedAddress
|
|
1408
1472
|
}) => {
|
|
1409
|
-
|
|
1410
|
-
useEffect(() => {
|
|
1411
|
-
const filterList2 = addressSearchList.filter(
|
|
1412
|
-
(item) => item.address.includes(searchKeyword) || item.oldAddress.includes(searchKeyword)
|
|
1413
|
-
) || [];
|
|
1414
|
-
setFilterList(filterList2);
|
|
1415
|
-
}, [addressSearchList, searchKeyword]);
|
|
1416
|
-
return /* @__PURE__ */ jsxs("div", { children: [
|
|
1473
|
+
return /* @__PURE__ */ jsxs("div", { className: cx$8("search-result-list"), children: [
|
|
1417
1474
|
/* @__PURE__ */ jsxs("p", { className: cx$8("guide-title"), children: [
|
|
1418
1475
|
"\uCD1D ",
|
|
1419
|
-
/* @__PURE__ */ jsx("span", { className: "text-primary", children:
|
|
1476
|
+
/* @__PURE__ */ jsx("span", { className: "text-primary", children: addressSearchList.length }),
|
|
1420
1477
|
"\uAC74\uC758 \uAC80\uC0C9\uACB0\uACFC"
|
|
1421
1478
|
] }),
|
|
1422
|
-
|
|
1479
|
+
addressSearchList.length > 0 && /* @__PURE__ */ jsx(
|
|
1423
1480
|
RadioGroup,
|
|
1424
1481
|
{
|
|
1425
|
-
items:
|
|
1426
|
-
|
|
1427
|
-
|
|
1428
|
-
|
|
1429
|
-
/* @__PURE__ */ jsxs("div", { className: cx$8("
|
|
1430
|
-
" ",
|
|
1431
|
-
|
|
1482
|
+
items: addressSearchList.map((item) => {
|
|
1483
|
+
return {
|
|
1484
|
+
value: JSON.stringify(item),
|
|
1485
|
+
select: item.roadNameBaseAddress === selectedAddress?.roadNameBaseAddress && item.roadNameDetailAddress === selectedAddress?.roadNameDetailAddress && item.mainBuildingName === selectedAddress?.mainBuildingName,
|
|
1486
|
+
label: /* @__PURE__ */ jsxs("div", { className: cx$8("search-result"), children: [
|
|
1487
|
+
/* @__PURE__ */ jsx("div", { className: cx$8("zipcode"), children: highlightOnSearchKeyword$1(`${item.firstPostalCode}${item.secondPostalCode}`, searchKeyword) }),
|
|
1488
|
+
/* @__PURE__ */ jsx("div", { className: cx$8("divider") }),
|
|
1489
|
+
/* @__PURE__ */ jsxs("div", { className: cx$8("address-info"), children: [
|
|
1490
|
+
/* @__PURE__ */ jsx("span", { className: cx$8("address"), children: highlightOnSearchKeyword$1(
|
|
1491
|
+
`${item.roadNameBaseAddress} ${item.roadNameDetailAddress} ${item.mainBuildingName}`,
|
|
1492
|
+
searchKeyword
|
|
1493
|
+
) }),
|
|
1494
|
+
/* @__PURE__ */ jsx("span", { className: cx$8("old-address"), children: highlightOnSearchKeyword$1(
|
|
1495
|
+
`${item.landNumberBaseAddress} ${item.landNumberDetailAddress}`,
|
|
1496
|
+
searchKeyword
|
|
1497
|
+
) })
|
|
1498
|
+
] })
|
|
1432
1499
|
] }),
|
|
1433
|
-
|
|
1434
|
-
|
|
1435
|
-
|
|
1436
|
-
/* @__PURE__ */ jsx("span", { className: cx$8("old-address"), children: highlightOnSearchKeyword$1(item.oldAddress, searchKeyword) })
|
|
1437
|
-
] })
|
|
1438
|
-
] }),
|
|
1439
|
-
id: item.address
|
|
1440
|
-
})),
|
|
1500
|
+
id: JSON.stringify(item)
|
|
1501
|
+
};
|
|
1502
|
+
}),
|
|
1441
1503
|
className: cx$8("radio-group"),
|
|
1442
1504
|
name: "address-search",
|
|
1443
1505
|
size: "medium",
|
|
@@ -1445,7 +1507,7 @@ const AddressSearchResult = ({
|
|
|
1445
1507
|
onChange
|
|
1446
1508
|
}
|
|
1447
1509
|
),
|
|
1448
|
-
|
|
1510
|
+
addressSearchList.length === 0 && /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
1449
1511
|
"`",
|
|
1450
1512
|
/* @__PURE__ */ jsx("span", { className: "text-primary", children: searchKeyword }),
|
|
1451
1513
|
"`\uC5D0 \uB300\uD55C \uAC80\uC0C9\uACB0\uACFC\uAC00 \uC5C6\uC2B5\uB2C8\uB2E4."
|
|
@@ -1453,30 +1515,52 @@ const AddressSearchResult = ({
|
|
|
1453
1515
|
] });
|
|
1454
1516
|
};
|
|
1455
1517
|
const AddressSearchDetailInput = ({
|
|
1456
|
-
|
|
1518
|
+
addressStandardizationList,
|
|
1457
1519
|
onDetailChange,
|
|
1520
|
+
onStandardizationChange,
|
|
1458
1521
|
step,
|
|
1459
1522
|
detailAddressInput
|
|
1460
1523
|
}) => {
|
|
1461
|
-
return /* @__PURE__ */ jsxs("div", { children: [
|
|
1462
|
-
/* @__PURE__ */
|
|
1463
|
-
|
|
1464
|
-
|
|
1465
|
-
|
|
1466
|
-
|
|
1467
|
-
|
|
1468
|
-
|
|
1469
|
-
|
|
1470
|
-
|
|
1471
|
-
|
|
1472
|
-
|
|
1524
|
+
return /* @__PURE__ */ jsxs("div", { className: cx$8("search-result-list"), children: [
|
|
1525
|
+
/* @__PURE__ */ jsx(
|
|
1526
|
+
RadioGroup,
|
|
1527
|
+
{
|
|
1528
|
+
items: addressStandardizationList.map((item) => {
|
|
1529
|
+
return {
|
|
1530
|
+
value: JSON.stringify(item),
|
|
1531
|
+
select: true,
|
|
1532
|
+
label: /* @__PURE__ */ jsxs("div", { className: cx$8("search-result"), children: [
|
|
1533
|
+
/* @__PURE__ */ jsx("div", { className: cx$8("zipcode"), children: `${item.firstPostalCode}${item.secondPostalCode}` }),
|
|
1534
|
+
/* @__PURE__ */ jsx("div", { className: cx$8("divider") }),
|
|
1535
|
+
/* @__PURE__ */ jsxs("div", { className: cx$8("address-info"), children: [
|
|
1536
|
+
/* @__PURE__ */ jsx("span", { className: cx$8("address"), children: `${item.baseAddress} ${item.detailAddress}` }),
|
|
1537
|
+
/* @__PURE__ */ jsx("span", { className: cx$8("old-address"), children: `${item.baseAddress} ${item.detailAddress}` })
|
|
1538
|
+
] })
|
|
1539
|
+
] }),
|
|
1540
|
+
id: JSON.stringify(item)
|
|
1541
|
+
};
|
|
1542
|
+
}),
|
|
1543
|
+
className: cx$8("radio-group"),
|
|
1544
|
+
name: "address-search-standardization",
|
|
1545
|
+
size: "medium",
|
|
1546
|
+
defaultValue: "",
|
|
1547
|
+
onChange: onStandardizationChange
|
|
1548
|
+
}
|
|
1549
|
+
),
|
|
1550
|
+
/* @__PURE__ */ jsxs("div", { className: "d-flex gap-medium items-center", children: [
|
|
1473
1551
|
/* @__PURE__ */ jsx(FormField.Label, { id: "detail", style: { width: "90px" }, children: "\uC0C1\uC138\uC8FC\uC18C" }),
|
|
1474
1552
|
/* @__PURE__ */ jsx(
|
|
1475
|
-
|
|
1553
|
+
FormField.TextField,
|
|
1476
1554
|
{
|
|
1555
|
+
rootProps: {
|
|
1556
|
+
style: {
|
|
1557
|
+
display: "flex",
|
|
1558
|
+
flex: 1
|
|
1559
|
+
}
|
|
1560
|
+
},
|
|
1477
1561
|
placeholder: "\uC0C1\uC138\uC8FC\uC18C \uC785\uB825",
|
|
1478
1562
|
onChange: onDetailChange,
|
|
1479
|
-
size: "
|
|
1563
|
+
size: "small",
|
|
1480
1564
|
value: detailAddressInput,
|
|
1481
1565
|
...step === "detail-input" && { autoFocus: true }
|
|
1482
1566
|
}
|
|
@@ -1499,7 +1583,9 @@ function AddressComponent({ isOpen, onClose, setValue }) {
|
|
|
1499
1583
|
setDetail,
|
|
1500
1584
|
search,
|
|
1501
1585
|
searchInput,
|
|
1502
|
-
selectedAddress
|
|
1586
|
+
selectedAddress,
|
|
1587
|
+
onStandardizationChange,
|
|
1588
|
+
addressStandardizationList
|
|
1503
1589
|
} = useSearchAddress({
|
|
1504
1590
|
setValue,
|
|
1505
1591
|
onClose,
|
|
@@ -1526,7 +1612,7 @@ function AddressComponent({ isOpen, onClose, setValue }) {
|
|
|
1526
1612
|
AddressSearchResult,
|
|
1527
1613
|
{
|
|
1528
1614
|
onChange: onSelectChange,
|
|
1529
|
-
addressSearchList
|
|
1615
|
+
addressSearchList,
|
|
1530
1616
|
searchKeyword: addressSearchKeyword,
|
|
1531
1617
|
selectedAddress
|
|
1532
1618
|
}
|
|
@@ -1534,7 +1620,8 @@ function AddressComponent({ isOpen, onClose, setValue }) {
|
|
|
1534
1620
|
addressSearchStep === "detail-input" && selectedAddress && /* @__PURE__ */ jsx(
|
|
1535
1621
|
AddressSearchDetailInput,
|
|
1536
1622
|
{
|
|
1537
|
-
|
|
1623
|
+
addressStandardizationList,
|
|
1624
|
+
onStandardizationChange,
|
|
1538
1625
|
onDetailChange: setDetail,
|
|
1539
1626
|
step: addressSearchStep,
|
|
1540
1627
|
detailAddressInput
|
|
@@ -1563,21 +1650,48 @@ function AddressComponent({ isOpen, onClose, setValue }) {
|
|
|
1563
1650
|
function useSearchAddress({ setValue, onClose, isOpen }) {
|
|
1564
1651
|
const [searchKeyword, setSearchKeyword] = useState("");
|
|
1565
1652
|
const [step, setStep] = useState("initial");
|
|
1566
|
-
const [selectedAddress, setSelectedAddress] = useState(
|
|
1653
|
+
const [selectedAddress, setSelectedAddress] = useState();
|
|
1654
|
+
const [selectedStandardizationAddress, setSelectedStandardizationAddress] = useState();
|
|
1567
1655
|
const [searchInput, setSearchInput] = useState("");
|
|
1568
1656
|
const [detailAddressInput, setDetailAddressInput] = useState("");
|
|
1569
|
-
const
|
|
1657
|
+
const [displayList, setDisplayList] = useState([]);
|
|
1658
|
+
const [searchType, setSearchType] = useState("address");
|
|
1659
|
+
const [standardizationParams, setStandardizationParams] = useState({
|
|
1660
|
+
firstPostalCode: "",
|
|
1661
|
+
secondPostalCode: "",
|
|
1662
|
+
baseAddress: "",
|
|
1663
|
+
detailAddress: "",
|
|
1664
|
+
roadNameYn: "Y"
|
|
1665
|
+
});
|
|
1666
|
+
const { data: addressData } = useSearchAddressQuery(
|
|
1667
|
+
{ searchKeyWord: searchKeyword },
|
|
1668
|
+
{ enabled: !!searchKeyword && searchType === "address" }
|
|
1669
|
+
);
|
|
1670
|
+
const { data: postalData } = useSearchPostalCodeQuery(
|
|
1671
|
+
{ searchWordName: searchKeyword },
|
|
1672
|
+
{ enabled: !!searchKeyword && searchType === "postalcode" }
|
|
1673
|
+
);
|
|
1674
|
+
const { data: standardizedData } = useSearchAddressStandardizationQuery(standardizationParams, {
|
|
1675
|
+
enabled: !!standardizationParams?.baseAddress
|
|
1676
|
+
});
|
|
1570
1677
|
const [nextButtonDisabled, setNextButtonDisabled] = useState(false);
|
|
1571
1678
|
const onNext = () => {
|
|
1572
1679
|
if (step === "search-result") {
|
|
1573
1680
|
setStep("detail-input");
|
|
1574
1681
|
setNextButtonDisabled(true);
|
|
1682
|
+
if (selectedAddress) {
|
|
1683
|
+
setStandardizationParams({
|
|
1684
|
+
firstPostalCode: selectedAddress.firstPostalCode,
|
|
1685
|
+
secondPostalCode: selectedAddress.secondPostalCode,
|
|
1686
|
+
baseAddress: selectedAddress.roadNameBaseAddress,
|
|
1687
|
+
detailAddress: selectedAddress.roadNameDetailAddress,
|
|
1688
|
+
roadNameYn: "Y"
|
|
1689
|
+
});
|
|
1690
|
+
}
|
|
1575
1691
|
} else {
|
|
1576
|
-
setValue({
|
|
1577
|
-
|
|
1578
|
-
|
|
1579
|
-
zipCode: selectedAddress?.zipCode || "",
|
|
1580
|
-
detail: detailAddressInput || ""
|
|
1692
|
+
selectedStandardizationAddress && setValue({
|
|
1693
|
+
...selectedStandardizationAddress,
|
|
1694
|
+
detailAddressInput
|
|
1581
1695
|
});
|
|
1582
1696
|
onClose();
|
|
1583
1697
|
}
|
|
@@ -1592,9 +1706,11 @@ function useSearchAddress({ setValue, onClose, isOpen }) {
|
|
|
1592
1706
|
return;
|
|
1593
1707
|
}
|
|
1594
1708
|
if (searchInput && searchInput.length > 1) {
|
|
1709
|
+
const isNumeric = /^[0-9]+$/.test(searchInput);
|
|
1710
|
+
setSearchType(isNumeric ? "postalcode" : "address");
|
|
1595
1711
|
setSearchKeyword(searchInput);
|
|
1596
1712
|
setStep("search-result");
|
|
1597
|
-
setSelectedAddress(
|
|
1713
|
+
setSelectedAddress(void 0);
|
|
1598
1714
|
setDetailAddressInput("");
|
|
1599
1715
|
setNextButtonDisabled(true);
|
|
1600
1716
|
}
|
|
@@ -1605,19 +1721,23 @@ function useSearchAddress({ setValue, onClose, isOpen }) {
|
|
|
1605
1721
|
}
|
|
1606
1722
|
};
|
|
1607
1723
|
const onSelectChange = (e) => {
|
|
1608
|
-
const
|
|
1609
|
-
if (
|
|
1610
|
-
|
|
1611
|
-
|
|
1612
|
-
|
|
1613
|
-
|
|
1724
|
+
const selected = e.target.value;
|
|
1725
|
+
if (selected) {
|
|
1726
|
+
setSelectedAddress(JSON.parse(selected));
|
|
1727
|
+
setNextButtonDisabled(false);
|
|
1728
|
+
}
|
|
1729
|
+
};
|
|
1730
|
+
const onStandardizationChange = (e) => {
|
|
1731
|
+
const selected = e.target.value;
|
|
1732
|
+
if (selected) {
|
|
1733
|
+
setSelectedStandardizationAddress(JSON.parse(selected));
|
|
1614
1734
|
setNextButtonDisabled(false);
|
|
1615
1735
|
}
|
|
1616
1736
|
};
|
|
1617
1737
|
const onClear = useCallback(() => {
|
|
1618
1738
|
setSearchKeyword("");
|
|
1619
1739
|
setSearchInput("");
|
|
1620
|
-
setSelectedAddress(
|
|
1740
|
+
setSelectedAddress(void 0);
|
|
1621
1741
|
setDetailAddressInput("");
|
|
1622
1742
|
setStep("initial");
|
|
1623
1743
|
}, []);
|
|
@@ -1630,19 +1750,39 @@ function useSearchAddress({ setValue, onClose, isOpen }) {
|
|
|
1630
1750
|
setNextButtonDisabled(true);
|
|
1631
1751
|
}
|
|
1632
1752
|
};
|
|
1753
|
+
useEffect(() => {
|
|
1754
|
+
if (searchType === "address" && addressData?.data?.addressList) {
|
|
1755
|
+
setDisplayList(addressData.data.addressList);
|
|
1756
|
+
} else if (searchType === "postalcode" && postalData?.data?.postalCodeList) {
|
|
1757
|
+
console.log("transformedList", postalData.data.postalCodeList);
|
|
1758
|
+
const transformedList = postalData.data.postalCodeList.map((p) => ({
|
|
1759
|
+
firstPostalCode: p.originalNumber1PostalCode,
|
|
1760
|
+
secondPostalCode: p.originalNumber2PostalCode,
|
|
1761
|
+
roadNameBaseAddress: p.roadNameBaseAddress,
|
|
1762
|
+
roadNameDetailAddress: p.roadNameDetailAddress,
|
|
1763
|
+
landNumberBaseAddress: p.landNumberBaseAddress,
|
|
1764
|
+
landNumberDetailAddress: p.landNumberDetailAddress,
|
|
1765
|
+
mainBuildingName: p.mainBuildingName
|
|
1766
|
+
}));
|
|
1767
|
+
setDisplayList(transformedList);
|
|
1768
|
+
}
|
|
1769
|
+
}, [addressData, postalData, searchType]);
|
|
1633
1770
|
useEffect(() => {
|
|
1634
1771
|
if (isOpen) {
|
|
1635
|
-
setSelectedAddress(
|
|
1772
|
+
setSelectedAddress(void 0);
|
|
1636
1773
|
setDetailAddressInput("");
|
|
1637
1774
|
setStep("initial");
|
|
1638
1775
|
setSearchKeyword("");
|
|
1639
1776
|
}
|
|
1640
1777
|
}, [isOpen]);
|
|
1641
1778
|
return {
|
|
1779
|
+
addressStandardizationList: standardizedData?.data?.addressStandardizationList || [],
|
|
1780
|
+
selectedStandardizationAddress,
|
|
1781
|
+
onStandardizationChange,
|
|
1642
1782
|
onAddressSearchClear: onClear,
|
|
1643
1783
|
onAddressSearchNext: onNext,
|
|
1644
1784
|
addressSearchKeyword: searchKeyword,
|
|
1645
|
-
addressSearchList:
|
|
1785
|
+
addressSearchList: displayList,
|
|
1646
1786
|
addressSearchStep: step,
|
|
1647
1787
|
selectedAddress,
|
|
1648
1788
|
addressSearchOnValueChange: onSelectChange,
|
|
@@ -1657,7 +1797,7 @@ function useSearchAddress({ setValue, onClose, isOpen }) {
|
|
|
1657
1797
|
};
|
|
1658
1798
|
}
|
|
1659
1799
|
const useAddressComponent = () => {
|
|
1660
|
-
const [fullAddress, setFullAddress] = useState(
|
|
1800
|
+
const [fullAddress, setFullAddress] = useState();
|
|
1661
1801
|
const { isOpen, closeModal, openModal } = useModalState();
|
|
1662
1802
|
const AddressSearchComponent = () => /* @__PURE__ */ jsx(AddressComponent, { isOpen, onClose: closeModal, setValue: setFullAddress });
|
|
1663
1803
|
return {
|
|
@@ -2308,34 +2448,20 @@ const JobSearchModal = ({ onClose }) => {
|
|
|
2308
2448
|
] });
|
|
2309
2449
|
};
|
|
2310
2450
|
|
|
2311
|
-
const mockCustomers = [
|
|
2312
|
-
{ customerId: "1", customerName: "\uAE40\uD55C\uD654", birthDate: "1999.01.01", genderCode: "\uB0A8\uC131" },
|
|
2313
|
-
{
|
|
2314
|
-
customerId: "2",
|
|
2315
|
-
customerName: "\uAE40\uD55C\uD654\uC0DD\uBA85",
|
|
2316
|
-
birthDate: "1989.01.01",
|
|
2317
|
-
genderCode: "\uC5EC\uC131",
|
|
2318
|
-
baseAddress: "\uC11C\uC6B8\uC2DC \uB9C8\uD3EC\uAD6C"
|
|
2319
|
-
},
|
|
2320
|
-
{
|
|
2321
|
-
customerId: "3",
|
|
2322
|
-
customerName: "\uAE40\uD55C\uD654\uC190\uD574\uBCF4\uD5D8",
|
|
2323
|
-
birthDate: "1999.01.01",
|
|
2324
|
-
genderCode: "\uB0A8\uC131",
|
|
2325
|
-
baseAddress: "\uC11C\uC6B8\uC2DC \uB9C8\uD3EC\uAD6C"
|
|
2326
|
-
}
|
|
2327
|
-
];
|
|
2328
2451
|
const useCustomerSearch = (onSelect) => {
|
|
2329
2452
|
const { triggerRef, isOpen, setIsOpen, DropDown } = useDropDown();
|
|
2330
2453
|
const [searchKeyword, setSearchKeyword] = useState("");
|
|
2331
2454
|
const [searchInput, setSearchInput] = useState("");
|
|
2332
2455
|
const [customerList, setCustomerList] = useState([]);
|
|
2333
2456
|
const [selectedCustomer, setSelectedCustomer] = useState(null);
|
|
2457
|
+
const { data } = useSearchCustomerListQuery({ customerName: searchKeyword });
|
|
2334
2458
|
const search = () => {
|
|
2335
2459
|
if (searchInput.length >= 2) {
|
|
2336
2460
|
setSearchKeyword(searchInput);
|
|
2337
|
-
const filtered =
|
|
2338
|
-
|
|
2461
|
+
const filtered = data?.data?.custList?.filter(
|
|
2462
|
+
(c) => c.customerName?.toLowerCase().includes(searchInput.toLowerCase())
|
|
2463
|
+
);
|
|
2464
|
+
setCustomerList(filtered || []);
|
|
2339
2465
|
setIsOpen(true);
|
|
2340
2466
|
} else {
|
|
2341
2467
|
setCustomerList([]);
|