sales-frontend-bridge 0.0.38 → 0.0.40

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 CHANGED
@@ -1944,6 +1944,50 @@ var NativeBridge = class extends CommonBridge {
1944
1944
  hideWebPopup() {
1945
1945
  return this.core.callToTarget("hideWebPopup");
1946
1946
  }
1947
+ /**
1948
+ * OnePass 인증
1949
+ * @example
1950
+ * ```tsx
1951
+ * // 사용 예시
1952
+ * Bridge.native.requestAuthentication()
1953
+ * ```
1954
+ */
1955
+ requestAuthentication() {
1956
+ return this.core.callToTarget("requestAuthentication");
1957
+ }
1958
+ /**
1959
+ * 웹뷰 띄우기
1960
+ * @example
1961
+ * ```tsx
1962
+ * // 사용 예시
1963
+ * Bridge.native.openWeb()
1964
+ * ```
1965
+ */
1966
+ openWeb(options) {
1967
+ return this.core.callToTarget("openWeb", options);
1968
+ }
1969
+ /**
1970
+ * 웹뷰 닫기
1971
+ * @example
1972
+ * ```tsx
1973
+ * // 사용 예시
1974
+ * Bridge.native.closeWeb()
1975
+ * ```
1976
+ */
1977
+ closeWeb() {
1978
+ return this.core.callToTarget("closeWeb");
1979
+ }
1980
+ /**
1981
+ * 앱 종료
1982
+ * @example
1983
+ * ```tsx
1984
+ * // 사용 예시
1985
+ * Bridge.native.closeWeb()
1986
+ * ```
1987
+ */
1988
+ exitApp() {
1989
+ return this.core.callToTarget("exitApp");
1990
+ }
1947
1991
  // TODO: 필요 플러그인들 추가
1948
1992
  };
1949
1993
 
