mirror of
https://github.com/logos-messaging/waku-react-native.git
synced 2026-01-02 14:23:08 +00:00
Compare commits
23 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
284f9a0992 | ||
|
|
49ea163a59 | ||
|
|
dc6ab3cf27 | ||
|
|
dd1f2a222b | ||
|
|
dff2d0259b | ||
|
|
6757cd4dd0 | ||
|
|
7040e63e41 | ||
|
|
2ed5c9b376 | ||
|
|
98ef3d59f8 | ||
|
|
b2624f4db1 | ||
|
|
1b26a8f5f5 | ||
|
|
e4d75ffdee | ||
|
|
0c2ab3dd5e | ||
|
|
a0990d17c2 | ||
|
|
6dea7bb417 | ||
|
|
a32ebd6bd2 | ||
|
|
f7022b9c7b | ||
|
|
3c2371252d | ||
|
|
3ab9bb046b | ||
|
|
84838f4ef8 | ||
|
|
db241fc4ae | ||
|
|
00262f6d4c | ||
|
|
db0525f971 |
15
.github/workflows/add-action-project.yml
vendored
Normal file
15
.github/workflows/add-action-project.yml
vendored
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
name: Add new issues to Waku project board
|
||||||
|
|
||||||
|
on:
|
||||||
|
issues:
|
||||||
|
types: [opened]
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
add-to-project:
|
||||||
|
name: Add issue to project
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: actions/add-to-project@v0.3.0
|
||||||
|
with:
|
||||||
|
project-url: https://github.com/orgs/waku-org/projects/2
|
||||||
|
github-token: ${{ secrets.ADD_TO_PROJECT_PAT }}
|
||||||
4
.gitignore
vendored
4
.gitignore
vendored
@ -67,6 +67,6 @@ android/keystores/debug.keystore
|
|||||||
lib/
|
lib/
|
||||||
|
|
||||||
tmp/
|
tmp/
|
||||||
android/libs/gowaku-sources.jar
|
gowaku-sources.jar
|
||||||
android/libs/gowaku.aar
|
gowaku.aar
|
||||||
ios/Gowaku.xcframework
|
ios/Gowaku.xcframework
|
||||||
14
README.md
14
README.md
@ -6,16 +6,20 @@ Waku React Native
|
|||||||
npm install @waku/react-native
|
npm install @waku/react-native
|
||||||
```
|
```
|
||||||
|
|
||||||
|
Edit `settings.gradle` from your app and add:
|
||||||
|
```
|
||||||
|
include ':gowaku'
|
||||||
|
project(':gowaku').projectDir = new File(rootProject.projectDir, './../node_modules/@waku/react-native/android/gowaku')
|
||||||
|
```
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
|
|
||||||
```js
|
```js
|
||||||
import { multiply } from "@waku/react-native";
|
import * as waku from "@waku/react-native";
|
||||||
|
|
||||||
// ...
|
|
||||||
|
|
||||||
const result = await multiply(3, 7);
|
|
||||||
```
|
```
|
||||||
|
|
||||||
|
See also [Fixing `route ip+net: netlinkrib: permission denied` in android](android-netlink.md)
|
||||||
|
|
||||||
## Contributing
|
## Contributing
|
||||||
|
|
||||||
See the [contributing guide](CONTRIBUTING.md) to learn how to contribute to the repository and the development workflow.
|
See the [contributing guide](CONTRIBUTING.md) to learn how to contribute to the repository and the development workflow.
|
||||||
|
|||||||
214
android-netlink.md
Normal file
214
android-netlink.md
Normal file
@ -0,0 +1,214 @@
|
|||||||
|
# Fixing `route ip+net: netlinkrib: permission denied` in android
|
||||||
|
|
||||||
|
|
||||||
|
The details for this error can be seen in https://github.com/ipfs-shipyard/gomobile-ipfs/issues/68, and happens when targeting android API version +30. (`targetSdkVersion 30` in your `gradle.properties` / `build.gradle`) In this issue a possible solution was described which involved all the steps shown below. I have modified these to take in account that we are using +Go 1.18 as well as using a newer version of the Android NDK. These instructions should be used until https://github.com/golang/go/issues/40569 is fixed and a new gomobile version is released that includes this fix
|
||||||
|
|
||||||
|
|
||||||
|
### Installing the requirements to build go-waku for android
|
||||||
|
|
||||||
|
These instructions assume that you are running Ubuntu, have NodeJS installed, and don't have any of the go and android required software installed. `root` access is required. Paths containing `/home/YOUR_USER` are referenced in different places. Replace `YOUR_USER` with your username (obtained with `whoami`). Don't blindly copy/paste the commands (It's not a good practice anyway)
|
||||||
|
|
||||||
|
**Installing required dependencies**
|
||||||
|
```
|
||||||
|
sudo apt update
|
||||||
|
sudo apt install build-essential unzip openjdk-11-jdk
|
||||||
|
```
|
||||||
|
|
||||||
|
**Installing Go 1.18**
|
||||||
|
```
|
||||||
|
wget https://go.dev/dl/go1.18.6.linux-amd64.tar.gz
|
||||||
|
sudo rm -rf /usr/local/go
|
||||||
|
sudo tar -C /usr/local -xzf go1.18.6.linux-amd64.tar.gz
|
||||||
|
export PATH=$PATH:/usr/local/go/bin
|
||||||
|
```
|
||||||
|
|
||||||
|
**Installing the Android NDK 25**
|
||||||
|
```
|
||||||
|
mkdir -p /home/YOUR_USER/Android/Sdk/
|
||||||
|
wget https://dl.google.com/android/repository/android-ndk-r25b-linux.zip
|
||||||
|
unzip android-ndk-r25b-linux.zip
|
||||||
|
mv -r android-ndk-r25b /home/YOUR_USER/Android/Sdk/ndk
|
||||||
|
export ANDROID_NDK_HOME=/home/YOUR_USER/Android/Sdk/ndk
|
||||||
|
```
|
||||||
|
|
||||||
|
**Installing the Android SDK command line tools and android-30**
|
||||||
|
```
|
||||||
|
mkdir /home/YOUR_USER/Android/Sdk/cmdline-tools
|
||||||
|
wget https://dl.google.com/android/repository/commandlinetools-linux-8512546_latest.zip
|
||||||
|
unzip commandlinetools-linux-8512546_latest.zip
|
||||||
|
mv cmdline-tools /home/YOUR_USER/Android/Sdk/cmdline-tools/latest
|
||||||
|
export PATH=$PATH:/home/YOUR_USER/Android/Sdk/cmdline-tools/latest/bin
|
||||||
|
sdkmanager "platform-tools" "platforms;android-30"
|
||||||
|
```
|
||||||
|
|
||||||
|
### Building go-waku for android
|
||||||
|
```
|
||||||
|
mkdir -p /home/YOUR_USER/go/src/github.com/waku-org
|
||||||
|
cd /home/YOUR_USER/go/src/github.com/status-im
|
||||||
|
git clone https://github.com/waku-org/go-waku
|
||||||
|
cd go-waku
|
||||||
|
echo "replace github.com/multiformats/go-multiaddr v0.7.0 => github.com/waku-org/go-multiaddr v0.0.0-20230105211400-b3bd508cf855" >> go.mod
|
||||||
|
export GO111MODULE=off
|
||||||
|
go get golang.org/x/mobile/cmd/gobind
|
||||||
|
go get golang.org/x/mobile/cmd/gomobile
|
||||||
|
export GO111MODULE=on
|
||||||
|
gomobile init
|
||||||
|
export GO111MODULE=off
|
||||||
|
gomobile bind -v -target=android -androidapi=23 -ldflags="-s -w" -v -o ./build/lib/gowaku.aar ./mobile
|
||||||
|
```
|
||||||
|
|
||||||
|
### Edit waku-react-native
|
||||||
|
```
|
||||||
|
mkdir -p /home/YOUR_USER/waku
|
||||||
|
cd /home/YOUR_USER/waku
|
||||||
|
git clone https://github.com/waku-org/waku-react-native
|
||||||
|
cd waku-react-native
|
||||||
|
npm install
|
||||||
|
./download-gowaku.sh
|
||||||
|
cp /home/YOUR_USER/go/src/github.com/waku-org/build/lib/gowaku.aar ./android/libs/.
|
||||||
|
```
|
||||||
|
|
||||||
|
### Edit your react-native project
|
||||||
|
**Edit packages.json**
|
||||||
|
Set `@waku/react-native` to the absolute path of your local copy of `waku-react-native` downloaded in the previous step
|
||||||
|
```json
|
||||||
|
...
|
||||||
|
"dependencies": {
|
||||||
|
"@waku/react-native": "file:/home/YOUR_USER/waku/waku-react-native/",
|
||||||
|
}
|
||||||
|
...
|
||||||
|
```
|
||||||
|
And execute `npm install` (or `yarn`) to link your local dependency
|
||||||
|
|
||||||
|
**Edit metro.config.js**
|
||||||
|
```js
|
||||||
|
const { getDefaultConfig } = require('expo/metro-config');
|
||||||
|
const exclusionList = require('metro-config/src/defaults/exclusionList');
|
||||||
|
const path = require('path');
|
||||||
|
|
||||||
|
const root = '/home/YOUR_USER/waku/waku-react-native/';
|
||||||
|
const pak = require(root + 'package.json');
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
// ...
|
||||||
|
watchFolders: [root],
|
||||||
|
resolver: {
|
||||||
|
blacklistRE: exclusionList(
|
||||||
|
Object
|
||||||
|
.keys({...pak.peerDependencies})
|
||||||
|
.map(m => new RegExp(`^${escape(path.join(root, 'node_modules', m))}\\/.*$`))
|
||||||
|
),
|
||||||
|
extraNodeModules: new Proxy(
|
||||||
|
{},
|
||||||
|
{
|
||||||
|
get: (target, name) => {
|
||||||
|
if (target.hasOwnProperty(name)) {
|
||||||
|
return target[name]
|
||||||
|
}
|
||||||
|
return path.join(process.cwd(), `node_modules/${name}`)
|
||||||
|
},
|
||||||
|
},
|
||||||
|
),
|
||||||
|
},
|
||||||
|
}
|
||||||
|
```
|
||||||
|
If you're using `expo`, in `waku-react-native`'s example app, you can see an example configuration achieving the same result
|
||||||
|
|
||||||
|
**Edit your application `android/build.gradle`**
|
||||||
|
Add `gowaku.aar` to the list of dependencies
|
||||||
|
```js
|
||||||
|
...
|
||||||
|
dependencies {
|
||||||
|
|
||||||
|
implementation files("$rootDir/../node_modules/@waku/react-native/android/libs/gowaku.aar")
|
||||||
|
|
||||||
|
}
|
||||||
|
...
|
||||||
|
```
|
||||||
|
|
||||||
|
**Edit `MainApplication.java`**
|
||||||
|
|
||||||
|
```java
|
||||||
|
// Add the following imports
|
||||||
|
import go.Seq;
|
||||||
|
import java.lang.StringBuilder;
|
||||||
|
import java.net.InetAddress;
|
||||||
|
import java.net.InterfaceAddress;
|
||||||
|
import java.net.NetworkInterface;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Locale;
|
||||||
|
|
||||||
|
...
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onCreate() {
|
||||||
|
// ...
|
||||||
|
|
||||||
|
// Add this line so that if RunOnJVM() with golang.org/x/mobile/app to call JAVA from GO,
|
||||||
|
// will not cause error "no current JVM"
|
||||||
|
Seq.setContext(getApplicationContext());
|
||||||
|
}
|
||||||
|
|
||||||
|
...
|
||||||
|
// Add this function
|
||||||
|
// To fix [x/mobile: Calling net.InterfaceAddrs() fails on Android SDK 30](https://github.com/golang/go/issues/40569)
|
||||||
|
// Ref to getInterfaces() in https://github.com/tailscale/tailscale-android/pull/21/files
|
||||||
|
//
|
||||||
|
// Returns details of the interfaces in the system, encoded as a single string for ease
|
||||||
|
// of JNI transfer over to the Go environment.
|
||||||
|
//
|
||||||
|
// Example:
|
||||||
|
// rmnet_data0 10 2000 true false false false false | fe80::4059:dc16:7ed3:9c6e%rmnet_data0/64
|
||||||
|
// dummy0 3 1500 true false false false false | fe80::1450:5cff:fe13:f891%dummy0/64
|
||||||
|
// wlan0 30 1500 true true false false true | fe80::2f60:2c82:4163:8389%wlan0/64 10.1.10.131/24
|
||||||
|
// r_rmnet_data0 21 1500 true false false false false | fe80::9318:6093:d1ad:ba7f%r_rmnet_data0/64
|
||||||
|
// rmnet_data2 12 1500 true false false false false | fe80::3c8c:44dc:46a9:9907%rmnet_data2/64
|
||||||
|
// r_rmnet_data1 22 1500 true false false false false | fe80::b6cd:5cb0:8ae6:fe92%r_rmnet_data1/64
|
||||||
|
// rmnet_data1 11 1500 true false false false false | fe80::51f2:ee00:edce:d68b%rmnet_data1/64
|
||||||
|
// lo 1 65536 true false true false false | ::1/128 127.0.0.1/8
|
||||||
|
// v4-rmnet_data2 68 1472 true true false true true | 192.0.0.4/32
|
||||||
|
//
|
||||||
|
// Where the fields are:
|
||||||
|
// name ifindex mtu isUp hasBroadcast isLoopback isPointToPoint hasMulticast | ip1/N ip2/N ip3/N;
|
||||||
|
String getInterfacesAsString() {
|
||||||
|
List<NetworkInterface> interfaces;
|
||||||
|
try {
|
||||||
|
interfaces = Collections.list(NetworkInterface.getNetworkInterfaces());
|
||||||
|
} catch (Exception e) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
StringBuilder sb = new StringBuilder("");
|
||||||
|
for (NetworkInterface nif : interfaces) {
|
||||||
|
try {
|
||||||
|
// Android doesn't have a supportsBroadcast() but the Go net.Interface wants
|
||||||
|
// one, so we say the interface has broadcast if it has multicast.
|
||||||
|
sb.append(String.format(java.util.Locale.ROOT, "%s %d %d %b %b %b %b %b |", nif.getName(),
|
||||||
|
nif.getIndex(), nif.getMTU(), nif.isUp(), nif.supportsMulticast(),
|
||||||
|
nif.isLoopback(), nif.isPointToPoint(), nif.supportsMulticast()));
|
||||||
|
|
||||||
|
for (InterfaceAddress ia : nif.getInterfaceAddresses()) {
|
||||||
|
// InterfaceAddress == hostname + "/" + IP
|
||||||
|
String[] parts = ia.toString().split("/", 0);
|
||||||
|
if (parts.length > 1) {
|
||||||
|
sb.append(String.format(java.util.Locale.ROOT, "%s/%d ", parts[1], ia.getNetworkPrefixLength()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
// TODO(dgentry) should log the exception not silently suppress it.
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
sb.append("\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
return sb.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
...
|
||||||
|
|
||||||
|
```
|
||||||
|
|
||||||
|
After this step, build your app. The error should have dissapeared.
|
||||||
|
In `adb logcat` you will see this message instead `avc: denied { bind } for scontext=u:r:untrusted_app` which seems to be due to Android restrictions which prevents Waku from obtaining the IP address of the device, but it will still be able to connect to other devices succesfully.
|
||||||
@ -133,8 +133,8 @@ dependencies {
|
|||||||
//noinspection GradleDynamicVersion
|
//noinspection GradleDynamicVersion
|
||||||
implementation "com.facebook.react:react-native:+"
|
implementation "com.facebook.react:react-native:+"
|
||||||
implementation "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version"
|
implementation "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version"
|
||||||
implementation files('libs/gowaku.aar')
|
implementation project(":gowaku")
|
||||||
// From node_modules
|
// From node_modules
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isNewArchitectureEnabled()) {
|
if (isNewArchitectureEnabled()) {
|
||||||
|
|||||||
2
android/gowaku/build.gradle
Normal file
2
android/gowaku/build.gradle
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
configurations.maybeCreate("default")
|
||||||
|
artifacts.add("default", file('gowaku.aar'))
|
||||||
1
android/settings.gradle
Normal file
1
android/settings.gradle
Normal file
@ -0,0 +1 @@
|
|||||||
|
include ':gowaku'
|
||||||
@ -183,4 +183,8 @@ class ReactNativeModule(reactContext: ReactApplicationContext) : ReactContextBas
|
|||||||
promise.resolve(Gowaku.filterUnsubscribe(filterJSON, ms.toLong()))
|
promise.resolve(Gowaku.filterUnsubscribe(filterJSON, ms.toLong()))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ReactMethod
|
||||||
|
fun dnsDiscovery(url: String, nameserver: String = "", ms: Double, promise: Promise) {
|
||||||
|
promise.resolve(Gowaku.dnsDiscovery(url, nameserver, ms.toLong()))
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -30,24 +30,24 @@ mkdir -p tmp
|
|||||||
cd tmp
|
cd tmp
|
||||||
|
|
||||||
rm -f ${SHA_FILE}
|
rm -f ${SHA_FILE}
|
||||||
wget "https://github.com/status-im/go-waku/releases/download/v${VERSION}/${SHA_FILE}"
|
wget "https://github.com/waku-org/go-waku/releases/download/v${VERSION}/${SHA_FILE}"
|
||||||
|
|
||||||
if [ "$DOWNLOAD_ANDROID" = true ]; then
|
if [ "$DOWNLOAD_ANDROID" = true ]; then
|
||||||
rm -f ${ANDROID_TAR}
|
rm -f ${ANDROID_TAR}
|
||||||
wget "https://github.com/status-im/go-waku/releases/download/v${VERSION}/${ANDROID_TAR}"
|
curl -L "https://github.com/waku-org/go-waku/releases/download/v${VERSION}/${ANDROID_TAR}" --output $ANDROID_TAR
|
||||||
sha256sum --status --ignore-missing -c ${SHA_FILE}
|
sha256sum --status --ignore-missing -c ${SHA_FILE}
|
||||||
if ! sha256sum --status --ignore-missing -c ${SHA_FILE}; then
|
if ! sha256sum --status --ignore-missing -c ${SHA_FILE}; then
|
||||||
echo "checksum failed - verify download"
|
echo "checksum failed - verify download"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
rm -f ../android/libs/gowaku*
|
rm -f ../android/gowaku/gowaku*
|
||||||
tar xvfz ${ANDROID_TAR} -C ../android/libs
|
tar xvfz ${ANDROID_TAR} -C ../android/gowaku
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$DOWNLOAD_IOS" = true ]; then
|
if [ "$DOWNLOAD_IOS" = true ]; then
|
||||||
rm -f ${IOS_TAR}
|
rm -f ${IOS_TAR}
|
||||||
wget "https://github.com/status-im/go-waku/releases/download/v${VERSION}/${IOS_TAR}"
|
curl -L "https://github.com/waku-org/go-waku/releases/download/v${VERSION}/${IOS_TAR}" --output $IOS_TAR
|
||||||
|
|
||||||
if ! sha256sum --status --ignore-missing -c ${SHA_FILE}; then
|
if ! sha256sum --status --ignore-missing -c ${SHA_FILE}; then
|
||||||
echo "checksum failed - verify download"
|
echo "checksum failed - verify download"
|
||||||
|
|||||||
6
example/.buckconfig
Normal file
6
example/.buckconfig
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
|
||||||
|
[android]
|
||||||
|
target = Google Inc.:Google APIs:31
|
||||||
|
|
||||||
|
[maven_repositories]
|
||||||
|
central = https://repo1.maven.org/maven2
|
||||||
@ -1,2 +0,0 @@
|
|||||||
BUNDLE_PATH: "vendor/bundle"
|
|
||||||
BUNDLE_FORCE_RUBY_PLATFORM: 1
|
|
||||||
1
example/.gitattributes
vendored
Normal file
1
example/.gitattributes
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
*.pbxproj -text
|
||||||
56
example/.gitignore
vendored
Normal file
56
example/.gitignore
vendored
Normal file
@ -0,0 +1,56 @@
|
|||||||
|
# OSX
|
||||||
|
#
|
||||||
|
.DS_Store
|
||||||
|
|
||||||
|
# Xcode
|
||||||
|
#
|
||||||
|
build/
|
||||||
|
*.pbxuser
|
||||||
|
!default.pbxuser
|
||||||
|
*.mode1v3
|
||||||
|
!default.mode1v3
|
||||||
|
*.mode2v3
|
||||||
|
!default.mode2v3
|
||||||
|
*.perspectivev3
|
||||||
|
!default.perspectivev3
|
||||||
|
xcuserdata
|
||||||
|
*.xccheckout
|
||||||
|
*.moved-aside
|
||||||
|
DerivedData
|
||||||
|
*.hmap
|
||||||
|
*.ipa
|
||||||
|
*.xcuserstate
|
||||||
|
project.xcworkspace
|
||||||
|
|
||||||
|
# Android/IntelliJ
|
||||||
|
#
|
||||||
|
build/
|
||||||
|
.idea
|
||||||
|
.gradle
|
||||||
|
local.properties
|
||||||
|
*.iml
|
||||||
|
*.hprof
|
||||||
|
.cxx/
|
||||||
|
|
||||||
|
# node.js
|
||||||
|
#
|
||||||
|
node_modules/
|
||||||
|
npm-debug.log
|
||||||
|
yarn-error.log
|
||||||
|
|
||||||
|
# BUCK
|
||||||
|
buck-out/
|
||||||
|
\.buckd/
|
||||||
|
*.keystore
|
||||||
|
!debug.keystore
|
||||||
|
|
||||||
|
# Bundle artifacts
|
||||||
|
*.jsbundle
|
||||||
|
|
||||||
|
# CocoaPods
|
||||||
|
/ios/Pods/
|
||||||
|
|
||||||
|
# Expo
|
||||||
|
.expo/
|
||||||
|
web-build/
|
||||||
|
dist/
|
||||||
@ -1 +0,0 @@
|
|||||||
2.7.4
|
|
||||||
155
example/App.js
Normal file
155
example/App.js
Normal file
@ -0,0 +1,155 @@
|
|||||||
|
import * as React from 'react';
|
||||||
|
|
||||||
|
import { StyleSheet, View, Text } from 'react-native';
|
||||||
|
import {
|
||||||
|
defaultPubsubTopic,
|
||||||
|
newNode,
|
||||||
|
start,
|
||||||
|
isStarted,
|
||||||
|
stop,
|
||||||
|
peerID,
|
||||||
|
relayEnoughPeers,
|
||||||
|
listenAddresses,
|
||||||
|
connect,
|
||||||
|
peerCnt,
|
||||||
|
peers,
|
||||||
|
relayPublish,
|
||||||
|
relayUnsubscribe,
|
||||||
|
relaySubscribe,
|
||||||
|
WakuMessage,
|
||||||
|
onMessage,
|
||||||
|
StoreQuery,
|
||||||
|
storeQuery,
|
||||||
|
Config,
|
||||||
|
FilterSubscription,
|
||||||
|
ContentFilter,
|
||||||
|
filterSubscribe,
|
||||||
|
dnsDiscovery,
|
||||||
|
} from '@waku/react-native';
|
||||||
|
|
||||||
|
const myContentTopic = '/example/1/react-native-app/proto';
|
||||||
|
|
||||||
|
export default function App() {
|
||||||
|
const [result, setResult] = React.useState();
|
||||||
|
|
||||||
|
React.useEffect(() => {
|
||||||
|
(async () => {
|
||||||
|
const nodeStarted = await isStarted();
|
||||||
|
|
||||||
|
if (!nodeStarted) {
|
||||||
|
await newNode(null);
|
||||||
|
await start();
|
||||||
|
}
|
||||||
|
console.log('The node ID:', await peerID());
|
||||||
|
|
||||||
|
await relaySubscribe();
|
||||||
|
|
||||||
|
onMessage((event) => {
|
||||||
|
if (event.wakuMessage.contentTopic !== myContentTopic) return;
|
||||||
|
|
||||||
|
setResult(
|
||||||
|
'Message received: ' +
|
||||||
|
event.wakuMessage.timestamp +
|
||||||
|
' - payload:[' +
|
||||||
|
JSON.stringify(event.wakuMessage.payload) +
|
||||||
|
']'
|
||||||
|
);
|
||||||
|
console.log('Message received: ', event);
|
||||||
|
});
|
||||||
|
|
||||||
|
console.log('enoughPeers?', await relayEnoughPeers());
|
||||||
|
console.log('addresses', await listenAddresses());
|
||||||
|
console.log('connecting...');
|
||||||
|
|
||||||
|
try {
|
||||||
|
await connect(
|
||||||
|
'/dns4/node-01.ac-cn-hongkong-c.wakuv2.test.statusim.net/tcp/30303/p2p/16Uiu2HAkvWiyFsgRhuJEb9JfjYxEkoHLgnUQmr1N5mKWnYjxYRVm',
|
||||||
|
5000
|
||||||
|
);
|
||||||
|
} catch (err) {
|
||||||
|
console.log('Could not connect to peers');
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
await connect(
|
||||||
|
'/dns4/node-01.do-ams3.wakuv2.test.statusim.net/tcp/30303/p2p/16Uiu2HAmPLe7Mzm8TsYUubgCAW1aJoeFScxrLj8ppHFivPo97bUZ',
|
||||||
|
5000
|
||||||
|
);
|
||||||
|
} catch (err) {
|
||||||
|
console.log('Could not connect to peers');
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log('connected!');
|
||||||
|
|
||||||
|
console.log('PeerCNT', await peerCnt());
|
||||||
|
console.log('Peers', await peers());
|
||||||
|
|
||||||
|
let msg = new WakuMessage();
|
||||||
|
msg.contentTopic = myContentTopic;
|
||||||
|
msg.payload = new Uint8Array([1, 2, 3, 4, 5]);
|
||||||
|
msg.timestamp = new Date();
|
||||||
|
msg.version = 0;
|
||||||
|
|
||||||
|
let messageID = await relayPublish(msg);
|
||||||
|
|
||||||
|
console.log('The messageID', messageID);
|
||||||
|
|
||||||
|
// TO RETRIEVE HISTORIC MESSAGES:
|
||||||
|
console.log('Retrieving messages from store node');
|
||||||
|
const query = new StoreQuery();
|
||||||
|
query.contentFilters.push(new ContentFilter(myContentTopic));
|
||||||
|
const queryResult = await storeQuery(
|
||||||
|
query,
|
||||||
|
'16Uiu2HAkvWiyFsgRhuJEb9JfjYxEkoHLgnUQmr1N5mKWnYjxYRVm'
|
||||||
|
);
|
||||||
|
console.log(queryResult);
|
||||||
|
|
||||||
|
// DNS Discovery
|
||||||
|
console.log('Retrieving Nodes using DNS Discovery');
|
||||||
|
const dnsDiscoveryResult = await dnsDiscovery(
|
||||||
|
'enrtree://AO47IDOLBKH72HIZZOXQP6NMRESAN7CHYWIBNXDXWRJRZWLODKII6@test.wakuv2.nodes.status.im',
|
||||||
|
'1.1.1.1'
|
||||||
|
);
|
||||||
|
console.log(dnsDiscoveryResult);
|
||||||
|
|
||||||
|
// USING FILTER INSTEAD OF RELAY:
|
||||||
|
// Instantiate the node passing these parameters:
|
||||||
|
// let config = new Config();
|
||||||
|
// config.relay = false;
|
||||||
|
// config.filter = true;
|
||||||
|
// newNode(config})
|
||||||
|
/*
|
||||||
|
const filterSubs = new FilterSubscription();
|
||||||
|
filterSubs.contentFilters.push(new ContentFilter("/toy-chat/2/luzhou/proto"))
|
||||||
|
await filterSubscribe(filterSubs, "16Uiu2HAkvWiyFsgRhuJEb9JfjYxEkoHLgnUQmr1N5mKWnYjxYRVm")
|
||||||
|
*/
|
||||||
|
|
||||||
|
// console.log("Unsubscribing and stopping node...")
|
||||||
|
|
||||||
|
// await relayUnsubscribe();
|
||||||
|
|
||||||
|
// await stop(); // TODO: This must be called only once
|
||||||
|
})();
|
||||||
|
|
||||||
|
defaultPubsubTopic().then(setResult);
|
||||||
|
}, []);
|
||||||
|
|
||||||
|
return (
|
||||||
|
<View style={styles.container}>
|
||||||
|
<Text>{result}</Text>
|
||||||
|
</View>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
const styles = StyleSheet.create({
|
||||||
|
container: {
|
||||||
|
flex: 1,
|
||||||
|
alignItems: 'center',
|
||||||
|
justifyContent: 'center',
|
||||||
|
},
|
||||||
|
box: {
|
||||||
|
width: 60,
|
||||||
|
height: 60,
|
||||||
|
marginVertical: 20,
|
||||||
|
},
|
||||||
|
});
|
||||||
@ -1,6 +0,0 @@
|
|||||||
source 'https://rubygems.org'
|
|
||||||
|
|
||||||
# You may use http://rbenv.org/ or https://rvm.io/ to install and use this version
|
|
||||||
ruby '2.7.4'
|
|
||||||
|
|
||||||
gem 'cocoapods', '~> 1.11', '>= 1.11.2'
|
|
||||||
@ -1,100 +0,0 @@
|
|||||||
GEM
|
|
||||||
remote: https://rubygems.org/
|
|
||||||
specs:
|
|
||||||
CFPropertyList (3.0.5)
|
|
||||||
rexml
|
|
||||||
activesupport (6.1.5.1)
|
|
||||||
concurrent-ruby (~> 1.0, >= 1.0.2)
|
|
||||||
i18n (>= 1.6, < 2)
|
|
||||||
minitest (>= 5.1)
|
|
||||||
tzinfo (~> 2.0)
|
|
||||||
zeitwerk (~> 2.3)
|
|
||||||
addressable (2.8.0)
|
|
||||||
public_suffix (>= 2.0.2, < 5.0)
|
|
||||||
algoliasearch (1.27.5)
|
|
||||||
httpclient (~> 2.8, >= 2.8.3)
|
|
||||||
json (>= 1.5.1)
|
|
||||||
atomos (0.1.3)
|
|
||||||
claide (1.1.0)
|
|
||||||
cocoapods (1.11.3)
|
|
||||||
addressable (~> 2.8)
|
|
||||||
claide (>= 1.0.2, < 2.0)
|
|
||||||
cocoapods-core (= 1.11.3)
|
|
||||||
cocoapods-deintegrate (>= 1.0.3, < 2.0)
|
|
||||||
cocoapods-downloader (>= 1.4.0, < 2.0)
|
|
||||||
cocoapods-plugins (>= 1.0.0, < 2.0)
|
|
||||||
cocoapods-search (>= 1.0.0, < 2.0)
|
|
||||||
cocoapods-trunk (>= 1.4.0, < 2.0)
|
|
||||||
cocoapods-try (>= 1.1.0, < 2.0)
|
|
||||||
colored2 (~> 3.1)
|
|
||||||
escape (~> 0.0.4)
|
|
||||||
fourflusher (>= 2.3.0, < 3.0)
|
|
||||||
gh_inspector (~> 1.0)
|
|
||||||
molinillo (~> 0.8.0)
|
|
||||||
nap (~> 1.0)
|
|
||||||
ruby-macho (>= 1.0, < 3.0)
|
|
||||||
xcodeproj (>= 1.21.0, < 2.0)
|
|
||||||
cocoapods-core (1.11.3)
|
|
||||||
activesupport (>= 5.0, < 7)
|
|
||||||
addressable (~> 2.8)
|
|
||||||
algoliasearch (~> 1.0)
|
|
||||||
concurrent-ruby (~> 1.1)
|
|
||||||
fuzzy_match (~> 2.0.4)
|
|
||||||
nap (~> 1.0)
|
|
||||||
netrc (~> 0.11)
|
|
||||||
public_suffix (~> 4.0)
|
|
||||||
typhoeus (~> 1.0)
|
|
||||||
cocoapods-deintegrate (1.0.5)
|
|
||||||
cocoapods-downloader (1.6.3)
|
|
||||||
cocoapods-plugins (1.0.0)
|
|
||||||
nap
|
|
||||||
cocoapods-search (1.0.1)
|
|
||||||
cocoapods-trunk (1.6.0)
|
|
||||||
nap (>= 0.8, < 2.0)
|
|
||||||
netrc (~> 0.11)
|
|
||||||
cocoapods-try (1.2.0)
|
|
||||||
colored2 (3.1.2)
|
|
||||||
concurrent-ruby (1.1.10)
|
|
||||||
escape (0.0.4)
|
|
||||||
ethon (0.15.0)
|
|
||||||
ffi (>= 1.15.0)
|
|
||||||
ffi (1.15.5)
|
|
||||||
fourflusher (2.3.1)
|
|
||||||
fuzzy_match (2.0.4)
|
|
||||||
gh_inspector (1.1.3)
|
|
||||||
httpclient (2.8.3)
|
|
||||||
i18n (1.10.0)
|
|
||||||
concurrent-ruby (~> 1.0)
|
|
||||||
json (2.6.1)
|
|
||||||
minitest (5.15.0)
|
|
||||||
molinillo (0.8.0)
|
|
||||||
nanaimo (0.3.0)
|
|
||||||
nap (1.1.0)
|
|
||||||
netrc (0.11.0)
|
|
||||||
public_suffix (4.0.7)
|
|
||||||
rexml (3.2.5)
|
|
||||||
ruby-macho (2.5.1)
|
|
||||||
typhoeus (1.4.0)
|
|
||||||
ethon (>= 0.9.0)
|
|
||||||
tzinfo (2.0.4)
|
|
||||||
concurrent-ruby (~> 1.0)
|
|
||||||
xcodeproj (1.21.0)
|
|
||||||
CFPropertyList (>= 2.3.3, < 4.0)
|
|
||||||
atomos (~> 0.1.3)
|
|
||||||
claide (>= 1.0.2, < 2.0)
|
|
||||||
colored2 (~> 3.1)
|
|
||||||
nanaimo (~> 0.3.0)
|
|
||||||
rexml (~> 3.2.4)
|
|
||||||
zeitwerk (2.5.4)
|
|
||||||
|
|
||||||
PLATFORMS
|
|
||||||
ruby
|
|
||||||
|
|
||||||
DEPENDENCIES
|
|
||||||
cocoapods (~> 1.11, >= 1.11.2)
|
|
||||||
|
|
||||||
RUBY VERSION
|
|
||||||
ruby 2.7.4p191
|
|
||||||
|
|
||||||
BUNDLED WITH
|
|
||||||
2.2.27
|
|
||||||
21
example/android/.gitignore
vendored
Normal file
21
example/android/.gitignore
vendored
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
# OSX
|
||||||
|
#
|
||||||
|
.DS_Store
|
||||||
|
|
||||||
|
# Android/IntelliJ
|
||||||
|
#
|
||||||
|
build/
|
||||||
|
.idea
|
||||||
|
.gradle
|
||||||
|
local.properties
|
||||||
|
*.iml
|
||||||
|
*.hprof
|
||||||
|
|
||||||
|
# BUCK
|
||||||
|
buck-out/
|
||||||
|
\.buckd/
|
||||||
|
*.keystore
|
||||||
|
!debug.keystore
|
||||||
|
|
||||||
|
# Bundle artifacts
|
||||||
|
*.jsbundle
|
||||||
55
example/android/app/BUCK
Normal file
55
example/android/app/BUCK
Normal file
@ -0,0 +1,55 @@
|
|||||||
|
# To learn about Buck see [Docs](https://buckbuild.com/).
|
||||||
|
# To run your application with Buck:
|
||||||
|
# - install Buck
|
||||||
|
# - `npm start` - to start the packager
|
||||||
|
# - `cd android`
|
||||||
|
# - `keytool -genkey -v -keystore keystores/debug.keystore -storepass android -alias androiddebugkey -keypass android -dname "CN=Android Debug,O=Android,C=US"`
|
||||||
|
# - `./gradlew :app:copyDownloadableDepsToLibs` - make all Gradle compile dependencies available to Buck
|
||||||
|
# - `buck install -r android/app` - compile, install and run application
|
||||||
|
#
|
||||||
|
|
||||||
|
load(":build_defs.bzl", "create_aar_targets", "create_jar_targets")
|
||||||
|
|
||||||
|
lib_deps = []
|
||||||
|
|
||||||
|
create_aar_targets(glob(["libs/*.aar"]))
|
||||||
|
|
||||||
|
create_jar_targets(glob(["libs/*.jar"]))
|
||||||
|
|
||||||
|
android_library(
|
||||||
|
name = "all-libs",
|
||||||
|
exported_deps = lib_deps,
|
||||||
|
)
|
||||||
|
|
||||||
|
android_library(
|
||||||
|
name = "app-code",
|
||||||
|
srcs = glob([
|
||||||
|
"src/main/java/**/*.java",
|
||||||
|
]),
|
||||||
|
deps = [
|
||||||
|
":all-libs",
|
||||||
|
":build_config",
|
||||||
|
":res",
|
||||||
|
],
|
||||||
|
)
|
||||||
|
|
||||||
|
android_build_config(
|
||||||
|
name = "build_config",
|
||||||
|
package = "com.example",
|
||||||
|
)
|
||||||
|
|
||||||
|
android_resource(
|
||||||
|
name = "res",
|
||||||
|
package = "com.example",
|
||||||
|
res = "src/main/res",
|
||||||
|
)
|
||||||
|
|
||||||
|
android_binary(
|
||||||
|
name = "app",
|
||||||
|
keystore = "//android/keystores:debug",
|
||||||
|
manifest = "src/main/AndroidManifest.xml",
|
||||||
|
package_type = "debug",
|
||||||
|
deps = [
|
||||||
|
":app-code",
|
||||||
|
],
|
||||||
|
)
|
||||||
@ -1,7 +1,6 @@
|
|||||||
apply plugin: "com.android.application"
|
apply plugin: "com.android.application"
|
||||||
|
|
||||||
import com.android.build.OutputFile
|
import com.android.build.OutputFile
|
||||||
import org.apache.tools.ant.taskdefs.condition.Os
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The react.gradle file registers a task for each build variant (e.g. bundleDebugJsAndAssets
|
* The react.gradle file registers a task for each build variant (e.g. bundleDebugJsAndAssets
|
||||||
@ -78,11 +77,19 @@ import org.apache.tools.ant.taskdefs.condition.Os
|
|||||||
* ]
|
* ]
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
def projectRoot = rootDir.getAbsoluteFile().getParentFile().getAbsolutePath()
|
||||||
|
|
||||||
|
def reactNativeRoot = new File(["node", "--print", "require.resolve('react-native/package.json')"].execute(null, rootDir).text.trim()).getParentFile().getAbsolutePath()
|
||||||
|
|
||||||
project.ext.react = [
|
project.ext.react = [
|
||||||
enableHermes: true, // clean and rebuild if changing
|
entryFile: ["node", "-e", "require('expo/scripts/resolveAppEntry')", projectRoot, "android"].execute(null, rootDir).text.trim(),
|
||||||
|
enableHermes: (findProperty('expo.jsEngine') ?: "jsc") == "hermes",
|
||||||
|
hermesCommand: new File(["node", "--print", "require.resolve('react-native/package.json')"].execute(null, rootDir).text.trim()).getParentFile().getAbsolutePath() + "/sdks/hermesc/%OS-BIN%/hermesc",
|
||||||
|
cliPath: "${reactNativeRoot}/cli.js",
|
||||||
|
composeSourceMapsPath: "${reactNativeRoot}/scripts/compose-source-maps.js",
|
||||||
]
|
]
|
||||||
|
|
||||||
apply from: "../../node_modules/react-native/react.gradle"
|
apply from: new File(reactNativeRoot, "react.gradle")
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set this to true to create two separate APKs instead of one:
|
* Set this to true to create two separate APKs instead of one:
|
||||||
@ -97,7 +104,7 @@ def enableSeparateBuildPerCPUArchitecture = false
|
|||||||
/**
|
/**
|
||||||
* Run Proguard to shrink the Java bytecode in release builds.
|
* Run Proguard to shrink the Java bytecode in release builds.
|
||||||
*/
|
*/
|
||||||
def enableProguardInReleaseBuilds = false
|
def enableProguardInReleaseBuilds = (findProperty('android.enableProguardInReleaseBuilds') ?: false).toBoolean()
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The preferred build flavor of JavaScriptCore.
|
* The preferred build flavor of JavaScriptCore.
|
||||||
@ -135,7 +142,7 @@ android {
|
|||||||
compileSdkVersion rootProject.ext.compileSdkVersion
|
compileSdkVersion rootProject.ext.compileSdkVersion
|
||||||
|
|
||||||
defaultConfig {
|
defaultConfig {
|
||||||
applicationId "com.example.wakureactnative"
|
applicationId "com.example"
|
||||||
minSdkVersion rootProject.ext.minSdkVersion
|
minSdkVersion rootProject.ext.minSdkVersion
|
||||||
targetSdkVersion rootProject.ext.targetSdkVersion
|
targetSdkVersion rootProject.ext.targetSdkVersion
|
||||||
versionCode 1
|
versionCode 1
|
||||||
@ -143,25 +150,14 @@ android {
|
|||||||
buildConfigField "boolean", "IS_NEW_ARCHITECTURE_ENABLED", isNewArchitectureEnabled().toString()
|
buildConfigField "boolean", "IS_NEW_ARCHITECTURE_ENABLED", isNewArchitectureEnabled().toString()
|
||||||
|
|
||||||
if (isNewArchitectureEnabled()) {
|
if (isNewArchitectureEnabled()) {
|
||||||
// We configure the NDK build only if you decide to opt-in for the New Architecture.
|
// We configure the CMake build only if you decide to opt-in for the New Architecture.
|
||||||
externalNativeBuild {
|
externalNativeBuild {
|
||||||
ndkBuild {
|
cmake {
|
||||||
arguments "APP_PLATFORM=android-21",
|
arguments "-DPROJECT_BUILD_DIR=$buildDir",
|
||||||
"APP_STL=c++_shared",
|
"-DREACT_ANDROID_DIR=${reactNativeRoot}/ReactAndroid",
|
||||||
"NDK_TOOLCHAIN_VERSION=clang",
|
"-DREACT_ANDROID_BUILD_DIR=${reactNativeRoot}/ReactAndroid/build",
|
||||||
"GENERATED_SRC_DIR=$buildDir/generated/source",
|
"-DNODE_MODULES_DIR=$rootDir/../node_modules",
|
||||||
"PROJECT_BUILD_DIR=$buildDir",
|
"-DANDROID_STL=c++_shared"
|
||||||
"REACT_ANDROID_DIR=$rootDir/../node_modules/react-native/ReactAndroid",
|
|
||||||
"REACT_ANDROID_BUILD_DIR=$rootDir/../node_modules/react-native/ReactAndroid/build"
|
|
||||||
cFlags "-Wall", "-Werror", "-fexceptions", "-frtti", "-DWITH_INSPECTOR=1"
|
|
||||||
cppFlags "-std=c++17"
|
|
||||||
// Make sure this target name is the same you specify inside the
|
|
||||||
// src/main/jni/Android.mk file for the `LOCAL_MODULE` variable.
|
|
||||||
targets "example_appmodules"
|
|
||||||
// Fix for windows limit on number of character in file paths and in command lines
|
|
||||||
if (Os.isFamily(Os.FAMILY_WINDOWS)) {
|
|
||||||
arguments "NDK_APP_SHORT_COMMANDS=true"
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (!enableSeparateBuildPerCPUArchitecture) {
|
if (!enableSeparateBuildPerCPUArchitecture) {
|
||||||
@ -173,10 +169,10 @@ android {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (isNewArchitectureEnabled()) {
|
if (isNewArchitectureEnabled()) {
|
||||||
// We configure the NDK build only if you decide to opt-in for the New Architecture.
|
// We configure the CMake build only if you decide to opt-in for the New Architecture.
|
||||||
externalNativeBuild {
|
externalNativeBuild {
|
||||||
ndkBuild {
|
cmake {
|
||||||
path "$projectDir/src/main/jni/Android.mk"
|
path "$projectDir/src/main/jni/CMakeLists.txt"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
def reactAndroidProjectDir = project(':ReactAndroid').projectDir
|
def reactAndroidProjectDir = project(':ReactAndroid').projectDir
|
||||||
@ -198,15 +194,15 @@ android {
|
|||||||
preReleaseBuild.dependsOn(packageReactNdkReleaseLibs)
|
preReleaseBuild.dependsOn(packageReactNdkReleaseLibs)
|
||||||
|
|
||||||
// Due to a bug inside AGP, we have to explicitly set a dependency
|
// Due to a bug inside AGP, we have to explicitly set a dependency
|
||||||
// between configureNdkBuild* tasks and the preBuild tasks.
|
// between configureCMakeDebug* tasks and the preBuild tasks.
|
||||||
// This can be removed once this is solved: https://issuetracker.google.com/issues/207403732
|
// This can be removed once this is solved: https://issuetracker.google.com/issues/207403732
|
||||||
configureNdkBuildRelease.dependsOn(preReleaseBuild)
|
configureCMakeRelWithDebInfo.dependsOn(preReleaseBuild)
|
||||||
configureNdkBuildDebug.dependsOn(preDebugBuild)
|
configureCMakeDebug.dependsOn(preDebugBuild)
|
||||||
reactNativeArchitectures().each { architecture ->
|
reactNativeArchitectures().each { architecture ->
|
||||||
tasks.findByName("configureNdkBuildDebug[${architecture}]")?.configure {
|
tasks.findByName("configureCMakeDebug[${architecture}]")?.configure {
|
||||||
dependsOn("preDebugBuild")
|
dependsOn("preDebugBuild")
|
||||||
}
|
}
|
||||||
tasks.findByName("configureNdkBuildRelease[${architecture}]")?.configure {
|
tasks.findByName("configureCMakeRelWithDebInfo[${architecture}]")?.configure {
|
||||||
dependsOn("preReleaseBuild")
|
dependsOn("preReleaseBuild")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -247,43 +243,85 @@ android {
|
|||||||
variant.outputs.each { output ->
|
variant.outputs.each { output ->
|
||||||
// For each separate APK per architecture, set a unique version code as described here:
|
// For each separate APK per architecture, set a unique version code as described here:
|
||||||
// https://developer.android.com/studio/build/configure-apk-splits.html
|
// https://developer.android.com/studio/build/configure-apk-splits.html
|
||||||
// Example: versionCode 1 will generate 1001 for armeabi-v7a, 1002 for x86, etc.
|
|
||||||
def versionCodes = ["armeabi-v7a": 1, "x86": 2, "arm64-v8a": 3, "x86_64": 4]
|
def versionCodes = ["armeabi-v7a": 1, "x86": 2, "arm64-v8a": 3, "x86_64": 4]
|
||||||
def abi = output.getFilter(OutputFile.ABI)
|
def abi = output.getFilter(OutputFile.ABI)
|
||||||
if (abi != null) { // null for the universal-debug, universal-release variants
|
if (abi != null) { // null for the universal-debug, universal-release variants
|
||||||
output.versionCodeOverride =
|
output.versionCodeOverride =
|
||||||
defaultConfig.versionCode * 1000 + versionCodes.get(abi)
|
versionCodes.get(abi) * 1048576 + defaultConfig.versionCode
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Apply static values from `gradle.properties` to the `android.packagingOptions`
|
||||||
|
// Accepts values in comma delimited lists, example:
|
||||||
|
// android.packagingOptions.pickFirsts=/LICENSE,**/picasa.ini
|
||||||
|
["pickFirsts", "excludes", "merges", "doNotStrip"].each { prop ->
|
||||||
|
// Split option: 'foo,bar' -> ['foo', 'bar']
|
||||||
|
def options = (findProperty("android.packagingOptions.$prop") ?: "").split(",");
|
||||||
|
// Trim all elements in place.
|
||||||
|
for (i in 0..<options.size()) options[i] = options[i].trim();
|
||||||
|
// `[] - ""` is essentially `[""].filter(Boolean)` removing all empty strings.
|
||||||
|
options -= ""
|
||||||
|
|
||||||
|
if (options.length > 0) {
|
||||||
|
println "android.packagingOptions.$prop += $options ($options.length)"
|
||||||
|
// Ex: android.packagingOptions.pickFirsts += '**/SCCS/**'
|
||||||
|
options.each {
|
||||||
|
android.packagingOptions[prop] += it
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
implementation fileTree(dir: "libs", include: ["*.jar"])
|
implementation fileTree(dir: "libs", include: ["*.jar"])
|
||||||
|
|
||||||
//noinspection GradleDynamicVersion
|
//noinspection GradleDynamicVersion
|
||||||
implementation "com.facebook.react:react-native:+" // From node_modules
|
implementation "com.facebook.react:react-native:+" // From node_modules
|
||||||
|
|
||||||
implementation "androidx.swiperefreshlayout:swiperefreshlayout:1.0.0"
|
def isGifEnabled = (findProperty('expo.gif.enabled') ?: "") == "true";
|
||||||
|
def isWebpEnabled = (findProperty('expo.webp.enabled') ?: "") == "true";
|
||||||
|
def isWebpAnimatedEnabled = (findProperty('expo.webp.animated') ?: "") == "true";
|
||||||
|
def frescoVersion = rootProject.ext.frescoVersion
|
||||||
|
|
||||||
|
// If your app supports Android versions before Ice Cream Sandwich (API level 14)
|
||||||
|
if (isGifEnabled || isWebpEnabled) {
|
||||||
|
implementation "com.facebook.fresco:fresco:${frescoVersion}"
|
||||||
|
implementation "com.facebook.fresco:imagepipeline-okhttp3:${frescoVersion}"
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isGifEnabled) {
|
||||||
|
// For animated gif support
|
||||||
|
implementation "com.facebook.fresco:animated-gif:${frescoVersion}"
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isWebpEnabled) {
|
||||||
|
// For webp support
|
||||||
|
implementation "com.facebook.fresco:webpsupport:${frescoVersion}"
|
||||||
|
if (isWebpAnimatedEnabled) {
|
||||||
|
// Animated webp support
|
||||||
|
implementation "com.facebook.fresco:animated-webp:${frescoVersion}"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
implementation "androidx.swiperefreshlayout:swiperefreshlayout:1.0.0"
|
||||||
debugImplementation("com.facebook.flipper:flipper:${FLIPPER_VERSION}") {
|
debugImplementation("com.facebook.flipper:flipper:${FLIPPER_VERSION}") {
|
||||||
exclude group:'com.facebook.fbjni'
|
exclude group:'com.facebook.fbjni'
|
||||||
}
|
}
|
||||||
|
|
||||||
debugImplementation("com.facebook.flipper:flipper-network-plugin:${FLIPPER_VERSION}") {
|
debugImplementation("com.facebook.flipper:flipper-network-plugin:${FLIPPER_VERSION}") {
|
||||||
exclude group:'com.facebook.flipper'
|
exclude group:'com.facebook.flipper'
|
||||||
exclude group:'com.squareup.okhttp3', module:'okhttp'
|
exclude group:'com.squareup.okhttp3', module:'okhttp'
|
||||||
}
|
}
|
||||||
|
|
||||||
debugImplementation("com.facebook.flipper:flipper-fresco-plugin:${FLIPPER_VERSION}") {
|
debugImplementation("com.facebook.flipper:flipper-fresco-plugin:${FLIPPER_VERSION}") {
|
||||||
exclude group:'com.facebook.flipper'
|
exclude group:'com.facebook.flipper'
|
||||||
}
|
}
|
||||||
|
|
||||||
if (enableHermes) {
|
if (enableHermes) {
|
||||||
def hermesPath = "../../node_modules/hermes-engine/android/";
|
//noinspection GradleDynamicVersion
|
||||||
debugImplementation files(hermesPath + "hermes-debug.aar")
|
implementation("com.facebook.react:hermes-engine:+") { // From node_modules
|
||||||
releaseImplementation files(hermesPath + "hermes-release.aar")
|
exclude group:'com.facebook.fbjni'
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
implementation jscFlavor
|
implementation jscFlavor
|
||||||
}
|
}
|
||||||
@ -296,7 +334,11 @@ if (isNewArchitectureEnabled()) {
|
|||||||
configurations.all {
|
configurations.all {
|
||||||
resolutionStrategy.dependencySubstitution {
|
resolutionStrategy.dependencySubstitution {
|
||||||
substitute(module("com.facebook.react:react-native"))
|
substitute(module("com.facebook.react:react-native"))
|
||||||
.using(project(":ReactAndroid")).because("On New Architecture we're building React Native from source")
|
.using(project(":ReactAndroid"))
|
||||||
|
.because("On New Architecture we're building React Native from source")
|
||||||
|
substitute(module("com.facebook.react:hermes-engine"))
|
||||||
|
.using(project(":ReactAndroid:hermes-engine"))
|
||||||
|
.because("On New Architecture we're building Hermes from source")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -308,7 +350,8 @@ task copyDownloadableDepsToLibs(type: Copy) {
|
|||||||
into 'libs'
|
into 'libs'
|
||||||
}
|
}
|
||||||
|
|
||||||
apply from: file("../../node_modules/@react-native-community/cli-platform-android/native_modules.gradle"); applyNativeModulesAppBuildGradle(project)
|
apply from: new File(["node", "--print", "require.resolve('@react-native-community/cli-platform-android/package.json')"].execute(null, rootDir).text.trim(), "../native_modules.gradle");
|
||||||
|
applyNativeModulesAppBuildGradle(project)
|
||||||
|
|
||||||
def isNewArchitectureEnabled() {
|
def isNewArchitectureEnabled() {
|
||||||
// To opt-in for the New Architecture, you can either:
|
// To opt-in for the New Architecture, you can either:
|
||||||
|
|||||||
19
example/android/app/build_defs.bzl
Normal file
19
example/android/app/build_defs.bzl
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
"""Helper definitions to glob .aar and .jar targets"""
|
||||||
|
|
||||||
|
def create_aar_targets(aarfiles):
|
||||||
|
for aarfile in aarfiles:
|
||||||
|
name = "aars__" + aarfile[aarfile.rindex("/") + 1:aarfile.rindex(".aar")]
|
||||||
|
lib_deps.append(":" + name)
|
||||||
|
android_prebuilt_aar(
|
||||||
|
name = name,
|
||||||
|
aar = aarfile,
|
||||||
|
)
|
||||||
|
|
||||||
|
def create_jar_targets(jarfiles):
|
||||||
|
for jarfile in jarfiles:
|
||||||
|
name = "jars__" + jarfile[jarfile.rindex("/") + 1:jarfile.rindex(".jar")]
|
||||||
|
lib_deps.append(":" + name)
|
||||||
|
prebuilt_jar(
|
||||||
|
name = name,
|
||||||
|
binary_jar = jarfile,
|
||||||
|
)
|
||||||
7
example/android/app/proguard-rules.pro
vendored
7
example/android/app/proguard-rules.pro
vendored
@ -7,7 +7,8 @@
|
|||||||
# For more details, see
|
# For more details, see
|
||||||
# http://developer.android.com/guide/developing/tools/proguard.html
|
# http://developer.android.com/guide/developing/tools/proguard.html
|
||||||
|
|
||||||
# Add any project specific keep options here:
|
# react-native-reanimated
|
||||||
|
-keep class com.swmansion.reanimated.** { *; }
|
||||||
|
-keep class com.facebook.react.turbomodule.** { *; }
|
||||||
|
|
||||||
-keep class com.facebook.hermes.unicode.** { *; }
|
# Add any project specific keep options here:
|
||||||
-keep class com.facebook.jni.** { *; }
|
|
||||||
|
|||||||
@ -1,13 +1,7 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
|
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
xmlns:tools="http://schemas.android.com/tools">
|
xmlns:tools="http://schemas.android.com/tools">
|
||||||
|
|
||||||
<uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW"/>
|
<uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW"/>
|
||||||
|
|
||||||
<application
|
<application android:usesCleartextTraffic="true" tools:targetApi="28" tools:ignore="GoogleAppIndexingWarning" />
|
||||||
android:usesCleartextTraffic="true"
|
|
||||||
tools:targetApi="28"
|
|
||||||
tools:ignore="GoogleAppIndexingWarning">
|
|
||||||
<activity android:name="com.facebook.react.devsupport.DevSettingsActivity" android:exported="false" />
|
|
||||||
</application>
|
|
||||||
</manifest>
|
</manifest>
|
||||||
|
|||||||
@ -1,10 +1,10 @@
|
|||||||
/**
|
/**
|
||||||
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
||||||
*
|
*
|
||||||
* <p>This source code is licensed under the MIT license found in the LICENSE file in the root
|
* <p>This source code is licensed under the MIT license found in the LICENSE file in the root
|
||||||
* directory of this source tree.
|
* directory of this source tree.
|
||||||
*/
|
*/
|
||||||
package com.example.wakureactnative;
|
package com.example;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import com.facebook.flipper.android.AndroidFlipperClient;
|
import com.facebook.flipper.android.AndroidFlipperClient;
|
||||||
@ -19,7 +19,6 @@ import com.facebook.flipper.plugins.network.FlipperOkhttpInterceptor;
|
|||||||
import com.facebook.flipper.plugins.network.NetworkFlipperPlugin;
|
import com.facebook.flipper.plugins.network.NetworkFlipperPlugin;
|
||||||
import com.facebook.flipper.plugins.react.ReactFlipperPlugin;
|
import com.facebook.flipper.plugins.react.ReactFlipperPlugin;
|
||||||
import com.facebook.flipper.plugins.sharedpreferences.SharedPreferencesFlipperPlugin;
|
import com.facebook.flipper.plugins.sharedpreferences.SharedPreferencesFlipperPlugin;
|
||||||
import com.facebook.react.ReactInstanceEventListener;
|
|
||||||
import com.facebook.react.ReactInstanceManager;
|
import com.facebook.react.ReactInstanceManager;
|
||||||
import com.facebook.react.bridge.ReactContext;
|
import com.facebook.react.bridge.ReactContext;
|
||||||
import com.facebook.react.modules.network.NetworkingModule;
|
import com.facebook.react.modules.network.NetworkingModule;
|
||||||
@ -29,13 +28,11 @@ public class ReactNativeFlipper {
|
|||||||
public static void initializeFlipper(Context context, ReactInstanceManager reactInstanceManager) {
|
public static void initializeFlipper(Context context, ReactInstanceManager reactInstanceManager) {
|
||||||
if (FlipperUtils.shouldEnableFlipper(context)) {
|
if (FlipperUtils.shouldEnableFlipper(context)) {
|
||||||
final FlipperClient client = AndroidFlipperClient.getInstance(context);
|
final FlipperClient client = AndroidFlipperClient.getInstance(context);
|
||||||
|
|
||||||
client.addPlugin(new InspectorFlipperPlugin(context, DescriptorMapping.withDefaults()));
|
client.addPlugin(new InspectorFlipperPlugin(context, DescriptorMapping.withDefaults()));
|
||||||
client.addPlugin(new ReactFlipperPlugin());
|
client.addPlugin(new ReactFlipperPlugin());
|
||||||
client.addPlugin(new DatabasesFlipperPlugin(context));
|
client.addPlugin(new DatabasesFlipperPlugin(context));
|
||||||
client.addPlugin(new SharedPreferencesFlipperPlugin(context));
|
client.addPlugin(new SharedPreferencesFlipperPlugin(context));
|
||||||
client.addPlugin(CrashReporterPlugin.getInstance());
|
client.addPlugin(CrashReporterPlugin.getInstance());
|
||||||
|
|
||||||
NetworkFlipperPlugin networkFlipperPlugin = new NetworkFlipperPlugin();
|
NetworkFlipperPlugin networkFlipperPlugin = new NetworkFlipperPlugin();
|
||||||
NetworkingModule.setCustomClientBuilder(
|
NetworkingModule.setCustomClientBuilder(
|
||||||
new NetworkingModule.CustomClientBuilder() {
|
new NetworkingModule.CustomClientBuilder() {
|
||||||
@ -46,13 +43,12 @@ public class ReactNativeFlipper {
|
|||||||
});
|
});
|
||||||
client.addPlugin(networkFlipperPlugin);
|
client.addPlugin(networkFlipperPlugin);
|
||||||
client.start();
|
client.start();
|
||||||
|
|
||||||
// Fresco Plugin needs to ensure that ImagePipelineFactory is initialized
|
// Fresco Plugin needs to ensure that ImagePipelineFactory is initialized
|
||||||
// Hence we run if after all native modules have been initialized
|
// Hence we run if after all native modules have been initialized
|
||||||
ReactContext reactContext = reactInstanceManager.getCurrentReactContext();
|
ReactContext reactContext = reactInstanceManager.getCurrentReactContext();
|
||||||
if (reactContext == null) {
|
if (reactContext == null) {
|
||||||
reactInstanceManager.addReactInstanceEventListener(
|
reactInstanceManager.addReactInstanceEventListener(
|
||||||
new ReactInstanceEventListener() {
|
new ReactInstanceManager.ReactInstanceEventListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onReactContextInitialized(ReactContext reactContext) {
|
public void onReactContextInitialized(ReactContext reactContext) {
|
||||||
reactInstanceManager.removeReactInstanceEventListener(this);
|
reactInstanceManager.removeReactInstanceEventListener(this);
|
||||||
@ -1,26 +1,32 @@
|
|||||||
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
|
<manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.example">
|
||||||
package="com.example.wakureactnative">
|
|
||||||
|
|
||||||
<uses-permission android:name="android.permission.INTERNET" />
|
<uses-permission android:name="android.permission.INTERNET"/>
|
||||||
|
<!-- OPTIONAL PERMISSIONS, REMOVE WHATEVER YOU DO NOT NEED -->
|
||||||
|
<uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW"/>
|
||||||
|
<uses-permission android:name="android.permission.VIBRATE"/>
|
||||||
|
<!-- These require runtime permissions on M -->
|
||||||
|
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
|
||||||
|
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
|
||||||
|
<!-- END OPTIONAL PERMISSIONS -->
|
||||||
|
|
||||||
<application
|
<queries>
|
||||||
android:name=".MainApplication"
|
<!-- Support checking for http(s) links via the Linking API -->
|
||||||
android:label="@string/app_name"
|
<intent>
|
||||||
android:icon="@mipmap/ic_launcher"
|
<action android:name="android.intent.action.VIEW" />
|
||||||
android:roundIcon="@mipmap/ic_launcher_round"
|
<category android:name="android.intent.category.BROWSABLE" />
|
||||||
android:allowBackup="false"
|
<data android:scheme="https" />
|
||||||
android:theme="@style/AppTheme">
|
</intent>
|
||||||
<activity
|
</queries>
|
||||||
android:name=".MainActivity"
|
|
||||||
android:label="@string/app_name"
|
<application android:name=".MainApplication" android:label="@string/app_name" android:icon="@mipmap/ic_launcher" android:roundIcon="@mipmap/ic_launcher_round" android:allowBackup="false" android:theme="@style/AppTheme" android:usesCleartextTraffic="true">
|
||||||
android:configChanges="keyboard|keyboardHidden|orientation|screenLayout|screenSize|smallestScreenSize|uiMode"
|
<meta-data android:name="expo.modules.updates.EXPO_UPDATE_URL" android:value="YOUR-APP-URL-HERE"/>
|
||||||
android:launchMode="singleTask"
|
<meta-data android:name="expo.modules.updates.EXPO_SDK_VERSION" android:value="YOUR-APP-SDK-VERSION-HERE"/>
|
||||||
android:windowSoftInputMode="adjustResize"
|
<activity android:name=".MainActivity" android:label="@string/app_name" android:configChanges="keyboard|keyboardHidden|orientation|screenSize|uiMode" android:launchMode="singleTask" android:windowSoftInputMode="adjustResize" android:theme="@style/Theme.App.SplashScreen" android:exported="true">
|
||||||
android:exported="true">
|
<intent-filter>
|
||||||
<intent-filter>
|
<action android:name="android.intent.action.MAIN"/>
|
||||||
<action android:name="android.intent.action.MAIN" />
|
<category android:name="android.intent.category.LAUNCHER"/>
|
||||||
<category android:name="android.intent.category.LAUNCHER" />
|
</intent-filter>
|
||||||
</intent-filter>
|
</activity>
|
||||||
</activity>
|
<activity android:name="com.facebook.react.devsupport.DevSettingsActivity" android:exported="false"/>
|
||||||
</application>
|
</application>
|
||||||
</manifest>
|
</manifest>
|
||||||
|
|||||||
@ -0,0 +1,83 @@
|
|||||||
|
package com.example;
|
||||||
|
|
||||||
|
import android.os.Build;
|
||||||
|
import android.os.Bundle;
|
||||||
|
|
||||||
|
import com.facebook.react.ReactActivity;
|
||||||
|
import com.facebook.react.ReactActivityDelegate;
|
||||||
|
import com.facebook.react.ReactRootView;
|
||||||
|
|
||||||
|
import expo.modules.ReactActivityDelegateWrapper;
|
||||||
|
|
||||||
|
public class MainActivity extends ReactActivity {
|
||||||
|
@Override
|
||||||
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
|
// Set the theme to AppTheme BEFORE onCreate to support
|
||||||
|
// coloring the background, status bar, and navigation bar.
|
||||||
|
// This is required for expo-splash-screen.
|
||||||
|
setTheme(R.style.AppTheme);
|
||||||
|
super.onCreate(null);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the name of the main component registered from JavaScript.
|
||||||
|
* This is used to schedule rendering of the component.
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
protected String getMainComponentName() {
|
||||||
|
return "main";
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the instance of the {@link ReactActivityDelegate}. There the RootView is created and
|
||||||
|
* you can specify the renderer you wish to use - the new renderer (Fabric) or the old renderer
|
||||||
|
* (Paper).
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
protected ReactActivityDelegate createReactActivityDelegate() {
|
||||||
|
return new ReactActivityDelegateWrapper(this, BuildConfig.IS_NEW_ARCHITECTURE_ENABLED,
|
||||||
|
new MainActivityDelegate(this, getMainComponentName())
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Align the back button behavior with Android S
|
||||||
|
* where moving root activities to background instead of finishing activities.
|
||||||
|
* @see <a href="https://developer.android.com/reference/android/app/Activity#onBackPressed()">onBackPressed</a>
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void invokeDefaultOnBackPressed() {
|
||||||
|
if (Build.VERSION.SDK_INT <= Build.VERSION_CODES.R) {
|
||||||
|
if (!moveTaskToBack(false)) {
|
||||||
|
// For non-root activities, use the default implementation to finish them.
|
||||||
|
super.invokeDefaultOnBackPressed();
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Use the default back button implementation on Android S
|
||||||
|
// because it's doing more than {@link Activity#moveTaskToBack} in fact.
|
||||||
|
super.invokeDefaultOnBackPressed();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static class MainActivityDelegate extends ReactActivityDelegate {
|
||||||
|
public MainActivityDelegate(ReactActivity activity, String mainComponentName) {
|
||||||
|
super(activity, mainComponentName);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected ReactRootView createRootView() {
|
||||||
|
ReactRootView reactRootView = new ReactRootView(getContext());
|
||||||
|
// If you opted-in for the New Architecture, we enable the Fabric Renderer.
|
||||||
|
reactRootView.setIsFabric(BuildConfig.IS_NEW_ARCHITECTURE_ENABLED);
|
||||||
|
return reactRootView;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected boolean isConcurrentRootEnabled() {
|
||||||
|
// If you opted-in for the New Architecture, we enable Concurrent Root (i.e. React 18).
|
||||||
|
// More on this on https://reactjs.org/blog/2022/03/29/react-v18.html
|
||||||
|
return BuildConfig.IS_NEW_ARCHITECTURE_ENABLED;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -1,7 +1,10 @@
|
|||||||
package com.example.wakureactnative;
|
package com.example;
|
||||||
|
|
||||||
import android.app.Application;
|
import android.app.Application;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.content.res.Configuration;
|
||||||
|
import androidx.annotation.NonNull;
|
||||||
|
|
||||||
import com.facebook.react.PackageList;
|
import com.facebook.react.PackageList;
|
||||||
import com.facebook.react.ReactApplication;
|
import com.facebook.react.ReactApplication;
|
||||||
import com.facebook.react.ReactInstanceManager;
|
import com.facebook.react.ReactInstanceManager;
|
||||||
@ -9,36 +12,40 @@ import com.facebook.react.ReactNativeHost;
|
|||||||
import com.facebook.react.ReactPackage;
|
import com.facebook.react.ReactPackage;
|
||||||
import com.facebook.react.config.ReactFeatureFlags;
|
import com.facebook.react.config.ReactFeatureFlags;
|
||||||
import com.facebook.soloader.SoLoader;
|
import com.facebook.soloader.SoLoader;
|
||||||
import com.example.wakureactnative.newarchitecture.MainApplicationReactNativeHost;
|
import com.example.newarchitecture.MainApplicationReactNativeHost;
|
||||||
|
|
||||||
|
import expo.modules.ApplicationLifecycleDispatcher;
|
||||||
|
import expo.modules.ReactNativeHostWrapper;
|
||||||
|
|
||||||
import java.lang.reflect.InvocationTargetException;
|
import java.lang.reflect.InvocationTargetException;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
public class MainApplication extends Application implements ReactApplication {
|
public class MainApplication extends Application implements ReactApplication {
|
||||||
|
private final ReactNativeHost mReactNativeHost = new ReactNativeHostWrapper(
|
||||||
|
this,
|
||||||
|
new ReactNativeHost(this) {
|
||||||
|
@Override
|
||||||
|
public boolean getUseDeveloperSupport() {
|
||||||
|
return BuildConfig.DEBUG;
|
||||||
|
}
|
||||||
|
|
||||||
private final ReactNativeHost mReactNativeHost =
|
@Override
|
||||||
new ReactNativeHost(this) {
|
protected List<ReactPackage> getPackages() {
|
||||||
@Override
|
@SuppressWarnings("UnnecessaryLocalVariable")
|
||||||
public boolean getUseDeveloperSupport() {
|
List<ReactPackage> packages = new PackageList(this).getPackages();
|
||||||
return BuildConfig.DEBUG;
|
// Packages that cannot be autolinked yet can be added manually here, for example:
|
||||||
}
|
// packages.add(new MyReactNativePackage());
|
||||||
|
return packages;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected List<ReactPackage> getPackages() {
|
protected String getJSMainModuleName() {
|
||||||
@SuppressWarnings("UnnecessaryLocalVariable")
|
return "index";
|
||||||
List<ReactPackage> packages = new PackageList(this).getPackages();
|
}
|
||||||
// Packages that cannot be autolinked yet can be added manually here, for example:
|
});
|
||||||
// packages.add(new MyReactNativePackage());
|
|
||||||
return packages;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected String getJSMainModuleName() {
|
|
||||||
return "index";
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
private final ReactNativeHost mNewArchitectureNativeHost =
|
private final ReactNativeHost mNewArchitectureNativeHost =
|
||||||
new MainApplicationReactNativeHost(this);
|
new ReactNativeHostWrapper(this, new MainApplicationReactNativeHost(this));
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ReactNativeHost getReactNativeHost() {
|
public ReactNativeHost getReactNativeHost() {
|
||||||
@ -55,7 +62,15 @@ public class MainApplication extends Application implements ReactApplication {
|
|||||||
// If you opted-in for the New Architecture, we enable the TurboModule system
|
// If you opted-in for the New Architecture, we enable the TurboModule system
|
||||||
ReactFeatureFlags.useTurboModules = BuildConfig.IS_NEW_ARCHITECTURE_ENABLED;
|
ReactFeatureFlags.useTurboModules = BuildConfig.IS_NEW_ARCHITECTURE_ENABLED;
|
||||||
SoLoader.init(this, /* native exopackage */ false);
|
SoLoader.init(this, /* native exopackage */ false);
|
||||||
|
|
||||||
initializeFlipper(this, getReactNativeHost().getReactInstanceManager());
|
initializeFlipper(this, getReactNativeHost().getReactInstanceManager());
|
||||||
|
ApplicationLifecycleDispatcher.onApplicationCreate(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onConfigurationChanged(@NonNull Configuration newConfig) {
|
||||||
|
super.onConfigurationChanged(newConfig);
|
||||||
|
ApplicationLifecycleDispatcher.onConfigurationChanged(this, newConfig);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -73,7 +88,7 @@ public class MainApplication extends Application implements ReactApplication {
|
|||||||
We use reflection here to pick up the class that initializes Flipper,
|
We use reflection here to pick up the class that initializes Flipper,
|
||||||
since Flipper library is not available in release mode
|
since Flipper library is not available in release mode
|
||||||
*/
|
*/
|
||||||
Class<?> aClass = Class.forName("com.example.wakureactnative.ReactNativeFlipper");
|
Class<?> aClass = Class.forName("com.example.ReactNativeFlipper");
|
||||||
aClass
|
aClass
|
||||||
.getMethod("initializeFlipper", Context.class, ReactInstanceManager.class)
|
.getMethod("initializeFlipper", Context.class, ReactInstanceManager.class)
|
||||||
.invoke(null, context, reactInstanceManager);
|
.invoke(null, context, reactInstanceManager);
|
||||||
@ -1,4 +1,4 @@
|
|||||||
package com.example.wakureactnative.newarchitecture;
|
package com.example.newarchitecture;
|
||||||
|
|
||||||
import android.app.Application;
|
import android.app.Application;
|
||||||
import androidx.annotation.NonNull;
|
import androidx.annotation.NonNull;
|
||||||
@ -18,10 +18,11 @@ import com.facebook.react.fabric.ComponentFactory;
|
|||||||
import com.facebook.react.fabric.CoreComponentsRegistry;
|
import com.facebook.react.fabric.CoreComponentsRegistry;
|
||||||
import com.facebook.react.fabric.EmptyReactNativeConfig;
|
import com.facebook.react.fabric.EmptyReactNativeConfig;
|
||||||
import com.facebook.react.fabric.FabricJSIModuleProvider;
|
import com.facebook.react.fabric.FabricJSIModuleProvider;
|
||||||
|
import com.facebook.react.fabric.ReactNativeConfig;
|
||||||
import com.facebook.react.uimanager.ViewManagerRegistry;
|
import com.facebook.react.uimanager.ViewManagerRegistry;
|
||||||
import com.example.wakureactnative.BuildConfig;
|
import com.example.BuildConfig;
|
||||||
import com.example.wakureactnative.newarchitecture.components.MainComponentsRegistry;
|
import com.example.newarchitecture.components.MainComponentsRegistry;
|
||||||
import com.example.wakureactnative.newarchitecture.modules.MainApplicationTurboModuleManagerDelegate;
|
import com.example.newarchitecture.modules.MainApplicationTurboModuleManagerDelegate;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@ -105,7 +106,7 @@ public class MainApplicationReactNativeHost extends ReactNativeHost {
|
|||||||
return new FabricJSIModuleProvider(
|
return new FabricJSIModuleProvider(
|
||||||
reactApplicationContext,
|
reactApplicationContext,
|
||||||
componentFactory,
|
componentFactory,
|
||||||
new EmptyReactNativeConfig(),
|
ReactNativeConfig.DEFAULT_CONFIG,
|
||||||
viewManagerRegistry);
|
viewManagerRegistry);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -1,4 +1,4 @@
|
|||||||
package com.example.wakureactnative.newarchitecture.components;
|
package com.example.newarchitecture.components;
|
||||||
|
|
||||||
import com.facebook.jni.HybridData;
|
import com.facebook.jni.HybridData;
|
||||||
import com.facebook.proguard.annotations.DoNotStrip;
|
import com.facebook.proguard.annotations.DoNotStrip;
|
||||||
@ -1,4 +1,4 @@
|
|||||||
package com.example.wakureactnative.newarchitecture.modules;
|
package com.example.newarchitecture.modules;
|
||||||
|
|
||||||
import com.facebook.jni.HybridData;
|
import com.facebook.jni.HybridData;
|
||||||
import com.facebook.react.ReactPackage;
|
import com.facebook.react.ReactPackage;
|
||||||
@ -1,40 +0,0 @@
|
|||||||
package com.example.wakureactnative;
|
|
||||||
|
|
||||||
import com.facebook.react.ReactActivity;
|
|
||||||
import com.facebook.react.ReactActivityDelegate;
|
|
||||||
import com.facebook.react.ReactRootView;
|
|
||||||
|
|
||||||
public class MainActivity extends ReactActivity {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the name of the main component registered from JavaScript. This is used to schedule
|
|
||||||
* rendering of the component.
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
protected String getMainComponentName() {
|
|
||||||
return "main";
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the instance of the {@link ReactActivityDelegate}. There the RootView is created and
|
|
||||||
* you can specify the rendered you wish to use (Fabric or the older renderer).
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
protected ReactActivityDelegate createReactActivityDelegate() {
|
|
||||||
return new MainActivityDelegate(this, getMainComponentName());
|
|
||||||
}
|
|
||||||
|
|
||||||
public static class MainActivityDelegate extends ReactActivityDelegate {
|
|
||||||
public MainActivityDelegate(ReactActivity activity, String mainComponentName) {
|
|
||||||
super(activity, mainComponentName);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected ReactRootView createRootView() {
|
|
||||||
ReactRootView reactRootView = new ReactRootView(getContext());
|
|
||||||
// If you opted-in for the New Architecture, we enable the Fabric Renderer.
|
|
||||||
reactRootView.setIsFabric(BuildConfig.IS_NEW_ARCHITECTURE_ENABLED);
|
|
||||||
return reactRootView;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@ -1,49 +0,0 @@
|
|||||||
THIS_DIR := $(call my-dir)
|
|
||||||
|
|
||||||
include $(REACT_ANDROID_DIR)/Android-prebuilt.mk
|
|
||||||
|
|
||||||
# If you wish to add a custom TurboModule or Fabric component in your app you
|
|
||||||
# will have to include the following autogenerated makefile.
|
|
||||||
# include $(GENERATED_SRC_DIR)/codegen/jni/Android.mk
|
|
||||||
include $(CLEAR_VARS)
|
|
||||||
|
|
||||||
LOCAL_PATH := $(THIS_DIR)
|
|
||||||
|
|
||||||
# You can customize the name of your application .so file here.
|
|
||||||
LOCAL_MODULE := example_appmodules
|
|
||||||
|
|
||||||
LOCAL_C_INCLUDES := $(LOCAL_PATH)
|
|
||||||
LOCAL_SRC_FILES := $(wildcard $(LOCAL_PATH)/*.cpp)
|
|
||||||
LOCAL_EXPORT_C_INCLUDES := $(LOCAL_PATH)
|
|
||||||
|
|
||||||
# If you wish to add a custom TurboModule or Fabric component in your app you
|
|
||||||
# will have to uncomment those lines to include the generated source
|
|
||||||
# files from the codegen (placed in $(GENERATED_SRC_DIR)/codegen/jni)
|
|
||||||
#
|
|
||||||
# LOCAL_C_INCLUDES += $(GENERATED_SRC_DIR)/codegen/jni
|
|
||||||
# LOCAL_SRC_FILES += $(wildcard $(GENERATED_SRC_DIR)/codegen/jni/*.cpp)
|
|
||||||
# LOCAL_EXPORT_C_INCLUDES += $(GENERATED_SRC_DIR)/codegen/jni
|
|
||||||
|
|
||||||
# Here you should add any native library you wish to depend on.
|
|
||||||
LOCAL_SHARED_LIBRARIES := \
|
|
||||||
libfabricjni \
|
|
||||||
libfbjni \
|
|
||||||
libfolly_futures \
|
|
||||||
libfolly_json \
|
|
||||||
libglog \
|
|
||||||
libjsi \
|
|
||||||
libreact_codegen_rncore \
|
|
||||||
libreact_debug \
|
|
||||||
libreact_nativemodule_core \
|
|
||||||
libreact_render_componentregistry \
|
|
||||||
libreact_render_core \
|
|
||||||
libreact_render_debug \
|
|
||||||
libreact_render_graphics \
|
|
||||||
librrc_view \
|
|
||||||
libruntimeexecutor \
|
|
||||||
libturbomodulejsijni \
|
|
||||||
libyoga
|
|
||||||
|
|
||||||
LOCAL_CFLAGS := -DLOG_TAG=\"ReactNative\" -fexceptions -frtti -std=c++17 -Wall
|
|
||||||
|
|
||||||
include $(BUILD_SHARED_LIBRARY)
|
|
||||||
7
example/android/app/src/main/jni/CMakeLists.txt
Normal file
7
example/android/app/src/main/jni/CMakeLists.txt
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
cmake_minimum_required(VERSION 3.13)
|
||||||
|
|
||||||
|
# Define the library name here.
|
||||||
|
project(example_appmodules)
|
||||||
|
|
||||||
|
# This file includes all the necessary to let you build your application with the New Architecture.
|
||||||
|
include(${REACT_ANDROID_DIR}/cmake-utils/ReactNative-application.cmake)
|
||||||
@ -1,12 +1,13 @@
|
|||||||
#include "MainApplicationModuleProvider.h"
|
#include "MainApplicationModuleProvider.h"
|
||||||
|
|
||||||
|
#include <rncli.h>
|
||||||
#include <rncore.h>
|
#include <rncore.h>
|
||||||
|
|
||||||
namespace facebook {
|
namespace facebook {
|
||||||
namespace react {
|
namespace react {
|
||||||
|
|
||||||
std::shared_ptr<TurboModule> MainApplicationModuleProvider(
|
std::shared_ptr<TurboModule> MainApplicationModuleProvider(
|
||||||
const std::string moduleName,
|
const std::string &moduleName,
|
||||||
const JavaTurboModule::InitParams ¶ms) {
|
const JavaTurboModule::InitParams ¶ms) {
|
||||||
// Here you can provide your own module provider for TurboModules coming from
|
// Here you can provide your own module provider for TurboModules coming from
|
||||||
// either your application or from external libraries. The approach to follow
|
// either your application or from external libraries. The approach to follow
|
||||||
@ -18,6 +19,11 @@ std::shared_ptr<TurboModule> MainApplicationModuleProvider(
|
|||||||
// }
|
// }
|
||||||
// return rncore_ModuleProvider(moduleName, params);
|
// return rncore_ModuleProvider(moduleName, params);
|
||||||
|
|
||||||
|
// Module providers autolinked by RN CLI
|
||||||
|
auto rncli_module = rncli_ModuleProvider(moduleName, params);
|
||||||
|
if (rncli_module != nullptr) {
|
||||||
|
return rncli_module;
|
||||||
|
}
|
||||||
|
|
||||||
return rncore_ModuleProvider(moduleName, params);
|
return rncore_ModuleProvider(moduleName, params);
|
||||||
}
|
}
|
||||||
|
|||||||
@ -9,7 +9,7 @@ namespace facebook {
|
|||||||
namespace react {
|
namespace react {
|
||||||
|
|
||||||
std::shared_ptr<TurboModule> MainApplicationModuleProvider(
|
std::shared_ptr<TurboModule> MainApplicationModuleProvider(
|
||||||
const std::string moduleName,
|
const std::string &moduleName,
|
||||||
const JavaTurboModule::InitParams ¶ms);
|
const JavaTurboModule::InitParams ¶ms);
|
||||||
|
|
||||||
} // namespace react
|
} // namespace react
|
||||||
|
|||||||
@ -22,21 +22,21 @@ void MainApplicationTurboModuleManagerDelegate::registerNatives() {
|
|||||||
|
|
||||||
std::shared_ptr<TurboModule>
|
std::shared_ptr<TurboModule>
|
||||||
MainApplicationTurboModuleManagerDelegate::getTurboModule(
|
MainApplicationTurboModuleManagerDelegate::getTurboModule(
|
||||||
const std::string name,
|
const std::string &name,
|
||||||
const std::shared_ptr<CallInvoker> jsInvoker) {
|
const std::shared_ptr<CallInvoker> &jsInvoker) {
|
||||||
// Not implemented yet: provide pure-C++ NativeModules here.
|
// Not implemented yet: provide pure-C++ NativeModules here.
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::shared_ptr<TurboModule>
|
std::shared_ptr<TurboModule>
|
||||||
MainApplicationTurboModuleManagerDelegate::getTurboModule(
|
MainApplicationTurboModuleManagerDelegate::getTurboModule(
|
||||||
const std::string name,
|
const std::string &name,
|
||||||
const JavaTurboModule::InitParams ¶ms) {
|
const JavaTurboModule::InitParams ¶ms) {
|
||||||
return MainApplicationModuleProvider(name, params);
|
return MainApplicationModuleProvider(name, params);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool MainApplicationTurboModuleManagerDelegate::canCreateTurboModule(
|
bool MainApplicationTurboModuleManagerDelegate::canCreateTurboModule(
|
||||||
std::string name) {
|
const std::string &name) {
|
||||||
return getTurboModule(name, nullptr) != nullptr ||
|
return getTurboModule(name, nullptr) != nullptr ||
|
||||||
getTurboModule(name, {.moduleName = name}) != nullptr;
|
getTurboModule(name, {.moduleName = name}) != nullptr;
|
||||||
}
|
}
|
||||||
|
|||||||
@ -14,24 +14,24 @@ class MainApplicationTurboModuleManagerDelegate
|
|||||||
public:
|
public:
|
||||||
// Adapt it to the package you used for your Java class.
|
// Adapt it to the package you used for your Java class.
|
||||||
static constexpr auto kJavaDescriptor =
|
static constexpr auto kJavaDescriptor =
|
||||||
"Lcom/example/wakureactnative/newarchitecture/modules/MainApplicationTurboModuleManagerDelegate;";
|
"Lcom/example/newarchitecture/modules/MainApplicationTurboModuleManagerDelegate;";
|
||||||
|
|
||||||
static jni::local_ref<jhybriddata> initHybrid(jni::alias_ref<jhybridobject>);
|
static jni::local_ref<jhybriddata> initHybrid(jni::alias_ref<jhybridobject>);
|
||||||
|
|
||||||
static void registerNatives();
|
static void registerNatives();
|
||||||
|
|
||||||
std::shared_ptr<TurboModule> getTurboModule(
|
std::shared_ptr<TurboModule> getTurboModule(
|
||||||
const std::string name,
|
const std::string &name,
|
||||||
const std::shared_ptr<CallInvoker> jsInvoker) override;
|
const std::shared_ptr<CallInvoker> &jsInvoker) override;
|
||||||
std::shared_ptr<TurboModule> getTurboModule(
|
std::shared_ptr<TurboModule> getTurboModule(
|
||||||
const std::string name,
|
const std::string &name,
|
||||||
const JavaTurboModule::InitParams ¶ms) override;
|
const JavaTurboModule::InitParams ¶ms) override;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test-only method. Allows user to verify whether a TurboModule can be
|
* Test-only method. Allows user to verify whether a TurboModule can be
|
||||||
* created by instances of this class.
|
* created by instances of this class.
|
||||||
*/
|
*/
|
||||||
bool canCreateTurboModule(std::string name);
|
bool canCreateTurboModule(const std::string &name);
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace react
|
} // namespace react
|
||||||
|
|||||||
@ -4,6 +4,7 @@
|
|||||||
#include <fbjni/fbjni.h>
|
#include <fbjni/fbjni.h>
|
||||||
#include <react/renderer/componentregistry/ComponentDescriptorProviderRegistry.h>
|
#include <react/renderer/componentregistry/ComponentDescriptorProviderRegistry.h>
|
||||||
#include <react/renderer/components/rncore/ComponentDescriptors.h>
|
#include <react/renderer/components/rncore/ComponentDescriptors.h>
|
||||||
|
#include <rncli.h>
|
||||||
|
|
||||||
namespace facebook {
|
namespace facebook {
|
||||||
namespace react {
|
namespace react {
|
||||||
@ -14,6 +15,9 @@ std::shared_ptr<ComponentDescriptorProviderRegistry const>
|
|||||||
MainComponentsRegistry::sharedProviderRegistry() {
|
MainComponentsRegistry::sharedProviderRegistry() {
|
||||||
auto providerRegistry = CoreComponentsRegistry::sharedProviderRegistry();
|
auto providerRegistry = CoreComponentsRegistry::sharedProviderRegistry();
|
||||||
|
|
||||||
|
// Autolinked providers registered by RN CLI
|
||||||
|
rncli_registerProviders(providerRegistry);
|
||||||
|
|
||||||
// Custom Fabric Components go here. You can register custom
|
// Custom Fabric Components go here. You can register custom
|
||||||
// components coming from your App or from 3rd party libraries here.
|
// components coming from your App or from 3rd party libraries here.
|
||||||
//
|
//
|
||||||
|
|||||||
@ -13,7 +13,7 @@ class MainComponentsRegistry
|
|||||||
public:
|
public:
|
||||||
// Adapt it to the package you used for your Java class.
|
// Adapt it to the package you used for your Java class.
|
||||||
constexpr static auto kJavaDescriptor =
|
constexpr static auto kJavaDescriptor =
|
||||||
"Lcom/example/wakureactnative/newarchitecture/components/MainComponentsRegistry;";
|
"Lcom/example/newarchitecture/components/MainComponentsRegistry;";
|
||||||
|
|
||||||
static void registerNatives();
|
static void registerNatives();
|
||||||
|
|
||||||
|
|||||||
@ -0,0 +1,4 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
|
||||||
|
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
|
||||||
|
<item android:drawable="@color/splashscreen_background"/>
|
||||||
|
</layer-list>
|
||||||
BIN
example/android/app/src/main/res/drawable/splashscreen_image.png
Normal file
BIN
example/android/app/src/main/res/drawable/splashscreen_image.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 9.1 KiB |
4
example/android/app/src/main/res/values/colors.xml
Normal file
4
example/android/app/src/main/res/values/colors.xml
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
|
||||||
|
<resources>
|
||||||
|
<color name="splashscreen_background">#FFFFFF</color>
|
||||||
|
</resources>
|
||||||
@ -1,3 +1,3 @@
|
|||||||
<resources>
|
<resources>
|
||||||
<string name="app_name">ReactNative Example</string>
|
<string name="app_name">example</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
|||||||
@ -1,9 +1,15 @@
|
|||||||
<resources>
|
<resources>
|
||||||
|
<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
|
||||||
<!-- Base application theme. -->
|
<item name="android:textColor">@android:color/black</item>
|
||||||
<style name="AppTheme" parent="Theme.AppCompat.DayNight.NoActionBar">
|
<item name="android:editTextStyle">@style/ResetEditText</item>
|
||||||
<!-- Customize your theme here. -->
|
<item name="android:editTextBackground">@drawable/rn_edit_text_material</item>
|
||||||
<item name="android:editTextBackground">@drawable/rn_edit_text_material</item>
|
</style>
|
||||||
</style>
|
<style name="ResetEditText" parent="@android:style/Widget.EditText">
|
||||||
|
<item name="android:padding">0dp</item>
|
||||||
|
<item name="android:textColorHint">#c8c8c8</item>
|
||||||
|
<item name="android:textColor">@android:color/black</item>
|
||||||
|
</style>
|
||||||
|
<style name="Theme.App.SplashScreen" parent="AppTheme">
|
||||||
|
<item name="android:windowBackground">@drawable/splashscreen</item>
|
||||||
|
</style>
|
||||||
</resources>
|
</resources>
|
||||||
|
|||||||
@ -1,20 +1,22 @@
|
|||||||
import org.apache.tools.ant.taskdefs.condition.Os
|
|
||||||
|
|
||||||
// Top-level build file where you can add configuration options common to all sub-projects/modules.
|
// Top-level build file where you can add configuration options common to all sub-projects/modules.
|
||||||
|
|
||||||
buildscript {
|
buildscript {
|
||||||
ext {
|
ext {
|
||||||
buildToolsVersion = "31.0.0"
|
buildToolsVersion = findProperty('android.buildToolsVersion') ?: '31.0.0'
|
||||||
minSdkVersion = 21
|
minSdkVersion = Integer.parseInt(findProperty('android.minSdkVersion') ?: '23')
|
||||||
compileSdkVersion = 31
|
compileSdkVersion = Integer.parseInt(findProperty('android.compileSdkVersion') ?: '31')
|
||||||
targetSdkVersion = 31
|
targetSdkVersion = Integer.parseInt(findProperty('android.targetSdkVersion') ?: '31')
|
||||||
|
if (findProperty('android.kotlinVersion')) {
|
||||||
|
kotlinVersion = findProperty('android.kotlinVersion')
|
||||||
|
}
|
||||||
|
frescoVersion = findProperty('expo.frescoVersion') ?: '2.5.0'
|
||||||
|
|
||||||
if (System.properties['os.arch'] == "aarch64") {
|
if (System.properties['os.arch'] == 'aarch64') {
|
||||||
// For M1 Users we need to use the NDK 24 which added support for aarch64
|
// For M1 Users we need to use the NDK 24 which added support for aarch64
|
||||||
ndkVersion = "24.0.8215888"
|
ndkVersion = '24.0.8215888'
|
||||||
} else {
|
} else {
|
||||||
// Otherwise we default to the side-by-side NDK version from AGP.
|
// Otherwise we default to the side-by-side NDK version from AGP.
|
||||||
ndkVersion = "21.4.7075529"
|
ndkVersion = '21.4.7075529'
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
repositories {
|
repositories {
|
||||||
@ -22,32 +24,42 @@ buildscript {
|
|||||||
mavenCentral()
|
mavenCentral()
|
||||||
}
|
}
|
||||||
dependencies {
|
dependencies {
|
||||||
classpath("com.android.tools.build:gradle:7.0.4")
|
classpath('com.android.tools.build:gradle:7.2.1')
|
||||||
classpath("com.facebook.react:react-native-gradle-plugin")
|
classpath('com.facebook.react:react-native-gradle-plugin')
|
||||||
classpath("de.undercouch:gradle-download-task:4.1.2")
|
classpath('de.undercouch:gradle-download-task:5.0.1')
|
||||||
// NOTE: Do not place your application dependencies here; they belong
|
// NOTE: Do not place your application dependencies here; they belong
|
||||||
// in the individual module build.gradle files
|
// in the individual module build.gradle files
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
def REACT_NATIVE_VERSION = new File(['node', '--print', "JSON.parse(require('fs').readFileSync(require.resolve('react-native/package.json'), 'utf-8')).version"].execute(null, rootDir).text.trim())
|
||||||
|
|
||||||
allprojects {
|
allprojects {
|
||||||
|
configurations.all {
|
||||||
|
resolutionStrategy {
|
||||||
|
force "com.facebook.react:react-native:" + REACT_NATIVE_VERSION
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
repositories {
|
repositories {
|
||||||
|
mavenLocal()
|
||||||
maven {
|
maven {
|
||||||
// All of React Native (JS, Obj-C sources, Android binaries) is installed from npm
|
// All of React Native (JS, Obj-C sources, Android binaries) is installed from npm
|
||||||
url("$rootDir/../node_modules/react-native/android")
|
url(new File(['node', '--print', "require.resolve('react-native/package.json')"].execute(null, rootDir).text.trim(), '../android'))
|
||||||
}
|
}
|
||||||
maven {
|
maven {
|
||||||
// Android JSC is installed from npm
|
// Android JSC is installed from npm
|
||||||
url("$rootDir/../node_modules/jsc-android/dist")
|
url(new File(['node', '--print', "require.resolve('jsc-android/package.json')"].execute(null, rootDir).text.trim(), '../dist'))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
google()
|
||||||
mavenCentral {
|
mavenCentral {
|
||||||
// We don't want to fetch react-native from Maven Central as there are
|
// We don't want to fetch react-native from Maven Central as there are
|
||||||
// older versions over there.
|
// older versions over there.
|
||||||
content {
|
content {
|
||||||
excludeGroup "com.facebook.react"
|
excludeGroup 'com.facebook.react'
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
google()
|
|
||||||
maven { url 'https://www.jitpack.io' }
|
maven { url 'https://www.jitpack.io' }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -21,6 +21,7 @@ org.gradle.jvmargs=-Xmx2048m -XX:MaxMetaspaceSize=512m
|
|||||||
# Android operating system, and which are packaged with your app's APK
|
# Android operating system, and which are packaged with your app's APK
|
||||||
# https://developer.android.com/topic/libraries/support-library/androidx-rn
|
# https://developer.android.com/topic/libraries/support-library/androidx-rn
|
||||||
android.useAndroidX=true
|
android.useAndroidX=true
|
||||||
|
|
||||||
# Automatically convert third-party libraries to use AndroidX
|
# Automatically convert third-party libraries to use AndroidX
|
||||||
android.enableJetifier=true
|
android.enableJetifier=true
|
||||||
|
|
||||||
@ -38,3 +39,15 @@ reactNativeArchitectures=armeabi-v7a,arm64-v8a,x86,x86_64
|
|||||||
# to write custom TurboModules/Fabric components OR use libraries that
|
# to write custom TurboModules/Fabric components OR use libraries that
|
||||||
# are providing them.
|
# are providing them.
|
||||||
newArchEnabled=false
|
newArchEnabled=false
|
||||||
|
|
||||||
|
# The hosted JavaScript engine
|
||||||
|
# Supported values: expo.jsEngine = "hermes" | "jsc"
|
||||||
|
expo.jsEngine=jsc
|
||||||
|
|
||||||
|
# Enable GIF support in React Native images (~200 B increase)
|
||||||
|
expo.gif.enabled=true
|
||||||
|
# Enable webp support in React Native images (~85 KB increase)
|
||||||
|
expo.webp.enabled=true
|
||||||
|
# Enable animated webp support (~3.4 MB increase)
|
||||||
|
# Disabled by default because iOS doesn't support animated webp
|
||||||
|
expo.webp.animated=false
|
||||||
|
|||||||
BIN
example/android/gradle/wrapper/gradle-wrapper.jar
vendored
BIN
example/android/gradle/wrapper/gradle-wrapper.jar
vendored
Binary file not shown.
@ -1,5 +1,5 @@
|
|||||||
distributionBase=GRADLE_USER_HOME
|
distributionBase=GRADLE_USER_HOME
|
||||||
distributionPath=wrapper/dists
|
distributionPath=wrapper/dists
|
||||||
distributionUrl=https\://services.gradle.org/distributions/gradle-7.3.3-all.zip
|
distributionUrl=https\://services.gradle.org/distributions/gradle-7.5.1-all.zip
|
||||||
zipStoreBase=GRADLE_USER_HOME
|
zipStoreBase=GRADLE_USER_HOME
|
||||||
zipStorePath=wrapper/dists
|
zipStorePath=wrapper/dists
|
||||||
|
|||||||
6
example/android/gradlew
vendored
6
example/android/gradlew
vendored
@ -205,6 +205,12 @@ set -- \
|
|||||||
org.gradle.wrapper.GradleWrapperMain \
|
org.gradle.wrapper.GradleWrapperMain \
|
||||||
"$@"
|
"$@"
|
||||||
|
|
||||||
|
# Stop when "xargs" is not available.
|
||||||
|
if ! command -v xargs >/dev/null 2>&1
|
||||||
|
then
|
||||||
|
die "xargs is not available"
|
||||||
|
fi
|
||||||
|
|
||||||
# Use "xargs" to parse quoted args.
|
# Use "xargs" to parse quoted args.
|
||||||
#
|
#
|
||||||
# With -n1 it outputs one arg per line, with the quotes and backslashes removed.
|
# With -n1 it outputs one arg per line, with the quotes and backslashes removed.
|
||||||
|
|||||||
14
example/android/gradlew.bat
vendored
14
example/android/gradlew.bat
vendored
@ -14,7 +14,7 @@
|
|||||||
@rem limitations under the License.
|
@rem limitations under the License.
|
||||||
@rem
|
@rem
|
||||||
|
|
||||||
@if "%DEBUG%" == "" @echo off
|
@if "%DEBUG%"=="" @echo off
|
||||||
@rem ##########################################################################
|
@rem ##########################################################################
|
||||||
@rem
|
@rem
|
||||||
@rem Gradle startup script for Windows
|
@rem Gradle startup script for Windows
|
||||||
@ -25,7 +25,7 @@
|
|||||||
if "%OS%"=="Windows_NT" setlocal
|
if "%OS%"=="Windows_NT" setlocal
|
||||||
|
|
||||||
set DIRNAME=%~dp0
|
set DIRNAME=%~dp0
|
||||||
if "%DIRNAME%" == "" set DIRNAME=.
|
if "%DIRNAME%"=="" set DIRNAME=.
|
||||||
set APP_BASE_NAME=%~n0
|
set APP_BASE_NAME=%~n0
|
||||||
set APP_HOME=%DIRNAME%
|
set APP_HOME=%DIRNAME%
|
||||||
|
|
||||||
@ -40,7 +40,7 @@ if defined JAVA_HOME goto findJavaFromJavaHome
|
|||||||
|
|
||||||
set JAVA_EXE=java.exe
|
set JAVA_EXE=java.exe
|
||||||
%JAVA_EXE% -version >NUL 2>&1
|
%JAVA_EXE% -version >NUL 2>&1
|
||||||
if "%ERRORLEVEL%" == "0" goto execute
|
if %ERRORLEVEL% equ 0 goto execute
|
||||||
|
|
||||||
echo.
|
echo.
|
||||||
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
|
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
|
||||||
@ -75,13 +75,15 @@ set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
|
|||||||
|
|
||||||
:end
|
:end
|
||||||
@rem End local scope for the variables with windows NT shell
|
@rem End local scope for the variables with windows NT shell
|
||||||
if "%ERRORLEVEL%"=="0" goto mainEnd
|
if %ERRORLEVEL% equ 0 goto mainEnd
|
||||||
|
|
||||||
:fail
|
:fail
|
||||||
rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
|
rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
|
||||||
rem the _cmd.exe /c_ return code!
|
rem the _cmd.exe /c_ return code!
|
||||||
if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
|
set EXIT_CODE=%ERRORLEVEL%
|
||||||
exit /b 1
|
if %EXIT_CODE% equ 0 set EXIT_CODE=1
|
||||||
|
if not ""=="%GRADLE_EXIT_CONSOLE%" exit %EXIT_CODE%
|
||||||
|
exit /b %EXIT_CODE%
|
||||||
|
|
||||||
:mainEnd
|
:mainEnd
|
||||||
if "%OS%"=="Windows_NT" endlocal
|
if "%OS%"=="Windows_NT" endlocal
|
||||||
|
|||||||
@ -1,9 +1,20 @@
|
|||||||
rootProject.name = 'ReactNativeExample'
|
rootProject.name = 'example'
|
||||||
apply from: file("../node_modules/@react-native-community/cli-platform-android/native_modules.gradle"); applyNativeModulesSettingsGradle(settings)
|
|
||||||
|
apply from: new File(["node", "--print", "require.resolve('expo/package.json')"].execute(null, rootDir).text.trim(), "../scripts/autolinking.gradle");
|
||||||
|
useExpoModules()
|
||||||
|
|
||||||
|
apply from: new File(["node", "--print", "require.resolve('@react-native-community/cli-platform-android/package.json')"].execute(null, rootDir).text.trim(), "../native_modules.gradle");
|
||||||
|
applyNativeModulesSettingsGradle(settings)
|
||||||
|
|
||||||
include ':app'
|
include ':app'
|
||||||
includeBuild('../node_modules/react-native-gradle-plugin')
|
includeBuild(new File(["node", "--print", "require.resolve('react-native-gradle-plugin/package.json')"].execute(null, rootDir).text.trim()).getParentFile())
|
||||||
|
|
||||||
if (settings.hasProperty("newArchEnabled") && settings.newArchEnabled == "true") {
|
if (settings.hasProperty("newArchEnabled") && settings.newArchEnabled == "true") {
|
||||||
include(":ReactAndroid")
|
include(":ReactAndroid")
|
||||||
project(":ReactAndroid").projectDir = file('../node_modules/react-native/ReactAndroid')
|
project(":ReactAndroid").projectDir = new File(["node", "--print", "require.resolve('react-native/package.json')"].execute(null, rootDir).text.trim(), "../ReactAndroid");
|
||||||
|
include(":ReactAndroid:hermes-engine")
|
||||||
|
project(":ReactAndroid:hermes-engine").projectDir = new File(["node", "--print", "require.resolve('react-native/package.json')"].execute(null, rootDir).text.trim(), "../ReactAndroid/hermes-engine");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
include ':gowaku'
|
||||||
|
project(':gowaku').projectDir = new File(rootProject.projectDir, './../node_modules/@waku/react-native/android/gowaku')
|
||||||
11
example/app.json
Normal file
11
example/app.json
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
{
|
||||||
|
"expo": {
|
||||||
|
"name": "example",
|
||||||
|
"slug": "example",
|
||||||
|
"version": "1.0.0",
|
||||||
|
"assetBundlePatterns": [
|
||||||
|
"**/*"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"name": "example"
|
||||||
|
}
|
||||||
@ -1,17 +1,6 @@
|
|||||||
const path = require('path');
|
module.exports = function (api) {
|
||||||
const pak = require('../package.json');
|
api.cache(true);
|
||||||
|
return {
|
||||||
module.exports = {
|
presets: ['babel-preset-expo'],
|
||||||
presets: ['module:metro-react-native-babel-preset'],
|
};
|
||||||
plugins: [
|
|
||||||
[
|
|
||||||
'module-resolver',
|
|
||||||
{
|
|
||||||
extensions: ['.tsx', '.ts', '.js', '.json'],
|
|
||||||
alias: {
|
|
||||||
[pak.name]: path.join(__dirname, '..', pak.source),
|
|
||||||
},
|
|
||||||
},
|
|
||||||
],
|
|
||||||
],
|
|
||||||
};
|
};
|
||||||
|
|||||||
8
example/index.js
Normal file
8
example/index.js
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
import { registerRootComponent } from 'expo';
|
||||||
|
|
||||||
|
import App from './App';
|
||||||
|
|
||||||
|
// registerRootComponent calls AppRegistry.registerComponent('main', () => App);
|
||||||
|
// It also ensures that whether you load the app in Expo Go or in a native build,
|
||||||
|
// the environment is set up appropriately
|
||||||
|
registerRootComponent(App);
|
||||||
@ -1,4 +0,0 @@
|
|||||||
import { AppRegistry } from 'react-native';
|
|
||||||
import App from './src/App';
|
|
||||||
|
|
||||||
AppRegistry.registerComponent('main', () => App);
|
|
||||||
30
example/ios/.gitignore
vendored
Normal file
30
example/ios/.gitignore
vendored
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
# OSX
|
||||||
|
#
|
||||||
|
.DS_Store
|
||||||
|
|
||||||
|
# Xcode
|
||||||
|
#
|
||||||
|
build/
|
||||||
|
*.pbxuser
|
||||||
|
!default.pbxuser
|
||||||
|
*.mode1v3
|
||||||
|
!default.mode1v3
|
||||||
|
*.mode2v3
|
||||||
|
!default.mode2v3
|
||||||
|
*.perspectivev3
|
||||||
|
!default.perspectivev3
|
||||||
|
xcuserdata
|
||||||
|
*.xccheckout
|
||||||
|
*.moved-aside
|
||||||
|
DerivedData
|
||||||
|
*.hmap
|
||||||
|
*.ipa
|
||||||
|
*.xcuserstate
|
||||||
|
project.xcworkspace
|
||||||
|
.xcode.env.local
|
||||||
|
|
||||||
|
# Bundle artifacts
|
||||||
|
*.jsbundle
|
||||||
|
|
||||||
|
# CocoaPods
|
||||||
|
/Pods/
|
||||||
11
example/ios/.xcode.env
Normal file
11
example/ios/.xcode.env
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
# This `.xcode.env` file is versioned and is used to source the environment
|
||||||
|
# used when running script phases inside Xcode.
|
||||||
|
# To customize your local environment, you can create an `.xcode.env.local`
|
||||||
|
# file that is not versioned.
|
||||||
|
|
||||||
|
# NODE_BINARY variable contains the PATH to the node executable.
|
||||||
|
#
|
||||||
|
# Customize the NODE_BINARY variable here.
|
||||||
|
# For example, to use nvm with brew, add the following line
|
||||||
|
# . "$(brew --prefix nvm)/nvm.sh" --no-use
|
||||||
|
export NODE_BINARY=$(command -v node)
|
||||||
@ -1,6 +0,0 @@
|
|||||||
//
|
|
||||||
// File.swift
|
|
||||||
// ReactNativeExample
|
|
||||||
//
|
|
||||||
|
|
||||||
import Foundation
|
|
||||||
@ -1,34 +1,61 @@
|
|||||||
require_relative '../node_modules/react-native/scripts/react_native_pods'
|
require File.join(File.dirname(`node --print "require.resolve('expo/package.json')"`), "scripts/autolinking")
|
||||||
require_relative '../node_modules/@react-native-community/cli-platform-ios/native_modules'
|
require File.join(File.dirname(`node --print "require.resolve('react-native/package.json')"`), "scripts/react_native_pods")
|
||||||
|
require File.join(File.dirname(`node --print "require.resolve('@react-native-community/cli-platform-ios/package.json')"`), "native_modules")
|
||||||
|
|
||||||
platform :ios, '11.0'
|
require 'json'
|
||||||
install! 'cocoapods', :deterministic_uuids => false
|
podfile_properties = JSON.parse(File.read(File.join(__dir__, 'Podfile.properties.json'))) rescue {}
|
||||||
|
|
||||||
ENV['RCT_NEW_ARCH_ENABLED'] = '0'
|
platform :ios, podfile_properties['ios.deploymentTarget'] || '13.0'
|
||||||
|
install! 'cocoapods',
|
||||||
|
:deterministic_uuids => false
|
||||||
|
|
||||||
target 'ReactNativeExample' do
|
target 'example' do
|
||||||
|
use_expo_modules!
|
||||||
config = use_native_modules!
|
config = use_native_modules!
|
||||||
|
|
||||||
|
use_frameworks! :linkage => podfile_properties['ios.useFrameworks'].to_sym if podfile_properties['ios.useFrameworks']
|
||||||
|
|
||||||
# Flags change depending on the env values.
|
# Flags change depending on the env values.
|
||||||
flags = get_default_flags()
|
flags = get_default_flags()
|
||||||
|
|
||||||
use_react_native!(
|
use_react_native!(
|
||||||
:path => config[:reactNativePath],
|
:path => config[:reactNativePath],
|
||||||
# to enable hermes on iOS, change `false` to `true` and then install pods
|
:hermes_enabled => podfile_properties['expo.jsEngine'] == 'hermes',
|
||||||
:hermes_enabled => true,
|
|
||||||
:fabric_enabled => flags[:fabric_enabled],
|
:fabric_enabled => flags[:fabric_enabled],
|
||||||
# An absolute path to your application root.
|
# An absolute path to your application root.
|
||||||
:app_path => "#{Pod::Config.instance.installation_root}/.."
|
:app_path => "#{Pod::Config.instance.installation_root}/..",
|
||||||
|
#
|
||||||
|
# Uncomment to opt-in to using Flipper
|
||||||
|
# Note that if you have use_frameworks! enabled, Flipper will not work
|
||||||
|
# :flipper_configuration => !ENV['CI'] ? FlipperConfiguration.enabled : FlipperConfiguration.disabled,
|
||||||
)
|
)
|
||||||
|
|
||||||
# Enables Flipper.
|
|
||||||
#
|
|
||||||
# Note that if you have use_frameworks! enabled, Flipper will not work and
|
|
||||||
# you should disable the next line.
|
|
||||||
use_flipper!()
|
|
||||||
|
|
||||||
post_install do |installer|
|
post_install do |installer|
|
||||||
react_native_post_install(installer)
|
react_native_post_install(
|
||||||
|
installer,
|
||||||
|
# Set `mac_catalyst_enabled` to `true` in order to apply patches
|
||||||
|
# necessary for Mac Catalyst builds
|
||||||
|
:mac_catalyst_enabled => false
|
||||||
|
)
|
||||||
__apply_Xcode_12_5_M1_post_install_workaround(installer)
|
__apply_Xcode_12_5_M1_post_install_workaround(installer)
|
||||||
|
|
||||||
|
# This is necessary for Xcode 14, because it signs resource bundles by default
|
||||||
|
# when building for devices.
|
||||||
|
installer.target_installation_results.pod_target_installation_results
|
||||||
|
.each do |pod_name, target_installation_result|
|
||||||
|
target_installation_result.resource_bundle_targets.each do |resource_bundle_target|
|
||||||
|
resource_bundle_target.build_configurations.each do |config|
|
||||||
|
config.build_settings['CODE_SIGNING_ALLOWED'] = 'NO'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
post_integrate do |installer|
|
||||||
|
begin
|
||||||
|
expo_patch_react_imports!(installer)
|
||||||
|
rescue => e
|
||||||
|
Pod::UI.warn e
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
@ -1,576 +0,0 @@
|
|||||||
PODS:
|
|
||||||
- boost (1.76.0)
|
|
||||||
- CocoaAsyncSocket (7.6.5)
|
|
||||||
- DoubleConversion (1.1.6)
|
|
||||||
- FBLazyVector (0.68.2)
|
|
||||||
- FBReactNativeSpec (0.68.2):
|
|
||||||
- RCT-Folly (= 2021.06.28.00-v2)
|
|
||||||
- RCTRequired (= 0.68.2)
|
|
||||||
- RCTTypeSafety (= 0.68.2)
|
|
||||||
- React-Core (= 0.68.2)
|
|
||||||
- React-jsi (= 0.68.2)
|
|
||||||
- ReactCommon/turbomodule/core (= 0.68.2)
|
|
||||||
- Flipper (0.125.0):
|
|
||||||
- Flipper-Folly (~> 2.6)
|
|
||||||
- Flipper-RSocket (~> 1.4)
|
|
||||||
- Flipper-Boost-iOSX (1.76.0.1.11)
|
|
||||||
- Flipper-DoubleConversion (3.2.0)
|
|
||||||
- Flipper-Fmt (7.1.7)
|
|
||||||
- Flipper-Folly (2.6.10):
|
|
||||||
- Flipper-Boost-iOSX
|
|
||||||
- Flipper-DoubleConversion
|
|
||||||
- Flipper-Fmt (= 7.1.7)
|
|
||||||
- Flipper-Glog
|
|
||||||
- libevent (~> 2.1.12)
|
|
||||||
- OpenSSL-Universal (= 1.1.1100)
|
|
||||||
- Flipper-Glog (0.5.0.4)
|
|
||||||
- Flipper-PeerTalk (0.0.4)
|
|
||||||
- Flipper-RSocket (1.4.3):
|
|
||||||
- Flipper-Folly (~> 2.6)
|
|
||||||
- FlipperKit (0.125.0):
|
|
||||||
- FlipperKit/Core (= 0.125.0)
|
|
||||||
- FlipperKit/Core (0.125.0):
|
|
||||||
- Flipper (~> 0.125.0)
|
|
||||||
- FlipperKit/CppBridge
|
|
||||||
- FlipperKit/FBCxxFollyDynamicConvert
|
|
||||||
- FlipperKit/FBDefines
|
|
||||||
- FlipperKit/FKPortForwarding
|
|
||||||
- SocketRocket (~> 0.6.0)
|
|
||||||
- FlipperKit/CppBridge (0.125.0):
|
|
||||||
- Flipper (~> 0.125.0)
|
|
||||||
- FlipperKit/FBCxxFollyDynamicConvert (0.125.0):
|
|
||||||
- Flipper-Folly (~> 2.6)
|
|
||||||
- FlipperKit/FBDefines (0.125.0)
|
|
||||||
- FlipperKit/FKPortForwarding (0.125.0):
|
|
||||||
- CocoaAsyncSocket (~> 7.6)
|
|
||||||
- Flipper-PeerTalk (~> 0.0.4)
|
|
||||||
- FlipperKit/FlipperKitHighlightOverlay (0.125.0)
|
|
||||||
- FlipperKit/FlipperKitLayoutHelpers (0.125.0):
|
|
||||||
- FlipperKit/Core
|
|
||||||
- FlipperKit/FlipperKitHighlightOverlay
|
|
||||||
- FlipperKit/FlipperKitLayoutTextSearchable
|
|
||||||
- FlipperKit/FlipperKitLayoutIOSDescriptors (0.125.0):
|
|
||||||
- FlipperKit/Core
|
|
||||||
- FlipperKit/FlipperKitHighlightOverlay
|
|
||||||
- FlipperKit/FlipperKitLayoutHelpers
|
|
||||||
- YogaKit (~> 1.18)
|
|
||||||
- FlipperKit/FlipperKitLayoutPlugin (0.125.0):
|
|
||||||
- FlipperKit/Core
|
|
||||||
- FlipperKit/FlipperKitHighlightOverlay
|
|
||||||
- FlipperKit/FlipperKitLayoutHelpers
|
|
||||||
- FlipperKit/FlipperKitLayoutIOSDescriptors
|
|
||||||
- FlipperKit/FlipperKitLayoutTextSearchable
|
|
||||||
- YogaKit (~> 1.18)
|
|
||||||
- FlipperKit/FlipperKitLayoutTextSearchable (0.125.0)
|
|
||||||
- FlipperKit/FlipperKitNetworkPlugin (0.125.0):
|
|
||||||
- FlipperKit/Core
|
|
||||||
- FlipperKit/FlipperKitReactPlugin (0.125.0):
|
|
||||||
- FlipperKit/Core
|
|
||||||
- FlipperKit/FlipperKitUserDefaultsPlugin (0.125.0):
|
|
||||||
- FlipperKit/Core
|
|
||||||
- FlipperKit/SKIOSNetworkPlugin (0.125.0):
|
|
||||||
- FlipperKit/Core
|
|
||||||
- FlipperKit/FlipperKitNetworkPlugin
|
|
||||||
- fmt (6.2.1)
|
|
||||||
- glog (0.3.5)
|
|
||||||
- hermes-engine (0.11.0)
|
|
||||||
- libevent (2.1.12)
|
|
||||||
- OpenSSL-Universal (1.1.1100)
|
|
||||||
- RCT-Folly (2021.06.28.00-v2):
|
|
||||||
- boost
|
|
||||||
- DoubleConversion
|
|
||||||
- fmt (~> 6.2.1)
|
|
||||||
- glog
|
|
||||||
- RCT-Folly/Default (= 2021.06.28.00-v2)
|
|
||||||
- RCT-Folly/Default (2021.06.28.00-v2):
|
|
||||||
- boost
|
|
||||||
- DoubleConversion
|
|
||||||
- fmt (~> 6.2.1)
|
|
||||||
- glog
|
|
||||||
- RCT-Folly/Futures (2021.06.28.00-v2):
|
|
||||||
- boost
|
|
||||||
- DoubleConversion
|
|
||||||
- fmt (~> 6.2.1)
|
|
||||||
- glog
|
|
||||||
- libevent
|
|
||||||
- RCTRequired (0.68.2)
|
|
||||||
- RCTTypeSafety (0.68.2):
|
|
||||||
- FBLazyVector (= 0.68.2)
|
|
||||||
- RCT-Folly (= 2021.06.28.00-v2)
|
|
||||||
- RCTRequired (= 0.68.2)
|
|
||||||
- React-Core (= 0.68.2)
|
|
||||||
- React (0.68.2):
|
|
||||||
- React-Core (= 0.68.2)
|
|
||||||
- React-Core/DevSupport (= 0.68.2)
|
|
||||||
- React-Core/RCTWebSocket (= 0.68.2)
|
|
||||||
- React-RCTActionSheet (= 0.68.2)
|
|
||||||
- React-RCTAnimation (= 0.68.2)
|
|
||||||
- React-RCTBlob (= 0.68.2)
|
|
||||||
- React-RCTImage (= 0.68.2)
|
|
||||||
- React-RCTLinking (= 0.68.2)
|
|
||||||
- React-RCTNetwork (= 0.68.2)
|
|
||||||
- React-RCTSettings (= 0.68.2)
|
|
||||||
- React-RCTText (= 0.68.2)
|
|
||||||
- React-RCTVibration (= 0.68.2)
|
|
||||||
- React-callinvoker (0.68.2)
|
|
||||||
- React-Codegen (0.68.2):
|
|
||||||
- FBReactNativeSpec (= 0.68.2)
|
|
||||||
- RCT-Folly (= 2021.06.28.00-v2)
|
|
||||||
- RCTRequired (= 0.68.2)
|
|
||||||
- RCTTypeSafety (= 0.68.2)
|
|
||||||
- React-Core (= 0.68.2)
|
|
||||||
- React-jsi (= 0.68.2)
|
|
||||||
- React-jsiexecutor (= 0.68.2)
|
|
||||||
- ReactCommon/turbomodule/core (= 0.68.2)
|
|
||||||
- React-Core (0.68.2):
|
|
||||||
- glog
|
|
||||||
- RCT-Folly (= 2021.06.28.00-v2)
|
|
||||||
- React-Core/Default (= 0.68.2)
|
|
||||||
- React-cxxreact (= 0.68.2)
|
|
||||||
- React-jsi (= 0.68.2)
|
|
||||||
- React-jsiexecutor (= 0.68.2)
|
|
||||||
- React-perflogger (= 0.68.2)
|
|
||||||
- Yoga
|
|
||||||
- React-Core/CoreModulesHeaders (0.68.2):
|
|
||||||
- glog
|
|
||||||
- RCT-Folly (= 2021.06.28.00-v2)
|
|
||||||
- React-Core/Default
|
|
||||||
- React-cxxreact (= 0.68.2)
|
|
||||||
- React-jsi (= 0.68.2)
|
|
||||||
- React-jsiexecutor (= 0.68.2)
|
|
||||||
- React-perflogger (= 0.68.2)
|
|
||||||
- Yoga
|
|
||||||
- React-Core/Default (0.68.2):
|
|
||||||
- glog
|
|
||||||
- RCT-Folly (= 2021.06.28.00-v2)
|
|
||||||
- React-cxxreact (= 0.68.2)
|
|
||||||
- React-jsi (= 0.68.2)
|
|
||||||
- React-jsiexecutor (= 0.68.2)
|
|
||||||
- React-perflogger (= 0.68.2)
|
|
||||||
- Yoga
|
|
||||||
- React-Core/DevSupport (0.68.2):
|
|
||||||
- glog
|
|
||||||
- RCT-Folly (= 2021.06.28.00-v2)
|
|
||||||
- React-Core/Default (= 0.68.2)
|
|
||||||
- React-Core/RCTWebSocket (= 0.68.2)
|
|
||||||
- React-cxxreact (= 0.68.2)
|
|
||||||
- React-jsi (= 0.68.2)
|
|
||||||
- React-jsiexecutor (= 0.68.2)
|
|
||||||
- React-jsinspector (= 0.68.2)
|
|
||||||
- React-perflogger (= 0.68.2)
|
|
||||||
- Yoga
|
|
||||||
- React-Core/RCTActionSheetHeaders (0.68.2):
|
|
||||||
- glog
|
|
||||||
- RCT-Folly (= 2021.06.28.00-v2)
|
|
||||||
- React-Core/Default
|
|
||||||
- React-cxxreact (= 0.68.2)
|
|
||||||
- React-jsi (= 0.68.2)
|
|
||||||
- React-jsiexecutor (= 0.68.2)
|
|
||||||
- React-perflogger (= 0.68.2)
|
|
||||||
- Yoga
|
|
||||||
- React-Core/RCTAnimationHeaders (0.68.2):
|
|
||||||
- glog
|
|
||||||
- RCT-Folly (= 2021.06.28.00-v2)
|
|
||||||
- React-Core/Default
|
|
||||||
- React-cxxreact (= 0.68.2)
|
|
||||||
- React-jsi (= 0.68.2)
|
|
||||||
- React-jsiexecutor (= 0.68.2)
|
|
||||||
- React-perflogger (= 0.68.2)
|
|
||||||
- Yoga
|
|
||||||
- React-Core/RCTBlobHeaders (0.68.2):
|
|
||||||
- glog
|
|
||||||
- RCT-Folly (= 2021.06.28.00-v2)
|
|
||||||
- React-Core/Default
|
|
||||||
- React-cxxreact (= 0.68.2)
|
|
||||||
- React-jsi (= 0.68.2)
|
|
||||||
- React-jsiexecutor (= 0.68.2)
|
|
||||||
- React-perflogger (= 0.68.2)
|
|
||||||
- Yoga
|
|
||||||
- React-Core/RCTImageHeaders (0.68.2):
|
|
||||||
- glog
|
|
||||||
- RCT-Folly (= 2021.06.28.00-v2)
|
|
||||||
- React-Core/Default
|
|
||||||
- React-cxxreact (= 0.68.2)
|
|
||||||
- React-jsi (= 0.68.2)
|
|
||||||
- React-jsiexecutor (= 0.68.2)
|
|
||||||
- React-perflogger (= 0.68.2)
|
|
||||||
- Yoga
|
|
||||||
- React-Core/RCTLinkingHeaders (0.68.2):
|
|
||||||
- glog
|
|
||||||
- RCT-Folly (= 2021.06.28.00-v2)
|
|
||||||
- React-Core/Default
|
|
||||||
- React-cxxreact (= 0.68.2)
|
|
||||||
- React-jsi (= 0.68.2)
|
|
||||||
- React-jsiexecutor (= 0.68.2)
|
|
||||||
- React-perflogger (= 0.68.2)
|
|
||||||
- Yoga
|
|
||||||
- React-Core/RCTNetworkHeaders (0.68.2):
|
|
||||||
- glog
|
|
||||||
- RCT-Folly (= 2021.06.28.00-v2)
|
|
||||||
- React-Core/Default
|
|
||||||
- React-cxxreact (= 0.68.2)
|
|
||||||
- React-jsi (= 0.68.2)
|
|
||||||
- React-jsiexecutor (= 0.68.2)
|
|
||||||
- React-perflogger (= 0.68.2)
|
|
||||||
- Yoga
|
|
||||||
- React-Core/RCTSettingsHeaders (0.68.2):
|
|
||||||
- glog
|
|
||||||
- RCT-Folly (= 2021.06.28.00-v2)
|
|
||||||
- React-Core/Default
|
|
||||||
- React-cxxreact (= 0.68.2)
|
|
||||||
- React-jsi (= 0.68.2)
|
|
||||||
- React-jsiexecutor (= 0.68.2)
|
|
||||||
- React-perflogger (= 0.68.2)
|
|
||||||
- Yoga
|
|
||||||
- React-Core/RCTTextHeaders (0.68.2):
|
|
||||||
- glog
|
|
||||||
- RCT-Folly (= 2021.06.28.00-v2)
|
|
||||||
- React-Core/Default
|
|
||||||
- React-cxxreact (= 0.68.2)
|
|
||||||
- React-jsi (= 0.68.2)
|
|
||||||
- React-jsiexecutor (= 0.68.2)
|
|
||||||
- React-perflogger (= 0.68.2)
|
|
||||||
- Yoga
|
|
||||||
- React-Core/RCTVibrationHeaders (0.68.2):
|
|
||||||
- glog
|
|
||||||
- RCT-Folly (= 2021.06.28.00-v2)
|
|
||||||
- React-Core/Default
|
|
||||||
- React-cxxreact (= 0.68.2)
|
|
||||||
- React-jsi (= 0.68.2)
|
|
||||||
- React-jsiexecutor (= 0.68.2)
|
|
||||||
- React-perflogger (= 0.68.2)
|
|
||||||
- Yoga
|
|
||||||
- React-Core/RCTWebSocket (0.68.2):
|
|
||||||
- glog
|
|
||||||
- RCT-Folly (= 2021.06.28.00-v2)
|
|
||||||
- React-Core/Default (= 0.68.2)
|
|
||||||
- React-cxxreact (= 0.68.2)
|
|
||||||
- React-jsi (= 0.68.2)
|
|
||||||
- React-jsiexecutor (= 0.68.2)
|
|
||||||
- React-perflogger (= 0.68.2)
|
|
||||||
- Yoga
|
|
||||||
- React-CoreModules (0.68.2):
|
|
||||||
- RCT-Folly (= 2021.06.28.00-v2)
|
|
||||||
- RCTTypeSafety (= 0.68.2)
|
|
||||||
- React-Codegen (= 0.68.2)
|
|
||||||
- React-Core/CoreModulesHeaders (= 0.68.2)
|
|
||||||
- React-jsi (= 0.68.2)
|
|
||||||
- React-RCTImage (= 0.68.2)
|
|
||||||
- ReactCommon/turbomodule/core (= 0.68.2)
|
|
||||||
- React-cxxreact (0.68.2):
|
|
||||||
- boost (= 1.76.0)
|
|
||||||
- DoubleConversion
|
|
||||||
- glog
|
|
||||||
- RCT-Folly (= 2021.06.28.00-v2)
|
|
||||||
- React-callinvoker (= 0.68.2)
|
|
||||||
- React-jsi (= 0.68.2)
|
|
||||||
- React-jsinspector (= 0.68.2)
|
|
||||||
- React-logger (= 0.68.2)
|
|
||||||
- React-perflogger (= 0.68.2)
|
|
||||||
- React-runtimeexecutor (= 0.68.2)
|
|
||||||
- React-hermes (0.68.2):
|
|
||||||
- DoubleConversion
|
|
||||||
- glog
|
|
||||||
- hermes-engine
|
|
||||||
- RCT-Folly (= 2021.06.28.00-v2)
|
|
||||||
- RCT-Folly/Futures (= 2021.06.28.00-v2)
|
|
||||||
- React-cxxreact (= 0.68.2)
|
|
||||||
- React-jsi (= 0.68.2)
|
|
||||||
- React-jsiexecutor (= 0.68.2)
|
|
||||||
- React-jsinspector (= 0.68.2)
|
|
||||||
- React-perflogger (= 0.68.2)
|
|
||||||
- React-jsi (0.68.2):
|
|
||||||
- boost (= 1.76.0)
|
|
||||||
- DoubleConversion
|
|
||||||
- glog
|
|
||||||
- RCT-Folly (= 2021.06.28.00-v2)
|
|
||||||
- React-jsi/Default (= 0.68.2)
|
|
||||||
- React-jsi/Default (0.68.2):
|
|
||||||
- boost (= 1.76.0)
|
|
||||||
- DoubleConversion
|
|
||||||
- glog
|
|
||||||
- RCT-Folly (= 2021.06.28.00-v2)
|
|
||||||
- React-jsiexecutor (0.68.2):
|
|
||||||
- DoubleConversion
|
|
||||||
- glog
|
|
||||||
- RCT-Folly (= 2021.06.28.00-v2)
|
|
||||||
- React-cxxreact (= 0.68.2)
|
|
||||||
- React-jsi (= 0.68.2)
|
|
||||||
- React-perflogger (= 0.68.2)
|
|
||||||
- React-jsinspector (0.68.2)
|
|
||||||
- React-logger (0.68.2):
|
|
||||||
- glog
|
|
||||||
- React-perflogger (0.68.2)
|
|
||||||
- React-RCTActionSheet (0.68.2):
|
|
||||||
- React-Core/RCTActionSheetHeaders (= 0.68.2)
|
|
||||||
- React-RCTAnimation (0.68.2):
|
|
||||||
- RCT-Folly (= 2021.06.28.00-v2)
|
|
||||||
- RCTTypeSafety (= 0.68.2)
|
|
||||||
- React-Codegen (= 0.68.2)
|
|
||||||
- React-Core/RCTAnimationHeaders (= 0.68.2)
|
|
||||||
- React-jsi (= 0.68.2)
|
|
||||||
- ReactCommon/turbomodule/core (= 0.68.2)
|
|
||||||
- React-RCTBlob (0.68.2):
|
|
||||||
- RCT-Folly (= 2021.06.28.00-v2)
|
|
||||||
- React-Codegen (= 0.68.2)
|
|
||||||
- React-Core/RCTBlobHeaders (= 0.68.2)
|
|
||||||
- React-Core/RCTWebSocket (= 0.68.2)
|
|
||||||
- React-jsi (= 0.68.2)
|
|
||||||
- React-RCTNetwork (= 0.68.2)
|
|
||||||
- ReactCommon/turbomodule/core (= 0.68.2)
|
|
||||||
- React-RCTImage (0.68.2):
|
|
||||||
- RCT-Folly (= 2021.06.28.00-v2)
|
|
||||||
- RCTTypeSafety (= 0.68.2)
|
|
||||||
- React-Codegen (= 0.68.2)
|
|
||||||
- React-Core/RCTImageHeaders (= 0.68.2)
|
|
||||||
- React-jsi (= 0.68.2)
|
|
||||||
- React-RCTNetwork (= 0.68.2)
|
|
||||||
- ReactCommon/turbomodule/core (= 0.68.2)
|
|
||||||
- React-RCTLinking (0.68.2):
|
|
||||||
- React-Codegen (= 0.68.2)
|
|
||||||
- React-Core/RCTLinkingHeaders (= 0.68.2)
|
|
||||||
- React-jsi (= 0.68.2)
|
|
||||||
- ReactCommon/turbomodule/core (= 0.68.2)
|
|
||||||
- React-RCTNetwork (0.68.2):
|
|
||||||
- RCT-Folly (= 2021.06.28.00-v2)
|
|
||||||
- RCTTypeSafety (= 0.68.2)
|
|
||||||
- React-Codegen (= 0.68.2)
|
|
||||||
- React-Core/RCTNetworkHeaders (= 0.68.2)
|
|
||||||
- React-jsi (= 0.68.2)
|
|
||||||
- ReactCommon/turbomodule/core (= 0.68.2)
|
|
||||||
- React-RCTSettings (0.68.2):
|
|
||||||
- RCT-Folly (= 2021.06.28.00-v2)
|
|
||||||
- RCTTypeSafety (= 0.68.2)
|
|
||||||
- React-Codegen (= 0.68.2)
|
|
||||||
- React-Core/RCTSettingsHeaders (= 0.68.2)
|
|
||||||
- React-jsi (= 0.68.2)
|
|
||||||
- ReactCommon/turbomodule/core (= 0.68.2)
|
|
||||||
- React-RCTText (0.68.2):
|
|
||||||
- React-Core/RCTTextHeaders (= 0.68.2)
|
|
||||||
- React-RCTVibration (0.68.2):
|
|
||||||
- RCT-Folly (= 2021.06.28.00-v2)
|
|
||||||
- React-Codegen (= 0.68.2)
|
|
||||||
- React-Core/RCTVibrationHeaders (= 0.68.2)
|
|
||||||
- React-jsi (= 0.68.2)
|
|
||||||
- ReactCommon/turbomodule/core (= 0.68.2)
|
|
||||||
- React-runtimeexecutor (0.68.2):
|
|
||||||
- React-jsi (= 0.68.2)
|
|
||||||
- ReactCommon/turbomodule/core (0.68.2):
|
|
||||||
- DoubleConversion
|
|
||||||
- glog
|
|
||||||
- RCT-Folly (= 2021.06.28.00-v2)
|
|
||||||
- React-callinvoker (= 0.68.2)
|
|
||||||
- React-Core (= 0.68.2)
|
|
||||||
- React-cxxreact (= 0.68.2)
|
|
||||||
- React-jsi (= 0.68.2)
|
|
||||||
- React-logger (= 0.68.2)
|
|
||||||
- React-perflogger (= 0.68.2)
|
|
||||||
- SocketRocket (0.6.0)
|
|
||||||
- waku-react-native (0.0.4):
|
|
||||||
- React-Core
|
|
||||||
- Yoga (1.14.0)
|
|
||||||
- YogaKit (1.18.1):
|
|
||||||
- Yoga (~> 1.14)
|
|
||||||
|
|
||||||
DEPENDENCIES:
|
|
||||||
- boost (from `../node_modules/react-native/third-party-podspecs/boost.podspec`)
|
|
||||||
- DoubleConversion (from `../node_modules/react-native/third-party-podspecs/DoubleConversion.podspec`)
|
|
||||||
- FBLazyVector (from `../node_modules/react-native/Libraries/FBLazyVector`)
|
|
||||||
- FBReactNativeSpec (from `../node_modules/react-native/React/FBReactNativeSpec`)
|
|
||||||
- Flipper (= 0.125.0)
|
|
||||||
- Flipper-Boost-iOSX (= 1.76.0.1.11)
|
|
||||||
- Flipper-DoubleConversion (= 3.2.0)
|
|
||||||
- Flipper-Fmt (= 7.1.7)
|
|
||||||
- Flipper-Folly (= 2.6.10)
|
|
||||||
- Flipper-Glog (= 0.5.0.4)
|
|
||||||
- Flipper-PeerTalk (= 0.0.4)
|
|
||||||
- Flipper-RSocket (= 1.4.3)
|
|
||||||
- FlipperKit (= 0.125.0)
|
|
||||||
- FlipperKit/Core (= 0.125.0)
|
|
||||||
- FlipperKit/CppBridge (= 0.125.0)
|
|
||||||
- FlipperKit/FBCxxFollyDynamicConvert (= 0.125.0)
|
|
||||||
- FlipperKit/FBDefines (= 0.125.0)
|
|
||||||
- FlipperKit/FKPortForwarding (= 0.125.0)
|
|
||||||
- FlipperKit/FlipperKitHighlightOverlay (= 0.125.0)
|
|
||||||
- FlipperKit/FlipperKitLayoutPlugin (= 0.125.0)
|
|
||||||
- FlipperKit/FlipperKitLayoutTextSearchable (= 0.125.0)
|
|
||||||
- FlipperKit/FlipperKitNetworkPlugin (= 0.125.0)
|
|
||||||
- FlipperKit/FlipperKitReactPlugin (= 0.125.0)
|
|
||||||
- FlipperKit/FlipperKitUserDefaultsPlugin (= 0.125.0)
|
|
||||||
- FlipperKit/SKIOSNetworkPlugin (= 0.125.0)
|
|
||||||
- glog (from `../node_modules/react-native/third-party-podspecs/glog.podspec`)
|
|
||||||
- hermes-engine (~> 0.11.0)
|
|
||||||
- libevent (~> 2.1.12)
|
|
||||||
- OpenSSL-Universal (= 1.1.1100)
|
|
||||||
- RCT-Folly (from `../node_modules/react-native/third-party-podspecs/RCT-Folly.podspec`)
|
|
||||||
- RCTRequired (from `../node_modules/react-native/Libraries/RCTRequired`)
|
|
||||||
- RCTTypeSafety (from `../node_modules/react-native/Libraries/TypeSafety`)
|
|
||||||
- React (from `../node_modules/react-native/`)
|
|
||||||
- React-callinvoker (from `../node_modules/react-native/ReactCommon/callinvoker`)
|
|
||||||
- React-Codegen (from `build/generated/ios`)
|
|
||||||
- React-Core (from `../node_modules/react-native/`)
|
|
||||||
- React-Core/DevSupport (from `../node_modules/react-native/`)
|
|
||||||
- React-Core/RCTWebSocket (from `../node_modules/react-native/`)
|
|
||||||
- React-CoreModules (from `../node_modules/react-native/React/CoreModules`)
|
|
||||||
- React-cxxreact (from `../node_modules/react-native/ReactCommon/cxxreact`)
|
|
||||||
- React-hermes (from `../node_modules/react-native/ReactCommon/hermes`)
|
|
||||||
- React-jsi (from `../node_modules/react-native/ReactCommon/jsi`)
|
|
||||||
- React-jsiexecutor (from `../node_modules/react-native/ReactCommon/jsiexecutor`)
|
|
||||||
- React-jsinspector (from `../node_modules/react-native/ReactCommon/jsinspector`)
|
|
||||||
- React-logger (from `../node_modules/react-native/ReactCommon/logger`)
|
|
||||||
- React-perflogger (from `../node_modules/react-native/ReactCommon/reactperflogger`)
|
|
||||||
- React-RCTActionSheet (from `../node_modules/react-native/Libraries/ActionSheetIOS`)
|
|
||||||
- React-RCTAnimation (from `../node_modules/react-native/Libraries/NativeAnimation`)
|
|
||||||
- React-RCTBlob (from `../node_modules/react-native/Libraries/Blob`)
|
|
||||||
- React-RCTImage (from `../node_modules/react-native/Libraries/Image`)
|
|
||||||
- React-RCTLinking (from `../node_modules/react-native/Libraries/LinkingIOS`)
|
|
||||||
- React-RCTNetwork (from `../node_modules/react-native/Libraries/Network`)
|
|
||||||
- React-RCTSettings (from `../node_modules/react-native/Libraries/Settings`)
|
|
||||||
- React-RCTText (from `../node_modules/react-native/Libraries/Text`)
|
|
||||||
- React-RCTVibration (from `../node_modules/react-native/Libraries/Vibration`)
|
|
||||||
- React-runtimeexecutor (from `../node_modules/react-native/ReactCommon/runtimeexecutor`)
|
|
||||||
- ReactCommon/turbomodule/core (from `../node_modules/react-native/ReactCommon`)
|
|
||||||
- waku-react-native (from `../..`)
|
|
||||||
- Yoga (from `../node_modules/react-native/ReactCommon/yoga`)
|
|
||||||
|
|
||||||
SPEC REPOS:
|
|
||||||
trunk:
|
|
||||||
- CocoaAsyncSocket
|
|
||||||
- Flipper
|
|
||||||
- Flipper-Boost-iOSX
|
|
||||||
- Flipper-DoubleConversion
|
|
||||||
- Flipper-Fmt
|
|
||||||
- Flipper-Folly
|
|
||||||
- Flipper-Glog
|
|
||||||
- Flipper-PeerTalk
|
|
||||||
- Flipper-RSocket
|
|
||||||
- FlipperKit
|
|
||||||
- fmt
|
|
||||||
- hermes-engine
|
|
||||||
- libevent
|
|
||||||
- OpenSSL-Universal
|
|
||||||
- SocketRocket
|
|
||||||
- YogaKit
|
|
||||||
|
|
||||||
EXTERNAL SOURCES:
|
|
||||||
boost:
|
|
||||||
:podspec: "../node_modules/react-native/third-party-podspecs/boost.podspec"
|
|
||||||
DoubleConversion:
|
|
||||||
:podspec: "../node_modules/react-native/third-party-podspecs/DoubleConversion.podspec"
|
|
||||||
FBLazyVector:
|
|
||||||
:path: "../node_modules/react-native/Libraries/FBLazyVector"
|
|
||||||
FBReactNativeSpec:
|
|
||||||
:path: "../node_modules/react-native/React/FBReactNativeSpec"
|
|
||||||
glog:
|
|
||||||
:podspec: "../node_modules/react-native/third-party-podspecs/glog.podspec"
|
|
||||||
RCT-Folly:
|
|
||||||
:podspec: "../node_modules/react-native/third-party-podspecs/RCT-Folly.podspec"
|
|
||||||
RCTRequired:
|
|
||||||
:path: "../node_modules/react-native/Libraries/RCTRequired"
|
|
||||||
RCTTypeSafety:
|
|
||||||
:path: "../node_modules/react-native/Libraries/TypeSafety"
|
|
||||||
React:
|
|
||||||
:path: "../node_modules/react-native/"
|
|
||||||
React-callinvoker:
|
|
||||||
:path: "../node_modules/react-native/ReactCommon/callinvoker"
|
|
||||||
React-Codegen:
|
|
||||||
:path: build/generated/ios
|
|
||||||
React-Core:
|
|
||||||
:path: "../node_modules/react-native/"
|
|
||||||
React-CoreModules:
|
|
||||||
:path: "../node_modules/react-native/React/CoreModules"
|
|
||||||
React-cxxreact:
|
|
||||||
:path: "../node_modules/react-native/ReactCommon/cxxreact"
|
|
||||||
React-hermes:
|
|
||||||
:path: "../node_modules/react-native/ReactCommon/hermes"
|
|
||||||
React-jsi:
|
|
||||||
:path: "../node_modules/react-native/ReactCommon/jsi"
|
|
||||||
React-jsiexecutor:
|
|
||||||
:path: "../node_modules/react-native/ReactCommon/jsiexecutor"
|
|
||||||
React-jsinspector:
|
|
||||||
:path: "../node_modules/react-native/ReactCommon/jsinspector"
|
|
||||||
React-logger:
|
|
||||||
:path: "../node_modules/react-native/ReactCommon/logger"
|
|
||||||
React-perflogger:
|
|
||||||
:path: "../node_modules/react-native/ReactCommon/reactperflogger"
|
|
||||||
React-RCTActionSheet:
|
|
||||||
:path: "../node_modules/react-native/Libraries/ActionSheetIOS"
|
|
||||||
React-RCTAnimation:
|
|
||||||
:path: "../node_modules/react-native/Libraries/NativeAnimation"
|
|
||||||
React-RCTBlob:
|
|
||||||
:path: "../node_modules/react-native/Libraries/Blob"
|
|
||||||
React-RCTImage:
|
|
||||||
:path: "../node_modules/react-native/Libraries/Image"
|
|
||||||
React-RCTLinking:
|
|
||||||
:path: "../node_modules/react-native/Libraries/LinkingIOS"
|
|
||||||
React-RCTNetwork:
|
|
||||||
:path: "../node_modules/react-native/Libraries/Network"
|
|
||||||
React-RCTSettings:
|
|
||||||
:path: "../node_modules/react-native/Libraries/Settings"
|
|
||||||
React-RCTText:
|
|
||||||
:path: "../node_modules/react-native/Libraries/Text"
|
|
||||||
React-RCTVibration:
|
|
||||||
:path: "../node_modules/react-native/Libraries/Vibration"
|
|
||||||
React-runtimeexecutor:
|
|
||||||
:path: "../node_modules/react-native/ReactCommon/runtimeexecutor"
|
|
||||||
ReactCommon:
|
|
||||||
:path: "../node_modules/react-native/ReactCommon"
|
|
||||||
waku-react-native:
|
|
||||||
:path: "../.."
|
|
||||||
Yoga:
|
|
||||||
:path: "../node_modules/react-native/ReactCommon/yoga"
|
|
||||||
|
|
||||||
SPEC CHECKSUMS:
|
|
||||||
boost: a7c83b31436843459a1961bfd74b96033dc77234
|
|
||||||
CocoaAsyncSocket: 065fd1e645c7abab64f7a6a2007a48038fdc6a99
|
|
||||||
DoubleConversion: 831926d9b8bf8166fd87886c4abab286c2422662
|
|
||||||
FBLazyVector: a7a655862f6b09625d11c772296b01cd5164b648
|
|
||||||
FBReactNativeSpec: 81ce99032d5b586fddd6a38d450f8595f7e04be4
|
|
||||||
Flipper: 26fc4b7382499f1281eb8cb921e5c3ad6de91fe0
|
|
||||||
Flipper-Boost-iOSX: fd1e2b8cbef7e662a122412d7ac5f5bea715403c
|
|
||||||
Flipper-DoubleConversion: 3d3d04a078d4f3a1b6c6916587f159dc11f232c4
|
|
||||||
Flipper-Fmt: 60cbdd92fc254826e61d669a5d87ef7015396a9b
|
|
||||||
Flipper-Folly: 584845625005ff068a6ebf41f857f468decd26b3
|
|
||||||
Flipper-Glog: 87bc98ff48de90cb5b0b5114ed3da79d85ee2dd4
|
|
||||||
Flipper-PeerTalk: 116d8f857dc6ef55c7a5a75ea3ceaafe878aadc9
|
|
||||||
Flipper-RSocket: d9d9ade67cbecf6ac10730304bf5607266dd2541
|
|
||||||
FlipperKit: cbdee19bdd4e7f05472a66ce290f1b729ba3cb86
|
|
||||||
fmt: ff9d55029c625d3757ed641535fd4a75fedc7ce9
|
|
||||||
glog: 476ee3e89abb49e07f822b48323c51c57124b572
|
|
||||||
hermes-engine: 84e3af1ea01dd7351ac5d8689cbbea1f9903ffc3
|
|
||||||
libevent: 4049cae6c81cdb3654a443be001fb9bdceff7913
|
|
||||||
OpenSSL-Universal: ebc357f1e6bc71fa463ccb2fe676756aff50e88c
|
|
||||||
RCT-Folly: 4d8508a426467c48885f1151029bc15fa5d7b3b8
|
|
||||||
RCTRequired: 3e917ea5377751094f38145fdece525aa90545a0
|
|
||||||
RCTTypeSafety: c43c072a4bd60feb49a9570b0517892b4305c45e
|
|
||||||
React: 176dd882de001854ced260fad41bb68a31aa4bd0
|
|
||||||
React-callinvoker: c2864d1818d6e64928d2faf774a3800dfc38fe1f
|
|
||||||
React-Codegen: 98b6f97f0a7abf7d67e4ce435c77c05b7a95cf05
|
|
||||||
React-Core: fdaa2916b1c893f39f02cff0476d1fb0cab1e352
|
|
||||||
React-CoreModules: fd8705b80699ec36c2cdd635c2ce9d874b9cfdfc
|
|
||||||
React-cxxreact: 1832d971f7b0cb2c7b943dc0ec962762c90c906e
|
|
||||||
React-hermes: 14e0ea3ce4b44bb3ac7663d96d0e3e28857f7b62
|
|
||||||
React-jsi: 72af715135abe8c3f0dcf3b2548b71d048b69a7e
|
|
||||||
React-jsiexecutor: b7b553412f2ec768fe6c8f27cd6bafdb9d8719e6
|
|
||||||
React-jsinspector: c5989c77cb89ae6a69561095a61cce56a44ae8e8
|
|
||||||
React-logger: a0833912d93b36b791b7a521672d8ee89107aff1
|
|
||||||
React-perflogger: a18b4f0bd933b8b24ecf9f3c54f9bf65180f3fe6
|
|
||||||
React-RCTActionSheet: 547fe42fdb4b6089598d79f8e1d855d7c23e2162
|
|
||||||
React-RCTAnimation: bc9440a1c37b06ae9ebbb532d244f607805c6034
|
|
||||||
React-RCTBlob: a1295c8e183756d7ef30ba6e8f8144dfe8a19215
|
|
||||||
React-RCTImage: a30d1ee09b1334067fbb6f30789aae2d7ac150c9
|
|
||||||
React-RCTLinking: ffc6d5b88d1cb9aca13c54c2ec6507fbf07f2ac4
|
|
||||||
React-RCTNetwork: f807a2facab6cf5cf36d592e634611de9cf12d81
|
|
||||||
React-RCTSettings: 861806819226ed8332e6a8f90df2951a34bb3e7f
|
|
||||||
React-RCTText: f3fb464cc41a50fc7a1aba4deeb76a9ad8282cb9
|
|
||||||
React-RCTVibration: 79040b92bfa9c3c2d2cb4f57e981164ec7ab9374
|
|
||||||
React-runtimeexecutor: b960b687d2dfef0d3761fbb187e01812ebab8b23
|
|
||||||
ReactCommon: 095366164a276d91ea704ce53cb03825c487a3f2
|
|
||||||
SocketRocket: fccef3f9c5cedea1353a9ef6ada904fde10d6608
|
|
||||||
waku-react-native: 569e0f4efd02ca2ddea2db168365841891db973c
|
|
||||||
Yoga: 99652481fcd320aefa4a7ef90095b95acd181952
|
|
||||||
YogaKit: f782866e155069a2cca2517aafea43200b01fd5a
|
|
||||||
|
|
||||||
PODFILE CHECKSUM: 03ef7c44a386299aa54f35c5e53a0528696ab0fd
|
|
||||||
|
|
||||||
COCOAPODS: 1.11.3
|
|
||||||
3
example/ios/Podfile.properties.json
Normal file
3
example/ios/Podfile.properties.json
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
{
|
||||||
|
"expo.jsEngine": "jsc"
|
||||||
|
}
|
||||||
@ -1,3 +0,0 @@
|
|||||||
//
|
|
||||||
// Use this file to import your target's public headers that you would like to expose to Swift.
|
|
||||||
//
|
|
||||||
@ -1,10 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<Workspace
|
|
||||||
version = "1.0">
|
|
||||||
<FileRef
|
|
||||||
location = "group:ReactNativeExample.xcodeproj">
|
|
||||||
</FileRef>
|
|
||||||
<FileRef
|
|
||||||
location = "group:Pods/Pods.xcodeproj">
|
|
||||||
</FileRef>
|
|
||||||
</Workspace>
|
|
||||||
@ -1,8 +0,0 @@
|
|||||||
#import <React/RCTBridgeDelegate.h>
|
|
||||||
#import <UIKit/UIKit.h>
|
|
||||||
|
|
||||||
@interface AppDelegate : UIResponder <UIApplicationDelegate, RCTBridgeDelegate>
|
|
||||||
|
|
||||||
@property (nonatomic, strong) UIWindow *window;
|
|
||||||
|
|
||||||
@end
|
|
||||||
@ -1,108 +0,0 @@
|
|||||||
#import "AppDelegate.h"
|
|
||||||
|
|
||||||
#import <React/RCTBridge.h>
|
|
||||||
#import <React/RCTBundleURLProvider.h>
|
|
||||||
#import <React/RCTRootView.h>
|
|
||||||
|
|
||||||
#import <React/RCTAppSetupUtils.h>
|
|
||||||
|
|
||||||
#if RCT_NEW_ARCH_ENABLED
|
|
||||||
#import <React/CoreModulesPlugins.h>
|
|
||||||
#import <React/RCTCxxBridgeDelegate.h>
|
|
||||||
#import <React/RCTFabricSurfaceHostingProxyRootView.h>
|
|
||||||
#import <React/RCTSurfacePresenter.h>
|
|
||||||
#import <React/RCTSurfacePresenterBridgeAdapter.h>
|
|
||||||
#import <ReactCommon/RCTTurboModuleManager.h>
|
|
||||||
|
|
||||||
#import <react/config/ReactNativeConfig.h>
|
|
||||||
|
|
||||||
@interface AppDelegate () <RCTCxxBridgeDelegate, RCTTurboModuleManagerDelegate> {
|
|
||||||
RCTTurboModuleManager *_turboModuleManager;
|
|
||||||
RCTSurfacePresenterBridgeAdapter *_bridgeAdapter;
|
|
||||||
std::shared_ptr<const facebook::react::ReactNativeConfig> _reactNativeConfig;
|
|
||||||
facebook::react::ContextContainer::Shared _contextContainer;
|
|
||||||
}
|
|
||||||
@end
|
|
||||||
#endif
|
|
||||||
|
|
||||||
@implementation AppDelegate
|
|
||||||
|
|
||||||
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
|
|
||||||
{
|
|
||||||
RCTAppSetupPrepareApp(application);
|
|
||||||
|
|
||||||
RCTBridge *bridge = [[RCTBridge alloc] initWithDelegate:self launchOptions:launchOptions];
|
|
||||||
|
|
||||||
#if RCT_NEW_ARCH_ENABLED
|
|
||||||
_contextContainer = std::make_shared<facebook::react::ContextContainer const>();
|
|
||||||
_reactNativeConfig = std::make_shared<facebook::react::EmptyReactNativeConfig const>();
|
|
||||||
_contextContainer->insert("ReactNativeConfig", _reactNativeConfig);
|
|
||||||
_bridgeAdapter = [[RCTSurfacePresenterBridgeAdapter alloc] initWithBridge:bridge contextContainer:_contextContainer];
|
|
||||||
bridge.surfacePresenter = _bridgeAdapter.surfacePresenter;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
UIView *rootView = RCTAppSetupDefaultRootView(bridge, @"main", nil);
|
|
||||||
|
|
||||||
if (@available(iOS 13.0, *)) {
|
|
||||||
rootView.backgroundColor = [UIColor systemBackgroundColor];
|
|
||||||
} else {
|
|
||||||
rootView.backgroundColor = [UIColor whiteColor];
|
|
||||||
}
|
|
||||||
|
|
||||||
self.window = [[UIWindow alloc] initWithFrame:[UIScreen mainScreen].bounds];
|
|
||||||
UIViewController *rootViewController = [UIViewController new];
|
|
||||||
rootViewController.view = rootView;
|
|
||||||
self.window.rootViewController = rootViewController;
|
|
||||||
[self.window makeKeyAndVisible];
|
|
||||||
return YES;
|
|
||||||
}
|
|
||||||
|
|
||||||
- (NSURL *)sourceURLForBridge:(RCTBridge *)bridge
|
|
||||||
{
|
|
||||||
#if DEBUG
|
|
||||||
return [[RCTBundleURLProvider sharedSettings] jsBundleURLForBundleRoot:@"index"];
|
|
||||||
#else
|
|
||||||
return [[NSBundle mainBundle] URLForResource:@"main" withExtension:@"jsbundle"];
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
#if RCT_NEW_ARCH_ENABLED
|
|
||||||
|
|
||||||
#pragma mark - RCTCxxBridgeDelegate
|
|
||||||
|
|
||||||
- (std::unique_ptr<facebook::react::JSExecutorFactory>)jsExecutorFactoryForBridge:(RCTBridge *)bridge
|
|
||||||
{
|
|
||||||
_turboModuleManager = [[RCTTurboModuleManager alloc] initWithBridge:bridge
|
|
||||||
delegate:self
|
|
||||||
jsInvoker:bridge.jsCallInvoker];
|
|
||||||
return RCTAppSetupDefaultJsExecutorFactory(bridge, _turboModuleManager);
|
|
||||||
}
|
|
||||||
|
|
||||||
#pragma mark RCTTurboModuleManagerDelegate
|
|
||||||
|
|
||||||
- (Class)getModuleClassFromName:(const char *)name
|
|
||||||
{
|
|
||||||
return RCTCoreModulesClassProvider(name);
|
|
||||||
}
|
|
||||||
|
|
||||||
- (std::shared_ptr<facebook::react::TurboModule>)getTurboModule:(const std::string &)name
|
|
||||||
jsInvoker:(std::shared_ptr<facebook::react::CallInvoker>)jsInvoker
|
|
||||||
{
|
|
||||||
return nullptr;
|
|
||||||
}
|
|
||||||
|
|
||||||
- (std::shared_ptr<facebook::react::TurboModule>)getTurboModule:(const std::string &)name
|
|
||||||
initParams:
|
|
||||||
(const facebook::react::ObjCTurboModule::InitParams &)params
|
|
||||||
{
|
|
||||||
return nullptr;
|
|
||||||
}
|
|
||||||
|
|
||||||
- (id<RCTTurboModule>)getModuleInstanceFromClass:(Class)moduleClass
|
|
||||||
{
|
|
||||||
return RCTAppSetupDefaultModuleFromClass(moduleClass);
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
@end
|
|
||||||
@ -1,53 +0,0 @@
|
|||||||
{
|
|
||||||
"images" : [
|
|
||||||
{
|
|
||||||
"idiom" : "iphone",
|
|
||||||
"scale" : "2x",
|
|
||||||
"size" : "20x20"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"idiom" : "iphone",
|
|
||||||
"scale" : "3x",
|
|
||||||
"size" : "20x20"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"idiom" : "iphone",
|
|
||||||
"scale" : "2x",
|
|
||||||
"size" : "29x29"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"idiom" : "iphone",
|
|
||||||
"scale" : "3x",
|
|
||||||
"size" : "29x29"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"idiom" : "iphone",
|
|
||||||
"scale" : "2x",
|
|
||||||
"size" : "40x40"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"idiom" : "iphone",
|
|
||||||
"scale" : "3x",
|
|
||||||
"size" : "40x40"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"idiom" : "iphone",
|
|
||||||
"scale" : "2x",
|
|
||||||
"size" : "60x60"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"idiom" : "iphone",
|
|
||||||
"scale" : "3x",
|
|
||||||
"size" : "60x60"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"idiom" : "ios-marketing",
|
|
||||||
"scale" : "1x",
|
|
||||||
"size" : "1024x1024"
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"info" : {
|
|
||||||
"author" : "xcode",
|
|
||||||
"version" : 1
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@ -1,47 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<document type="com.apple.InterfaceBuilder3.CocoaTouch.Storyboard.XIB" version="3.0" toolsVersion="15702" targetRuntime="iOS.CocoaTouch" propertyAccessControl="none" useAutolayout="YES" launchScreen="YES" useTraitCollections="YES" useSafeAreas="YES" colorMatched="YES" initialViewController="01J-lp-oVM">
|
|
||||||
<device id="retina4_7" orientation="portrait" appearance="light"/>
|
|
||||||
<dependencies>
|
|
||||||
<deployment identifier="iOS"/>
|
|
||||||
<plugIn identifier="com.apple.InterfaceBuilder.IBCocoaTouchPlugin" version="15704"/>
|
|
||||||
<capability name="Safe area layout guides" minToolsVersion="9.0"/>
|
|
||||||
<capability name="documents saved in the Xcode 8 format" minToolsVersion="8.0"/>
|
|
||||||
</dependencies>
|
|
||||||
<scenes>
|
|
||||||
<!--View Controller-->
|
|
||||||
<scene sceneID="EHf-IW-A2E">
|
|
||||||
<objects>
|
|
||||||
<viewController id="01J-lp-oVM" sceneMemberID="viewController">
|
|
||||||
<view key="view" contentMode="scaleToFill" id="Ze5-6b-2t3">
|
|
||||||
<rect key="frame" x="0.0" y="0.0" width="375" height="667"/>
|
|
||||||
<autoresizingMask key="autoresizingMask" widthSizable="YES" heightSizable="YES"/>
|
|
||||||
<subviews>
|
|
||||||
<label opaque="NO" clipsSubviews="YES" userInteractionEnabled="NO" contentMode="left" horizontalHuggingPriority="251" verticalHuggingPriority="251" text="ReactNative Example" textAlignment="center" lineBreakMode="middleTruncation" baselineAdjustment="alignBaselines" minimumFontSize="18" translatesAutoresizingMaskIntoConstraints="NO" id="GJd-Yh-RWb">
|
|
||||||
<rect key="frame" x="0.0" y="202" width="375" height="43"/>
|
|
||||||
<fontDescription key="fontDescription" type="boldSystem" pointSize="36"/>
|
|
||||||
<nil key="highlightedColor"/>
|
|
||||||
</label>
|
|
||||||
<label opaque="NO" clipsSubviews="YES" userInteractionEnabled="NO" contentMode="left" horizontalHuggingPriority="251" verticalHuggingPriority="251" text="Powered by React Native" textAlignment="center" lineBreakMode="tailTruncation" baselineAdjustment="alignBaselines" minimumFontSize="9" translatesAutoresizingMaskIntoConstraints="NO" id="MN2-I3-ftu">
|
|
||||||
<rect key="frame" x="0.0" y="626" width="375" height="21"/>
|
|
||||||
<fontDescription key="fontDescription" type="system" pointSize="17"/>
|
|
||||||
<nil key="highlightedColor"/>
|
|
||||||
</label>
|
|
||||||
</subviews>
|
|
||||||
<color key="backgroundColor" systemColor="systemBackgroundColor" cocoaTouchSystemColor="whiteColor"/>
|
|
||||||
<constraints>
|
|
||||||
<constraint firstItem="Bcu-3y-fUS" firstAttribute="bottom" secondItem="MN2-I3-ftu" secondAttribute="bottom" constant="20" id="OZV-Vh-mqD"/>
|
|
||||||
<constraint firstItem="Bcu-3y-fUS" firstAttribute="centerX" secondItem="GJd-Yh-RWb" secondAttribute="centerX" id="Q3B-4B-g5h"/>
|
|
||||||
<constraint firstItem="MN2-I3-ftu" firstAttribute="centerX" secondItem="Bcu-3y-fUS" secondAttribute="centerX" id="akx-eg-2ui"/>
|
|
||||||
<constraint firstItem="MN2-I3-ftu" firstAttribute="leading" secondItem="Bcu-3y-fUS" secondAttribute="leading" id="i1E-0Y-4RG"/>
|
|
||||||
<constraint firstItem="GJd-Yh-RWb" firstAttribute="centerY" secondItem="Ze5-6b-2t3" secondAttribute="bottom" multiplier="1/3" constant="1" id="moa-c2-u7t"/>
|
|
||||||
<constraint firstItem="GJd-Yh-RWb" firstAttribute="leading" secondItem="Bcu-3y-fUS" secondAttribute="leading" symbolic="YES" id="x7j-FC-K8j"/>
|
|
||||||
</constraints>
|
|
||||||
<viewLayoutGuide key="safeArea" id="Bcu-3y-fUS"/>
|
|
||||||
</view>
|
|
||||||
</viewController>
|
|
||||||
<placeholder placeholderIdentifier="IBFirstResponder" id="iYj-Kq-Ea1" userLabel="First Responder" sceneMemberID="firstResponder"/>
|
|
||||||
</objects>
|
|
||||||
<point key="canvasLocation" x="52.173913043478265" y="375"/>
|
|
||||||
</scene>
|
|
||||||
</scenes>
|
|
||||||
</document>
|
|
||||||
@ -3,29 +3,34 @@
|
|||||||
archiveVersion = 1;
|
archiveVersion = 1;
|
||||||
classes = {
|
classes = {
|
||||||
};
|
};
|
||||||
objectVersion = 54;
|
objectVersion = 46;
|
||||||
objects = {
|
objects = {
|
||||||
|
|
||||||
/* Begin PBXBuildFile section */
|
/* Begin PBXBuildFile section */
|
||||||
0C80B921A6F3F58F76C31292 /* libPods-ReactNativeExample.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 5DCACB8F33CDC322A6C60F78 /* libPods-ReactNativeExample.a */; };
|
|
||||||
13B07FBC1A68108700A75B9A /* AppDelegate.mm in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB01A68108700A75B9A /* AppDelegate.mm */; };
|
13B07FBC1A68108700A75B9A /* AppDelegate.mm in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB01A68108700A75B9A /* AppDelegate.mm */; };
|
||||||
13B07FBF1A68108700A75B9A /* Images.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 13B07FB51A68108700A75B9A /* Images.xcassets */; };
|
13B07FBF1A68108700A75B9A /* Images.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 13B07FB51A68108700A75B9A /* Images.xcassets */; };
|
||||||
13B07FC11A68108700A75B9A /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB71A68108700A75B9A /* main.m */; };
|
13B07FC11A68108700A75B9A /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB71A68108700A75B9A /* main.m */; };
|
||||||
81AB9BB82411601600AC10FF /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 81AB9BB72411601600AC10FF /* LaunchScreen.storyboard */; };
|
3E461D99554A48A4959DE609 /* SplashScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = AA286B85B6C04FC6940260E9 /* SplashScreen.storyboard */; };
|
||||||
|
96905EF65AED1B983A6B3ABC /* libPods-example.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 58EEBF8E8E6FB1BC6CAF49B5 /* libPods-example.a */; };
|
||||||
|
B18059E884C0ABDD17F3DC3D /* ExpoModulesProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = FAC715A2D49A985799AEE119 /* ExpoModulesProvider.swift */; };
|
||||||
|
BB2F792D24A3F905000567C9 /* Expo.plist in Resources */ = {isa = PBXBuildFile; fileRef = BB2F792C24A3F905000567C9 /* Expo.plist */; };
|
||||||
/* End PBXBuildFile section */
|
/* End PBXBuildFile section */
|
||||||
|
|
||||||
/* Begin PBXFileReference section */
|
/* Begin PBXFileReference section */
|
||||||
13B07F961A680F5B00A75B9A /* ReactNativeExample.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = ReactNativeExample.app; sourceTree = BUILT_PRODUCTS_DIR; };
|
008F07F21AC5B25A0029DE68 /* main.jsbundle */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = main.jsbundle; sourceTree = "<group>"; };
|
||||||
13B07FAF1A68108700A75B9A /* AppDelegate.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = AppDelegate.h; path = ReactNativeExample/AppDelegate.h; sourceTree = "<group>"; };
|
13B07F961A680F5B00A75B9A /* example.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = example.app; sourceTree = BUILT_PRODUCTS_DIR; };
|
||||||
13B07FB01A68108700A75B9A /* AppDelegate.mm */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.objcpp; name = AppDelegate.mm; path = ReactNativeExample/AppDelegate.mm; sourceTree = "<group>"; };
|
13B07FAF1A68108700A75B9A /* AppDelegate.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = AppDelegate.h; path = example/AppDelegate.h; sourceTree = "<group>"; };
|
||||||
13B07FB51A68108700A75B9A /* Images.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; name = Images.xcassets; path = ReactNativeExample/Images.xcassets; sourceTree = "<group>"; };
|
13B07FB01A68108700A75B9A /* AppDelegate.mm */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.objcpp; name = AppDelegate.mm; path = example/AppDelegate.mm; sourceTree = "<group>"; };
|
||||||
13B07FB61A68108700A75B9A /* Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = Info.plist; path = ReactNativeExample/Info.plist; sourceTree = "<group>"; };
|
13B07FB51A68108700A75B9A /* Images.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; name = Images.xcassets; path = example/Images.xcassets; sourceTree = "<group>"; };
|
||||||
13B07FB71A68108700A75B9A /* main.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = main.m; path = ReactNativeExample/main.m; sourceTree = "<group>"; };
|
13B07FB61A68108700A75B9A /* Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = Info.plist; path = example/Info.plist; sourceTree = "<group>"; };
|
||||||
3B4392A12AC88292D35C810B /* Pods-ReactNativeExample.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-ReactNativeExample.debug.xcconfig"; path = "Target Support Files/Pods-ReactNativeExample/Pods-ReactNativeExample.debug.xcconfig"; sourceTree = "<group>"; };
|
13B07FB71A68108700A75B9A /* main.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = main.m; path = example/main.m; sourceTree = "<group>"; };
|
||||||
5709B34CF0A7D63546082F79 /* Pods-ReactNativeExample.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-ReactNativeExample.release.xcconfig"; path = "Target Support Files/Pods-ReactNativeExample/Pods-ReactNativeExample.release.xcconfig"; sourceTree = "<group>"; };
|
58EEBF8E8E6FB1BC6CAF49B5 /* libPods-example.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = "libPods-example.a"; sourceTree = BUILT_PRODUCTS_DIR; };
|
||||||
5DCACB8F33CDC322A6C60F78 /* libPods-ReactNativeExample.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = "libPods-ReactNativeExample.a"; sourceTree = BUILT_PRODUCTS_DIR; };
|
6C2E3173556A471DD304B334 /* Pods-example.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-example.debug.xcconfig"; path = "Target Support Files/Pods-example/Pods-example.debug.xcconfig"; sourceTree = "<group>"; };
|
||||||
81AB9BB72411601600AC10FF /* LaunchScreen.storyboard */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = file.storyboard; name = LaunchScreen.storyboard; path = ReactNativeExample/LaunchScreen.storyboard; sourceTree = "<group>"; };
|
7A4D352CD337FB3A3BF06240 /* Pods-example.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-example.release.xcconfig"; path = "Target Support Files/Pods-example/Pods-example.release.xcconfig"; sourceTree = "<group>"; };
|
||||||
|
AA286B85B6C04FC6940260E9 /* SplashScreen.storyboard */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = file.storyboard; name = SplashScreen.storyboard; path = example/SplashScreen.storyboard; sourceTree = "<group>"; };
|
||||||
|
BB2F792C24A3F905000567C9 /* Expo.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; path = Expo.plist; sourceTree = "<group>"; };
|
||||||
ED297162215061F000B7C4FE /* JavaScriptCore.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = JavaScriptCore.framework; path = System/Library/Frameworks/JavaScriptCore.framework; sourceTree = SDKROOT; };
|
ED297162215061F000B7C4FE /* JavaScriptCore.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = JavaScriptCore.framework; path = System/Library/Frameworks/JavaScriptCore.framework; sourceTree = SDKROOT; };
|
||||||
|
FAC715A2D49A985799AEE119 /* ExpoModulesProvider.swift */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = sourcecode.swift; name = ExpoModulesProvider.swift; path = "Pods/Target Support Files/Pods-example/ExpoModulesProvider.swift"; sourceTree = "<group>"; };
|
||||||
/* End PBXFileReference section */
|
/* End PBXFileReference section */
|
||||||
|
|
||||||
/* Begin PBXFrameworksBuildPhase section */
|
/* Begin PBXFrameworksBuildPhase section */
|
||||||
@ -33,31 +38,33 @@
|
|||||||
isa = PBXFrameworksBuildPhase;
|
isa = PBXFrameworksBuildPhase;
|
||||||
buildActionMask = 2147483647;
|
buildActionMask = 2147483647;
|
||||||
files = (
|
files = (
|
||||||
0C80B921A6F3F58F76C31292 /* libPods-ReactNativeExample.a in Frameworks */,
|
96905EF65AED1B983A6B3ABC /* libPods-example.a in Frameworks */,
|
||||||
);
|
);
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
};
|
};
|
||||||
/* End PBXFrameworksBuildPhase section */
|
/* End PBXFrameworksBuildPhase section */
|
||||||
|
|
||||||
/* Begin PBXGroup section */
|
/* Begin PBXGroup section */
|
||||||
13B07FAE1A68108700A75B9A /* ReactNativeExample */ = {
|
13B07FAE1A68108700A75B9A /* example */ = {
|
||||||
isa = PBXGroup;
|
isa = PBXGroup;
|
||||||
children = (
|
children = (
|
||||||
|
BB2F792B24A3F905000567C9 /* Supporting */,
|
||||||
|
008F07F21AC5B25A0029DE68 /* main.jsbundle */,
|
||||||
13B07FAF1A68108700A75B9A /* AppDelegate.h */,
|
13B07FAF1A68108700A75B9A /* AppDelegate.h */,
|
||||||
13B07FB01A68108700A75B9A /* AppDelegate.mm */,
|
13B07FB01A68108700A75B9A /* AppDelegate.mm */,
|
||||||
13B07FB51A68108700A75B9A /* Images.xcassets */,
|
13B07FB51A68108700A75B9A /* Images.xcassets */,
|
||||||
13B07FB61A68108700A75B9A /* Info.plist */,
|
13B07FB61A68108700A75B9A /* Info.plist */,
|
||||||
81AB9BB72411601600AC10FF /* LaunchScreen.storyboard */,
|
|
||||||
13B07FB71A68108700A75B9A /* main.m */,
|
13B07FB71A68108700A75B9A /* main.m */,
|
||||||
|
AA286B85B6C04FC6940260E9 /* SplashScreen.storyboard */,
|
||||||
);
|
);
|
||||||
name = ReactNativeExample;
|
name = example;
|
||||||
sourceTree = "<group>";
|
sourceTree = "<group>";
|
||||||
};
|
};
|
||||||
2D16E6871FA4F8E400B85C8A /* Frameworks */ = {
|
2D16E6871FA4F8E400B85C8A /* Frameworks */ = {
|
||||||
isa = PBXGroup;
|
isa = PBXGroup;
|
||||||
children = (
|
children = (
|
||||||
ED297162215061F000B7C4FE /* JavaScriptCore.framework */,
|
ED297162215061F000B7C4FE /* JavaScriptCore.framework */,
|
||||||
5DCACB8F33CDC322A6C60F78 /* libPods-ReactNativeExample.a */,
|
58EEBF8E8E6FB1BC6CAF49B5 /* libPods-example.a */,
|
||||||
);
|
);
|
||||||
name = Frameworks;
|
name = Frameworks;
|
||||||
sourceTree = "<group>";
|
sourceTree = "<group>";
|
||||||
@ -72,11 +79,12 @@
|
|||||||
83CBB9F61A601CBA00E9B192 = {
|
83CBB9F61A601CBA00E9B192 = {
|
||||||
isa = PBXGroup;
|
isa = PBXGroup;
|
||||||
children = (
|
children = (
|
||||||
13B07FAE1A68108700A75B9A /* ReactNativeExample */,
|
13B07FAE1A68108700A75B9A /* example */,
|
||||||
832341AE1AAA6A7D00B99B32 /* Libraries */,
|
832341AE1AAA6A7D00B99B32 /* Libraries */,
|
||||||
83CBBA001A601CBA00E9B192 /* Products */,
|
83CBBA001A601CBA00E9B192 /* Products */,
|
||||||
2D16E6871FA4F8E400B85C8A /* Frameworks */,
|
2D16E6871FA4F8E400B85C8A /* Frameworks */,
|
||||||
BBD78D7AC51CEA395F1C20DB /* Pods */,
|
D65327D7A22EEC0BE12398D9 /* Pods */,
|
||||||
|
D7E4C46ADA2E9064B798F356 /* ExpoModulesProviders */,
|
||||||
);
|
);
|
||||||
indentWidth = 2;
|
indentWidth = 2;
|
||||||
sourceTree = "<group>";
|
sourceTree = "<group>";
|
||||||
@ -86,43 +94,67 @@
|
|||||||
83CBBA001A601CBA00E9B192 /* Products */ = {
|
83CBBA001A601CBA00E9B192 /* Products */ = {
|
||||||
isa = PBXGroup;
|
isa = PBXGroup;
|
||||||
children = (
|
children = (
|
||||||
13B07F961A680F5B00A75B9A /* ReactNativeExample.app */,
|
13B07F961A680F5B00A75B9A /* example.app */,
|
||||||
);
|
);
|
||||||
name = Products;
|
name = Products;
|
||||||
sourceTree = "<group>";
|
sourceTree = "<group>";
|
||||||
};
|
};
|
||||||
BBD78D7AC51CEA395F1C20DB /* Pods */ = {
|
92DBD88DE9BF7D494EA9DA96 /* example */ = {
|
||||||
isa = PBXGroup;
|
isa = PBXGroup;
|
||||||
children = (
|
children = (
|
||||||
3B4392A12AC88292D35C810B /* Pods-ReactNativeExample.debug.xcconfig */,
|
FAC715A2D49A985799AEE119 /* ExpoModulesProvider.swift */,
|
||||||
5709B34CF0A7D63546082F79 /* Pods-ReactNativeExample.release.xcconfig */,
|
);
|
||||||
|
name = example;
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
|
BB2F792B24A3F905000567C9 /* Supporting */ = {
|
||||||
|
isa = PBXGroup;
|
||||||
|
children = (
|
||||||
|
BB2F792C24A3F905000567C9 /* Expo.plist */,
|
||||||
|
);
|
||||||
|
name = Supporting;
|
||||||
|
path = example/Supporting;
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
|
D65327D7A22EEC0BE12398D9 /* Pods */ = {
|
||||||
|
isa = PBXGroup;
|
||||||
|
children = (
|
||||||
|
6C2E3173556A471DD304B334 /* Pods-example.debug.xcconfig */,
|
||||||
|
7A4D352CD337FB3A3BF06240 /* Pods-example.release.xcconfig */,
|
||||||
);
|
);
|
||||||
path = Pods;
|
path = Pods;
|
||||||
sourceTree = "<group>";
|
sourceTree = "<group>";
|
||||||
};
|
};
|
||||||
|
D7E4C46ADA2E9064B798F356 /* ExpoModulesProviders */ = {
|
||||||
|
isa = PBXGroup;
|
||||||
|
children = (
|
||||||
|
92DBD88DE9BF7D494EA9DA96 /* example */,
|
||||||
|
);
|
||||||
|
name = ExpoModulesProviders;
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
/* End PBXGroup section */
|
/* End PBXGroup section */
|
||||||
|
|
||||||
/* Begin PBXNativeTarget section */
|
/* Begin PBXNativeTarget section */
|
||||||
13B07F861A680F5B00A75B9A /* ReactNativeExample */ = {
|
13B07F861A680F5B00A75B9A /* example */ = {
|
||||||
isa = PBXNativeTarget;
|
isa = PBXNativeTarget;
|
||||||
buildConfigurationList = 13B07F931A680F5B00A75B9A /* Build configuration list for PBXNativeTarget "ReactNativeExample" */;
|
buildConfigurationList = 13B07F931A680F5B00A75B9A /* Build configuration list for PBXNativeTarget "example" */;
|
||||||
buildPhases = (
|
buildPhases = (
|
||||||
C38B50BA6285516D6DCD4F65 /* [CP] Check Pods Manifest.lock */,
|
08A4A3CD28434E44B6B9DE2E /* [CP] Check Pods Manifest.lock */,
|
||||||
FD10A7F022414F080027D42C /* Start Packager */,
|
FD10A7F022414F080027D42C /* Start Packager */,
|
||||||
13B07F871A680F5B00A75B9A /* Sources */,
|
13B07F871A680F5B00A75B9A /* Sources */,
|
||||||
13B07F8C1A680F5B00A75B9A /* Frameworks */,
|
13B07F8C1A680F5B00A75B9A /* Frameworks */,
|
||||||
13B07F8E1A680F5B00A75B9A /* Resources */,
|
13B07F8E1A680F5B00A75B9A /* Resources */,
|
||||||
00DD1BFF1BD5951E006B06BC /* Bundle React Native code and images */,
|
00DD1BFF1BD5951E006B06BC /* Bundle React Native code and images */,
|
||||||
00EEFC60759A1932668264C0 /* [CP] Embed Pods Frameworks */,
|
800E24972A6A228C8D4807E9 /* [CP] Copy Pods Resources */,
|
||||||
E235C05ADACE081382539298 /* [CP] Copy Pods Resources */,
|
|
||||||
);
|
);
|
||||||
buildRules = (
|
buildRules = (
|
||||||
);
|
);
|
||||||
dependencies = (
|
dependencies = (
|
||||||
);
|
);
|
||||||
name = ReactNativeExample;
|
name = example;
|
||||||
productName = ReactNativeExample;
|
productName = example;
|
||||||
productReference = 13B07F961A680F5B00A75B9A /* ReactNativeExample.app */;
|
productReference = 13B07F961A680F5B00A75B9A /* example.app */;
|
||||||
productType = "com.apple.product-type.application";
|
productType = "com.apple.product-type.application";
|
||||||
};
|
};
|
||||||
/* End PBXNativeTarget section */
|
/* End PBXNativeTarget section */
|
||||||
@ -131,15 +163,15 @@
|
|||||||
83CBB9F71A601CBA00E9B192 /* Project object */ = {
|
83CBB9F71A601CBA00E9B192 /* Project object */ = {
|
||||||
isa = PBXProject;
|
isa = PBXProject;
|
||||||
attributes = {
|
attributes = {
|
||||||
LastUpgradeCheck = 1210;
|
LastUpgradeCheck = 1130;
|
||||||
TargetAttributes = {
|
TargetAttributes = {
|
||||||
13B07F861A680F5B00A75B9A = {
|
13B07F861A680F5B00A75B9A = {
|
||||||
LastSwiftMigration = 1120;
|
LastSwiftMigration = 1250;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
buildConfigurationList = 83CBB9FA1A601CBA00E9B192 /* Build configuration list for PBXProject "ReactNativeExample" */;
|
buildConfigurationList = 83CBB9FA1A601CBA00E9B192 /* Build configuration list for PBXProject "example" */;
|
||||||
compatibilityVersion = "Xcode 12.0";
|
compatibilityVersion = "Xcode 3.2";
|
||||||
developmentRegion = en;
|
developmentRegion = en;
|
||||||
hasScannedForEncodings = 0;
|
hasScannedForEncodings = 0;
|
||||||
knownRegions = (
|
knownRegions = (
|
||||||
@ -151,7 +183,7 @@
|
|||||||
projectDirPath = "";
|
projectDirPath = "";
|
||||||
projectRoot = "";
|
projectRoot = "";
|
||||||
targets = (
|
targets = (
|
||||||
13B07F861A680F5B00A75B9A /* ReactNativeExample */,
|
13B07F861A680F5B00A75B9A /* example */,
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
/* End PBXProject section */
|
/* End PBXProject section */
|
||||||
@ -161,8 +193,9 @@
|
|||||||
isa = PBXResourcesBuildPhase;
|
isa = PBXResourcesBuildPhase;
|
||||||
buildActionMask = 2147483647;
|
buildActionMask = 2147483647;
|
||||||
files = (
|
files = (
|
||||||
81AB9BB82411601600AC10FF /* LaunchScreen.storyboard in Resources */,
|
BB2F792D24A3F905000567C9 /* Expo.plist in Resources */,
|
||||||
13B07FBF1A68108700A75B9A /* Images.xcassets in Resources */,
|
13B07FBF1A68108700A75B9A /* Images.xcassets in Resources */,
|
||||||
|
3E461D99554A48A4959DE609 /* SplashScreen.storyboard in Resources */,
|
||||||
);
|
);
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
};
|
};
|
||||||
@ -181,26 +214,9 @@
|
|||||||
);
|
);
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
shellPath = /bin/sh;
|
shellPath = /bin/sh;
|
||||||
shellScript = "set -e\n\nexport NODE_BINARY=node\n../node_modules/react-native/scripts/react-native-xcode.sh\n";
|
shellScript = "if [[ -f \"$PODS_ROOT/../.xcode.env\" ]]; then\n source \"$PODS_ROOT/../.xcode.env\"\nfi\nif [[ -f \"$PODS_ROOT/../.xcode.env.local\" ]]; then\n source \"$PODS_ROOT/../.xcode.env.local\"\nfi\n\n# The project root by default is one level up from the ios directory\nexport PROJECT_ROOT=\"$PROJECT_DIR\"/..\n\nif [[ \"$CONFIGURATION\" = *Debug* ]]; then\n export SKIP_BUNDLING=1\nfi\nif [[ -z \"$ENTRY_FILE\" ]]; then\n # Set the entry JS file using the bundler's entry resolution.\n export ENTRY_FILE=\"$(\"$NODE_BINARY\" -e \"require('expo/scripts/resolveAppEntry')\" $PROJECT_ROOT ios relative | tail -n 1)\"\nfi\n\n`\"$NODE_BINARY\" --print \"require('path').dirname(require.resolve('react-native/package.json')) + '/scripts/react-native-xcode.sh'\"`\n\n";
|
||||||
};
|
};
|
||||||
00EEFC60759A1932668264C0 /* [CP] Embed Pods Frameworks */ = {
|
08A4A3CD28434E44B6B9DE2E /* [CP] Check Pods Manifest.lock */ = {
|
||||||
isa = PBXShellScriptBuildPhase;
|
|
||||||
buildActionMask = 2147483647;
|
|
||||||
files = (
|
|
||||||
);
|
|
||||||
inputFileListPaths = (
|
|
||||||
"${PODS_ROOT}/Target Support Files/Pods-ReactNativeExample/Pods-ReactNativeExample-frameworks-${CONFIGURATION}-input-files.xcfilelist",
|
|
||||||
);
|
|
||||||
name = "[CP] Embed Pods Frameworks";
|
|
||||||
outputFileListPaths = (
|
|
||||||
"${PODS_ROOT}/Target Support Files/Pods-ReactNativeExample/Pods-ReactNativeExample-frameworks-${CONFIGURATION}-output-files.xcfilelist",
|
|
||||||
);
|
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
|
||||||
shellPath = /bin/sh;
|
|
||||||
shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-ReactNativeExample/Pods-ReactNativeExample-frameworks.sh\"\n";
|
|
||||||
showEnvVarsInLog = 0;
|
|
||||||
};
|
|
||||||
C38B50BA6285516D6DCD4F65 /* [CP] Check Pods Manifest.lock */ = {
|
|
||||||
isa = PBXShellScriptBuildPhase;
|
isa = PBXShellScriptBuildPhase;
|
||||||
buildActionMask = 2147483647;
|
buildActionMask = 2147483647;
|
||||||
files = (
|
files = (
|
||||||
@ -215,28 +231,33 @@
|
|||||||
outputFileListPaths = (
|
outputFileListPaths = (
|
||||||
);
|
);
|
||||||
outputPaths = (
|
outputPaths = (
|
||||||
"$(DERIVED_FILE_DIR)/Pods-ReactNativeExample-checkManifestLockResult.txt",
|
"$(DERIVED_FILE_DIR)/Pods-example-checkManifestLockResult.txt",
|
||||||
);
|
);
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
shellPath = /bin/sh;
|
shellPath = /bin/sh;
|
||||||
shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n";
|
shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n";
|
||||||
showEnvVarsInLog = 0;
|
showEnvVarsInLog = 0;
|
||||||
};
|
};
|
||||||
E235C05ADACE081382539298 /* [CP] Copy Pods Resources */ = {
|
800E24972A6A228C8D4807E9 /* [CP] Copy Pods Resources */ = {
|
||||||
isa = PBXShellScriptBuildPhase;
|
isa = PBXShellScriptBuildPhase;
|
||||||
buildActionMask = 2147483647;
|
buildActionMask = 2147483647;
|
||||||
files = (
|
files = (
|
||||||
);
|
);
|
||||||
inputFileListPaths = (
|
inputPaths = (
|
||||||
"${PODS_ROOT}/Target Support Files/Pods-ReactNativeExample/Pods-ReactNativeExample-resources-${CONFIGURATION}-input-files.xcfilelist",
|
"${PODS_ROOT}/Target Support Files/Pods-example/Pods-example-resources.sh",
|
||||||
|
"${PODS_CONFIGURATION_BUILD_DIR}/EXConstants/EXConstants.bundle",
|
||||||
|
"${PODS_CONFIGURATION_BUILD_DIR}/EXUpdates/EXUpdates.bundle",
|
||||||
|
"${PODS_CONFIGURATION_BUILD_DIR}/React-Core/AccessibilityResources.bundle",
|
||||||
);
|
);
|
||||||
name = "[CP] Copy Pods Resources";
|
name = "[CP] Copy Pods Resources";
|
||||||
outputFileListPaths = (
|
outputPaths = (
|
||||||
"${PODS_ROOT}/Target Support Files/Pods-ReactNativeExample/Pods-ReactNativeExample-resources-${CONFIGURATION}-output-files.xcfilelist",
|
"${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/EXConstants.bundle",
|
||||||
|
"${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/EXUpdates.bundle",
|
||||||
|
"${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/AccessibilityResources.bundle",
|
||||||
);
|
);
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
shellPath = /bin/sh;
|
shellPath = /bin/sh;
|
||||||
shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-ReactNativeExample/Pods-ReactNativeExample-resources.sh\"\n";
|
shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-example/Pods-example-resources.sh\"\n";
|
||||||
showEnvVarsInLog = 0;
|
showEnvVarsInLog = 0;
|
||||||
};
|
};
|
||||||
FD10A7F022414F080027D42C /* Start Packager */ = {
|
FD10A7F022414F080027D42C /* Start Packager */ = {
|
||||||
@ -255,7 +276,7 @@
|
|||||||
);
|
);
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
shellPath = /bin/sh;
|
shellPath = /bin/sh;
|
||||||
shellScript = "export RCT_METRO_PORT=\"${RCT_METRO_PORT:=8081}\"\necho \"export RCT_METRO_PORT=${RCT_METRO_PORT}\" > \"${SRCROOT}/../node_modules/react-native/scripts/.packager.env\"\nif [ -z \"${RCT_NO_LAUNCH_PACKAGER+xxx}\" ] ; then\n if nc -w 5 -z localhost ${RCT_METRO_PORT} ; then\n if ! curl -s \"http://localhost:${RCT_METRO_PORT}/status\" | grep -q \"packager-status:running\" ; then\n echo \"Port ${RCT_METRO_PORT} already in use, packager is either not running or not running correctly\"\n exit 2\n fi\n else\n open \"$SRCROOT/../node_modules/react-native/scripts/launchPackager.command\" || echo \"Can't start packager automatically\"\n fi\nfi\n";
|
shellScript = "if [[ -f \"$PODS_ROOT/../.xcode.env\" ]]; then\n source \"$PODS_ROOT/../.xcode.env\"\nfi\nif [[ -f \"$PODS_ROOT/../.xcode.env.local\" ]]; then\n source \"$PODS_ROOT/../.xcode.env.local\"\nfi\n\nexport RCT_METRO_PORT=\"${RCT_METRO_PORT:=8081}\"\necho \"export RCT_METRO_PORT=${RCT_METRO_PORT}\" > `$NODE_BINARY --print \"require('path').dirname(require.resolve('react-native/package.json')) + '/scripts/.packager.env'\"`\nif [ -z \"${RCT_NO_LAUNCH_PACKAGER+xxx}\" ] ; then\n if nc -w 5 -z localhost ${RCT_METRO_PORT} ; then\n if ! curl -s \"http://localhost:${RCT_METRO_PORT}/status\" | grep -q \"packager-status:running\" ; then\n echo \"Port ${RCT_METRO_PORT} already in use, packager is either not running or not running correctly\"\n exit 2\n fi\n else\n open `$NODE_BINARY --print \"require('path').dirname(require.resolve('react-native/package.json')) + '/scripts/launchPackager.command'\"` || echo \"Can't start packager automatically\"\n fi\nfi\n";
|
||||||
showEnvVarsInLog = 0;
|
showEnvVarsInLog = 0;
|
||||||
};
|
};
|
||||||
/* End PBXShellScriptBuildPhase section */
|
/* End PBXShellScriptBuildPhase section */
|
||||||
@ -267,6 +288,7 @@
|
|||||||
files = (
|
files = (
|
||||||
13B07FBC1A68108700A75B9A /* AppDelegate.mm in Sources */,
|
13B07FBC1A68108700A75B9A /* AppDelegate.mm in Sources */,
|
||||||
13B07FC11A68108700A75B9A /* main.m in Sources */,
|
13B07FC11A68108700A75B9A /* main.m in Sources */,
|
||||||
|
B18059E884C0ABDD17F3DC3D /* ExpoModulesProvider.swift in Sources */,
|
||||||
);
|
);
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
};
|
};
|
||||||
@ -275,24 +297,26 @@
|
|||||||
/* Begin XCBuildConfiguration section */
|
/* Begin XCBuildConfiguration section */
|
||||||
13B07F941A680F5B00A75B9A /* Debug */ = {
|
13B07F941A680F5B00A75B9A /* Debug */ = {
|
||||||
isa = XCBuildConfiguration;
|
isa = XCBuildConfiguration;
|
||||||
baseConfigurationReference = 3B4392A12AC88292D35C810B /* Pods-ReactNativeExample.debug.xcconfig */;
|
baseConfigurationReference = 6C2E3173556A471DD304B334 /* Pods-example.debug.xcconfig */;
|
||||||
buildSettings = {
|
buildSettings = {
|
||||||
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
|
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
|
||||||
CLANG_ENABLE_MODULES = YES;
|
CLANG_ENABLE_MODULES = YES;
|
||||||
CURRENT_PROJECT_VERSION = 1;
|
CURRENT_PROJECT_VERSION = 1;
|
||||||
ENABLE_BITCODE = NO;
|
ENABLE_BITCODE = NO;
|
||||||
INFOPLIST_FILE = ReactNativeExample/Info.plist;
|
GCC_PREPROCESSOR_DEFINITIONS = (
|
||||||
LD_RUNPATH_SEARCH_PATHS = (
|
|
||||||
"$(inherited)",
|
"$(inherited)",
|
||||||
"@executable_path/Frameworks",
|
"FB_SONARKIT_ENABLED=1",
|
||||||
);
|
);
|
||||||
|
INFOPLIST_FILE = example/Info.plist;
|
||||||
|
IPHONEOS_DEPLOYMENT_TARGET = 13.0;
|
||||||
|
LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
|
||||||
OTHER_LDFLAGS = (
|
OTHER_LDFLAGS = (
|
||||||
"$(inherited)",
|
"$(inherited)",
|
||||||
"-ObjC",
|
"-ObjC",
|
||||||
"-lc++",
|
"-lc++",
|
||||||
);
|
);
|
||||||
PRODUCT_BUNDLE_IDENTIFIER = com.example.wakureactnative;
|
PRODUCT_BUNDLE_IDENTIFIER = org.name.example;
|
||||||
PRODUCT_NAME = ReactNativeExample;
|
PRODUCT_NAME = example;
|
||||||
SWIFT_OPTIMIZATION_LEVEL = "-Onone";
|
SWIFT_OPTIMIZATION_LEVEL = "-Onone";
|
||||||
SWIFT_VERSION = 5.0;
|
SWIFT_VERSION = 5.0;
|
||||||
VERSIONING_SYSTEM = "apple-generic";
|
VERSIONING_SYSTEM = "apple-generic";
|
||||||
@ -301,23 +325,21 @@
|
|||||||
};
|
};
|
||||||
13B07F951A680F5B00A75B9A /* Release */ = {
|
13B07F951A680F5B00A75B9A /* Release */ = {
|
||||||
isa = XCBuildConfiguration;
|
isa = XCBuildConfiguration;
|
||||||
baseConfigurationReference = 5709B34CF0A7D63546082F79 /* Pods-ReactNativeExample.release.xcconfig */;
|
baseConfigurationReference = 7A4D352CD337FB3A3BF06240 /* Pods-example.release.xcconfig */;
|
||||||
buildSettings = {
|
buildSettings = {
|
||||||
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
|
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
|
||||||
CLANG_ENABLE_MODULES = YES;
|
CLANG_ENABLE_MODULES = YES;
|
||||||
CURRENT_PROJECT_VERSION = 1;
|
CURRENT_PROJECT_VERSION = 1;
|
||||||
INFOPLIST_FILE = ReactNativeExample/Info.plist;
|
INFOPLIST_FILE = example/Info.plist;
|
||||||
LD_RUNPATH_SEARCH_PATHS = (
|
IPHONEOS_DEPLOYMENT_TARGET = 13.0;
|
||||||
"$(inherited)",
|
LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
|
||||||
"@executable_path/Frameworks",
|
|
||||||
);
|
|
||||||
OTHER_LDFLAGS = (
|
OTHER_LDFLAGS = (
|
||||||
"$(inherited)",
|
"$(inherited)",
|
||||||
"-ObjC",
|
"-ObjC",
|
||||||
"-lc++",
|
"-lc++",
|
||||||
);
|
);
|
||||||
PRODUCT_BUNDLE_IDENTIFIER = com.example.wakureactnative;
|
PRODUCT_BUNDLE_IDENTIFIER = org.name.example;
|
||||||
PRODUCT_NAME = ReactNativeExample;
|
PRODUCT_NAME = example;
|
||||||
SWIFT_VERSION = 5.0;
|
SWIFT_VERSION = 5.0;
|
||||||
VERSIONING_SYSTEM = "apple-generic";
|
VERSIONING_SYSTEM = "apple-generic";
|
||||||
};
|
};
|
||||||
@ -346,7 +368,6 @@
|
|||||||
CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
|
CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
|
||||||
CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
|
CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
|
||||||
CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
|
CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
|
||||||
CLANG_WARN_QUOTED_INCLUDE_IN_FRAMEWORK_HEADER = YES;
|
|
||||||
CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
|
CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
|
||||||
CLANG_WARN_STRICT_PROTOTYPES = YES;
|
CLANG_WARN_STRICT_PROTOTYPES = YES;
|
||||||
CLANG_WARN_SUSPICIOUS_MOVE = YES;
|
CLANG_WARN_SUSPICIOUS_MOVE = YES;
|
||||||
@ -356,7 +377,6 @@
|
|||||||
COPY_PHASE_STRIP = NO;
|
COPY_PHASE_STRIP = NO;
|
||||||
ENABLE_STRICT_OBJC_MSGSEND = YES;
|
ENABLE_STRICT_OBJC_MSGSEND = YES;
|
||||||
ENABLE_TESTABILITY = YES;
|
ENABLE_TESTABILITY = YES;
|
||||||
"EXCLUDED_ARCHS[sdk=iphonesimulator*]" = i386;
|
|
||||||
GCC_C_LANGUAGE_STANDARD = gnu99;
|
GCC_C_LANGUAGE_STANDARD = gnu99;
|
||||||
GCC_DYNAMIC_NO_PIC = NO;
|
GCC_DYNAMIC_NO_PIC = NO;
|
||||||
GCC_NO_COMMON_BLOCKS = YES;
|
GCC_NO_COMMON_BLOCKS = YES;
|
||||||
@ -372,24 +392,11 @@
|
|||||||
GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
|
GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
|
||||||
GCC_WARN_UNUSED_FUNCTION = YES;
|
GCC_WARN_UNUSED_FUNCTION = YES;
|
||||||
GCC_WARN_UNUSED_VARIABLE = YES;
|
GCC_WARN_UNUSED_VARIABLE = YES;
|
||||||
IPHONEOS_DEPLOYMENT_TARGET = 11.0;
|
IPHONEOS_DEPLOYMENT_TARGET = 13.0;
|
||||||
LD_RUNPATH_SEARCH_PATHS = (
|
LD_RUNPATH_SEARCH_PATHS = "/usr/lib/swift $(inherited)";
|
||||||
/usr/lib/swift,
|
LIBRARY_SEARCH_PATHS = "\"$(inherited)\"";
|
||||||
"$(inherited)",
|
|
||||||
);
|
|
||||||
LIBRARY_SEARCH_PATHS = (
|
|
||||||
"\"$(SDKROOT)/usr/lib/swift\"",
|
|
||||||
"\"$(TOOLCHAIN_DIR)/usr/lib/swift/$(PLATFORM_NAME)\"",
|
|
||||||
"\"$(inherited)\"",
|
|
||||||
);
|
|
||||||
MTL_ENABLE_DEBUG_INFO = YES;
|
MTL_ENABLE_DEBUG_INFO = YES;
|
||||||
ONLY_ACTIVE_ARCH = YES;
|
ONLY_ACTIVE_ARCH = YES;
|
||||||
OTHER_CPLUSPLUSFLAGS = (
|
|
||||||
"$(OTHER_CFLAGS)",
|
|
||||||
"-DFOLLY_NO_CONFIG",
|
|
||||||
"-DFOLLY_MOBILE=1",
|
|
||||||
"-DFOLLY_USE_LIBCPP=1",
|
|
||||||
);
|
|
||||||
SDKROOT = iphoneos;
|
SDKROOT = iphoneos;
|
||||||
};
|
};
|
||||||
name = Debug;
|
name = Debug;
|
||||||
@ -417,7 +424,6 @@
|
|||||||
CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
|
CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
|
||||||
CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
|
CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
|
||||||
CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
|
CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
|
||||||
CLANG_WARN_QUOTED_INCLUDE_IN_FRAMEWORK_HEADER = YES;
|
|
||||||
CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
|
CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
|
||||||
CLANG_WARN_STRICT_PROTOTYPES = YES;
|
CLANG_WARN_STRICT_PROTOTYPES = YES;
|
||||||
CLANG_WARN_SUSPICIOUS_MOVE = YES;
|
CLANG_WARN_SUSPICIOUS_MOVE = YES;
|
||||||
@ -427,7 +433,6 @@
|
|||||||
COPY_PHASE_STRIP = YES;
|
COPY_PHASE_STRIP = YES;
|
||||||
ENABLE_NS_ASSERTIONS = NO;
|
ENABLE_NS_ASSERTIONS = NO;
|
||||||
ENABLE_STRICT_OBJC_MSGSEND = YES;
|
ENABLE_STRICT_OBJC_MSGSEND = YES;
|
||||||
"EXCLUDED_ARCHS[sdk=iphonesimulator*]" = i386;
|
|
||||||
GCC_C_LANGUAGE_STANDARD = gnu99;
|
GCC_C_LANGUAGE_STANDARD = gnu99;
|
||||||
GCC_NO_COMMON_BLOCKS = YES;
|
GCC_NO_COMMON_BLOCKS = YES;
|
||||||
GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
|
GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
|
||||||
@ -436,23 +441,10 @@
|
|||||||
GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
|
GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
|
||||||
GCC_WARN_UNUSED_FUNCTION = YES;
|
GCC_WARN_UNUSED_FUNCTION = YES;
|
||||||
GCC_WARN_UNUSED_VARIABLE = YES;
|
GCC_WARN_UNUSED_VARIABLE = YES;
|
||||||
IPHONEOS_DEPLOYMENT_TARGET = 11.0;
|
IPHONEOS_DEPLOYMENT_TARGET = 13.0;
|
||||||
LD_RUNPATH_SEARCH_PATHS = (
|
LD_RUNPATH_SEARCH_PATHS = "/usr/lib/swift $(inherited)";
|
||||||
/usr/lib/swift,
|
LIBRARY_SEARCH_PATHS = "\"$(inherited)\"";
|
||||||
"$(inherited)",
|
|
||||||
);
|
|
||||||
LIBRARY_SEARCH_PATHS = (
|
|
||||||
"\"$(SDKROOT)/usr/lib/swift\"",
|
|
||||||
"\"$(TOOLCHAIN_DIR)/usr/lib/swift/$(PLATFORM_NAME)\"",
|
|
||||||
"\"$(inherited)\"",
|
|
||||||
);
|
|
||||||
MTL_ENABLE_DEBUG_INFO = NO;
|
MTL_ENABLE_DEBUG_INFO = NO;
|
||||||
OTHER_CPLUSPLUSFLAGS = (
|
|
||||||
"$(OTHER_CFLAGS)",
|
|
||||||
"-DFOLLY_NO_CONFIG",
|
|
||||||
"-DFOLLY_MOBILE=1",
|
|
||||||
"-DFOLLY_USE_LIBCPP=1",
|
|
||||||
);
|
|
||||||
SDKROOT = iphoneos;
|
SDKROOT = iphoneos;
|
||||||
VALIDATE_PRODUCT = YES;
|
VALIDATE_PRODUCT = YES;
|
||||||
};
|
};
|
||||||
@ -461,7 +453,7 @@
|
|||||||
/* End XCBuildConfiguration section */
|
/* End XCBuildConfiguration section */
|
||||||
|
|
||||||
/* Begin XCConfigurationList section */
|
/* Begin XCConfigurationList section */
|
||||||
13B07F931A680F5B00A75B9A /* Build configuration list for PBXNativeTarget "ReactNativeExample" */ = {
|
13B07F931A680F5B00A75B9A /* Build configuration list for PBXNativeTarget "example" */ = {
|
||||||
isa = XCConfigurationList;
|
isa = XCConfigurationList;
|
||||||
buildConfigurations = (
|
buildConfigurations = (
|
||||||
13B07F941A680F5B00A75B9A /* Debug */,
|
13B07F941A680F5B00A75B9A /* Debug */,
|
||||||
@ -470,7 +462,7 @@
|
|||||||
defaultConfigurationIsVisible = 0;
|
defaultConfigurationIsVisible = 0;
|
||||||
defaultConfigurationName = Release;
|
defaultConfigurationName = Release;
|
||||||
};
|
};
|
||||||
83CBB9FA1A601CBA00E9B192 /* Build configuration list for PBXProject "ReactNativeExample" */ = {
|
83CBB9FA1A601CBA00E9B192 /* Build configuration list for PBXProject "example" */ = {
|
||||||
isa = XCConfigurationList;
|
isa = XCConfigurationList;
|
||||||
buildConfigurations = (
|
buildConfigurations = (
|
||||||
83CBBA201A601CBA00E9B192 /* Debug */,
|
83CBBA201A601CBA00E9B192 /* Debug */,
|
||||||
@ -1,6 +1,6 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<Scheme
|
<Scheme
|
||||||
LastUpgradeVersion = "1210"
|
LastUpgradeVersion = "1130"
|
||||||
version = "1.3">
|
version = "1.3">
|
||||||
<BuildAction
|
<BuildAction
|
||||||
parallelizeBuildables = "YES"
|
parallelizeBuildables = "YES"
|
||||||
@ -15,13 +15,31 @@
|
|||||||
<BuildableReference
|
<BuildableReference
|
||||||
BuildableIdentifier = "primary"
|
BuildableIdentifier = "primary"
|
||||||
BlueprintIdentifier = "13B07F861A680F5B00A75B9A"
|
BlueprintIdentifier = "13B07F861A680F5B00A75B9A"
|
||||||
BuildableName = "ReactNativeExample.app"
|
BuildableName = "example.app"
|
||||||
BlueprintName = "ReactNativeExample"
|
BlueprintName = "example"
|
||||||
ReferencedContainer = "container:ReactNativeExample.xcodeproj">
|
ReferencedContainer = "container:example.xcodeproj">
|
||||||
</BuildableReference>
|
</BuildableReference>
|
||||||
</BuildActionEntry>
|
</BuildActionEntry>
|
||||||
</BuildActionEntries>
|
</BuildActionEntries>
|
||||||
</BuildAction>
|
</BuildAction>
|
||||||
|
<TestAction
|
||||||
|
buildConfiguration = "Debug"
|
||||||
|
selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
|
||||||
|
selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
|
||||||
|
shouldUseLaunchSchemeArgsEnv = "YES">
|
||||||
|
<Testables>
|
||||||
|
<TestableReference
|
||||||
|
skipped = "NO">
|
||||||
|
<BuildableReference
|
||||||
|
BuildableIdentifier = "primary"
|
||||||
|
BlueprintIdentifier = "00E356ED1AD99517003FC87E"
|
||||||
|
BuildableName = "exampleTests.xctest"
|
||||||
|
BlueprintName = "exampleTests"
|
||||||
|
ReferencedContainer = "container:example.xcodeproj">
|
||||||
|
</BuildableReference>
|
||||||
|
</TestableReference>
|
||||||
|
</Testables>
|
||||||
|
</TestAction>
|
||||||
<LaunchAction
|
<LaunchAction
|
||||||
buildConfiguration = "Debug"
|
buildConfiguration = "Debug"
|
||||||
selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
|
selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
|
||||||
@ -37,9 +55,9 @@
|
|||||||
<BuildableReference
|
<BuildableReference
|
||||||
BuildableIdentifier = "primary"
|
BuildableIdentifier = "primary"
|
||||||
BlueprintIdentifier = "13B07F861A680F5B00A75B9A"
|
BlueprintIdentifier = "13B07F861A680F5B00A75B9A"
|
||||||
BuildableName = "ReactNativeExample.app"
|
BuildableName = "example.app"
|
||||||
BlueprintName = "ReactNativeExample"
|
BlueprintName = "example"
|
||||||
ReferencedContainer = "container:ReactNativeExample.xcodeproj">
|
ReferencedContainer = "container:example.xcodeproj">
|
||||||
</BuildableReference>
|
</BuildableReference>
|
||||||
</BuildableProductRunnable>
|
</BuildableProductRunnable>
|
||||||
</LaunchAction>
|
</LaunchAction>
|
||||||
@ -54,9 +72,9 @@
|
|||||||
<BuildableReference
|
<BuildableReference
|
||||||
BuildableIdentifier = "primary"
|
BuildableIdentifier = "primary"
|
||||||
BlueprintIdentifier = "13B07F861A680F5B00A75B9A"
|
BlueprintIdentifier = "13B07F861A680F5B00A75B9A"
|
||||||
BuildableName = "ReactNativeExample.app"
|
BuildableName = "example.app"
|
||||||
BlueprintName = "ReactNativeExample"
|
BlueprintName = "example"
|
||||||
ReferencedContainer = "container:ReactNativeExample.xcodeproj">
|
ReferencedContainer = "container:example.xcodeproj">
|
||||||
</BuildableReference>
|
</BuildableReference>
|
||||||
</BuildableProductRunnable>
|
</BuildableProductRunnable>
|
||||||
</ProfileAction>
|
</ProfileAction>
|
||||||
9
example/ios/example/AppDelegate.h
Normal file
9
example/ios/example/AppDelegate.h
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
#import <Foundation/Foundation.h>
|
||||||
|
#import <React/RCTBridgeDelegate.h>
|
||||||
|
#import <UIKit/UIKit.h>
|
||||||
|
|
||||||
|
#import <Expo/Expo.h>
|
||||||
|
|
||||||
|
@interface AppDelegate : EXAppDelegateWrapper <RCTBridgeDelegate>
|
||||||
|
|
||||||
|
@end
|
||||||
166
example/ios/example/AppDelegate.mm
Normal file
166
example/ios/example/AppDelegate.mm
Normal file
@ -0,0 +1,166 @@
|
|||||||
|
#import "AppDelegate.h"
|
||||||
|
|
||||||
|
#import <React/RCTBridge.h>
|
||||||
|
#import <React/RCTBundleURLProvider.h>
|
||||||
|
#import <React/RCTRootView.h>
|
||||||
|
#import <React/RCTLinkingManager.h>
|
||||||
|
#import <React/RCTConvert.h>
|
||||||
|
|
||||||
|
#import <React/RCTAppSetupUtils.h>
|
||||||
|
|
||||||
|
#if RCT_NEW_ARCH_ENABLED
|
||||||
|
#import <React/CoreModulesPlugins.h>
|
||||||
|
#import <React/RCTCxxBridgeDelegate.h>
|
||||||
|
#import <React/RCTFabricSurfaceHostingProxyRootView.h>
|
||||||
|
#import <React/RCTSurfacePresenter.h>
|
||||||
|
#import <React/RCTSurfacePresenterBridgeAdapter.h>
|
||||||
|
#import <ReactCommon/RCTTurboModuleManager.h>
|
||||||
|
|
||||||
|
#import <react/config/ReactNativeConfig.h>
|
||||||
|
|
||||||
|
static NSString *const kRNConcurrentRoot = @"concurrentRoot";
|
||||||
|
|
||||||
|
@interface AppDelegate () <RCTCxxBridgeDelegate, RCTTurboModuleManagerDelegate> {
|
||||||
|
RCTTurboModuleManager *_turboModuleManager;
|
||||||
|
RCTSurfacePresenterBridgeAdapter *_bridgeAdapter;
|
||||||
|
std::shared_ptr<const facebook::react::ReactNativeConfig> _reactNativeConfig;
|
||||||
|
facebook::react::ContextContainer::Shared _contextContainer;
|
||||||
|
}
|
||||||
|
@end
|
||||||
|
#endif
|
||||||
|
|
||||||
|
@implementation AppDelegate
|
||||||
|
|
||||||
|
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
|
||||||
|
{
|
||||||
|
RCTAppSetupPrepareApp(application);
|
||||||
|
|
||||||
|
RCTBridge *bridge = [self.reactDelegate createBridgeWithDelegate:self launchOptions:launchOptions];
|
||||||
|
|
||||||
|
#if RCT_NEW_ARCH_ENABLED
|
||||||
|
_contextContainer = std::make_shared<facebook::react::ContextContainer const>();
|
||||||
|
_reactNativeConfig = std::make_shared<facebook::react::EmptyReactNativeConfig const>();
|
||||||
|
_contextContainer->insert("ReactNativeConfig", _reactNativeConfig);
|
||||||
|
_bridgeAdapter = [[RCTSurfacePresenterBridgeAdapter alloc] initWithBridge:bridge contextContainer:_contextContainer];
|
||||||
|
bridge.surfacePresenter = _bridgeAdapter.surfacePresenter;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
NSDictionary *initProps = [self prepareInitialProps];
|
||||||
|
UIView *rootView = [self.reactDelegate createRootViewWithBridge:bridge moduleName:@"main" initialProperties:initProps];
|
||||||
|
|
||||||
|
rootView.backgroundColor = [UIColor whiteColor];
|
||||||
|
self.window = [[UIWindow alloc] initWithFrame:[UIScreen mainScreen].bounds];
|
||||||
|
UIViewController *rootViewController = [self.reactDelegate createRootViewController];
|
||||||
|
rootViewController.view = rootView;
|
||||||
|
self.window.rootViewController = rootViewController;
|
||||||
|
[self.window makeKeyAndVisible];
|
||||||
|
|
||||||
|
[super application:application didFinishLaunchingWithOptions:launchOptions];
|
||||||
|
|
||||||
|
return YES;
|
||||||
|
}
|
||||||
|
|
||||||
|
- (NSArray<id<RCTBridgeModule>> *)extraModulesForBridge:(RCTBridge *)bridge
|
||||||
|
{
|
||||||
|
// If you'd like to export some custom RCTBridgeModules, add them here!
|
||||||
|
return @[];
|
||||||
|
}
|
||||||
|
|
||||||
|
/// This method controls whether the `concurrentRoot`feature of React18 is turned on or off.
|
||||||
|
///
|
||||||
|
/// @see: https://reactjs.org/blog/2022/03/29/react-v18.html
|
||||||
|
/// @note: This requires to be rendering on Fabric (i.e. on the New Architecture).
|
||||||
|
/// @return: `true` if the `concurrentRoot` feture is enabled. Otherwise, it returns `false`.
|
||||||
|
- (BOOL)concurrentRootEnabled
|
||||||
|
{
|
||||||
|
// Switch this bool to turn on and off the concurrent root
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
- (NSDictionary *)prepareInitialProps
|
||||||
|
{
|
||||||
|
NSMutableDictionary *initProps = [NSMutableDictionary new];
|
||||||
|
#if RCT_NEW_ARCH_ENABLED
|
||||||
|
initProps[kRNConcurrentRoot] = @([self concurrentRootEnabled]);
|
||||||
|
#endif
|
||||||
|
return initProps;
|
||||||
|
}
|
||||||
|
|
||||||
|
- (NSURL *)sourceURLForBridge:(RCTBridge *)bridge
|
||||||
|
{
|
||||||
|
#if DEBUG
|
||||||
|
return [[RCTBundleURLProvider sharedSettings] jsBundleURLForBundleRoot:@"index"];
|
||||||
|
#else
|
||||||
|
return [[NSBundle mainBundle] URLForResource:@"main" withExtension:@"jsbundle"];
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
// Linking API
|
||||||
|
- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url options:(NSDictionary<UIApplicationOpenURLOptionsKey,id> *)options {
|
||||||
|
return [super application:application openURL:url options:options] || [RCTLinkingManager application:application openURL:url options:options];
|
||||||
|
}
|
||||||
|
|
||||||
|
// Universal Links
|
||||||
|
- (BOOL)application:(UIApplication *)application continueUserActivity:(nonnull NSUserActivity *)userActivity restorationHandler:(nonnull void (^)(NSArray<id<UIUserActivityRestoring>> * _Nullable))restorationHandler {
|
||||||
|
BOOL result = [RCTLinkingManager application:application continueUserActivity:userActivity restorationHandler:restorationHandler];
|
||||||
|
return [super application:application continueUserActivity:userActivity restorationHandler:restorationHandler] || result;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Explicitly define remote notification delegates to ensure compatibility with some third-party libraries
|
||||||
|
- (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken
|
||||||
|
{
|
||||||
|
return [super application:application didRegisterForRemoteNotificationsWithDeviceToken:deviceToken];
|
||||||
|
}
|
||||||
|
|
||||||
|
// Explicitly define remote notification delegates to ensure compatibility with some third-party libraries
|
||||||
|
- (void)application:(UIApplication *)application didFailToRegisterForRemoteNotificationsWithError:(NSError *)error
|
||||||
|
{
|
||||||
|
return [super application:application didFailToRegisterForRemoteNotificationsWithError:error];
|
||||||
|
}
|
||||||
|
|
||||||
|
// Explicitly define remote notification delegates to ensure compatibility with some third-party libraries
|
||||||
|
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo fetchCompletionHandler:(void (^)(UIBackgroundFetchResult))completionHandler
|
||||||
|
{
|
||||||
|
return [super application:application didReceiveRemoteNotification:userInfo fetchCompletionHandler:completionHandler];
|
||||||
|
}
|
||||||
|
|
||||||
|
#if RCT_NEW_ARCH_ENABLED
|
||||||
|
|
||||||
|
#pragma mark - RCTCxxBridgeDelegate
|
||||||
|
|
||||||
|
- (std::unique_ptr<facebook::react::JSExecutorFactory>)jsExecutorFactoryForBridge:(RCTBridge *)bridge
|
||||||
|
{
|
||||||
|
_turboModuleManager = [[RCTTurboModuleManager alloc] initWithBridge:bridge
|
||||||
|
delegate:self
|
||||||
|
jsInvoker:bridge.jsCallInvoker];
|
||||||
|
return RCTAppSetupDefaultJsExecutorFactory(bridge, _turboModuleManager);
|
||||||
|
}
|
||||||
|
|
||||||
|
#pragma mark RCTTurboModuleManagerDelegate
|
||||||
|
|
||||||
|
- (Class)getModuleClassFromName:(const char *)name
|
||||||
|
{
|
||||||
|
return RCTCoreModulesClassProvider(name);
|
||||||
|
}
|
||||||
|
|
||||||
|
- (std::shared_ptr<facebook::react::TurboModule>)getTurboModule:(const std::string &)name
|
||||||
|
jsInvoker:(std::shared_ptr<facebook::react::CallInvoker>)jsInvoker
|
||||||
|
{
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
- (std::shared_ptr<facebook::react::TurboModule>)getTurboModule:(const std::string &)name
|
||||||
|
initParams:
|
||||||
|
(const facebook::react::ObjCTurboModule::InitParams &)params
|
||||||
|
{
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
- (id<RCTTurboModule>)getModuleInstanceFromClass:(Class)moduleClass
|
||||||
|
{
|
||||||
|
return RCTAppSetupDefaultModuleFromClass(moduleClass);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
@end
|
||||||
@ -0,0 +1,38 @@
|
|||||||
|
{
|
||||||
|
"images" : [
|
||||||
|
{
|
||||||
|
"idiom" : "iphone",
|
||||||
|
"size" : "29x29",
|
||||||
|
"scale" : "2x"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"idiom" : "iphone",
|
||||||
|
"size" : "29x29",
|
||||||
|
"scale" : "3x"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"idiom" : "iphone",
|
||||||
|
"size" : "40x40",
|
||||||
|
"scale" : "2x"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"idiom" : "iphone",
|
||||||
|
"size" : "40x40",
|
||||||
|
"scale" : "3x"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"idiom" : "iphone",
|
||||||
|
"size" : "60x60",
|
||||||
|
"scale" : "2x"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"idiom" : "iphone",
|
||||||
|
"size" : "60x60",
|
||||||
|
"scale" : "3x"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"info" : {
|
||||||
|
"version" : 1,
|
||||||
|
"author" : "expo"
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"info" : {
|
"info" : {
|
||||||
"version" : 1,
|
"version" : 1,
|
||||||
"author" : "xcode"
|
"author" : "expo"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
21
example/ios/example/Images.xcassets/SplashScreen.imageset/Contents.json
vendored
Normal file
21
example/ios/example/Images.xcassets/SplashScreen.imageset/Contents.json
vendored
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
{
|
||||||
|
"images": [
|
||||||
|
{
|
||||||
|
"idiom": "universal",
|
||||||
|
"filename": "splashscreen.png",
|
||||||
|
"scale": "1x"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"idiom": "universal",
|
||||||
|
"scale": "2x"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"idiom": "universal",
|
||||||
|
"scale": "3x"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"info": {
|
||||||
|
"version": 1,
|
||||||
|
"author": "expo"
|
||||||
|
}
|
||||||
|
}
|
||||||
BIN
example/ios/example/Images.xcassets/SplashScreen.imageset/splashscreen.png
vendored
Normal file
BIN
example/ios/example/Images.xcassets/SplashScreen.imageset/splashscreen.png
vendored
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 9.1 KiB |
21
example/ios/example/Images.xcassets/SplashScreenBackground.imageset/Contents.json
vendored
Normal file
21
example/ios/example/Images.xcassets/SplashScreenBackground.imageset/Contents.json
vendored
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
{
|
||||||
|
"images": [
|
||||||
|
{
|
||||||
|
"idiom": "universal",
|
||||||
|
"filename": "background.png",
|
||||||
|
"scale": "1x"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"idiom": "universal",
|
||||||
|
"scale": "2x"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"idiom": "universal",
|
||||||
|
"scale": "3x"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"info": {
|
||||||
|
"version": 1,
|
||||||
|
"author": "expo"
|
||||||
|
}
|
||||||
|
}
|
||||||
BIN
example/ios/example/Images.xcassets/SplashScreenBackground.imageset/background.png
vendored
Normal file
BIN
example/ios/example/Images.xcassets/SplashScreenBackground.imageset/background.png
vendored
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 80 B |
@ -3,9 +3,7 @@
|
|||||||
<plist version="1.0">
|
<plist version="1.0">
|
||||||
<dict>
|
<dict>
|
||||||
<key>CFBundleDevelopmentRegion</key>
|
<key>CFBundleDevelopmentRegion</key>
|
||||||
<string>en</string>
|
<string>$(DEVELOPMENT_LANGUAGE)</string>
|
||||||
<key>CFBundleDisplayName</key>
|
|
||||||
<string>example</string>
|
|
||||||
<key>CFBundleExecutable</key>
|
<key>CFBundleExecutable</key>
|
||||||
<string>$(EXECUTABLE_NAME)</string>
|
<string>$(EXECUTABLE_NAME)</string>
|
||||||
<key>CFBundleIdentifier</key>
|
<key>CFBundleIdentifier</key>
|
||||||
@ -15,17 +13,19 @@
|
|||||||
<key>CFBundleName</key>
|
<key>CFBundleName</key>
|
||||||
<string>$(PRODUCT_NAME)</string>
|
<string>$(PRODUCT_NAME)</string>
|
||||||
<key>CFBundlePackageType</key>
|
<key>CFBundlePackageType</key>
|
||||||
<string>APPL</string>
|
<string>$(PRODUCT_BUNDLE_PACKAGE_TYPE)</string>
|
||||||
<key>CFBundleShortVersionString</key>
|
|
||||||
<string>1.0</string>
|
|
||||||
<key>CFBundleSignature</key>
|
<key>CFBundleSignature</key>
|
||||||
<string>????</string>
|
<string>????</string>
|
||||||
|
<key>CFBundleShortVersionString</key>
|
||||||
|
<string>1.0</string>
|
||||||
<key>CFBundleVersion</key>
|
<key>CFBundleVersion</key>
|
||||||
<string>1</string>
|
<string>1</string>
|
||||||
<key>LSRequiresIPhoneOS</key>
|
<key>LSRequiresIPhoneOS</key>
|
||||||
<true/>
|
<true/>
|
||||||
<key>NSAppTransportSecurity</key>
|
<key>NSAppTransportSecurity</key>
|
||||||
<dict>
|
<dict>
|
||||||
|
<key>NSAllowsArbitraryLoads</key>
|
||||||
|
<true/>
|
||||||
<key>NSExceptionDomains</key>
|
<key>NSExceptionDomains</key>
|
||||||
<dict>
|
<dict>
|
||||||
<key>localhost</key>
|
<key>localhost</key>
|
||||||
@ -35,10 +35,8 @@
|
|||||||
</dict>
|
</dict>
|
||||||
</dict>
|
</dict>
|
||||||
</dict>
|
</dict>
|
||||||
<key>NSLocationWhenInUseUsageDescription</key>
|
|
||||||
<string></string>
|
|
||||||
<key>UILaunchStoryboardName</key>
|
<key>UILaunchStoryboardName</key>
|
||||||
<string>LaunchScreen</string>
|
<string>SplashScreen</string>
|
||||||
<key>UIRequiredDeviceCapabilities</key>
|
<key>UIRequiredDeviceCapabilities</key>
|
||||||
<array>
|
<array>
|
||||||
<string>armv7</string>
|
<string>armv7</string>
|
||||||
@ -51,5 +49,7 @@
|
|||||||
</array>
|
</array>
|
||||||
<key>UIViewControllerBasedStatusBarAppearance</key>
|
<key>UIViewControllerBasedStatusBarAppearance</key>
|
||||||
<false/>
|
<false/>
|
||||||
|
<key>UIStatusBarStyle</key>
|
||||||
|
<string>UIStatusBarStyleDefault</string>
|
||||||
</dict>
|
</dict>
|
||||||
</plist>
|
</plist>
|
||||||
91
example/ios/example/SplashScreen.storyboard
Normal file
91
example/ios/example/SplashScreen.storyboard
Normal file
@ -0,0 +1,91 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<document
|
||||||
|
type="com.apple.InterfaceBuilder3.CocoaTouch.Storyboard.XIB"
|
||||||
|
version="3.0"
|
||||||
|
toolsVersion="16096"
|
||||||
|
targetRuntime="iOS.CocoaTouch"
|
||||||
|
propertyAccessControl="none"
|
||||||
|
useAutolayout="YES"
|
||||||
|
launchScreen="YES"
|
||||||
|
useTraitCollections="YES"
|
||||||
|
useSafeAreas="YES"
|
||||||
|
colorMatched="YES"
|
||||||
|
initialViewController="EXPO-VIEWCONTROLLER-1"
|
||||||
|
>
|
||||||
|
<device id="retina5_5" orientation="portrait" appearance="light"/>
|
||||||
|
<dependencies>
|
||||||
|
<deployment identifier="iOS"/>
|
||||||
|
<plugIn identifier="com.apple.InterfaceBuilder.IBCocoaTouchPlugin" version="16087"/>
|
||||||
|
<capability name="Safe area layout guides" minToolsVersion="9.0"/>
|
||||||
|
<capability name="documents saved in the Xcode 8 format" minToolsVersion="8.0"/>
|
||||||
|
</dependencies>
|
||||||
|
<scenes>
|
||||||
|
<!--View Controller-->
|
||||||
|
<scene sceneID="EXPO-SCENE-1">
|
||||||
|
<objects>
|
||||||
|
<viewController
|
||||||
|
storyboardIdentifier="SplashScreenViewController"
|
||||||
|
id="EXPO-VIEWCONTROLLER-1"
|
||||||
|
sceneMemberID="viewController"
|
||||||
|
>
|
||||||
|
<view
|
||||||
|
key="view"
|
||||||
|
userInteractionEnabled="NO"
|
||||||
|
contentMode="scaleToFill"
|
||||||
|
insetsLayoutMarginsFromSafeArea="NO"
|
||||||
|
id="EXPO-ContainerView"
|
||||||
|
userLabel="ContainerView"
|
||||||
|
>
|
||||||
|
<rect key="frame" x="0.0" y="0.0" width="414" height="736"/>
|
||||||
|
<autoresizingMask key="autoresizingMask" flexibleMaxX="YES" flexibleMaxY="YES"/>
|
||||||
|
<subviews>
|
||||||
|
<imageView
|
||||||
|
userInteractionEnabled="NO"
|
||||||
|
contentMode="scaleAspectFill"
|
||||||
|
horizontalHuggingPriority="251"
|
||||||
|
verticalHuggingPriority="251"
|
||||||
|
insetsLayoutMarginsFromSafeArea="NO"
|
||||||
|
image="SplashScreenBackground"
|
||||||
|
translatesAutoresizingMaskIntoConstraints="NO"
|
||||||
|
id="EXPO-SplashScreenBackground"
|
||||||
|
userLabel="SplashScreenBackground"
|
||||||
|
>
|
||||||
|
<rect key="frame" x="0.0" y="0.0" width="414" height="736"/>
|
||||||
|
</imageView>
|
||||||
|
<imageView
|
||||||
|
clipsSubviews="YES"
|
||||||
|
userInteractionEnabled="NO"
|
||||||
|
contentMode="scaleAspectFit"
|
||||||
|
horizontalHuggingPriority="251"
|
||||||
|
verticalHuggingPriority="251"
|
||||||
|
translatesAutoresizingMaskIntoConstraints="NO"
|
||||||
|
image="SplashScreen"
|
||||||
|
id="EXPO-SplashScreen"
|
||||||
|
userLabel="SplashScreen"
|
||||||
|
>
|
||||||
|
<rect key="frame" x="0.0" y="0.0" width="414" height="736"/>
|
||||||
|
</imageView>
|
||||||
|
</subviews>
|
||||||
|
<constraints>
|
||||||
|
<constraint firstItem="EXPO-SplashScreenBackground" firstAttribute="top" secondItem="EXPO-ContainerView" secondAttribute="top" id="1gX-mQ-vu6"/>
|
||||||
|
<constraint firstItem="EXPO-SplashScreenBackground" firstAttribute="leading" secondItem="EXPO-ContainerView" secondAttribute="leading" id="6tX-OG-Sck"/>
|
||||||
|
<constraint firstItem="EXPO-SplashScreenBackground" firstAttribute="trailing" secondItem="EXPO-ContainerView" secondAttribute="trailing" id="ABX-8g-7v4"/>
|
||||||
|
<constraint firstItem="EXPO-SplashScreenBackground" firstAttribute="bottom" secondItem="EXPO-ContainerView" secondAttribute="bottom" id="jkI-2V-eW5"/>
|
||||||
|
<constraint firstItem="EXPO-SplashScreen" firstAttribute="top" secondItem="EXPO-ContainerView" secondAttribute="top" id="2VS-Uz-0LU"/>
|
||||||
|
<constraint firstItem="EXPO-SplashScreen" firstAttribute="leading" secondItem="EXPO-ContainerView" secondAttribute="leading" id="LhH-Ei-DKo"/>
|
||||||
|
<constraint firstItem="EXPO-SplashScreen" firstAttribute="trailing" secondItem="EXPO-ContainerView" secondAttribute="trailing" id="I6l-TP-6fn"/>
|
||||||
|
<constraint firstItem="EXPO-SplashScreen" firstAttribute="bottom" secondItem="EXPO-ContainerView" secondAttribute="bottom" id="nbp-HC-eaG"/>
|
||||||
|
</constraints>
|
||||||
|
<viewLayoutGuide key="safeArea" id="Rmq-lb-GrQ"/>
|
||||||
|
</view>
|
||||||
|
</viewController>
|
||||||
|
<placeholder placeholderIdentifier="IBFirstResponder" id="EXPO-PLACEHOLDER-1" userLabel="First Responder" sceneMemberID="firstResponder"/>
|
||||||
|
</objects>
|
||||||
|
<point key="canvasLocation" x="140.625" y="129.4921875"/>
|
||||||
|
</scene>
|
||||||
|
</scenes>
|
||||||
|
<resources>
|
||||||
|
<image name="SplashScreen" width="414" height="736"/>
|
||||||
|
<image name="SplashScreenBackground" width="1" height="1"/>
|
||||||
|
</resources>
|
||||||
|
</document>
|
||||||
@ -2,7 +2,9 @@
|
|||||||
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
||||||
<plist version="1.0">
|
<plist version="1.0">
|
||||||
<dict>
|
<dict>
|
||||||
<key>IDEDidComputeMac32BitWarning</key>
|
<key>EXUpdatesSDKVersion</key>
|
||||||
<true/>
|
<string>YOUR-APP-SDK-VERSION-HERE</string>
|
||||||
|
<key>EXUpdatesURL</key>
|
||||||
|
<string>YOUR-APP-URL-HERE</string>
|
||||||
</dict>
|
</dict>
|
||||||
</plist>
|
</plist>
|
||||||
@ -2,9 +2,9 @@
|
|||||||
|
|
||||||
#import "AppDelegate.h"
|
#import "AppDelegate.h"
|
||||||
|
|
||||||
int main(int argc, char *argv[])
|
int main(int argc, char * argv[]) {
|
||||||
{
|
|
||||||
@autoreleasepool {
|
@autoreleasepool {
|
||||||
return UIApplicationMain(argc, argv, nil, NSStringFromClass([AppDelegate class]));
|
return UIApplicationMain(argc, argv, nil, NSStringFromClass([AppDelegate class]));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1,40 +1,29 @@
|
|||||||
const path = require('path');
|
// Learn more https://docs.expo.io/guides/customizing-metro
|
||||||
const escape = require('escape-string-regexp');
|
const { getDefaultConfig } = require('expo/metro-config');
|
||||||
const exclusionList = require('metro-config/src/defaults/exclusionList');
|
const exclusionList = require('metro-config/src/defaults/exclusionList');
|
||||||
|
|
||||||
|
const path = require('path');
|
||||||
const pak = require('../package.json');
|
const pak = require('../package.json');
|
||||||
|
|
||||||
const root = path.resolve(__dirname, '..');
|
const root = path.resolve(__dirname, '..');
|
||||||
|
|
||||||
const modules = Object.keys({
|
const modules = Object.keys({
|
||||||
...pak.peerDependencies,
|
...pak.peerDependencies,
|
||||||
});
|
});
|
||||||
|
|
||||||
module.exports = {
|
let config = getDefaultConfig(__dirname);
|
||||||
projectRoot: __dirname,
|
config.projectRoot = __dirname;
|
||||||
watchFolders: [root],
|
config.watchFolders = [root];
|
||||||
|
|
||||||
// We need to make sure that only one version is loaded for peerDependencies
|
config.resolver = {
|
||||||
// So we block them at the root, and alias them to the versions in example's node_modules
|
blacklistRE: exclusionList(
|
||||||
resolver: {
|
modules.map(
|
||||||
blacklistRE: exclusionList(
|
(m) => new RegExp(`^${escape(path.join(root, 'node_modules', m))}\\/.*$`)
|
||||||
modules.map(
|
)
|
||||||
(m) =>
|
),
|
||||||
new RegExp(`^${escape(path.join(root, 'node_modules', m))}\\/.*$`)
|
extraNodeModules: modules.reduce((acc, name) => {
|
||||||
)
|
acc[name] = path.join(__dirname, 'node_modules', name);
|
||||||
),
|
return acc;
|
||||||
|
}, {}),
|
||||||
extraNodeModules: modules.reduce((acc, name) => {
|
|
||||||
acc[name] = path.join(__dirname, 'node_modules', name);
|
|
||||||
return acc;
|
|
||||||
}, {}),
|
|
||||||
},
|
|
||||||
|
|
||||||
transformer: {
|
|
||||||
getTransformOptions: async () => ({
|
|
||||||
transform: {
|
|
||||||
experimentalImportSupport: false,
|
|
||||||
inlineRequires: true,
|
|
||||||
},
|
|
||||||
}),
|
|
||||||
},
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
module.exports = config;
|
||||||
|
|||||||
19388
example/package-lock.json
generated
Normal file
19388
example/package-lock.json
generated
Normal file
File diff suppressed because it is too large
Load Diff
@ -2,24 +2,24 @@
|
|||||||
"name": "@waku/react-native-example",
|
"name": "@waku/react-native-example",
|
||||||
"description": "Example app for @waku/react-native",
|
"description": "Example app for @waku/react-native",
|
||||||
"version": "0.0.1",
|
"version": "0.0.1",
|
||||||
"private": true,
|
"main": "index.js",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"android": "react-native run-android",
|
"start": "expo start --dev-client",
|
||||||
"ios": "react-native run-ios",
|
"android": "expo run:android",
|
||||||
"start": "react-native start",
|
"ios": "expo run:ios",
|
||||||
"pods": "pod-install --quiet",
|
"web": "expo start --web",
|
||||||
"postinstall": "patch-package"
|
"pods": "npx pod-install"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"react": "17.0.2",
|
"@waku/react-native": "file:../",
|
||||||
"react-native": "0.68.2"
|
"expo": "~47.0.8",
|
||||||
|
"expo-splash-screen": "~0.17.5",
|
||||||
|
"expo-status-bar": "~1.4.2",
|
||||||
|
"react": "18.1.0",
|
||||||
|
"react-native": "0.70.5"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@babel/core": "^7.12.10",
|
"@babel/core": "^7.12.9"
|
||||||
"@babel/runtime": "^7.12.5",
|
},
|
||||||
"babel-plugin-module-resolver": "^4.1.0",
|
"private": true
|
||||||
"metro-react-native-babel-preset": "^0.67.0",
|
|
||||||
"patch-package": "^6.4.7",
|
|
||||||
"postinstall-postinstall": "^2.1.0"
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,9 +0,0 @@
|
|||||||
const path = require('path');
|
|
||||||
|
|
||||||
module.exports = {
|
|
||||||
dependencies: {
|
|
||||||
'@waku/react-native': {
|
|
||||||
root: path.join(__dirname, '..'),
|
|
||||||
},
|
|
||||||
},
|
|
||||||
};
|
|
||||||
@ -1,98 +0,0 @@
|
|||||||
import * as React from 'react';
|
|
||||||
|
|
||||||
import { StyleSheet, View, Text } from 'react-native';
|
|
||||||
import { defaultPubsubTopic, newNode, start, isStarted, stop, peerID, relayEnoughPeers, listenAddresses, connect, peerCnt, peers, relayPublish, relayUnsubscribe, relaySubscribe, WakuMessage, onMessage, StoreQuery, storeQuery, Config, FilterSubscription, ContentFilter, filterSubscribe} from '@waku/react-native';
|
|
||||||
|
|
||||||
export default function App() {
|
|
||||||
const [result, setResult] = React.useState<string | undefined>();
|
|
||||||
|
|
||||||
React.useEffect(() => {
|
|
||||||
(async () => {
|
|
||||||
const nodeStarted = await isStarted();
|
|
||||||
|
|
||||||
if (!nodeStarted) {
|
|
||||||
await newNode(null);
|
|
||||||
await start();
|
|
||||||
}
|
|
||||||
console.log("The node ID:", await peerID())
|
|
||||||
|
|
||||||
await relaySubscribe()
|
|
||||||
|
|
||||||
onMessage(event => {
|
|
||||||
console.log("Message Received: ", event)
|
|
||||||
})
|
|
||||||
|
|
||||||
console.log("enoughPeers?", await relayEnoughPeers())
|
|
||||||
console.log("addresses", await listenAddresses())
|
|
||||||
console.log("connecting...")
|
|
||||||
|
|
||||||
await connect("/dns4/node-01.ac-cn-hongkong-c.wakuv2.test.statusim.net/tcp/30303/p2p/16Uiu2HAkvWiyFsgRhuJEb9JfjYxEkoHLgnUQmr1N5mKWnYjxYRVm", 5000)
|
|
||||||
await connect("/dns4/node-01.do-ams3.wakuv2.test.statusim.net/tcp/30303/p2p/16Uiu2HAmPLe7Mzm8TsYUubgCAW1aJoeFScxrLj8ppHFivPo97bUZ", 5000)
|
|
||||||
|
|
||||||
console.log("connected!")
|
|
||||||
|
|
||||||
console.log("PeerCNT", await peerCnt())
|
|
||||||
console.log("Peers", await peers())
|
|
||||||
|
|
||||||
let msg: WakuMessage = new WakuMessage()
|
|
||||||
msg.contentTopic = "ABC"
|
|
||||||
msg.payload = new Uint8Array([1, 2, 3, 4, 5])
|
|
||||||
msg.timestamp = Date.now();
|
|
||||||
msg.version = 0;
|
|
||||||
|
|
||||||
let messageID = await relayPublish(msg);
|
|
||||||
|
|
||||||
console.log("The messageID", messageID)
|
|
||||||
|
|
||||||
|
|
||||||
// TO RETRIEVE HISTORIC MESSAGES:
|
|
||||||
console.log("Retrieving messages from store node")
|
|
||||||
const query = new StoreQuery();
|
|
||||||
query.contentFilters.push(new ContentFilter("/toy-chat/2/luzhou/proto"))
|
|
||||||
const queryResult = await storeQuery(query, "16Uiu2HAkvWiyFsgRhuJEb9JfjYxEkoHLgnUQmr1N5mKWnYjxYRVm")
|
|
||||||
console.log(queryResult)
|
|
||||||
|
|
||||||
// USING FILTER INSTEAD OF RELAY:
|
|
||||||
// Instantiate the node passing these parameters:
|
|
||||||
// let config = new Config();
|
|
||||||
// config.relay = false;
|
|
||||||
// config.filter = true;
|
|
||||||
// newNode(config})
|
|
||||||
/*
|
|
||||||
const filterSubs = new FilterSubscription();
|
|
||||||
filterSubs.contentFilters.push(new ContentFilter("/toy-chat/2/luzhou/proto"))
|
|
||||||
await filterSubscribe(filterSubs, "16Uiu2HAkvWiyFsgRhuJEb9JfjYxEkoHLgnUQmr1N5mKWnYjxYRVm")
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// console.log("Unsubscribing and stopping node...")
|
|
||||||
|
|
||||||
// await relayUnsubscribe();
|
|
||||||
|
|
||||||
// await stop(); // TODO: This must be called only once
|
|
||||||
})();
|
|
||||||
|
|
||||||
defaultPubsubTopic().then(setResult);
|
|
||||||
}, []);
|
|
||||||
|
|
||||||
return (
|
|
||||||
<View style={styles.container}>
|
|
||||||
<Text>Result: {result}</Text>
|
|
||||||
</View>
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
const styles = StyleSheet.create({
|
|
||||||
container: {
|
|
||||||
flex: 1,
|
|
||||||
alignItems: 'center',
|
|
||||||
justifyContent: 'center',
|
|
||||||
},
|
|
||||||
box: {
|
|
||||||
width: 60,
|
|
||||||
height: 60,
|
|
||||||
marginVertical: 20,
|
|
||||||
},
|
|
||||||
});
|
|
||||||
4469
example/yarn.lock
4469
example/yarn.lock
File diff suppressed because it is too large
Load Diff
@ -1 +1 @@
|
|||||||
0.2.1
|
0.5.1
|
||||||
|
|||||||
@ -146,5 +146,11 @@ RCT_EXTERN_METHOD(filterUnsubscribe:(NSString *)filterJSON
|
|||||||
withResolver:(RCTPromiseResolveBlock)resolve
|
withResolver:(RCTPromiseResolveBlock)resolve
|
||||||
withRejecter:(RCTPromiseRejectBlock)reject)
|
withRejecter:(RCTPromiseRejectBlock)reject)
|
||||||
|
|
||||||
|
RCT_EXTERN_METHOD(dnsDiscovery:(NSString *)url
|
||||||
|
withNameserver:(NSString *)nameserver
|
||||||
|
withMs:(nonnull NSNumber *)ms
|
||||||
|
withResolver:(RCTPromiseResolveBlock)resolve
|
||||||
|
withRejecter:(RCTPromiseRejectBlock)reject)
|
||||||
|
|
||||||
|
|
||||||
@end
|
@end
|
||||||
|
|||||||
@ -177,4 +177,9 @@ class ReactNative: RCTEventEmitter {
|
|||||||
resolve(GowakuFilterUnsubscribe(filterJSON, ms))
|
resolve(GowakuFilterUnsubscribe(filterJSON, ms))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@objc(dnsDiscovery:withNameserver:withMs:withResolver:withRejecter:)
|
||||||
|
func dnsDiscovery(url: String, nameserver: String, ms: Int, resolve:RCTPromiseResolveBlock,reject:RCTPromiseRejectBlock) -> Void {
|
||||||
|
resolve(GowakuDnsDiscovery(url, nameserver, ms))
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,10 +1,6 @@
|
|||||||
pre-commit:
|
pre-commit:
|
||||||
parallel: true
|
parallel: true
|
||||||
commands:
|
commands:
|
||||||
lint:
|
|
||||||
files: git diff --name-only @{push}
|
|
||||||
glob: "*.{js,ts,jsx,tsx}"
|
|
||||||
run: npx eslint {files}
|
|
||||||
types:
|
types:
|
||||||
files: git diff --name-only @{push}
|
files: git diff --name-only @{push}
|
||||||
glob: "*.{js,ts, jsx, tsx}"
|
glob: "*.{js,ts, jsx, tsx}"
|
||||||
|
|||||||
31891
package-lock.json
generated
Normal file
31891
package-lock.json
generated
Normal file
File diff suppressed because it is too large
Load Diff
58
package.json
58
package.json
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@waku/react-native",
|
"name": "@waku/react-native",
|
||||||
"version": "0.0.5",
|
"version": "0.2.0",
|
||||||
"description": "Waku React Native",
|
"description": "Waku React Native",
|
||||||
"author": "Status Research & Development GMBH",
|
"author": "Status Research & Development GMBH",
|
||||||
"authors": [
|
"authors": [
|
||||||
@ -21,6 +21,8 @@
|
|||||||
"android",
|
"android",
|
||||||
"ios",
|
"ios",
|
||||||
"cpp",
|
"cpp",
|
||||||
|
"download-gowaku.sh",
|
||||||
|
"go-waku.VERSION",
|
||||||
"waku-react-native.podspec",
|
"waku-react-native.podspec",
|
||||||
"!lib/typescript/example",
|
"!lib/typescript/example",
|
||||||
"!android/build",
|
"!android/build",
|
||||||
@ -36,6 +38,7 @@
|
|||||||
"prepare": "bob build",
|
"prepare": "bob build",
|
||||||
"release": "release-it",
|
"release": "release-it",
|
||||||
"example": "yarn --cwd example",
|
"example": "yarn --cwd example",
|
||||||
|
"pods": "npx pod-install",
|
||||||
"bootstrap": "yarn example && yarn && yarn example pods"
|
"bootstrap": "yarn example && yarn && yarn example pods"
|
||||||
},
|
},
|
||||||
"keywords": [
|
"keywords": [
|
||||||
@ -54,31 +57,31 @@
|
|||||||
"registry": "https://registry.npmjs.org/"
|
"registry": "https://registry.npmjs.org/"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@arkweid/lefthook": "^0.7.7",
|
"@arkweid/lefthook": "^0.7.7",
|
||||||
"@babel/eslint-parser": "^7.18.2",
|
"@babel/eslint-parser": "^7.18.2",
|
||||||
"@commitlint/config-conventional": "^17.0.2",
|
"@commitlint/config-conventional": "^17.0.2",
|
||||||
"@react-native-community/eslint-config": "^3.0.2",
|
"@react-native-community/eslint-config": "^3.0.2",
|
||||||
"@release-it/conventional-changelog": "^5.0.0",
|
"@release-it/conventional-changelog": "^5.0.0",
|
||||||
"@types/base-64": "^1.0.0",
|
"@types/base-64": "^1.0.0",
|
||||||
"@types/jest": "^28.1.2",
|
"@types/jest": "^28.1.2",
|
||||||
"@types/react": "~17.0.21",
|
"@types/react": "~17.0.21",
|
||||||
"@types/react-native": "0.68.0",
|
"@types/react-native": "0.68.0",
|
||||||
"commitlint": "^17.0.2",
|
"commitlint": "^17.0.2",
|
||||||
"eslint": "^8.4.1",
|
"eslint": "^8.4.1",
|
||||||
"eslint-config-prettier": "^8.5.0",
|
"eslint-config-prettier": "^8.5.0",
|
||||||
"eslint-plugin-prettier": "^4.0.0",
|
"eslint-plugin-prettier": "^4.0.0",
|
||||||
"jest": "^28.1.1",
|
"jest": "^28.1.1",
|
||||||
"pod-install": "^0.1.0",
|
"pod-install": "^0.1.0",
|
||||||
"prettier": "^2.0.5",
|
"prettier": "^2.0.5",
|
||||||
"react": "17.0.2",
|
"react": "17.0.2",
|
||||||
"react-native": "0.68.2",
|
"react-native": "0.68.2",
|
||||||
"react-native-builder-bob": "^0.18.3",
|
"react-native-builder-bob": "^0.18.3",
|
||||||
"release-it": "^15.0.0",
|
"release-it": "^15.0.0",
|
||||||
"typescript": "^4.5.2"
|
"typescript": "^4.5.2"
|
||||||
},
|
},
|
||||||
"resolutions": {
|
"resolutions": {
|
||||||
"@types/react": "17.0.21"
|
"@types/react": "17.0.21"
|
||||||
},
|
},
|
||||||
"peerDependencies": {
|
"peerDependencies": {
|
||||||
"react": "*",
|
"react": "*",
|
||||||
"react-native": "*"
|
"react-native": "*"
|
||||||
@ -158,6 +161,7 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"base-64": "^1.0.0"
|
"big-integer": "^1.6.51",
|
||||||
|
"buffer": "^6.0.3"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
547
src/index.tsx
547
src/index.tsx
@ -1,5 +1,6 @@
|
|||||||
import { NativeModules, Platform, NativeEventEmitter} from 'react-native';
|
import { NativeModules, Platform, NativeEventEmitter } from 'react-native';
|
||||||
import {decode, encode} from 'base-64'
|
import bigInt from 'big-integer';
|
||||||
|
import { Buffer } from 'buffer';
|
||||||
|
|
||||||
const LINKING_ERROR =
|
const LINKING_ERROR =
|
||||||
`The package '@waku/react-native' doesn't seem to be linked. Make sure: \n\n` +
|
`The package '@waku/react-native' doesn't seem to be linked. Make sure: \n\n` +
|
||||||
@ -7,7 +8,9 @@ const LINKING_ERROR =
|
|||||||
'- You rebuilt the app after installing the package\n' +
|
'- You rebuilt the app after installing the package\n' +
|
||||||
'- You are not using Expo managed workflow\n';
|
'- You are not using Expo managed workflow\n';
|
||||||
|
|
||||||
const ReactNative = NativeModules.ReactNative ? NativeModules.ReactNative : new Proxy(
|
const ReactNative = NativeModules.ReactNative
|
||||||
|
? NativeModules.ReactNative
|
||||||
|
: new Proxy(
|
||||||
{},
|
{},
|
||||||
{
|
{
|
||||||
get() {
|
get() {
|
||||||
@ -16,27 +19,25 @@ const ReactNative = NativeModules.ReactNative ? NativeModules.ReactNative : ne
|
|||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
export function multiply(a: number, b: number): Promise<number> {
|
const OneMillion = bigInt(1000000);
|
||||||
return ReactNative.multiply(a, b);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
export class WakuMessage {
|
export class WakuMessage {
|
||||||
payload: Uint8Array = new Uint8Array();
|
payload: Uint8Array = new Uint8Array();
|
||||||
contentTopic: String | null = "";
|
contentTopic: String | null = '';
|
||||||
version: Number | null = 0;
|
version: Number | null = 0;
|
||||||
timestamp: Number | null = null;
|
timestamp?: Date = undefined;
|
||||||
|
|
||||||
toJSON(){
|
toJSON() {
|
||||||
const b64encoded = encode(String.fromCharCode(...this.payload));
|
return {
|
||||||
return {
|
contentTopic: this.contentTopic,
|
||||||
contentTopic: this.contentTopic,
|
version: this.version,
|
||||||
version: this.version,
|
timestamp: this.timestamp
|
||||||
timestamp: this.timestamp,
|
? bigInt(this.timestamp.valueOf()).multiply(OneMillion).toString(10)
|
||||||
payload: b64encoded
|
: 0,
|
||||||
}
|
payload: Buffer.from(this.payload).toString('base64'),
|
||||||
}
|
};
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
var eventEmitter = new NativeEventEmitter(NativeModules.ReactNative);
|
var eventEmitter = new NativeEventEmitter(NativeModules.ReactNative);
|
||||||
|
|
||||||
@ -44,28 +45,36 @@ var eventEmitter = new NativeEventEmitter(NativeModules.ReactNative);
|
|||||||
* Execute function each time a message is received
|
* Execute function each time a message is received
|
||||||
* @param cb callback to be eecuted
|
* @param cb callback to be eecuted
|
||||||
*/
|
*/
|
||||||
export function onMessage(cb: (arg0:any) => void) {
|
export function onMessage(cb: (arg0: any) => void) {
|
||||||
eventEmitter.addListener("message", event => {
|
eventEmitter.addListener('message', (event) => {
|
||||||
let signal = JSON.parse(event.signal);
|
let signal = JSON.parse(event.signal);
|
||||||
let msg = signal.event.wakuMessage;
|
let msg = signal.event.wakuMessage;
|
||||||
signal.event.wakuMessage = new WakuMessage();
|
signal.event.wakuMessage = new WakuMessage();
|
||||||
signal.event.wakuMessage.timestamp = msg.timestamp;
|
signal.event.wakuMessage.timestamp =
|
||||||
|
msg.timestamp != 0
|
||||||
|
? new Date(bigInt(msg.timestamp).divide(OneMillion).toJSNumber())
|
||||||
|
: undefined;
|
||||||
signal.event.wakuMessage.version = msg.version || 0;
|
signal.event.wakuMessage.version = msg.version || 0;
|
||||||
signal.event.wakuMessage.contentTopic = msg.contentTopic;
|
signal.event.wakuMessage.contentTopic = msg.contentTopic;
|
||||||
signal.event.wakuMessage.payload = new Uint8Array(decode(msg.payload ?? []).split("").map((c:any) => c.charCodeAt(0)));
|
signal.event.wakuMessage.payload = Buffer.from(msg.payload || [], 'base64');
|
||||||
cb(signal.event);
|
cb(signal.event);
|
||||||
})
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
export class Config {
|
export class Config {
|
||||||
host: String | null = null
|
host: String | null = null; // IP address. Default 0.0.0.0
|
||||||
port: Number | null = null
|
port: Number | null = null; // TCP port to listen. Default 60000. Use 0 for random
|
||||||
advertiseAddr: String | null = null
|
advertiseAddr: String | null = null; // Advertise custom multiaddress
|
||||||
nodeKey: String | null = null
|
nodeKey: String | null = null; // secp256k1 private key. Default random
|
||||||
keepAliveInterval: Number | null = null
|
keepAliveInterval: Number | null = null; // interval in seconds to ping all peers
|
||||||
relay: Boolean | null = null
|
relay: Boolean | null = null; // enable waku relay
|
||||||
filter: Boolean | null = null
|
relayTopics: Array<String> = []; // array of pubsub topics that WakuRelay will automatically subscribe to when the node starts
|
||||||
minPeersToPublish: Number | null = null
|
minPeersToPublish: Number | null = null;
|
||||||
|
filter: Boolean | null = null; // enable waku filter
|
||||||
|
discv5: Boolean | null = null; // enable discv5
|
||||||
|
discV5BootstrapNodes: Array<String> = []; // array of bootstrap nodes ENR
|
||||||
|
discV5UDPPort: Number | null = null; // UDP port for DiscoveryV5
|
||||||
|
logLevel: String | null = null; // Set the log level. Default `INFO`. Allowed values "DEBUG", "INFO", "WARN", "ERROR", "DPANIC", "PANIC", "FATAL"
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -74,8 +83,10 @@ export class Config {
|
|||||||
*/
|
*/
|
||||||
export function newNode(config: Config | null): Promise<void> {
|
export function newNode(config: Config | null): Promise<void> {
|
||||||
return new Promise<void>(async (resolve, reject) => {
|
return new Promise<void>(async (resolve, reject) => {
|
||||||
let response = JSON.parse(await ReactNative.newNode(config ? JSON.stringify(config) : ""));
|
let response = JSON.parse(
|
||||||
if(response.error){
|
await ReactNative.newNode(config ? JSON.stringify(config) : '')
|
||||||
|
);
|
||||||
|
if (response.error) {
|
||||||
reject(response.error);
|
reject(response.error);
|
||||||
} else {
|
} else {
|
||||||
resolve();
|
resolve();
|
||||||
@ -89,7 +100,7 @@ export function newNode(config: Config | null): Promise<void> {
|
|||||||
export function start(): Promise<void> {
|
export function start(): Promise<void> {
|
||||||
return new Promise<void>(async (resolve, reject) => {
|
return new Promise<void>(async (resolve, reject) => {
|
||||||
let response = JSON.parse(await ReactNative.start());
|
let response = JSON.parse(await ReactNative.start());
|
||||||
if(response.error){
|
if (response.error) {
|
||||||
reject(response.error);
|
reject(response.error);
|
||||||
} else {
|
} else {
|
||||||
resolve();
|
resolve();
|
||||||
@ -103,7 +114,7 @@ export function start(): Promise<void> {
|
|||||||
export function stop(): Promise<void> {
|
export function stop(): Promise<void> {
|
||||||
return new Promise<void>(async (resolve, reject) => {
|
return new Promise<void>(async (resolve, reject) => {
|
||||||
let response = JSON.parse(await ReactNative.stop());
|
let response = JSON.parse(await ReactNative.stop());
|
||||||
if(response.error){
|
if (response.error) {
|
||||||
reject(response.error);
|
reject(response.error);
|
||||||
} else {
|
} else {
|
||||||
resolve();
|
resolve();
|
||||||
@ -118,7 +129,7 @@ export function stop(): Promise<void> {
|
|||||||
export function isStarted(): Promise<Boolean> {
|
export function isStarted(): Promise<Boolean> {
|
||||||
return new Promise<Boolean>(async (resolve, reject) => {
|
return new Promise<Boolean>(async (resolve, reject) => {
|
||||||
let response = JSON.parse(await ReactNative.isStarted());
|
let response = JSON.parse(await ReactNative.isStarted());
|
||||||
if(response.error){
|
if (response.error) {
|
||||||
reject(response.error);
|
reject(response.error);
|
||||||
} else {
|
} else {
|
||||||
resolve(response.result);
|
resolve(response.result);
|
||||||
@ -133,7 +144,7 @@ export function isStarted(): Promise<Boolean> {
|
|||||||
export function peerID(): Promise<string> {
|
export function peerID(): Promise<string> {
|
||||||
return new Promise<string>(async (resolve, reject) => {
|
return new Promise<string>(async (resolve, reject) => {
|
||||||
let response = JSON.parse(await ReactNative.peerID());
|
let response = JSON.parse(await ReactNative.peerID());
|
||||||
if(response.error){
|
if (response.error) {
|
||||||
reject(response.error);
|
reject(response.error);
|
||||||
} else {
|
} else {
|
||||||
resolve(response.result);
|
resolve(response.result);
|
||||||
@ -148,11 +159,20 @@ export function peerID(): Promise<string> {
|
|||||||
* @param timeoutMs Timeout value in milliseconds to execute the call. If the function takes longer than this value, the execution will be canceled and an error returned
|
* @param timeoutMs Timeout value in milliseconds to execute the call. If the function takes longer than this value, the execution will be canceled and an error returned
|
||||||
* @returns string containing the message id
|
* @returns string containing the message id
|
||||||
*/
|
*/
|
||||||
export function relayPublish(msg: WakuMessage, pubsubTopic: String = "", timeoutMs: Number = 0): Promise<string> {
|
export function relayPublish(
|
||||||
|
msg: WakuMessage,
|
||||||
|
pubsubTopic: String = '',
|
||||||
|
timeoutMs: Number = 0
|
||||||
|
): Promise<string> {
|
||||||
return new Promise<string>(async (resolve, reject) => {
|
return new Promise<string>(async (resolve, reject) => {
|
||||||
let messageJSON = JSON.stringify(msg)
|
let messageJSON = JSON.stringify(msg).replace(
|
||||||
let response = JSON.parse(await ReactNative.relayPublish(messageJSON, pubsubTopic, timeoutMs));
|
/"timestamp":"([0-9]+)"/,
|
||||||
if(response.error){
|
`"timestamp":$1`
|
||||||
|
);
|
||||||
|
let response = JSON.parse(
|
||||||
|
await ReactNative.relayPublish(messageJSON, pubsubTopic, timeoutMs)
|
||||||
|
);
|
||||||
|
if (response.error) {
|
||||||
reject(response.error);
|
reject(response.error);
|
||||||
} else {
|
} else {
|
||||||
resolve(response.result);
|
resolve(response.result);
|
||||||
@ -169,11 +189,25 @@ export function relayPublish(msg: WakuMessage, pubsubTopic: String = "", timeout
|
|||||||
* @param timeoutMs Timeout value in milliseconds to execute the call. If the function takes longer than this value, the execution will be canceled and an error returned
|
* @param timeoutMs Timeout value in milliseconds to execute the call. If the function takes longer than this value, the execution will be canceled and an error returned
|
||||||
* @returns string containing the message id
|
* @returns string containing the message id
|
||||||
*/
|
*/
|
||||||
export function relayPublishEncodeAsymmetric(msg: WakuMessage, publicKey: String, optionalSigningKey: String = "", pubsubTopic: String = "", timeoutMs: Number = 0): Promise<string> {
|
export function relayPublishEncodeAsymmetric(
|
||||||
|
msg: WakuMessage,
|
||||||
|
publicKey: String,
|
||||||
|
optionalSigningKey: String = '',
|
||||||
|
pubsubTopic: String = '',
|
||||||
|
timeoutMs: Number = 0
|
||||||
|
): Promise<string> {
|
||||||
return new Promise<string>(async (resolve, reject) => {
|
return new Promise<string>(async (resolve, reject) => {
|
||||||
let messageJSON = JSON.stringify(msg)
|
let messageJSON = JSON.stringify(msg);
|
||||||
let response = JSON.parse(await ReactNative.relayPublishEncodeAsymmetric(messageJSON, pubsubTopic, publicKey, optionalSigningKey, timeoutMs));
|
let response = JSON.parse(
|
||||||
if(response.error){
|
await ReactNative.relayPublishEncodeAsymmetric(
|
||||||
|
messageJSON,
|
||||||
|
pubsubTopic,
|
||||||
|
publicKey,
|
||||||
|
optionalSigningKey,
|
||||||
|
timeoutMs
|
||||||
|
)
|
||||||
|
);
|
||||||
|
if (response.error) {
|
||||||
reject(response.error);
|
reject(response.error);
|
||||||
} else {
|
} else {
|
||||||
resolve(response.result);
|
resolve(response.result);
|
||||||
@ -190,11 +224,25 @@ export function relayPublishEncodeAsymmetric(msg: WakuMessage, publicKey: String
|
|||||||
* @param timeoutMs Timeout value in milliseconds to execute the call. If the function takes longer than this value, the execution will be canceled and an error returned
|
* @param timeoutMs Timeout value in milliseconds to execute the call. If the function takes longer than this value, the execution will be canceled and an error returned
|
||||||
* @returns string containing the message id
|
* @returns string containing the message id
|
||||||
*/
|
*/
|
||||||
export function relayPublishEncodeSymmetric(msg: WakuMessage, symmetricKey: String, optionalSigningKey: String = "", pubsubTopic: String = "", timeoutMs: Number = 0): Promise<string> {
|
export function relayPublishEncodeSymmetric(
|
||||||
|
msg: WakuMessage,
|
||||||
|
symmetricKey: String,
|
||||||
|
optionalSigningKey: String = '',
|
||||||
|
pubsubTopic: String = '',
|
||||||
|
timeoutMs: Number = 0
|
||||||
|
): Promise<string> {
|
||||||
return new Promise<string>(async (resolve, reject) => {
|
return new Promise<string>(async (resolve, reject) => {
|
||||||
let messageJSON = JSON.stringify(msg)
|
let messageJSON = JSON.stringify(msg);
|
||||||
let response = JSON.parse(await ReactNative.relayPublishEncodeAsymmetric(messageJSON, pubsubTopic, symmetricKey, optionalSigningKey, timeoutMs));
|
let response = JSON.parse(
|
||||||
if(response.error){
|
await ReactNative.relayPublishEncodeAsymmetric(
|
||||||
|
messageJSON,
|
||||||
|
pubsubTopic,
|
||||||
|
symmetricKey,
|
||||||
|
optionalSigningKey,
|
||||||
|
timeoutMs
|
||||||
|
)
|
||||||
|
);
|
||||||
|
if (response.error) {
|
||||||
reject(response.error);
|
reject(response.error);
|
||||||
} else {
|
} else {
|
||||||
resolve(response.result);
|
resolve(response.result);
|
||||||
@ -206,10 +254,10 @@ export function relayPublishEncodeSymmetric(msg: WakuMessage, symmetricKey: Stri
|
|||||||
* Subscribe to a Waku Relay pubsub topic to receive messages.
|
* Subscribe to a Waku Relay pubsub topic to receive messages.
|
||||||
* @param topic Pubsub topic to subscribe to.
|
* @param topic Pubsub topic to subscribe to.
|
||||||
*/
|
*/
|
||||||
export function relaySubscribe(topic: String = ""): Promise<void> {
|
export function relaySubscribe(topic: String = ''): Promise<void> {
|
||||||
return new Promise<void>(async (resolve, reject) => {
|
return new Promise<void>(async (resolve, reject) => {
|
||||||
let response = JSON.parse(await ReactNative.relaySubscribe(topic));
|
let response = JSON.parse(await ReactNative.relaySubscribe(topic));
|
||||||
if(response.error){
|
if (response.error) {
|
||||||
reject(response.error);
|
reject(response.error);
|
||||||
} else {
|
} else {
|
||||||
resolve(response.result);
|
resolve(response.result);
|
||||||
@ -232,7 +280,7 @@ export function defaultPubsubTopic(): Promise<String> {
|
|||||||
export function listenAddresses(): Promise<Array<String>> {
|
export function listenAddresses(): Promise<Array<String>> {
|
||||||
return new Promise<Array<string>>(async (resolve, reject) => {
|
return new Promise<Array<string>>(async (resolve, reject) => {
|
||||||
let response = JSON.parse(await ReactNative.listenAddresses());
|
let response = JSON.parse(await ReactNative.listenAddresses());
|
||||||
if(response.error){
|
if (response.error) {
|
||||||
reject(response.error);
|
reject(response.error);
|
||||||
} else {
|
} else {
|
||||||
resolve(response.result);
|
resolve(response.result);
|
||||||
@ -246,10 +294,15 @@ export function listenAddresses(): Promise<Array<String>> {
|
|||||||
* @param protocol protocol we expect the peer to support
|
* @param protocol protocol we expect the peer to support
|
||||||
* @returns peer ID as a base58 `string` of the peer that was added
|
* @returns peer ID as a base58 `string` of the peer that was added
|
||||||
*/
|
*/
|
||||||
export function addPeer(multiAddress: String, protocol: String): Promise<String> {
|
export function addPeer(
|
||||||
|
multiAddress: String,
|
||||||
|
protocol: String
|
||||||
|
): Promise<String> {
|
||||||
return new Promise<string>(async (resolve, reject) => {
|
return new Promise<string>(async (resolve, reject) => {
|
||||||
let response = JSON.parse(await ReactNative.addPeer(multiAddress, protocol));
|
let response = JSON.parse(
|
||||||
if(response.error){
|
await ReactNative.addPeer(multiAddress, protocol)
|
||||||
|
);
|
||||||
|
if (response.error) {
|
||||||
reject(response.error);
|
reject(response.error);
|
||||||
} else {
|
} else {
|
||||||
resolve(response.result);
|
resolve(response.result);
|
||||||
@ -262,10 +315,15 @@ export function addPeer(multiAddress: String, protocol: String): Promise<String>
|
|||||||
* @param multiAddress multiaddress to reach the peer being dialed
|
* @param multiAddress multiaddress to reach the peer being dialed
|
||||||
* @param timeoutMs Timeout value in milliseconds to execute the call. If the function takes longer than this value, the execution will be canceled and an error returned
|
* @param timeoutMs Timeout value in milliseconds to execute the call. If the function takes longer than this value, the execution will be canceled and an error returned
|
||||||
*/
|
*/
|
||||||
export function connect(multiAddress: String, timeoutMs: Number = 0): Promise<void> {
|
export function connect(
|
||||||
|
multiAddress: String,
|
||||||
|
timeoutMs: Number = 0
|
||||||
|
): Promise<void> {
|
||||||
return new Promise<void>(async (resolve, reject) => {
|
return new Promise<void>(async (resolve, reject) => {
|
||||||
let response = JSON.parse(await ReactNative.connect(multiAddress, timeoutMs));
|
let response = JSON.parse(
|
||||||
if(response.error){
|
await ReactNative.connect(multiAddress, timeoutMs)
|
||||||
|
);
|
||||||
|
if (response.error) {
|
||||||
reject(response.error);
|
reject(response.error);
|
||||||
} else {
|
} else {
|
||||||
resolve();
|
resolve();
|
||||||
@ -278,10 +336,15 @@ export function connect(multiAddress: String, timeoutMs: Number = 0): Promise<vo
|
|||||||
* @param peerID Peer ID to dial. The peer must be already known. It must have been added before with `addPeer` or previously dialed with `connect`
|
* @param peerID Peer ID to dial. The peer must be already known. It must have been added before with `addPeer` or previously dialed with `connect`
|
||||||
* @param timeoutMs Timeout value in milliseconds to execute the call. If the function takes longer than this value, the execution will be canceled and an error returned
|
* @param timeoutMs Timeout value in milliseconds to execute the call. If the function takes longer than this value, the execution will be canceled and an error returned
|
||||||
*/
|
*/
|
||||||
export function connectPeerID(peerID: String, timeoutMs: Number = 0): Promise<void> {
|
export function connectPeerID(
|
||||||
|
peerID: String,
|
||||||
|
timeoutMs: Number = 0
|
||||||
|
): Promise<void> {
|
||||||
return new Promise<void>(async (resolve, reject) => {
|
return new Promise<void>(async (resolve, reject) => {
|
||||||
let response = JSON.parse(await ReactNative.connectPeerID(peerID, timeoutMs));
|
let response = JSON.parse(
|
||||||
if(response.error){
|
await ReactNative.connectPeerID(peerID, timeoutMs)
|
||||||
|
);
|
||||||
|
if (response.error) {
|
||||||
reject(response.error);
|
reject(response.error);
|
||||||
} else {
|
} else {
|
||||||
resolve();
|
resolve();
|
||||||
@ -296,7 +359,7 @@ export function connectPeerID(peerID: String, timeoutMs: Number = 0): Promise<vo
|
|||||||
export function disconnect(peerID: String): Promise<void> {
|
export function disconnect(peerID: String): Promise<void> {
|
||||||
return new Promise<void>(async (resolve, reject) => {
|
return new Promise<void>(async (resolve, reject) => {
|
||||||
let response = JSON.parse(await ReactNative.disconnect(peerID));
|
let response = JSON.parse(await ReactNative.disconnect(peerID));
|
||||||
if(response.error){
|
if (response.error) {
|
||||||
reject(response.error);
|
reject(response.error);
|
||||||
} else {
|
} else {
|
||||||
resolve();
|
resolve();
|
||||||
@ -311,7 +374,7 @@ export function disconnect(peerID: String): Promise<void> {
|
|||||||
export function peerCnt(): Promise<Number> {
|
export function peerCnt(): Promise<Number> {
|
||||||
return new Promise<Number>(async (resolve, reject) => {
|
return new Promise<Number>(async (resolve, reject) => {
|
||||||
let response = JSON.parse(await ReactNative.peerCnt());
|
let response = JSON.parse(await ReactNative.peerCnt());
|
||||||
if(response.error){
|
if (response.error) {
|
||||||
reject(response.error);
|
reject(response.error);
|
||||||
} else {
|
} else {
|
||||||
resolve(response.result);
|
resolve(response.result);
|
||||||
@ -319,21 +382,40 @@ export function peerCnt(): Promise<Number> {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export class EncryptedPayload extends WakuMessage {
|
||||||
|
constructor(msg: WakuMessage) {
|
||||||
|
super();
|
||||||
|
this.contentTopic = msg.contentTopic;
|
||||||
|
this.version = msg.version;
|
||||||
|
this.timestamp = msg.timestamp;
|
||||||
|
this.payload = msg.payload;
|
||||||
|
}
|
||||||
|
|
||||||
|
toJSON() {
|
||||||
|
return {
|
||||||
|
contentTopic: this.contentTopic,
|
||||||
|
version: this.version,
|
||||||
|
timestamp: this.timestamp
|
||||||
|
? bigInt(this.timestamp.valueOf()).multiply(OneMillion).toJSNumber()
|
||||||
|
: 0,
|
||||||
|
payload: Buffer.from(Array.from(this.payload)).toString('base64'),
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
export class DecodedPayload {
|
export class DecodedPayload {
|
||||||
payload: Uint8Array = new Uint8Array();
|
payload: Uint8Array = new Uint8Array();
|
||||||
padding: Uint8Array = new Uint8Array();
|
padding: Uint8Array = new Uint8Array();
|
||||||
pubkey: String | null = "";
|
pubkey: String | null = '';
|
||||||
signature: String | null = "";
|
signature: String | null = '';
|
||||||
|
|
||||||
toJSON(){
|
toJSON() {
|
||||||
const b64payload = encode(String.fromCharCode(...this.payload));
|
|
||||||
const b64padding = encode(String.fromCharCode(...this.padding));
|
|
||||||
return {
|
return {
|
||||||
payload: b64payload,
|
payload: Buffer.from(this.payload).toString('base64'),
|
||||||
padding: b64padding,
|
padding: Buffer.from(this.padding).toString('base64'),
|
||||||
pubkey: this.pubkey,
|
pubkey: this.pubkey,
|
||||||
signature: this.signature,
|
signature: this.signature,
|
||||||
}
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -343,16 +425,22 @@ export class DecodedPayload {
|
|||||||
* @param symmetricKey 32 byte symmetric key hex encoded
|
* @param symmetricKey 32 byte symmetric key hex encoded
|
||||||
* @returns DecodedPayload
|
* @returns DecodedPayload
|
||||||
*/
|
*/
|
||||||
export function decodeSymmetric(msg: WakuMessage, symmetricKey: String): Promise<DecodedPayload> {
|
export function decodeSymmetric(
|
||||||
|
msg: WakuMessage,
|
||||||
|
symmetricKey: String
|
||||||
|
): Promise<DecodedPayload> {
|
||||||
return new Promise<DecodedPayload>(async (resolve, reject) => {
|
return new Promise<DecodedPayload>(async (resolve, reject) => {
|
||||||
let messageJSON = JSON.stringify(msg);
|
let message = new EncryptedPayload(msg);
|
||||||
let response = JSON.parse(await ReactNative.decodeSymmetric(messageJSON, symmetricKey));
|
let messageJSON = JSON.stringify(message);
|
||||||
if(response.error){
|
let response = JSON.parse(
|
||||||
|
await ReactNative.decodeSymmetric(messageJSON, symmetricKey)
|
||||||
|
);
|
||||||
|
if (response.error) {
|
||||||
reject(response.error);
|
reject(response.error);
|
||||||
} else {
|
} else {
|
||||||
let decodedPayload = new DecodedPayload();
|
let decodedPayload = new DecodedPayload();
|
||||||
decodedPayload.payload = new Uint8Array(atob(response.result.payload).split("").map(c => c.charCodeAt(0)));
|
decodedPayload.payload = Buffer.from(response.result.data, 'base64');
|
||||||
decodedPayload.padding = new Uint8Array(atob(response.result.padding).split("").map(c => c.charCodeAt(0)));
|
decodedPayload.padding = Buffer.from(response.result.padding, 'base64');
|
||||||
decodedPayload.pubkey = response.result.pubkey;
|
decodedPayload.pubkey = response.result.pubkey;
|
||||||
decodedPayload.signature = response.result.signature;
|
decodedPayload.signature = response.result.signature;
|
||||||
resolve(decodedPayload);
|
resolve(decodedPayload);
|
||||||
@ -366,16 +454,22 @@ export function decodeSymmetric(msg: WakuMessage, symmetricKey: String): Promise
|
|||||||
* @param privateKey secp256k1 private key hex encoded
|
* @param privateKey secp256k1 private key hex encoded
|
||||||
* @returns DecodedPayload
|
* @returns DecodedPayload
|
||||||
*/
|
*/
|
||||||
export function decodeAsymmetric(msg: WakuMessage, privateKey: String): Promise<DecodedPayload> {
|
export function decodeAsymmetric(
|
||||||
|
msg: WakuMessage,
|
||||||
|
privateKey: String
|
||||||
|
): Promise<DecodedPayload> {
|
||||||
return new Promise<DecodedPayload>(async (resolve, reject) => {
|
return new Promise<DecodedPayload>(async (resolve, reject) => {
|
||||||
let messageJSON = JSON.stringify(msg);
|
let message = new EncryptedPayload(msg);
|
||||||
let response = JSON.parse(await ReactNative.decodeSymmetric(messageJSON, privateKey));
|
let messageJSON = JSON.stringify(message);
|
||||||
if(response.error){
|
let response = JSON.parse(
|
||||||
|
await ReactNative.decodeAsymmetric(messageJSON, privateKey)
|
||||||
|
);
|
||||||
|
if (response.error) {
|
||||||
reject(response.error);
|
reject(response.error);
|
||||||
} else {
|
} else {
|
||||||
let decodedPayload = new DecodedPayload();
|
let decodedPayload = new DecodedPayload();
|
||||||
decodedPayload.payload = new Uint8Array(atob(response.result.payload).split("").map(c => c.charCodeAt(0)));
|
decodedPayload.payload = Buffer.from(response.result.data, 'base64');
|
||||||
decodedPayload.padding = new Uint8Array(atob(response.result.padding).split("").map(c => c.charCodeAt(0)));
|
decodedPayload.padding = Buffer.from(response.result.padding, 'base64');
|
||||||
decodedPayload.pubkey = response.result.pubkey;
|
decodedPayload.pubkey = response.result.pubkey;
|
||||||
decodedPayload.signature = response.result.signature;
|
decodedPayload.signature = response.result.signature;
|
||||||
resolve(decodedPayload);
|
resolve(decodedPayload);
|
||||||
@ -388,10 +482,10 @@ export function decodeAsymmetric(msg: WakuMessage, privateKey: String): Promise<
|
|||||||
* @param pubsubTopic Pubsub topic to verify. If not specified, it will verify the default pubsub topic
|
* @param pubsubTopic Pubsub topic to verify. If not specified, it will verify the default pubsub topic
|
||||||
* @returns boolean indicates whether there are enough peers
|
* @returns boolean indicates whether there are enough peers
|
||||||
*/
|
*/
|
||||||
export function relayEnoughPeers(pubsubTopic: String = ""): Promise<Boolean> {
|
export function relayEnoughPeers(pubsubTopic: String = ''): Promise<Boolean> {
|
||||||
return new Promise<Boolean>(async (resolve, reject) => {
|
return new Promise<Boolean>(async (resolve, reject) => {
|
||||||
let response = JSON.parse(await ReactNative.relayEnoughPeers(pubsubTopic));
|
let response = JSON.parse(await ReactNative.relayEnoughPeers(pubsubTopic));
|
||||||
if(response.error){
|
if (response.error) {
|
||||||
reject(response.error);
|
reject(response.error);
|
||||||
} else {
|
} else {
|
||||||
resolve(response.result);
|
resolve(response.result);
|
||||||
@ -403,10 +497,10 @@ export function relayEnoughPeers(pubsubTopic: String = ""): Promise<Boolean> {
|
|||||||
* Closes the pubsub subscription to a pubsub topic. No more messages will be received from this pubsub topic.
|
* Closes the pubsub subscription to a pubsub topic. No more messages will be received from this pubsub topic.
|
||||||
* @param pubsubTopic
|
* @param pubsubTopic
|
||||||
*/
|
*/
|
||||||
export function relayUnsubscribe(pubsubTopic: String = ""): Promise<void> {
|
export function relayUnsubscribe(pubsubTopic: String = ''): Promise<void> {
|
||||||
return new Promise<void>(async (resolve, reject) => {
|
return new Promise<void>(async (resolve, reject) => {
|
||||||
let response = JSON.parse(await ReactNative.relayUnsubscribe(pubsubTopic));
|
let response = JSON.parse(await ReactNative.relayUnsubscribe(pubsubTopic));
|
||||||
if(response.error){
|
if (response.error) {
|
||||||
reject(response.error);
|
reject(response.error);
|
||||||
} else {
|
} else {
|
||||||
resolve(response.result);
|
resolve(response.result);
|
||||||
@ -422,11 +516,26 @@ export function relayUnsubscribe(pubsubTopic: String = ""): Promise<void> {
|
|||||||
* @param timeoutMs Timeout value in milliseconds to execute the call. If the function takes longer than this value, the execution will be canceled and an error returned
|
* @param timeoutMs Timeout value in milliseconds to execute the call. If the function takes longer than this value, the execution will be canceled and an error returned
|
||||||
* @returns the message ID
|
* @returns the message ID
|
||||||
*/
|
*/
|
||||||
export function lightpushPublish(msg: WakuMessage, pubsubTopic: String = "", peerID: String = "", timeoutMs: Number = 0): Promise<string> {
|
export function lightpushPublish(
|
||||||
|
msg: WakuMessage,
|
||||||
|
pubsubTopic: String = '',
|
||||||
|
peerID: String = '',
|
||||||
|
timeoutMs: Number = 0
|
||||||
|
): Promise<string> {
|
||||||
return new Promise<string>(async (resolve, reject) => {
|
return new Promise<string>(async (resolve, reject) => {
|
||||||
let messageJSON = JSON.stringify(msg)
|
let messageJSON = JSON.stringify(msg).replace(
|
||||||
let response = JSON.parse(await ReactNative.lightpushPublish(messageJSON, pubsubTopic, peerID, timeoutMs));
|
/"timestamp":"([0-9]+)"/,
|
||||||
if(response.error){
|
`"timestamp":$1`
|
||||||
|
);
|
||||||
|
let response = JSON.parse(
|
||||||
|
await ReactNative.lightpushPublish(
|
||||||
|
messageJSON,
|
||||||
|
pubsubTopic,
|
||||||
|
peerID,
|
||||||
|
timeoutMs
|
||||||
|
)
|
||||||
|
);
|
||||||
|
if (response.error) {
|
||||||
reject(response.error);
|
reject(response.error);
|
||||||
} else {
|
} else {
|
||||||
resolve(response.result);
|
resolve(response.result);
|
||||||
@ -444,11 +553,28 @@ export function lightpushPublish(msg: WakuMessage, pubsubTopic: String = "", pee
|
|||||||
* @param timeoutMs Timeout value in milliseconds to execute the call. If the function takes longer than this value, the execution will be canceled and an error returned
|
* @param timeoutMs Timeout value in milliseconds to execute the call. If the function takes longer than this value, the execution will be canceled and an error returned
|
||||||
* @returns the message ID
|
* @returns the message ID
|
||||||
*/
|
*/
|
||||||
export function lightpushPublishEncAsymmetric(msg: WakuMessage, publicKey: String, optionalSigningKey: String = "", pubsubTopic: String = "", peerID: String = "", timeoutMs: Number = 0): Promise<string> {
|
export function lightpushPublishEncAsymmetric(
|
||||||
|
msg: WakuMessage,
|
||||||
|
publicKey: String,
|
||||||
|
optionalSigningKey: String = '',
|
||||||
|
pubsubTopic: String = '',
|
||||||
|
peerID: String = '',
|
||||||
|
timeoutMs: Number = 0
|
||||||
|
): Promise<string> {
|
||||||
return new Promise<string>(async (resolve, reject) => {
|
return new Promise<string>(async (resolve, reject) => {
|
||||||
let messageJSON = JSON.stringify(msg)
|
let message = new EncryptedPayload(msg);
|
||||||
let response = JSON.parse(await ReactNative.lightpushPublishEncodeAsymmetric(messageJSON, pubsubTopic, peerID, publicKey, optionalSigningKey, timeoutMs));
|
let messageJSON = JSON.stringify(message);
|
||||||
if(response.error){
|
let response = JSON.parse(
|
||||||
|
await ReactNative.lightpushPublishEncodeAsymmetric(
|
||||||
|
messageJSON,
|
||||||
|
pubsubTopic,
|
||||||
|
peerID,
|
||||||
|
publicKey,
|
||||||
|
optionalSigningKey,
|
||||||
|
timeoutMs
|
||||||
|
)
|
||||||
|
);
|
||||||
|
if (response.error) {
|
||||||
reject(response.error);
|
reject(response.error);
|
||||||
} else {
|
} else {
|
||||||
resolve(response.result);
|
resolve(response.result);
|
||||||
@ -466,11 +592,28 @@ export function lightpushPublishEncAsymmetric(msg: WakuMessage, publicKey: Strin
|
|||||||
* @param timeoutMs Timeout value in milliseconds to execute the call. If the function takes longer than this value, the execution will be canceled and an error returned
|
* @param timeoutMs Timeout value in milliseconds to execute the call. If the function takes longer than this value, the execution will be canceled and an error returned
|
||||||
* @returns the message ID
|
* @returns the message ID
|
||||||
*/
|
*/
|
||||||
export function lightpushPublishEncSymmetric(msg: WakuMessage, symmetricKey: String, optionalSigningKey: String = "", pubsubTopic: String = "", peerID: String = "", timeoutMs: Number = 0): Promise<string> {
|
export function lightpushPublishEncSymmetric(
|
||||||
|
msg: WakuMessage,
|
||||||
|
symmetricKey: String,
|
||||||
|
optionalSigningKey: String = '',
|
||||||
|
pubsubTopic: String = '',
|
||||||
|
peerID: String = '',
|
||||||
|
timeoutMs: Number = 0
|
||||||
|
): Promise<string> {
|
||||||
return new Promise<string>(async (resolve, reject) => {
|
return new Promise<string>(async (resolve, reject) => {
|
||||||
let messageJSON = JSON.stringify(msg)
|
let message = new EncryptedPayload(msg);
|
||||||
let response = JSON.parse(await ReactNative.lightpushPublishEncodeAsymmetric(messageJSON, pubsubTopic, peerID, symmetricKey, optionalSigningKey, timeoutMs));
|
let messageJSON = JSON.stringify(message);
|
||||||
if(response.error){
|
let response = JSON.parse(
|
||||||
|
await ReactNative.lightpushPublishEncodeAsymmetric(
|
||||||
|
messageJSON,
|
||||||
|
pubsubTopic,
|
||||||
|
peerID,
|
||||||
|
symmetricKey,
|
||||||
|
optionalSigningKey,
|
||||||
|
timeoutMs
|
||||||
|
)
|
||||||
|
);
|
||||||
|
if (response.error) {
|
||||||
reject(response.error);
|
reject(response.error);
|
||||||
} else {
|
} else {
|
||||||
resolve(response.result);
|
resolve(response.result);
|
||||||
@ -479,12 +622,17 @@ export function lightpushPublishEncSymmetric(msg: WakuMessage, symmetricKey: Str
|
|||||||
}
|
}
|
||||||
|
|
||||||
export class Peer {
|
export class Peer {
|
||||||
addrs: Array<String> = Array()
|
addrs: Array<String> = Array();
|
||||||
connected: Boolean = false
|
connected: Boolean = false;
|
||||||
peerID: String = ""
|
peerID: String = '';
|
||||||
protocols: Array<String> = Array()
|
protocols: Array<String> = Array();
|
||||||
|
|
||||||
constructor(addrs: Array<String>, connected: Boolean, peerID: String, protocols: Array<String>){
|
constructor(
|
||||||
|
addrs: Array<String>,
|
||||||
|
connected: Boolean,
|
||||||
|
peerID: String,
|
||||||
|
protocols: Array<String>
|
||||||
|
) {
|
||||||
this.addrs = addrs;
|
this.addrs = addrs;
|
||||||
this.connected = connected;
|
this.connected = connected;
|
||||||
this.peerID = peerID;
|
this.peerID = peerID;
|
||||||
@ -499,53 +647,106 @@ export class Peer {
|
|||||||
export function peers(): Promise<Array<Peer>> {
|
export function peers(): Promise<Array<Peer>> {
|
||||||
return new Promise<Array<Peer>>(async (resolve, reject) => {
|
return new Promise<Array<Peer>>(async (resolve, reject) => {
|
||||||
let response = JSON.parse(await ReactNative.peers());
|
let response = JSON.parse(await ReactNative.peers());
|
||||||
if(response.error){
|
if (response.error) {
|
||||||
reject(response.error);
|
reject(response.error);
|
||||||
} else {
|
} else {
|
||||||
resolve(response.result.map((x:any) => new Peer(x.addrs, x.connected, x.peerID, x.protocols)));
|
resolve(
|
||||||
|
response.result.map(
|
||||||
|
(x: any) => new Peer(x.addrs, x.connected, x.peerID, x.protocols)
|
||||||
|
)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
})
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
export class DiscoveredNode {
|
||||||
|
peerID: String = '';
|
||||||
|
addrs: Array<String> = Array();
|
||||||
|
enr: String = '';
|
||||||
|
|
||||||
|
constructor(
|
||||||
|
peerID: String,
|
||||||
|
addrs: Array<String>,
|
||||||
|
enr: String
|
||||||
|
) {
|
||||||
|
this.peerID = peerID;
|
||||||
|
this.addrs = addrs;
|
||||||
|
this.enr = enr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Use DNS Discovery to retrieve a list of nodes from an enrtree:// URL
|
||||||
|
* @return List of Nodes
|
||||||
|
*/
|
||||||
|
export function dnsDiscovery(
|
||||||
|
url: String,
|
||||||
|
nameserver: String,
|
||||||
|
timeoutMs: Number = 0
|
||||||
|
): Promise<Array<DiscoveredNode>> {
|
||||||
|
return new Promise<Array<DiscoveredNode>>(async (resolve, reject) => {
|
||||||
|
let response = JSON.parse(await ReactNative.dnsDiscovery(url, nameserver, timeoutMs));
|
||||||
|
if (response.error) {
|
||||||
|
reject(response.error);
|
||||||
|
} else {
|
||||||
|
resolve(
|
||||||
|
response.result.map(
|
||||||
|
(x: any) => new DiscoveredNode(x.peerID, x.multiaddrs, x.enr)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
export class Index {
|
export class Index {
|
||||||
digest: Uint8Array = new Uint8Array();
|
digest: Uint8Array = new Uint8Array();
|
||||||
receiverTime: Number = 0
|
receiverTime: Number = 0;
|
||||||
senderTime: Number = 0
|
senderTime: Number = 0;
|
||||||
pubsubTopic: String = ""
|
pubsubTopic: String = '';
|
||||||
}
|
}
|
||||||
export class PagingOptions {
|
export class PagingOptions {
|
||||||
pageSize: Number = 0
|
pageSize: Number = 0;
|
||||||
cursor: Index | null = null
|
cursor: Index | null = null;
|
||||||
forward: Boolean = false
|
forward: Boolean = false;
|
||||||
|
|
||||||
constructor(pageSize: Number = 0, forward: Boolean = false, cursor: Index | null = null){
|
constructor(
|
||||||
this.pageSize = pageSize
|
pageSize: Number = 0,
|
||||||
this.forward = forward
|
forward: Boolean = false,
|
||||||
this.cursor = cursor
|
cursor: Index | null = null
|
||||||
|
) {
|
||||||
|
this.pageSize = pageSize;
|
||||||
|
this.forward = forward;
|
||||||
|
this.cursor = cursor;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export class ContentFilter {
|
export class ContentFilter {
|
||||||
contentTopic: String = ""
|
contentTopic: String = '';
|
||||||
|
|
||||||
constructor(contentTopic: String = "") {
|
constructor(contentTopic: String = '') {
|
||||||
this.contentTopic = contentTopic
|
this.contentTopic = contentTopic;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export class StoreQuery {
|
export class StoreQuery {
|
||||||
pubsubTopic: String | null = null
|
pubsubTopic: String | null = null;
|
||||||
contentFilters: Array<ContentFilter> = Array()
|
contentFilters: Array<ContentFilter> = Array();
|
||||||
startTime: Number = 0
|
startTime?: Date = undefined;
|
||||||
endTime: Number = 0
|
endTime?: Date = undefined;
|
||||||
pagingOptions: PagingOptions | null = null
|
pagingOptions: PagingOptions | null = null;
|
||||||
|
|
||||||
constructor(pubsubTopic: String | null = null, contentFilters: Array<ContentFilter> = Array(), startTime: Number = 0, endTime: Number = 0, pagingOptions: PagingOptions | null = null) {
|
constructor(
|
||||||
this.pubsubTopic = pubsubTopic
|
pubsubTopic: String | null = null,
|
||||||
this.contentFilters = contentFilters
|
contentFilters: Array<ContentFilter> = Array(),
|
||||||
this.startTime = startTime
|
startTime: Date | undefined = undefined,
|
||||||
this.endTime = endTime
|
endTime: Date | undefined = undefined,
|
||||||
this.pagingOptions = pagingOptions
|
pagingOptions: PagingOptions | null = null
|
||||||
|
) {
|
||||||
|
this.pubsubTopic = pubsubTopic;
|
||||||
|
this.contentFilters = contentFilters;
|
||||||
|
this.startTime = startTime;
|
||||||
|
this.endTime = endTime;
|
||||||
|
this.pagingOptions = pagingOptions;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -556,26 +757,59 @@ export class StoreQuery {
|
|||||||
* @param timeoutMs Timeout value in milliseconds to execute the call. If the function takes longer than this value, the execution will be canceled and an error returned
|
* @param timeoutMs Timeout value in milliseconds to execute the call. If the function takes longer than this value, the execution will be canceled and an error returned
|
||||||
* @returns
|
* @returns
|
||||||
*/
|
*/
|
||||||
export function storeQuery(query: StoreQuery, peerID: String = "", timeoutMs: Number = 0): Promise<any> {
|
export function storeQuery(
|
||||||
|
query: StoreQuery,
|
||||||
|
peerID: String = '',
|
||||||
|
timeoutMs: Number = 0
|
||||||
|
): Promise<any> {
|
||||||
return new Promise<string>(async (resolve, reject) => {
|
return new Promise<string>(async (resolve, reject) => {
|
||||||
let queryJSON = JSON.stringify(query)
|
let queryJSON = JSON.stringify({
|
||||||
let response = JSON.parse(await ReactNative.storeQuery(queryJSON, peerID, timeoutMs));
|
pubsubTopic: query.pubsubTopic,
|
||||||
|
contentFilters: query.contentFilters,
|
||||||
|
startTime: query.startTime
|
||||||
|
? bigInt(query.startTime.valueOf()).multiply(OneMillion).toString(10)
|
||||||
|
: 0,
|
||||||
|
endTime: query.endTime
|
||||||
|
? bigInt(query.endTime.valueOf()).multiply(OneMillion).toString(10)
|
||||||
|
: 0,
|
||||||
|
pagingOptions: query.pagingOptions,
|
||||||
|
})
|
||||||
|
.replace(/"startTime":"([0-9]+)"/, `"startTime":$1`)
|
||||||
|
.replace(/"endTime":"([0-9]+)"/, `"endTime":$1`);
|
||||||
|
let response = JSON.parse(
|
||||||
|
await ReactNative.storeQuery(queryJSON, peerID, timeoutMs)
|
||||||
|
);
|
||||||
|
|
||||||
if(response.error){
|
if (response.error) {
|
||||||
reject(response.error);
|
reject(response.error);
|
||||||
} else {
|
} else {
|
||||||
|
if (response.result.messages) {
|
||||||
|
for (let i = 0; i < response.result.messages.length; i++) {
|
||||||
|
const t = response.result.messages[i].timestamp;
|
||||||
|
response.result.messages[i].timestamp =
|
||||||
|
t != 0
|
||||||
|
? new Date(bigInt(t).divide(OneMillion).toJSNumber())
|
||||||
|
: undefined;
|
||||||
|
response.result.messages[i].payload = new Uint8Array(
|
||||||
|
Buffer.from(response.result.messages[i].payload ?? [], 'base64')
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
resolve(response.result);
|
resolve(response.result);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
export class FilterSubscription {
|
export class FilterSubscription {
|
||||||
pubsubTopic: String | null = null
|
pubsubTopic: String | null = null;
|
||||||
contentFilters: Array<ContentFilter> = Array()
|
contentFilters: Array<ContentFilter> = Array();
|
||||||
|
|
||||||
constructor(pubsubTopic: String | null = null, contentFilters: Array<ContentFilter> = Array()) {
|
constructor(
|
||||||
this.pubsubTopic = pubsubTopic
|
pubsubTopic: String | null = null,
|
||||||
this.contentFilters = contentFilters
|
contentFilters: Array<ContentFilter> = Array()
|
||||||
|
) {
|
||||||
|
this.pubsubTopic = pubsubTopic;
|
||||||
|
this.contentFilters = contentFilters;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -585,12 +819,18 @@ export class FilterSubscription {
|
|||||||
* @param peerID
|
* @param peerID
|
||||||
* @param timeoutMs Timeout value in milliseconds to execute the call. If the function takes longer than this value, the execution will be canceled and an error returned
|
* @param timeoutMs Timeout value in milliseconds to execute the call. If the function takes longer than this value, the execution will be canceled and an error returned
|
||||||
*/
|
*/
|
||||||
export function filterSubscribe(filter: FilterSubscription, peerID: String = "", timeoutMs: Number = 0): Promise<void> {
|
export function filterSubscribe(
|
||||||
|
filter: FilterSubscription,
|
||||||
|
peerID: String = '',
|
||||||
|
timeoutMs: Number = 0
|
||||||
|
): Promise<void> {
|
||||||
return new Promise<void>(async (resolve, reject) => {
|
return new Promise<void>(async (resolve, reject) => {
|
||||||
let filterJSON = JSON.stringify(filter)
|
let filterJSON = JSON.stringify(filter);
|
||||||
let response = JSON.parse(await ReactNative.filterSubscribe(filterJSON, peerID, timeoutMs));
|
let response = JSON.parse(
|
||||||
|
await ReactNative.filterSubscribe(filterJSON, peerID, timeoutMs)
|
||||||
|
);
|
||||||
|
|
||||||
if(response.error){
|
if (response.error) {
|
||||||
reject(response.error);
|
reject(response.error);
|
||||||
} else {
|
} else {
|
||||||
resolve();
|
resolve();
|
||||||
@ -603,12 +843,17 @@ export function filterSubscribe(filter: FilterSubscription, peerID: String = "",
|
|||||||
* @param filter
|
* @param filter
|
||||||
* @param timeoutMs Timeout value in milliseconds to execute the call. If the function takes longer than this value, the execution will be canceled and an error returned
|
* @param timeoutMs Timeout value in milliseconds to execute the call. If the function takes longer than this value, the execution will be canceled and an error returned
|
||||||
*/
|
*/
|
||||||
export function filterUnsubscribe(filter: FilterSubscription, timeoutMs: Number = 0): Promise<void> {
|
export function filterUnsubscribe(
|
||||||
|
filter: FilterSubscription,
|
||||||
|
timeoutMs: Number = 0
|
||||||
|
): Promise<void> {
|
||||||
return new Promise<void>(async (resolve, reject) => {
|
return new Promise<void>(async (resolve, reject) => {
|
||||||
let filterJSON = JSON.stringify(filter)
|
let filterJSON = JSON.stringify(filter);
|
||||||
let response = JSON.parse(await ReactNative.filterUnsubscribe(filterJSON, timeoutMs));
|
let response = JSON.parse(
|
||||||
|
await ReactNative.filterUnsubscribe(filterJSON, timeoutMs)
|
||||||
|
);
|
||||||
|
|
||||||
if(response.error){
|
if (response.error) {
|
||||||
reject(response.error);
|
reject(response.error);
|
||||||
} else {
|
} else {
|
||||||
resolve();
|
resolve();
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user