sales-frontend-bridge 0.0.39 → 0.0.41
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 +89 -57
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +94 -23
- package/dist/index.d.ts +94 -23
- package/dist/index.js +87 -59
- package/dist/index.js.map +1 -1
- package/package.json +2 -2
package/dist/index.cjs
CHANGED
|
@@ -1710,7 +1710,8 @@ var NativeBridgeCore = class extends CommonBridgeCore {
|
|
|
1710
1710
|
return;
|
|
1711
1711
|
}
|
|
1712
1712
|
if (platform === "ios-webview") {
|
|
1713
|
-
|
|
1713
|
+
const message = salesFrontendUtils.isFpPlannerApp() ? { ...command, service: "native" } : command;
|
|
1714
|
+
window.webkit?.messageHandlers?.[this.callBridgeName]?.postMessage(JSON.stringify(message));
|
|
1714
1715
|
return;
|
|
1715
1716
|
}
|
|
1716
1717
|
console.warn(
|
|
@@ -2219,7 +2220,7 @@ var commonOzParam = [
|
|
|
2219
2220
|
`information.debug = true`,
|
|
2220
2221
|
`global.inheritparameter=true`,
|
|
2221
2222
|
`global.concatpage=true`,
|
|
2222
|
-
`global.eachpagenumberatconcatpage=true`,
|
|
2223
|
+
// `global.eachpagenumberatconcatpage=true`,
|
|
2223
2224
|
`eform.signpad_type=embedded`,
|
|
2224
2225
|
// `eform.signpad_type=keypad`,
|
|
2225
2226
|
`eform.show_prev_next_input=true`,
|
|
@@ -2228,10 +2229,10 @@ var commonOzParam = [
|
|
|
2228
2229
|
`eform.inputcomponent_toolbar_button_json=${JSON.stringify({
|
|
2229
2230
|
// 서명패드 버튼 배열 수정
|
|
2230
2231
|
"all": {
|
|
2231
|
-
// 왼쪽에 이전,
|
|
2232
|
-
"left_align": "prev,
|
|
2233
|
-
// 오른쪽에
|
|
2234
|
-
"right_align": "
|
|
2232
|
+
// 왼쪽에 [이전, 창닫기]
|
|
2233
|
+
"left_align": "prev,ok",
|
|
2234
|
+
// 오른쪽에 [다시쓰기, 성명,서명 불러오기, 다음]
|
|
2235
|
+
"right_align": "clear,reusablesign,next"
|
|
2235
2236
|
}
|
|
2236
2237
|
})}`,
|
|
2237
2238
|
`eform.signpad_show_draw_erase_button=false`,
|
|
@@ -2241,7 +2242,8 @@ var commonOzParam = [
|
|
|
2241
2242
|
`eform.prev_next_required_rule=required_only`,
|
|
2242
2243
|
`eform.prev_next_navigation_rule=required_only`,
|
|
2243
2244
|
`eform.prev_next_constraint_rule=empty_only`,
|
|
2244
|
-
//
|
|
2245
|
+
// 서명 입력 중간중간에 onValueChanged가 호출 / 디폴트는 입력끝나고 창이 닫힐때 호출
|
|
2246
|
+
`eform.onvaluechanged_callrule_json=${JSON.stringify({ signpad: "changed" })}`,
|
|
2245
2247
|
`viewer.pagenavigate_by_prev_next=true`,
|
|
2246
2248
|
`eform.imagepicker_id_info=${JSON.stringify({
|
|
2247
2249
|
ids: [
|
|
@@ -2313,7 +2315,8 @@ var commonOzParam = [
|
|
|
2313
2315
|
`viewer.exportcommand=true`,
|
|
2314
2316
|
`viewer.errorcommand=true`,
|
|
2315
2317
|
`viewer.reportchangecommand=true`,
|
|
2316
|
-
`viewer.pagebindcommandinterval=500
|
|
2318
|
+
`viewer.pagebindcommandinterval=500`,
|
|
2319
|
+
`ozd.allowreplaceformparam=true`
|
|
2317
2320
|
];
|
|
2318
2321
|
|
|
2319
2322
|
// src/oz/constant/pdf-param.ts
|
|
@@ -2334,19 +2337,20 @@ var commonPdfExportParam = [
|
|
|
2334
2337
|
var wrapperStyle = { display: "flex", flexFlow: "column", gap: "10px" };
|
|
2335
2338
|
var btnStyle = { border: "1px solid red", minHeight: "40px" };
|
|
2336
2339
|
var DownloadDocumentList = [
|
|
2337
|
-
{ name: "[A0010]\uCCAD\uC57D\uC11C",
|
|
2338
|
-
{ name:
|
|
2339
|
-
// { name: '[A0900]상품설명서',
|
|
2340
|
-
{ name:
|
|
2341
|
-
{ name:
|
|
2342
|
-
{ name:
|
|
2343
|
-
{ name:
|
|
2344
|
-
{ name:
|
|
2345
|
-
{ name:
|
|
2346
|
-
{ name:
|
|
2347
|
-
{ name:
|
|
2348
|
-
{ name:
|
|
2349
|
-
{ name:
|
|
2340
|
+
{ name: "[A0010]\uCCAD\uC57D\uC11C", doc: [{ docCode: "A0010", fileID: "Fgn33vCNaUbAHKkAA", imageFormatCode: "RT003001", imageDocumentTypeCode: "IT00", filePath: "", startPage: 0, endPage: 0 }], complete: false, startPage: 0, endPage: 0, focus: false }
|
|
2341
|
+
// { name: '[A0100]비교안내확인서', doc: [{ docCode: 'A0100', fileID: '0IxCQWCNZNl-SKkAA', imageFormatCode: 'RT003001', imageDocumentTypeCode: 'IT00', filePath: '', startPage: 0, endPage: 0 }], complete: false, startPage: 0, endPage: 0, focus: false },
|
|
2342
|
+
// { name: '[A0900]상품설명서', doc: [{ docCode: 'A0900', fileID: 'IRnk0TCNZNzt7KkAA', imageFormatCode: 'RT003001', imageDocumentTypeCode: 'IT00', filePath: '', startPage: 0, endPage: 0 }], complete: false, startPage: 0, endPage: 0, focus: false },
|
|
2343
|
+
// { name: '[A1500]청약부속정보확인서', doc: [{ docCode: 'A1500', fileID: 'uw0KChCNZP1eFKkAA', imageFormatCode: 'RT003001', imageDocumentTypeCode: 'IT00', filePath: '', startPage: 0, endPage: 0 }], complete: false, startPage: 0, endPage: 0, focus: false },
|
|
2344
|
+
// { name: '[A2215]보험계약대출이행관리동의서', doc: [{ docCode: 'A2215', fileID: 'QIpmmaCNZRWRuKkAA', imageFormatCode: 'RT003001', imageDocumentTypeCode: 'IT00', filePath: '', startPage: 0, endPage: 0 }], complete: false, startPage: 0, endPage: 0, focus: false },
|
|
2345
|
+
// { name: '[A2800]계약전알릴의무', doc: [{ docCode: 'A2800', fileID: 'ZirCIiCNZRbLFKkAA', imageFormatCode: 'RT003001', imageDocumentTypeCode: 'IT00', filePath: '', startPage: 0, endPage: 0 }], complete: false, startPage: 0, endPage: 0, focus: false },
|
|
2346
|
+
// { name: '[A3503]청약서별지(변액용)', doc: [{ docCode: 'A3503', fileID: '7Cm2jqCNZRimXKkAA', imageFormatCode: 'RT003001', imageDocumentTypeCode: 'IT00', filePath: '', startPage: 0, endPage: 0 }], complete: false, startPage: 0, endPage: 0, focus: false },
|
|
2347
|
+
// { name: '[B0101]보험계약체결동의서', doc: [{ docCode: 'B0101', fileID: 'g1oZeaCNZRrGhKkAA', imageFormatCode: 'RT003001', imageDocumentTypeCode: 'IT00', filePath: '', startPage: 0, endPage: 0 }], complete: false, startPage: 0, endPage: 0, focus: false },
|
|
2348
|
+
// { name: '[C0400]계약체결이행동의서', doc: [{ docCode: 'C0400', fileID: 'eyBV4QCNalUwWKkAA', imageFormatCode: 'RT003001', imageDocumentTypeCode: 'IT00', filePath: '', startPage: 0, endPage: 0 }], complete: false, startPage: 0, endPage: 0, focus: false },
|
|
2349
|
+
// { name: '[C0401]상품소개상세동의서', doc: [{ docCode: 'C0401', fileID: 'OqBHIjCNZS1BTKkAA', imageFormatCode: 'RT003001', imageDocumentTypeCode: 'IT00', filePath: '', startPage: 0, endPage: 0 }], complete: false, startPage: 0, endPage: 0, focus: false },
|
|
2350
|
+
// { name: '[C1000]보험상품판매체크리스트', doc: [{ docCode: 'C1000', fileID: 'aSAXJOCNa8UgjKkAA', imageFormatCode: 'RT003001', imageDocumentTypeCode: 'IT00', filePath: '', startPage: 0, endPage: 0 }], complete: false, startPage: 0, endPage: 0, focus: false },
|
|
2351
|
+
// { name: '[C1300]계약체결고지의무확인서', doc: [{ docCode: 'C1300', fileID: 'uz9gVwCNZTYsUKkAA', imageFormatCode: 'RT003001', imageDocumentTypeCode: 'IT00', filePath: '', startPage: 0, endPage: 0 }], complete: false, startPage: 0, endPage: 0, focus: false },
|
|
2352
|
+
// { name: '[C1400]보험상품비교설명확인서', doc: [{ docCode: 'C1400', fileID: 'KFZ4kKCNZTb5CKkAA', imageFormatCode: 'RT003001', imageDocumentTypeCode: 'IT00', filePath: '', startPage: 0, endPage: 0 }], complete: false, startPage: 0, endPage: 0, focus: false },
|
|
2353
|
+
// { name: '[A0010]청약서', doc: [{ docCode: 'A0010', fileID: 'Fgn33vCNaUbAHKkAA', imageFormatCode: 'RT003001', imageDocumentTypeCode: 'IT00', filePath: '', startPage: 0, endPage: 0 }], complete: false, startPage: 0, endPage: 0, focus: false },
|
|
2350
2354
|
];
|
|
2351
2355
|
var ExtraData = {
|
|
2352
2356
|
// 문서코드
|
|
@@ -2359,28 +2363,30 @@ var ExtraData = {
|
|
|
2359
2363
|
A0010_mysg_sign: ""
|
|
2360
2364
|
},
|
|
2361
2365
|
// 기타 공통으로 사용하지 않을 파라미터
|
|
2362
|
-
extraParam: [
|
|
2363
|
-
|
|
2366
|
+
extraParam: [],
|
|
2367
|
+
// aaa=bbb
|
|
2368
|
+
args: []
|
|
2364
2369
|
},
|
|
2365
2370
|
A0900: {
|
|
2366
|
-
args: [
|
|
2371
|
+
args: []
|
|
2367
2372
|
}
|
|
2368
2373
|
};
|
|
2369
2374
|
var policyNumber = "300034894";
|
|
2370
2375
|
var fpInfo = { uniqNo: "2210000" };
|
|
2376
|
+
var roleCode = [`11`, `21`];
|
|
2371
2377
|
|
|
2372
2378
|
// src/oz/hooks/use-document-info.tsx
|
|
2373
2379
|
var import_react = __toESM(require_react());
|
|
2374
2380
|
function useDocumentInfo(initialValue) {
|
|
2375
2381
|
const [documentInfo, setDocumentInfo] = (0, import_react.useState)([...initialValue]);
|
|
2376
|
-
const documentList = (0, import_react.useMemo)(() => documentInfo.map((i) => i.
|
|
2382
|
+
const documentList = (0, import_react.useMemo)(() => documentInfo.map((i) => i.doc).flat(1), [documentInfo]);
|
|
2377
2383
|
const documentIndexMap = documentList.reduce((acc, cur, index) => {
|
|
2378
|
-
acc[cur] = index;
|
|
2384
|
+
acc[cur.docCode] = index;
|
|
2379
2385
|
return acc;
|
|
2380
2386
|
}, {});
|
|
2381
|
-
const documentTemplateMap = (0, import_react.useMemo)(() => documentInfo.reduce((map,
|
|
2382
|
-
doc.
|
|
2383
|
-
map[
|
|
2387
|
+
const documentTemplateMap = (0, import_react.useMemo)(() => documentInfo.reduce((map, template) => {
|
|
2388
|
+
template.doc.forEach((ozdFile) => {
|
|
2389
|
+
map[ozdFile.docCode] = { ...template };
|
|
2384
2390
|
});
|
|
2385
2391
|
return map;
|
|
2386
2392
|
}, {}), [documentInfo]);
|
|
@@ -2389,13 +2395,13 @@ function useDocumentInfo(initialValue) {
|
|
|
2389
2395
|
return acc;
|
|
2390
2396
|
}, {});
|
|
2391
2397
|
const groupIndexes = (0, import_react.useMemo)(() => documentInfo.reduce((acc, item) => {
|
|
2392
|
-
item.
|
|
2393
|
-
const currentIndex = documentIndexMap[
|
|
2398
|
+
item.doc.forEach((ozdFile) => {
|
|
2399
|
+
const currentIndex = documentIndexMap[ozdFile.docCode];
|
|
2394
2400
|
if (!acc[currentIndex]) {
|
|
2395
2401
|
acc[currentIndex] = [];
|
|
2396
2402
|
}
|
|
2397
|
-
item.
|
|
2398
|
-
acc[currentIndex].push(documentIndexMap[
|
|
2403
|
+
item.doc.forEach((ozdFile2) => {
|
|
2404
|
+
acc[currentIndex].push(documentIndexMap[ozdFile2.docCode]);
|
|
2399
2405
|
});
|
|
2400
2406
|
});
|
|
2401
2407
|
return acc;
|
|
@@ -2445,27 +2451,25 @@ var OZViewerEvent = /* @__PURE__ */ ((OZViewerEvent2) => {
|
|
|
2445
2451
|
OZViewerEvent2["OZReportCreated"] = "OZReportCreated";
|
|
2446
2452
|
return OZViewerEvent2;
|
|
2447
2453
|
})(OZViewerEvent || {});
|
|
2454
|
+
var OZTriggerExternalEvent = /* @__PURE__ */ ((OZTriggerExternalEvent2) => {
|
|
2455
|
+
OZTriggerExternalEvent2["GetDraftData"] = "getDraftData";
|
|
2456
|
+
return OZTriggerExternalEvent2;
|
|
2457
|
+
})(OZTriggerExternalEvent || {});
|
|
2448
2458
|
|
|
2449
2459
|
// src/oz/utils/common-util.ts
|
|
2450
2460
|
function categorizeByPageRange(data, pageCounts) {
|
|
2451
|
-
let
|
|
2452
|
-
const result = [];
|
|
2461
|
+
let currentPage = 1;
|
|
2453
2462
|
let pageIndex = 0;
|
|
2454
|
-
data
|
|
2455
|
-
|
|
2456
|
-
|
|
2457
|
-
|
|
2458
|
-
const pageCount = pageCounts[pageIndex];
|
|
2459
|
-
|
|
2460
|
-
|
|
2461
|
-
|
|
2462
|
-
endPage = pageEnd;
|
|
2463
|
-
});
|
|
2464
|
-
result.push({
|
|
2465
|
-
...item,
|
|
2466
|
-
startPage,
|
|
2467
|
-
endPage
|
|
2463
|
+
const result = DeepCopy(data);
|
|
2464
|
+
result.forEach((group) => {
|
|
2465
|
+
group.startPage = currentPage;
|
|
2466
|
+
group.doc.forEach((doc) => {
|
|
2467
|
+
const pageCount = pageCounts[pageIndex++];
|
|
2468
|
+
doc.startPage = currentPage;
|
|
2469
|
+
doc.endPage = currentPage + pageCount - 1;
|
|
2470
|
+
currentPage += pageCount;
|
|
2468
2471
|
});
|
|
2472
|
+
group.endPage = group.doc[group.doc.length - 1].endPage;
|
|
2469
2473
|
});
|
|
2470
2474
|
return result;
|
|
2471
2475
|
}
|
|
@@ -2481,10 +2485,10 @@ function extractFileName(filePath) {
|
|
|
2481
2485
|
}
|
|
2482
2486
|
function getFileListByGlobalIndex(index, data) {
|
|
2483
2487
|
let currentIndex = 0;
|
|
2484
|
-
for (const
|
|
2485
|
-
const fileCount =
|
|
2488
|
+
for (const template of data) {
|
|
2489
|
+
const fileCount = template.doc.length;
|
|
2486
2490
|
if (index >= currentIndex && index < currentIndex + fileCount) {
|
|
2487
|
-
return
|
|
2491
|
+
return template;
|
|
2488
2492
|
}
|
|
2489
2493
|
currentIndex += fileCount;
|
|
2490
2494
|
}
|
|
@@ -2815,8 +2819,8 @@ async function SaveTotalPdf() {
|
|
|
2815
2819
|
|
|
2816
2820
|
// src/oz/utils/bridge-util/fetch-util.ts
|
|
2817
2821
|
async function fetchDocument(options) {
|
|
2818
|
-
const { data } = await Bridge.native.downloadDocument({ data: options });
|
|
2819
|
-
return data.map((i) => ({ ...i, startPage: 0, endPage: 0 }));
|
|
2822
|
+
const { data: result } = await Bridge.native.downloadDocument({ data: options, policyNumber, fpInfo });
|
|
2823
|
+
return result.data.map((i) => ({ ...i, startPage: 0, endPage: 0 }));
|
|
2820
2824
|
}
|
|
2821
2825
|
async function fetchFont() {
|
|
2822
2826
|
const { data: fontMap } = await Bridge.native.getOzFontParam();
|
|
@@ -2831,12 +2835,12 @@ async function CreateOzParam(documentList, extraData = {}) {
|
|
|
2831
2835
|
}
|
|
2832
2836
|
const fontParms = await fetchFont();
|
|
2833
2837
|
const connectionParams = documentList.map(
|
|
2834
|
-
(
|
|
2838
|
+
({ filePath }, idx) => idx === 0 ? `connection.openfile=${filePath}` : `child${idx}.connection.openfile=${filePath}`
|
|
2835
2839
|
);
|
|
2836
2840
|
const childCount = documentList.length - 1;
|
|
2837
|
-
const extraParams = documentList.map((
|
|
2841
|
+
const extraParams = documentList.map((ozdFile, idx) => {
|
|
2838
2842
|
const result = [];
|
|
2839
|
-
const docCode =
|
|
2843
|
+
const docCode = ozdFile.docCode.replace(/^.*[\\/]|(\.[^/.]+)$/g, "");
|
|
2840
2844
|
const prefix = idx === 0 ? "" : `child${idx}.`;
|
|
2841
2845
|
const data = extraData[docCode] || {};
|
|
2842
2846
|
if (data.inputJson) {
|
|
@@ -2845,6 +2849,7 @@ async function CreateOzParam(documentList, extraData = {}) {
|
|
|
2845
2849
|
const args = [
|
|
2846
2850
|
// 모든서식에 공통으로 필요한 docCd param 추가
|
|
2847
2851
|
`docCd=${docCode}`,
|
|
2852
|
+
`roleCd=11,28`,
|
|
2848
2853
|
...ensureArray(data.args)
|
|
2849
2854
|
];
|
|
2850
2855
|
args.forEach((arg, idx2) => result.push(`${prefix}connection.args${idx2 + 1}=${arg}`));
|
|
@@ -2898,6 +2903,29 @@ async function getTotalPageOnAllDocuments(reportCount) {
|
|
|
2898
2903
|
}
|
|
2899
2904
|
return totalPages;
|
|
2900
2905
|
}
|
|
2906
|
+
|
|
2907
|
+
// src/oz/utils/bridge-util/get-draft-data-util.ts
|
|
2908
|
+
async function getDraftDataHandler(rawOzRequest, documentIndexMap) {
|
|
2909
|
+
const parsedRequest = JSON.parse(rawOzRequest);
|
|
2910
|
+
const { docCd, ...signKeyMap } = parsedRequest;
|
|
2911
|
+
const documentIndex = documentIndexMap[docCd];
|
|
2912
|
+
if (documentIndex === void 0) {
|
|
2913
|
+
throw new Error(`Invalid document code: ${docCd}`);
|
|
2914
|
+
}
|
|
2915
|
+
const { data } = await Bridge.nativeOz.getInformation({ command: `INPUT_JSON_AT=${documentIndex}` });
|
|
2916
|
+
const documentJson = JSON.parse(data);
|
|
2917
|
+
const signDataMap = Object.keys(signKeyMap).reduce((acc, key) => {
|
|
2918
|
+
acc[key] = documentJson[key];
|
|
2919
|
+
return acc;
|
|
2920
|
+
}, {});
|
|
2921
|
+
return signDataMap;
|
|
2922
|
+
}
|
|
2923
|
+
async function triggerDraftDataByIndexList(indexList) {
|
|
2924
|
+
for (let i = 0; i < indexList.length; i++) {
|
|
2925
|
+
await sleep();
|
|
2926
|
+
await Bridge.nativeOz.triggerExternalEventByDocIndex({ param1: "getDraftData" /* GetDraftData */, docIndex: indexList[i] });
|
|
2927
|
+
}
|
|
2928
|
+
}
|
|
2901
2929
|
/*! Bundled license information:
|
|
2902
2930
|
|
|
2903
2931
|
react/cjs/react.production.js:
|
|
@@ -2931,6 +2959,7 @@ exports.CreateOzViewer = CreateOzViewer;
|
|
|
2931
2959
|
exports.DownloadDocumentList = DownloadDocumentList;
|
|
2932
2960
|
exports.ExtraData = ExtraData;
|
|
2933
2961
|
exports.MovePage = MovePage;
|
|
2962
|
+
exports.OZTriggerExternalEvent = OZTriggerExternalEvent;
|
|
2934
2963
|
exports.OZViewerEvent = OZViewerEvent;
|
|
2935
2964
|
exports.PdfHandler = PdfHandler;
|
|
2936
2965
|
exports.PromiseWithResolvers = PromiseWithResolvers;
|
|
@@ -2955,18 +2984,21 @@ exports.fetchDocument = fetchDocument;
|
|
|
2955
2984
|
exports.fetchFont = fetchFont;
|
|
2956
2985
|
exports.fpInfo = fpInfo;
|
|
2957
2986
|
exports.getCurrentPage = getCurrentPage;
|
|
2987
|
+
exports.getDraftDataHandler = getDraftDataHandler;
|
|
2958
2988
|
exports.getFileListByGlobalIndex = getFileListByGlobalIndex;
|
|
2959
2989
|
exports.getReportCountMemo = getReportCountMemo;
|
|
2960
2990
|
exports.getTotalPageMemo = getTotalPageMemo;
|
|
2961
2991
|
exports.getTotalPageOnAllDocuments = getTotalPageOnAllDocuments;
|
|
2962
2992
|
exports.isCommentMode = isCommentMode;
|
|
2963
2993
|
exports.policyNumber = policyNumber;
|
|
2994
|
+
exports.roleCode = roleCode;
|
|
2964
2995
|
exports.setCheckEform = setCheckEform;
|
|
2965
2996
|
exports.setDisableCommentMode = setDisableCommentMode;
|
|
2966
2997
|
exports.setEnableCommentMode = setEnableCommentMode;
|
|
2967
2998
|
exports.sleep = sleep;
|
|
2968
2999
|
exports.triggerClickOnAllDocuments = triggerClickOnAllDocuments;
|
|
2969
3000
|
exports.triggerCropImageOnAllDocuments = triggerCropImageOnAllDocuments;
|
|
3001
|
+
exports.triggerDraftDataByIndexList = triggerDraftDataByIndexList;
|
|
2970
3002
|
exports.useDocumentInfo = useDocumentInfo;
|
|
2971
3003
|
exports.useOzEventListener = useOzEventListener;
|
|
2972
3004
|
exports.validateAllPages = validateAllPages;
|