@@ -2175,7 +2219,7 @@ var commonOzParam = [
2175
2219
  `information.debug = true`,
2176
2220
  `global.inheritparameter=true`,
2177
2221
  `global.concatpage=true`,
2178
- `global.eachpagenumberatconcatpage=true`,
2222
+ // `global.eachpagenumberatconcatpage=true`,
2179
2223
  `eform.signpad_type=embedded`,
2180
2224
  // `eform.signpad_type=keypad`,
2181
2225
  `eform.show_prev_next_input=true`,
@@ -2184,10 +2228,10 @@ var commonOzParam = [
2184
2228
  `eform.inputcomponent_toolbar_button_json=${JSON.stringify({
2185
2229
  // 서명패드 버튼 배열 수정
2186
2230
  "all": {
2187
- // 왼쪽에 이전, 다시쓰기 버튼
2188
- "left_align": "prev,clear",
2189
- // 오른쪽에 완료 성명,서명 불러오기, 다음
2190
- "right_align": "ok,reusablesign,next"
2231
+ // 왼쪽에 [이전, 창닫기]
2232
+ "left_align": "prev,ok",
2233
+ // 오른쪽에 [다시쓰기, 성명,서명 불러오기, 다음]
2234
+ "right_align": "clear,reusablesign,next"
2191
2235
  }
2192
2236
  })}`,
2193
2237
  `eform.signpad_show_draw_erase_button=false`,
@@ -2197,7 +2241,8 @@ var commonOzParam = [
2197
2241
  `eform.prev_next_required_rule=required_only`,
2198
2242
  `eform.prev_next_navigation_rule=required_only`,
2199
2243
  `eform.prev_next_constraint_rule=empty_only`,
2200
- // `eform.onvaluechanged_callrule_json=${JSON.stringify({ signpad: 'changed' })}`,
2244
+ // 서명 입력 중간중간에 onValueChanged가 호출 / 디폴트는 입력끝나고 창이 닫힐때 호출
2245
+ `eform.onvaluechanged_callrule_json=${JSON.stringify({ signpad: "changed" })}`,
2201
2246
  `viewer.pagenavigate_by_prev_next=true`,
2202
2247
  `eform.imagepicker_id_info=${JSON.stringify({
2203
2248
  ids: [
@@ -2269,7 +2314,8 @@ var commonOzParam = [
2269
2314
  `viewer.exportcommand=true`,
2270
2315
  `viewer.errorcommand=true`,
2271
2316
  `viewer.reportchangecommand=true`,
2272
- `viewer.pagebindcommandinterval=500`
2317
+ `viewer.pagebindcommandinterval=500`,
2318
+ `ozd.allowreplaceformparam=true`
2273
2319
  ];
2274
2320
 
2275
2321
  // src/oz/constant/pdf-param.ts
@@ -2290,19 +2336,20 @@ var commonPdfExportParam = [
2290
2336
  var wrapperStyle = { display: "flex", flexFlow: "column", gap: "10px" };
2291
2337
  var btnStyle = { border: "1px solid red", minHeight: "40px" };
2292
2338
  var DownloadDocumentList = [
2293
- { name: "[A0010]\uCCAD\uC57D\uC11C", file: ["A0010.ozd"], complete: false, startPage: 0, endPage: 0, focus: false },
2294
- { name: "[A0100]\uBE44\uAD50\uC548\uB0B4\uD655\uC778\uC11C", file: ["A0100.ozd"], complete: false, startPage: 0, endPage: 0, focus: false },
2295
- // { name: '[A0900]상품설명서', file: ['A0900.ozd'], complete: false, startPage: 0, endPage: 0, focus: false },
2296
- { name: "[A1500]\uCCAD\uC57D\uBD80\uC18D\uC815\uBCF4\uD655\uC778\uC11C", file: ["A1500.ozd"], complete: false, startPage: 0, endPage: 0, focus: false },
2297
- { name: "[A2215]\uBCF4\uD5D8\uACC4\uC57D\uB300\uCD9C\uC774\uD589\uAD00\uB9AC\uB3D9\uC758\uC11C", file: ["A2215.ozd"], complete: false, startPage: 0, endPage: 0, focus: false },
2298
- { name: "[A2800]\uACC4\uC57D\uC804\uC54C\uB9B4\uC758\uBB34", file: ["A2800.ozd"], complete: false, startPage: 0, endPage: 0, focus: false },
2299
- { name: "[A3503]\uCCAD\uC57D\uC11C\uBCC4\uC9C0(\uBCC0\uC561\uC6A9)", file: ["A3503.ozd"], complete: false, startPage: 0, endPage: 0, focus: false },
2300
- { name: "[B0101]\uBCF4\uD5D8\uACC4\uC57D\uCCB4\uACB0\uB3D9\uC758\uC11C", file: ["B0101.ozd"], complete: false, startPage: 0, endPage: 0, focus: false },
2301
- { name: "[C0400]\uACC4\uC57D\uCCB4\uACB0\uC774\uD589\uB3D9\uC758\uC11C", file: ["C0400.ozd"], complete: false, startPage: 0, endPage: 0, focus: false },
2302
- { name: "[C0401]\uC0C1\uD488\uC18C\uAC1C\uC0C1\uC138\uB3D9\uC758\uC11C", file: ["C0401.ozd"], complete: false, startPage: 0, endPage: 0, focus: false },
2303
- { name: "[C1000]\uBCF4\uD5D8\uC0C1\uD488\uD310\uB9E4\uCCB4\uD06C\uB9AC\uC2A4\uD2B8", file: ["C1000.ozd"], complete: false, startPage: 0, endPage: 0, focus: false },
2304
- { name: "[C1300]\uACC4\uC57D\uCCB4\uACB0\uACE0\uC9C0\uC758\uBB34\uD655\uC778\uC11C", file: ["C1300.ozd"], complete: false, startPage: 0, endPage: 0, focus: false },
2305
- { name: "[C1400]\uBCF4\uD5D8\uC0C1\uD488\uBE44\uAD50\uC124\uBA85\uD655\uC778\uC11C", file: ["C1400.ozd"], complete: false, startPage: 0, endPage: 0, focus: false }
2339
+ { 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 }
2340
+ // { 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 },
2341
+ // { name: '[A0900]상품설명서', doc: [{ docCode: 'A0900', fileID: 'IRnk0TCNZNzt7KkAA', imageFormatCode: 'RT003001', imageDocumentTypeCode: 'IT00', filePath: '', startPage: 0, endPage: 0 }], complete: false, startPage: 0, endPage: 0, focus: false },
2342
+ // { name: '[A1500]청약부속정보확인서', doc: [{ docCode: 'A1500', fileID: 'uw0KChCNZP1eFKkAA', imageFormatCode: 'RT003001', imageDocumentTypeCode: 'IT00', filePath: '', startPage: 0, endPage: 0 }], complete: false, startPage: 0, endPage: 0, focus: false },
2343
+ // { name: '[A2215]보험계약대출이행관리동의서', doc: [{ docCode: 'A2215', fileID: 'QIpmmaCNZRWRuKkAA', imageFormatCode: 'RT003001', imageDocumentTypeCode: 'IT00', filePath: '', startPage: 0, endPage: 0 }], complete: false, startPage: 0, endPage: 0, focus: false },
2344
+ // { name: '[A2800]계약전알릴의무', doc: [{ docCode: 'A2800', fileID: 'ZirCIiCNZRbLFKkAA', imageFormatCode: 'RT003001', imageDocumentTypeCode: 'IT00', filePath: '', startPage: 0, endPage: 0 }], complete: false, startPage: 0, endPage: 0, focus: false },
2345
+ // { name: '[A3503]청약서별지(변액용)', doc: [{ docCode: 'A3503', fileID: '7Cm2jqCNZRimXKkAA', imageFormatCode: 'RT003001', imageDocumentTypeCode: 'IT00', filePath: '', startPage: 0, endPage: 0 }], complete: false, startPage: 0, endPage: 0, focus: false },
2346
+ // { name: '[B0101]보험계약체결동의서', doc: [{ docCode: 'B0101', fileID: 'g1oZeaCNZRrGhKkAA', imageFormatCode: 'RT003001', imageDocumentTypeCode: 'IT00', filePath: '', startPage: 0, endPage: 0 }], complete: false, startPage: 0, endPage: 0, focus: false },
2347
+ // { name: '[C0400]계약체결이행동의서', doc: [{ docCode: 'C0400', fileID: 'eyBV4QCNalUwWKkAA', imageFormatCode: 'RT003001', imageDocumentTypeCode: 'IT00', filePath: '', startPage: 0, endPage: 0 }], complete: false, startPage: 0, endPage: 0, focus: false },
2348
+ // { name: '[C0401]상품소개상세동의서', doc: [{ docCode: 'C0401', fileID: 'OqBHIjCNZS1BTKkAA', imageFormatCode: 'RT003001', imageDocumentTypeCode: 'IT00', filePath: '', startPage: 0, endPage: 0 }], complete: false, startPage: 0, endPage: 0, focus: false },
2349
+ // { name: '[C1000]보험상품판매체크리스트', doc: [{ docCode: 'C1000', fileID: 'aSAXJOCNa8UgjKkAA', imageFormatCode: 'RT003001', imageDocumentTypeCode: 'IT00', filePath: '', startPage: 0, endPage: 0 }], complete: false, startPage: 0, endPage: 0, focus: false },
2350
+ // { name: '[C1300]계약체결고지의무확인서', doc: [{ docCode: 'C1300', fileID: 'uz9gVwCNZTYsUKkAA', imageFormatCode: 'RT003001', imageDocumentTypeCode: 'IT00', filePath: '', startPage: 0, endPage: 0 }], complete: false, startPage: 0, endPage: 0, focus: false },
2351
+ // { name: '[C1400]보험상품비교설명확인서', doc: [{ docCode: 'C1400', fileID: 'KFZ4kKCNZTb5CKkAA', imageFormatCode: 'RT003001', imageDocumentTypeCode: 'IT00', filePath: '', startPage: 0, endPage: 0 }], complete: false, startPage: 0, endPage: 0, focus: false },
2352
+ // { name: '[A0010]청약서', doc: [{ docCode: 'A0010', fileID: 'Fgn33vCNaUbAHKkAA', imageFormatCode: 'RT003001', imageDocumentTypeCode: 'IT00', filePath: '', startPage: 0, endPage: 0 }], complete: false, startPage: 0, endPage: 0, focus: false },
2306
2353
  ];
2307
2354
  var ExtraData = {
2308
2355
  // 문서코드
@@ -2315,28 +2362,30 @@ var ExtraData = {
2315
2362
  A0010_mysg_sign: ""
2316
2363
  },
2317
2364
  // 기타 공통으로 사용하지 않을 파라미터
2318
- extraParam: [`viewer.zoom=137`],
2319
- args: [`roleCd=11,21`, `ccc=ddd`]
2365
+ extraParam: [],
2366
+ // aaa=bbb
2367
+ args: []
2320
2368
  },
2321
2369
  A0900: {
2322
- args: [`roleCd=11,21`, `aaa=bbb`]
2370
+ args: []
2323
2371
  }
2324
2372
  };
2325
2373
  var policyNumber = "300034894";
2326
2374
  var fpInfo = { uniqNo: "2210000" };
2375
+ var roleCode = [`11`, `21`];
2327
2376
 
2328
2377
  // src/oz/hooks/use-document-info.tsx
2329
2378
  var import_react = __toESM(require_react());
2330
2379
  function useDocumentInfo(initialValue) {
2331
2380
  const [documentInfo, setDocumentInfo] = (0, import_react.useState)([...initialValue]);
2332
- const documentList = (0, import_react.useMemo)(() => documentInfo.map((i) => i.file).flat(1), [documentInfo]);
2381
+ const documentList = (0, import_react.useMemo)(() => documentInfo.map((i) => i.doc).flat(1), [documentInfo]);
2333
2382
  const documentIndexMap = documentList.reduce((acc, cur, index) => {
2334
- acc[cur] = index;
2383
+ acc[cur.docCode] = index;
2335
2384
  return acc;
2336
2385
  }, {});
2337
- const documentTemplateMap = (0, import_react.useMemo)(() => documentInfo.reduce((map, doc) => {
2338
- doc.file.forEach((file) => {
2339
- map[file] = { ...doc };
2386
+ const documentTemplateMap = (0, import_react.useMemo)(() => documentInfo.reduce((map, template) => {
2387
+ template.doc.forEach((ozdFile) => {
2388
+ map[ozdFile.docCode] = { ...template };
2340
2389
  });
2341
2390
  return map;
2342
2391
  }, {}), [documentInfo]);
@@ -2345,13 +2394,13 @@ function useDocumentInfo(initialValue) {
2345
2394
  return acc;
2346
2395
  }, {});
2347
2396
  const groupIndexes = (0, import_react.useMemo)(() => documentInfo.reduce((acc, item) => {
2348
- item.file.forEach((file) => {
2349
- const currentIndex = documentIndexMap[file];
2397
+ item.doc.forEach((ozdFile) => {
2398
+ const currentIndex = documentIndexMap[ozdFile.docCode];
2350
2399
  if (!acc[currentIndex]) {
2351
2400
  acc[currentIndex] = [];
2352
2401
  }
2353
- item.file.forEach((groupFile) => {
2354
- acc[currentIndex].push(documentIndexMap[groupFile]);
2402
+ item.doc.forEach((ozdFile2) => {
2403
+ acc[currentIndex].push(documentIndexMap[ozdFile2.docCode]);
2355
2404
  });
2356
2405
  });
2357
2406
  return acc;
@@ -2401,27 +2450,25 @@ var OZViewerEvent = /* @__PURE__ */ ((OZViewerEvent2) => {
2401
2450
  OZViewerEvent2["OZReportCreated"] = "OZReportCreated";
2402
2451
  return OZViewerEvent2;
2403
2452
  })(OZViewerEvent || {});
2453
+ var OZTriggerExternalEvent = /* @__PURE__ */ ((OZTriggerExternalEvent2) => {
2454
+ OZTriggerExternalEvent2["GetDraftData"] = "getDraftData";
2455
+ return OZTriggerExternalEvent2;
2456
+ })(OZTriggerExternalEvent || {});
2404
2457
 
2405
2458
  // src/oz/utils/common-util.ts
2406
2459
  function categorizeByPageRange(data, pageCounts) {
2407
- let pageStart = 1;
2408
- const result = [];
2460
+ let currentPage = 1;
2409
2461
  let pageIndex = 0;
2410
- data.forEach((item) => {
2411
- const startPage = pageStart;
2412
- let endPage = pageStart;
2413
- item.file.forEach(() => {
2414
- const pageCount = pageCounts[pageIndex];
2415
- const pageEnd = pageStart + pageCount - 1;
2416
- pageStart = pageEnd + 1;
2417
- pageIndex++;
2418
- endPage = pageEnd;
2419
- });
2420
- result.push({
2421
- ...item,
2422
- startPage,
2423
- endPage
2462
+ const result = DeepCopy(data);
2463
+ result.forEach((group) => {
2464
+ group.startPage = currentPage;
2465
+ group.doc.forEach((doc) => {
2466
+ const pageCount = pageCounts[pageIndex++];
2467
+ doc.startPage = currentPage;
2468
+ doc.endPage = currentPage + pageCount - 1;
2469
+ currentPage += pageCount;
2424
2470
  });
2471
+ group.endPage = group.doc[group.doc.length - 1].endPage;
2425
2472
  });
2426
2473
  return result;
2427
2474
  }
@@ -2437,10 +2484,10 @@ function extractFileName(filePath) {
2437
2484
  }
2438
2485
  function getFileListByGlobalIndex(index, data) {
2439
2486
  let currentIndex = 0;
2440
- for (const form of data) {
2441
- const fileCount = form.file.length;
2487
+ for (const template of data) {
2488
+ const fileCount = template.doc.length;
2442
2489
  if (index >= currentIndex && index < currentIndex + fileCount) {
2443
- return form;
2490
+ return template;
2444
2491
  }
2445
2492
  currentIndex += fileCount;
2446
2493
  }
@@ -2771,8 +2818,8 @@ async function SaveTotalPdf() {
2771
2818
 
2772
2819
  // src/oz/utils/bridge-util/fetch-util.ts
2773
2820
  async function fetchDocument(options) {
2774
- const { data } = await Bridge.native.downloadDocument({ data: options });
2775
- return data.map((i) => ({ ...i, startPage: 0, endPage: 0 }));
2821
+ const { data: result } = await Bridge.native.downloadDocument({ data: options, policyNumber, fpInfo });
2822
+ return result.data.map((i) => ({ ...i, startPage: 0, endPage: 0 }));
2776
2823
  }
2777
2824
  async function fetchFont() {
2778
2825
  const { data: fontMap } = await Bridge.native.getOzFontParam();
@@ -2787,12 +2834,12 @@ async function CreateOzParam(documentList, extraData = {}) {
2787
2834
  }
2788
2835
  const fontParms = await fetchFont();
2789
2836
  const connectionParams = documentList.map(
2790
- (file, idx) => idx === 0 ? `connection.openfile=${file}` : `child${idx}.connection.openfile=${file}`
2837
+ ({ filePath }, idx) => idx === 0 ? `connection.openfile=${filePath}` : `child${idx}.connection.openfile=${filePath}`
2791
2838
  );
2792
2839
  const childCount = documentList.length - 1;
2793
- const extraParams = documentList.map((file, idx) => {
2840
+ const extraParams = documentList.map((ozdFile, idx) => {
2794
2841
  const result = [];
2795
- const docCode = file.replace(/^.*[\\/]|(\.[^/.]+)$/g, "");
2842
+ const docCode = ozdFile.docCode.replace(/^.*[\\/]|(\.[^/.]+)$/g, "");
2796
2843
  const prefix = idx === 0 ? "" : `child${idx}.`;
2797
2844
  const data = extraData[docCode] || {};
2798
2845
  if (data.inputJson) {
@@ -2801,6 +2848,7 @@ async function CreateOzParam(documentList, extraData = {}) {
2801
2848
  const args = [
2802
2849
  // 모든서식에 공통으로 필요한 docCd param 추가
2803
2850
  `docCd=${docCode}`,
2851
+ `roleCd=11,28`,
2804
2852
  ...ensureArray(data.args)
2805
2853
  ];
2806
2854
  args.forEach((arg, idx2) => result.push(`${prefix}connection.args${idx2 + 1}=${arg}`));
@@ -2854,6 +2902,29 @@ async function getTotalPageOnAllDocuments(reportCount) {
2854
2902
  }
2855
2903
  return totalPages;
2856
2904
  }
2905
+
2906
+ // src/oz/utils/bridge-util/get-draft-data-util.ts
2907
+ async function getDraftDataHandler(rawOzRequest, documentIndexMap) {
2908
+ const parsedRequest = JSON.parse(rawOzRequest);
2909
+ const { docCd, ...signKeyMap } = parsedRequest;
2910
+ const documentIndex = documentIndexMap[docCd];
2911
+ if (documentIndex === void 0) {
2912
+ throw new Error(`Invalid document code: ${docCd}`);
2913
+ }
2914
+ const { data } = await Bridge.nativeOz.getInformation({ command: `INPUT_JSON_AT=${documentIndex}` });
2915
+ const documentJson = JSON.parse(data);
2916
+ const signDataMap = Object.keys(signKeyMap).reduce((acc, key) => {
2917
+ acc[key] = documentJson[key];
2918
+ return acc;
2919
+ }, {});
2920
+ return signDataMap;
2921
+ }
2922
+ async function triggerDraftDataByIndexList(indexList) {
2923
+ for (let i = 0; i < indexList.length; i++) {
2924
+ await sleep();
2925
+ await Bridge.nativeOz.triggerExternalEventByDocIndex({ param1: "getDraftData" /* GetDraftData */, docIndex: indexList[i] });
2926
+ }
2927
+ }
2857
2928
  /*! Bundled license information:
2858
2929
 
2859
2930
  react/cjs/react.production.js:
@@ -2887,6 +2958,7 @@ exports.CreateOzViewer = CreateOzViewer;
2887
2958
  exports.DownloadDocumentList = DownloadDocumentList;
2888
2959
  exports.ExtraData = ExtraData;
2889
2960
  exports.MovePage = MovePage;
2961
+ exports.OZTriggerExternalEvent = OZTriggerExternalEvent;
2890
2962
  exports.OZViewerEvent = OZViewerEvent;
2891
2963
  exports.PdfHandler = PdfHandler;
2892
2964
  exports.PromiseWithResolvers = PromiseWithResolvers;
@@ -2911,18 +2983,21 @@ exports.fetchDocument = fetchDocument;
2911
2983
  exports.fetchFont = fetchFont;
2912
2984
  exports.fpInfo = fpInfo;
2913
2985
  exports.getCurrentPage = getCurrentPage;
2986
+ exports.getDraftDataHandler = getDraftDataHandler;
2914
2987
  exports.getFileListByGlobalIndex = getFileListByGlobalIndex;
2915
2988
  exports.getReportCountMemo = getReportCountMemo;
2916
2989
  exports.getTotalPageMemo = getTotalPageMemo;
2917
2990
  exports.getTotalPageOnAllDocuments = getTotalPageOnAllDocuments;
2918
2991
  exports.isCommentMode = isCommentMode;
2919
2992
  exports.policyNumber = policyNumber;
2993
+ exports.roleCode = roleCode;
2920
2994
  exports.setCheckEform = setCheckEform;
2921
2995
  exports.setDisableCommentMode = setDisableCommentMode;
2922
2996
  exports.setEnableCommentMode = setEnableCommentMode;
2923
2997
  exports.sleep = sleep;
2924
2998
  exports.triggerClickOnAllDocuments = triggerClickOnAllDocuments;
2925
2999
  exports.triggerCropImageOnAllDocuments = triggerCropImageOnAllDocuments;
3000
+ exports.triggerDraftDataByIndexList = triggerDraftDataByIndexList;
2926
3001
  exports.useDocumentInfo = useDocumentInfo;
2927
3002
  exports.useOzEventListener = useOzEventListener;
2928
3003
  exports.validateAllPages = validateAllPages;