@apps-in-toss/native-modules 0.0.0-dev.1752115036458 → 0.0.0-dev.1757056983098
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/bridges-meta.json +36 -13
- package/dist/index.cjs +343 -129
- package/dist/index.d.cts +1212 -418
- package/dist/index.d.ts +1212 -418
- package/dist/index.js +315 -108
- package/package.json +7 -8
- package/src/AppsInTossModule/constants.ts +6 -0
- package/src/AppsInTossModule/native-event-emitter/appsInTossEvent.ts +15 -0
- package/src/AppsInTossModule/native-event-emitter/contactsViral.ts +140 -0
- package/src/AppsInTossModule/native-event-emitter/event-plugins/EntryMessageExitedEvent.ts +10 -0
- package/src/AppsInTossModule/native-event-emitter/event-plugins/HomeIconButtonClickHandleEvent.ts +10 -0
- package/src/AppsInTossModule/native-event-emitter/event-plugins/UpdateLocationEvent.ts +60 -0
- package/src/AppsInTossModule/native-event-emitter/index.ts +6 -0
- package/src/AppsInTossModule/native-event-emitter/internal/AppBridgeCallbackEvent.ts +45 -0
- package/src/AppsInTossModule/native-event-emitter/internal/VisibilityChangedByTransparentServiceWebEvent.ts +50 -0
- package/src/AppsInTossModule/native-event-emitter/internal/appBridge.spec.ts +135 -0
- package/src/AppsInTossModule/native-event-emitter/internal/appBridge.ts +79 -0
- package/src/AppsInTossModule/native-event-emitter/internal/onVisibilityChangedByTransparentServiceWeb.ts +20 -0
- package/src/AppsInTossModule/native-event-emitter/nativeEventEmitter.ts +35 -0
- package/src/AppsInTossModule/native-event-emitter/startUpdateLocation.ts +98 -0
- package/src/AppsInTossModule/native-event-emitter/types.ts +4 -0
- package/src/AppsInTossModule/native-modules/AppsInTossModule.ts +89 -0
- package/src/AppsInTossModule/native-modules/ads/googleAdMob.ts +681 -0
- package/src/AppsInTossModule/native-modules/ads/googleAdMobV2.ts +363 -0
- package/src/AppsInTossModule/native-modules/ads/types.ts +123 -0
- package/src/AppsInTossModule/native-modules/appLogin.ts +29 -0
- package/src/AppsInTossModule/native-modules/checkoutPayment.ts +80 -0
- package/src/AppsInTossModule/native-modules/eventLog.spec.ts +300 -0
- package/src/AppsInTossModule/native-modules/eventLog.ts +77 -0
- package/src/AppsInTossModule/native-modules/fetchAlbumPhotos.ts +88 -0
- package/src/AppsInTossModule/native-modules/fetchContacts.ts +121 -0
- package/src/AppsInTossModule/native-modules/getClipboardText.ts +47 -0
- package/src/AppsInTossModule/native-modules/getCurrentLocation.ts +65 -0
- package/src/AppsInTossModule/native-modules/getDeviceId.ts +33 -0
- package/src/AppsInTossModule/native-modules/getGameCenterGameProfile.ts +68 -0
- package/src/AppsInTossModule/native-modules/getOperationalEnvironment.ts +37 -0
- package/src/AppsInTossModule/native-modules/getPermission.ts +58 -0
- package/src/AppsInTossModule/native-modules/getTossAppVersion.ts +33 -0
- package/src/AppsInTossModule/native-modules/getTossShareLink.ts +39 -0
- package/src/AppsInTossModule/native-modules/iap.ts +213 -0
- package/src/AppsInTossModule/native-modules/index.ts +104 -0
- package/src/AppsInTossModule/native-modules/isMinVersionSupported.spec.ts +190 -0
- package/src/AppsInTossModule/native-modules/isMinVersionSupported.ts +68 -0
- package/src/AppsInTossModule/native-modules/openCamera.ts +81 -0
- package/src/AppsInTossModule/native-modules/openGameCenterLeaderboard.ts +44 -0
- package/src/AppsInTossModule/native-modules/openPermissionDialog.ts +54 -0
- package/src/AppsInTossModule/native-modules/requestPermission.ts +63 -0
- package/src/AppsInTossModule/native-modules/saveBase64Data.ts +57 -0
- package/src/AppsInTossModule/native-modules/setClipboardText.ts +39 -0
- package/src/AppsInTossModule/native-modules/setDeviceOrientation.ts +74 -0
- package/src/AppsInTossModule/native-modules/storage.ts +100 -0
- package/src/AppsInTossModule/native-modules/submitGameCenterLeaderBoardScore.ts +74 -0
- package/src/AppsInTossModule/native-modules/tossCore.ts +29 -0
- package/src/BedrockModule/native-modules/core/BedrockCoreModule.ts +8 -0
- package/src/BedrockModule/native-modules/index.ts +4 -0
- package/src/BedrockModule/native-modules/natives/BedrockModule.ts +20 -0
- package/src/BedrockModule/native-modules/natives/closeView.ts +25 -0
- package/src/BedrockModule/native-modules/natives/generateHapticFeedback/index.ts +27 -0
- package/src/BedrockModule/native-modules/natives/generateHapticFeedback/types.ts +38 -0
- package/src/BedrockModule/native-modules/natives/getLocale.ts +46 -0
- package/src/BedrockModule/native-modules/natives/getNetworkStatus/index.ts +59 -0
- package/src/BedrockModule/native-modules/natives/getNetworkStatus/types.ts +1 -0
- package/src/BedrockModule/native-modules/natives/getPlatformOS.ts +37 -0
- package/src/BedrockModule/native-modules/natives/getSchemeUri.ts +27 -0
- package/src/BedrockModule/native-modules/natives/index.ts +11 -0
- package/src/BedrockModule/native-modules/natives/openURL.ts +40 -0
- package/src/BedrockModule/native-modules/natives/setIosSwipeGestureEnabled.ts +43 -0
- package/src/BedrockModule/native-modules/natives/setScreenAwakeMode.ts +66 -0
- package/src/BedrockModule/native-modules/natives/setSecureScreen.ts +31 -0
- package/src/BedrockModule/native-modules/natives/share.ts +36 -0
- package/src/async-bridges.ts +3 -0
- package/src/event-bridges.ts +2 -0
- package/src/index.ts +16 -0
- package/src/types.ts +108 -0
- package/src/utils/compareVersion.spec.ts +176 -0
- package/src/utils/compareVersion.ts +104 -0
- package/src/utils/generateUUID.ts +5 -0
|
@@ -0,0 +1,363 @@
|
|
|
1
|
+
import { noop } from 'es-toolkit';
|
|
2
|
+
import type { AdMobFullScreenEvent, AdMobHandlerParams, AdMobLoadResult, AdUserEarnedReward } from './types';
|
|
3
|
+
import { INTERNAL__appBridgeHandler } from '../../native-event-emitter/internal/appBridge';
|
|
4
|
+
import { getOperationalEnvironment } from '../getOperationalEnvironment';
|
|
5
|
+
import { isMinVersionSupported } from '../isMinVersionSupported';
|
|
6
|
+
|
|
7
|
+
// MARK: AdMob Load
|
|
8
|
+
|
|
9
|
+
export interface LoadAdMobOptions {
|
|
10
|
+
/**
|
|
11
|
+
* 광고 그룹 단위 ID
|
|
12
|
+
*/
|
|
13
|
+
adGroupId: string;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* @public
|
|
18
|
+
* @category 광고
|
|
19
|
+
* @name LoadAdMobEvent
|
|
20
|
+
* @description 광고를 불러오는 함수에서 발생하는 이벤트 타입이에요. `loaded` 이벤트가 발생하면 광고를 성공적으로 불러온 거예요. 이때 [AdMobLoadResult](/react-native/reference/native-modules/광고/AdMobLoadResult.html) 객체가 함께 반환돼요.
|
|
21
|
+
*/
|
|
22
|
+
export type LoadAdMobEvent = {
|
|
23
|
+
type: 'loaded';
|
|
24
|
+
data: AdMobLoadResult;
|
|
25
|
+
};
|
|
26
|
+
|
|
27
|
+
/**
|
|
28
|
+
* @public
|
|
29
|
+
* @category 광고
|
|
30
|
+
* @name LoadAdMobParams
|
|
31
|
+
* @description 광고를 불러오는 함수에 필요한 옵션 객체예요.
|
|
32
|
+
*/
|
|
33
|
+
export type LoadAdMobParams = AdMobHandlerParams<LoadAdMobOptions, LoadAdMobEvent>;
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* @public
|
|
37
|
+
* @category 광고
|
|
38
|
+
* @name loadAppsInTossAdMob
|
|
39
|
+
* @description 광고를 미리 불러와서, 광고가 필요한 시점에 바로 보여줄 수 있도록 준비하는 함수예요.
|
|
40
|
+
* @param {LoadAdMobParams} params 광고를 불러올 때 사용할 설정 값이에요. 광고 그룹 ID와 광고의 동작에 대한 콜백을 설정할 수 있어요.
|
|
41
|
+
* @param {LoadAdMobOptions} params.options 광고를 불러올 때 전달할 옵션 객체예요.
|
|
42
|
+
* @param {string} params.options.adGroupId 광고 그룹 단위 ID예요. 콘솔에서 발급받은 ID를 입력해요.
|
|
43
|
+
* @param {(event: LoadAdMobEvent) => void} [params.onEvent] 광고 관련 이벤트가 발생했을 때 호출돼요. (예시: 광고가 닫히거나 클릭됐을 때). 자세한 이벤트 타입은 [LoadAdMobEvent](/react-native/reference/native-modules/광고/LoadAdMobEvent.html)를 참고하세요.
|
|
44
|
+
* @param {(reason: unknown) => void} [params.onError] 광고를 불러오지 못했을 때 호출돼요. (예시: 네트워크 오류나 지원하지 않는 환경일 때)
|
|
45
|
+
* @property {() => boolean} [isSupported] 현재 실행 중인 앱(예: 토스 앱, 개발용 샌드박스 앱 등)에서 Google AdMob 광고 기능을 지원하는지 확인하는 함수예요. 기능을 사용하기 전에 지원 여부를 확인해야 해요.
|
|
46
|
+
*
|
|
47
|
+
* @example
|
|
48
|
+
* ### 버튼 눌러 불러온 광고 보여주기
|
|
49
|
+
* ```tsx
|
|
50
|
+
* import { GoogleAdMob } from '@apps-in-toss/framework';
|
|
51
|
+
* import { useFocusEffect } from '@react-native-bedrock/native/@react-navigation/native';
|
|
52
|
+
* import { useCallback, useState } from 'react';
|
|
53
|
+
* import { Button, Text, View } from 'react-native';
|
|
54
|
+
* import { useNavigation } from 'react-native-bedrock';
|
|
55
|
+
*
|
|
56
|
+
* const AD_GROUP_ID = '<AD_GROUP_ID>';
|
|
57
|
+
*
|
|
58
|
+
* export function GoogleAdmobExample() {
|
|
59
|
+
* const [adLoadStatus, setAdLoadStatus] = useState<'not_loaded' | 'loaded' | 'failed'>('not_loaded');
|
|
60
|
+
* const navigation = useNavigation();
|
|
61
|
+
*
|
|
62
|
+
* const loadAd = useCallback(() => {
|
|
63
|
+
* if (GoogleAdMob.loadAppsInTossAdMob.isSupported() !== true) {
|
|
64
|
+
* return;
|
|
65
|
+
* }
|
|
66
|
+
|
|
67
|
+
* const cleanup = GoogleAdMob.loadAppsInTossAdMob({
|
|
68
|
+
* options: {
|
|
69
|
+
* adGroupId: AD_GROUP_ID,
|
|
70
|
+
* },
|
|
71
|
+
* onEvent: (event) => {
|
|
72
|
+
* switch (event.type) {
|
|
73
|
+
* case 'loaded':
|
|
74
|
+
* console.log('광고 로드 성공', event.data);
|
|
75
|
+
* setAdLoadStatus('loaded');
|
|
76
|
+
* break;
|
|
77
|
+
* }
|
|
78
|
+
* },
|
|
79
|
+
* onError: (error) => {
|
|
80
|
+
* console.error('광고 불러오기 실패', error);
|
|
81
|
+
* },
|
|
82
|
+
* });
|
|
83
|
+
*
|
|
84
|
+
* return cleanup;
|
|
85
|
+
* }, [navigation]);
|
|
86
|
+
*
|
|
87
|
+
* const showAd = useCallback(() => {
|
|
88
|
+
* if (GoogleAdMob.showAppsInTossAdMob.isSupported() !== true) {
|
|
89
|
+
* return;
|
|
90
|
+
* }
|
|
91
|
+
*
|
|
92
|
+
* GoogleAdMob.showAppsInTossAdMob({
|
|
93
|
+
* options: {
|
|
94
|
+
* adGroupId: AD_GROUP_ID,
|
|
95
|
+
* },
|
|
96
|
+
* onEvent: (event) => {
|
|
97
|
+
* switch (event.type) {
|
|
98
|
+
* case 'requested':
|
|
99
|
+
* console.log('광고 보여주기 요청 완료');
|
|
100
|
+
* break;
|
|
101
|
+
*
|
|
102
|
+
* case 'clicked':
|
|
103
|
+
* console.log('광고 클릭');
|
|
104
|
+
* break;
|
|
105
|
+
*
|
|
106
|
+
* case 'dismissed':
|
|
107
|
+
* console.log('광고 닫힘');
|
|
108
|
+
* navigation.navigate('/examples/google-admob-interstitial-ad-landing');
|
|
109
|
+
* break;
|
|
110
|
+
*
|
|
111
|
+
* case 'failedToShow':
|
|
112
|
+
* console.log('광고 보여주기 실패');
|
|
113
|
+
* break;
|
|
114
|
+
*
|
|
115
|
+
* case 'impression':
|
|
116
|
+
* console.log('광고 노출');
|
|
117
|
+
* break;
|
|
118
|
+
*
|
|
119
|
+
* case 'userEarnedReward':
|
|
120
|
+
* console.log('광고 보상 획득 unitType:', event.data.unitType);
|
|
121
|
+
* console.log('광고 보상 획득 unitAmount:', event.data.unitAmount);
|
|
122
|
+
* break;
|
|
123
|
+
*
|
|
124
|
+
* case 'show':
|
|
125
|
+
* console.log('광고 컨텐츠 보여졌음');
|
|
126
|
+
* break;
|
|
127
|
+
* }
|
|
128
|
+
* },
|
|
129
|
+
* onError: (error) => {
|
|
130
|
+
* console.error('광고 보여주기 실패', error);
|
|
131
|
+
* },
|
|
132
|
+
* });
|
|
133
|
+
* }, []);
|
|
134
|
+
*
|
|
135
|
+
* useFocusEffect(loadAd);
|
|
136
|
+
*
|
|
137
|
+
* return (
|
|
138
|
+
* <View>
|
|
139
|
+
* <Text>
|
|
140
|
+
* {adLoadStatus === 'not_loaded' && '광고 로드 하지 않음 '}
|
|
141
|
+
* {adLoadStatus === 'loaded' && '광고 로드 완료'}
|
|
142
|
+
* {adLoadStatus === 'failed' && '광고 로드 실패'}
|
|
143
|
+
* </Text>
|
|
144
|
+
*
|
|
145
|
+
* <Button title="Show Ad" onPress={showAd} disabled={adLoadStatus !== 'loaded'} />
|
|
146
|
+
* </View>
|
|
147
|
+
* );
|
|
148
|
+
* }
|
|
149
|
+
* ```
|
|
150
|
+
*/
|
|
151
|
+
export function loadAppsInTossAdMob(params: LoadAdMobParams) {
|
|
152
|
+
if (!loadAppsInTossAdMob.isSupported()) {
|
|
153
|
+
params.onError(new Error(UNSUPPORTED_ERROR_MESSAGE));
|
|
154
|
+
return noop;
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
const { onEvent, onError, options } = params;
|
|
158
|
+
|
|
159
|
+
const unregisterCallbacks = INTERNAL__appBridgeHandler.invokeAppBridgeMethod('loadAppsInTossAdmob', options, {
|
|
160
|
+
onSuccess: (result) => onEvent({ type: 'loaded', data: result }),
|
|
161
|
+
onError,
|
|
162
|
+
});
|
|
163
|
+
|
|
164
|
+
return unregisterCallbacks;
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
// MARK: AdMob Show
|
|
168
|
+
|
|
169
|
+
export interface ShowAdMobOptions {
|
|
170
|
+
/**
|
|
171
|
+
* 광고 그룹 단위 ID
|
|
172
|
+
*/
|
|
173
|
+
adGroupId: string;
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
/**
|
|
177
|
+
* @public
|
|
178
|
+
* @category 광고
|
|
179
|
+
* @name ShowAdMobEvent
|
|
180
|
+
* @description 광고를 보여주는 함수에서 발생하는 이벤트 타입이에요. `requested` 이벤트가 발생하면 광고 노출 요청이 Google AdMob에 성공적으로 전달된 거예요.
|
|
181
|
+
*/
|
|
182
|
+
export type ShowAdMobEvent = AdMobFullScreenEvent | AdUserEarnedReward | { type: 'requested' };
|
|
183
|
+
|
|
184
|
+
/**
|
|
185
|
+
* @public
|
|
186
|
+
* @category 광고
|
|
187
|
+
* @name ShowAdMobParams
|
|
188
|
+
* @description 불러온 광고를 보여주는 함수에 필요한 옵션 객체예요.
|
|
189
|
+
*/
|
|
190
|
+
export type ShowAdMobParams = AdMobHandlerParams<ShowAdMobOptions, ShowAdMobEvent>;
|
|
191
|
+
|
|
192
|
+
/**
|
|
193
|
+
* @public
|
|
194
|
+
* @category 광고
|
|
195
|
+
* @name showAppsInTossAdMob
|
|
196
|
+
* @description 광고를 사용자에게 노출해요. 이 함수는 `loadAppsInTossAdMob` 로 미리 불러온 광고를 실제로 사용자에게 노출해요.
|
|
197
|
+
* @param {ShowAdMobParams} params 광고를 보여주기 위해 사용할 설정 값이에요. 광고 그룹 ID와과 광고의 동작에 대한 콜백을 설정할 수 있어요.
|
|
198
|
+
* @param {ShowAdMobOptions} params.options 광고를 보여줄 때 전달할 옵션 객체예요.
|
|
199
|
+
* @param {string} params.options.adUnitId 광고 그룹 단위 ID예요. `loadAppsInTossAdMob` 로 불러온 광고용 그룹 ID를 입력해요.
|
|
200
|
+
* @param {(event: ShowAdMobEvent) => void} [params.onEvent] 광고 관련 이벤트가 발생했을 때 호출돼요. (예시: 광고 노출을 요청했을 때). 자세한 이벤트 타입은 [ShowAdMobEvent](/react-native/reference/native-modules/광고/ShowAdMobEvent.html)를 참고하세요.
|
|
201
|
+
* @param {(reason: unknown) => void} [params.onError] 광고를 노출하지 못했을 때 호출돼요. (예시: 네트워크 오류나 지원하지 않는 환경일 때)
|
|
202
|
+
* @property {() => boolean} [isSupported] 현재 실행 중인 앱(예: 토스 앱, 개발용 샌드박스 앱 등)에서 Google AdMob 광고 기능을 지원하는지 확인하는 함수예요. 기능을 사용하기 전에 지원 여부를 확인해야 해요.
|
|
203
|
+
*
|
|
204
|
+
* @example
|
|
205
|
+
* ### 버튼 눌러 불러온 광고 보여주기
|
|
206
|
+
* ```tsx
|
|
207
|
+
* import { GoogleAdMob } from '@apps-in-toss/framework';
|
|
208
|
+
* import { useFocusEffect } from '@react-native-bedrock/native/@react-navigation/native';
|
|
209
|
+
* import { useCallback, useState } from 'react';
|
|
210
|
+
* import { Button, Text, View } from 'react-native';
|
|
211
|
+
* import { useNavigation } from 'react-native-bedrock';
|
|
212
|
+
*
|
|
213
|
+
* const AD_GROUP_ID = '<AD_GROUP_ID>';
|
|
214
|
+
*
|
|
215
|
+
* export function GoogleAdmobExample() {
|
|
216
|
+
* const [adLoadStatus, setAdLoadStatus] = useState<'not_loaded' | 'loaded' | 'failed'>('not_loaded');
|
|
217
|
+
* const navigation = useNavigation();
|
|
218
|
+
*
|
|
219
|
+
* const loadAd = useCallback(() => {
|
|
220
|
+
* if (GoogleAdMob.loadAppsInTossAdMob.isSupported() !== true) {
|
|
221
|
+
* return;
|
|
222
|
+
* }
|
|
223
|
+
|
|
224
|
+
* const cleanup = GoogleAdMob.loadAppsInTossAdMob({
|
|
225
|
+
* options: {
|
|
226
|
+
* adGroupId: AD_GROUP_ID,
|
|
227
|
+
* },
|
|
228
|
+
* onEvent: (event) => {
|
|
229
|
+
* switch (event.type) {
|
|
230
|
+
* case 'loaded':
|
|
231
|
+
* console.log('광고 로드 성공', event.data);
|
|
232
|
+
* setAdLoadStatus('loaded');
|
|
233
|
+
* break;
|
|
234
|
+
* }
|
|
235
|
+
* },
|
|
236
|
+
* onError: (error) => {
|
|
237
|
+
* console.error('광고 불러오기 실패', error);
|
|
238
|
+
* },
|
|
239
|
+
* });
|
|
240
|
+
*
|
|
241
|
+
* return cleanup;
|
|
242
|
+
* }, [navigation]);
|
|
243
|
+
*
|
|
244
|
+
* const showAd = useCallback(() => {
|
|
245
|
+
* if (GoogleAdMob.showAppsInTossAdMob.isSupported() !== true) {
|
|
246
|
+
* return;
|
|
247
|
+
* }
|
|
248
|
+
*
|
|
249
|
+
* GoogleAdMob.showAppsInTossAdMob({
|
|
250
|
+
* options: {
|
|
251
|
+
* adGroupId: AD_GROUP_ID,
|
|
252
|
+
* },
|
|
253
|
+
* onEvent: (event) => {
|
|
254
|
+
* switch (event.type) {
|
|
255
|
+
* case 'requested':
|
|
256
|
+
* console.log('광고 보여주기 요청 완료');
|
|
257
|
+
* break;
|
|
258
|
+
*
|
|
259
|
+
* case 'clicked':
|
|
260
|
+
* console.log('광고 클릭');
|
|
261
|
+
* break;
|
|
262
|
+
*
|
|
263
|
+
* case 'dismissed':
|
|
264
|
+
* console.log('광고 닫힘');
|
|
265
|
+
* navigation.navigate('/examples/google-admob-interstitial-ad-landing');
|
|
266
|
+
* break;
|
|
267
|
+
*
|
|
268
|
+
* case 'failedToShow':
|
|
269
|
+
* console.log('광고 보여주기 실패');
|
|
270
|
+
* break;
|
|
271
|
+
*
|
|
272
|
+
* case 'impression':
|
|
273
|
+
* console.log('광고 노출');
|
|
274
|
+
* break;
|
|
275
|
+
*
|
|
276
|
+
* case 'userEarnedReward':
|
|
277
|
+
* console.log('광고 보상 획득 unitType:', event.data.unitType);
|
|
278
|
+
* console.log('광고 보상 획득 unitAmount:', event.data.unitAmount);
|
|
279
|
+
* break;
|
|
280
|
+
*
|
|
281
|
+
* case 'show':
|
|
282
|
+
* console.log('광고 컨텐츠 보여졌음');
|
|
283
|
+
* break;
|
|
284
|
+
* }
|
|
285
|
+
* },
|
|
286
|
+
* onError: (error) => {
|
|
287
|
+
* console.error('광고 보여주기 실패', error);
|
|
288
|
+
* },
|
|
289
|
+
* });
|
|
290
|
+
* }, []);
|
|
291
|
+
*
|
|
292
|
+
* useFocusEffect(loadAd);
|
|
293
|
+
*
|
|
294
|
+
* return (
|
|
295
|
+
* <View>
|
|
296
|
+
* <Text>
|
|
297
|
+
* {adLoadStatus === 'not_loaded' && '광고 로드 하지 않음 '}
|
|
298
|
+
* {adLoadStatus === 'loaded' && '광고 로드 완료'}
|
|
299
|
+
* {adLoadStatus === 'failed' && '광고 로드 실패'}
|
|
300
|
+
* </Text>
|
|
301
|
+
*
|
|
302
|
+
* <Button title="Show Ad" onPress={showAd} disabled={adLoadStatus !== 'loaded'} />
|
|
303
|
+
* </View>
|
|
304
|
+
* );
|
|
305
|
+
* }
|
|
306
|
+
* ```
|
|
307
|
+
*/
|
|
308
|
+
export function showAppsInTossAdMob(params: ShowAdMobParams) {
|
|
309
|
+
if (!showAppsInTossAdMob.isSupported()) {
|
|
310
|
+
params.onError(new Error(UNSUPPORTED_ERROR_MESSAGE));
|
|
311
|
+
return noop;
|
|
312
|
+
}
|
|
313
|
+
|
|
314
|
+
const { onEvent, onError, options } = params;
|
|
315
|
+
|
|
316
|
+
const unregisterCallbacks = INTERNAL__appBridgeHandler.invokeAppBridgeMethod('showAppsInTossAdmob', options, {
|
|
317
|
+
onAdClicked: () => {
|
|
318
|
+
onEvent({ type: 'clicked' });
|
|
319
|
+
},
|
|
320
|
+
onAdDismissed: () => {
|
|
321
|
+
onEvent({ type: 'dismissed' });
|
|
322
|
+
},
|
|
323
|
+
onAdFailedToShow: () => {
|
|
324
|
+
onEvent({ type: 'failedToShow' });
|
|
325
|
+
},
|
|
326
|
+
onAdImpression: () => {
|
|
327
|
+
onEvent({ type: 'impression' });
|
|
328
|
+
},
|
|
329
|
+
onAdShow: () => {
|
|
330
|
+
onEvent({ type: 'show' });
|
|
331
|
+
},
|
|
332
|
+
onUserEarnedReward: (data: { unitType: string; unitAmount: number }) => {
|
|
333
|
+
onEvent({ type: 'userEarnedReward', data });
|
|
334
|
+
},
|
|
335
|
+
onSuccess: () => onEvent({ type: 'requested' }),
|
|
336
|
+
onError,
|
|
337
|
+
});
|
|
338
|
+
|
|
339
|
+
return unregisterCallbacks;
|
|
340
|
+
}
|
|
341
|
+
|
|
342
|
+
// MARK: - isSupported
|
|
343
|
+
|
|
344
|
+
const ANDROID_GOOGLE_AD_MOB_SUPPORTED_VERSION = '5.227.0';
|
|
345
|
+
const IOS_GOOGLE_AD_MOB_SUPPORTED_VERSION = '5.227.0';
|
|
346
|
+
const UNSUPPORTED_ERROR_MESSAGE = 'This feature is not supported in the current environment';
|
|
347
|
+
const ENVIRONMENT = getOperationalEnvironment();
|
|
348
|
+
|
|
349
|
+
function createIsSupported() {
|
|
350
|
+
return () => {
|
|
351
|
+
if (ENVIRONMENT !== 'toss') {
|
|
352
|
+
return false;
|
|
353
|
+
}
|
|
354
|
+
|
|
355
|
+
return isMinVersionSupported({
|
|
356
|
+
android: ANDROID_GOOGLE_AD_MOB_SUPPORTED_VERSION,
|
|
357
|
+
ios: IOS_GOOGLE_AD_MOB_SUPPORTED_VERSION,
|
|
358
|
+
});
|
|
359
|
+
};
|
|
360
|
+
}
|
|
361
|
+
|
|
362
|
+
loadAppsInTossAdMob.isSupported = createIsSupported();
|
|
363
|
+
showAppsInTossAdMob.isSupported = createIsSupported();
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @public
|
|
3
|
+
* @category 광고
|
|
4
|
+
* @name AdMobFullScreenEvent
|
|
5
|
+
* @description 앱 화면을 덮는 광고(예: 전면 광고, 보상형 광고)를 사용하는 경우에 발생하는 이벤트 타입이에요.
|
|
6
|
+
* @example
|
|
7
|
+
* ### 광고 이벤트 처리하기
|
|
8
|
+
* ```ts
|
|
9
|
+
* function handleEvent(event: AdMobFullScreenEvent) {
|
|
10
|
+
* switch (event.type) {
|
|
11
|
+
* case 'clicked':
|
|
12
|
+
* console.log('광고가 클릭됐어요.');
|
|
13
|
+
* break;
|
|
14
|
+
*
|
|
15
|
+
* case 'dismissed':
|
|
16
|
+
* console.log('광고가 닫혔어요.');
|
|
17
|
+
* break;
|
|
18
|
+
*
|
|
19
|
+
* case 'failedToShow':
|
|
20
|
+
* console.log('광고가 보여지지 않았어요.');
|
|
21
|
+
* break;
|
|
22
|
+
*
|
|
23
|
+
* case 'impression':
|
|
24
|
+
* console.log('광고가 노출됐어요.');
|
|
25
|
+
* break;
|
|
26
|
+
*
|
|
27
|
+
* case 'show':
|
|
28
|
+
* console.log('광고가 보여졌어요.');
|
|
29
|
+
* break;
|
|
30
|
+
* }
|
|
31
|
+
* }
|
|
32
|
+
* ```
|
|
33
|
+
*/
|
|
34
|
+
export type AdMobFullScreenEvent = AdClicked | AdDismissed | AdFailedToShow | AdImpression | AdShow;
|
|
35
|
+
|
|
36
|
+
type AdClicked = { type: 'clicked' };
|
|
37
|
+
type AdDismissed = { type: 'dismissed' };
|
|
38
|
+
type AdFailedToShow = { type: 'failedToShow' };
|
|
39
|
+
type AdImpression = { type: 'impression' };
|
|
40
|
+
type AdShow = { type: 'show' };
|
|
41
|
+
|
|
42
|
+
export type AdUserEarnedReward = { type: 'userEarnedReward'; data: { unitType: string; unitAmount: number } };
|
|
43
|
+
|
|
44
|
+
export interface AdMobHandlerParams<Options = void, Event = AdMobFullScreenEvent> {
|
|
45
|
+
options: Options;
|
|
46
|
+
onEvent: (event: Event) => void;
|
|
47
|
+
onError: (error: unknown) => void;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
/**
|
|
51
|
+
* @public
|
|
52
|
+
* @category 광고
|
|
53
|
+
* @name ResponseInfo
|
|
54
|
+
* @description 광고 로드 응답 정보를 담고 있는 객체예요.
|
|
55
|
+
* @property {Array<AdNetworkResponseInfo>} adNetworkInfoArray 광고 네트워크 응답 정보 배열예요.
|
|
56
|
+
* @property {AdNetworkResponseInfo | null} loadedAdNetworkInfo 로드된 광고 네트워크 응답 정보예요.
|
|
57
|
+
* @property {string | null} responseId 광고 응답 ID예요.
|
|
58
|
+
*/
|
|
59
|
+
export interface ResponseInfo {
|
|
60
|
+
adNetworkInfoArray: Array<AdNetworkResponseInfo>;
|
|
61
|
+
loadedAdNetworkInfo: AdNetworkResponseInfo | null;
|
|
62
|
+
responseId: string | null;
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
/**
|
|
66
|
+
* @public
|
|
67
|
+
* @category 광고
|
|
68
|
+
* @name AdNetworkResponseInfo
|
|
69
|
+
* @description 광고 네트워크 응답 정보를 담고 있는 객체예요.
|
|
70
|
+
* @property {string} adSourceId 광고 소스 ID예요.
|
|
71
|
+
* @property {string} adSourceName 광고 소스 이름이예요.
|
|
72
|
+
* @property {string} adSourceInstanceId 광고 소스 인스턴스 ID예요.
|
|
73
|
+
* @property {string} adSourceInstanceName 광고 소스 인스턴스 이름이예요.
|
|
74
|
+
* @property {string | null} adNetworkClassName 광고 네트워크 클래스 이름이예요.
|
|
75
|
+
*/
|
|
76
|
+
export interface AdNetworkResponseInfo {
|
|
77
|
+
adSourceId: string;
|
|
78
|
+
adSourceName: string;
|
|
79
|
+
adSourceInstanceId: string;
|
|
80
|
+
adSourceInstanceName: string;
|
|
81
|
+
adNetworkClassName: string | null;
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
/**
|
|
85
|
+
* @public
|
|
86
|
+
* @category 광고
|
|
87
|
+
* @name InterstitialAd
|
|
88
|
+
* @description 전면 광고의 ID와 응답 정보를 담고 있는 객체예요. 광고를 로드한 뒤, 관련 정보를 확인할 때 유용해요.
|
|
89
|
+
* @property {string} adUnitId 광고 ID예요.
|
|
90
|
+
* @property {ResponseInfo} responseInfo 광고 로드 응답 정보예요. 자세한 내용은 [ResponseInfo](/react-native/reference/native-modules/광고/ResponseInfo.html)를 참고하세요.
|
|
91
|
+
*/
|
|
92
|
+
export interface InterstitialAd {
|
|
93
|
+
adUnitId: string;
|
|
94
|
+
responseInfo: ResponseInfo;
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
/**
|
|
98
|
+
* @public
|
|
99
|
+
* @category 광고
|
|
100
|
+
* @name RewardedAd
|
|
101
|
+
* @description 보상형 광고의 ID와 응답 정보를 담고 있는 객체예요. 광고를 로드한 뒤, 관련 정보를 확인할 때 유용해요.
|
|
102
|
+
* @property {string} adUnitId 광고 ID예요.
|
|
103
|
+
* @property {ResponseInfo} responseInfo 광고 로드 응답 정보예요. 자세한 내용은 [ResponseInfo](/react-native/reference/native-modules/광고/ResponseInfo.html)를 참고하세요.
|
|
104
|
+
*/
|
|
105
|
+
export interface RewardedAd {
|
|
106
|
+
adUnitId: string;
|
|
107
|
+
responseInfo: ResponseInfo;
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
/**
|
|
111
|
+
* @public
|
|
112
|
+
* @category 광고
|
|
113
|
+
* @name AdMobLoadResult
|
|
114
|
+
* @description 광고의 ID와 응답 정보를 담고 있는 객체예요. 광고를 로드한 뒤, 관련 정보를 확인할 때 유용해요.
|
|
115
|
+
* @property {string} adGroupId 광고 그룹 ID예요.
|
|
116
|
+
* @property {string} adUnitId 광고 ID예요.
|
|
117
|
+
* @property {ResponseInfo} responseInfo 광고 로드 응답 정보예요. 자세한 내용은 [ResponseInfo](/react-native/reference/native-modules/광고/ResponseInfo.html)를 참고하세요.
|
|
118
|
+
*/
|
|
119
|
+
export interface AdMobLoadResult {
|
|
120
|
+
adGroupId: string;
|
|
121
|
+
adUnitId: string;
|
|
122
|
+
responseInfo: ResponseInfo;
|
|
123
|
+
}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { AppsInTossModule } from './AppsInTossModule';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* @public
|
|
5
|
+
* @category 로그인
|
|
6
|
+
* @name appLogin
|
|
7
|
+
* @description 토스 인증으로 로그인해요. 로그인이 완료되면 다시 토스 앱으로 이동해요.
|
|
8
|
+
* @example
|
|
9
|
+
*
|
|
10
|
+
* ### 토스 인증을 통해 로그인을 하는 예제
|
|
11
|
+
*
|
|
12
|
+
* ```tsx
|
|
13
|
+
* import { Button } from 'react-native';
|
|
14
|
+
* import { appLogin } from '@apps-in-toss/framework';
|
|
15
|
+
*
|
|
16
|
+
* function Page() {
|
|
17
|
+
* const handleLogin = async () => {
|
|
18
|
+
* const { authorizationCode, referrer } = await appLogin();
|
|
19
|
+
*
|
|
20
|
+
* // 획득한 인가 코드(`authorizationCode`)와 `referrer`를 서버로 전달해요.
|
|
21
|
+
* }
|
|
22
|
+
*
|
|
23
|
+
* return <Button title="로그인" onPress={handleLogin} />;
|
|
24
|
+
* }
|
|
25
|
+
* ```
|
|
26
|
+
*/
|
|
27
|
+
export async function appLogin(): Promise<{ authorizationCode: string; referrer: 'DEFAULT' | 'SANDBOX' }> {
|
|
28
|
+
return AppsInTossModule.appLogin({});
|
|
29
|
+
}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import { AppsInTossModule } from './AppsInTossModule';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* @public
|
|
5
|
+
* @category 토스페이
|
|
6
|
+
* @name CheckoutPaymentOptions
|
|
7
|
+
* @description 토스페이 결제창을 띄울 때 필요한 옵션이에요.
|
|
8
|
+
* @property {string} payToken 결제 토큰이에요.
|
|
9
|
+
*/
|
|
10
|
+
export interface CheckoutPaymentOptions {
|
|
11
|
+
/**
|
|
12
|
+
* 결제 토큰이에요.
|
|
13
|
+
*/
|
|
14
|
+
payToken: string;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* @public
|
|
19
|
+
* @category 토스페이
|
|
20
|
+
* @name CheckoutPaymentResult
|
|
21
|
+
* @description 토스페이 결제창에서 사용자가 인증에 성공했는지 여부예요.
|
|
22
|
+
* @property {boolean} success 인증이 성공했는지 여부예요.
|
|
23
|
+
* @property {string} [reason] 인증이 실패했을 경우의 이유예요.
|
|
24
|
+
*/
|
|
25
|
+
export interface CheckoutPaymentResult {
|
|
26
|
+
/**
|
|
27
|
+
* 인증이 성공했는지 여부예요.
|
|
28
|
+
*/
|
|
29
|
+
success: boolean;
|
|
30
|
+
|
|
31
|
+
/**
|
|
32
|
+
* 인증이 실패했을 경우의 이유예요.
|
|
33
|
+
*/
|
|
34
|
+
reason?: string;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
/**
|
|
38
|
+
* @public
|
|
39
|
+
* @category 토스페이
|
|
40
|
+
* @name checkoutPayment
|
|
41
|
+
* @description 토스페이 결제창을 띄우고, 사용자 인증을 수행해요. 인증이 완료되면 성공 여부를 반환해요.
|
|
42
|
+
*
|
|
43
|
+
* 이 함수는 결제창을 통해 사용자 인증만 해요. 실제 결제 처리는 인증 성공 후 서버에서 별도로 해야 해요.
|
|
44
|
+
*
|
|
45
|
+
* @param {CheckoutPaymentOptions} options 결제창을 띄울 때 필요한 옵션이에요.
|
|
46
|
+
* @returns {Promise<CheckoutPaymentResult>} 인증 성공 여부를 포함한 결과를 반환해요.
|
|
47
|
+
*
|
|
48
|
+
* @example
|
|
49
|
+
*
|
|
50
|
+
* ### 토스페이 결제창 띄우고 인증 처리하기
|
|
51
|
+
*
|
|
52
|
+
* ```tsx
|
|
53
|
+
* import { TossPay } from '@apps-in-toss/framework';
|
|
54
|
+
*
|
|
55
|
+
* async function handlePayment() {
|
|
56
|
+
* try {
|
|
57
|
+
* // 실제 구현 시 결제 생성 역할을 하는 API 엔드포인트로 대체해주세요.
|
|
58
|
+
* const { payToken } = await fetch('/my-api/payment/create').then(res => res.json());
|
|
59
|
+
*
|
|
60
|
+
* const { success, reason } = await TossPay.checkoutPayment({ payToken });
|
|
61
|
+
*
|
|
62
|
+
* if (success) {
|
|
63
|
+
* // 실제 구현 시 결제를 실행하는 API 엔드포인트로 대체해주세요.
|
|
64
|
+
* await fetch('/my-api/payment/execute', {
|
|
65
|
+
* method: 'POST',
|
|
66
|
+
* body: JSON.stringify({ payToken }),
|
|
67
|
+
* headers: { 'Content-Type': 'application/json' },
|
|
68
|
+
* });
|
|
69
|
+
* } else {
|
|
70
|
+
* console.log('인증 실패:', reason);
|
|
71
|
+
* }
|
|
72
|
+
* } catch (error) {
|
|
73
|
+
* console.error('결제 인증 중 오류가 발생했어요:', error);
|
|
74
|
+
* }
|
|
75
|
+
* }
|
|
76
|
+
* ```
|
|
77
|
+
*/
|
|
78
|
+
export async function checkoutPayment(options: CheckoutPaymentOptions): Promise<CheckoutPaymentResult> {
|
|
79
|
+
return AppsInTossModule.checkoutPayment({ params: options });
|
|
80
|
+
}
|