@apps-in-toss/web-bridge 0.0.0-dev.1758275837494 → 0.0.0-dev.1760943445541

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.
@@ -0,0 +1,33 @@
1
+ export interface AppsInTossSignTossCertParams {
2
+ txId: string;
3
+ }
4
+ /**
5
+ * @public
6
+ * @category 토스인증
7
+ * @name appsInTossSignTossCert
8
+ * @description 토스 인증서를 사용해 서명하는 기능을 제공해요. 이 함수를 사용하면 앱인토스에서 제공하는 인증서를 활용해 서명을 할 수 있어요.
9
+ *
10
+ * @param {AppsInTossSignTossCertParams} params - 서명에 필요한 파라미터를 포함하는 객체예요.
11
+ * @param {string} params.txId - 토스인증서를 사용한 본인확인이나 간편인증, 전자서명에서 사용하는 Transaction Id예요.
12
+ *
13
+ * @example
14
+ * ```tsx
15
+ * import { appsInTossSignTossCert } from '@apps-in-toss/web-framework';
16
+ *
17
+ * // 서명에 필요한 파라미터를 정의해요.
18
+ * const params = {
19
+ * txId: "f2e1a6df..."
20
+ * };
21
+ *
22
+ * appsInTossSignTossCert(params)
23
+ * .then(() => {
24
+ * console.log('서명 작업이 성공적으로 완료되었어요.');
25
+ * })
26
+ * .catch((error) => {
27
+ * console.error('서명 작업 중 에러가 발생했어요:', error);
28
+ * });
29
+ * ```
30
+ */
31
+ export declare function appsInTossSignTossCert(params: AppsInTossSignTossCertParams): Promise<void>;
32
+
33
+ export {};
package/built/bridge.d.ts CHANGED
@@ -21,6 +21,7 @@ export * from './getTossShareLink';
21
21
  export * from './setDeviceOrientation';
22
22
  export * from './checkoutPayment';
23
23
  export * from './saveBase64Data';
24
+ export * from './appsInTossSignTossCert';
24
25
  export * from './getGameCenterGameProfile';
25
26
  export * from './openGameCenterLeaderboard';
26
27
  export * from './submitGameCenterLeaderBoardScore';
