@apps-in-toss/web-framework 0.0.13 → 0.0.14
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/cli/index.js +17 -11
- package/dist/prebuilt/dev.android.js +121 -73
- package/dist/prebuilt/dev.ios.js +121 -73
- package/dist/prebuilt/prod.android.js +1 -1
- package/dist/prebuilt/prod.ios.js +1 -1
- package/dist/prebuilt/prod.json +4 -4
- package/{src-web/index.d.ts → dist-web/bridge.d.ts} +2 -0
- package/{src-web/index.js → dist-web/bridge.js} +1 -1
- package/dist-web/checkoutPayment.d.ts +125 -0
- package/dist-web/executePayment.d.ts +266 -0
- package/dist-web/index.d.ts +70 -0
- package/dist-web/index.js +144 -0
- package/package.json +9 -9
- /package/{src-web → dist-web}/appLogin.d.ts +0 -0
- /package/{src-web → dist-web}/closeView.d.ts +0 -0
- /package/{src-web → dist-web}/fetchAlbumPhotos.d.ts +0 -0
- /package/{src-web → dist-web}/fetchContacts.d.ts +0 -0
- /package/{src-web → dist-web}/generateHapticFeedback.d.ts +0 -0
- /package/{src-web → dist-web}/getClipboardText.d.ts +0 -0
- /package/{src-web → dist-web}/getCurrentLocation.d.ts +0 -0
- /package/{src-web → dist-web}/getDeviceId.d.ts +0 -0
- /package/{src-web → dist-web}/getLocale.d.ts +0 -0
- /package/{src-web → dist-web}/getNetworkStatus.d.ts +0 -0
- /package/{src-web → dist-web}/getOperationalEnvironment.d.ts +0 -0
- /package/{src-web → dist-web}/getPlatformOS.d.ts +0 -0
- /package/{src-web → dist-web}/getSchemeUri.d.ts +0 -0
- /package/{src-web → dist-web}/openCamera.d.ts +0 -0
- /package/{src-web → dist-web}/setClipboardText.d.ts +0 -0
- /package/{src-web → dist-web}/setScreenAwakeMode.d.ts +0 -0
- /package/{src-web → dist-web}/setSecureScreen.d.ts +0 -0
- /package/{src-web → dist-web}/share.d.ts +0 -0
- /package/{src-web → dist-web}/startUpdateLocation.d.ts +0 -0
package/dist/prebuilt/prod.json
CHANGED
|
@@ -2,13 +2,13 @@
|
|
|
2
2
|
{
|
|
3
3
|
"platform": "ios",
|
|
4
4
|
"totalModuleCount": 360,
|
|
5
|
-
"duration":
|
|
6
|
-
"size":
|
|
5
|
+
"duration": 396.9661249999999,
|
|
6
|
+
"size": 131205
|
|
7
7
|
},
|
|
8
8
|
{
|
|
9
9
|
"platform": "android",
|
|
10
10
|
"totalModuleCount": 360,
|
|
11
|
-
"duration":
|
|
12
|
-
"size":
|
|
11
|
+
"duration": 397.9799580000001,
|
|
12
|
+
"size": 130951
|
|
13
13
|
}
|
|
14
14
|
]
|
|
@@ -15,5 +15,7 @@ export * from './fetchAlbumPhotos';
|
|
|
15
15
|
export * from './getCurrentLocation';
|
|
16
16
|
export * from './openCamera';
|
|
17
17
|
export * from './appLogin';
|
|
18
|
+
export * from './checkoutPayment';
|
|
19
|
+
export * from './executePayment';
|
|
18
20
|
export * from './getOperationalEnvironment';
|
|
19
21
|
export * from './startUpdateLocation';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export const createEvents=()=>({emit(event,args){for(let callbacks=this.events[event]||[],i=0,length=callbacks.length;i<length;i++){callbacks[i](args)}},events:{},on(event,cb){var _this_events,_event;((_this_events=this.events)[_event=event]||(_this_events[_event]=[])).push(cb);return()=>{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(i=>cb!==i)}}});const createEventId=()=>Math.random().toString(36).substring(2,15);const deserializeError=value=>{if(value&&value.__isError){const err=new Error(value.message);err.name=value.name;err.stack=value.stack;return err}return value};window.__BEDROCK_NATIVE_EMITTER=createEvents();export function closeView(...args){if(!window.ReactNativeWebView){throw new Error("This closeView is not available in browser environment")}const eventId=createEventId();const emitters=[];const unsubscribe=()=>{for(const emitter of emitters){emitter()}};return new Promise((resolve,reject)=>{emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`closeView/resolve/${eventId}`,args=>{unsubscribe();resolve(args)}));emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`closeView/reject/${eventId}`,error=>{unsubscribe();reject(deserializeError(error))}));window.ReactNativeWebView.postMessage(JSON.stringify({type:"method",functionName:"closeView",eventId,args}))})}export function generateHapticFeedback(...args){if(!window.ReactNativeWebView){throw new Error("This generateHapticFeedback is not available in browser environment")}const eventId=createEventId();const emitters=[];const unsubscribe=()=>{for(const emitter of emitters){emitter()}};return new Promise((resolve,reject)=>{emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`generateHapticFeedback/resolve/${eventId}`,args=>{unsubscribe();resolve(args)}));emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`generateHapticFeedback/reject/${eventId}`,error=>{unsubscribe();reject(deserializeError(error))}));window.ReactNativeWebView.postMessage(JSON.stringify({type:"method",functionName:"generateHapticFeedback",eventId,args}))})}export function share(...args){if(!window.ReactNativeWebView){throw new Error("This share is not available in browser environment")}const eventId=createEventId();const emitters=[];const unsubscribe=()=>{for(const emitter of emitters){emitter()}};return new Promise((resolve,reject)=>{emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`share/resolve/${eventId}`,args=>{unsubscribe();resolve(args)}));emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`share/reject/${eventId}`,error=>{unsubscribe();reject(deserializeError(error))}));window.ReactNativeWebView.postMessage(JSON.stringify({type:"method",functionName:"share",eventId,args}))})}export function setSecureScreen(...args){if(!window.ReactNativeWebView){throw new Error("This setSecureScreen is not available in browser environment")}const eventId=createEventId();const emitters=[];const unsubscribe=()=>{for(const emitter of emitters){emitter()}};return new Promise((resolve,reject)=>{emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`setSecureScreen/resolve/${eventId}`,args=>{unsubscribe();resolve(args)}));emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`setSecureScreen/reject/${eventId}`,error=>{unsubscribe();reject(deserializeError(error))}));window.ReactNativeWebView.postMessage(JSON.stringify({type:"method",functionName:"setSecureScreen",eventId,args}))})}export function setScreenAwakeMode(...args){if(!window.ReactNativeWebView){throw new Error("This setScreenAwakeMode is not available in browser environment")}const eventId=createEventId();const emitters=[];const unsubscribe=()=>{for(const emitter of emitters){emitter()}};return new Promise((resolve,reject)=>{emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`setScreenAwakeMode/resolve/${eventId}`,args=>{unsubscribe();resolve(args)}));emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`setScreenAwakeMode/reject/${eventId}`,error=>{unsubscribe();reject(deserializeError(error))}));window.ReactNativeWebView.postMessage(JSON.stringify({type:"method",functionName:"setScreenAwakeMode",eventId,args}))})}export function getNetworkStatus(...args){if(!window.ReactNativeWebView){throw new Error("This getNetworkStatus is not available in browser environment")}const eventId=createEventId();const emitters=[];const unsubscribe=()=>{for(const emitter of emitters){emitter()}};return new Promise((resolve,reject)=>{emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`getNetworkStatus/resolve/${eventId}`,args=>{unsubscribe();resolve(args)}));emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`getNetworkStatus/reject/${eventId}`,error=>{unsubscribe();reject(deserializeError(error))}));window.ReactNativeWebView.postMessage(JSON.stringify({type:"method",functionName:"getNetworkStatus",eventId,args}))})}export function getLocale(){if(!window.ReactNativeWebView){throw new Error("This getLocale is not available in browser environment")}if("getLocale"in window.__CONSTANT_HANDLER_MAP){return window.__CONSTANT_HANDLER_MAP["getLocale"]}throw new Error("getLocale is not a constant handler")}export function getSchemeUri(){if(!window.ReactNativeWebView){throw new Error("This getSchemeUri is not available in browser environment")}if("getSchemeUri"in window.__CONSTANT_HANDLER_MAP){return window.__CONSTANT_HANDLER_MAP["getSchemeUri"]}throw new Error("getSchemeUri is not a constant handler")}export function getDeviceId(){if(!window.ReactNativeWebView){throw new Error("This getDeviceId is not available in browser environment")}if("getDeviceId"in window.__CONSTANT_HANDLER_MAP){return window.__CONSTANT_HANDLER_MAP["getDeviceId"]}throw new Error("getDeviceId is not a constant handler")}export function getPlatformOS(){if(!window.ReactNativeWebView){throw new Error("This getPlatformOS is not available in browser environment")}if("getPlatformOS"in window.__CONSTANT_HANDLER_MAP){return window.__CONSTANT_HANDLER_MAP["getPlatformOS"]}throw new Error("getPlatformOS is not a constant handler")}export function setClipboardText(...args){if(!window.ReactNativeWebView){throw new Error("This setClipboardText is not available in browser environment")}const eventId=createEventId();const emitters=[];const unsubscribe=()=>{for(const emitter of emitters){emitter()}};return new Promise((resolve,reject)=>{emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`setClipboardText/resolve/${eventId}`,args=>{unsubscribe();resolve(args)}));emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`setClipboardText/reject/${eventId}`,error=>{unsubscribe();reject(deserializeError(error))}));window.ReactNativeWebView.postMessage(JSON.stringify({type:"method",functionName:"setClipboardText",eventId,args}))})}export function getClipboardText(...args){if(!window.ReactNativeWebView){throw new Error("This getClipboardText is not available in browser environment")}const eventId=createEventId();const emitters=[];const unsubscribe=()=>{for(const emitter of emitters){emitter()}};return new Promise((resolve,reject)=>{emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`getClipboardText/resolve/${eventId}`,args=>{unsubscribe();resolve(args)}));emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`getClipboardText/reject/${eventId}`,error=>{unsubscribe();reject(deserializeError(error))}));window.ReactNativeWebView.postMessage(JSON.stringify({type:"method",functionName:"getClipboardText",eventId,args}))})}export function fetchContacts(...args){if(!window.ReactNativeWebView){throw new Error("This fetchContacts is not available in browser environment")}const eventId=createEventId();const emitters=[];const unsubscribe=()=>{for(const emitter of emitters){emitter()}};return new Promise((resolve,reject)=>{emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`fetchContacts/resolve/${eventId}`,args=>{unsubscribe();resolve(args)}));emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`fetchContacts/reject/${eventId}`,error=>{unsubscribe();reject(deserializeError(error))}));window.ReactNativeWebView.postMessage(JSON.stringify({type:"method",functionName:"fetchContacts",eventId,args}))})}export function fetchAlbumPhotos(...args){if(!window.ReactNativeWebView){throw new Error("This fetchAlbumPhotos is not available in browser environment")}const eventId=createEventId();const emitters=[];const unsubscribe=()=>{for(const emitter of emitters){emitter()}};return new Promise((resolve,reject)=>{emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`fetchAlbumPhotos/resolve/${eventId}`,args=>{unsubscribe();resolve(args)}));emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`fetchAlbumPhotos/reject/${eventId}`,error=>{unsubscribe();reject(deserializeError(error))}));window.ReactNativeWebView.postMessage(JSON.stringify({type:"method",functionName:"fetchAlbumPhotos",eventId,args}))})}export var Accuracy=function(Accuracy){Accuracy[Accuracy["Lowest"]=1]="Lowest";Accuracy[Accuracy["Low"]=2]="Low";Accuracy[Accuracy["Balanced"]=3]="Balanced";Accuracy[Accuracy["High"]=4]="High";Accuracy[Accuracy["Highest"]=5]="Highest";Accuracy[Accuracy["BestForNavigation"]=6]="BestForNavigation";return Accuracy}({});export function getCurrentLocation(...args){if(!window.ReactNativeWebView){throw new Error("This getCurrentLocation is not available in browser environment")}const eventId=createEventId();const emitters=[];const unsubscribe=()=>{for(const emitter of emitters){emitter()}};return new Promise((resolve,reject)=>{emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`getCurrentLocation/resolve/${eventId}`,args=>{unsubscribe();resolve(args)}));emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`getCurrentLocation/reject/${eventId}`,error=>{unsubscribe();reject(deserializeError(error))}));window.ReactNativeWebView.postMessage(JSON.stringify({type:"method",functionName:"getCurrentLocation",eventId,args}))})}export function openCamera(...args){if(!window.ReactNativeWebView){throw new Error("This openCamera is not available in browser environment")}const eventId=createEventId();const emitters=[];const unsubscribe=()=>{for(const emitter of emitters){emitter()}};return new Promise((resolve,reject)=>{emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`openCamera/resolve/${eventId}`,args=>{unsubscribe();resolve(args)}));emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`openCamera/reject/${eventId}`,error=>{unsubscribe();reject(deserializeError(error))}));window.ReactNativeWebView.postMessage(JSON.stringify({type:"method",functionName:"openCamera",eventId,args}))})}export function appLogin(...args){if(!window.ReactNativeWebView){throw new Error("This appLogin is not available in browser environment")}const eventId=createEventId();const emitters=[];const unsubscribe=()=>{for(const emitter of emitters){emitter()}};return new Promise((resolve,reject)=>{emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`appLogin/resolve/${eventId}`,args=>{unsubscribe();resolve(args)}));emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`appLogin/reject/${eventId}`,error=>{unsubscribe();reject(deserializeError(error))}));window.ReactNativeWebView.postMessage(JSON.stringify({type:"method",functionName:"appLogin",eventId,args}))})}export function getOperationalEnvironment(){if(!window.ReactNativeWebView){throw new Error("This getOperationalEnvironment is not available in browser environment")}if("getOperationalEnvironment"in window.__CONSTANT_HANDLER_MAP){return window.__CONSTANT_HANDLER_MAP["getOperationalEnvironment"]}throw new Error("getOperationalEnvironment is not a constant handler")}export function startUpdateLocation({onEvent,onError,options}){if(!window.ReactNativeWebView){onError(new Error("This startUpdateLocation is not available in browser environment"));return()=>{}}const eventId=createEventId();const removes=[window.__BEDROCK_NATIVE_EMITTER.on(`startUpdateLocation/onEvent/${eventId}`,response=>{onEvent(response)}),window.__BEDROCK_NATIVE_EMITTER.on(`startUpdateLocation/onError/${eventId}`,error=>{onError(deserializeError(error))})];window.ReactNativeWebView.postMessage(JSON.stringify({type:"addEventListener",functionName:"startUpdateLocation",eventId,args:options}));return()=>{window.ReactNativeWebView.postMessage(JSON.stringify({type:"removeEventListener",functionName:"startUpdateLocation",eventId}));for(const remove of removes){remove()}}}
|
|
1
|
+
export const createEvents=()=>({emit(event,args){for(let callbacks=this.events[event]||[],i=0,length=callbacks.length;i<length;i++){callbacks[i](args)}},events:{},on(event,cb){var _this_events,_event;((_this_events=this.events)[_event=event]||(_this_events[_event]=[])).push(cb);return()=>{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(i=>cb!==i)}}});const createEventId=()=>Math.random().toString(36).substring(2,15);const deserializeError=value=>{if(value&&value.__isError){const err=new Error(value.message);err.name=value.name;err.stack=value.stack;return err}return value};window.__BEDROCK_NATIVE_EMITTER=createEvents();export function closeView(...args){if(!window.ReactNativeWebView){throw new Error("This closeView is not available in browser environment")}const eventId=createEventId();const emitters=[];const unsubscribe=()=>{for(const emitter of emitters){emitter()}};return new Promise((resolve,reject)=>{emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`closeView/resolve/${eventId}`,args=>{unsubscribe();resolve(args)}));emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`closeView/reject/${eventId}`,error=>{unsubscribe();reject(deserializeError(error))}));window.ReactNativeWebView.postMessage(JSON.stringify({type:"method",functionName:"closeView",eventId,args}))})}export function generateHapticFeedback(...args){if(!window.ReactNativeWebView){throw new Error("This generateHapticFeedback is not available in browser environment")}const eventId=createEventId();const emitters=[];const unsubscribe=()=>{for(const emitter of emitters){emitter()}};return new Promise((resolve,reject)=>{emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`generateHapticFeedback/resolve/${eventId}`,args=>{unsubscribe();resolve(args)}));emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`generateHapticFeedback/reject/${eventId}`,error=>{unsubscribe();reject(deserializeError(error))}));window.ReactNativeWebView.postMessage(JSON.stringify({type:"method",functionName:"generateHapticFeedback",eventId,args}))})}export function share(...args){if(!window.ReactNativeWebView){throw new Error("This share is not available in browser environment")}const eventId=createEventId();const emitters=[];const unsubscribe=()=>{for(const emitter of emitters){emitter()}};return new Promise((resolve,reject)=>{emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`share/resolve/${eventId}`,args=>{unsubscribe();resolve(args)}));emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`share/reject/${eventId}`,error=>{unsubscribe();reject(deserializeError(error))}));window.ReactNativeWebView.postMessage(JSON.stringify({type:"method",functionName:"share",eventId,args}))})}export function setSecureScreen(...args){if(!window.ReactNativeWebView){throw new Error("This setSecureScreen is not available in browser environment")}const eventId=createEventId();const emitters=[];const unsubscribe=()=>{for(const emitter of emitters){emitter()}};return new Promise((resolve,reject)=>{emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`setSecureScreen/resolve/${eventId}`,args=>{unsubscribe();resolve(args)}));emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`setSecureScreen/reject/${eventId}`,error=>{unsubscribe();reject(deserializeError(error))}));window.ReactNativeWebView.postMessage(JSON.stringify({type:"method",functionName:"setSecureScreen",eventId,args}))})}export function setScreenAwakeMode(...args){if(!window.ReactNativeWebView){throw new Error("This setScreenAwakeMode is not available in browser environment")}const eventId=createEventId();const emitters=[];const unsubscribe=()=>{for(const emitter of emitters){emitter()}};return new Promise((resolve,reject)=>{emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`setScreenAwakeMode/resolve/${eventId}`,args=>{unsubscribe();resolve(args)}));emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`setScreenAwakeMode/reject/${eventId}`,error=>{unsubscribe();reject(deserializeError(error))}));window.ReactNativeWebView.postMessage(JSON.stringify({type:"method",functionName:"setScreenAwakeMode",eventId,args}))})}export function getNetworkStatus(...args){if(!window.ReactNativeWebView){throw new Error("This getNetworkStatus is not available in browser environment")}const eventId=createEventId();const emitters=[];const unsubscribe=()=>{for(const emitter of emitters){emitter()}};return new Promise((resolve,reject)=>{emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`getNetworkStatus/resolve/${eventId}`,args=>{unsubscribe();resolve(args)}));emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`getNetworkStatus/reject/${eventId}`,error=>{unsubscribe();reject(deserializeError(error))}));window.ReactNativeWebView.postMessage(JSON.stringify({type:"method",functionName:"getNetworkStatus",eventId,args}))})}export function getLocale(){if(!window.ReactNativeWebView){throw new Error("This getLocale is not available in browser environment")}if("getLocale"in window.__CONSTANT_HANDLER_MAP){return window.__CONSTANT_HANDLER_MAP["getLocale"]}throw new Error("getLocale is not a constant handler")}export function getSchemeUri(){if(!window.ReactNativeWebView){throw new Error("This getSchemeUri is not available in browser environment")}if("getSchemeUri"in window.__CONSTANT_HANDLER_MAP){return window.__CONSTANT_HANDLER_MAP["getSchemeUri"]}throw new Error("getSchemeUri is not a constant handler")}export function getDeviceId(){if(!window.ReactNativeWebView){throw new Error("This getDeviceId is not available in browser environment")}if("getDeviceId"in window.__CONSTANT_HANDLER_MAP){return window.__CONSTANT_HANDLER_MAP["getDeviceId"]}throw new Error("getDeviceId is not a constant handler")}export function getPlatformOS(){if(!window.ReactNativeWebView){throw new Error("This getPlatformOS is not available in browser environment")}if("getPlatformOS"in window.__CONSTANT_HANDLER_MAP){return window.__CONSTANT_HANDLER_MAP["getPlatformOS"]}throw new Error("getPlatformOS is not a constant handler")}export function setClipboardText(...args){if(!window.ReactNativeWebView){throw new Error("This setClipboardText is not available in browser environment")}const eventId=createEventId();const emitters=[];const unsubscribe=()=>{for(const emitter of emitters){emitter()}};return new Promise((resolve,reject)=>{emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`setClipboardText/resolve/${eventId}`,args=>{unsubscribe();resolve(args)}));emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`setClipboardText/reject/${eventId}`,error=>{unsubscribe();reject(deserializeError(error))}));window.ReactNativeWebView.postMessage(JSON.stringify({type:"method",functionName:"setClipboardText",eventId,args}))})}export function getClipboardText(...args){if(!window.ReactNativeWebView){throw new Error("This getClipboardText is not available in browser environment")}const eventId=createEventId();const emitters=[];const unsubscribe=()=>{for(const emitter of emitters){emitter()}};return new Promise((resolve,reject)=>{emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`getClipboardText/resolve/${eventId}`,args=>{unsubscribe();resolve(args)}));emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`getClipboardText/reject/${eventId}`,error=>{unsubscribe();reject(deserializeError(error))}));window.ReactNativeWebView.postMessage(JSON.stringify({type:"method",functionName:"getClipboardText",eventId,args}))})}export function fetchContacts(...args){if(!window.ReactNativeWebView){throw new Error("This fetchContacts is not available in browser environment")}const eventId=createEventId();const emitters=[];const unsubscribe=()=>{for(const emitter of emitters){emitter()}};return new Promise((resolve,reject)=>{emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`fetchContacts/resolve/${eventId}`,args=>{unsubscribe();resolve(args)}));emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`fetchContacts/reject/${eventId}`,error=>{unsubscribe();reject(deserializeError(error))}));window.ReactNativeWebView.postMessage(JSON.stringify({type:"method",functionName:"fetchContacts",eventId,args}))})}export function fetchAlbumPhotos(...args){if(!window.ReactNativeWebView){throw new Error("This fetchAlbumPhotos is not available in browser environment")}const eventId=createEventId();const emitters=[];const unsubscribe=()=>{for(const emitter of emitters){emitter()}};return new Promise((resolve,reject)=>{emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`fetchAlbumPhotos/resolve/${eventId}`,args=>{unsubscribe();resolve(args)}));emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`fetchAlbumPhotos/reject/${eventId}`,error=>{unsubscribe();reject(deserializeError(error))}));window.ReactNativeWebView.postMessage(JSON.stringify({type:"method",functionName:"fetchAlbumPhotos",eventId,args}))})}export var Accuracy=function(Accuracy){Accuracy[Accuracy["Lowest"]=1]="Lowest";Accuracy[Accuracy["Low"]=2]="Low";Accuracy[Accuracy["Balanced"]=3]="Balanced";Accuracy[Accuracy["High"]=4]="High";Accuracy[Accuracy["Highest"]=5]="Highest";Accuracy[Accuracy["BestForNavigation"]=6]="BestForNavigation";return Accuracy}({});export function getCurrentLocation(...args){if(!window.ReactNativeWebView){throw new Error("This getCurrentLocation is not available in browser environment")}const eventId=createEventId();const emitters=[];const unsubscribe=()=>{for(const emitter of emitters){emitter()}};return new Promise((resolve,reject)=>{emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`getCurrentLocation/resolve/${eventId}`,args=>{unsubscribe();resolve(args)}));emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`getCurrentLocation/reject/${eventId}`,error=>{unsubscribe();reject(deserializeError(error))}));window.ReactNativeWebView.postMessage(JSON.stringify({type:"method",functionName:"getCurrentLocation",eventId,args}))})}export function openCamera(...args){if(!window.ReactNativeWebView){throw new Error("This openCamera is not available in browser environment")}const eventId=createEventId();const emitters=[];const unsubscribe=()=>{for(const emitter of emitters){emitter()}};return new Promise((resolve,reject)=>{emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`openCamera/resolve/${eventId}`,args=>{unsubscribe();resolve(args)}));emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`openCamera/reject/${eventId}`,error=>{unsubscribe();reject(deserializeError(error))}));window.ReactNativeWebView.postMessage(JSON.stringify({type:"method",functionName:"openCamera",eventId,args}))})}export function appLogin(...args){if(!window.ReactNativeWebView){throw new Error("This appLogin is not available in browser environment")}const eventId=createEventId();const emitters=[];const unsubscribe=()=>{for(const emitter of emitters){emitter()}};return new Promise((resolve,reject)=>{emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`appLogin/resolve/${eventId}`,args=>{unsubscribe();resolve(args)}));emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`appLogin/reject/${eventId}`,error=>{unsubscribe();reject(deserializeError(error))}));window.ReactNativeWebView.postMessage(JSON.stringify({type:"method",functionName:"appLogin",eventId,args}))})}export function checkoutPayment(...args){if(!window.ReactNativeWebView){throw new Error("This checkoutPayment is not available in browser environment")}const eventId=createEventId();const emitters=[];const unsubscribe=()=>{for(const emitter of emitters){emitter()}};return new Promise((resolve,reject)=>{emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`checkoutPayment/resolve/${eventId}`,args=>{unsubscribe();resolve(args)}));emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`checkoutPayment/reject/${eventId}`,error=>{unsubscribe();reject(deserializeError(error))}));window.ReactNativeWebView.postMessage(JSON.stringify({type:"method",functionName:"checkoutPayment",eventId,args}))})}export function executePayment(...args){if(!window.ReactNativeWebView){throw new Error("This executePayment is not available in browser environment")}const eventId=createEventId();const emitters=[];const unsubscribe=()=>{for(const emitter of emitters){emitter()}};return new Promise((resolve,reject)=>{emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`executePayment/resolve/${eventId}`,args=>{unsubscribe();resolve(args)}));emitters.push(window.__BEDROCK_NATIVE_EMITTER.on(`executePayment/reject/${eventId}`,error=>{unsubscribe();reject(deserializeError(error))}));window.ReactNativeWebView.postMessage(JSON.stringify({type:"method",functionName:"executePayment",eventId,args}))})}export function getOperationalEnvironment(){if(!window.ReactNativeWebView){throw new Error("This getOperationalEnvironment is not available in browser environment")}if("getOperationalEnvironment"in window.__CONSTANT_HANDLER_MAP){return window.__CONSTANT_HANDLER_MAP["getOperationalEnvironment"]}throw new Error("getOperationalEnvironment is not a constant handler")}export function startUpdateLocation({onEvent,onError,options}){if(!window.ReactNativeWebView){onError(new Error("This startUpdateLocation is not available in browser environment"));return()=>{}}const eventId=createEventId();const removes=[window.__BEDROCK_NATIVE_EMITTER.on(`startUpdateLocation/onEvent/${eventId}`,response=>{onEvent(response)}),window.__BEDROCK_NATIVE_EMITTER.on(`startUpdateLocation/onError/${eventId}`,error=>{onError(deserializeError(error))})];window.ReactNativeWebView.postMessage(JSON.stringify({type:"addEventListener",functionName:"startUpdateLocation",eventId,args:options}));return()=>{window.ReactNativeWebView.postMessage(JSON.stringify({type:"removeEventListener",functionName:"startUpdateLocation",eventId}));for(const remove of removes){remove()}}}
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @public
|
|
3
|
+
* @category 토스페이
|
|
4
|
+
* @name CheckoutPaymentOptions
|
|
5
|
+
* @description 토스페이 결제를 생성할 때 필요한 옵션 객체예요.
|
|
6
|
+
* @property {string} orderNo 가맹점의 상품 주문번호예요.
|
|
7
|
+
* @property {string} productDesc 상품 설명이에요.
|
|
8
|
+
* @property {number} amount 결제 금액이에요.
|
|
9
|
+
* @property {number} amountTaxFree 결제 금액 중 비과세 금액이에요.
|
|
10
|
+
* @property {number} [amountTaxable] 결제 금액 중 과세 금액이에요.
|
|
11
|
+
* @property {number} [amountVat] 결제 금액 중 부가세예요.
|
|
12
|
+
* @property {number} [amountServiceFee] 결제 금액 중 봉사료예요.
|
|
13
|
+
* @property {'TOSS_MONEY' | 'CARD' | null} [enablePayMethods] 결제수단 구분 변수예요. (TOSS_MONEY: 토스머니만, CARD: 카드만, null: 기본 결제수단)
|
|
14
|
+
* @property {boolean} [cashReceipt] 현금영수증 발급 가능 여부예요.
|
|
15
|
+
* @property {'CULTURE' | 'GENERAL' | 'PUBLIC_TP'} [cashReceiptTradeOption] 현금영수증 발급 타입이에요. (CULTURE: 문화비, GENERAL: 일반, PUBLIC_TP: 교통비)
|
|
16
|
+
* @property {'USE' | 'NO_USE'} [installment] 할부를 사용할 지 말 지 여부에요. (USE: 사용, NO_USE: 할부 미사용)
|
|
17
|
+
*/
|
|
18
|
+
export interface CheckoutPaymentOptions {
|
|
19
|
+
/**
|
|
20
|
+
* 가맹점의 상품 주문번호에요.
|
|
21
|
+
*/
|
|
22
|
+
orderNo: string;
|
|
23
|
+
/**
|
|
24
|
+
* 상품 설명이에요.
|
|
25
|
+
*/
|
|
26
|
+
productDesc: string;
|
|
27
|
+
/**
|
|
28
|
+
* 결제 금액이예요.
|
|
29
|
+
*/
|
|
30
|
+
amount: number;
|
|
31
|
+
/**
|
|
32
|
+
* 결제 금액 중 비과세 금액이에요.
|
|
33
|
+
*/
|
|
34
|
+
amountTaxFree: number;
|
|
35
|
+
/**
|
|
36
|
+
* 결제 금액 중 과세 금액이에요.
|
|
37
|
+
*/
|
|
38
|
+
amountTaxable?: number;
|
|
39
|
+
/**
|
|
40
|
+
* 결제 금액 중 부가세예요.
|
|
41
|
+
*/
|
|
42
|
+
amountVat?: number;
|
|
43
|
+
/**
|
|
44
|
+
* 결제 금액 중 봉사료예요.
|
|
45
|
+
*/
|
|
46
|
+
amountServiceFee?: number;
|
|
47
|
+
/**
|
|
48
|
+
* 결제수단 구분 변수예요.
|
|
49
|
+
*
|
|
50
|
+
* - 'TOSS_MONEY': 결제수단 중 토스머니만 노출
|
|
51
|
+
* - 'CARD': 결제수단 중 카드만 노출
|
|
52
|
+
* - null: 상점에 설정된 기본 결제 수단 노출
|
|
53
|
+
*/
|
|
54
|
+
enablePayMethods?: "TOSS_MONEY" | "CARD" | null;
|
|
55
|
+
/**
|
|
56
|
+
* 현금영수증 발급 가능 여부예요.
|
|
57
|
+
*/
|
|
58
|
+
cashReceipt?: boolean;
|
|
59
|
+
/**
|
|
60
|
+
* 현금영수증 발급 타입이에요.
|
|
61
|
+
*
|
|
62
|
+
* - 'CULTURE': 문화비
|
|
63
|
+
* - 'GENERAL': 일반(기본값)
|
|
64
|
+
* - 'PUBLIC_TP': 교통비
|
|
65
|
+
*/
|
|
66
|
+
cashReceiptTradeOption?: "CULTURE" | "GENERAL" | "PUBLIC_TP";
|
|
67
|
+
/**
|
|
68
|
+
* 할부를 사용할 지 말 지 여부에요.
|
|
69
|
+
*
|
|
70
|
+
* - 'USE': 사용(기본값)
|
|
71
|
+
* - 'NO_USE': 할부 미사용
|
|
72
|
+
*/
|
|
73
|
+
installment?: "USE" | "NO_USE";
|
|
74
|
+
}
|
|
75
|
+
/**
|
|
76
|
+
* @public
|
|
77
|
+
* @category 토스페이
|
|
78
|
+
* @name checkoutPayment
|
|
79
|
+
* @description 토스페이 결제를 생성하는 함수예요.
|
|
80
|
+
*
|
|
81
|
+
* @param {CheckoutPaymentOptions} options 결제를 생성할 때 필요한 옵션 객체예요.
|
|
82
|
+
* @param {string} options.orderNo 가맹점의 상품 주문번호예요.
|
|
83
|
+
* @param {string} options.productDesc 상품 설명이에요.
|
|
84
|
+
* @param {number} options.amount 결제 금액이에요.
|
|
85
|
+
* @param {number} options.amountTaxFree 결제 금액 중 비과세 금액이에요.
|
|
86
|
+
* @param {number} [options.amountTaxable] 결제 금액 중 과세 금액이에요.
|
|
87
|
+
* @param {number} [options.amountVat] 결제 금액 중 부가세예요.
|
|
88
|
+
* @param {number} [options.amountServiceFee] 결제 금액 중 봉사료예요.
|
|
89
|
+
* @param {'TOSS_MONEY' | 'CARD' | null} [options.enablePayMethods] 결제수단 구분 변수예요. (TOSS_MONEY: 토스머니만, CARD: 카드만, null: 기본 결제수단)
|
|
90
|
+
* @param {boolean} [options.cashReceipt] 현금영수증 발급 가능 여부예요.
|
|
91
|
+
* @param {'CULTURE' | 'GENERAL' | 'PUBLIC_TP'} [options.cashReceiptTradeOption] 현금영수증 발급 타입이에요. (CULTURE: 문화비, GENERAL: 일반, PUBLIC_TP: 교통비)
|
|
92
|
+
* @param {'USE' | 'NO_USE'} [options.installment] 할부를 사용할 지 말 지 여부에요. (USE: 사용, NO_USE: 할부 미사용)
|
|
93
|
+
* @returns {Promise<{ payToken: string }>} 결제 인증 후 발급된 결제 토큰 값이 포함된 객체를 반환해요.
|
|
94
|
+
*
|
|
95
|
+
* @example
|
|
96
|
+
* ### 결제 생성하기
|
|
97
|
+
*
|
|
98
|
+
* ```tsx
|
|
99
|
+
* import { TossPay } from '@apps-in-toss/web-framework';
|
|
100
|
+
*
|
|
101
|
+
* async function handlePayment() {
|
|
102
|
+
* try {
|
|
103
|
+
* const result = await TossPay.checkoutPayment({
|
|
104
|
+
* orderNo: 'ORDER_12345',
|
|
105
|
+
* productDesc: '티셔츠',
|
|
106
|
+
* amount: 15000,
|
|
107
|
+
* amountTaxFree: 0,
|
|
108
|
+
* amountTaxable: 13636,
|
|
109
|
+
* amountVat: 1364,
|
|
110
|
+
* enablePayMethods: 'CARD',
|
|
111
|
+
* installment: 'USE'
|
|
112
|
+
* });
|
|
113
|
+
*
|
|
114
|
+
* console.log('결제 토큰:', result.payToken);
|
|
115
|
+
* } catch (error) {
|
|
116
|
+
* console.error('결제 생성에 실패했어요:', error);
|
|
117
|
+
* }
|
|
118
|
+
* }
|
|
119
|
+
* ```
|
|
120
|
+
*/
|
|
121
|
+
export declare function checkoutPayment(options: CheckoutPaymentOptions): Promise<{
|
|
122
|
+
payToken: string;
|
|
123
|
+
}>;
|
|
124
|
+
|
|
125
|
+
export {};
|
|
@@ -0,0 +1,266 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @public
|
|
3
|
+
* @category 토스페이
|
|
4
|
+
* @name ExecutePaymentOptions
|
|
5
|
+
* @description 생성한 토스페이 결제를 실행할 때 필요한 옵션이에요.
|
|
6
|
+
* @property {string} orderNo 결제를 생성할 때 사용한 주문번호예요.
|
|
7
|
+
* @property {string} payToken 결제 인증 과정에서 전달받은 결제 토큰이에요. 결제를 실행할 때 사용해요.
|
|
8
|
+
*/
|
|
9
|
+
export interface ExecutePaymentOptions {
|
|
10
|
+
/**
|
|
11
|
+
* 결제를 생성할 때 사용한 주문번호예요.
|
|
12
|
+
*/
|
|
13
|
+
orderNo: string;
|
|
14
|
+
/**
|
|
15
|
+
* 결제 인증 과정에서 전달받은 Pay 토큰이에요.
|
|
16
|
+
*/
|
|
17
|
+
payToken: string;
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* @public
|
|
21
|
+
* @category 토스페이
|
|
22
|
+
* @name CardExecutePaymentResult
|
|
23
|
+
* @description 카드로 결제 요청을 실행한 뒤 돌아오는 결제 결과 객체예요. 결제 승인 여부, 결제된 금액, 주문 정보 등을 담고 있어요.
|
|
24
|
+
* @property {'CARD'} payMethod 결제 수단이에요.
|
|
25
|
+
* @property {number} code 결제 요청의 결과 코드예요.
|
|
26
|
+
* @property {'LIVE' | 'TEST'} mode 현재 결제 환경이에요.
|
|
27
|
+
* @property {string} orderNo 주문번호예요.
|
|
28
|
+
* @property {number} amount 총 결제 금액이에요.
|
|
29
|
+
* @property {string} approvalTime 결제가 승인된 시간이에요. (ISO 8601 형식)
|
|
30
|
+
* @property {string} stateMsg 결제 상태 메시지예요.
|
|
31
|
+
* @property {number} discountedAmount 적용된 할인 금액이에요.
|
|
32
|
+
* @property {number} paidAmount 실제 결제된 금액이에요.
|
|
33
|
+
* @property {string} payToken 결제 요청 시 사용한 Pay 토큰이에요.
|
|
34
|
+
* @property {string} transactionId 거래 ID예요.
|
|
35
|
+
* @property {number} cardCompanyCode 카드사 코드예요.
|
|
36
|
+
* @property {string} cardCompanyName 카드사 이름이에요.
|
|
37
|
+
* @property {string} cardAuthorizationNo 카드사 승인 번호예요. (라이브 결제 환경에서만 확인 가능해요)
|
|
38
|
+
* @property {number} spreadOut 할부 개월 수예요. (5만원 미만 금액 및 일시불 결제의 경우에는 `0`)
|
|
39
|
+
* @property {boolean} noInterest 무이자 할부 여부예요.
|
|
40
|
+
* @property {string} salesCheckLinkUrl 결제 내역을 확인할 수 있는 매출전표 URL이에요.
|
|
41
|
+
* @property {'CREDIT' | 'CHECK' | 'PREPAYMENT'} cardMethodType 카드 유형이에요.
|
|
42
|
+
* @property {string} cardNumber 마스킹된 카드 번호예요. (`****-****-****-1234` 형식)
|
|
43
|
+
* @property {string} cardNum4Print 카드 번호의 마지막 4자리예요.
|
|
44
|
+
* @property {string} cardBinNumber 카드 BIN 번호예요.
|
|
45
|
+
*/
|
|
46
|
+
export interface CardExecutePaymentResult {
|
|
47
|
+
/**
|
|
48
|
+
* 결제 수단이에요.
|
|
49
|
+
*/
|
|
50
|
+
payMethod: "CARD";
|
|
51
|
+
/**
|
|
52
|
+
* 결제 요청의 결과 코드예요.
|
|
53
|
+
*/
|
|
54
|
+
code: number;
|
|
55
|
+
/**
|
|
56
|
+
* 현재 결제 환경이에요.
|
|
57
|
+
*
|
|
58
|
+
* - `LIVE`: 실제 환경
|
|
59
|
+
* - `TEST`: 테스트 환경
|
|
60
|
+
*/
|
|
61
|
+
mode: "LIVE" | "TEST";
|
|
62
|
+
/**
|
|
63
|
+
* 주문번호예요.
|
|
64
|
+
*/
|
|
65
|
+
orderNo: string;
|
|
66
|
+
/**
|
|
67
|
+
* 총 결제 금액이에요.
|
|
68
|
+
*/
|
|
69
|
+
amount: number;
|
|
70
|
+
/**
|
|
71
|
+
* 결제가 승인된 시간이에요. (ISO 8601 형식)
|
|
72
|
+
*/
|
|
73
|
+
approvalTime: string;
|
|
74
|
+
/**
|
|
75
|
+
* 결제 상태 메시지예요.
|
|
76
|
+
*/
|
|
77
|
+
stateMsg: string;
|
|
78
|
+
/**
|
|
79
|
+
* 적용된 할인 금액이에요.
|
|
80
|
+
*/
|
|
81
|
+
discountedAmount: number;
|
|
82
|
+
/**
|
|
83
|
+
* 실제 결제된 금액이에요.
|
|
84
|
+
*/
|
|
85
|
+
paidAmount: number;
|
|
86
|
+
/**
|
|
87
|
+
* 결제 요청 시 사용한 Pay 토큰이에요.
|
|
88
|
+
*/
|
|
89
|
+
payToken: string;
|
|
90
|
+
/**
|
|
91
|
+
* 거래 ID예요.
|
|
92
|
+
*/
|
|
93
|
+
transactionId: string;
|
|
94
|
+
/**
|
|
95
|
+
* 카드사 코드예요.
|
|
96
|
+
*/
|
|
97
|
+
cardCompanyCode: number;
|
|
98
|
+
/**
|
|
99
|
+
* 카드사 이름이에요.
|
|
100
|
+
*/
|
|
101
|
+
cardCompanyName: string;
|
|
102
|
+
/**
|
|
103
|
+
* 카드사 승인 번호예요. (라이브 결제 환경에서만 확인 가능해요)
|
|
104
|
+
*/
|
|
105
|
+
cardAuthorizationNo: string;
|
|
106
|
+
/**
|
|
107
|
+
* 할부 개월 수예요. (5만원 미만 금액 및 일시불 결제의 경우에는 `0`)
|
|
108
|
+
*/
|
|
109
|
+
spreadOut: number;
|
|
110
|
+
/**
|
|
111
|
+
* 무이자 할부 여부예요.
|
|
112
|
+
*/
|
|
113
|
+
noInterest: boolean;
|
|
114
|
+
/**
|
|
115
|
+
* 결제 내역을 확인할 수 있는 매출전표 URL이에요.
|
|
116
|
+
*/
|
|
117
|
+
salesCheckLinkUrl: string;
|
|
118
|
+
/**
|
|
119
|
+
* 카드 유형이에요.
|
|
120
|
+
*
|
|
121
|
+
* - 'CREDIT': 신용카드
|
|
122
|
+
* - 'CHECK': 체크카드
|
|
123
|
+
* - 'PREPAYMENT': 선불카드
|
|
124
|
+
*/
|
|
125
|
+
cardMethodType: "CREDIT" | "CHECK" | "PREPAYMENT";
|
|
126
|
+
/**
|
|
127
|
+
* 마스킹된 카드 번호예요. (`****-****-****-1234` 형식)
|
|
128
|
+
*/
|
|
129
|
+
cardNumber: string;
|
|
130
|
+
/**
|
|
131
|
+
* 카드 사용자 구분을 나타내는 값이에요.
|
|
132
|
+
*
|
|
133
|
+
* - 'PERSONAL': 개인 카드
|
|
134
|
+
* - 'PERSONAL_FAMILY': 가족 카드
|
|
135
|
+
* - 'CORP_PERSONAL': 법인지정 결제계좌 (임직원)
|
|
136
|
+
* - 'CORP_PRIVATE': 법인 공용
|
|
137
|
+
* - 'CORP_COMPANY': 법인지정 결제계좌 회사 (하나카드 Only)
|
|
138
|
+
*/
|
|
139
|
+
cardUserType: "PERSONAL" | "PERSONAL_FAMILY" | "CORP_PERSONAL" | "CORP_PRIVATE" | "CORP_COMPANY";
|
|
140
|
+
/**
|
|
141
|
+
* 카드 번호의 마지막 4자리예요.
|
|
142
|
+
*/
|
|
143
|
+
cardNum4Print: string;
|
|
144
|
+
/**
|
|
145
|
+
* 카드 BIN 번호예요.
|
|
146
|
+
*/
|
|
147
|
+
cardBinNumber: string;
|
|
148
|
+
}
|
|
149
|
+
/**
|
|
150
|
+
* @public
|
|
151
|
+
* @category 토스페이
|
|
152
|
+
* @name TossMoneyExecutePaymentResult
|
|
153
|
+
* @description 토스머니로 결제 요청을 실행한 뒤 돌아오는 결제 결과 객체예요. 결제 승인 여부, 결제된 금액, 주문 정보 등을 담고 있어요.
|
|
154
|
+
* @property {'TOSS_MONEY'} payMethod 결제 수단이에요.
|
|
155
|
+
* @property {number} code 결제 요청의 결과 코드예요.
|
|
156
|
+
* @property {'LIVE' | 'TEST'} mode 현재 결제 환경이에요.
|
|
157
|
+
* @property {string} orderNo 주문번호예요.
|
|
158
|
+
* @property {number} amount 총 결제 금액이에요.
|
|
159
|
+
* @property {string} approvalTime 결제가 승인된 시간이에요. (ISO 8601 형식)
|
|
160
|
+
* @property {string} stateMsg 결제 상태 메시지예요.
|
|
161
|
+
* @property {number} discountedAmount 적용된 할인 금액이에요.
|
|
162
|
+
* @property {number} paidAmount 실제 결제된 금액이에요.
|
|
163
|
+
* @property {string} payToken 결제 요청 시 사용한 Pay 토큰이에요.
|
|
164
|
+
* @property {string} transactionId 거래 ID예요.
|
|
165
|
+
* @property {string} cashReceiptMgtKey 현금영수증 관리번호 식별값이에요.
|
|
166
|
+
* @property {string} accountBankName 결제된 은행의 코드예요.
|
|
167
|
+
* @property {string} accountNumber 결제된 계좌번호예요.
|
|
168
|
+
*/
|
|
169
|
+
export interface TossMoneyExecutePaymentResult {
|
|
170
|
+
/**
|
|
171
|
+
* 결제에 사용된 결제 수단이에요.
|
|
172
|
+
*/
|
|
173
|
+
payMethod: "TOSS_MONEY";
|
|
174
|
+
/**
|
|
175
|
+
* 결제 요청의 결과 코드예요.
|
|
176
|
+
*/
|
|
177
|
+
code: number;
|
|
178
|
+
/**
|
|
179
|
+
* 현재 결제 환경이에요.
|
|
180
|
+
*
|
|
181
|
+
* - `LIVE`: 실제 환경
|
|
182
|
+
* - `TEST`: 테스트 환경
|
|
183
|
+
*/
|
|
184
|
+
mode: "LIVE" | "TEST";
|
|
185
|
+
/**
|
|
186
|
+
* 결제 승인된 상품의 주문번호예요.
|
|
187
|
+
*/
|
|
188
|
+
orderNo: string;
|
|
189
|
+
/**
|
|
190
|
+
* 결제 승인된 상품의 총 결제 금액이에요.
|
|
191
|
+
*/
|
|
192
|
+
amount: number;
|
|
193
|
+
/**
|
|
194
|
+
* 결제가 승인된 시간이에요. (ISO 8601 형식)
|
|
195
|
+
*/
|
|
196
|
+
approvalTime: string;
|
|
197
|
+
/**
|
|
198
|
+
* 결제 상태 메시지예요.
|
|
199
|
+
*/
|
|
200
|
+
stateMsg: string;
|
|
201
|
+
/**
|
|
202
|
+
* 적용된 할인 금액이에요.
|
|
203
|
+
*/
|
|
204
|
+
discountedAmount: number;
|
|
205
|
+
/**
|
|
206
|
+
* 실제 결제 승인된 금액이에요.
|
|
207
|
+
*/
|
|
208
|
+
paidAmount: number;
|
|
209
|
+
/**
|
|
210
|
+
* 결제 요청 시 사용한 Pay 토큰이에요.
|
|
211
|
+
*/
|
|
212
|
+
payToken: string;
|
|
213
|
+
/**
|
|
214
|
+
* 거래 ID예요.
|
|
215
|
+
*/
|
|
216
|
+
transactionId: string;
|
|
217
|
+
/**
|
|
218
|
+
* 현금영수증 관리번호 식별값이에요.
|
|
219
|
+
*/
|
|
220
|
+
cashReceiptMgtKey: string;
|
|
221
|
+
/**
|
|
222
|
+
* 결제된 은행의 코드예요.
|
|
223
|
+
*/
|
|
224
|
+
accountBankName: string;
|
|
225
|
+
/**
|
|
226
|
+
* 결제된 계좌번호예요.
|
|
227
|
+
*/
|
|
228
|
+
accountNumber: string;
|
|
229
|
+
}
|
|
230
|
+
/**
|
|
231
|
+
* @public
|
|
232
|
+
* @category 토스페이
|
|
233
|
+
* @name executePayment
|
|
234
|
+
* @description 구매자가 결제를 시도하면, 먼저 결제 정보를 생성하고 인증을 받아요. 이때 결제 상태는 '대기' 중이에요. 이후 결제를 실제로 승인하려면 주어진 주문번호와 결제 토큰을 사용해서 이 함수로 생성된 결제를 승인해요. 결제 승인이 완료되면, 구매자의 결제 수단(예: 카드, 계좌)에서 실제로 금액이 출금돼요. 이 함수를 호출하지 않으면 결제가 자동으로 만료되고, 출금도 발생하지 않아요.
|
|
235
|
+
*
|
|
236
|
+
* @param {ExecutePaymentOptions} options 결제를 실행할 때 필요한 옵션이에요.
|
|
237
|
+
* @param {string} options.orderNo 결제를 생성할 때 사용한 주문번호예요.
|
|
238
|
+
* @param {string} options.payToken 결제 인증 과정에서 전달받은 결제 토큰이에요. 결제를 실행할 때 사용해요.
|
|
239
|
+
* @returns {Promise<CardExecutePaymentResult | TossMoneyExecutePaymentResult>} 결제 결과 객체를 반환해요. 자세한 내용은 [카드 결제 결과](reference/framework/토스페이/CardExecutePaymentResult.html) 또는 [토스머니 결제 결과](reference/framework/토스페이/TossMoneyExecutePaymentResult.html)를 참고하세요.
|
|
240
|
+
*
|
|
241
|
+
* @example
|
|
242
|
+
*
|
|
243
|
+
* ### 카드 결제 실행하기
|
|
244
|
+
*
|
|
245
|
+
* ```tsx
|
|
246
|
+
* import { TossPay } from '@apps-in-toss/web-framework';
|
|
247
|
+
*
|
|
248
|
+
* async function handlePayment() {
|
|
249
|
+
* try {
|
|
250
|
+
* const payToken = 'PAY_TOKEN_12345'; // 결제 인증 후 받은 토큰
|
|
251
|
+
*
|
|
252
|
+
* const result = await TossPay.executePayment({
|
|
253
|
+
* orderNo: 'ORDER_12345',
|
|
254
|
+
* payToken,
|
|
255
|
+
* });
|
|
256
|
+
*
|
|
257
|
+
* console.log('결제가 완료되었어요:', result);
|
|
258
|
+
* } catch (error) {
|
|
259
|
+
* console.error('결제에 실패했어요:', error);
|
|
260
|
+
* }
|
|
261
|
+
* }
|
|
262
|
+
* ```
|
|
263
|
+
*/
|
|
264
|
+
export declare function executePayment(options: ExecutePaymentOptions): Promise<CardExecutePaymentResult | TossMoneyExecutePaymentResult>;
|
|
265
|
+
|
|
266
|
+
export {};
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
export * from './bridge'
|
|
2
|
+
/**
|
|
3
|
+
* 비동기 브릿지 함수 생성
|
|
4
|
+
* @param method 호출할 메서드 이름
|
|
5
|
+
* @returns args를 받아 Promise를 반환하는 함수
|
|
6
|
+
* @typeParam T: 인자로 전달할 데이터 타입
|
|
7
|
+
* @typeParam R: resolve 시 반환될 데이터 타입 (기본 any)
|
|
8
|
+
* @example
|
|
9
|
+
* // 카메라 열기 브릿지 함수 생성
|
|
10
|
+
* const openCamera = createAsyncBridge<{base64: boolean}, { dataUri: string }>('openCamera');
|
|
11
|
+
*
|
|
12
|
+
* // 사용 예시
|
|
13
|
+
* async function takePicture() {
|
|
14
|
+
* try {
|
|
15
|
+
* const result = await openCamera();
|
|
16
|
+
* console.log('카메라로 찍은 이미지 URL:', result.dataUri);
|
|
17
|
+
* } catch (error) {
|
|
18
|
+
* console.error('카메라 오류:', error);
|
|
19
|
+
* }
|
|
20
|
+
* }
|
|
21
|
+
*/
|
|
22
|
+
declare function createAsyncBridge<T, R = any>(method: string): (args: T) => Promise<R>;
|
|
23
|
+
|
|
24
|
+
/**
|
|
25
|
+
* 상수 브릿지 함수 생성
|
|
26
|
+
* @param method 호출할 상수 핸들러 이름
|
|
27
|
+
* @returns 상수 값을 반환하는 함수
|
|
28
|
+
* @typeParam T: 상수 값의 타입
|
|
29
|
+
* @example
|
|
30
|
+
* // 디바이스 ID를 가져오는 상수 브릿지 생성
|
|
31
|
+
* const getDeviceId = createConstantBridge<string>('getDeviceId');
|
|
32
|
+
*
|
|
33
|
+
* // 사용 예시
|
|
34
|
+
* function displayDeviceInfo() {
|
|
35
|
+
* const deviceId = getDeviceId();
|
|
36
|
+
* console.log('디바이스 ID:', deviceId);
|
|
37
|
+
* }
|
|
38
|
+
*/
|
|
39
|
+
declare function createConstantBridge<T>(method: string): () => T;
|
|
40
|
+
|
|
41
|
+
/**
|
|
42
|
+
* 이벤트 브릿지 함수 생성
|
|
43
|
+
* @param method 호출할 이벤트 핸들러 이름
|
|
44
|
+
* @returns 이벤트 및 에러 핸들러를 포함한 객체를 받아 리스너 해제 함수를 반환하는 함수
|
|
45
|
+
* @typeParam T: 이벤트 관련 추가 옵션 등의 타입
|
|
46
|
+
* @example
|
|
47
|
+
* // 위치 추적 이벤트 브릿지 생성
|
|
48
|
+
* const startUpdatingLocation = createEventBridge<{ interval: number }>('startUpdatingLocation');
|
|
49
|
+
*
|
|
50
|
+
* // 사용 예시
|
|
51
|
+
* const unsubscribe = startUpdatingLocation({
|
|
52
|
+
* options: { interval: 1000 }, // 1초마다 위치 업데이트
|
|
53
|
+
* onEvent: (location) => {
|
|
54
|
+
* console.log('현재 위치:', location.latitude, location.longitude);
|
|
55
|
+
* },
|
|
56
|
+
* onError: (error) => {
|
|
57
|
+
* console.error('위치 추적 오류:', error);
|
|
58
|
+
* }
|
|
59
|
+
* });
|
|
60
|
+
*
|
|
61
|
+
* // 위치 추적 중단
|
|
62
|
+
* unsubscribe();
|
|
63
|
+
*/
|
|
64
|
+
declare function createEventBridge<TOptions, TData>(method: string): (args: {
|
|
65
|
+
onEvent: (data: TData) => void;
|
|
66
|
+
onError: (error: Error) => void;
|
|
67
|
+
options?: TOptions;
|
|
68
|
+
}) => () => void;
|
|
69
|
+
|
|
70
|
+
export { createAsyncBridge, createConstantBridge, createEventBridge };
|