{"id":137998,"date":"2023-04-24T00:00:00","date_gmt":"2023-04-24T00:00:00","guid":{"rendered":"https:\/\/adapty.io\/jp-react-native-in-app-purchases-implementation-tutorial\/"},"modified":"2023-04-24T00:00:00","modified_gmt":"2023-04-24T00:00:00","slug":"react-native-in-app-purchases-implementation-tutorial","status":"publish","type":"post","link":"https:\/\/adapty.io\/ja\/blog\/react-native-in-app-purchases-implementation-tutorial\/","title":{"rendered":"React Native\u30a2\u30d7\u30ea\u5185\u8cfc\u5165: \u30b7\u30f3\u30d7\u30eb\u306a\u5b9f\u88c5\u3002\u30c1\u30e5\u30fc\u30c8\u30ea\u30a2\u30eb"},"content":{"rendered":"\n

\u30af\u30ed\u30b9\u30d7\u30e9\u30c3\u30c8\u30d5\u30a9\u30fc\u30e0\u306e\u30a2\u30d7\u30ea\u958b\u767a\u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u306f\u3001\u958b\u767a\u8005\u306e\u8ca0\u62c5\u3092\u78ba\u5b9f\u306b\u8efd\u6e1b\u3057\u3066\u3001\u4e00\u5ea6\u306b\u8907\u6570\u306e\u30d7\u30e9\u30c3\u30c8\u30d5\u30a9\u30fc\u30e0\u7528\u306e\u30a2\u30d7\u30ea\u3092\u69cb\u7bc9\u3067\u304d\u308b\u3088\u3046\u306b\u3057\u307e\u3059\u3002\u305f\u3060\u3057\u3001\u3044\u304f\u3064\u304b\u306e\u6b20\u70b9\u304c\u3042\u308a\u307e\u3059\u3002\u305f\u3068\u3048\u3070\u3001React Native\u306b\u306f\u3001\u30a2\u30d7\u30ea\u5185\u8cfc\u5165 (in-app purchase) \u3092\u5b9f\u88c5\u3059\u308b\u305f\u3081\u306e\u65e2\u6210\u306e\u30c4\u30fc\u30eb\u304c\u3042\u308a\u307e\u305b\u3093\u3002\u305d\u306e\u305f\u3081\u3001\u5fc5\u7136\u7684\u306b\u30b5\u30fc\u30c9\u30d1\u30fc\u30c6\u30a3\u306e\u30e9\u30a4\u30d6\u30e9\u30ea\u306b\u7740\u76ee\u3059\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n\n\n\n

\u30a2\u30d7\u30ea\u5185\u8cfc\u5165\u306e\u5b9f\u88c5\u306b\u306f\u3069\u306e\u3088\u3046\u306a\u30aa\u30d7\u30b7\u30e7\u30f3\u304c\u3042\u308a\u307e\u3059\u304b\uff1f<\/h2>\n\n\n\n

React Native\u30a2\u30d7\u30ea\u306e\u30a2\u30d7\u30ea\u5185\u30b5\u30d6\u30b9\u30af\u30ea\u30d7\u30b7\u30e7\u30f3 (in-app subscription) \u3067\u4eba\u6c17\u306e\u3042\u308b\u30e9\u30a4\u30d6\u30e9\u30ea\u306f\u3001react-native-iap\u3068expo-in-app-purchases\u3067\u3059\u3002\u305f\u3060\u3057\u3001\u4ed6\u306e\u30e9\u30a4\u30d6\u30e9\u30ea\u3068\u6bd4\u8f03\u3057\u3066\u3001react-native-adapty<\/a>\u306b\u306f\u591a\u6570\u306e\u30e1\u30ea\u30c3\u30c8\u304c\u3042\u308b\u305f\u3081\u3001\u3053\u306e\u30e9\u30a4\u30d6\u30e9\u30ea\u306b\u3064\u3044\u3066\u8aac\u660e\u3057\u307e\u3059\u3002<\/p>\n\n\n\n

\u25cf \u4ed6\u306e\u30e9\u30a4\u30d6\u30e9\u30ea\u3068\u306f\u7570\u306a\u308a\u3001\u30b5\u30fc\u30d0\u30fc\u30d9\u30fc\u30b9 (server-side) \u306e\u8cfc\u5165\u691c\u8a3c (purchase validation) \u306b\u5bfe\u5fdc\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n

\u25cf \u30d7\u30ed\u30e2\u30fc\u30b7\u30e7\u30f3\u30aa\u30d5\u30a1\u30fc<\/a> (promo offer) \u304b\u3089\u524d\u6255\u3044 (pay upfront) \u6a5f\u80fd\u307e\u3067\u3001App Store\u3067\u6700\u8fd1\u5b9f\u88c5\u3055\u308c\u305f\u3059\u3079\u3066\u306e\u6a5f\u80fd\u3092\u30b5\u30dd\u30fc\u30c8\u3057\u3066\u3044\u307e\u3059\u3002\u307e\u305f\u3001\u4eca\u5f8c\u306e\u65b0\u6a5f\u80fd\u3078\u306e\u5bfe\u5fdc\u3082\u8fc5\u901f\u3067\u3059\u3002<\/p>\n\n\n\n

\u25cf \u3088\u308a\u660e\u78ba\u3067\u30b7\u30f3\u30d7\u30eb\u306a\u30b3\u30fc\u30c9\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n\n\n\n

\u25cf \u5b8c\u5168\u306a\u30ea\u30ea\u30fc\u30b9\u30b5\u30a4\u30af\u30eb\u3092\u901a\u904e\u3057\u306a\u304f\u3066\u3082\u3001\u63d0\u4f9b\u3059\u308b\u30d7\u30ed\u30c0\u30af\u30c8\u3092\u5909\u66f4\u3057\u305f\u308a\u3001\u65b0\u3057\u3044\u30aa\u30d5\u30a1\u30fc\u3092\u8ffd\u52a0\u307e\u305f\u306f\u524a\u9664\u3057\u305f\u308a\u3067\u304d\u307e\u3059\u3002\u30d9\u30fc\u30bf\u7248\u3092\u30ea\u30ea\u30fc\u30b9\u3057\u3066\u627f\u8a8d\u3092\u5f85\u3064\u5fc5\u8981\u306f\u3042\u308a\u307e\u305b\u3093\u3002<\/p>\n\n\n\n

\u305d\u306e\u4ed6\u306b\u3082Adapty SDK\u306b\u306f\u3001\u5145\u5b9f\u3057\u305f\u6a5f\u80fd\u304c\u63c3\u3063\u3066\u3044\u307e\u3059\u3002\u3059\u3079\u3066\u306e\u4e3b\u8981\u306a\u6307\u6a19\u3001\u30b3\u30db\u30fc\u30c8\u5206\u6790 (Cohort analysis)\u3001\u30b5\u30fc\u30d0\u30fc\u30d9\u30fc\u30b9\u306e\u8cfc\u5165\u691c\u8a3c\u3001\u30da\u30a4\u30a6\u30a9\u30fc\u30eb (paywall) \u306eA\/B\u30c6\u30b9\u30c8 (A\/B test) \u3001\u67d4\u8edf\u306a\u30bb\u30b0\u30e1\u30f3\u30c6\u30fc\u30b7\u30e7\u30f3\u306b\u3088\u308b\u30d7\u30ed\u30e2\u30fc\u30b7\u30e7\u30f3\u30ad\u30e3\u30f3\u30da\u30fc\u30f3\u3001\u30b5\u30fc\u30c9\u30d1\u30fc\u30c6\u30a3\u306e\u5206\u6790\u30c4\u30fc\u30eb\u306e\u7d71\u5408\u306a\u3069\u3001\u7d44\u307f\u8fbc\u307f\u306e\u5206\u6790\u30c4\u30fc\u30eb\u3092\u5229\u7528\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n

\u8a18\u4e8b\u306e\u5185\u5bb9<\/h2>\n\n\n\n

\u3053\u3053\u3067\u306f\u3001React Native\u30a2\u30d7\u30ea\u3067\u306e\u30a2\u30d7\u30ea\u5185\u8cfc\u5165\u306e\u8a2d\u5b9a\u306b\u3064\u3044\u3066\u8aac\u660e\u3057\u307e\u3059\u3002\u4eca\u56de\u306e\u5185\u5bb9\u306f\u6b21\u306e\u3068\u304a\u308a\u3067\u3059\u3002<\/p>\n\n\n\n

1. React Native\u30a2\u30d7\u30ea\u306e\u30a2\u30d7\u30ea\u5185\u8cfc\u5165\u3067Expo\u3092\u4f7f\u7528\u3067\u304d\u306a\u3044\u7406\u7531<\/p>\n\n\n\n

2. \u30c7\u30d9\u30ed\u30c3\u30d1\u30fc\u30a2\u30ab\u30a6\u30f3\u30c8\u306e\u4f5c\u6210<\/p>\n\n\n\n

3. Adapty\u306e\u8a2d\u5b9a\uff1a<\/p>\n\n\n\n

App Store\u306e\u8a2d\u5b9a<\/p>\n\n\n\n

Play\u30b9\u30c8\u30a2\u306e\u8a2d\u5b9a<\/p>\n\n\n\n

4. \u30b5\u30d6\u30b9\u30af\u30ea\u30d7\u30b7\u30e7\u30f3\u306e\u8ffd\u52a0<\/p>\n\n\n\n

5. \u30da\u30a4\u30a6\u30a9\u30fc\u30eb\u306e\u4f5c\u6210<\/p>\n\n\n\n

6. React Native-adapty\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb<\/p>\n\n\n\n

7. \u30b5\u30f3\u30d7\u30eb\u30a2\u30d7\u30ea\u3068\u7d50\u679c<\/p>\n\n\n\n

\u3053\u306e\u30ac\u30a4\u30c9\u3067\u306f\u3001\u30b5\u30d6\u30b9\u30af\u30ea\u30d7\u30b7\u30e7\u30f3\u30e6\u30fc\u30b6\u30fc\u306b\u732b\u306e\u5199\u771f\u3092\u8868\u793a\u3057\u3066\u3001\u305d\u306e\u4ed6\u306e\u30e6\u30fc\u30b6\u30fc\u306b\u30b5\u30d6\u30b9\u30af\u30ea\u30d7\u30b7\u30e7\u30f3\u306e\u30aa\u30d5\u30a1\u30fc\u3092\u63d0\u793a\u3059\u308b\u30a2\u30d7\u30ea\u306e\u69cb\u7bc9\u3092\u8a66\u307f\u307e\u3059\u3002<\/p>\n\n\n\n\n\n

React Native \u30a2\u30d7\u30ea\u306e\u30a2\u30d7\u30ea\u5185\u8cfc\u5165\u3067Expo\u3092\u4f7f\u7528\u3067\u304d\u306a\u3044\u7406\u7531<\/h3>\n\n\n\n

\u7c21\u5358\u306b\u8a00\u3046\u3068\u3001<\/em>Expo\u306e\u300c\u30de\u30cd\u30fc\u30b8\u30c9\u300d<\/em><\/a>\u306f\u3001App Store\u304c\u63d0\u4f9b\u3059\u308b\u8cfc\u5165\u51e6\u7406\u7528\u306e\u30cd\u30a4\u30c6\u30a3\u30d6\u30e1\u30bd\u30c3\u30c9 (\u5225\u540dStoreKit) \u3092\u30b5\u30dd\u30fc\u30c8\u3057\u3066\u3044\u307e\u305b\u3093\u3002\u5f15\u304d\u7d9a\u304dReact Native\u3092\u4f7f\u7528\u3059\u308b\u304b\u3001Expo Bare Workflow\u3092\u4f7f\u7528\u3059\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002<\/em><\/p>\n\n\n\n

Expo\u306e\u4f7f\u7528\u3092\u691c\u8a0e\u3057\u3066\u3044\u305f\u65b9\u306f\u304c\u3063\u304b\u308a\u3059\u308b\u304b\u3082\u3057\u308c\u307e\u305b\u3093\u304c\u3001\u4f7f\u3046\u3053\u3068\u306f\u3067\u304d\u307e\u305b\u3093\u3002 Expo\u306f\u3001\u30a2\u30d7\u30ea\u958b\u767a\u3092\u52b9\u7387\u5316\u3059\u308bReact Native\u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u3067\u3059\u3002\u305f\u3060\u3057\u3001\u30de\u30cd\u30fc\u30b8\u30c9\u30ef\u30fc\u30af\u30d5\u30ed\u30fc\u306f\u3001\u8cfc\u5165\u3084\u30b5\u30d6\u30b9\u30af\u30ea\u30d7\u30b7\u30e7\u30f3\u306e\u51e6\u7406\u3068\u4e92\u63db\u6027\u304c\u3042\u308a\u307e\u305b\u3093\u3002Expo\u3067\u306f\u3001StoreKit\u306b\u5fc5\u8981\u306a\u30e1\u30bd\u30c3\u30c9\u3068\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8 (\u4e21\u65b9\u3068\u3082JavaScript\u306e\u307f) \u3067\u30cd\u30a4\u30c6\u30a3\u30d6\u30b3\u30fc\u30c9\u3092\u4f7f\u7528\u3057\u307e\u305b\u3093\u3002\u30e2\u30d0\u30a4\u30eb\u30b9\u30c8\u30a2\u3067JavaScript\u3092\u4f7f\u7528\u3057\u3066\u30a2\u30d7\u30ea\u5185\u8cfc\u5165\u3092\u5b9f\u88c5\u3059\u308b\u65b9\u6cd5\u306f\u306a\u3044\u305f\u3081\u3001\u300c\u30a4\u30b8\u30a7\u30af\u30c8\u300d\u3059\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n\n\n\n

\u30c7\u30d9\u30ed\u30c3\u30d1\u30fc\u30a2\u30ab\u30a6\u30f3\u30c8\u306e\u4f5c\u6210<\/h2>\n\n\n\n

\u307e\u305a\u3001App Store\u30a2\u30ab\u30a6\u30f3\u30c8\u3092\u4f5c\u6210\u3057\u3066\u3001iOS\u3068Android \u306e\u4e21\u65b9\u3067\u8cfc\u5165\u3068\u30b5\u30d6\u30b9\u30af\u30ea\u30d7\u30b7\u30e7\u30f3\u3092\u4f5c\u6210\u3057\u3066\u8a2d\u5b9a\u3059\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u300220\u5206\u4ee5\u5185\u3067\u5b8c\u4e86\u3067\u304d\u308b\u306f\u305a\u3067\u3059\u3002<\/p>\n\n\n\n

App Store Connect\u3084Google Play Console\u3067\u30c7\u30d9\u30ed\u30c3\u30d1\u30fc\u30a2\u30ab\u30a6\u30f3\u30c8\u3068\u30d7\u30ed\u30c0\u30af\u30c8\u3092\u307e\u3060\u8a2d\u5b9a\u3057\u3066\u3044\u306a\u3044\u5834\u5408\u306f\u3001\u6b21\u306e\u30ac\u30a4\u30c9\u3092\u53c2\u7167\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n\n\n\n

\u25cf iOS<\/a>\u306e\u5834\u5408\uff1a\u30ac\u30a4\u30c9\u306e\u6700\u521d\u304b\u3089\u300cSKProduct\u306e\u30ea\u30b9\u30c8\u306e\u53d6\u5f97\u300d\u306e\u898b\u51fa\u3057\u307e\u3067\u304a\u8aad\u307f\u304f\u3060\u3055\u3044\u3002\u305d\u306e\u5f8c\u3001\u30cd\u30a4\u30c6\u30a3\u30d6\u5b9f\u88c5\u306b\u3064\u3044\u3066\u8aac\u660e\u3057\u307e\u3059\u3002<\/p>\n\n\n\n

\u25cf Android<\/a>\u306e\u5834\u5408\uff1a\u30ac\u30a4\u30c9\u306e\u6700\u521d\u304b\u3089\u300c\u30a2\u30d7\u30ea\u5185\u306e\u30d7\u30ed\u30c0\u30af\u30c8\u30ea\u30b9\u30c8\u306e\u53d6\u5f97\u300d\u306e\u898b\u51fa\u3057\u307e\u3067\u304a\u8aad\u307f\u304f\u3060\u3055\u3044\u3002<\/p>\n\n\n\n

Adapty\u306e\u8a2d\u5b9a<\/h2>\n\n\n\n

react-native-adapty\u306e\u5834\u5408\u3001\u6700\u521d\u306bAdapty\u30c0\u30c3\u30b7\u30e5\u30dc\u30fc\u30c9\u3092\u8a2d\u5b9a\u3059\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002\u305d\u308c\u307b\u3069\u6642\u9593\u306f\u304b\u304b\u308a\u307e\u305b\u3093\u304c\u3001Adapty\u304c\u30cf\u30fc\u30c9\u30b3\u30fc\u30c7\u30a3\u30f3\u30b0\u3088\u308a\u3082\u512a\u308c\u3066\u3044\u308b\u3068\u3044\u3046\u4e0a\u8a18\u306e\u3059\u3079\u3066\u306e\u30e1\u30ea\u30c3\u30c8\u3092\u5f97\u3089\u308c\u307e\u3059\u3002<\/p>\n\n\n\n

3\u756a\u76ee\u306e\u624b\u9806\u3067\u306f\u3001App Store\u3068Google Play\u306e\u8a2d\u5b9a\u3092\u6c42\u3081\u3089\u308c\u307e\u3059\u3002<\/p>\n\n\n\n

\"\"<\/figure>\n\n\n\n

iOS\u306e\u5834\u5408\u3001\u6b21\u306e\u3053\u3068\u3092\u884c\u3046\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n\n\n\n

\u25cf \u30d0\u30f3\u30c9\u30ebID\u3092\u6307\u5b9a\u3059\u308b<\/p>\n\n\n\n

\u25cf App Store\u30b5\u30fc\u30d0\u901a\u77e5\u3092\u8a2d\u5b9a\u3059\u308b<\/p>\n\n\n\n

\u25cf App Store Connect\u5171\u6709\u30b7\u30fc\u30af\u30ec\u30c3\u30c8\u3092\u6307\u5b9a\u3059\u308b<\/p>\n\n\n\n

\u3053\u308c\u3089\u306e\u30d5\u30a3\u30fc\u30eb\u30c9\u306f\u3001\u8cfc\u5165\u3092\u5b8c\u4e86\u3059\u308b\u305f\u3081\u306b\u5fc5\u8981\u3067\u3059\u3002<\/p>\n\n\n\n

\u5404\u30d5\u30a3\u30fc\u30eb\u30c9\u306b\u306f\u3001\u624b\u9806\u3054\u3068\u306e\u65b9\u6cd5\u3092\u542b\u3080\u300c\u8aac\u660e\u300d\u306e\u30d2\u30f3\u30c8\u304c\u3042\u308a\u307e\u3059\u3002\u4e0d\u660e\u306a\u70b9\u304c\u3042\u308b\u5834\u5408\u306f\u3001\u3053\u308c\u3089\u306e\u30d2\u30f3\u30c8\u3092\u78ba\u8a8d\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n\n\n\n

\u30d0\u30f3\u30c9\u30ebID\u306f\u3001\u30a2\u30d7\u30ea\u306e\u4e00\u610f\u306eID\u3067\u3059\u3002 Xcode\u306e [Targets] > [App Name] > [General]<\/em> \u3067\u6307\u5b9a\u3057\u305fID\u3068\u4e00\u81f4\u3059\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n\n\n\n

\"\"<\/figure>\n\n\n\n

Android\u306e\u5834\u5408\u3001\u5fc5\u9808\u30d5\u30a3\u30fc\u30eb\u30c9\u306f\u300c\u30d1\u30c3\u30b1\u30fc\u30b8\u540d\u300d\u3068\u300c\u30b5\u30fc\u30d3\u30b9\u30a2\u30ab\u30a6\u30f3\u30c8\u30ad\u30fc\u30d5\u30a1\u30a4\u30eb\u300d\u3067\u3059\u3002\u3053\u308c\u3089\u3059\u3079\u3066\u306e\u30d5\u30a3\u30fc\u30eb\u30c9\u306b\u306f\u3001\u8aac\u660e\u306b\u95a2\u3059\u308b\u30d2\u30f3\u30c8\u304c\u3042\u308a\u307e\u3059\u3002Android\u3067\u306e\u30d1\u30c3\u30b1\u30fc\u30b8\u540d\u306f\u3001iOS\u3067\u306e\u30d0\u30f3\u30c9\u30ebID\u306b\u5bfe\u5fdc\u3057\u3066\u3044\u307e\u3059\u3002\u30b3\u30fc\u30c9\u3067\u6307\u5b9a\u3057\u305f\u3082\u306e\u3068\u4e00\u81f4\u3059\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002\u3053\u308c\u306f\u3001android.defaultConfig.applicationId\u306e\/android\/app\/build.gradle\u30d5\u30a1\u30a4\u30eb\u3067\u78ba\u8a8d\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n

\"\"<\/figure>\n\n\n\n

4\u756a\u76ee\u306e\u624b\u9806\u3067\u306f\u3001Adapty SDK\u3092\u30a2\u30d7\u30ea\u306b\u9023\u643a\u3059\u308b\u3088\u3046\u6c42\u3081\u3089\u308c\u307e\u3059\u3002\u305f\u3060\u3057\u3001\u5f8c\u3067\u8aac\u660e\u3059\u308b\u305f\u3081\u3001\u4eca\u306f\u3053\u306e\u624b\u9806\u3092\u98db\u3070\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n\n\n\n

\u65b0\u898f\u767b\u9332\u3057\u305f\u3089\u3001[\u8a2d\u5b9a] \u30bf\u30d6\u3092\u78ba\u8a8d\u3057\u3066\u304f\u3060\u3055\u3044\u3002\u3053\u3053\u306b\u30d1\u30d6\u30ea\u30c3\u30afSDK\u30ad\u30fc\u304c\u8868\u793a\u3055\u308c\u3066\u3044\u308b\u305f\u3081\u3001\u899a\u3048\u3066\u304a\u304d\u307e\u3057\u3087\u3046\u3002\u30ad\u30fc\u306f\u5f8c\u3067\u5fc5\u8981\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n\n\n\n

\"\"<\/figure>\n\n\n\n

\u30b5\u30d6\u30b9\u30af\u30ea\u30d7\u30b7\u30e7\u30f3\u306e\u8ffd\u52a0<\/strong><\/p>\n\n\n\n

Adapty\u3067\u306f\u3001\u3055\u307e\u3056\u307e\u306a\u30b5\u30d6\u30b9\u30af\u30ea\u30d7\u30b7\u30e7\u30f3\u306e\u30d7\u30ed\u30c0\u30af\u30c8\u3092\u4f7f\u7528\u3057\u307e\u3059\u3002\u732b\u306e\u5199\u771f\u306e\u30b5\u30d6\u30b9\u30af\u30ea\u30d7\u30b7\u30e7\u30f3\u30d7\u30e9\u30f3\u306f\u3001\u6bce\u9031\u3001\u534a\u5e74\u3054\u3068\u3001\u307e\u305f\u306f\u6bce\u5e74\u306e\u3044\u305a\u308c\u304b\u3067\u3059\u3002\u3053\u308c\u3089\u306e\u30aa\u30d7\u30b7\u30e7\u30f3\u306f\u3001\u305d\u308c\u305e\u308c\u500b\u5225\u306eAdapty\u30d7\u30ed\u30c0\u30af\u30c8\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n\n\n\n

\u30c0\u30c3\u30b7\u30e5\u30dc\u30fc\u30c9\u3067\u3001\u30d7\u30ed\u30c0\u30af\u30c8\u304c1\u3064\u3042\u308b\u3053\u3068\u3092\u6307\u5b9a\u3057\u307e\u3057\u3087\u3046\u3002[Products & A\/B Tests] \u2192 [Products] \u3092\u30af\u30ea\u30c3\u30af\u3057\u3001[Create product] \u3092\u30af\u30ea\u30c3\u30af\u3057\u307e\u3059\u3002<\/p>\n\n\n\n

\u3053\u3053\u3067\u306f\u3001\u30d7\u30ed\u30c0\u30af\u30c8\u540d\u3001\u3064\u307e\u308a\u30b5\u30d6\u30b9\u30af\u30ea\u30d7\u30b7\u30e7\u30f3\u304cAdapty\u30c0\u30c3\u30b7\u30e5\u30dc\u30fc\u30c9\u3067\u3069\u306e\u3088\u3046\u306b\u8868\u793a\u3055\u308c\u308b\u304b\u3092\u6307\u5b9a\u3059\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n\n\n\n

App Store\u30d7\u30ed\u30c0\u30af\u30c8ID \u3068 Play Store\u30a2\u30a4\u30c6\u30e0ID \u3082\u6307\u5b9a\u3059\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002\u5fc5\u8981\u306b\u5fdc\u3058\u3066\u3001\u671f\u9593\u3068\u5206\u6790\u7528\u306e\u540d\u524d\u3082\u6307\u5b9a\u3057\u307e\u3059\u3002[Save] \u3092\u30af\u30ea\u30c3\u30af\u3057\u307e\u3059\u3002<\/p>\n\n\n\n

\"\"<\/figure>\n\n\n\n

\u30da\u30a4\u30a6\u30a9\u30fc\u30eb\u306e\u4f5c\u6210<\/h2>\n\n\n\n

\u3053\u3053\u3067\u306f\u3001\u30e6\u30fc\u30b6\u30fc\u306e\u6709\u6599\u6a5f\u80fd\u3078\u306e\u30a2\u30af\u30bb\u30b9\u6a29\u3092\u5236\u9650\u3057\u3066\u3001\u30b5\u30d6\u30b9\u30af\u30ea\u30d7\u30b7\u30e7\u30f3\u306e\u30aa\u30d5\u30a1\u30fc\u3092\u8868\u793a\u3059\u308b\u753b\u9762\u3068\u3057\u3066\u3001\u30da\u30a4\u30a6\u30a9\u30fc\u30eb\u3092\u8a2d\u8a08\u3059\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002\u4f5c\u6210\u3057\u305f\u30d7\u30ed\u30c0\u30af\u30c8\u3092\u30da\u30a4\u30a6\u30a9\u30fc\u30eb\u306b\u8ffd\u52a0\u3059\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002\u3053\u308c\u3092\u884c\u3046\u306b\u306f\u3001\u540c\u3058\u30bb\u30af\u30b7\u30e7\u30f3 ([Products & A\/B Tests] \u2192 [Paywalls]) \u3067 [Create paywall] \u3092\u30af\u30ea\u30c3\u30af\u3057\u307e\u3059\u3002<\/p>\n\n\n\n

\u25cf \u540d\u524d\u3092\u898b\u305f\u3060\u3051\u3067\u3001\u3069\u306e\u30da\u30a4\u30a6\u30a9\u30fc\u30eb\u3067\u3042\u308b\u304b\u3092\u7c21\u5358\u306b\u63a8\u6e2c\u3067\u304d\u308b\u3088\u3046\u306a\u30da\u30a4\u30a6\u30a9\u30fc\u30eb\u540d\u3092\u9078\u629e\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n\n\n\n

\u25cf \u30da\u30a4\u30a6\u30a9\u30fc\u30ebID\u3092\u4f7f\u7528\u3057\u3066\u3001\u3053\u306e\u30da\u30a4\u30a6\u30a9\u30fc\u30eb\u3092\u30a2\u30d7\u30ea\u306b\u8868\u793a\u3057\u307e\u3059\u3002\u30b5\u30f3\u30d7\u30eb\u30a2\u30d7\u30ea\u3067\u306f\u3001\u300ccats_paywall\u300d\u3092\u4f7f\u7528\u3057\u307e\u3059\u3002<\/p>\n\n\n\n

\u25cf [Product] \u30c9\u30ed\u30c3\u30d7\u30c0\u30a6\u30f3\u3067\u3001\u30b5\u30d6\u30b9\u30af\u30ea\u30d7\u30b7\u30e7\u30f3\u3092\u9078\u629e\u3057\u307e\u3059\u3002<\/p>\n\n\n\n

[Save & publish] \u3092\u30af\u30ea\u30c3\u30af\u3057\u307e\u3059\u3002<\/p>\n\n\n\n

\"\"<\/figure>\n\n\n\n

\u8a2d\u5b9a\u306f\u4ee5\u4e0a\u3067\u3059\u3002\u6b21\u306b\u3001\u4f9d\u5b58\u95a2\u4fc2\u3092\u8ffd\u52a0\u3057\u3066\u30b3\u30fc\u30c9\u3092\u8a18\u8ff0\u3057\u307e\u3059\u3002<\/p>\n\n\n\n

react-native-adapty\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb<\/h2>\n\n\n\n

1. \u307e\u305a\u3001\u4f9d\u5b58\u95a2\u4fc2\u3092\u8ffd\u52a0\u3057\u307e\u3059\u3002<\/p>\n\n\n\n

<\/path><\/path><\/svg><\/span>
yarn<\/span> <\/span>add<\/span> <\/span>react-native-adapty<\/span><\/span><\/code><\/pre><\/div>\n\n\n\n

2. iOS\u30dd\u30c3\u30c9\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u307e\u3059\u3002CLI\u30dd\u30c3\u30c9\u3092\u304a\u6301\u3061\u3067\u306a\u3044\u5834\u5408\u306f\u3001\u30c0\u30a6\u30f3\u30ed\u30fc\u30c9<\/a>\u3059\u308b\u3053\u3068\u3092\u5f37\u304f\u304a\u52e7\u3081\u3057\u307e\u3059\u3002iOS\u958b\u767a\u3067\u306f\u3001\u78ba\u304b\u306b\u591a\u304f\u306e\u30dd\u30c3\u30c9\u304c\u5fc5\u8981\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n\n\n\n

<\/path><\/path><\/svg><\/span>
#pods get installed into the native iOS project, which, by default, is the \/ios folderpod install --project-directory=ios<\/span><\/span><\/code><\/pre><\/div>\n\n\n\n

3. iOS React Native\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306fObj-C\u3067\u8a18\u8ff0\u3055\u308c\u3066\u3044\u308b\u305f\u3081\u3001Obj-C\u304cSwift\u30e9\u30a4\u30d6\u30e9\u30ea\u3092\u8aad\u307f\u53d6\u308c\u308b\u3088\u3046\u306b\u3001Swift Bridging Header\u3092\u4f5c\u6210\u3059\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002\u305d\u306e\u305f\u3081\u306b\u306f\u3001Xcode\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3092\u958b\u3044\u3066\u65b0\u3057\u3044Swift\u30d5\u30a1\u30a4\u30eb\u3092\u4f5c\u6210\u3059\u308b\u3060\u3051\u3067\u3059\u3002Xcode\u3067\u306f\u3001Swift Bridging Header\u3092\u4f5c\u6210\u3059\u308b\u304b\u3069\u3046\u304b\u3092\u5c0b\u306d\u3089\u308c\u308b\u305f\u3081\u3001[Create] \u3092\u30af\u30ea\u30c3\u30af\u3057\u307e\u3059\u3002<\/p>\n\n\n\n

\"\"<\/figure>\n\n\n\n
\"\"<\/figure>\n\n\n\n

4. Android \u306e\u5834\u5408\u3001\u30d7\u30ed\u30b8\u30a7\u30af\u30c8 (\u30c7\u30d5\u30a9\u30eb\u30c8\u3067\u306f\u300c\/android\/build.gradle\u300d) \u304c\u30d0\u30fc\u30b8\u30e7\u30f31.4.0\u4ee5\u964d\u306ekotlin-gradle-plugin\u3092\u4f7f\u7528\u3057\u3066\u3044\u308b\u3053\u3068\u3092\u78ba\u8a8d\u3057\u307e\u3059\u3002<\/p>\n\n\n\n

<\/path><\/path><\/svg><\/span>
...<\/span> <\/span>buildscript<\/span> <\/span>{<\/span> <\/span><\/span>\n  <\/span>...<\/span> <\/span>dependencies<\/span> <\/span>{<\/span> <\/span><\/span>\n    <\/span>...<\/span> <\/span>classpath<\/span> <\/span>"<\/span>org.jetbrains.kotlin:kotlin-gradle-plugin:1.4.0<\/span>"<\/span> <\/span><\/span>\n  <\/span>}<\/span> <\/span><\/span>\n}<\/span> <\/span>...<\/span><\/span><\/code><\/pre><\/div>\n\n\n\n

5. Android\u306e\u5834\u5408\u3001\u30a2\u30d7\u30ea\u306e\u8a2d\u5b9a\u30d5\u30a1\u30a4\u30eb (\u30c7\u30d5\u30a9\u30eb\u30c8\u3067\u306f\u300c\/android\/app\/build.gradle\u300d) \u306b\u3042\u308bmultiDex\u3092\u6709\u52b9\u306b\u3059\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n\n\n\n

<\/path><\/path><\/svg><\/span>
...<\/span> <\/span><\/span>\nandroid<\/span> <\/span>{<\/span> <\/span><\/span>\n  <\/span>...<\/span> <\/span>defaultConfig<\/span> <\/span>{<\/span> <\/span><\/span>\n    <\/span>...<\/span> <\/span>multiDexEnabled<\/span> <\/span>true<\/span> <\/span><\/span>\n  <\/span>}<\/span> <\/span><\/span>\n}<\/span><\/span><\/code><\/pre><\/div>\n\n\n\n

\u3053\u308c\u3067\u6e96\u5099\u304c\u5b8c\u4e86\u3057\u305f\u306e\u3067\u3001\u30b3\u30fc\u30c7\u30a3\u30f3\u30b0\u3092\u958b\u59cb\u3067\u304d\u308b\u3088\u3046\u306b\u306a\u308a\u307e\u3057\u305f <\/p>\n\n\n\n

\u30a2\u30d7\u30ea\u3067\u306e\u30d7\u30ed\u30c0\u30af\u30c8\u30ea\u30b9\u30c8\u306e\u53d6\u5f97<\/h2>\n\n\n\n

react-native-adapty<\/em>\u306b\u306f\u3001\u3055\u307e\u3056\u307e\u306a\u4fbf\u5229\u306a\u6a5f\u80fd\u304c\u3042\u308a\u307e\u3059\u3002\u9045\u304b\u308c\u65e9\u304b\u308c\u5fc5\u305a\u5fc5\u8981\u306b\u306a\u308b\u305f\u3081\u3001\u30d5\u30ed\u30fc\u306e\u6700\u521d\u3067\u30e9\u30a4\u30d6\u30e9\u30ea\u3092\u521d\u671f\u5316\u3059\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002\u30a2\u30d7\u30ea\u306e\u30b3\u30fc\u30c7\u30a3\u30f3\u30b0\u753b\u9762\u3067\u4e0a\u306b\u30b9\u30af\u30ed\u30fc\u30eb\u3057\u3066 (App.tsx\u3067\u3082\u540c\u69d8\u306b\u5b9f\u884c\u3067\u304d\u307e\u3059)\u3001\u521d\u671f\u5316\u3092\u958b\u59cb\u3057\u307e\u3057\u3087\u3046\u3002<\/p>\n\n\n\n

<\/path><\/path><\/svg><\/span>
\/\/ import the method<\/span><\/span>\nimport<\/span> <\/span>{<\/span> <\/span>activateAdapty<\/span> <\/span>}<\/span> <\/span>from<\/span> <\/span>'<\/span>react-native-adapty<\/span>'<\/span>;<\/span><\/span>\n<\/span>\n\/\/ We\u2019ve had this App component in our app\u2019s root<\/span><\/span>\nconst<\/span> <\/span>App<\/span>:<\/span> <\/span>React<\/span>.<\/span>FC<\/span> <\/span>=<\/span> <\/span>()<\/span> <\/span>=><\/span> <\/span>{<\/span><\/span>\n  <\/span>...<\/span><\/span>\n\/\/ we\u2019re invoking it once in a root component on mount<\/span><\/span>\n  <\/span>useEffect<\/span>(<\/span>()<\/span> <\/span>=><\/span> <\/span>{<\/span><\/span>\n    <\/span>activateAdapty<\/span>(<\/span>{<\/span> <\/span>sdkKey<\/span>:<\/span> <\/span>'<\/span>MY_PUBLIC_KEY<\/span>'<\/span> <\/span>}<\/span>)<\/span>;<\/span><\/span>\n  <\/span>},<\/span>[])<\/span>;<\/span><\/span>\n  <\/span>...<\/span><\/span>\n}<\/span><\/span><\/code><\/pre><\/div>\n\n\n\n

\u3053\u3053\u3067\u306f\u3001MY_PUBLIC_KEY\u3092\u30c0\u30c3\u30b7\u30e5\u200b\u200b\u30dc\u30fc\u30c9\u8a2d\u5b9a\u306b\u3042\u308b\u30d1\u30d6\u30ea\u30c3\u30afSDK\u30ad\u30fc\u306b\u7f6e\u304d\u63db\u3048\u307e\u3059\u3002\u5b9f\u969b\u306b\u306f\u3001 activateAdapty()\u30e1\u30bd\u30c3\u30c9\u306f\u8907\u6570\u56de\u3001\u8907\u6570\u306e\u5834\u6240\u3067\u547c\u3073\u51fa\u3059\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u304c\u3001\u5f15\u304d\u7d9a\u304d\u3053\u306e\u65b9\u6cd5\u3092\u4f7f\u7528\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n\n\n\n

\u3053\u308c\u3067\u3001Adapty \u30c0\u30c3\u30b7\u30e5\u30dc\u30fc\u30c9\u306b\u8ffd\u52a0\u3057\u305f\u30d7\u30ed\u30c0\u30af\u30c8\u3092\u53d6\u5f97\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n

<\/path><\/path><\/svg><\/span>
import<\/span> <\/span>{<\/span> <\/span>adapty<\/span> <\/span>}<\/span> <\/span>from<\/span> <\/span>'<\/span>react-native-adapty<\/span>'<\/span>;<\/span><\/span>\n<\/span>\nasync<\/span> <\/span>function<\/span> <\/span>getProducts<\/span>()<\/span> <\/span>{<\/span><\/span>\n\t<\/span>const<\/span> <\/span>{<\/span>paywalls<\/span>,<\/span> <\/span>products<\/span>}<\/span> <\/span>=<\/span> <\/span>await<\/span> <\/span>adapty<\/span>.<\/span>paywalls<\/span>.<\/span>getPaywalls<\/span>()<\/span>;<\/span><\/span>\n<\/span>\n\t<\/span>return<\/span> <\/span>products<\/span>;<\/span><\/span>\n}<\/span><\/span><\/code><\/pre><\/div>\n\n\n\n

\u305d\u308c\u3067\u306f\u3001\u5b9f\u8df5\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u3002\u30da\u30a4\u30a6\u30a9\u30fc\u30eb\u304b\u3089\u30d7\u30ed\u30c0\u30af\u30c8\u3092\u95b2\u89a7\u3057\u3066\u8cfc\u5165\u3067\u304d\u308b\u8efd\u91cf\u30a2\u30d7\u30ea\u3092\u4f5c\u6210\u3057\u3066\u307f\u307e\u3059\u3002<\/p>\n\n\n\n\n\n

\u30b5\u30f3\u30d7\u30eb\u30a2\u30d7\u30ea<\/h2>\n\n\n\n

\u57fa\u672c\u30ed\u30b8\u30c3\u30af\u304c\u8907\u96d1\u306b\u306a\u308a\u3059\u304e\u306a\u3044\u3088\u3046\u306b\u3001\u3053\u3053\u304b\u3089\u5148\u306f\u7c21\u6f54\u306b\u3057\u307e\u3059\u3002\u307e\u305f\u3001TypeScript\u3067\u30b3\u30fc\u30c7\u30a3\u30f3\u30b0\u3057\u3066\u3001\u3069\u306e\u30bf\u30a4\u30d7\u304c\u3069\u3053\u3067\u4f7f\u7528\u3055\u308c\u3066\u3044\u308b\u304b\u3092\u793a\u3057\u307e\u3059\u3002\u30c6\u30b9\u30c8\u306b\u306f\u3001\u61d0\u304b\u3057\u3044iPhone 8\u3092\u4f7f\u7528\u3057\u307e\u3059\u3002iOS 14\u4ee5\u964d\u3001App Store\u3067\u306f\u30a8\u30df\u30e5\u30ec\u30fc\u30bf\u30fc\u3067StoreKit\u3092\u4f7f\u7528\u3059\u308b\u3053\u3068\u304c\u7981\u6b62\u3055\u308c\u308b\u3088\u3046\u306b\u306a\u308a\u307e\u3057\u305f\u3002\u5b9f\u6a5f\u3092\u4f7f\u3063\u3066\u306e\u307f\u30c6\u30b9\u30c8\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n

App.tsx\u30eb\u30fc\u30c8\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8<\/h3>\n\n\n\n

1. \u307e\u305a\u3001\u30da\u30a4\u30a6\u30a9\u30fc\u30eb\u8868\u793a\u30dc\u30bf\u30f3\u3092\u542b\u3080App.tsx<\/em>\u30eb\u30fc\u30c8\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3092\u4f5c\u6210\u3057\u307e\u3057\u3087\u3046\u3002\u3059\u3067\u306breact-native-navigation<\/a>\u304b\u3089\u30ca\u30d3\u30b2\u30fc\u30b7\u30e7\u30f3\u3092\u8a2d\u5b9a\u3057\u3066\u3044\u307e\u3059\u3002\u516c\u5f0f\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u3067\u63a8\u5968\u3055\u308c\u3066\u3044\u308breact-navigation\u30aa\u30d7\u30b7\u30e7\u30f3\u3088\u308a\u3082\u306f\u308b\u304b\u306b\u512a\u308c\u3066\u3044\u308b\u3068\u8003\u3048\u3089\u308c\u307e\u3059\u3002<\/p>\n\n\n\n

\u554f\u984c<\/p>\n\n\n\n

<\/path><\/path><\/svg><\/span>
import<\/span> <\/span>React<\/span>,<\/span> <\/span>{<\/span> <\/span>useEffect<\/span>,<\/span> <\/span>useState<\/span> <\/span>}<\/span> <\/span>from<\/span> <\/span>"<\/span>react<\/span>"<\/span>;<\/span><\/span>\nimport<\/span> <\/span>{<\/span> <\/span>Button<\/span>,<\/span> <\/span>StyleSheet<\/span>,<\/span> <\/span>View<\/span> <\/span>}<\/span> <\/span>from<\/span> <\/span>"<\/span>react-native<\/span>"<\/span>;<\/span><\/span>\nimport<\/span> <\/span>{<\/span> <\/span>adapty<\/span>,<\/span> <\/span>activateAdapty<\/span>,<\/span> <\/span>AdaptyPaywall<\/span> <\/span>}<\/span> <\/span>from<\/span> <\/span>"<\/span>react-native-adapty<\/span>"<\/span>;<\/span><\/span>\n<\/span>\nexport<\/span> <\/span>const<\/span> <\/span>App<\/span>:<\/span> React<\/span>.<\/span>FC <\/span>=<\/span> <\/span>()<\/span> <\/span>=><\/span> <\/span>{<\/span><\/span>\n  <\/span>const<\/span> <\/span>[<\/span>paywalls<\/span>,<\/span> <\/span>setPaywalls<\/span>]<\/span> <\/span>=<\/span> <\/span>useState<\/span><<\/span>AdaptyPaywall[]<\/span>><\/span>([])<\/span>;<\/span><\/span>\n<\/span>\n  <\/span>useEffect<\/span>(<\/span>()<\/span> <\/span>=><\/span> <\/span>{<\/span><\/span>\n    <\/span>async<\/span> <\/span>function<\/span> <\/span>fetchPaywalls<\/span>()<\/span>:<\/span> Promise<\/span><<\/span>void<\/span>><\/span> <\/span>{<\/span><\/span>\n      <\/span>await<\/span> <\/span>activateAdapty<\/span>(<\/span>{<\/span> <\/span>sdkKey<\/span>:<\/span> <\/span>"<\/span>MY_PUBLIC_KEY<\/span>"<\/span> <\/span>}<\/span>)<\/span>;<\/span><\/span>\n<\/span>\n      <\/span>const<\/span> <\/span>result<\/span> <\/span>=<\/span> <\/span>await<\/span> <\/span>adapty<\/span>.<\/span>paywalls<\/span>.<\/span>getPaywalls<\/span>()<\/span>;<\/span><\/span>\n      <\/span>setPaywalls<\/span>(<\/span>result<\/span>.<\/span>paywalls<\/span>)<\/span>;<\/span><\/span>\n    <\/span>}<\/span><\/span>\n<\/span>\n    <\/span>fetchPaywalls<\/span>()<\/span>;<\/span><\/span>\n  <\/span>},<\/span> [])<\/span>;<\/span><\/span>\n<\/span>\n  <\/span>return<\/span> (<\/span><\/span>\n    <\/span><<\/span>View<\/span> <\/span>style<\/span>={<\/span>styles<\/span>.<\/span>container<\/span>}><\/span><\/span>\n      <\/span><<\/span>Button<\/span><\/span>\n        <\/span>title<\/span>=<\/span>"<\/span>Show the paywall<\/span>"<\/span><\/span>\n        <\/span>onPress<\/span>={<\/span>()<\/span> <\/span>=><\/span> <\/span>{<\/span><\/span>\n          <\/span>const<\/span> <\/span>paywall<\/span> <\/span>=<\/span> <\/span>paywalls<\/span>.<\/span>find<\/span>(<\/span><\/span>\n            <\/span>(<\/span>paywall<\/span>)<\/span> <\/span>=><\/span> <\/span>paywall<\/span>.<\/span>developerId<\/span> <\/span>===<\/span> <\/span>"<\/span>cats_paywall<\/span>"<\/span><\/span>\n          )<\/span>;<\/span><\/span>\n<\/span>\n          <\/span>if<\/span> (<\/span>!<\/span>paywall<\/span>) <\/span>{<\/span><\/span>\n            <\/span>return<\/span> <\/span>alert<\/span>(<\/span>"<\/span>There is no such paywall<\/span>"<\/span>)<\/span>;<\/span><\/span>\n          <\/span>}<\/span><\/span>\n\t\t\t\t\t<\/span>\/\/ Switching to a paywall...<\/span><\/span>\n        <\/span>}<\/span>}<\/span><\/span>\n      <\/span>\/><\/span><\/span>\n    <\/span><\/<\/span>View<\/span>><\/span><\/span>\n  )<\/span>;<\/span><\/span>\n}<\/span>;<\/span><\/span>\n<\/span>\nconst<\/span> <\/span>styles<\/span> <\/span>=<\/span> <\/span>StyleSheet<\/span>.<\/span>create<\/span>(<\/span>{<\/span><\/span>\n  <\/span>container<\/span>:<\/span> <\/span>{<\/span> <\/span>flex<\/span>:<\/span> <\/span>1<\/span>,<\/span> <\/span>alignItems<\/span>:<\/span> <\/span>"<\/span>center<\/span>"<\/span>,<\/span> <\/span>justifyContent<\/span>:<\/span> <\/span>"<\/span>center<\/span>"<\/span> <\/span>},<\/span><\/span>\n}<\/span>)<\/span>;<\/span><\/span><\/code><\/pre><\/div>\n\n\n\n

\u4f55\u304c\u8d77\u304d\u3066\u3044\u308b\u306e\u3067\u3057\u3087\u3046\u304b\uff1f\u30de\u30a6\u30f3\u30c8\u6642\u306b\u3001fetchPaywalls()\u95a2\u6570\u304c\u547c\u3073\u51fa\u3055\u308c\u307e\u3059\u3002 SDK \u3092\u30a2\u30af\u30c6\u30a3\u30d9\u30fc\u30b7\u30e7\u30f3\u3057\u3066\u3001\u30da\u30a4\u30a6\u30a9\u30fc\u30eb\u3092\u305d\u306e\u72b6\u614b\u3067\u4fdd\u5b58\u3059\u308b\u305f\u3081\u3001\u30e6\u30fc\u30b6\u30fc\u306f\u30dc\u30bf\u30f3\u3092\u30bf\u30c3\u30d7\u3057\u305f\u5f8c\u306b\u53d6\u5f97\u3055\u308c\u308b\u307e\u3067\u5f85\u3064\u5fc5\u8981\u304c\u3042\u308a\u307e\u305b\u3093\u3002\u30d3\u30e5\u30fc\u306b\u306f\u3001\u30c0\u30c3\u30b7\u30e5\u30dc\u30fc\u30c9\u3067\u4ee5\u524d\u306b\u8a2d\u8a08\u3057\u305f\u30da\u30a4\u30a6\u30a9\u30fc\u30eb\u753b\u9762\u306b\u79fb\u52d5\u3059\u308b\u30dc\u30bf\u30f3\u304c1\u3064\u306e\u307f\u8868\u793a\u3055\u308c\u307e\u3059\u3002<\/p>\n\n\n\n

\u5b9f\u969b\u3001\u30da\u30a4\u30a6\u30a9\u30fc\u30eb\u3092\u72b6\u614b\u306b\u4fdd\u5b58\u305b\u305a\u306b\u3001\u3053\u3053\u3067\u53d6\u5f97\u3059\u308b\u3053\u3068\u306f\u53ef\u80fd\u3067\u3059\u3002\u30c7\u30d5\u30a9\u30eb\u30c8\u3067\u306f\u3001adapty.paywalls.getPaywalls()\u306f (\u8d77\u52d5\u6642\u306b\u30ad\u30e3\u30c3\u30b7\u30e5\u3057\u305f\u5f8c) \u30ad\u30e3\u30c3\u30b7\u30e5\u30b9\u30c8\u30ec\u30fc\u30b8\u304b\u3089\u53d6\u5f97\u3057\u307e\u3059\u3002\u3064\u307e\u308a\u3001\u30e1\u30bd\u30c3\u30c9\u304c\u30b5\u30fc\u30d0\u30fc\u3068\u901a\u4fe1\u3059\u308b\u306e\u3092\u5f85\u3064\u5fc5\u8981\u306f\u3042\u308a\u307e\u305b\u3093\u3002<\/p>\n\n\n\n

\u7d50\u679c\u306f\u6b21\u306e\u3068\u304a\u308a\u3067\u3059\u3002<\/p>\n\n\n

\n
\"react<\/figure><\/div>\n\n\n

\u30da\u30a4\u30a6\u30a9\u30fc\u30eb\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8<\/h3>\n\n\n\n

2. \u540c\u3058\u30d5\u30a1\u30a4\u30eb\u306b\u30da\u30a4\u30a6\u30a9\u30fc\u30eb\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3092\u66f8\u304d\u307e\u3057\u3087\u3046\u3002<\/p>\n\n\n\n

<\/path><\/path><\/svg><\/span>
\/\/ there are more imports here<\/span><\/span>\nimport<\/span> <\/span>React<\/span>,<\/span> <\/span>{<\/span> <\/span>useEffect<\/span>,<\/span> <\/span>useState<\/span> <\/span>}<\/span> <\/span>from<\/span> <\/span>"<\/span>react<\/span>"<\/span>;<\/span><\/span>\nimport<\/span> <\/span>{<\/span><\/span>\n  <\/span>Button<\/span>,<\/span><\/span>\n  <\/span>SafeAreaView<\/span>,<\/span><\/span>\n  <\/span>StyleSheet<\/span>,<\/span><\/span>\n  <\/span>Text<\/span>,<\/span><\/span>\n  <\/span>View<\/span>,<\/span><\/span>\n  <\/span>PlatformColor<\/span>,<\/span><\/span>\n}<\/span> <\/span>from<\/span> <\/span>"<\/span>react-native<\/span>"<\/span>;<\/span><\/span>\nimport<\/span> <\/span>{<\/span><\/span>\n  <\/span>adapty<\/span>,<\/span><\/span>\n  <\/span>activateAdapty<\/span>,<\/span><\/span>\n  <\/span>AdaptyPaywall<\/span>,<\/span><\/span>\n  <\/span>AdaptyProduct<\/span>,<\/span><\/span>\n}<\/span> <\/span>from<\/span> <\/span>"<\/span>react-native-adapty<\/span>"<\/span>;<\/span><\/span>\nimport<\/span> <\/span>{<\/span> <\/span>Navigation<\/span> <\/span>}<\/span> <\/span>from<\/span> <\/span>"<\/span>react-native-navigation<\/span>"<\/span>;<\/span><\/span>\n<\/span>\n\/\/ ...<\/span><\/span>\n<\/span>\ninterface<\/span> <\/span>PaywallProps<\/span> <\/span>{<\/span><\/span>\n  paywall<\/span>:<\/span> <\/span>AdaptyPaywall<\/span>;<\/span><\/span>\n  <\/span>onRequestBuy<\/span>:<\/span> <\/span>(<\/span>product<\/span>:<\/span> <\/span>AdaptyProduct<\/span>)<\/span> <\/span>=><\/span> <\/span>void<\/span> <\/span>|<\/span> <\/span>Promise<\/span><<\/span>void<\/span>><\/span>;<\/span><\/span>\n}<\/span><\/span>\nexport<\/span> <\/span>const<\/span> <\/span>Paywall<\/span>:<\/span> <\/span>React<\/span>.<\/span>FC<\/span><<\/span>PaywallProps<\/span>><\/span> <\/span>=<\/span> <\/span>({<\/span> <\/span>paywall<\/span>,<\/span> <\/span>onRequestBuy<\/span> <\/span>})<\/span> <\/span>=><\/span> <\/span>{<\/span><\/span>\n  <\/span>const<\/span> <\/span>[<\/span>isLoading<\/span>,<\/span> <\/span>setIsLoading<\/span>]<\/span> <\/span>=<\/span> <\/span>useState<\/span><<\/span>boolean<\/span>><\/span>(<\/span>false<\/span>)<\/span>;<\/span><\/span>\n<\/span>\n  <\/span>return<\/span> (<\/span><\/span>\n    <\/span><<\/span>SafeAreaView<\/span> <\/span>style<\/span>=<\/span>{<\/span>styles.<\/span>container<\/span>}<\/span>><\/span><\/span>\n      <\/span>{<\/span>paywall<\/span>.<\/span>products<\/span>.<\/span>map<\/span>((<\/span>product<\/span>) <\/span>=><\/span> (<\/span><\/span>\n        <\/span><<\/span>View<\/span> <\/span>key<\/span>=<\/span>{<\/span>product.<\/span>vendorProductId<\/span>}<\/span>><\/span><\/span>\n          <<\/span>Text<\/span>><\/span>{<\/span>product.<\/span>localizedTitle<\/span>}<\/span><\/<\/span>Text<\/span>><\/span><\/span>\n          <\/span><<\/span>Button<\/span><\/span>\n            <\/span>title<\/span>=<\/span>{<\/span>`<\/span>Buy for \u0437\u0430 <\/span>${<\/span>product<\/span>.<\/span>localizedPrice<\/span>}`<\/span>}<\/span><\/span>\n            <\/span>disabled<\/span>=<\/span>{<\/span>isLoading<\/span>}<\/span><\/span>\n            <\/span>onPress<\/span>=<\/span>{<\/span>async<\/span> <\/span>()<\/span> <\/span>=><\/span> <\/span>{<\/span><\/span>\n              <\/span>try<\/span> <\/span>{<\/span><\/span>\n                <\/span>setIsLoading<\/span>(<\/span>true<\/span>)<\/span>;<\/span><\/span>\n                <\/span>await<\/span> <\/span>onRequestBuy<\/span>(<\/span>product<\/span>)<\/span>;<\/span><\/span>\n              <\/span>}<\/span> catch (error) {<\/span><\/span>\n                <\/span>alert<\/span>(<\/span>"<\/span>Error occured :(<\/span>"<\/span>)<\/span>;<\/span><\/span>\n              <\/span>}<\/span> <\/span>finally<\/span> <\/span>{<\/span><\/span>\n                <\/span>setIsLoading<\/span>(<\/span>false<\/span>)<\/span>;<\/span><\/span>\n              <\/span>}<\/span><\/span>\n            <\/span>}<\/span>}<\/span><\/span>\n          <\/span>\/><\/span><\/span>\n        <\/span><\/<\/span>View<\/span>><\/span><\/span>\n      ))<\/span>}<\/span><\/span>\n    <\/span><\/<\/span>SafeAreaView<\/span>><\/span><\/span>\n  )<\/span>;<\/span><\/span>\n}<\/span>;<\/span><\/span>\n<\/span>\n\/\/ A new key<\/span><\/span>\nconst<\/span> <\/span>styles<\/span> <\/span>=<\/span> <\/span>StyleSheet<\/span>.<\/span>create<\/span>(<\/span>{<\/span><\/span>\n  <\/span>container<\/span>:<\/span> <\/span>{<\/span> <\/span>flex<\/span>:<\/span> <\/span>1<\/span>,<\/span> <\/span>alignItems<\/span>:<\/span> <\/span>"<\/span>center<\/span>"<\/span>,<\/span> <\/span>justifyContent<\/span>:<\/span> <\/span>"<\/span>center<\/span>"<\/span> <\/span>},<\/span><\/span>\n  <\/span>paywallContainer<\/span>:<\/span> <\/span>{<\/span><\/span>\n    <\/span>flex<\/span>:<\/span> <\/span>1<\/span>,<\/span><\/span>\n    <\/span>alignItems<\/span>:<\/span> <\/span>"<\/span>center<\/span>"<\/span>,<\/span><\/span>\n    <\/span>justifyContent<\/span>:<\/span> <\/span>"<\/span>space-evenly<\/span>"<\/span>,<\/span><\/span>\n    <\/span>backgroundColor<\/span>:<\/span> <\/span>PlatformColor<\/span>(<\/span>"<\/span>secondarySystemBackground<\/span>"<\/span>)<\/span>,<\/span><\/span>\n  <\/span>},<\/span><\/span>\n}<\/span>)<\/span>;<\/span><\/span><\/code><\/pre><\/div>\n\n\n\n

\u3053\u3053\u3067\u306f\u3001\u30da\u30a4\u30a6\u30a9\u30fc\u30eb\u304b\u3089\u30d7\u30ed\u30c0\u30af\u30c8\u3092\u30de\u30c3\u30d4\u30f3\u30b0\u3057\u3001\u5404\u30d7\u30ed\u30c0\u30af\u30c8\u306e\u6a2a\u306b\u8cfc\u5165\u30dc\u30bf\u30f3\u3092\u8868\u793a\u3057\u307e\u3059\u3002<\/p>\n\n\n\n

\u753b\u9762\u306e\u767b\u9332<\/h3>\n\n\n\n

3. \u8868\u793a\u3092\u78ba\u8a8d\u3059\u308b\u305f\u3081\u306b\u3001\u3053\u306e\u753b\u9762\u3092react-native-navigation\u306b\u767b\u9332\u3057\u307e\u3057\u3087\u3046\u3002\u4ed6\u306e\u30ca\u30d3\u30b2\u30fc\u30b7\u30e7\u30f3\u3092\u4f7f\u7528\u3057\u3066\u3044\u308b\u5834\u5408\u306f\u3001\u3053\u306e\u624b\u9806\u3092\u30b9\u30ad\u30c3\u30d7\u3057\u3066\u304f\u3060\u3055\u3044\u3002\u30eb\u30fc\u30c8index.js<\/em>\u30d5\u30a1\u30a4\u30eb\u306f\u6b21\u306e\u3088\u3046\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n\n\n\n

<\/path><\/path><\/svg><\/span>
import<\/span> <\/span>"<\/span>react-native-gesture-handler<\/span>"<\/span>;<\/span><\/span>\nimport<\/span> <\/span>{<\/span> <\/span>Navigation<\/span> <\/span>}<\/span> <\/span>from<\/span> <\/span>"<\/span>react-native-navigation<\/span>"<\/span>;<\/span><\/span>\n<\/span>\nimport<\/span> <\/span>{<\/span> <\/span>App<\/span>,<\/span> <\/span>Paywall<\/span> <\/span>}<\/span> <\/span>from<\/span> <\/span>"<\/span>.\/App<\/span>"<\/span>;<\/span><\/span>\n<\/span>\nNavigation<\/span>.<\/span>registerComponent<\/span>(<\/span>"<\/span>Home<\/span>"<\/span>,<\/span> <\/span>()<\/span> <\/span>=><\/span> <\/span>App<\/span>)<\/span>;<\/span><\/span>\nNavigation<\/span>.<\/span>registerComponent<\/span>(<\/span>"<\/span>Paywall<\/span>"<\/span>,<\/span> <\/span>()<\/span> <\/span>=><\/span> <\/span>Paywall<\/span>)<\/span>;<\/span><\/span>\n<\/span>\nNavigation<\/span>.<\/span>events<\/span>()<\/span>.<\/span>registerAppLaunchedListener<\/span>(<\/span>()<\/span> <\/span>=><\/span> <\/span>{<\/span><\/span>\n  <\/span>Navigation<\/span>.<\/span>setRoot<\/span>(<\/span>{<\/span><\/span>\n    <\/span>root<\/span>:<\/span> <\/span>{<\/span> <\/span>stack<\/span>:<\/span> <\/span>{<\/span> <\/span>children<\/span>:<\/span> [<\/span>{<\/span> <\/span>component<\/span>:<\/span> <\/span>{<\/span> <\/span>name<\/span>:<\/span> <\/span>"<\/span>Home<\/span>"<\/span> <\/span>}<\/span> <\/span>}<\/span>] <\/span>}<\/span> <\/span>},<\/span><\/span>\n  <\/span>}<\/span>)<\/span>;<\/span><\/span>\n}<\/span>)<\/span>;<\/span><\/span><\/code><\/pre><\/div>\n\n\n\n

\u300c\u30da\u30a4\u30a6\u30a9\u30fc\u30eb\u3092\u8868\u793a\u3059\u308b\u300d\u30dc\u30bf\u30f3<\/h3>\n\n\n\n

4. \u6b21\u306b\u3001\u300c\u30da\u30a4\u30a6\u30a9\u30fc\u30eb\u3092\u8868\u793a\u3059\u308b\u300d\u30dc\u30bf\u30f3\u306b\u30a2\u30af\u30b7\u30e7\u30f3\u3092\u5272\u308a\u5f53\u3066\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002\u3053\u306e\u5834\u5408\u3001[Navigation] \u3092\u4ecb\u3057\u3066\u30e2\u30fc\u30c0\u30eb\u304c\u8868\u793a\u3055\u308c\u307e\u3059\u3002<\/p>\n\n\n\n

<\/path><\/path><\/svg><\/span>
Navigation<\/span>.<\/span>showModal<\/span><<\/span>PaywallProps<\/span>><\/span>(<\/span>{<\/span><\/span>\n    <\/span>component<\/span>:<\/span> <\/span>{<\/span><\/span>\n      <\/span>name<\/span>:<\/span> <\/span>"<\/span>Paywall<\/span>"<\/span>,<\/span><\/span>\n      <\/span>passProps<\/span>:<\/span> <\/span>{<\/span><\/span>\n        <\/span>paywall<\/span>,<\/span><\/span>\n        <\/span>onRequestBuy<\/span>:<\/span> <\/span>async<\/span> <\/span>(<\/span>product<\/span>)<\/span> <\/span>=><\/span> <\/span>{<\/span><\/span>\n          <\/span>const<\/span> <\/span>purchase<\/span> <\/span>=<\/span> <\/span>await<\/span> <\/span>adapty<\/span>.<\/span>purchases<\/span>.<\/span>makePurchase<\/span>(<\/span>product<\/span>)<\/span>;<\/span><\/span>\n          <\/span>\/\/ Doing everything we need<\/span><\/span>\n          <\/span>console<\/span>.<\/span>log<\/span>(<\/span>"<\/span>purchase<\/span>"<\/span>,<\/span> <\/span>purchase<\/span>)<\/span>;<\/span><\/span>\n        <\/span>},<\/span><\/span>\n      <\/span>},<\/span><\/span>\n    <\/span>},<\/span><\/span>\n  <\/span>}<\/span>)<\/span>;<\/span><\/span><\/code><\/pre><\/div>\n\n\n\n

App.tsx\u30d5\u30a1\u30a4\u30eb\u5168\u4f53\uff1a<\/p>\n\n\n\n

<\/path><\/path><\/svg><\/span>
import<\/span> <\/span>React<\/span>,<\/span> <\/span>{<\/span> <\/span>useEffect<\/span>,<\/span> <\/span>useState<\/span> <\/span>}<\/span> <\/span>from<\/span> <\/span>"<\/span>react<\/span>"<\/span>;<\/span><\/span>\nimport<\/span> <\/span>{<\/span><\/span>\n  <\/span>Button<\/span>,<\/span><\/span>\n  <\/span>SafeAreaView<\/span>,<\/span><\/span>\n  <\/span>StyleSheet<\/span>,<\/span><\/span>\n  <\/span>Text<\/span>,<\/span><\/span>\n  <\/span>View<\/span>,<\/span><\/span>\n  <\/span>PlatformColor<\/span>,<\/span><\/span>\n}<\/span> <\/span>from<\/span> <\/span>"<\/span>react-native<\/span>"<\/span>;<\/span><\/span>\nimport<\/span> <\/span>{<\/span><\/span>\n  <\/span>adapty<\/span>,<\/span><\/span>\n  <\/span>activateAdapty<\/span>,<\/span><\/span>\n  <\/span>AdaptyPaywall<\/span>,<\/span><\/span>\n  <\/span>AdaptyProduct<\/span>,<\/span><\/span>\n}<\/span> <\/span>from<\/span> <\/span>"<\/span>react-native-adapty<\/span>"<\/span>;<\/span><\/span>\nimport<\/span> <\/span>{<\/span> <\/span>Navigation<\/span> <\/span>}<\/span> <\/span>from<\/span> <\/span>"<\/span>react-native-navigation<\/span>"<\/span>;<\/span><\/span>\nexport<\/span> <\/span>const<\/span> <\/span>App<\/span>:<\/span> <\/span>React<\/span>.<\/span>FC<\/span> <\/span>=<\/span> <\/span>()<\/span> <\/span>=><\/span> <\/span>{<\/span><\/span>\n  <\/span>const<\/span> <\/span>[<\/span>paywalls<\/span>,<\/span> <\/span>setPaywalls<\/span>]<\/span> <\/span>=<\/span> <\/span>useState<\/span><<\/span>AdaptyPaywall<\/span>[]<\/span>><\/span>([])<\/span>;<\/span><\/span>\n  <\/span>useEffect<\/span>(<\/span>()<\/span> <\/span>=><\/span> <\/span>{<\/span><\/span>\n    <\/span>async<\/span> <\/span>function<\/span> <\/span>fetchPaywalls<\/span>()<\/span>:<\/span> <\/span>Promise<\/span><<\/span>void<\/span>><\/span> <\/span>{<\/span><\/span>\n      <\/span>await<\/span> <\/span>activateAdapty<\/span>(<\/span>{<\/span><\/span>\n        <\/span>sdkKey<\/span>:<\/span> <\/span>"<\/span>MY_PUBLIC_KEY<\/span>"<\/span>,<\/span><\/span>\n      <\/span>}<\/span>)<\/span>;<\/span><\/span>\n<\/span>\n      <\/span>const<\/span> <\/span>result<\/span> <\/span>=<\/span> <\/span>await<\/span> <\/span>adapty<\/span>.<\/span>paywalls<\/span>.<\/span>getPaywalls<\/span>()<\/span>;<\/span><\/span>\n      <\/span>setPaywalls<\/span>(<\/span>result<\/span>.<\/span>paywalls<\/span>)<\/span>;<\/span><\/span>\n    <\/span>}<\/span><\/span>\n<\/span>\n    <\/span>fetchPaywalls<\/span>()<\/span>;<\/span><\/span>\n  <\/span>},<\/span> [])<\/span>;<\/span><\/span>\n<\/span>\n  <\/span>return<\/span> (<\/span><\/span>\n    <\/span><<\/span>View<\/span> <\/span>style<\/span>=<\/span>{<\/span>styles.<\/span>container<\/span>}<\/span>><\/span><\/span>\n      <\/span><<\/span>Button<\/span><\/span>\n        <\/span>title<\/span>=<\/span>"<\/span>Show paywall<\/span>"<\/span><\/span>\n        <\/span>onPress<\/span>=<\/span>{<\/span>() => <\/span>{<\/span><\/span>\n          <\/span>const<\/span> <\/span>paywall<\/span> <\/span>=<\/span> <\/span>paywalls<\/span>.<\/span>find<\/span>(<\/span><\/span>\n            <\/span>(<\/span>paywall<\/span>)<\/span> <\/span>=><\/span> <\/span>paywall<\/span>.<\/span>developerId<\/span> <\/span>===<\/span> <\/span>"<\/span>cats_paywall<\/span>"<\/span><\/span>\n          )<\/span>;<\/span><\/span>\n<\/span>\n          <\/span>if<\/span> (<\/span>!<\/span>paywall<\/span>) <\/span>{<\/span><\/span>\n            <\/span>return<\/span> <\/span>alert<\/span>(<\/span>"<\/span>There is no such paywall<\/span>"<\/span>)<\/span>;<\/span><\/span>\n          <\/span>}<\/span><\/span>\n<\/span>\n          <\/span>Navigation<\/span>.<\/span>showModal<\/span><<\/span>PaywallProps<\/span>><\/span>(<\/span>{<\/span><\/span>\n            <\/span>component<\/span>:<\/span> <\/span>{<\/span><\/span>\n              <\/span>name<\/span>:<\/span> <\/span>"<\/span>Paywall<\/span>"<\/span>,<\/span><\/span>\n              <\/span>passProps<\/span>:<\/span> <\/span>{<\/span><\/span>\n                <\/span>paywall<\/span>,<\/span><\/span>\n                <\/span>onRequestBuy<\/span>:<\/span> <\/span>async<\/span> <\/span>(<\/span>product<\/span>)<\/span> <\/span>=><\/span> <\/span>{<\/span><\/span>\n                  <\/span>const<\/span> <\/span>purchase<\/span> <\/span>=<\/span> <\/span>await<\/span> <\/span>adapty<\/span>.<\/span>purchases<\/span>.<\/span>makePurchase<\/span>(<\/span>product<\/span>)<\/span>;<\/span><\/span>\n                  <\/span>\/\/ Doing everything we need<\/span><\/span>\n                  <\/span>console<\/span>.<\/span>log<\/span>(<\/span>"<\/span>purchase<\/span>"<\/span>,<\/span> <\/span>purchase<\/span>)<\/span>;<\/span><\/span>\n                <\/span>},<\/span><\/span>\n              <\/span>},<\/span><\/span>\n            <\/span>},<\/span><\/span>\n          <\/span>}<\/span>)<\/span>;<\/span><\/span>\n        <\/span>}}<\/span><\/span>\n      <\/span>\/><\/span><\/span>\n    <\/span><\/<\/span>View<\/span>><\/span><\/span>\n  )<\/span>;<\/span><\/span>\n}<\/span>;<\/span><\/span>\n<\/span>\ninterface<\/span> <\/span>PaywallProps<\/span> <\/span>{<\/span><\/span>\n  paywall<\/span>:<\/span> <\/span>AdaptyPaywall<\/span>;<\/span><\/span>\n  <\/span>onRequestBuy<\/span>:<\/span> <\/span>(<\/span>product<\/span>:<\/span> <\/span>AdaptyProduct<\/span>)<\/span> <\/span>=><\/span> <\/span>void<\/span> <\/span>|<\/span> <\/span>Promise<\/span><<\/span>void<\/span>><\/span>;<\/span><\/span>\n}<\/span><\/span>\nexport<\/span> <\/span>const<\/span> <\/span>Paywall<\/span>:<\/span> <\/span>React<\/span>.<\/span>FC<\/span><<\/span>PaywallProps<\/span>><\/span> <\/span>=<\/span> <\/span>({<\/span> <\/span>paywall<\/span>,<\/span> <\/span>onRequestBuy<\/span> <\/span>})<\/span> <\/span>=><\/span> <\/span>{<\/span><\/span>\n  <\/span>const<\/span> <\/span>[<\/span>isLoading<\/span>,<\/span> <\/span>setIsLoading<\/span>]<\/span> <\/span>=<\/span> <\/span>useState<\/span><<\/span>boolean<\/span>><\/span>(<\/span>false<\/span>)<\/span>;<\/span><\/span>\n<\/span>\n  <\/span>return<\/span> (<\/span><\/span>\n    <\/span><<\/span>SafeAreaView<\/span> <\/span>style<\/span>=<\/span>{<\/span>styles.<\/span>paywallContainer<\/span>}<\/span>><\/span><\/span>\n      <\/span>{<\/span>paywall<\/span>.<\/span>products<\/span>.<\/span>map<\/span>((<\/span>product<\/span>) <\/span>=><\/span> (<\/span><\/span>\n        <\/span><<\/span>View<\/span> <\/span>key<\/span>=<\/span>{<\/span>product.<\/span>vendorProductId<\/span>}<\/span>><\/span><\/span>\n          <<\/span>Text<\/span>><\/span>{<\/span>product.<\/span>localizedTitle<\/span>}<\/span><\/<\/span>Text<\/span>><\/span><\/span>\n          <\/span><<\/span>Button<\/span><\/span>\n            <\/span>title<\/span>=<\/span>{<\/span>`<\/span>Buy for <\/span>${<\/span>product<\/span>.<\/span>localizedPrice<\/span>}`<\/span>}<\/span><\/span>\n            <\/span>disabled<\/span>=<\/span>{<\/span>isLoading<\/span>}<\/span><\/span>\n            <\/span>onPress<\/span>=<\/span>{<\/span>async<\/span> <\/span>()<\/span> <\/span>=><\/span> <\/span>{<\/span><\/span>\n              <\/span>try<\/span> <\/span>{<\/span><\/span>\n                <\/span>setIsLoading<\/span>(<\/span>true<\/span>)<\/span>;<\/span><\/span>\n                <\/span>await<\/span> <\/span>onRequestBuy<\/span>(<\/span>product<\/span>)<\/span>;<\/span><\/span>\n              <\/span>}<\/span> catch (error) {<\/span><\/span>\n                <\/span>alert<\/span>(<\/span>"<\/span>Error occured :(<\/span>"<\/span>)<\/span>;<\/span><\/span>\n              <\/span>}<\/span> <\/span>finally<\/span> <\/span>{<\/span><\/span>\n                <\/span>setIsLoading<\/span>(<\/span>false<\/span>)<\/span>;<\/span><\/span>\n              <\/span>}<\/span><\/span>\n            <\/span>}<\/span>}<\/span><\/span>\n          <\/span>\/><\/span><\/span>\n        <\/span><\/<\/span>View<\/span>><\/span><\/span>\n      ))<\/span>}<\/span><\/span>\n    <\/span><\/<\/span>SafeAreaView<\/span>><\/span><\/span>\n  )<\/span>;<\/span><\/span>\n}<\/span>;<\/span><\/span>\n<\/span>\nconst<\/span> <\/span>styles<\/span> <\/span>=<\/span> <\/span>StyleSheet<\/span>.<\/span>create<\/span>(<\/span>{<\/span><\/span>\n  <\/span>container<\/span>:<\/span> <\/span>{<\/span> <\/span>flex<\/span>:<\/span> <\/span>1<\/span>,<\/span> <\/span>alignItems<\/span>:<\/span> <\/span>"<\/span>center<\/span>"<\/span>,<\/span> <\/span>justifyContent<\/span>:<\/span> <\/span>"<\/span>center<\/span>"<\/span> <\/span>},<\/span><\/span>\n  <\/span>paywallContainer<\/span>:<\/span> <\/span>{<\/span><\/span>\n    <\/span>flex<\/span>:<\/span> <\/span>1<\/span>,<\/span><\/span>\n    <\/span>alignItems<\/span>:<\/span> <\/span>"<\/span>center<\/span>"<\/span>,<\/span><\/span>\n    <\/span>justifyContent<\/span>:<\/span> <\/span>"<\/span>space-evenly<\/span>"<\/span>,<\/span><\/span>\n    <\/span>backgroundColor<\/span>:<\/span> <\/span>PlatformColor<\/span>(<\/span>"<\/span>secondarySystemBackground<\/span>"<\/span>)<\/span>,<\/span><\/span>\n  <\/span>},<\/span><\/span>\n}<\/span>)<\/span>;<\/span><\/span><\/code><\/pre><\/div>\n\n\n\n\n
\n
\"\"<\/figure><\/div>\n\n\n

\u4ee5\u4e0a\u3067\u3001\u30da\u30a4\u30a6\u30a9\u30fc\u30eb\u3092\u30e6\u30fc\u30b6\u30fc\u306b\u8868\u793a\u3067\u304d\u308b\u3088\u3046\u306b\u306a\u308a\u307e\u3057\u305f\u3002<\/p>\n\n\n\n

\u30b5\u30f3\u30c9\u30dc\u30c3\u30af\u30b9\u3067iOS\u306e\u30b5\u30d6\u30b9\u30af\u30ea\u30d7\u30b7\u30e7\u30f3\u3092\u30c6\u30b9\u30c8\u3059\u308b\u5834\u5408\u306f\u3001\u72ec\u81ea\u306e\u30b5\u30f3\u30c9\u30dc\u30c3\u30af\u30b9\u30c6\u30b9\u30bf\u30fc\u30a2\u30ab\u30a6\u30f3\u30c8<\/a>\u3092\u4f5c\u6210\u3059\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002\u30c6\u30b9\u30c8\u3092\u52b9\u7387\u5316\u3059\u308b\u305f\u3081\u306b\u3001\u30b5\u30f3\u30c9\u30dc\u30c3\u30af\u30b9\u30b5\u30d6\u30b9\u30af\u30ea\u30d7\u30b7\u30e7\u30f3\u306f\u3059\u3050\u306b\u7121\u52b9\u306b\u306a\u308b\u3053\u3068\u306b\u6ce8\u610f\u3057\u3066\u304f\u3060\u3055\u3044\u3002Android\u306e\u5834\u5408\u3001\u8ffd\u52a0\u306e\u30a2\u30ab\u30a6\u30f3\u30c8\u306f\u5fc5\u8981\u3042\u308a\u307e\u305b\u3093\u3002\u30a8\u30df\u30e5\u30ec\u30fc\u30bf\u30fc\u3067\u30c6\u30b9\u30c8\u3092\u5b9f\u884c\u3059\u308b\u3053\u3068\u3082\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n

\u30e6\u30fc\u30b6\u30fc\u306b\u30a2\u30af\u30c6\u30a3\u30d6\u306a\u30b5\u30d6\u30b9\u30af\u30ea\u30d7\u30b7\u30e7\u30f3\u304c\u3042\u308b\u304b\u3069\u3046\u304b\u3092\u78ba\u8a8d\u3059\u308b<\/h2>\n\n\n\n

\u30a8\u30f3\u30c9\u30e6\u30fc\u30b6\u30fc\u306b\u6709\u6599\u30b3\u30f3\u30c6\u30f3\u30c4\u3078\u306e\u30a2\u30af\u30bb\u30b9\u3092\u8a31\u53ef\u3059\u308b\u305f\u3081\u306b\u3001\u30a2\u30af\u30c6\u30a3\u30d6\u306a\u30b5\u30d6\u30b9\u30af\u30ea\u30d7\u30b7\u30e7\u30f3 \u30c7\u30fc\u30bf\u3092\u3069\u3053\u306b\u4fdd\u5b58\u3059\u308b\u304b\u3092\u6307\u5b9a\u3057\u306a\u3051\u308c\u3070\u306a\u308a\u307e\u305b\u3093\u3002Adapty\u3067\u306f\u3001\u30e6\u30fc\u30b6\u30fc\u306b\u95a2\u9023\u4ed8\u3051\u3089\u308c\u305f\u3059\u3079\u3066\u306e\u8cfc\u5165\u60c5\u5831\u304c\u4fdd\u5b58\u3055\u308c\u308b\u305f\u3081\u3001\u3053\u306e\u5834\u5408\u306b\u3082\u5f79\u7acb\u3061\u307e\u3059\u3002\u4eee\u306b\u30e6\u30fc\u30b6\u30fc\u304c\u30b5\u30d6\u30b9\u30af\u30ea\u30d7\u30b7\u30e7\u30f3\u3092\u5229\u7528\u3057\u3066\u3044\u306a\u3044\u5834\u5408\u306f\u3001\u30da\u30a4\u30a6\u30a9\u30fc\u30eb\u30dc\u30bf\u30f3\u304c\u8868\u793a\u3055\u308c\u308b\u3068\u3057\u307e\u3059\u3002\u30b5\u30d6\u30b9\u30af\u30ea\u30d7\u30b7\u30e7\u30f3\u3092\u5229\u7528\u3057\u3066\u3044\u308b\u5834\u5408\u306f\u3001\u30e6\u30fc\u30b6\u30fc\u306b\u732b\u306e\u5199\u771f\u3092\u8868\u793a\u3057\u307e\u3059\u3002.<\/p>\n\n\n\n

\u30a2\u30af\u30c6\u30a3\u30d6\u306a\u30b5\u30d6\u30b9\u30af\u30ea\u30d7\u30b7\u30e7\u30f3\u30c7\u30fc\u30bf\u306f\u30b5\u30fc\u30d0\u30fc\u307e\u305f\u306f\u30ad\u30e3\u30c3\u30b7\u30e5\u30b9\u30c8\u30ec\u30fc\u30b8\u304b\u3089\u53d6\u5f97\u3055\u308c\u308b\u305f\u3081\u3001\u30ed\u30fc\u30c0\u30fc\u304c\u5fc5\u8981\u306b\u306a\u308a\u307e\u3059\u3002\u52b9\u7387\u5316\u306e\u305f\u3081\u306b\u3001isLoading\u3068isPremium\u306e\u72b6\u614b\u3092\u8ffd\u52a0\u3057\u307e\u3057\u3087\u3046\u3002<\/p>\n\n\n\n

<\/path><\/path><\/svg><\/span>
\/\/ ...<\/span><\/span>\nexport<\/span> <\/span>const<\/span> <\/span>App<\/span>:<\/span> <\/span>React<\/span>.<\/span>FC<\/span> <\/span>=<\/span> <\/span>()<\/span> <\/span>=><\/span> <\/span>{<\/span><\/span>\n\t<\/span>const<\/span> <\/span>[<\/span>isLoading<\/span>,<\/span> <\/span>setIsLoading<\/span>]<\/span> <\/span>=<\/span> <\/span>useState<\/span><<\/span>boolean<\/span>><\/span>(<\/span>true<\/span>)<\/span>;<\/span><\/span>\n\t<\/span>const<\/span> <\/span>[<\/span>isPremium<\/span>,<\/span> <\/span>setIsPremium<\/span>]<\/span> <\/span>=<\/span> <\/span>useState<\/span><<\/span>boolean<\/span>><\/span>(<\/span>false<\/span>)<\/span>;<\/span><\/span>\n  <\/span>const<\/span> <\/span>[<\/span>paywalls<\/span>,<\/span> <\/span>setPaywalls<\/span>]<\/span> <\/span>=<\/span> <\/span>useState<\/span><<\/span>AdaptyPaywall<\/span>[]<\/span>><\/span>([])<\/span>;<\/span><\/span>\n<\/span>\n\t<\/span>useEffect<\/span>(<\/span>()<\/span> <\/span>=><\/span> <\/span>{<\/span><\/span>\n    <\/span>async<\/span> <\/span>function<\/span> <\/span>fetchPaywalls<\/span>()<\/span>:<\/span> <\/span>Promise<\/span><<\/span>void<\/span>><\/span> <\/span>{<\/span><\/span>\n      <\/span>try<\/span> <\/span>{<\/span><\/span>\n        <\/span>await<\/span> <\/span>activateAdapty<\/span>(<\/span>{<\/span><\/span>\n          <\/span>sdkKey<\/span>:<\/span> <\/span>"<\/span>MY_PUBLIC_KEY<\/span>"<\/span>,<\/span><\/span>\n        <\/span>}<\/span>)<\/span>;<\/span><\/span>\n<\/span>\n        <\/span>const<\/span> <\/span>profile<\/span> <\/span>=<\/span> <\/span>await<\/span> <\/span>adapty<\/span>.<\/span>purchases<\/span>.<\/span>getInfo<\/span>()<\/span>;<\/span><\/span>\n        <\/span>const<\/span> <\/span>isSubscribed<\/span> <\/span>=<\/span> <\/span>profile<\/span>.<\/span>accessLevels<\/span>.<\/span>premium<\/span>.<\/span>isActive<\/span>;<\/span><\/span>\n        <\/span>setIsPremium<\/span>(<\/span>isSubscribed<\/span>)<\/span>;<\/span><\/span>\n<\/span>\n        <\/span>if<\/span> (<\/span>!<\/span>isSubscribed<\/span>) <\/span>{<\/span><\/span>\n          <\/span>const<\/span> <\/span>result<\/span> <\/span>=<\/span> <\/span>await<\/span> <\/span>adapty<\/span>.<\/span>paywalls<\/span>.<\/span>getPaywalls<\/span>()<\/span>;<\/span><\/span>\n          <\/span>setPaywalls<\/span>(<\/span>result<\/span>.<\/span>paywalls<\/span>)<\/span>;<\/span><\/span>\n        <\/span>}<\/span><\/span>\n      <\/span>}<\/span> <\/span>finally<\/span> <\/span>{<\/span><\/span>\n        <\/span>setIsLoading<\/span>(<\/span>false<\/span>)<\/span>;<\/span><\/span>\n      <\/span>}<\/span><\/span>\n    <\/span>}<\/span><\/span>\n<\/span>\n    <\/span>fetchPaywalls<\/span>()<\/span>;<\/span><\/span>\n  <\/span>},<\/span> [])<\/span>;<\/span><\/span>\n<\/span>\n  <\/span>\/\/ ...<\/span><\/span>\n}<\/span><\/span>\n\/\/ ...<\/span><\/span><\/code><\/pre><\/div>\n\n\n\n

\u5909\u66f4\u70b9\u306f\u6b21\u306e\u3068\u304a\u308a\u3067\u3059\u3002\u72b6\u614b\u306b\u30d5\u30e9\u30b0\u3092\u8ffd\u52a0\u3057\u307e\u3057\u305f\u3002fetchPaywalls()<\/em>\u306e\u8a18\u8ff0\u5168\u4f53\u304ctry-catch<\/em>\u30d6\u30ed\u30c3\u30af\u306b\u30e9\u30c3\u30d7\u3055\u308c\u308b\u3088\u3046\u306b\u306a\u308a\u3001\u3042\u3089\u3086\u308b\u60f3\u5b9a\u3055\u308c\u308b\u30b7\u30ca\u30ea\u30aa\u3067\u30b3\u30fc\u30c9\u304csetIsLoading(false)<\/em>\u306b\u5230\u9054\u3059\u308b\u3088\u3046\u306b\u306a\u308a\u307e\u3057\u305f\u3002\u30e6\u30fc\u30b6\u30fc\u306b\u30a2\u30af\u30c6\u30a3\u30d6\u306a\u30b5\u30d6\u30b9\u30af\u30ea\u30d7\u30b7\u30e7\u30f3\u304c\u3042\u308b\u304b\u3069\u3046\u304b\u3092\u78ba\u8a8d\u3059\u308b\u305f\u3081\u306b\u3001\u30e6\u30fc\u30b6\u30fc\u306e\u30d7\u30ed\u30d5\u30a1\u30a4\u30eb (\u3059\u3079\u3066\u306e\u30b5\u30d6\u30b9\u30af\u30ea\u30d7\u30b7\u30e7\u30f3\u30c7\u30fc\u30bf\u3092\u542b\u3080) \u3092\u53d6\u5f97\u3057\u3001profile.accessLevels.premium.isActive<\/em>\u306e\u5024\u3092\u78ba\u8a8d\u3057\u307e\u3059\u3002\u5fc5\u8981\u306b\u5fdc\u3058\u3066\u30a2\u30af\u30bb\u30b9\u30ec\u30d9\u30eb (accessLevels<\/em>) \u3092\u4f7f\u7528\u3067\u304d\u307e\u3059\u304c (\u57fa\u672c\u7684\u306b\u306f\u300c\u30b4\u30fc\u30eb\u30c9\u300d\u3084\u300c\u30d7\u30ec\u30df\u30a2\u30e0\u300d\u306a\u3069\u306e\u30b5\u30d6\u30b9\u30af\u30ea\u30d7\u30b7\u30e7\u30f3\u30ec\u30d9\u30eb\u306b\u3059\u304e\u307e\u305b\u3093)\u3001\u3053\u3053\u3067\u306f\u65e2\u5b9a\u5024\u306e\u307e\u307e\u306b\u3057\u307e\u3059\u3002Adapty\u3067\u306f\u3001\u6709\u6599\u6a5f\u80fd\u3078\u306e\u30a2\u30af\u30bb\u30b9\u30ec\u30d9\u30eb\u3092\u81ea\u52d5\u7684\u306b\u4f5c\u6210\u3057\u307e\u3059\u3002\u307b\u3068\u3093\u3069\u306e\u30a2\u30d7\u30ea\u3067\u306f\u3001\u3053\u308c\u3067\u5341\u5206\u3067\u3059\u3002isActive<\/em>\u306f\u3001\u3053\u306e\u30a2\u30af\u30bb\u30b9\u30ec\u30d9\u30eb\u306e\u30a2\u30af\u30c6\u30a3\u30d6\u306a\u30b5\u30d6\u30b9\u30af\u30ea\u30d7\u30b7\u30e7\u30f3\u304c\u3042\u308b\u9593\u306f\u300ctrue<\/em>\u300d\u306e\u307e\u307e\u306b\u306a\u308a\u307e\u3059<\/p>\n\n\n\n

\u3053\u3053\u304b\u3089\u306f\u3001\u3059\u3079\u3066\u304c\u7c21\u5358\u306b\u601d\u3048\u308b\u306f\u305a\u3067\u3059\u3002\u30e6\u30fc\u30b6\u30fc\u306b\u30d7\u30ec\u30df\u30a2\u30e0\u30ec\u30d9\u30eb\u306e\u30b5\u30d6\u30b9\u30af\u30ea\u30d7\u30b7\u30e7\u30f3\u30b9\u30c6\u30fc\u30bf\u30b9\u304c\u3042\u308b\u5834\u5408\u3001\u30da\u30a4\u30a6\u30a9\u30fc\u30eb\u3092\u53d6\u5f97\u3059\u308b\u5fc5\u8981\u306f\u3042\u308a\u307e\u305b\u3093\u3002\u30ed\u30fc\u30c0\u30fc\u3092\u7121\u52b9\u306b\u3057\u3066\u30b3\u30f3\u30c6\u30f3\u30c4\u3092\u8868\u793a\u3059\u308b\u3060\u3051\u3067\u3059\u3002<\/p>\n\n\n\n

<\/path><\/path><\/svg><\/span>
export<\/span> <\/span>const<\/span> <\/span>App<\/span>:<\/span> <\/span>React<\/span>.<\/span>FC<\/span> <\/span>=<\/span> <\/span>()<\/span> <\/span>=><\/span> <\/span>{<\/span><\/span>\n\/\/ ...<\/span><\/span>\nconst<\/span> <\/span>renderContent<\/span> <\/span>=<\/span> <\/span>()<\/span>:<\/span> <\/span>React<\/span>.<\/span>ReactNode<\/span> <\/span>=><\/span> <\/span>{<\/span><\/span>\n  <\/span>if<\/span> (<\/span>isLoading<\/span>) <\/span>{<\/span><\/span>\n    <\/span>return<\/span> <<\/span>Text<\/span>><\/span>Loading<\/span>...<\/<\/span>Text<\/span>>;<\/span><\/span>\n  <\/span>}<\/span><\/span>\n<\/span>\n  <\/span>if<\/span> (<\/span>isPremium<\/span>) <\/span>{<\/span><\/span>\n    <\/span>return<\/span> (<\/span><\/span>\n      <\/span><<\/span>Image<\/span><\/span>\n        <\/span>source<\/span>=<\/span>{{<\/span><\/span>\n          url<\/span>:<\/span> <\/span>"<\/span>https:\/\/25.media.tumblr.com\/tumblr_lugj06ZSgX1r4xjo2o1_500.gif<\/span>"<\/span>,<\/span><\/span>\n          width<\/span>:<\/span> <\/span>Dimensions<\/span>.<\/span>get<\/span>(<\/span>"<\/span>window<\/span>"<\/span>)<\/span>.<\/span>width<\/span> <\/span>*<\/span> <\/span>0.8<\/span>,<\/span><\/span>\n          height<\/span>:<\/span> <\/span>Dimensions<\/span>.<\/span>get<\/span>(<\/span>"<\/span>window<\/span>"<\/span>)<\/span>.<\/span>height<\/span> <\/span>*<\/span> <\/span>0.8<\/span>,<\/span><\/span>\n        <\/span>}}<\/span><\/span>\n      <\/span>\/><\/span><\/span>\n    )<\/span>;<\/span><\/span>\n  <\/span>}<\/span><\/span>\n<\/span>\n  <\/span>return<\/span> (<\/span><\/span>\n    <\/span><<\/span>Button<\/span><\/span>\n      <\/span>title<\/span>=<\/span>"<\/span>Show paywall<\/span>"<\/span><\/span>\n      <\/span>onPress<\/span>=<\/span>{<\/span>() => <\/span>{<\/span><\/span>\n        <\/span>const<\/span> <\/span>paywall<\/span> <\/span>=<\/span> <\/span>paywalls<\/span>.<\/span>find<\/span>(<\/span><\/span>\n          <\/span>(<\/span>paywall<\/span>)<\/span> <\/span>=><\/span> <\/span>paywall<\/span>.<\/span>developerId<\/span> <\/span>===<\/span> <\/span>"<\/span>cats_paywall<\/span>"<\/span><\/span>\n        )<\/span>;<\/span><\/span>\n<\/span>\n        <\/span>if<\/span> (<\/span>!<\/span>paywall<\/span>) <\/span>{<\/span><\/span>\n          <\/span>return<\/span> <\/span>alert<\/span>(<\/span>"<\/span>There is no such paywall<\/span>"<\/span>)<\/span>;<\/span><\/span>\n        <\/span>}<\/span><\/span>\n<\/span>\n        <\/span>Navigation<\/span>.<\/span>showModal<\/span><<\/span>PaywallProps<\/span>><\/span>(<\/span>{<\/span><\/span>\n          <\/span>component<\/span>:<\/span> <\/span>{<\/span><\/span>\n            <\/span>name<\/span>:<\/span> <\/span>"<\/span>Paywall<\/span>"<\/span>,<\/span><\/span>\n            <\/span>passProps<\/span>:<\/span> <\/span>{<\/span><\/span>\n\t            <\/span>paywall<\/span>,<\/span><\/span>\n\t\t          <\/span>onRequestBuy<\/span>:<\/span> <\/span>async<\/span> <\/span>(<\/span>product<\/span>)<\/span> <\/span>=><\/span> <\/span>{<\/span><\/span>\n\t\t            <\/span>const<\/span> <\/span>purchase<\/span> <\/span>=<\/span> <\/span>await<\/span> <\/span>adapty<\/span>.<\/span>purchases<\/span>.<\/span>makePurchase<\/span>(<\/span>product<\/span>)<\/span>;<\/span><\/span>\n\t              <\/span>const<\/span> <\/span>isSubscribed<\/span> <\/span>=<\/span><\/span>\n\t\t              <\/span>purchase<\/span>.<\/span>purchaserInfo<\/span>.<\/span>accessLevels<\/span>?.<\/span>premium<\/span>.<\/span>isActive<\/span>;<\/span><\/span>\n                <\/span>setIsPremium<\/span>(<\/span>isSubscribed<\/span>)<\/span>;<\/span><\/span>\n                <\/span>Navigation<\/span>.<\/span>dismissAllModals<\/span>()<\/span>;<\/span><\/span>\n              <\/span>},<\/span><\/span>\n            <\/span>},<\/span><\/span>\n          <\/span>},<\/span><\/span>\n        <\/span>}<\/span>)<\/span>;<\/span><\/span>\n      <\/span>}}<\/span><\/span>\n    <\/span>\/><\/span><\/span>\n  )<\/span>;<\/span><\/span>\n}<\/span>;<\/span><\/span>\n<\/span>\nreturn<\/span> <<\/span>View<\/span> <\/span>style<\/span>=<\/span>{<\/span>styles<\/span>.<\/span>container<\/span>}<\/span>><\/span>{<\/span>renderContent<\/span>()}<\/span><\/<\/span>View<\/span>>;<\/span><\/span>\n}<\/span>;<\/span><\/span><\/code><\/pre><\/div>\n\n\n\n

\u3053\u3053\u3067\u306f\u3001\u30b3\u30f3\u30c6\u30f3\u30c4\u3092\u30ec\u30f3\u30c0\u30ea\u30f3\u30b0\u3059\u308b\u95a2\u6570\u3068\u3044\u304f\u3064\u304b\u306e\u30ed\u30b8\u30c3\u30af\u3092onRequestBuy\u306b\u8ffd\u52a0\u3057\u3066\u3044\u307e\u3059\u3002\u3064\u307e\u308a\u3001isPremium\u306e\u72b6\u614b\u3092\u66f4\u65b0\u3057\u3066\u3001\u30e2\u30fc\u30c0\u30eb\u3092\u7d42\u4e86\u3057\u307e\u3059\u3002<\/p>\n\n\n\n

\u6700\u7d42\u7d50\u679c\u306f\u6b21\u306e\u3068\u304a\u308a\u3067\u3059\u3002<\/p>\n\n\n\n