package/built/bridge.js CHANGED
@@ -1 +1 @@
1
- import{createAsyncBridge,createConstantBridge,createEventBridge}from"@apps-in-toss/bridge-core";var createEvents=function(){return{emit:function emit(event,args){for(var callbacks=this.events[event]||[],i=0,length=callbacks.length;i<length;i++){callbacks[i](args)}},events:{},on:function on(event,cb){var _this=this;var _this_events,_event;((_this_events=this.events)[_event=event]||(_this_events[_event]=[])).push(cb);return function(){var _this_events_event;_this.events[event]=(_this_events_event=_this.events[event])===null||_this_events_event===void 0?void 0:_this_events_event.filter(function(i){return cb!==i})}}}};if(typeof window!=="undefined"){window.__GRANITE_NATIVE_EMITTER=createEvents()}export var closeView=createAsyncBridge("closeView");export var generateHapticFeedback=createAsyncBridge("generateHapticFeedback");export var share=createAsyncBridge("share");export var setSecureScreen=createAsyncBridge("setSecureScreen");export var setScreenAwakeMode=createAsyncBridge("setScreenAwakeMode");export var getNetworkStatus=createAsyncBridge("getNetworkStatus");export var setIosSwipeGestureEnabled=createAsyncBridge("setIosSwipeGestureEnabled");export var openURL=createAsyncBridge("openURL");export var openPermissionDialog=createAsyncBridge("openPermissionDialog");export var getPermission=createAsyncBridge("getPermission");export var requestPermission=createAsyncBridge("requestPermission");export var setClipboardText=createConstantBridge("setClipboardText");export var getClipboardText=createConstantBridge("getClipboardText");export var fetchContacts=createConstantBridge("fetchContacts");export var fetchAlbumPhotos=createConstantBridge("fetchAlbumPhotos");export var getCurrentLocation=createConstantBridge("getCurrentLocation");export var openCamera=createConstantBridge("openCamera");export var appLogin=createAsyncBridge("appLogin");export var eventLog=createAsyncBridge("eventLog");export var getTossShareLink=createAsyncBridge("getTossShareLink");export var setDeviceOrientation=createAsyncBridge("setDeviceOrientation");export var checkoutPayment=createAsyncBridge("checkoutPayment");export var saveBase64Data=createAsyncBridge("saveBase64Data");export var getGameCenterGameProfile=createAsyncBridge("getGameCenterGameProfile");export var openGameCenterLeaderboard=createAsyncBridge("openGameCenterLeaderboard");export var submitGameCenterLeaderBoardScore=createAsyncBridge("submitGameCenterLeaderBoardScore");export var getLocale=createConstantBridge("getLocale");export var getSchemeUri=createConstantBridge("getSchemeUri");export var getPlatformOS=createConstantBridge("getPlatformOS");export var getOperationalEnvironment=createConstantBridge("getOperationalEnvironment");export var getTossAppVersion=createConstantBridge("getTossAppVersion");export var getDeviceId=createConstantBridge("getDeviceId");export var contactsViral=createEventBridge("contactsViral");export var startUpdateLocation=createEventBridge("startUpdateLocation");export var onVisibilityChangedByTransparentServiceWeb=createEventBridge("onVisibilityChangedByTransparentServiceWeb");
1
+ import{createAsyncBridge,createConstantBridge,createEventBridge}from"@apps-in-toss/bridge-core";var createEvents=function(){return{emit:function emit(event,args){for(var callbacks=this.events[event]||[],i=0,length=callbacks.length;i<length;i++){callbacks[i](args)}},events:{},on:function on(event,cb){var _this=this;var _this_events,_event;((_this_events=this.events)[_event=event]||(_this_events[_event]=[])).push(cb);return function(){var _this_events_event;_this.events[event]=(_this_events_event=_this.events[event])===null||_this_events_event===void 0?void 0:_this_events_event.filter(function(i){return cb!==i})}}}};if(typeof window!=="undefined"){window.__GRANITE_NATIVE_EMITTER=createEvents()}export var closeView=createAsyncBridge("closeView");export var generateHapticFeedback=createAsyncBridge("generateHapticFeedback");export var share=createAsyncBridge("share");export var setSecureScreen=createAsyncBridge("setSecureScreen");export var setScreenAwakeMode=createAsyncBridge("setScreenAwakeMode");export var getNetworkStatus=createAsyncBridge("getNetworkStatus");export var setIosSwipeGestureEnabled=createAsyncBridge("setIosSwipeGestureEnabled");export var openURL=createAsyncBridge("openURL");export var openPermissionDialog=createAsyncBridge("openPermissionDialog");export var getPermission=createAsyncBridge("getPermission");export var requestPermission=createAsyncBridge("requestPermission");export var setClipboardText=createConstantBridge("setClipboardText");export var getClipboardText=createConstantBridge("getClipboardText");export var fetchContacts=createConstantBridge("fetchContacts");export var fetchAlbumPhotos=createConstantBridge("fetchAlbumPhotos");export var getCurrentLocation=createConstantBridge("getCurrentLocation");export var openCamera=createConstantBridge("openCamera");export var appLogin=createAsyncBridge("appLogin");export var eventLog=createAsyncBridge("eventLog");export var getTossShareLink=createAsyncBridge("getTossShareLink");export var setDeviceOrientation=createAsyncBridge("setDeviceOrientation");export var checkoutPayment=createAsyncBridge("checkoutPayment");export var saveBase64Data=createAsyncBridge("saveBase64Data");export var appsInTossSignTossCert=createAsyncBridge("appsInTossSignTossCert");export var getGameCenterGameProfile=createAsyncBridge("getGameCenterGameProfile");export var openGameCenterLeaderboard=createAsyncBridge("openGameCenterLeaderboard");export var submitGameCenterLeaderBoardScore=createAsyncBridge("submitGameCenterLeaderBoardScore");export var getLocale=createConstantBridge("getLocale");export var getSchemeUri=createConstantBridge("getSchemeUri");export var getPlatformOS=createConstantBridge("getPlatformOS");export var getOperationalEnvironment=createConstantBridge("getOperationalEnvironment");export var getTossAppVersion=createConstantBridge("getTossAppVersion");export var getDeviceId=createConstantBridge("getDeviceId");export var contactsViral=createEventBridge("contactsViral");export var startUpdateLocation=createEventBridge("startUpdateLocation");export var onVisibilityChangedByTransparentServiceWeb=createEventBridge("onVisibilityChangedByTransparentServiceWeb");
package/built/index.cjs CHANGED
@@ -247,7 +247,7 @@ var IAP = {
247
247
  return noop;
248
248
  }
249
249
  const isProcessProductGrantSupported = isMinVersionSupported({
250
- android: "5.230.0",
250
+ android: "5.231.1",
251
251
  ios: "5.230.0"
252
252
  });
253
253
  const { options, onEvent, onError } = params;
