@apps-in-toss/web-framework 0.0.0-dev.1742869301025 → 0.0.0-dev.1742896938983
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/chunk-EXHALAXL.js +173587 -0
- package/dist/cli/chunk-MTTRU5WU.js +63 -0
- package/dist/cli/lib-ZQFUOOU5.js +1007 -0
- package/dist/cli/typescript-OMXIAERO.js +6 -0
- package/dist/index.d.ts +14 -0
- package/dist/index.js +124 -0
- package/dist/prebuilt/dev.android.js +491 -470
- package/dist/prebuilt/dev.ios.js +492 -471
- 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/dist-web/bridge.js +1 -0
- package/dist-web/checkoutPayment.d.ts +125 -0
- package/dist-web/closeView.d.ts +1 -0
- package/dist-web/executePayment.d.ts +266 -0
- package/dist-web/generateHapticFeedback.d.ts +1 -0
- package/dist-web/getDeviceId.d.ts +1 -0
- package/dist-web/getLocale.d.ts +1 -0
- package/dist-web/getNetworkStatus.d.ts +1 -0
- package/dist-web/getPlatformOS.d.ts +1 -0
- package/dist-web/getSchemeUri.d.ts +1 -0
- package/dist-web/index.d.ts +70 -0
- package/dist-web/index.js +150 -0
- package/dist-web/setScreenAwakeMode.d.ts +1 -0
- package/dist-web/setSecureScreen.d.ts +1 -0
- package/dist-web/share.d.ts +1 -0
- package/package.json +15 -16
- package/src-web/closeView.d.ts +0 -23
- package/src-web/generateHapticFeedback.d.ts +0 -49
- package/src-web/getDeviceId.d.ts +0 -31
- package/src-web/getLocale.d.ts +0 -30
- package/src-web/getNetworkStatus.d.ts +0 -54
- package/src-web/getPlatformOS.d.ts +0 -35
- package/src-web/getSchemeUri.d.ts +0 -25
- package/src-web/index.js +0 -1
- package/src-web/setScreenAwakeMode.d.ts +0 -68
- package/src-web/setSecureScreen.d.ts +0 -33
- package/src-web/share.d.ts +0 -36
- /package/{src-web → dist-web}/appLogin.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}/getClipboardText.d.ts +0 -0
- /package/{src-web → dist-web}/getCurrentLocation.d.ts +0 -0
- /package/{src-web → dist-web}/getOperationalEnvironment.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}/startUpdateLocation.d.ts +0 -0
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 런타임에서 브릿지 함수를 생성하는 createBridge 함수입니다.
|
|
3
|
+
*
|
|
4
|
+
* @param options.type - 'async'이면 비동기 메서드 호출,
|
|
5
|
+
* 'event'이면 이벤트 리스너 생성,
|
|
6
|
+
* 'constant'이면 상수 값을 반환하는 동기 함수 생성
|
|
7
|
+
* @param options.method - 브릿지로 호출할 메서드 이름
|
|
8
|
+
*/
|
|
9
|
+
declare function createBridge<T>({ type, method }: {
|
|
10
|
+
type: 'async' | 'event' | 'constant';
|
|
11
|
+
method: string;
|
|
12
|
+
}): any;
|
|
13
|
+
|
|
14
|
+
export { createBridge };
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
export * from './bridge.js'
|
|
2
|
+
|
|
3
|
+
// src-web/createBridge.ts
|
|
4
|
+
var NativeWindow = class {
|
|
5
|
+
/**
|
|
6
|
+
* ReactNativeWebView를 이용해 메시지를 전송합니다.
|
|
7
|
+
* @param message 전송할 메시지(JSON 문자열)
|
|
8
|
+
*/
|
|
9
|
+
postMessage(message) {
|
|
10
|
+
const webView = window.ReactNativeWebView;
|
|
11
|
+
if (!webView) {
|
|
12
|
+
throw new Error("ReactNativeWebView is not available in browser environment");
|
|
13
|
+
}
|
|
14
|
+
webView.postMessage(message);
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* __BEDROCK_NATIVE_EMITTER를 이용해 이벤트 리스너를 등록합니다.
|
|
18
|
+
* @param event 이벤트 이름
|
|
19
|
+
* @param callback 데이터가 도착했을 때 호출되는 콜백
|
|
20
|
+
* @returns 리스너 해제 함수
|
|
21
|
+
*/
|
|
22
|
+
on(event, callback) {
|
|
23
|
+
const emitter = window.__BEDROCK_NATIVE_EMITTER;
|
|
24
|
+
if (!emitter) {
|
|
25
|
+
throw new Error("__BEDROCK_NATIVE_EMITTER is not available");
|
|
26
|
+
}
|
|
27
|
+
return emitter.on(event, callback);
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* __CONSTANT_HANDLER_MAP에 등록된 상수 값을 반환합니다.
|
|
31
|
+
* @param method 상수 핸들러 이름
|
|
32
|
+
* @returns 상수 값
|
|
33
|
+
*/
|
|
34
|
+
getConstant(method) {
|
|
35
|
+
const constantHandlerMap = window.__CONSTANT_HANDLER_MAP;
|
|
36
|
+
if (constantHandlerMap && method in constantHandlerMap) {
|
|
37
|
+
return constantHandlerMap[method];
|
|
38
|
+
}
|
|
39
|
+
throw new Error(`${method} is not a constant handler`);
|
|
40
|
+
}
|
|
41
|
+
};
|
|
42
|
+
var nativeWindow = new NativeWindow();
|
|
43
|
+
var createEventId = () => Math.random().toString(36).substring(2, 15);
|
|
44
|
+
var deserializeError = (value) => {
|
|
45
|
+
if (value && value.__isError) {
|
|
46
|
+
const err = new Error(value.message);
|
|
47
|
+
err.name = value.name;
|
|
48
|
+
err.stack = value.stack;
|
|
49
|
+
return err;
|
|
50
|
+
}
|
|
51
|
+
return value;
|
|
52
|
+
};
|
|
53
|
+
function createBridge({ type, method }) {
|
|
54
|
+
if (type === "async") {
|
|
55
|
+
return (args) => {
|
|
56
|
+
const eventId = createEventId();
|
|
57
|
+
const emitters = [];
|
|
58
|
+
const unsubscribe = () => {
|
|
59
|
+
emitters.forEach((remove) => remove());
|
|
60
|
+
};
|
|
61
|
+
return new Promise((resolve, reject) => {
|
|
62
|
+
emitters.push(
|
|
63
|
+
nativeWindow.on(`${method}/resolve/${eventId}`, (data) => {
|
|
64
|
+
unsubscribe();
|
|
65
|
+
resolve(data);
|
|
66
|
+
})
|
|
67
|
+
);
|
|
68
|
+
emitters.push(
|
|
69
|
+
nativeWindow.on(`${method}/reject/${eventId}`, (error) => {
|
|
70
|
+
unsubscribe();
|
|
71
|
+
reject(deserializeError(error));
|
|
72
|
+
})
|
|
73
|
+
);
|
|
74
|
+
nativeWindow.postMessage(
|
|
75
|
+
JSON.stringify({
|
|
76
|
+
type: "method",
|
|
77
|
+
functionName: method,
|
|
78
|
+
eventId,
|
|
79
|
+
args
|
|
80
|
+
})
|
|
81
|
+
);
|
|
82
|
+
});
|
|
83
|
+
};
|
|
84
|
+
} else if (type === "event") {
|
|
85
|
+
return (args) => {
|
|
86
|
+
const eventId = createEventId();
|
|
87
|
+
const removes = [
|
|
88
|
+
nativeWindow.on(`${method}/onEvent/${eventId}`, (data) => {
|
|
89
|
+
args.onEvent(data);
|
|
90
|
+
}),
|
|
91
|
+
nativeWindow.on(`${method}/onError/${eventId}`, (error) => {
|
|
92
|
+
args.onError(deserializeError(error));
|
|
93
|
+
})
|
|
94
|
+
];
|
|
95
|
+
nativeWindow.postMessage(
|
|
96
|
+
JSON.stringify({
|
|
97
|
+
type: "addEventListener",
|
|
98
|
+
functionName: method,
|
|
99
|
+
eventId,
|
|
100
|
+
args: args.options
|
|
101
|
+
})
|
|
102
|
+
);
|
|
103
|
+
return () => {
|
|
104
|
+
nativeWindow.postMessage(
|
|
105
|
+
JSON.stringify({
|
|
106
|
+
type: "removeEventListener",
|
|
107
|
+
functionName: method,
|
|
108
|
+
eventId
|
|
109
|
+
})
|
|
110
|
+
);
|
|
111
|
+
removes.forEach((remove) => remove());
|
|
112
|
+
};
|
|
113
|
+
};
|
|
114
|
+
} else if (type === "constant") {
|
|
115
|
+
return function() {
|
|
116
|
+
return nativeWindow.getConstant(method);
|
|
117
|
+
};
|
|
118
|
+
} else {
|
|
119
|
+
throw new Error("Unsupported bridge type");
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
export {
|
|
123
|
+
createBridge
|
|
124
|
+
};
|