@@ -297,7 +297,76 @@ var IAP = {
297
297
  * @description 인앱결제로 구매할 수 있는 상품 목록을 가져와요. 상품 목록 화면에 진입할 때 호출해요.
298
298
  * @returns {Promise<{ products: IapProductListItem[] } | undefined>} 상품 목록을 포함한 객체를 반환해요. 앱 버전이 최소 지원 버전(안드로이드 5.219.0, iOS 5.219.0)보다 낮으면 `undefined`를 반환해요.
299
299
  */
300
- getProductItemList: (0, import_bridge_core3.createAsyncBridge)("iapGetProductItemList")
300
+ getProductItemList: (0, import_bridge_core3.createAsyncBridge)("iapGetProductItemList"),
301
+ /**
302
+ * @public
303
+ * @category 인앱결제
304
+ * @name getPendingOrders
305
+ * @description 대기 중인 주문 목록을 가져와요. 이 함수를 사용하면 결제가 아직 완료되지 않은 주문 정보를 확인할 수 있어요.
306
+ * @returns {Promise<{orderIds: string[]}}>} 대기 중인 주문ID 배열을 반환해요. 앱 버전이 최소 지원 버전(안드로이드 5.231.0, iOS 5.231.0)보다 낮으면 `undefined`를 반환해요.
307
+ *
308
+ * @example
309
+ * ### 대기 중인 주문 목록 가져오기
310
+ * ```typescript
311
+ * import { IAP } from '@apps-in-toss/web-framework';
312
+ *
313
+ * async function fetchOrders() {
314
+ * try {
315
+ * const pendingOrders = await IAP.getPendingOrders();
316
+ * return pendingOrders;
317
+ * } catch (error) {
318
+ * console.error(error);
319
+ * }
320
+ * }
321
+ * ```
322
+ */
323
+ getPendingOrders: (0, import_bridge_core3.createAsyncBridge)("getPendingOrders"),
324
+ /**
325
+ * @public
326
+ * @category 인앱결제
327
+ * @name getCompletedOrRefundedOrders
328
+ * @description 인앱결제로 구매하거나 환불한 주문 목록을 가져와요.
329
+ * @returns {Promise<CompletedOrRefundedOrdersResult>} 페이지네이션을 포함한 주문 목록 객체를 반환해요. 앱 버전이 최소 지원 버전(안드로이드 5.231.0, iOS 5.231.0)보다 낮으면 `undefined`를 반환해요.
330
+ *
331
+ * @example
332
+ * ```typescript
333
+ * import { IAP } from "@apps-in-toss/web-framework";
334
+ *
335
+ * async function fetchOrders() {
336
+ * try {
337
+ * const response = await IAP.getCompletedOrRefundedOrders();
338
+ * return response;
339
+ * } catch (error) {
340
+ * console.error(error);
341
+ * }
342
+ * }
343
+ * ```
344
+ */
345
+ getCompletedOrRefundedOrders: (0, import_bridge_core3.createAsyncBridge)("getCompletedOrRefundedOrders"),
346
+ /**
347
+ * @public
348
+ * @category 인앱결제
349
+ * @name completeProductGrant
350
+ * @description 상품 지급 처리를 완료했다는 메시지를 앱에 전달해요. 이 함수를 사용하면 결제가 완료된 주문의 상품 지급이 정상적으로 완료되었음을 알릴 수 있어요.
351
+ * @param {{ params: { orderId: string } }} params 결제가 완료된 주문 정보를 담은 객체예요.
352
+ * @param {string} params.orderId 주문의 고유 ID예요. 상품 지급을 완료할 주문을 지정할 때 사용해요.
353
+ * @returns {Promise<boolean>} 상품 지급이 완료됐는지 여부를 반환해요. 앱 버전이 최소 지원 버전(안드로이드 5.233.0, iOS 5.233.0)보다 낮으면 `undefined`를 반환해요.
354
+ *
355
+ * @example
356
+ * ### 결제를 성공한 뒤 상품을 지급하는 예시
357
+ * ```typescript
358
+ * import { IAP } from '@apps-in-toss/web-framework';
359
+ *
360
+ * async function handleGrantProduct(orderId: string) {
361
+ * try {
362
+ * await IAP.completeProductGrant({ params: { orderId } });
363
+ * } catch (error) {
364
+ * console.error(error);
365
+ * }
366
+ * }
367
+ * ```
368
+ */
369
+ completeProductGrant: (0, import_bridge_core3.createAsyncBridge)("completeProductGrant")
301
370
  };
302
371
 
303
372
  // src/getSafeAreaInsets.ts
package/built/index.d.cts CHANGED
@@ -158,13 +158,39 @@ interface IapProductListItem {
158
158
  iconUrl: string;
159
159
  description: string;
160
160
  }
161
+ /**
162
+ * @public
163
+ * @category 인앱결제
164
+ * @name CompletedOrRefundedOrdersResult
165
+ * @description 인앱결제로 구매하거나 환불한 주문 목록을 나타내는 객체예요. 페이지네이션 정보를 포함해요.
166
+ * @property {boolean} hasNext 다음 페이지가 있는지 여부예요. `true`면 더 많은 주문이 남아 있어요.
167
+ * @property {string | null} [nextKey] 다음 주문 목록을 조회할 때 사용할 키예요. 마지막 페이지라면 `null`이거나 생략될 수 있어요.
168
+ * @property {Array} orders 주문 정보를 담은 배열이에요. 각 요소는 하나의 주문을 나타내요.
169
+ * @property {string} orders[].orderId 주문의 고유 ID예요.
170
+ * @property {string} orders[].sku 주문 상품의 고유 ID예요.
171
+ * @property {'COMPLETED' | 'REFUNDED'} orders[].status 주문의 상태예요. 'COMPLETED'는 주문이 완료된 상태, 'REFUNDED'는 환불된 상태를 의미해요.
172
+ * @property {string} orders[].date 주문의 날짜 정보예요. ISO 8601 형식(YYYY-MM-DDTHH:mm:ss)을 사용해요. 예를 들어 "2025-09-22T00:00:00" 형식으로 제공돼요. 주문 상태가 `COMPLETED`라면 주문한 날짜를, `REFUNDED`라면 환불한 날짜를 나타내요.
173
+ */
174
+ interface CompletedOrRefundedOrdersResult {
175
+ hasNext: boolean;
176
+ nextKey?: string | null;
177
+ orders: {
178
+ orderId: string;
179
+ sku: string;
180
+ status: 'COMPLETED' | 'REFUNDED';
181
+ date: string;
182
+ }[];
183
+ }
161
184
  /**
162
185
  * @public
163
186
  * @category 인앱결제
164
187
  * @name IAP
165
188
  * @description 인앱결제 관련 기능을 모은 객체예요. 단건 인앱결제 주문서 이동과 상품 목록 조회 기능을 제공해요.
166
- * @property {typeof createOneTimePurchaseOrder} [createOneTimePurchaseOrder] 특정 인앱결제 주문서 페이지로 이동해요. 자세한 내용은 [createOneTimePurchaseOrder](https://developers-apps-in-toss.toss.im/bedrock/reference/framework/%EC%9D%B8%EC%95%B1%20%EA%B2%B0%EC%A0%9C/getProductItemList.html) 문서를 참고하세요.
167
- * @property {typeof getProductItemList} [getProductItemList] 인앱결제로 구매할 수 있는 상품 목록을 가져와요. 자세한 내용은 [getProductItemList](https://developers-apps-in-toss.toss.im/bedrock/reference/framework/%EC%9D%B8%EC%95%B1%20%EA%B2%B0%EC%A0%9C/createOneTimePurchaseOrder.html) 문서를 참고하세요.
189
+ * @property {typeof createOneTimePurchaseOrder} [createOneTimePurchaseOrder] 특정 인앱결제 주문서 페이지로 이동해요. 자세한 내용은 [createOneTimePurchaseOrder](https://developers-apps-in-toss.toss.im/bedrock/reference/framework/%EC%9D%B8%EC%95%B1%20%EA%B2%B0%EC%A0%9C/createOneTimePurchaseOrder.html) 문서를 참고하세요.
190
+ * @property {typeof getProductItemList} [getProductItemList] 인앱결제로 구매할 수 있는 상품 목록을 가져와요. 자세한 내용은 [getProductItemList](https://developers-apps-in-toss.toss.im/bedrock/reference/framework/%EC%9D%B8%EC%95%B1%20%EA%B2%B0%EC%A0%9C/getProductItemList.html) 문서를 참고하세요.
191
+ * @property {typeof getPendingOrders} [getPendingOrders] 대기 중인 주문 목록을 가져와요. 자세한 내용은 [getPendingOrders](https://developers-apps-in-toss.toss.im/bedrock/reference/framework/%EC%9D%B8%EC%95%B1%20%EA%B2%B0%EC%A0%9C/getPendingOrders.htm) 문서를 참고하세요.
192
+ * @property {typeof getCompletedOrRefundedOrders} [getCompletedOrRefundedOrders] 인앱결제로 구매하거나 환불한 주문 목록을 가져와요. 자세한 내용은 [getCompletedOrRefundedOrders](https://developers-apps-in-toss.toss.im/bedrock/reference/framework/%EC%9D%B8%EC%95%B1%20%EA%B2%B0%EC%A0%9C/getCompletedOrRefundedOrders.html) 문서를 참고하세요.
193
+ * @property {typeof completeProductGrant} [completeProductGrant] 상품 지급 처리를 완료했다는 메시지를 앱에 전달해요. 자세한 내용은 [completeProductGrant](https://developers-apps-in-toss.toss.im/bedrock/reference/framework/%EC%9D%B8%EC%95%B1%20%EA%B2%B0%EC%A0%9C/completeProductGrant.html) 문서를 참고하세요.
168
194
  */
169
195
  declare const IAP: {
170
196
  /**
@@ -199,6 +225,81 @@ declare const IAP: {
199
225
  getProductItemList: () => Promise<{
200
226
  products: IapProductListItem[];
201
227
  }>;
228
+ /**
229
+ * @public
230
+ * @category 인앱결제
231
+ * @name getPendingOrders
232
+ * @description 대기 중인 주문 목록을 가져와요. 이 함수를 사용하면 결제가 아직 완료되지 않은 주문 정보를 확인할 수 있어요.
233
+ * @returns {Promise<{orderIds: string[]}}>} 대기 중인 주문ID 배열을 반환해요. 앱 버전이 최소 지원 버전(안드로이드 5.231.0, iOS 5.231.0)보다 낮으면 `undefined`를 반환해요.
234
+ *
235
+ * @example
236
+ * ### 대기 중인 주문 목록 가져오기
237
+ * ```typescript
238
+ * import { IAP } from '@apps-in-toss/web-framework';
239
+ *
240
+ * async function fetchOrders() {
241
+ * try {
242
+ * const pendingOrders = await IAP.getPendingOrders();
243
+ * return pendingOrders;
244
+ * } catch (error) {
245
+ * console.error(error);
246
+ * }
247
+ * }
248
+ * ```
249
+ */
250
+ getPendingOrders: () => Promise<{
251
+ orderIds: string[];
252
+ }>;
253
+ /**
254
+ * @public
255
+ * @category 인앱결제
256
+ * @name getCompletedOrRefundedOrders
257
+ * @description 인앱결제로 구매하거나 환불한 주문 목록을 가져와요.
258
+ * @returns {Promise<CompletedOrRefundedOrdersResult>} 페이지네이션을 포함한 주문 목록 객체를 반환해요. 앱 버전이 최소 지원 버전(안드로이드 5.231.0, iOS 5.231.0)보다 낮으면 `undefined`를 반환해요.
259
+ *
260
+ * @example
261
+ * ```typescript
262
+ * import { IAP } from "@apps-in-toss/web-framework";
263
+ *
264
+ * async function fetchOrders() {
265
+ * try {
266
+ * const response = await IAP.getCompletedOrRefundedOrders();
267
+ * return response;
268
+ * } catch (error) {
269
+ * console.error(error);
270
+ * }
271
+ * }
272
+ * ```
273
+ */
274
+ getCompletedOrRefundedOrders: () => Promise<CompletedOrRefundedOrdersResult>;
275
+ /**
276
+ * @public
277
+ * @category 인앱결제
278
+ * @name completeProductGrant
279
+ * @description 상품 지급 처리를 완료했다는 메시지를 앱에 전달해요. 이 함수를 사용하면 결제가 완료된 주문의 상품 지급이 정상적으로 완료되었음을 알릴 수 있어요.
280
+ * @param {{ params: { orderId: string } }} params 결제가 완료된 주문 정보를 담은 객체예요.
281
+ * @param {string} params.orderId 주문의 고유 ID예요. 상품 지급을 완료할 주문을 지정할 때 사용해요.
282
+ * @returns {Promise<boolean>} 상품 지급이 완료됐는지 여부를 반환해요. 앱 버전이 최소 지원 버전(안드로이드 5.233.0, iOS 5.233.0)보다 낮으면 `undefined`를 반환해요.
283
+ *
284
+ * @example
285
+ * ### 결제를 성공한 뒤 상품을 지급하는 예시
286
+ * ```typescript
287
+ * import { IAP } from '@apps-in-toss/web-framework';
288
+ *
289
+ * async function handleGrantProduct(orderId: string) {
290
+ * try {
291
+ * await IAP.completeProductGrant({ params: { orderId } });
292
+ * } catch (error) {
293
+ * console.error(error);
294
+ * }
295
+ * }
296
+ * ```
297
+ */
298
+ completeProductGrant: (args_0: {
299
+ params: {
300
+ orderId: string;
301
+ };
302
+ }) => Promise<boolean>;
202
303
  };
203
304
 
204
305
  declare function getSafeAreaInsets(): {
@@ -818,4 +919,4 @@ declare const startUpdateLocation: {
818
919
  openPermissionDialog(): Promise<"denied" | "allowed">;
819
920
  };
820
921
 
821
- export { type AddAccessoryButtonOptions, type AppsInTossEvent, type AppsInTossGlobals, GoogleAdMob, type GraniteEvent, IAP, type IapCreateOneTimePurchaseOrderOptions, type IapProductListItem, Storage, type TdsEvent, appsInTossEvent, env, fetchAlbumPhotos, fetchContacts, getAppsInTossGlobals, getClipboardText, getCurrentLocation, getSafeAreaInsets, graniteEvent, isMinVersionSupported, openCamera, partner, setClipboardText, startUpdateLocation, tdsEvent };
922
+ export { type AddAccessoryButtonOptions, type AppsInTossEvent, type AppsInTossGlobals, type CompletedOrRefundedOrdersResult, GoogleAdMob, type GraniteEvent, IAP, type IapCreateOneTimePurchaseOrderOptions, type IapProductListItem, Storage, type TdsEvent, appsInTossEvent, env, fetchAlbumPhotos, fetchContacts, getAppsInTossGlobals, getClipboardText, getCurrentLocation, getSafeAreaInsets, graniteEvent, isMinVersionSupported, openCamera, partner, setClipboardText, startUpdateLocation, tdsEvent };
package/built/index.d.ts CHANGED
@@ -158,13 +158,39 @@ interface IapProductListItem {
158
158
  iconUrl: string;
159
159
  description: string;
160
160
  }
161
+ /**
162
+ * @public
163
+ * @category 인앱결제
164
+ * @name CompletedOrRefundedOrdersResult
165
+ * @description 인앱결제로 구매하거나 환불한 주문 목록을 나타내는 객체예요. 페이지네이션 정보를 포함해요.
166
+ * @property {boolean} hasNext 다음 페이지가 있는지 여부예요. `true`면 더 많은 주문이 남아 있어요.
167
+ * @property {string | null} [nextKey] 다음 주문 목록을 조회할 때 사용할 키예요. 마지막 페이지라면 `null`이거나 생략될 수 있어요.
168
+ * @property {Array} orders 주문 정보를 담은 배열이에요. 각 요소는 하나의 주문을 나타내요.
169
+ * @property {string} orders[].orderId 주문의 고유 ID예요.
170
+ * @property {string} orders[].sku 주문 상품의 고유 ID예요.
171
+ * @property {'COMPLETED' | 'REFUNDED'} orders[].status 주문의 상태예요. 'COMPLETED'는 주문이 완료된 상태, 'REFUNDED'는 환불된 상태를 의미해요.
172
+ * @property {string} orders[].date 주문의 날짜 정보예요. ISO 8601 형식(YYYY-MM-DDTHH:mm:ss)을 사용해요. 예를 들어 "2025-09-22T00:00:00" 형식으로 제공돼요. 주문 상태가 `COMPLETED`라면 주문한 날짜를, `REFUNDED`라면 환불한 날짜를 나타내요.
173
+ */
174
+ interface CompletedOrRefundedOrdersResult {
175
+ hasNext: boolean;
176
+ nextKey?: string | null;
177
+ orders: {
178
+ orderId: string;
179
+ sku: string;
180
+ status: 'COMPLETED' | 'REFUNDED';
181
+ date: string;
182
+ }[];
183
+ }
161
184
  /**
162
185
  * @public
163
186
  * @category 인앱결제
164
187
  * @name IAP
165
188
  * @description 인앱결제 관련 기능을 모은 객체예요. 단건 인앱결제 주문서 이동과 상품 목록 조회 기능을 제공해요.
166
- * @property {typeof createOneTimePurchaseOrder} [createOneTimePurchaseOrder] 특정 인앱결제 주문서 페이지로 이동해요. 자세한 내용은 [createOneTimePurchaseOrder](https://developers-apps-in-toss.toss.im/bedrock/reference/framework/%EC%9D%B8%EC%95%B1%20%EA%B2%B0%EC%A0%9C/getProductItemList.html) 문서를 참고하세요.
167
- * @property {typeof getProductItemList} [getProductItemList] 인앱결제로 구매할 수 있는 상품 목록을 가져와요. 자세한 내용은 [getProductItemList](https://developers-apps-in-toss.toss.im/bedrock/reference/framework/%EC%9D%B8%EC%95%B1%20%EA%B2%B0%EC%A0%9C/createOneTimePurchaseOrder.html) 문서를 참고하세요.
189
+ * @property {typeof createOneTimePurchaseOrder} [createOneTimePurchaseOrder] 특정 인앱결제 주문서 페이지로 이동해요. 자세한 내용은 [createOneTimePurchaseOrder](https://developers-apps-in-toss.toss.im/bedrock/reference/framework/%EC%9D%B8%EC%95%B1%20%EA%B2%B0%EC%A0%9C/createOneTimePurchaseOrder.html) 문서를 참고하세요.
190
+ * @property {typeof getProductItemList} [getProductItemList] 인앱결제로 구매할 수 있는 상품 목록을 가져와요. 자세한 내용은 [getProductItemList](https://developers-apps-in-toss.toss.im/bedrock/reference/framework/%EC%9D%B8%EC%95%B1%20%EA%B2%B0%EC%A0%9C/getProductItemList.html) 문서를 참고하세요.
191
+ * @property {typeof getPendingOrders} [getPendingOrders] 대기 중인 주문 목록을 가져와요. 자세한 내용은 [getPendingOrders](https://developers-apps-in-toss.toss.im/bedrock/reference/framework/%EC%9D%B8%EC%95%B1%20%EA%B2%B0%EC%A0%9C/getPendingOrders.htm) 문서를 참고하세요.
192
+ * @property {typeof getCompletedOrRefundedOrders} [getCompletedOrRefundedOrders] 인앱결제로 구매하거나 환불한 주문 목록을 가져와요. 자세한 내용은 [getCompletedOrRefundedOrders](https://developers-apps-in-toss.toss.im/bedrock/reference/framework/%EC%9D%B8%EC%95%B1%20%EA%B2%B0%EC%A0%9C/getCompletedOrRefundedOrders.html) 문서를 참고하세요.
193
+ * @property {typeof completeProductGrant} [completeProductGrant] 상품 지급 처리를 완료했다는 메시지를 앱에 전달해요. 자세한 내용은 [completeProductGrant](https://developers-apps-in-toss.toss.im/bedrock/reference/framework/%EC%9D%B8%EC%95%B1%20%EA%B2%B0%EC%A0%9C/completeProductGrant.html) 문서를 참고하세요.
168
194
  */
169
195
  declare const IAP: {
170
196
  /**
@@ -199,6 +225,81 @@ declare const IAP: {
199
225
  getProductItemList: () => Promise<{
200
226
  products: IapProductListItem[];
201
227
  }>;
228
+ /**
229
+ * @public
230
+ * @category 인앱결제
231
+ * @name getPendingOrders
232
+ * @description 대기 중인 주문 목록을 가져와요. 이 함수를 사용하면 결제가 아직 완료되지 않은 주문 정보를 확인할 수 있어요.
233
+ * @returns {Promise<{orderIds: string[]}}>} 대기 중인 주문ID 배열을 반환해요. 앱 버전이 최소 지원 버전(안드로이드 5.231.0, iOS 5.231.0)보다 낮으면 `undefined`를 반환해요.
234
+ *
235
+ * @example
236
+ * ### 대기 중인 주문 목록 가져오기
237
+ * ```typescript
238
+ * import { IAP } from '@apps-in-toss/web-framework';
239
+ *
240
+ * async function fetchOrders() {
241
+ * try {
242
+ * const pendingOrders = await IAP.getPendingOrders();
243
+ * return pendingOrders;
244
+ * } catch (error) {
245
+ * console.error(error);
246
+ * }
247
+ * }
248
+ * ```
249
+ */
250
+ getPendingOrders: () => Promise<{
251
+ orderIds: string[];
252
+ }>;
253
+ /**
254
+ * @public
255
+ * @category 인앱결제
256
+ * @name getCompletedOrRefundedOrders
257
+ * @description 인앱결제로 구매하거나 환불한 주문 목록을 가져와요.
258
+ * @returns {Promise<CompletedOrRefundedOrdersResult>} 페이지네이션을 포함한 주문 목록 객체를 반환해요. 앱 버전이 최소 지원 버전(안드로이드 5.231.0, iOS 5.231.0)보다 낮으면 `undefined`를 반환해요.
259
+ *
260
+ * @example
261
+ * ```typescript
262
+ * import { IAP } from "@apps-in-toss/web-framework";
263
+ *
264
+ * async function fetchOrders() {
265
+ * try {
266
+ * const response = await IAP.getCompletedOrRefundedOrders();
267
+ * return response;
268
+ * } catch (error) {
269
+ * console.error(error);
270
+ * }
271
+ * }
272
+ * ```
273
+ */
274
+ getCompletedOrRefundedOrders: () => Promise<CompletedOrRefundedOrdersResult>;
275
+ /**
276
+ * @public
277
+ * @category 인앱결제
278
+ * @name completeProductGrant
279
+ * @description 상품 지급 처리를 완료했다는 메시지를 앱에 전달해요. 이 함수를 사용하면 결제가 완료된 주문의 상품 지급이 정상적으로 완료되었음을 알릴 수 있어요.
280
+ * @param {{ params: { orderId: string } }} params 결제가 완료된 주문 정보를 담은 객체예요.
281
+ * @param {string} params.orderId 주문의 고유 ID예요. 상품 지급을 완료할 주문을 지정할 때 사용해요.
282
+ * @returns {Promise<boolean>} 상품 지급이 완료됐는지 여부를 반환해요. 앱 버전이 최소 지원 버전(안드로이드 5.233.0, iOS 5.233.0)보다 낮으면 `undefined`를 반환해요.
283
+ *
284
+ * @example
285
+ * ### 결제를 성공한 뒤 상품을 지급하는 예시
286
+ * ```typescript
287
+ * import { IAP } from '@apps-in-toss/web-framework';
288
+ *
289
+ * async function handleGrantProduct(orderId: string) {
290
+ * try {
291
+ * await IAP.completeProductGrant({ params: { orderId } });
292
+ * } catch (error) {
293
+ * console.error(error);
294
+ * }
295
+ * }
296
+ * ```
297
+ */
298
+ completeProductGrant: (args_0: {
299
+ params: {
300
+ orderId: string;
301
+ };
302
+ }) => Promise<boolean>;
202
303
  };
203
304
 
204
305
  declare function getSafeAreaInsets(): {
@@ -818,4 +919,4 @@ declare const startUpdateLocation: {
818
919
  openPermissionDialog(): Promise<"denied" | "allowed">;
819
920
  };
820
921
 
821
- export { type AddAccessoryButtonOptions, type AppsInTossEvent, type AppsInTossGlobals, GoogleAdMob, type GraniteEvent, IAP, type IapCreateOneTimePurchaseOrderOptions, type IapProductListItem, Storage, type TdsEvent, appsInTossEvent, env, fetchAlbumPhotos, fetchContacts, getAppsInTossGlobals, getClipboardText, getCurrentLocation, getSafeAreaInsets, graniteEvent, isMinVersionSupported, openCamera, partner, setClipboardText, startUpdateLocation, tdsEvent };
922
+ export { type AddAccessoryButtonOptions, type AppsInTossEvent, type AppsInTossGlobals, type CompletedOrRefundedOrdersResult, GoogleAdMob, type GraniteEvent, IAP, type IapCreateOneTimePurchaseOrderOptions, type IapProductListItem, Storage, type TdsEvent, appsInTossEvent, env, fetchAlbumPhotos, fetchContacts, getAppsInTossGlobals, getClipboardText, getCurrentLocation, getSafeAreaInsets, graniteEvent, isMinVersionSupported, openCamera, partner, setClipboardText, startUpdateLocation, tdsEvent };
package/built/index.js CHANGED
@@ -206,7 +206,7 @@ var IAP = {
206
206
  return noop;
207
207
  }
208
208
  const isProcessProductGrantSupported = isMinVersionSupported({
209
- android: "5.230.0",
209
+ android: "5.231.1",
210
210
  ios: "5.230.0"
211
211
  });
212
212
  const { options, onEvent, onError } = params;
@@ -256,7 +256,76 @@ var IAP = {
256
256
  * @description 인앱결제로 구매할 수 있는 상품 목록을 가져와요. 상품 목록 화면에 진입할 때 호출해요.
257
257
  * @returns {Promise<{ products: IapProductListItem[] } | undefined>} 상품 목록을 포함한 객체를 반환해요. 앱 버전이 최소 지원 버전(안드로이드 5.219.0, iOS 5.219.0)보다 낮으면 `undefined`를 반환해요.
258
258
  */
259
- getProductItemList: createAsyncBridge2("iapGetProductItemList")
259
+ getProductItemList: createAsyncBridge2("iapGetProductItemList"),
260
+ /**
261
+ * @public
262
+ * @category 인앱결제
263
+ * @name getPendingOrders
264
+ * @description 대기 중인 주문 목록을 가져와요. 이 함수를 사용하면 결제가 아직 완료되지 않은 주문 정보를 확인할 수 있어요.
265
+ * @returns {Promise<{orderIds: string[]}}>} 대기 중인 주문ID 배열을 반환해요. 앱 버전이 최소 지원 버전(안드로이드 5.231.0, iOS 5.231.0)보다 낮으면 `undefined`를 반환해요.
266
+ *
267
+ * @example
268
+ * ### 대기 중인 주문 목록 가져오기
269
+ * ```typescript
270
+ * import { IAP } from '@apps-in-toss/web-framework';
271
+ *
272
+ * async function fetchOrders() {
273
+ * try {
274
+ * const pendingOrders = await IAP.getPendingOrders();
275
+ * return pendingOrders;
276
+ * } catch (error) {
277
+ * console.error(error);
278
+ * }
279
+ * }
280
+ * ```
281
+ */
282
+ getPendingOrders: createAsyncBridge2("getPendingOrders"),
283
+ /**
284
+ * @public
285
+ * @category 인앱결제
286
+ * @name getCompletedOrRefundedOrders
287
+ * @description 인앱결제로 구매하거나 환불한 주문 목록을 가져와요.
288
+ * @returns {Promise<CompletedOrRefundedOrdersResult>} 페이지네이션을 포함한 주문 목록 객체를 반환해요. 앱 버전이 최소 지원 버전(안드로이드 5.231.0, iOS 5.231.0)보다 낮으면 `undefined`를 반환해요.
289
+ *
290
+ * @example
291
+ * ```typescript
292
+ * import { IAP } from "@apps-in-toss/web-framework";
293
+ *
294
+ * async function fetchOrders() {
295
+ * try {
296
+ * const response = await IAP.getCompletedOrRefundedOrders();
297
+ * return response;
298
+ * } catch (error) {
299
+ * console.error(error);
300
+ * }
301
+ * }
302
+ * ```
303
+ */
304
+ getCompletedOrRefundedOrders: createAsyncBridge2("getCompletedOrRefundedOrders"),
305
+ /**
306
+ * @public
307
+ * @category 인앱결제
308
+ * @name completeProductGrant
309
+ * @description 상품 지급 처리를 완료했다는 메시지를 앱에 전달해요. 이 함수를 사용하면 결제가 완료된 주문의 상품 지급이 정상적으로 완료되었음을 알릴 수 있어요.
310
+ * @param {{ params: { orderId: string } }} params 결제가 완료된 주문 정보를 담은 객체예요.
311
+ * @param {string} params.orderId 주문의 고유 ID예요. 상품 지급을 완료할 주문을 지정할 때 사용해요.
312
+ * @returns {Promise<boolean>} 상품 지급이 완료됐는지 여부를 반환해요. 앱 버전이 최소 지원 버전(안드로이드 5.233.0, iOS 5.233.0)보다 낮으면 `undefined`를 반환해요.
313
+ *
314
+ * @example
315
+ * ### 결제를 성공한 뒤 상품을 지급하는 예시
316
+ * ```typescript
317
+ * import { IAP } from '@apps-in-toss/web-framework';
318
+ *
319
+ * async function handleGrantProduct(orderId: string) {
320
+ * try {
321
+ * await IAP.completeProductGrant({ params: { orderId } });
322
+ * } catch (error) {
323
+ * console.error(error);
324
+ * }
325
+ * }
326
+ * ```
327
+ */
328
+ completeProductGrant: createAsyncBridge2("completeProductGrant")
260
329
  };
261
330
 
262
331
  // src/getSafeAreaInsets.ts
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@apps-in-toss/web-bridge",
3
3
  "type": "module",
4
- "version": "0.0.0-dev.1758275837494",
4
+ "version": "0.0.0-dev.1760943445541",
5
5
  "description": "Web Bridge for Apps In Toss",
6
6
  "scripts": {
7
7
  "prepack": "yarn build",
@@ -28,11 +28,11 @@
28
28
  "built"
29
29
  ],
30
30
  "dependencies": {
31
- "@apps-in-toss/types": "0.0.0-dev.1758275837494"
31
+ "@apps-in-toss/types": "0.0.0-dev.1760943445541"
32
32
  },
33
33
  "devDependencies": {
34
- "@apps-in-toss/bridge-core": "0.0.0-dev.1758275837494",
35
- "@apps-in-toss/framework": "0.0.0-dev.1758275837494",
34
+ "@apps-in-toss/bridge-core": "0.0.0-dev.1760943445541",
35
+ "@apps-in-toss/framework": "0.0.0-dev.1760943445541",
36
36
  "@swc/core": "^1.12.7",
37
37
  "picocolors": "^1.1.1",
38
38
  "ts-morph": "^26.0.0",
@@ -46,5 +46,5 @@
46
46
  "publishConfig": {
47
47
  "access": "public"
48
48
  },
49
- "gitHead": "b68a923a00c75af3ca66633e450370f20f025a34"
49
+ "gitHead": "cf764d154652145c36b92690deab07ecc6eff18d"
50
50
  }