10 | #endif
11 |
12 | #define FACTORYRESET_ENABLE 1
13 | #define MINIMUM_FIRMWARE_VERSION "0.6.6"
14 | #define MODE_LED_BEHAVIOUR "MODE"
15 |
16 |
17 | // Initialize the Software serial link to read data from the module
18 | SoftwareSerial bluefruitSS = SoftwareSerial(BLUEFRUIT_SWUART_TXD_PIN, BLUEFRUIT_SWUART_RXD_PIN);
19 |
20 | // Create bluetooth LE class to control our BLE module
21 | Adafruit_BluefruitLE_UART ble(bluefruitSS, BLUEFRUIT_UART_MODE_PIN,
22 | BLUEFRUIT_UART_CTS_PIN, BLUEFRUIT_UART_RTS_PIN);
23 |
24 | // defines the pin where the RGB led is wired
25 | int pinR = 3;
26 | int pinG = 5;
27 | int pinB = 6;
28 |
29 | // create variables to check characteristics have been created successful
30 | int counterChannel;
31 | int elevationChannel;
32 |
33 | // initialize the counter to 0
34 | int counter = 0;
35 |
36 |
37 | // A small helper
38 | void error(const __FlashStringHelper*err) {
39 | Serial.println(err);
40 | digitalWrite(pinR, 255);
41 | while (1);
42 | }
43 |
44 | void setup(void)
45 | {
46 | pinMode(pinR, OUTPUT);
47 | pinMode(pinG, OUTPUT);
48 | pinMode(pinB, OUTPUT);
49 |
50 | // At the beginning all the led are turned down
51 | analogWrite(pinR, 0);
52 | analogWrite(pinG, 0);
53 | analogWrite(pinB, 0);
54 |
55 | // verify if the serial port is available, and initialize it to display some informations
56 | while(!Serial) {
57 | delay(500);
58 | }
59 |
60 | Serial.begin(115200);
61 |
62 | /* Initialise the module */
63 | Serial.print(F("Initialising the Bluefruit LE module: "));
64 |
65 | if ( !ble.begin(VERBOSE_MODE) )
66 | {
67 | error(F("Couldn't find Bluefruit, make sure it's in CoMmanD mode & check wiring?"));
68 | }
69 |
70 | if ( FACTORYRESET_ENABLE )
71 | {
72 | /* Perform a factory reset to make sure everything is in a known state */
73 | Serial.println(F("Performing a factory reset: "));
74 | if ( !ble.factoryReset() ){
75 | error(F("Couldn't factory reset"));
76 | }
77 | }
78 |
79 | /* Disable command echo from Bluefruit */
80 | ble.echo(false);
81 |
82 | Serial.println("Requesting Bluefruit info:");
83 | /* Print Bluefruit information */
84 | ble.info();
85 |
86 | ble.reset();
87 |
88 | ble.println(F("AT+GATTADDSERVICE=UUID=0x180F"));
89 | if(!ble.waitForOK()){
90 | error(F("Error adding service"));
91 | }
92 |
93 | counterChannel = ble.println(F("AT+GATTADDCHAR=UUID=0x2A19,PROPERTIES=0x10,MIN_LEN=1,DESCRIPTION=Counter,VALUE=100"));
94 |
95 | if(counterChannel == 0){
96 | error(F("Error adding characteristic"));
97 | }
98 |
99 | elevationChannel = ble.println(F("AT+GATTADDCHAR=UUID=0x2A6C,PROPERTIES=0x08,MIN_LEN=1,DESCRIPTION=Elevation,VALUE=0"));
100 |
101 | if(elevationChannel == 0){
102 | error(F("Error adding characteristic"));
103 | }
104 |
105 |
106 | // reset the BLE module to take in count the previous modifications
107 | ble.reset();
108 | Serial.println();
109 |
110 | ble.verbose(false); // debug info is a little annoying after this point!
111 |
112 | // set the callbacks to detect when a device has just been connected or disconnected to the BLE module
113 | ble.setConnectCallback(connected);
114 | ble.setDisconnectCallback(disconnected);
115 |
116 |
117 | /* Wait for connection */
118 | while (!ble.isConnected()) {
119 | digitalWrite(pinB, 255);
120 | delay(500);
121 | digitalWrite(pinB, 0);
122 | delay(500);
123 | }
124 | digitalWrite(pinB, 0);
125 | digitalWrite(pinG, 255);
126 | delay(1000);
127 |
128 | }
129 |
130 | void loop(void)
131 | {
132 | ble.update(200);
133 |
134 | // send the AT command to read the second characteristic we added
135 | int elevation = ble.println(F("AT+GATTCHAR=2"));
136 |
137 | // if an error occured ("OK" is not received), then display an error message
138 | if(!ble.waitForOK()) {
139 | Serial.println(F("Error when reading elevation"));
140 | }
141 |
142 | // print the elevation value in the serial monitor
143 | Serial.print(F("[Elevation] ")); Serial.println(elevation);
144 |
145 |
146 | // increase the counter value of 1;
147 | counter++;
148 |
149 | // send the AT command to write the counter value in the first characteristic we added
150 | ble.print(F("AT+GATTCHAR=1,"));
151 | ble.println(counter);
152 |
153 | // handle the error if "OK" is not received
154 | if(!ble.waitForOK()) {
155 | Serial.println(F("Error when sending counter"));
156 | }
157 |
158 | // the green LED blinks to informe the user the counter inscreased
159 | digitalWrite(pinG, 0);
160 | delay(500);
161 | digitalWrite(pinG, 255);
162 | delay(500);
163 |
164 | }
165 |
166 | void connected(void)
167 | {
168 | Serial.println( F("Connected") );
169 | digitalWrite(pinR, 0);
170 | digitalWrite(pinG, 255);
171 | digitalWrite(pinB, 0);
172 | }
173 |
174 | void disconnected(void)
175 | {
176 | counter = 0;
177 | Serial.println( F("Disconnected") );
178 | digitalWrite(pinR, 0);
179 | digitalWrite(pinG, 0);
180 | digitalWrite(pinB, 255);
181 | }
182 |
--------------------------------------------------------------------------------
/BLE-react-native-counter-writer/BluefruitConfig.h:
--------------------------------------------------------------------------------
1 | // COMMON SETTINGS
2 | // ----------------------------------------------------------------------------------------------
3 | // These settings are used in both SW UART, HW UART and SPI mode
4 | // ----------------------------------------------------------------------------------------------
5 | #define BUFSIZE 128 // Size of the read buffer for incoming data
6 | #define VERBOSE_MODE true // If set to 'true' enables debug output
7 |
8 |
9 | // SOFTWARE UART SETTINGS
10 | // ----------------------------------------------------------------------------------------------
11 | // The following macros declare the pins that will be used for 'SW' serial.
12 | // You should use this option if you are connecting the UART Friend to an UNO
13 | // ----------------------------------------------------------------------------------------------
14 | #define BLUEFRUIT_SWUART_RXD_PIN 9 // Required for software serial!
15 | #define BLUEFRUIT_SWUART_TXD_PIN 10 // Required for software serial!
16 | #define BLUEFRUIT_UART_CTS_PIN 11 // Required for software serial!
17 | #define BLUEFRUIT_UART_RTS_PIN -1 // Optional, set to -1 if unused
18 |
19 |
20 | // HARDWARE UART SETTINGS
21 | // ----------------------------------------------------------------------------------------------
22 | // The following macros declare the HW serial port you are using. Uncomment
23 | // this line if you are connecting the BLE to Leonardo/Micro or Flora
24 | // ----------------------------------------------------------------------------------------------
25 | #ifdef Serial1 // this makes it not complain on compilation if there's no Serial1
26 | #define BLUEFRUIT_HWSERIAL_NAME Serial1
27 | #endif
28 |
29 |
30 | // SHARED UART SETTINGS
31 | // ----------------------------------------------------------------------------------------------
32 | // The following sets the optional Mode pin, its recommended but not required
33 | // ----------------------------------------------------------------------------------------------
34 | #define BLUEFRUIT_UART_MODE_PIN 12 // Set to -1 if unused
35 |
36 |
37 | // SHARED SPI SETTINGS
38 | // ----------------------------------------------------------------------------------------------
39 | // The following macros declare the pins to use for HW and SW SPI communication.
40 | // SCK, MISO and MOSI should be connected to the HW SPI pins on the Uno when
41 | // using HW SPI. This should be used with nRF51822 based Bluefruit LE modules
42 | // that use SPI (Bluefruit LE SPI Friend).
43 | // ----------------------------------------------------------------------------------------------
44 | #define BLUEFRUIT_SPI_CS 8
45 | #define BLUEFRUIT_SPI_IRQ 7
46 | #define BLUEFRUIT_SPI_RST 4 // Optional but recommended, set to -1 if unused
47 |
48 | // SOFTWARE SPI SETTINGS
49 | // ----------------------------------------------------------------------------------------------
50 | // The following macros declare the pins to use for SW SPI communication.
51 | // This should be used with nRF51822 based Bluefruit LE modules that use SPI
52 | // (Bluefruit LE SPI Friend).
53 | // ----------------------------------------------------------------------------------------------
54 | #define BLUEFRUIT_SPI_SCK 13
55 | #define BLUEFRUIT_SPI_MISO 12
56 | #define BLUEFRUIT_SPI_MOSI 11
57 |
--------------------------------------------------------------------------------
/__tests__/App-test.tsx:
--------------------------------------------------------------------------------
1 | /**
2 | * @format
3 | */
4 |
5 | import 'react-native';
6 | import React from 'react';
7 | import App from '../App';
8 |
9 | // Note: test renderer must be required after react-native.
10 | import renderer from 'react-test-renderer';
11 |
12 | it('renders correctly', () => {
13 | renderer.create();
14 | });
15 |
--------------------------------------------------------------------------------
/android/app/_BUCK:
--------------------------------------------------------------------------------
1 | # To learn about Buck see [Docs](https://buckbuild.com/).
2 | # To run your application with Buck:
3 | # - install Buck
4 | # - `npm start` - to start the packager
5 | # - `cd android`
6 | # - `keytool -genkey -v -keystore keystores/debug.keystore -storepass android -alias androiddebugkey -keypass android -dname "CN=Android Debug,O=Android,C=US"`
7 | # - `./gradlew :app:copyDownloadableDepsToLibs` - make all Gradle compile dependencies available to Buck
8 | # - `buck install -r android/app` - compile, install and run application
9 | #
10 |
11 | load(":build_defs.bzl", "create_aar_targets", "create_jar_targets")
12 |
13 | lib_deps = []
14 |
15 | create_aar_targets(glob(["libs/*.aar"]))
16 |
17 | create_jar_targets(glob(["libs/*.jar"]))
18 |
19 | android_library(
20 | name = "all-libs",
21 | exported_deps = lib_deps,
22 | )
23 |
24 | android_library(
25 | name = "app-code",
26 | srcs = glob([
27 | "src/main/java/**/*.java",
28 | ]),
29 | deps = [
30 | ":all-libs",
31 | ":build_config",
32 | ":res",
33 | ],
34 | )
35 |
36 | android_build_config(
37 | name = "build_config",
38 | package = "com.bleproject",
39 | )
40 |
41 | android_resource(
42 | name = "res",
43 | package = "com.bleproject",
44 | res = "src/main/res",
45 | )
46 |
47 | android_binary(
48 | name = "app",
49 | keystore = "//android/keystores:debug",
50 | manifest = "src/main/AndroidManifest.xml",
51 | package_type = "debug",
52 | deps = [
53 | ":app-code",
54 | ],
55 | )
56 |
--------------------------------------------------------------------------------
/android/app/build.gradle:
--------------------------------------------------------------------------------
1 | apply plugin: "com.android.application"
2 |
3 | import com.android.build.OutputFile
4 |
5 | /**
6 | * The react.gradle file registers a task for each build variant (e.g. bundleDebugJsAndAssets
7 | * and bundleReleaseJsAndAssets).
8 | * These basically call `react-native bundle` with the correct arguments during the Android build
9 | * cycle. By default, bundleDebugJsAndAssets is skipped, as in debug/dev mode we prefer to load the
10 | * bundle directly from the development server. Below you can see all the possible configurations
11 | * and their defaults. If you decide to add a configuration block, make sure to add it before the
12 | * `apply from: "../../node_modules/react-native/react.gradle"` line.
13 | *
14 | * project.ext.react = [
15 | * // the name of the generated asset file containing your JS bundle
16 | * bundleAssetName: "index.android.bundle",
17 | *
18 | * // the entry file for bundle generation. If none specified and
19 | * // "index.android.js" exists, it will be used. Otherwise "index.js" is
20 | * // default. Can be overridden with ENTRY_FILE environment variable.
21 | * entryFile: "index.android.js",
22 | *
23 | * // https://reactnative.dev/docs/performance#enable-the-ram-format
24 | * bundleCommand: "ram-bundle",
25 | *
26 | * // whether to bundle JS and assets in debug mode
27 | * bundleInDebug: false,
28 | *
29 | * // whether to bundle JS and assets in release mode
30 | * bundleInRelease: true,
31 | *
32 | * // whether to bundle JS and assets in another build variant (if configured).
33 | * // See http://tools.android.com/tech-docs/new-build-system/user-guide#TOC-Build-Variants
34 | * // The configuration property can be in the following formats
35 | * // 'bundleIn${productFlavor}${buildType}'
36 | * // 'bundleIn${buildType}'
37 | * // bundleInFreeDebug: true,
38 | * // bundleInPaidRelease: true,
39 | * // bundleInBeta: true,
40 | *
41 | * // whether to disable dev mode in custom build variants (by default only disabled in release)
42 | * // for example: to disable dev mode in the staging build type (if configured)
43 | * devDisabledInStaging: true,
44 | * // The configuration property can be in the following formats
45 | * // 'devDisabledIn${productFlavor}${buildType}'
46 | * // 'devDisabledIn${buildType}'
47 | *
48 | * // the root of your project, i.e. where "package.json" lives
49 | * root: "../../",
50 | *
51 | * // where to put the JS bundle asset in debug mode
52 | * jsBundleDirDebug: "$buildDir/intermediates/assets/debug",
53 | *
54 | * // where to put the JS bundle asset in release mode
55 | * jsBundleDirRelease: "$buildDir/intermediates/assets/release",
56 | *
57 | * // where to put drawable resources / React Native assets, e.g. the ones you use via
58 | * // require('./image.png')), in debug mode
59 | * resourcesDirDebug: "$buildDir/intermediates/res/merged/debug",
60 | *
61 | * // where to put drawable resources / React Native assets, e.g. the ones you use via
62 | * // require('./image.png')), in release mode
63 | * resourcesDirRelease: "$buildDir/intermediates/res/merged/release",
64 | *
65 | * // by default the gradle tasks are skipped if none of the JS files or assets change; this means
66 | * // that we don't look at files in android/ or ios/ to determine whether the tasks are up to
67 | * // date; if you have any other folders that you want to ignore for performance reasons (gradle
68 | * // indexes the entire tree), add them here. Alternatively, if you have JS files in android/
69 | * // for example, you might want to remove it from here.
70 | * inputExcludes: ["android/**", "ios/**"],
71 | *
72 | * // override which node gets called and with what additional arguments
73 | * nodeExecutableAndArgs: ["node"],
74 | *
75 | * // supply additional arguments to the packager
76 | * extraPackagerArgs: []
77 | * ]
78 | */
79 |
80 | project.ext.react = [
81 | enableHermes: false, // clean and rebuild if changing
82 | ]
83 |
84 | apply from: "../../node_modules/react-native/react.gradle"
85 |
86 | /**
87 | * Set this to true to create two separate APKs instead of one:
88 | * - An APK that only works on ARM devices
89 | * - An APK that only works on x86 devices
90 | * The advantage is the size of the APK is reduced by about 4MB.
91 | * Upload all the APKs to the Play Store and people will download
92 | * the correct one based on the CPU architecture of their device.
93 | */
94 | def enableSeparateBuildPerCPUArchitecture = false
95 |
96 | /**
97 | * Run Proguard to shrink the Java bytecode in release builds.
98 | */
99 | def enableProguardInReleaseBuilds = false
100 |
101 | /**
102 | * The preferred build flavor of JavaScriptCore.
103 | *
104 | * For example, to use the international variant, you can use:
105 | * `def jscFlavor = 'org.webkit:android-jsc-intl:+'`
106 | *
107 | * The international variant includes ICU i18n library and necessary data
108 | * allowing to use e.g. `Date.toLocaleString` and `String.localeCompare` that
109 | * give correct results when using with locales other than en-US. Note that
110 | * this variant is about 6MiB larger per architecture than default.
111 | */
112 | def jscFlavor = 'org.webkit:android-jsc:+'
113 |
114 | /**
115 | * Whether to enable the Hermes VM.
116 | *
117 | * This should be set on project.ext.react and mirrored here. If it is not set
118 | * on project.ext.react, JavaScript will not be compiled to Hermes Bytecode
119 | * and the benefits of using Hermes will therefore be sharply reduced.
120 | */
121 | def enableHermes = project.ext.react.get("enableHermes", false);
122 |
123 | android {
124 | compileSdkVersion rootProject.ext.compileSdkVersion
125 |
126 | compileOptions {
127 | sourceCompatibility JavaVersion.VERSION_1_8
128 | targetCompatibility JavaVersion.VERSION_1_8
129 | }
130 |
131 | defaultConfig {
132 | applicationId "com.bleproject"
133 | minSdkVersion rootProject.ext.minSdkVersion
134 | targetSdkVersion rootProject.ext.targetSdkVersion
135 | versionCode 1
136 | versionName "1.0"
137 | }
138 | splits {
139 | abi {
140 | reset()
141 | enable enableSeparateBuildPerCPUArchitecture
142 | universalApk false // If true, also generate a universal APK
143 | include "armeabi-v7a", "x86", "arm64-v8a", "x86_64"
144 | }
145 | }
146 | signingConfigs {
147 | debug {
148 | storeFile file('debug.keystore')
149 | storePassword 'android'
150 | keyAlias 'androiddebugkey'
151 | keyPassword 'android'
152 | }
153 | }
154 | buildTypes {
155 | debug {
156 | signingConfig signingConfigs.debug
157 | }
158 | release {
159 | // Caution! In production, you need to generate your own keystore file.
160 | // see https://reactnative.dev/docs/signed-apk-android.
161 | signingConfig signingConfigs.debug
162 | minifyEnabled enableProguardInReleaseBuilds
163 | proguardFiles getDefaultProguardFile("proguard-android.txt"), "proguard-rules.pro"
164 | }
165 | }
166 |
167 | // applicationVariants are e.g. debug, release
168 | applicationVariants.all { variant ->
169 | variant.outputs.each { output ->
170 | // For each separate APK per architecture, set a unique version code as described here:
171 | // https://developer.android.com/studio/build/configure-apk-splits.html
172 | def versionCodes = ["armeabi-v7a": 1, "x86": 2, "arm64-v8a": 3, "x86_64": 4]
173 | def abi = output.getFilter(OutputFile.ABI)
174 | if (abi != null) { // null for the universal-debug, universal-release variants
175 | output.versionCodeOverride =
176 | versionCodes.get(abi) * 1048576 + defaultConfig.versionCode
177 | }
178 |
179 | }
180 | }
181 | }
182 |
183 | dependencies {
184 | implementation fileTree(dir: "libs", include: ["*.jar"])
185 | //noinspection GradleDynamicVersion
186 | implementation "com.facebook.react:react-native:+" // From node_modules
187 |
188 | implementation "androidx.swiperefreshlayout:swiperefreshlayout:1.0.0"
189 |
190 | debugImplementation("com.facebook.flipper:flipper:${FLIPPER_VERSION}") {
191 | exclude group:'com.facebook.fbjni'
192 | }
193 |
194 | debugImplementation("com.facebook.flipper:flipper-network-plugin:${FLIPPER_VERSION}") {
195 | exclude group:'com.facebook.flipper'
196 | exclude group:'com.squareup.okhttp3', module:'okhttp'
197 | }
198 |
199 | debugImplementation("com.facebook.flipper:flipper-fresco-plugin:${FLIPPER_VERSION}") {
200 | exclude group:'com.facebook.flipper'
201 | }
202 |
203 | if (enableHermes) {
204 | def hermesPath = "../../node_modules/hermes-engine/android/";
205 | debugImplementation files(hermesPath + "hermes-debug.aar")
206 | releaseImplementation files(hermesPath + "hermes-release.aar")
207 | } else {
208 | implementation jscFlavor
209 | }
210 | }
211 |
212 | // Run this once to be able to run the application with BUCK
213 | // puts all compile dependencies into folder libs for BUCK to use
214 | task copyDownloadableDepsToLibs(type: Copy) {
215 | from configurations.compile
216 | into 'libs'
217 | }
218 |
219 | apply from: file("../../node_modules/@react-native-community/cli-platform-android/native_modules.gradle"); applyNativeModulesAppBuildGradle(project)
220 |
--------------------------------------------------------------------------------
/android/app/build_defs.bzl:
--------------------------------------------------------------------------------
1 | """Helper definitions to glob .aar and .jar targets"""
2 |
3 | def create_aar_targets(aarfiles):
4 | for aarfile in aarfiles:
5 | name = "aars__" + aarfile[aarfile.rindex("/") + 1:aarfile.rindex(".aar")]
6 | lib_deps.append(":" + name)
7 | android_prebuilt_aar(
8 | name = name,
9 | aar = aarfile,
10 | )
11 |
12 | def create_jar_targets(jarfiles):
13 | for jarfile in jarfiles:
14 | name = "jars__" + jarfile[jarfile.rindex("/") + 1:jarfile.rindex(".jar")]
15 | lib_deps.append(":" + name)
16 | prebuilt_jar(
17 | name = name,
18 | binary_jar = jarfile,
19 | )
20 |
--------------------------------------------------------------------------------
/android/app/debug.keystore:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/Spoutnik97/react-native-arduino-ble-example/935ebf8b8414d716bb14caf8d133b90ffedc22f8/android/app/debug.keystore
--------------------------------------------------------------------------------
/android/app/proguard-rules.pro:
--------------------------------------------------------------------------------
1 | # Add project specific ProGuard rules here.
2 | # By default, the flags in this file are appended to flags specified
3 | # in /usr/local/Cellar/android-sdk/24.3.3/tools/proguard/proguard-android.txt
4 | # You can edit the include path and order by changing the proguardFiles
5 | # directive in build.gradle.
6 | #
7 | # For more details, see
8 | # http://developer.android.com/guide/developing/tools/proguard.html
9 |
10 | # Add any project specific keep options here:
11 |
--------------------------------------------------------------------------------
/android/app/src/debug/AndroidManifest.xml:
--------------------------------------------------------------------------------
1 |
2 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 |
--------------------------------------------------------------------------------
/android/app/src/debug/java/com/bleproject/ReactNativeFlipper.java:
--------------------------------------------------------------------------------
1 | /**
2 | * Copyright (c) Facebook, Inc. and its affiliates.
3 | *
4 | * This source code is licensed under the MIT license found in the LICENSE file in the root
5 | * directory of this source tree.
6 | */
7 | package com.bleproject;
8 |
9 | import android.content.Context;
10 | import com.facebook.flipper.android.AndroidFlipperClient;
11 | import com.facebook.flipper.android.utils.FlipperUtils;
12 | import com.facebook.flipper.core.FlipperClient;
13 | import com.facebook.flipper.plugins.crashreporter.CrashReporterPlugin;
14 | import com.facebook.flipper.plugins.databases.DatabasesFlipperPlugin;
15 | import com.facebook.flipper.plugins.fresco.FrescoFlipperPlugin;
16 | import com.facebook.flipper.plugins.inspector.DescriptorMapping;
17 | import com.facebook.flipper.plugins.inspector.InspectorFlipperPlugin;
18 | import com.facebook.flipper.plugins.network.FlipperOkhttpInterceptor;
19 | import com.facebook.flipper.plugins.network.NetworkFlipperPlugin;
20 | import com.facebook.flipper.plugins.react.ReactFlipperPlugin;
21 | import com.facebook.flipper.plugins.sharedpreferences.SharedPreferencesFlipperPlugin;
22 | import com.facebook.react.ReactInstanceManager;
23 | import com.facebook.react.bridge.ReactContext;
24 | import com.facebook.react.modules.network.NetworkingModule;
25 | import okhttp3.OkHttpClient;
26 |
27 | public class ReactNativeFlipper {
28 | public static void initializeFlipper(Context context, ReactInstanceManager reactInstanceManager) {
29 | if (FlipperUtils.shouldEnableFlipper(context)) {
30 | final FlipperClient client = AndroidFlipperClient.getInstance(context);
31 |
32 | client.addPlugin(new InspectorFlipperPlugin(context, DescriptorMapping.withDefaults()));
33 | client.addPlugin(new ReactFlipperPlugin());
34 | client.addPlugin(new DatabasesFlipperPlugin(context));
35 | client.addPlugin(new SharedPreferencesFlipperPlugin(context));
36 | client.addPlugin(CrashReporterPlugin.getInstance());
37 |
38 | NetworkFlipperPlugin networkFlipperPlugin = new NetworkFlipperPlugin();
39 | NetworkingModule.setCustomClientBuilder(
40 | new NetworkingModule.CustomClientBuilder() {
41 | @Override
42 | public void apply(OkHttpClient.Builder builder) {
43 | builder.addNetworkInterceptor(new FlipperOkhttpInterceptor(networkFlipperPlugin));
44 | }
45 | });
46 | client.addPlugin(networkFlipperPlugin);
47 | client.start();
48 |
49 | // Fresco Plugin needs to ensure that ImagePipelineFactory is initialized
50 | // Hence we run if after all native modules have been initialized
51 | ReactContext reactContext = reactInstanceManager.getCurrentReactContext();
52 | if (reactContext == null) {
53 | reactInstanceManager.addReactInstanceEventListener(
54 | new ReactInstanceManager.ReactInstanceEventListener() {
55 | @Override
56 | public void onReactContextInitialized(ReactContext reactContext) {
57 | reactInstanceManager.removeReactInstanceEventListener(this);
58 | reactContext.runOnNativeModulesQueueThread(
59 | new Runnable() {
60 | @Override
61 | public void run() {
62 | client.addPlugin(new FrescoFlipperPlugin());
63 | }
64 | });
65 | }
66 | });
67 | } else {
68 | client.addPlugin(new FrescoFlipperPlugin());
69 | }
70 | }
71 | }
72 | }
73 |
--------------------------------------------------------------------------------
/android/app/src/main/AndroidManifest.xml:
--------------------------------------------------------------------------------
1 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
16 |
22 |
23 |
24 |
25 |
26 |
27 |
28 |
29 |
30 |
31 |
--------------------------------------------------------------------------------
/android/app/src/main/java/com/bleproject/MainActivity.java:
--------------------------------------------------------------------------------
1 | package com.bleproject;
2 |
3 | import com.facebook.react.ReactActivity;
4 |
5 | public class MainActivity extends ReactActivity {
6 |
7 | /**
8 | * Returns the name of the main component registered from JavaScript. This is used to schedule
9 | * rendering of the component.
10 | */
11 | @Override
12 | protected String getMainComponentName() {
13 | return "BLEProject";
14 | }
15 | }
16 |
--------------------------------------------------------------------------------
/android/app/src/main/java/com/bleproject/MainApplication.java:
--------------------------------------------------------------------------------
1 | package com.bleproject;
2 |
3 | import android.app.Application;
4 | import android.content.Context;
5 | import com.facebook.react.PackageList;
6 | import com.facebook.react.ReactApplication;
7 | import com.polidea.reactnativeble.BlePackage;
8 | import com.facebook.react.ReactInstanceManager;
9 | import com.facebook.react.ReactNativeHost;
10 | import com.facebook.react.ReactPackage;
11 | import com.facebook.soloader.SoLoader;
12 | import java.lang.reflect.InvocationTargetException;
13 | import java.util.List;
14 |
15 | public class MainApplication extends Application implements ReactApplication {
16 |
17 | private final ReactNativeHost mReactNativeHost =
18 | new ReactNativeHost(this) {
19 | @Override
20 | public boolean getUseDeveloperSupport() {
21 | return BuildConfig.DEBUG;
22 | }
23 |
24 | @Override
25 | protected List getPackages() {
26 | @SuppressWarnings("UnnecessaryLocalVariable")
27 | List packages = new PackageList(this).getPackages();
28 | // Packages that cannot be autolinked yet can be added manually here, for example:
29 | // packages.add(new MyReactNativePackage());
30 | return packages;
31 | }
32 |
33 | @Override
34 | protected String getJSMainModuleName() {
35 | return "index";
36 | }
37 | };
38 |
39 | @Override
40 | public ReactNativeHost getReactNativeHost() {
41 | return mReactNativeHost;
42 | }
43 |
44 | @Override
45 | public void onCreate() {
46 | super.onCreate();
47 | SoLoader.init(this, /* native exopackage */ false);
48 | initializeFlipper(this, getReactNativeHost().getReactInstanceManager());
49 | }
50 |
51 | /**
52 | * Loads Flipper in React Native templates. Call this in the onCreate method with something like
53 | * initializeFlipper(this, getReactNativeHost().getReactInstanceManager());
54 | *
55 | * @param context
56 | * @param reactInstanceManager
57 | */
58 | private static void initializeFlipper(
59 | Context context, ReactInstanceManager reactInstanceManager) {
60 | if (BuildConfig.DEBUG) {
61 | try {
62 | /*
63 | We use reflection here to pick up the class that initializes Flipper,
64 | since Flipper library is not available in release mode
65 | */
66 | Class> aClass = Class.forName("com.bleproject.ReactNativeFlipper");
67 | aClass
68 | .getMethod("initializeFlipper", Context.class, ReactInstanceManager.class)
69 | .invoke(null, context, reactInstanceManager);
70 | } catch (ClassNotFoundException e) {
71 | e.printStackTrace();
72 | } catch (NoSuchMethodException e) {
73 | e.printStackTrace();
74 | } catch (IllegalAccessException e) {
75 | e.printStackTrace();
76 | } catch (InvocationTargetException e) {
77 | e.printStackTrace();
78 | }
79 | }
80 | }
81 | }
82 |
--------------------------------------------------------------------------------
/android/app/src/main/res/mipmap-hdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/Spoutnik97/react-native-arduino-ble-example/935ebf8b8414d716bb14caf8d133b90ffedc22f8/android/app/src/main/res/mipmap-hdpi/ic_launcher.png
--------------------------------------------------------------------------------
/android/app/src/main/res/mipmap-hdpi/ic_launcher_round.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/Spoutnik97/react-native-arduino-ble-example/935ebf8b8414d716bb14caf8d133b90ffedc22f8/android/app/src/main/res/mipmap-hdpi/ic_launcher_round.png
--------------------------------------------------------------------------------
/android/app/src/main/res/mipmap-mdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/Spoutnik97/react-native-arduino-ble-example/935ebf8b8414d716bb14caf8d133b90ffedc22f8/android/app/src/main/res/mipmap-mdpi/ic_launcher.png
--------------------------------------------------------------------------------
/android/app/src/main/res/mipmap-mdpi/ic_launcher_round.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/Spoutnik97/react-native-arduino-ble-example/935ebf8b8414d716bb14caf8d133b90ffedc22f8/android/app/src/main/res/mipmap-mdpi/ic_launcher_round.png
--------------------------------------------------------------------------------
/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/Spoutnik97/react-native-arduino-ble-example/935ebf8b8414d716bb14caf8d133b90ffedc22f8/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png
--------------------------------------------------------------------------------
/android/app/src/main/res/mipmap-xhdpi/ic_launcher_round.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/Spoutnik97/react-native-arduino-ble-example/935ebf8b8414d716bb14caf8d133b90ffedc22f8/android/app/src/main/res/mipmap-xhdpi/ic_launcher_round.png
--------------------------------------------------------------------------------
/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/Spoutnik97/react-native-arduino-ble-example/935ebf8b8414d716bb14caf8d133b90ffedc22f8/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png
--------------------------------------------------------------------------------
/android/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/Spoutnik97/react-native-arduino-ble-example/935ebf8b8414d716bb14caf8d133b90ffedc22f8/android/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.png
--------------------------------------------------------------------------------
/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/Spoutnik97/react-native-arduino-ble-example/935ebf8b8414d716bb14caf8d133b90ffedc22f8/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png
--------------------------------------------------------------------------------
/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/Spoutnik97/react-native-arduino-ble-example/935ebf8b8414d716bb14caf8d133b90ffedc22f8/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.png
--------------------------------------------------------------------------------
/android/app/src/main/res/values/strings.xml:
--------------------------------------------------------------------------------
1 |
2 | BLEProject
3 |
4 |
--------------------------------------------------------------------------------
/android/app/src/main/res/values/styles.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
8 |
9 |
10 |
--------------------------------------------------------------------------------
/android/build.gradle:
--------------------------------------------------------------------------------
1 | // Top-level build file where you can add configuration options common to all sub-projects/modules.
2 |
3 | buildscript {
4 | ext {
5 | buildToolsVersion = "29.0.2"
6 | minSdkVersion = 18
7 | compileSdkVersion = 29
8 | targetSdkVersion = 29
9 | }
10 | repositories {
11 | google()
12 | jcenter()
13 | }
14 | dependencies {
15 | classpath("com.android.tools.build:gradle:3.5.3")
16 | // NOTE: Do not place your application dependencies here; they belong
17 | // in the individual module build.gradle files
18 | }
19 | }
20 |
21 | allprojects {
22 | repositories {
23 | mavenLocal()
24 | maven {
25 | // All of React Native (JS, Obj-C sources, Android binaries) is installed from npm
26 | url("$rootDir/../node_modules/react-native/android")
27 | }
28 | maven {
29 | // Android JSC is installed from npm
30 | url("$rootDir/../node_modules/jsc-android/dist")
31 | }
32 |
33 | google()
34 | jcenter()
35 | maven { url 'https://www.jitpack.io' }
36 | }
37 | }
38 |
--------------------------------------------------------------------------------
/android/gradle.properties:
--------------------------------------------------------------------------------
1 | # Project-wide Gradle settings.
2 |
3 | # IDE (e.g. Android Studio) users:
4 | # Gradle settings configured through the IDE *will override*
5 | # any settings specified in this file.
6 |
7 | # For more details on how to configure your build environment visit
8 | # http://www.gradle.org/docs/current/userguide/build_environment.html
9 |
10 | # Specifies the JVM arguments used for the daemon process.
11 | # The setting is particularly useful for tweaking memory settings.
12 | # Default value: -Xmx10248m -XX:MaxPermSize=256m
13 | # org.gradle.jvmargs=-Xmx2048m -XX:MaxPermSize=512m -XX:+HeapDumpOnOutOfMemoryError -Dfile.encoding=UTF-8
14 |
15 | # When configured, Gradle will run in incubating parallel mode.
16 | # This option should only be used with decoupled projects. More details, visit
17 | # http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects
18 | # org.gradle.parallel=true
19 |
20 | # AndroidX package structure to make it clearer which packages are bundled with the
21 | # Android operating system, and which are packaged with your app's APK
22 | # https://developer.android.com/topic/libraries/support-library/androidx-rn
23 | android.useAndroidX=true
24 | # Automatically convert third-party libraries to use AndroidX
25 | android.enableJetifier=true
26 |
27 | # Version of flipper SDK to use with React Native
28 | FLIPPER_VERSION=0.54.0
29 |
--------------------------------------------------------------------------------
/android/gradle/wrapper/gradle-wrapper.jar:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/Spoutnik97/react-native-arduino-ble-example/935ebf8b8414d716bb14caf8d133b90ffedc22f8/android/gradle/wrapper/gradle-wrapper.jar
--------------------------------------------------------------------------------
/android/gradle/wrapper/gradle-wrapper.properties:
--------------------------------------------------------------------------------
1 | distributionBase=GRADLE_USER_HOME
2 | distributionPath=wrapper/dists
3 | distributionUrl=https\://services.gradle.org/distributions/gradle-6.2-all.zip
4 | zipStoreBase=GRADLE_USER_HOME
5 | zipStorePath=wrapper/dists
6 |
--------------------------------------------------------------------------------
/android/gradlew:
--------------------------------------------------------------------------------
1 | #!/usr/bin/env sh
2 |
3 | #
4 | # Copyright 2015 the original author or authors.
5 | #
6 | # Licensed under the Apache License, Version 2.0 (the "License");
7 | # you may not use this file except in compliance with the License.
8 | # You may obtain a copy of the License at
9 | #
10 | # https://www.apache.org/licenses/LICENSE-2.0
11 | #
12 | # Unless required by applicable law or agreed to in writing, software
13 | # distributed under the License is distributed on an "AS IS" BASIS,
14 | # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 | # See the License for the specific language governing permissions and
16 | # limitations under the License.
17 | #
18 |
19 | ##############################################################################
20 | ##
21 | ## Gradle start up script for UN*X
22 | ##
23 | ##############################################################################
24 |
25 | # Attempt to set APP_HOME
26 | # Resolve links: $0 may be a link
27 | PRG="$0"
28 | # Need this for relative symlinks.
29 | while [ -h "$PRG" ] ; do
30 | ls=`ls -ld "$PRG"`
31 | link=`expr "$ls" : '.*-> \(.*\)$'`
32 | if expr "$link" : '/.*' > /dev/null; then
33 | PRG="$link"
34 | else
35 | PRG=`dirname "$PRG"`"/$link"
36 | fi
37 | done
38 | SAVED="`pwd`"
39 | cd "`dirname \"$PRG\"`/" >/dev/null
40 | APP_HOME="`pwd -P`"
41 | cd "$SAVED" >/dev/null
42 |
43 | APP_NAME="Gradle"
44 | APP_BASE_NAME=`basename "$0"`
45 |
46 | # Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
47 | DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
48 |
49 | # Use the maximum available, or set MAX_FD != -1 to use that value.
50 | MAX_FD="maximum"
51 |
52 | warn () {
53 | echo "$*"
54 | }
55 |
56 | die () {
57 | echo
58 | echo "$*"
59 | echo
60 | exit 1
61 | }
62 |
63 | # OS specific support (must be 'true' or 'false').
64 | cygwin=false
65 | msys=false
66 | darwin=false
67 | nonstop=false
68 | case "`uname`" in
69 | CYGWIN* )
70 | cygwin=true
71 | ;;
72 | Darwin* )
73 | darwin=true
74 | ;;
75 | MINGW* )
76 | msys=true
77 | ;;
78 | NONSTOP* )
79 | nonstop=true
80 | ;;
81 | esac
82 |
83 | CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
84 |
85 | # Determine the Java command to use to start the JVM.
86 | if [ -n "$JAVA_HOME" ] ; then
87 | if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
88 | # IBM's JDK on AIX uses strange locations for the executables
89 | JAVACMD="$JAVA_HOME/jre/sh/java"
90 | else
91 | JAVACMD="$JAVA_HOME/bin/java"
92 | fi
93 | if [ ! -x "$JAVACMD" ] ; then
94 | die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
95 |
96 | Please set the JAVA_HOME variable in your environment to match the
97 | location of your Java installation."
98 | fi
99 | else
100 | JAVACMD="java"
101 | which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
102 |
103 | Please set the JAVA_HOME variable in your environment to match the
104 | location of your Java installation."
105 | fi
106 |
107 | # Increase the maximum file descriptors if we can.
108 | if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then
109 | MAX_FD_LIMIT=`ulimit -H -n`
110 | if [ $? -eq 0 ] ; then
111 | if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then
112 | MAX_FD="$MAX_FD_LIMIT"
113 | fi
114 | ulimit -n $MAX_FD
115 | if [ $? -ne 0 ] ; then
116 | warn "Could not set maximum file descriptor limit: $MAX_FD"
117 | fi
118 | else
119 | warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
120 | fi
121 | fi
122 |
123 | # For Darwin, add options to specify how the application appears in the dock
124 | if $darwin; then
125 | GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
126 | fi
127 |
128 | # For Cygwin or MSYS, switch paths to Windows format before running java
129 | if [ "$cygwin" = "true" -o "$msys" = "true" ] ; then
130 | APP_HOME=`cygpath --path --mixed "$APP_HOME"`
131 | CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
132 | JAVACMD=`cygpath --unix "$JAVACMD"`
133 |
134 | # We build the pattern for arguments to be converted via cygpath
135 | ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`
136 | SEP=""
137 | for dir in $ROOTDIRSRAW ; do
138 | ROOTDIRS="$ROOTDIRS$SEP$dir"
139 | SEP="|"
140 | done
141 | OURCYGPATTERN="(^($ROOTDIRS))"
142 | # Add a user-defined pattern to the cygpath arguments
143 | if [ "$GRADLE_CYGPATTERN" != "" ] ; then
144 | OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
145 | fi
146 | # Now convert the arguments - kludge to limit ourselves to /bin/sh
147 | i=0
148 | for arg in "$@" ; do
149 | CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -`
150 | CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option
151 |
152 | if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition
153 | eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"`
154 | else
155 | eval `echo args$i`="\"$arg\""
156 | fi
157 | i=`expr $i + 1`
158 | done
159 | case $i in
160 | 0) set -- ;;
161 | 1) set -- "$args0" ;;
162 | 2) set -- "$args0" "$args1" ;;
163 | 3) set -- "$args0" "$args1" "$args2" ;;
164 | 4) set -- "$args0" "$args1" "$args2" "$args3" ;;
165 | 5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
166 | 6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
167 | 7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
168 | 8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
169 | 9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
170 | esac
171 | fi
172 |
173 | # Escape application args
174 | save () {
175 | for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done
176 | echo " "
177 | }
178 | APP_ARGS=`save "$@"`
179 |
180 | # Collect all arguments for the java command, following the shell quoting and substitution rules
181 | eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS"
182 |
183 | exec "$JAVACMD" "$@"
184 |
--------------------------------------------------------------------------------
/android/gradlew.bat:
--------------------------------------------------------------------------------
1 | @rem
2 | @rem Copyright 2015 the original author or authors.
3 | @rem
4 | @rem Licensed under the Apache License, Version 2.0 (the "License");
5 | @rem you may not use this file except in compliance with the License.
6 | @rem You may obtain a copy of the License at
7 | @rem
8 | @rem https://www.apache.org/licenses/LICENSE-2.0
9 | @rem
10 | @rem Unless required by applicable law or agreed to in writing, software
11 | @rem distributed under the License is distributed on an "AS IS" BASIS,
12 | @rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 | @rem See the License for the specific language governing permissions and
14 | @rem limitations under the License.
15 | @rem
16 |
17 | @if "%DEBUG%" == "" @echo off
18 | @rem ##########################################################################
19 | @rem
20 | @rem Gradle startup script for Windows
21 | @rem
22 | @rem ##########################################################################
23 |
24 | @rem Set local scope for the variables with windows NT shell
25 | if "%OS%"=="Windows_NT" setlocal
26 |
27 | set DIRNAME=%~dp0
28 | if "%DIRNAME%" == "" set DIRNAME=.
29 | set APP_BASE_NAME=%~n0
30 | set APP_HOME=%DIRNAME%
31 |
32 | @rem Resolve any "." and ".." in APP_HOME to make it shorter.
33 | for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi
34 |
35 | @rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
36 | set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m"
37 |
38 | @rem Find java.exe
39 | if defined JAVA_HOME goto findJavaFromJavaHome
40 |
41 | set JAVA_EXE=java.exe
42 | %JAVA_EXE% -version >NUL 2>&1
43 | if "%ERRORLEVEL%" == "0" goto init
44 |
45 | echo.
46 | echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
47 | echo.
48 | echo Please set the JAVA_HOME variable in your environment to match the
49 | echo location of your Java installation.
50 |
51 | goto fail
52 |
53 | :findJavaFromJavaHome
54 | set JAVA_HOME=%JAVA_HOME:"=%
55 | set JAVA_EXE=%JAVA_HOME%/bin/java.exe
56 |
57 | if exist "%JAVA_EXE%" goto init
58 |
59 | echo.
60 | echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
61 | echo.
62 | echo Please set the JAVA_HOME variable in your environment to match the
63 | echo location of your Java installation.
64 |
65 | goto fail
66 |
67 | :init
68 | @rem Get command-line arguments, handling Windows variants
69 |
70 | if not "%OS%" == "Windows_NT" goto win9xME_args
71 |
72 | :win9xME_args
73 | @rem Slurp the command line arguments.
74 | set CMD_LINE_ARGS=
75 | set _SKIP=2
76 |
77 | :win9xME_args_slurp
78 | if "x%~1" == "x" goto execute
79 |
80 | set CMD_LINE_ARGS=%*
81 |
82 | :execute
83 | @rem Setup the command line
84 |
85 | set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
86 |
87 | @rem Execute Gradle
88 | "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS%
89 |
90 | :end
91 | @rem End local scope for the variables with windows NT shell
92 | if "%ERRORLEVEL%"=="0" goto mainEnd
93 |
94 | :fail
95 | rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
96 | rem the _cmd.exe /c_ return code!
97 | if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
98 | exit /b 1
99 |
100 | :mainEnd
101 | if "%OS%"=="Windows_NT" endlocal
102 |
103 | :omega
104 |
--------------------------------------------------------------------------------
/android/settings.gradle:
--------------------------------------------------------------------------------
1 | rootProject.name = 'BLEProject'
2 | include ':react-native-ble-plx'
3 | project(':react-native-ble-plx').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-ble-plx/android')
4 | apply from: file("../node_modules/@react-native-community/cli-platform-android/native_modules.gradle"); applyNativeModulesSettingsGradle(settings)
5 | include ':app'
6 |
--------------------------------------------------------------------------------
/app.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "BLEProject",
3 | "displayName": "BLEProject"
4 | }
--------------------------------------------------------------------------------
/babel.config.js:
--------------------------------------------------------------------------------
1 | module.exports = {
2 | presets: ['module:metro-react-native-babel-preset'],
3 | };
4 |
--------------------------------------------------------------------------------
/index.js:
--------------------------------------------------------------------------------
1 | /**
2 | * @format
3 | */
4 |
5 | import {AppRegistry} from 'react-native';
6 | import App from './App';
7 | import {name as appName} from './app.json';
8 |
9 | AppRegistry.registerComponent(appName, () => App);
10 |
--------------------------------------------------------------------------------
/ios/BLEProject-tvOS/Info.plist:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | CFBundleDevelopmentRegion
6 | en
7 | CFBundleExecutable
8 | $(EXECUTABLE_NAME)
9 | CFBundleIdentifier
10 | $(PRODUCT_BUNDLE_IDENTIFIER)
11 | CFBundleInfoDictionaryVersion
12 | 6.0
13 | CFBundleName
14 | $(PRODUCT_NAME)
15 | CFBundlePackageType
16 | APPL
17 | CFBundleShortVersionString
18 | 1.0
19 | CFBundleSignature
20 | ????
21 | CFBundleVersion
22 | 1
23 | LSRequiresIPhoneOS
24 |
25 | NSAppTransportSecurity
26 |
27 | NSExceptionDomains
28 |
29 | localhost
30 |
31 | NSExceptionAllowsInsecureHTTPLoads
32 |
33 |
34 |
35 |
36 | NSLocationWhenInUseUsageDescription
37 |
38 | UILaunchStoryboardName
39 | LaunchScreen
40 | UIRequiredDeviceCapabilities
41 |
42 | armv7
43 |
44 | UISupportedInterfaceOrientations
45 |
46 | UIInterfaceOrientationPortrait
47 | UIInterfaceOrientationLandscapeLeft
48 | UIInterfaceOrientationLandscapeRight
49 |
50 | UIViewControllerBasedStatusBarAppearance
51 |
52 |
53 |
54 |
--------------------------------------------------------------------------------
/ios/BLEProject-tvOSTests/Info.plist:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | CFBundleDevelopmentRegion
6 | en
7 | CFBundleExecutable
8 | $(EXECUTABLE_NAME)
9 | CFBundleIdentifier
10 | $(PRODUCT_BUNDLE_IDENTIFIER)
11 | CFBundleInfoDictionaryVersion
12 | 6.0
13 | CFBundleName
14 | $(PRODUCT_NAME)
15 | CFBundlePackageType
16 | BNDL
17 | CFBundleShortVersionString
18 | 1.0
19 | CFBundleSignature
20 | ????
21 | CFBundleVersion
22 | 1
23 |
24 |
25 |
--------------------------------------------------------------------------------
/ios/BLEProject.xcodeproj/project.pbxproj:
--------------------------------------------------------------------------------
1 | // !$*UTF8*$!
2 | {
3 | archiveVersion = 1;
4 | classes = {
5 | };
6 | objectVersion = 46;
7 | objects = {
8 |
9 | /* Begin PBXBuildFile section */
10 | 00E356F31AD99517003FC87E /* BLEProjectTests.m in Sources */ = {isa = PBXBuildFile; fileRef = 00E356F21AD99517003FC87E /* BLEProjectTests.m */; };
11 | 13B07FBC1A68108700A75B9A /* AppDelegate.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB01A68108700A75B9A /* AppDelegate.m */; };
12 | 13B07FBF1A68108700A75B9A /* Images.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 13B07FB51A68108700A75B9A /* Images.xcassets */; };
13 | 13B07FC11A68108700A75B9A /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB71A68108700A75B9A /* main.m */; };
14 | 2D02E4BC1E0B4A80006451C7 /* AppDelegate.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB01A68108700A75B9A /* AppDelegate.m */; };
15 | 2D02E4BD1E0B4A84006451C7 /* Images.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 13B07FB51A68108700A75B9A /* Images.xcassets */; };
16 | 2D02E4BF1E0B4AB3006451C7 /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB71A68108700A75B9A /* main.m */; };
17 | 2DCD954D1E0B4F2C00145EB5 /* BLEProjectTests.m in Sources */ = {isa = PBXBuildFile; fileRef = 00E356F21AD99517003FC87E /* BLEProjectTests.m */; };
18 | 416380E5732FCCA614EF7B8F /* libPods-BLEProject-BLEProjectTests.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 7F5240DC6D79B696E82896E8 /* libPods-BLEProject-BLEProjectTests.a */; };
19 | 6EC9ED7BA27755964D5002ED /* libPods-BLEProject-tvOS.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 51E578D5D2E2B7950A2CC628 /* libPods-BLEProject-tvOS.a */; };
20 | 81AB9BB82411601600AC10FF /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 81AB9BB72411601600AC10FF /* LaunchScreen.storyboard */; };
21 | DEF54F674A9125173606E3BB /* libPods-BLEProject-tvOSTests.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 41971A93B96FD5B171110699 /* libPods-BLEProject-tvOSTests.a */; };
22 | F92F8EBD42308890FBBBF235 /* libPods-BLEProject.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 38D8EEC7404C26F66BF138FD /* libPods-BLEProject.a */; };
23 | /* End PBXBuildFile section */
24 |
25 | /* Begin PBXContainerItemProxy section */
26 | 00E356F41AD99517003FC87E /* PBXContainerItemProxy */ = {
27 | isa = PBXContainerItemProxy;
28 | containerPortal = 83CBB9F71A601CBA00E9B192 /* Project object */;
29 | proxyType = 1;
30 | remoteGlobalIDString = 13B07F861A680F5B00A75B9A;
31 | remoteInfo = BLEProject;
32 | };
33 | 2D02E4911E0B4A5D006451C7 /* PBXContainerItemProxy */ = {
34 | isa = PBXContainerItemProxy;
35 | containerPortal = 83CBB9F71A601CBA00E9B192 /* Project object */;
36 | proxyType = 1;
37 | remoteGlobalIDString = 2D02E47A1E0B4A5D006451C7;
38 | remoteInfo = "BLEProject-tvOS";
39 | };
40 | /* End PBXContainerItemProxy section */
41 |
42 | /* Begin PBXFileReference section */
43 | 008F07F21AC5B25A0029DE68 /* main.jsbundle */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = main.jsbundle; sourceTree = ""; };
44 | 00E356EE1AD99517003FC87E /* BLEProjectTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = BLEProjectTests.xctest; sourceTree = BUILT_PRODUCTS_DIR; };
45 | 00E356F11AD99517003FC87E /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; };
46 | 00E356F21AD99517003FC87E /* BLEProjectTests.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = BLEProjectTests.m; sourceTree = ""; };
47 | 13B07F961A680F5B00A75B9A /* BLEProject.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = BLEProject.app; sourceTree = BUILT_PRODUCTS_DIR; };
48 | 13B07FAF1A68108700A75B9A /* AppDelegate.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = AppDelegate.h; path = BLEProject/AppDelegate.h; sourceTree = ""; };
49 | 13B07FB01A68108700A75B9A /* AppDelegate.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = AppDelegate.m; path = BLEProject/AppDelegate.m; sourceTree = ""; };
50 | 13B07FB51A68108700A75B9A /* Images.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; name = Images.xcassets; path = BLEProject/Images.xcassets; sourceTree = ""; };
51 | 13B07FB61A68108700A75B9A /* Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = Info.plist; path = BLEProject/Info.plist; sourceTree = ""; };
52 | 13B07FB71A68108700A75B9A /* main.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = main.m; path = BLEProject/main.m; sourceTree = ""; };
53 | 1EB0D253A4D8565CD21ACAAF /* Pods-BLEProject.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-BLEProject.release.xcconfig"; path = "Target Support Files/Pods-BLEProject/Pods-BLEProject.release.xcconfig"; sourceTree = ""; };
54 | 2D02E47B1E0B4A5D006451C7 /* BLEProject-tvOS.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = "BLEProject-tvOS.app"; sourceTree = BUILT_PRODUCTS_DIR; };
55 | 2D02E4901E0B4A5D006451C7 /* BLEProject-tvOSTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = "BLEProject-tvOSTests.xctest"; sourceTree = BUILT_PRODUCTS_DIR; };
56 | 388FF1BBDEC1B3214B386960 /* Pods-BLEProject-tvOSTests.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-BLEProject-tvOSTests.debug.xcconfig"; path = "Target Support Files/Pods-BLEProject-tvOSTests/Pods-BLEProject-tvOSTests.debug.xcconfig"; sourceTree = ""; };
57 | 38D8EEC7404C26F66BF138FD /* libPods-BLEProject.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = "libPods-BLEProject.a"; sourceTree = BUILT_PRODUCTS_DIR; };
58 | 41971A93B96FD5B171110699 /* libPods-BLEProject-tvOSTests.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = "libPods-BLEProject-tvOSTests.a"; sourceTree = BUILT_PRODUCTS_DIR; };
59 | 4E4621380D0698DF86301C69 /* Pods-BLEProject-tvOSTests.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-BLEProject-tvOSTests.release.xcconfig"; path = "Target Support Files/Pods-BLEProject-tvOSTests/Pods-BLEProject-tvOSTests.release.xcconfig"; sourceTree = ""; };
60 | 51E578D5D2E2B7950A2CC628 /* libPods-BLEProject-tvOS.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = "libPods-BLEProject-tvOS.a"; sourceTree = BUILT_PRODUCTS_DIR; };
61 | 7F5240DC6D79B696E82896E8 /* libPods-BLEProject-BLEProjectTests.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = "libPods-BLEProject-BLEProjectTests.a"; sourceTree = BUILT_PRODUCTS_DIR; };
62 | 81AB9BB72411601600AC10FF /* LaunchScreen.storyboard */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = file.storyboard; name = LaunchScreen.storyboard; path = BLEProject/LaunchScreen.storyboard; sourceTree = ""; };
63 | A9130F925F35B29CFEF53469 /* Pods-BLEProject-tvOS.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-BLEProject-tvOS.debug.xcconfig"; path = "Target Support Files/Pods-BLEProject-tvOS/Pods-BLEProject-tvOS.debug.xcconfig"; sourceTree = ""; };
64 | CD62F04E09F3A65D06C794F6 /* Pods-BLEProject-BLEProjectTests.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-BLEProject-BLEProjectTests.debug.xcconfig"; path = "Target Support Files/Pods-BLEProject-BLEProjectTests/Pods-BLEProject-BLEProjectTests.debug.xcconfig"; sourceTree = ""; };
65 | D9F2465010A903040D078FB1 /* Pods-BLEProject-tvOS.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-BLEProject-tvOS.release.xcconfig"; path = "Target Support Files/Pods-BLEProject-tvOS/Pods-BLEProject-tvOS.release.xcconfig"; sourceTree = ""; };
66 | E64ACA038C2A90BD64C2810C /* Pods-BLEProject.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-BLEProject.debug.xcconfig"; path = "Target Support Files/Pods-BLEProject/Pods-BLEProject.debug.xcconfig"; sourceTree = ""; };
67 | ED297162215061F000B7C4FE /* JavaScriptCore.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = JavaScriptCore.framework; path = System/Library/Frameworks/JavaScriptCore.framework; sourceTree = SDKROOT; };
68 | ED2971642150620600B7C4FE /* JavaScriptCore.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = JavaScriptCore.framework; path = Platforms/AppleTVOS.platform/Developer/SDKs/AppleTVOS12.0.sdk/System/Library/Frameworks/JavaScriptCore.framework; sourceTree = DEVELOPER_DIR; };
69 | F0F9DC077A1926CB677286A0 /* Pods-BLEProject-BLEProjectTests.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-BLEProject-BLEProjectTests.release.xcconfig"; path = "Target Support Files/Pods-BLEProject-BLEProjectTests/Pods-BLEProject-BLEProjectTests.release.xcconfig"; sourceTree = ""; };
70 | /* End PBXFileReference section */
71 |
72 | /* Begin PBXFrameworksBuildPhase section */
73 | 00E356EB1AD99517003FC87E /* Frameworks */ = {
74 | isa = PBXFrameworksBuildPhase;
75 | buildActionMask = 2147483647;
76 | files = (
77 | 416380E5732FCCA614EF7B8F /* libPods-BLEProject-BLEProjectTests.a in Frameworks */,
78 | );
79 | runOnlyForDeploymentPostprocessing = 0;
80 | };
81 | 13B07F8C1A680F5B00A75B9A /* Frameworks */ = {
82 | isa = PBXFrameworksBuildPhase;
83 | buildActionMask = 2147483647;
84 | files = (
85 | F92F8EBD42308890FBBBF235 /* libPods-BLEProject.a in Frameworks */,
86 | );
87 | runOnlyForDeploymentPostprocessing = 0;
88 | };
89 | 2D02E4781E0B4A5D006451C7 /* Frameworks */ = {
90 | isa = PBXFrameworksBuildPhase;
91 | buildActionMask = 2147483647;
92 | files = (
93 | 6EC9ED7BA27755964D5002ED /* libPods-BLEProject-tvOS.a in Frameworks */,
94 | );
95 | runOnlyForDeploymentPostprocessing = 0;
96 | };
97 | 2D02E48D1E0B4A5D006451C7 /* Frameworks */ = {
98 | isa = PBXFrameworksBuildPhase;
99 | buildActionMask = 2147483647;
100 | files = (
101 | DEF54F674A9125173606E3BB /* libPods-BLEProject-tvOSTests.a in Frameworks */,
102 | );
103 | runOnlyForDeploymentPostprocessing = 0;
104 | };
105 | /* End PBXFrameworksBuildPhase section */
106 |
107 | /* Begin PBXGroup section */
108 | 00E356EF1AD99517003FC87E /* BLEProjectTests */ = {
109 | isa = PBXGroup;
110 | children = (
111 | 00E356F21AD99517003FC87E /* BLEProjectTests.m */,
112 | 00E356F01AD99517003FC87E /* Supporting Files */,
113 | );
114 | path = BLEProjectTests;
115 | sourceTree = "";
116 | };
117 | 00E356F01AD99517003FC87E /* Supporting Files */ = {
118 | isa = PBXGroup;
119 | children = (
120 | 00E356F11AD99517003FC87E /* Info.plist */,
121 | );
122 | name = "Supporting Files";
123 | sourceTree = "";
124 | };
125 | 13B07FAE1A68108700A75B9A /* BLEProject */ = {
126 | isa = PBXGroup;
127 | children = (
128 | 008F07F21AC5B25A0029DE68 /* main.jsbundle */,
129 | 13B07FAF1A68108700A75B9A /* AppDelegate.h */,
130 | 13B07FB01A68108700A75B9A /* AppDelegate.m */,
131 | 13B07FB51A68108700A75B9A /* Images.xcassets */,
132 | 13B07FB61A68108700A75B9A /* Info.plist */,
133 | 81AB9BB72411601600AC10FF /* LaunchScreen.storyboard */,
134 | 13B07FB71A68108700A75B9A /* main.m */,
135 | );
136 | name = BLEProject;
137 | sourceTree = "";
138 | };
139 | 2D16E6871FA4F8E400B85C8A /* Frameworks */ = {
140 | isa = PBXGroup;
141 | children = (
142 | ED297162215061F000B7C4FE /* JavaScriptCore.framework */,
143 | ED2971642150620600B7C4FE /* JavaScriptCore.framework */,
144 | 38D8EEC7404C26F66BF138FD /* libPods-BLEProject.a */,
145 | 7F5240DC6D79B696E82896E8 /* libPods-BLEProject-BLEProjectTests.a */,
146 | 51E578D5D2E2B7950A2CC628 /* libPods-BLEProject-tvOS.a */,
147 | 41971A93B96FD5B171110699 /* libPods-BLEProject-tvOSTests.a */,
148 | );
149 | name = Frameworks;
150 | sourceTree = "";
151 | };
152 | 832341AE1AAA6A7D00B99B32 /* Libraries */ = {
153 | isa = PBXGroup;
154 | children = (
155 | );
156 | name = Libraries;
157 | sourceTree = "";
158 | };
159 | 83CBB9F61A601CBA00E9B192 = {
160 | isa = PBXGroup;
161 | children = (
162 | 13B07FAE1A68108700A75B9A /* BLEProject */,
163 | 832341AE1AAA6A7D00B99B32 /* Libraries */,
164 | 00E356EF1AD99517003FC87E /* BLEProjectTests */,
165 | 83CBBA001A601CBA00E9B192 /* Products */,
166 | 2D16E6871FA4F8E400B85C8A /* Frameworks */,
167 | 99B62500816CD6FCD9B16C1A /* Pods */,
168 | );
169 | indentWidth = 2;
170 | sourceTree = "";
171 | tabWidth = 2;
172 | usesTabs = 0;
173 | };
174 | 83CBBA001A601CBA00E9B192 /* Products */ = {
175 | isa = PBXGroup;
176 | children = (
177 | 13B07F961A680F5B00A75B9A /* BLEProject.app */,
178 | 00E356EE1AD99517003FC87E /* BLEProjectTests.xctest */,
179 | 2D02E47B1E0B4A5D006451C7 /* BLEProject-tvOS.app */,
180 | 2D02E4901E0B4A5D006451C7 /* BLEProject-tvOSTests.xctest */,
181 | );
182 | name = Products;
183 | sourceTree = "";
184 | };
185 | 99B62500816CD6FCD9B16C1A /* Pods */ = {
186 | isa = PBXGroup;
187 | children = (
188 | E64ACA038C2A90BD64C2810C /* Pods-BLEProject.debug.xcconfig */,
189 | 1EB0D253A4D8565CD21ACAAF /* Pods-BLEProject.release.xcconfig */,
190 | CD62F04E09F3A65D06C794F6 /* Pods-BLEProject-BLEProjectTests.debug.xcconfig */,
191 | F0F9DC077A1926CB677286A0 /* Pods-BLEProject-BLEProjectTests.release.xcconfig */,
192 | A9130F925F35B29CFEF53469 /* Pods-BLEProject-tvOS.debug.xcconfig */,
193 | D9F2465010A903040D078FB1 /* Pods-BLEProject-tvOS.release.xcconfig */,
194 | 388FF1BBDEC1B3214B386960 /* Pods-BLEProject-tvOSTests.debug.xcconfig */,
195 | 4E4621380D0698DF86301C69 /* Pods-BLEProject-tvOSTests.release.xcconfig */,
196 | );
197 | name = Pods;
198 | path = Pods;
199 | sourceTree = "";
200 | };
201 | /* End PBXGroup section */
202 |
203 | /* Begin PBXNativeTarget section */
204 | 00E356ED1AD99517003FC87E /* BLEProjectTests */ = {
205 | isa = PBXNativeTarget;
206 | buildConfigurationList = 00E357021AD99517003FC87E /* Build configuration list for PBXNativeTarget "BLEProjectTests" */;
207 | buildPhases = (
208 | BA5B4007093C1218BEDA935F /* [CP] Check Pods Manifest.lock */,
209 | 00E356EA1AD99517003FC87E /* Sources */,
210 | 00E356EB1AD99517003FC87E /* Frameworks */,
211 | 00E356EC1AD99517003FC87E /* Resources */,
212 | 23C77971F69A911167A41AFC /* [CP] Copy Pods Resources */,
213 | );
214 | buildRules = (
215 | );
216 | dependencies = (
217 | 00E356F51AD99517003FC87E /* PBXTargetDependency */,
218 | );
219 | name = BLEProjectTests;
220 | productName = BLEProjectTests;
221 | productReference = 00E356EE1AD99517003FC87E /* BLEProjectTests.xctest */;
222 | productType = "com.apple.product-type.bundle.unit-test";
223 | };
224 | 13B07F861A680F5B00A75B9A /* BLEProject */ = {
225 | isa = PBXNativeTarget;
226 | buildConfigurationList = 13B07F931A680F5B00A75B9A /* Build configuration list for PBXNativeTarget "BLEProject" */;
227 | buildPhases = (
228 | F653A7F453CFA26573A91318 /* [CP] Check Pods Manifest.lock */,
229 | FD10A7F022414F080027D42C /* Start Packager */,
230 | 13B07F871A680F5B00A75B9A /* Sources */,
231 | 13B07F8C1A680F5B00A75B9A /* Frameworks */,
232 | 13B07F8E1A680F5B00A75B9A /* Resources */,
233 | 00DD1BFF1BD5951E006B06BC /* Bundle React Native code and images */,
234 | 2046C227EAE113027EC6EBD8 /* [CP] Copy Pods Resources */,
235 | );
236 | buildRules = (
237 | );
238 | dependencies = (
239 | );
240 | name = BLEProject;
241 | productName = BLEProject;
242 | productReference = 13B07F961A680F5B00A75B9A /* BLEProject.app */;
243 | productType = "com.apple.product-type.application";
244 | };
245 | 2D02E47A1E0B4A5D006451C7 /* BLEProject-tvOS */ = {
246 | isa = PBXNativeTarget;
247 | buildConfigurationList = 2D02E4BA1E0B4A5E006451C7 /* Build configuration list for PBXNativeTarget "BLEProject-tvOS" */;
248 | buildPhases = (
249 | 3D8DB5DBFE77EDE5AD8CD54A /* [CP] Check Pods Manifest.lock */,
250 | FD10A7F122414F3F0027D42C /* Start Packager */,
251 | 2D02E4771E0B4A5D006451C7 /* Sources */,
252 | 2D02E4781E0B4A5D006451C7 /* Frameworks */,
253 | 2D02E4791E0B4A5D006451C7 /* Resources */,
254 | 2D02E4CB1E0B4B27006451C7 /* Bundle React Native Code And Images */,
255 | );
256 | buildRules = (
257 | );
258 | dependencies = (
259 | );
260 | name = "BLEProject-tvOS";
261 | productName = "BLEProject-tvOS";
262 | productReference = 2D02E47B1E0B4A5D006451C7 /* BLEProject-tvOS.app */;
263 | productType = "com.apple.product-type.application";
264 | };
265 | 2D02E48F1E0B4A5D006451C7 /* BLEProject-tvOSTests */ = {
266 | isa = PBXNativeTarget;
267 | buildConfigurationList = 2D02E4BB1E0B4A5E006451C7 /* Build configuration list for PBXNativeTarget "BLEProject-tvOSTests" */;
268 | buildPhases = (
269 | BE52ECD45014C817A56430F3 /* [CP] Check Pods Manifest.lock */,
270 | 2D02E48C1E0B4A5D006451C7 /* Sources */,
271 | 2D02E48D1E0B4A5D006451C7 /* Frameworks */,
272 | 2D02E48E1E0B4A5D006451C7 /* Resources */,
273 | );
274 | buildRules = (
275 | );
276 | dependencies = (
277 | 2D02E4921E0B4A5D006451C7 /* PBXTargetDependency */,
278 | );
279 | name = "BLEProject-tvOSTests";
280 | productName = "BLEProject-tvOSTests";
281 | productReference = 2D02E4901E0B4A5D006451C7 /* BLEProject-tvOSTests.xctest */;
282 | productType = "com.apple.product-type.bundle.unit-test";
283 | };
284 | /* End PBXNativeTarget section */
285 |
286 | /* Begin PBXProject section */
287 | 83CBB9F71A601CBA00E9B192 /* Project object */ = {
288 | isa = PBXProject;
289 | attributes = {
290 | LastUpgradeCheck = 1130;
291 | TargetAttributes = {
292 | 00E356ED1AD99517003FC87E = {
293 | CreatedOnToolsVersion = 6.2;
294 | TestTargetID = 13B07F861A680F5B00A75B9A;
295 | };
296 | 13B07F861A680F5B00A75B9A = {
297 | LastSwiftMigration = 1120;
298 | };
299 | 2D02E47A1E0B4A5D006451C7 = {
300 | CreatedOnToolsVersion = 8.2.1;
301 | ProvisioningStyle = Automatic;
302 | };
303 | 2D02E48F1E0B4A5D006451C7 = {
304 | CreatedOnToolsVersion = 8.2.1;
305 | ProvisioningStyle = Automatic;
306 | TestTargetID = 2D02E47A1E0B4A5D006451C7;
307 | };
308 | };
309 | };
310 | buildConfigurationList = 83CBB9FA1A601CBA00E9B192 /* Build configuration list for PBXProject "BLEProject" */;
311 | compatibilityVersion = "Xcode 3.2";
312 | developmentRegion = en;
313 | hasScannedForEncodings = 0;
314 | knownRegions = (
315 | en,
316 | Base,
317 | );
318 | mainGroup = 83CBB9F61A601CBA00E9B192;
319 | productRefGroup = 83CBBA001A601CBA00E9B192 /* Products */;
320 | projectDirPath = "";
321 | projectRoot = "";
322 | targets = (
323 | 13B07F861A680F5B00A75B9A /* BLEProject */,
324 | 00E356ED1AD99517003FC87E /* BLEProjectTests */,
325 | 2D02E47A1E0B4A5D006451C7 /* BLEProject-tvOS */,
326 | 2D02E48F1E0B4A5D006451C7 /* BLEProject-tvOSTests */,
327 | );
328 | };
329 | /* End PBXProject section */
330 |
331 | /* Begin PBXResourcesBuildPhase section */
332 | 00E356EC1AD99517003FC87E /* Resources */ = {
333 | isa = PBXResourcesBuildPhase;
334 | buildActionMask = 2147483647;
335 | files = (
336 | );
337 | runOnlyForDeploymentPostprocessing = 0;
338 | };
339 | 13B07F8E1A680F5B00A75B9A /* Resources */ = {
340 | isa = PBXResourcesBuildPhase;
341 | buildActionMask = 2147483647;
342 | files = (
343 | 81AB9BB82411601600AC10FF /* LaunchScreen.storyboard in Resources */,
344 | 13B07FBF1A68108700A75B9A /* Images.xcassets in Resources */,
345 | );
346 | runOnlyForDeploymentPostprocessing = 0;
347 | };
348 | 2D02E4791E0B4A5D006451C7 /* Resources */ = {
349 | isa = PBXResourcesBuildPhase;
350 | buildActionMask = 2147483647;
351 | files = (
352 | 2D02E4BD1E0B4A84006451C7 /* Images.xcassets in Resources */,
353 | );
354 | runOnlyForDeploymentPostprocessing = 0;
355 | };
356 | 2D02E48E1E0B4A5D006451C7 /* Resources */ = {
357 | isa = PBXResourcesBuildPhase;
358 | buildActionMask = 2147483647;
359 | files = (
360 | );
361 | runOnlyForDeploymentPostprocessing = 0;
362 | };
363 | /* End PBXResourcesBuildPhase section */
364 |
365 | /* Begin PBXShellScriptBuildPhase section */
366 | 00DD1BFF1BD5951E006B06BC /* Bundle React Native code and images */ = {
367 | isa = PBXShellScriptBuildPhase;
368 | buildActionMask = 2147483647;
369 | files = (
370 | );
371 | inputPaths = (
372 | );
373 | name = "Bundle React Native code and images";
374 | outputPaths = (
375 | );
376 | runOnlyForDeploymentPostprocessing = 0;
377 | shellPath = /bin/sh;
378 | shellScript = "export NODE_BINARY=node\n../node_modules/react-native/scripts/react-native-xcode.sh";
379 | };
380 | 2046C227EAE113027EC6EBD8 /* [CP] Copy Pods Resources */ = {
381 | isa = PBXShellScriptBuildPhase;
382 | buildActionMask = 2147483647;
383 | files = (
384 | );
385 | inputPaths = (
386 | "${PODS_ROOT}/Target Support Files/Pods-BLEProject/Pods-BLEProject-resources.sh",
387 | "${PODS_CONFIGURATION_BUILD_DIR}/React-Core/AccessibilityResources.bundle",
388 | );
389 | name = "[CP] Copy Pods Resources";
390 | outputPaths = (
391 | "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/AccessibilityResources.bundle",
392 | );
393 | runOnlyForDeploymentPostprocessing = 0;
394 | shellPath = /bin/sh;
395 | shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-BLEProject/Pods-BLEProject-resources.sh\"\n";
396 | showEnvVarsInLog = 0;
397 | };
398 | 23C77971F69A911167A41AFC /* [CP] Copy Pods Resources */ = {
399 | isa = PBXShellScriptBuildPhase;
400 | buildActionMask = 2147483647;
401 | files = (
402 | );
403 | inputPaths = (
404 | "${PODS_ROOT}/Target Support Files/Pods-BLEProject-BLEProjectTests/Pods-BLEProject-BLEProjectTests-resources.sh",
405 | "${PODS_CONFIGURATION_BUILD_DIR}/React-Core/AccessibilityResources.bundle",
406 | );
407 | name = "[CP] Copy Pods Resources";
408 | outputPaths = (
409 | "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/AccessibilityResources.bundle",
410 | );
411 | runOnlyForDeploymentPostprocessing = 0;
412 | shellPath = /bin/sh;
413 | shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-BLEProject-BLEProjectTests/Pods-BLEProject-BLEProjectTests-resources.sh\"\n";
414 | showEnvVarsInLog = 0;
415 | };
416 | 2D02E4CB1E0B4B27006451C7 /* Bundle React Native Code And Images */ = {
417 | isa = PBXShellScriptBuildPhase;
418 | buildActionMask = 2147483647;
419 | files = (
420 | );
421 | inputPaths = (
422 | );
423 | name = "Bundle React Native Code And Images";
424 | outputPaths = (
425 | );
426 | runOnlyForDeploymentPostprocessing = 0;
427 | shellPath = /bin/sh;
428 | shellScript = "export NODE_BINARY=node\n../node_modules/react-native/scripts/react-native-xcode.sh";
429 | };
430 | 3D8DB5DBFE77EDE5AD8CD54A /* [CP] Check Pods Manifest.lock */ = {
431 | isa = PBXShellScriptBuildPhase;
432 | buildActionMask = 2147483647;
433 | files = (
434 | );
435 | inputFileListPaths = (
436 | );
437 | inputPaths = (
438 | "${PODS_PODFILE_DIR_PATH}/Podfile.lock",
439 | "${PODS_ROOT}/Manifest.lock",
440 | );
441 | name = "[CP] Check Pods Manifest.lock";
442 | outputFileListPaths = (
443 | );
444 | outputPaths = (
445 | "$(DERIVED_FILE_DIR)/Pods-BLEProject-tvOS-checkManifestLockResult.txt",
446 | );
447 | runOnlyForDeploymentPostprocessing = 0;
448 | shellPath = /bin/sh;
449 | 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";
450 | showEnvVarsInLog = 0;
451 | };
452 | BA5B4007093C1218BEDA935F /* [CP] Check Pods Manifest.lock */ = {
453 | isa = PBXShellScriptBuildPhase;
454 | buildActionMask = 2147483647;
455 | files = (
456 | );
457 | inputFileListPaths = (
458 | );
459 | inputPaths = (
460 | "${PODS_PODFILE_DIR_PATH}/Podfile.lock",
461 | "${PODS_ROOT}/Manifest.lock",
462 | );
463 | name = "[CP] Check Pods Manifest.lock";
464 | outputFileListPaths = (
465 | );
466 | outputPaths = (
467 | "$(DERIVED_FILE_DIR)/Pods-BLEProject-BLEProjectTests-checkManifestLockResult.txt",
468 | );
469 | runOnlyForDeploymentPostprocessing = 0;
470 | shellPath = /bin/sh;
471 | 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";
472 | showEnvVarsInLog = 0;
473 | };
474 | BE52ECD45014C817A56430F3 /* [CP] Check Pods Manifest.lock */ = {
475 | isa = PBXShellScriptBuildPhase;
476 | buildActionMask = 2147483647;
477 | files = (
478 | );
479 | inputFileListPaths = (
480 | );
481 | inputPaths = (
482 | "${PODS_PODFILE_DIR_PATH}/Podfile.lock",
483 | "${PODS_ROOT}/Manifest.lock",
484 | );
485 | name = "[CP] Check Pods Manifest.lock";
486 | outputFileListPaths = (
487 | );
488 | outputPaths = (
489 | "$(DERIVED_FILE_DIR)/Pods-BLEProject-tvOSTests-checkManifestLockResult.txt",
490 | );
491 | runOnlyForDeploymentPostprocessing = 0;
492 | shellPath = /bin/sh;
493 | 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";
494 | showEnvVarsInLog = 0;
495 | };
496 | F653A7F453CFA26573A91318 /* [CP] Check Pods Manifest.lock */ = {
497 | isa = PBXShellScriptBuildPhase;
498 | buildActionMask = 2147483647;
499 | files = (
500 | );
501 | inputFileListPaths = (
502 | );
503 | inputPaths = (
504 | "${PODS_PODFILE_DIR_PATH}/Podfile.lock",
505 | "${PODS_ROOT}/Manifest.lock",
506 | );
507 | name = "[CP] Check Pods Manifest.lock";
508 | outputFileListPaths = (
509 | );
510 | outputPaths = (
511 | "$(DERIVED_FILE_DIR)/Pods-BLEProject-checkManifestLockResult.txt",
512 | );
513 | runOnlyForDeploymentPostprocessing = 0;
514 | shellPath = /bin/sh;
515 | 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";
516 | showEnvVarsInLog = 0;
517 | };
518 | FD10A7F022414F080027D42C /* Start Packager */ = {
519 | isa = PBXShellScriptBuildPhase;
520 | buildActionMask = 2147483647;
521 | files = (
522 | );
523 | inputFileListPaths = (
524 | );
525 | inputPaths = (
526 | );
527 | name = "Start Packager";
528 | outputFileListPaths = (
529 | );
530 | outputPaths = (
531 | );
532 | runOnlyForDeploymentPostprocessing = 0;
533 | shellPath = /bin/sh;
534 | 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";
535 | showEnvVarsInLog = 0;
536 | };
537 | FD10A7F122414F3F0027D42C /* Start Packager */ = {
538 | isa = PBXShellScriptBuildPhase;
539 | buildActionMask = 2147483647;
540 | files = (
541 | );
542 | inputFileListPaths = (
543 | );
544 | inputPaths = (
545 | );
546 | name = "Start Packager";
547 | outputFileListPaths = (
548 | );
549 | outputPaths = (
550 | );
551 | runOnlyForDeploymentPostprocessing = 0;
552 | shellPath = /bin/sh;
553 | 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";
554 | showEnvVarsInLog = 0;
555 | };
556 | /* End PBXShellScriptBuildPhase section */
557 |
558 | /* Begin PBXSourcesBuildPhase section */
559 | 00E356EA1AD99517003FC87E /* Sources */ = {
560 | isa = PBXSourcesBuildPhase;
561 | buildActionMask = 2147483647;
562 | files = (
563 | 00E356F31AD99517003FC87E /* BLEProjectTests.m in Sources */,
564 | );
565 | runOnlyForDeploymentPostprocessing = 0;
566 | };
567 | 13B07F871A680F5B00A75B9A /* Sources */ = {
568 | isa = PBXSourcesBuildPhase;
569 | buildActionMask = 2147483647;
570 | files = (
571 | 13B07FBC1A68108700A75B9A /* AppDelegate.m in Sources */,
572 | 13B07FC11A68108700A75B9A /* main.m in Sources */,
573 | );
574 | runOnlyForDeploymentPostprocessing = 0;
575 | };
576 | 2D02E4771E0B4A5D006451C7 /* Sources */ = {
577 | isa = PBXSourcesBuildPhase;
578 | buildActionMask = 2147483647;
579 | files = (
580 | 2D02E4BF1E0B4AB3006451C7 /* main.m in Sources */,
581 | 2D02E4BC1E0B4A80006451C7 /* AppDelegate.m in Sources */,
582 | );
583 | runOnlyForDeploymentPostprocessing = 0;
584 | };
585 | 2D02E48C1E0B4A5D006451C7 /* Sources */ = {
586 | isa = PBXSourcesBuildPhase;
587 | buildActionMask = 2147483647;
588 | files = (
589 | 2DCD954D1E0B4F2C00145EB5 /* BLEProjectTests.m in Sources */,
590 | );
591 | runOnlyForDeploymentPostprocessing = 0;
592 | };
593 | /* End PBXSourcesBuildPhase section */
594 |
595 | /* Begin PBXTargetDependency section */
596 | 00E356F51AD99517003FC87E /* PBXTargetDependency */ = {
597 | isa = PBXTargetDependency;
598 | target = 13B07F861A680F5B00A75B9A /* BLEProject */;
599 | targetProxy = 00E356F41AD99517003FC87E /* PBXContainerItemProxy */;
600 | };
601 | 2D02E4921E0B4A5D006451C7 /* PBXTargetDependency */ = {
602 | isa = PBXTargetDependency;
603 | target = 2D02E47A1E0B4A5D006451C7 /* BLEProject-tvOS */;
604 | targetProxy = 2D02E4911E0B4A5D006451C7 /* PBXContainerItemProxy */;
605 | };
606 | /* End PBXTargetDependency section */
607 |
608 | /* Begin XCBuildConfiguration section */
609 | 00E356F61AD99517003FC87E /* Debug */ = {
610 | isa = XCBuildConfiguration;
611 | baseConfigurationReference = CD62F04E09F3A65D06C794F6 /* Pods-BLEProject-BLEProjectTests.debug.xcconfig */;
612 | buildSettings = {
613 | BUNDLE_LOADER = "$(TEST_HOST)";
614 | GCC_PREPROCESSOR_DEFINITIONS = (
615 | "DEBUG=1",
616 | "$(inherited)",
617 | );
618 | INFOPLIST_FILE = BLEProjectTests/Info.plist;
619 | IPHONEOS_DEPLOYMENT_TARGET = 10.0;
620 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
621 | OTHER_LDFLAGS = (
622 | "-ObjC",
623 | "-lc++",
624 | "$(inherited)",
625 | );
626 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)";
627 | PRODUCT_NAME = "$(TARGET_NAME)";
628 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/BLEProject.app/BLEProject";
629 | };
630 | name = Debug;
631 | };
632 | 00E356F71AD99517003FC87E /* Release */ = {
633 | isa = XCBuildConfiguration;
634 | baseConfigurationReference = F0F9DC077A1926CB677286A0 /* Pods-BLEProject-BLEProjectTests.release.xcconfig */;
635 | buildSettings = {
636 | BUNDLE_LOADER = "$(TEST_HOST)";
637 | COPY_PHASE_STRIP = NO;
638 | INFOPLIST_FILE = BLEProjectTests/Info.plist;
639 | IPHONEOS_DEPLOYMENT_TARGET = 10.0;
640 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
641 | OTHER_LDFLAGS = (
642 | "-ObjC",
643 | "-lc++",
644 | "$(inherited)",
645 | );
646 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)";
647 | PRODUCT_NAME = "$(TARGET_NAME)";
648 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/BLEProject.app/BLEProject";
649 | };
650 | name = Release;
651 | };
652 | 13B07F941A680F5B00A75B9A /* Debug */ = {
653 | isa = XCBuildConfiguration;
654 | baseConfigurationReference = E64ACA038C2A90BD64C2810C /* Pods-BLEProject.debug.xcconfig */;
655 | buildSettings = {
656 | ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
657 | CLANG_ENABLE_MODULES = YES;
658 | CURRENT_PROJECT_VERSION = 1;
659 | ENABLE_BITCODE = NO;
660 | INFOPLIST_FILE = BLEProject/Info.plist;
661 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
662 | OTHER_LDFLAGS = (
663 | "$(inherited)",
664 | "-ObjC",
665 | "-lc++",
666 | );
667 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)";
668 | PRODUCT_NAME = BLEProject;
669 | SWIFT_OPTIMIZATION_LEVEL = "-Onone";
670 | SWIFT_VERSION = 5.0;
671 | VERSIONING_SYSTEM = "apple-generic";
672 | };
673 | name = Debug;
674 | };
675 | 13B07F951A680F5B00A75B9A /* Release */ = {
676 | isa = XCBuildConfiguration;
677 | baseConfigurationReference = 1EB0D253A4D8565CD21ACAAF /* Pods-BLEProject.release.xcconfig */;
678 | buildSettings = {
679 | ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
680 | CLANG_ENABLE_MODULES = YES;
681 | CURRENT_PROJECT_VERSION = 1;
682 | INFOPLIST_FILE = BLEProject/Info.plist;
683 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
684 | OTHER_LDFLAGS = (
685 | "$(inherited)",
686 | "-ObjC",
687 | "-lc++",
688 | );
689 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)";
690 | PRODUCT_NAME = BLEProject;
691 | SWIFT_VERSION = 5.0;
692 | VERSIONING_SYSTEM = "apple-generic";
693 | };
694 | name = Release;
695 | };
696 | 2D02E4971E0B4A5E006451C7 /* Debug */ = {
697 | isa = XCBuildConfiguration;
698 | baseConfigurationReference = A9130F925F35B29CFEF53469 /* Pods-BLEProject-tvOS.debug.xcconfig */;
699 | buildSettings = {
700 | ASSETCATALOG_COMPILER_APPICON_NAME = "App Icon & Top Shelf Image";
701 | ASSETCATALOG_COMPILER_LAUNCHIMAGE_NAME = LaunchImage;
702 | CLANG_ANALYZER_NONNULL = YES;
703 | CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
704 | CLANG_WARN_INFINITE_RECURSION = YES;
705 | CLANG_WARN_SUSPICIOUS_MOVE = YES;
706 | DEBUG_INFORMATION_FORMAT = dwarf;
707 | ENABLE_TESTABILITY = YES;
708 | GCC_NO_COMMON_BLOCKS = YES;
709 | INFOPLIST_FILE = "BLEProject-tvOS/Info.plist";
710 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
711 | OTHER_LDFLAGS = (
712 | "$(inherited)",
713 | "-ObjC",
714 | "-lc++",
715 | );
716 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.BLEProject-tvOS";
717 | PRODUCT_NAME = "$(TARGET_NAME)";
718 | SDKROOT = appletvos;
719 | TARGETED_DEVICE_FAMILY = 3;
720 | TVOS_DEPLOYMENT_TARGET = 10.0;
721 | };
722 | name = Debug;
723 | };
724 | 2D02E4981E0B4A5E006451C7 /* Release */ = {
725 | isa = XCBuildConfiguration;
726 | baseConfigurationReference = D9F2465010A903040D078FB1 /* Pods-BLEProject-tvOS.release.xcconfig */;
727 | buildSettings = {
728 | ASSETCATALOG_COMPILER_APPICON_NAME = "App Icon & Top Shelf Image";
729 | ASSETCATALOG_COMPILER_LAUNCHIMAGE_NAME = LaunchImage;
730 | CLANG_ANALYZER_NONNULL = YES;
731 | CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
732 | CLANG_WARN_INFINITE_RECURSION = YES;
733 | CLANG_WARN_SUSPICIOUS_MOVE = YES;
734 | COPY_PHASE_STRIP = NO;
735 | DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym";
736 | GCC_NO_COMMON_BLOCKS = YES;
737 | INFOPLIST_FILE = "BLEProject-tvOS/Info.plist";
738 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
739 | OTHER_LDFLAGS = (
740 | "$(inherited)",
741 | "-ObjC",
742 | "-lc++",
743 | );
744 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.BLEProject-tvOS";
745 | PRODUCT_NAME = "$(TARGET_NAME)";
746 | SDKROOT = appletvos;
747 | TARGETED_DEVICE_FAMILY = 3;
748 | TVOS_DEPLOYMENT_TARGET = 10.0;
749 | };
750 | name = Release;
751 | };
752 | 2D02E4991E0B4A5E006451C7 /* Debug */ = {
753 | isa = XCBuildConfiguration;
754 | baseConfigurationReference = 388FF1BBDEC1B3214B386960 /* Pods-BLEProject-tvOSTests.debug.xcconfig */;
755 | buildSettings = {
756 | BUNDLE_LOADER = "$(TEST_HOST)";
757 | CLANG_ANALYZER_NONNULL = YES;
758 | CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
759 | CLANG_WARN_INFINITE_RECURSION = YES;
760 | CLANG_WARN_SUSPICIOUS_MOVE = YES;
761 | DEBUG_INFORMATION_FORMAT = dwarf;
762 | ENABLE_TESTABILITY = YES;
763 | GCC_NO_COMMON_BLOCKS = YES;
764 | INFOPLIST_FILE = "BLEProject-tvOSTests/Info.plist";
765 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
766 | OTHER_LDFLAGS = (
767 | "$(inherited)",
768 | "-ObjC",
769 | "-lc++",
770 | );
771 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.BLEProject-tvOSTests";
772 | PRODUCT_NAME = "$(TARGET_NAME)";
773 | SDKROOT = appletvos;
774 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/BLEProject-tvOS.app/BLEProject-tvOS";
775 | TVOS_DEPLOYMENT_TARGET = 10.1;
776 | };
777 | name = Debug;
778 | };
779 | 2D02E49A1E0B4A5E006451C7 /* Release */ = {
780 | isa = XCBuildConfiguration;
781 | baseConfigurationReference = 4E4621380D0698DF86301C69 /* Pods-BLEProject-tvOSTests.release.xcconfig */;
782 | buildSettings = {
783 | BUNDLE_LOADER = "$(TEST_HOST)";
784 | CLANG_ANALYZER_NONNULL = YES;
785 | CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
786 | CLANG_WARN_INFINITE_RECURSION = YES;
787 | CLANG_WARN_SUSPICIOUS_MOVE = YES;
788 | COPY_PHASE_STRIP = NO;
789 | DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym";
790 | GCC_NO_COMMON_BLOCKS = YES;
791 | INFOPLIST_FILE = "BLEProject-tvOSTests/Info.plist";
792 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
793 | OTHER_LDFLAGS = (
794 | "$(inherited)",
795 | "-ObjC",
796 | "-lc++",
797 | );
798 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.BLEProject-tvOSTests";
799 | PRODUCT_NAME = "$(TARGET_NAME)";
800 | SDKROOT = appletvos;
801 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/BLEProject-tvOS.app/BLEProject-tvOS";
802 | TVOS_DEPLOYMENT_TARGET = 10.1;
803 | };
804 | name = Release;
805 | };
806 | 83CBBA201A601CBA00E9B192 /* Debug */ = {
807 | isa = XCBuildConfiguration;
808 | buildSettings = {
809 | ALWAYS_SEARCH_USER_PATHS = NO;
810 | CLANG_ANALYZER_LOCALIZABILITY_NONLOCALIZED = YES;
811 | CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x";
812 | CLANG_CXX_LIBRARY = "libc++";
813 | CLANG_ENABLE_MODULES = YES;
814 | CLANG_ENABLE_OBJC_ARC = YES;
815 | CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
816 | CLANG_WARN_BOOL_CONVERSION = YES;
817 | CLANG_WARN_COMMA = YES;
818 | CLANG_WARN_CONSTANT_CONVERSION = YES;
819 | CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
820 | CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
821 | CLANG_WARN_EMPTY_BODY = YES;
822 | CLANG_WARN_ENUM_CONVERSION = YES;
823 | CLANG_WARN_INFINITE_RECURSION = YES;
824 | CLANG_WARN_INT_CONVERSION = YES;
825 | CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
826 | CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
827 | CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
828 | CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
829 | CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
830 | CLANG_WARN_STRICT_PROTOTYPES = YES;
831 | CLANG_WARN_SUSPICIOUS_MOVE = YES;
832 | CLANG_WARN_UNREACHABLE_CODE = YES;
833 | CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
834 | "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
835 | COPY_PHASE_STRIP = NO;
836 | ENABLE_STRICT_OBJC_MSGSEND = YES;
837 | ENABLE_TESTABILITY = YES;
838 | GCC_C_LANGUAGE_STANDARD = gnu99;
839 | GCC_DYNAMIC_NO_PIC = NO;
840 | GCC_NO_COMMON_BLOCKS = YES;
841 | GCC_OPTIMIZATION_LEVEL = 0;
842 | GCC_PREPROCESSOR_DEFINITIONS = (
843 | "DEBUG=1",
844 | "$(inherited)",
845 | );
846 | GCC_SYMBOLS_PRIVATE_EXTERN = NO;
847 | GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
848 | GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
849 | GCC_WARN_UNDECLARED_SELECTOR = YES;
850 | GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
851 | GCC_WARN_UNUSED_FUNCTION = YES;
852 | GCC_WARN_UNUSED_VARIABLE = YES;
853 | IPHONEOS_DEPLOYMENT_TARGET = 10.0;
854 | LD_RUNPATH_SEARCH_PATHS = "/usr/lib/swift $(inherited)";
855 | LIBRARY_SEARCH_PATHS = (
856 | "\"$(TOOLCHAIN_DIR)/usr/lib/swift/$(PLATFORM_NAME)\"",
857 | "\"$(TOOLCHAIN_DIR)/usr/lib/swift-5.0/$(PLATFORM_NAME)\"",
858 | "\"$(inherited)\"",
859 | );
860 | MTL_ENABLE_DEBUG_INFO = YES;
861 | ONLY_ACTIVE_ARCH = YES;
862 | SDKROOT = iphoneos;
863 | };
864 | name = Debug;
865 | };
866 | 83CBBA211A601CBA00E9B192 /* Release */ = {
867 | isa = XCBuildConfiguration;
868 | buildSettings = {
869 | ALWAYS_SEARCH_USER_PATHS = NO;
870 | CLANG_ANALYZER_LOCALIZABILITY_NONLOCALIZED = YES;
871 | CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x";
872 | CLANG_CXX_LIBRARY = "libc++";
873 | CLANG_ENABLE_MODULES = YES;
874 | CLANG_ENABLE_OBJC_ARC = YES;
875 | CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
876 | CLANG_WARN_BOOL_CONVERSION = YES;
877 | CLANG_WARN_COMMA = YES;
878 | CLANG_WARN_CONSTANT_CONVERSION = YES;
879 | CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
880 | CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
881 | CLANG_WARN_EMPTY_BODY = YES;
882 | CLANG_WARN_ENUM_CONVERSION = YES;
883 | CLANG_WARN_INFINITE_RECURSION = YES;
884 | CLANG_WARN_INT_CONVERSION = YES;
885 | CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
886 | CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
887 | CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
888 | CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
889 | CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
890 | CLANG_WARN_STRICT_PROTOTYPES = YES;
891 | CLANG_WARN_SUSPICIOUS_MOVE = YES;
892 | CLANG_WARN_UNREACHABLE_CODE = YES;
893 | CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
894 | "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
895 | COPY_PHASE_STRIP = YES;
896 | ENABLE_NS_ASSERTIONS = NO;
897 | ENABLE_STRICT_OBJC_MSGSEND = YES;
898 | GCC_C_LANGUAGE_STANDARD = gnu99;
899 | GCC_NO_COMMON_BLOCKS = YES;
900 | GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
901 | GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
902 | GCC_WARN_UNDECLARED_SELECTOR = YES;
903 | GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
904 | GCC_WARN_UNUSED_FUNCTION = YES;
905 | GCC_WARN_UNUSED_VARIABLE = YES;
906 | IPHONEOS_DEPLOYMENT_TARGET = 10.0;
907 | LD_RUNPATH_SEARCH_PATHS = "/usr/lib/swift $(inherited)";
908 | LIBRARY_SEARCH_PATHS = (
909 | "\"$(TOOLCHAIN_DIR)/usr/lib/swift/$(PLATFORM_NAME)\"",
910 | "\"$(TOOLCHAIN_DIR)/usr/lib/swift-5.0/$(PLATFORM_NAME)\"",
911 | "\"$(inherited)\"",
912 | );
913 | MTL_ENABLE_DEBUG_INFO = NO;
914 | SDKROOT = iphoneos;
915 | VALIDATE_PRODUCT = YES;
916 | };
917 | name = Release;
918 | };
919 | /* End XCBuildConfiguration section */
920 |
921 | /* Begin XCConfigurationList section */
922 | 00E357021AD99517003FC87E /* Build configuration list for PBXNativeTarget "BLEProjectTests" */ = {
923 | isa = XCConfigurationList;
924 | buildConfigurations = (
925 | 00E356F61AD99517003FC87E /* Debug */,
926 | 00E356F71AD99517003FC87E /* Release */,
927 | );
928 | defaultConfigurationIsVisible = 0;
929 | defaultConfigurationName = Release;
930 | };
931 | 13B07F931A680F5B00A75B9A /* Build configuration list for PBXNativeTarget "BLEProject" */ = {
932 | isa = XCConfigurationList;
933 | buildConfigurations = (
934 | 13B07F941A680F5B00A75B9A /* Debug */,
935 | 13B07F951A680F5B00A75B9A /* Release */,
936 | );
937 | defaultConfigurationIsVisible = 0;
938 | defaultConfigurationName = Release;
939 | };
940 | 2D02E4BA1E0B4A5E006451C7 /* Build configuration list for PBXNativeTarget "BLEProject-tvOS" */ = {
941 | isa = XCConfigurationList;
942 | buildConfigurations = (
943 | 2D02E4971E0B4A5E006451C7 /* Debug */,
944 | 2D02E4981E0B4A5E006451C7 /* Release */,
945 | );
946 | defaultConfigurationIsVisible = 0;
947 | defaultConfigurationName = Release;
948 | };
949 | 2D02E4BB1E0B4A5E006451C7 /* Build configuration list for PBXNativeTarget "BLEProject-tvOSTests" */ = {
950 | isa = XCConfigurationList;
951 | buildConfigurations = (
952 | 2D02E4991E0B4A5E006451C7 /* Debug */,
953 | 2D02E49A1E0B4A5E006451C7 /* Release */,
954 | );
955 | defaultConfigurationIsVisible = 0;
956 | defaultConfigurationName = Release;
957 | };
958 | 83CBB9FA1A601CBA00E9B192 /* Build configuration list for PBXProject "BLEProject" */ = {
959 | isa = XCConfigurationList;
960 | buildConfigurations = (
961 | 83CBBA201A601CBA00E9B192 /* Debug */,
962 | 83CBBA211A601CBA00E9B192 /* Release */,
963 | );
964 | defaultConfigurationIsVisible = 0;
965 | defaultConfigurationName = Release;
966 | };
967 | /* End XCConfigurationList section */
968 | };
969 | rootObject = 83CBB9F71A601CBA00E9B192 /* Project object */;
970 | }
971 |
--------------------------------------------------------------------------------
/ios/BLEProject.xcodeproj/xcshareddata/xcschemes/BLEProject-tvOS.xcscheme:
--------------------------------------------------------------------------------
1 |
2 |
5 |
8 |
9 |
15 |
21 |
22 |
23 |
24 |
25 |
30 |
31 |
33 |
39 |
40 |
41 |
42 |
43 |
53 |
55 |
61 |
62 |
63 |
64 |
70 |
72 |
78 |
79 |
80 |
81 |
83 |
84 |
87 |
88 |
89 |
--------------------------------------------------------------------------------
/ios/BLEProject.xcodeproj/xcshareddata/xcschemes/BLEProject.xcscheme:
--------------------------------------------------------------------------------
1 |
2 |
5 |
8 |
9 |
15 |
21 |
22 |
23 |
24 |
25 |
30 |
31 |
33 |
39 |
40 |
41 |
42 |
43 |
53 |
55 |
61 |
62 |
63 |
64 |
70 |
72 |
78 |
79 |
80 |
81 |
83 |
84 |
87 |
88 |
89 |
--------------------------------------------------------------------------------
/ios/BLEProject.xcworkspace/contents.xcworkspacedata:
--------------------------------------------------------------------------------
1 |
2 |
4 |
6 |
7 |
9 |
10 |
11 |
--------------------------------------------------------------------------------
/ios/BLEProject/AppDelegate.h:
--------------------------------------------------------------------------------
1 | #import
2 | #import
3 |
4 | @interface AppDelegate : UIResponder
5 |
6 | @property (nonatomic, strong) UIWindow *window;
7 |
8 | @end
9 |
--------------------------------------------------------------------------------
/ios/BLEProject/AppDelegate.m:
--------------------------------------------------------------------------------
1 | #import "AppDelegate.h"
2 |
3 | #import
4 | #import
5 | #import
6 |
7 | #ifdef FB_SONARKIT_ENABLED
8 | #import
9 | #import
10 | #import
11 | #import
12 | #import
13 | #import
14 |
15 | static void InitializeFlipper(UIApplication *application) {
16 | FlipperClient *client = [FlipperClient sharedClient];
17 | SKDescriptorMapper *layoutDescriptorMapper = [[SKDescriptorMapper alloc] initWithDefaults];
18 | [client addPlugin:[[FlipperKitLayoutPlugin alloc] initWithRootNode:application withDescriptorMapper:layoutDescriptorMapper]];
19 | [client addPlugin:[[FKUserDefaultsPlugin alloc] initWithSuiteName:nil]];
20 | [client addPlugin:[FlipperKitReactPlugin new]];
21 | [client addPlugin:[[FlipperKitNetworkPlugin alloc] initWithNetworkAdapter:[SKIOSNetworkAdapter new]]];
22 | [client start];
23 | }
24 | #endif
25 |
26 | @implementation AppDelegate
27 |
28 | - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
29 | {
30 | #ifdef FB_SONARKIT_ENABLED
31 | InitializeFlipper(application);
32 | #endif
33 |
34 | RCTBridge *bridge = [[RCTBridge alloc] initWithDelegate:self launchOptions:launchOptions];
35 | RCTRootView *rootView = [[RCTRootView alloc] initWithBridge:bridge
36 | moduleName:@"BLEProject"
37 | initialProperties:nil];
38 |
39 | rootView.backgroundColor = [[UIColor alloc] initWithRed:1.0f green:1.0f blue:1.0f alpha:1];
40 |
41 | self.window = [[UIWindow alloc] initWithFrame:[UIScreen mainScreen].bounds];
42 | UIViewController *rootViewController = [UIViewController new];
43 | rootViewController.view = rootView;
44 | self.window.rootViewController = rootViewController;
45 | [self.window makeKeyAndVisible];
46 | return YES;
47 | }
48 |
49 | - (NSURL *)sourceURLForBridge:(RCTBridge *)bridge
50 | {
51 | #if DEBUG
52 | return [[RCTBundleURLProvider sharedSettings] jsBundleURLForBundleRoot:@"index" fallbackResource:nil];
53 | #else
54 | return [[NSBundle mainBundle] URLForResource:@"main" withExtension:@"jsbundle"];
55 | #endif
56 | }
57 |
58 | @end
59 |
--------------------------------------------------------------------------------
/ios/BLEProject/Images.xcassets/AppIcon.appiconset/Contents.json:
--------------------------------------------------------------------------------
1 | {
2 | "images" : [
3 | {
4 | "idiom" : "iphone",
5 | "size" : "29x29",
6 | "scale" : "2x"
7 | },
8 | {
9 | "idiom" : "iphone",
10 | "size" : "29x29",
11 | "scale" : "3x"
12 | },
13 | {
14 | "idiom" : "iphone",
15 | "size" : "40x40",
16 | "scale" : "2x"
17 | },
18 | {
19 | "idiom" : "iphone",
20 | "size" : "40x40",
21 | "scale" : "3x"
22 | },
23 | {
24 | "idiom" : "iphone",
25 | "size" : "60x60",
26 | "scale" : "2x"
27 | },
28 | {
29 | "idiom" : "iphone",
30 | "size" : "60x60",
31 | "scale" : "3x"
32 | }
33 | ],
34 | "info" : {
35 | "version" : 1,
36 | "author" : "xcode"
37 | }
38 | }
--------------------------------------------------------------------------------
/ios/BLEProject/Images.xcassets/Contents.json:
--------------------------------------------------------------------------------
1 | {
2 | "info" : {
3 | "version" : 1,
4 | "author" : "xcode"
5 | }
6 | }
7 |
--------------------------------------------------------------------------------
/ios/BLEProject/Info.plist:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | CFBundleDevelopmentRegion
6 | en
7 | CFBundleDisplayName
8 | BLEProject
9 | CFBundleExecutable
10 | $(EXECUTABLE_NAME)
11 | CFBundleIdentifier
12 | $(PRODUCT_BUNDLE_IDENTIFIER)
13 | CFBundleInfoDictionaryVersion
14 | 6.0
15 | CFBundleName
16 | $(PRODUCT_NAME)
17 | CFBundlePackageType
18 | APPL
19 | CFBundleShortVersionString
20 | 1.0
21 | CFBundleSignature
22 | ????
23 | CFBundleVersion
24 | 1
25 | LSRequiresIPhoneOS
26 |
27 | NSAppTransportSecurity
28 |
29 | NSAllowsArbitraryLoads
30 |
31 | NSExceptionDomains
32 |
33 | localhost
34 |
35 | NSExceptionAllowsInsecureHTTPLoads
36 |
37 |
38 |
39 |
40 | NSLocationWhenInUseUsageDescription
41 |
42 | UILaunchStoryboardName
43 | LaunchScreen
44 | UIRequiredDeviceCapabilities
45 |
46 | armv7
47 |
48 | UISupportedInterfaceOrientations
49 |
50 | UIInterfaceOrientationPortrait
51 | UIInterfaceOrientationLandscapeLeft
52 | UIInterfaceOrientationLandscapeRight
53 |
54 | UIViewControllerBasedStatusBarAppearance
55 |
56 |
57 |
58 |
--------------------------------------------------------------------------------
/ios/BLEProject/LaunchScreen.storyboard:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
18 |
19 |
25 |
31 |
37 |
38 |
39 |
40 |
41 |
42 |
43 |
44 |
45 |
46 |
47 |
48 |
49 |
50 |
51 |
52 |
53 |
54 |
55 |
56 |
57 |
58 |
59 |
--------------------------------------------------------------------------------
/ios/BLEProject/main.m:
--------------------------------------------------------------------------------
1 | #import
2 |
3 | #import "AppDelegate.h"
4 |
5 | int main(int argc, char * argv[]) {
6 | @autoreleasepool {
7 | return UIApplicationMain(argc, argv, nil, NSStringFromClass([AppDelegate class]));
8 | }
9 | }
10 |
--------------------------------------------------------------------------------
/ios/BLEProjectTests/BLEProjectTests.m:
--------------------------------------------------------------------------------
1 | #import
2 | #import
3 |
4 | #import
5 | #import
6 |
7 | #define TIMEOUT_SECONDS 600
8 | #define TEXT_TO_LOOK_FOR @"Welcome to React"
9 |
10 | @interface BLEProjectTests : XCTestCase
11 |
12 | @end
13 |
14 | @implementation BLEProjectTests
15 |
16 | - (BOOL)findSubviewInView:(UIView *)view matching:(BOOL(^)(UIView *view))test
17 | {
18 | if (test(view)) {
19 | return YES;
20 | }
21 | for (UIView *subview in [view subviews]) {
22 | if ([self findSubviewInView:subview matching:test]) {
23 | return YES;
24 | }
25 | }
26 | return NO;
27 | }
28 |
29 | - (void)testRendersWelcomeScreen
30 | {
31 | UIViewController *vc = [[[RCTSharedApplication() delegate] window] rootViewController];
32 | NSDate *date = [NSDate dateWithTimeIntervalSinceNow:TIMEOUT_SECONDS];
33 | BOOL foundElement = NO;
34 |
35 | __block NSString *redboxError = nil;
36 | #ifdef DEBUG
37 | RCTSetLogFunction(^(RCTLogLevel level, RCTLogSource source, NSString *fileName, NSNumber *lineNumber, NSString *message) {
38 | if (level >= RCTLogLevelError) {
39 | redboxError = message;
40 | }
41 | });
42 | #endif
43 |
44 | while ([date timeIntervalSinceNow] > 0 && !foundElement && !redboxError) {
45 | [[NSRunLoop mainRunLoop] runMode:NSDefaultRunLoopMode beforeDate:[NSDate dateWithTimeIntervalSinceNow:0.1]];
46 | [[NSRunLoop mainRunLoop] runMode:NSRunLoopCommonModes beforeDate:[NSDate dateWithTimeIntervalSinceNow:0.1]];
47 |
48 | foundElement = [self findSubviewInView:vc.view matching:^BOOL(UIView *view) {
49 | if ([view.accessibilityLabel isEqualToString:TEXT_TO_LOOK_FOR]) {
50 | return YES;
51 | }
52 | return NO;
53 | }];
54 | }
55 |
56 | #ifdef DEBUG
57 | RCTSetLogFunction(RCTDefaultLogFunction);
58 | #endif
59 |
60 | XCTAssertNil(redboxError, @"RedBox error: %@", redboxError);
61 | XCTAssertTrue(foundElement, @"Couldn't find element with text '%@' in %d seconds", TEXT_TO_LOOK_FOR, TIMEOUT_SECONDS);
62 | }
63 |
64 |
65 | @end
66 |
--------------------------------------------------------------------------------
/ios/BLEProjectTests/Info.plist:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | CFBundleDevelopmentRegion
6 | en
7 | CFBundleExecutable
8 | $(EXECUTABLE_NAME)
9 | CFBundleIdentifier
10 | $(PRODUCT_BUNDLE_IDENTIFIER)
11 | CFBundleInfoDictionaryVersion
12 | 6.0
13 | CFBundleName
14 | $(PRODUCT_NAME)
15 | CFBundlePackageType
16 | BNDL
17 | CFBundleShortVersionString
18 | 1.0
19 | CFBundleSignature
20 | ????
21 | CFBundleVersion
22 | 1
23 |
24 |
25 |
--------------------------------------------------------------------------------
/ios/Podfile:
--------------------------------------------------------------------------------
1 | require_relative '../node_modules/react-native/scripts/react_native_pods'
2 | require_relative '../node_modules/@react-native-community/cli-platform-ios/native_modules'
3 |
4 | platform :ios, '10.0'
5 |
6 | target 'BLEProject' do
7 | config = use_native_modules!
8 |
9 | use_react_native!(:path => config["reactNativePath"])
10 |
11 | pod 'react-native-ble-plx', :path => '../node_modules/react-native-ble-plx'
12 |
13 | target 'BLEProjectTests' do
14 | inherit! :complete
15 | # Pods for testing
16 | end
17 |
18 | # Enables Flipper.
19 | #
20 | # Note that if you have use_frameworks! enabled, Flipper will not work and
21 | # you should disable these next few lines.
22 | use_flipper!
23 | post_install do |installer|
24 | flipper_post_install(installer)
25 | end
26 | end
27 |
28 | target 'BLEProject-tvOS' do
29 | # Pods for BLEProject-tvOS
30 |
31 | target 'BLEProject-tvOSTests' do
32 | inherit! :search_paths
33 | # Pods for testing
34 | end
35 | end
36 |
--------------------------------------------------------------------------------
/ios/Podfile.lock:
--------------------------------------------------------------------------------
1 | PODS:
2 | - boost-for-react-native (1.63.0)
3 | - CocoaAsyncSocket (7.6.4)
4 | - CocoaLibEvent (1.0.0)
5 | - DoubleConversion (1.1.6)
6 | - FBLazyVector (0.63.3)
7 | - FBReactNativeSpec (0.63.3):
8 | - Folly (= 2020.01.13.00)
9 | - RCTRequired (= 0.63.3)
10 | - RCTTypeSafety (= 0.63.3)
11 | - React-Core (= 0.63.3)
12 | - React-jsi (= 0.63.3)
13 | - ReactCommon/turbomodule/core (= 0.63.3)
14 | - Flipper (0.54.0):
15 | - Flipper-Folly (~> 2.2)
16 | - Flipper-RSocket (~> 1.1)
17 | - Flipper-DoubleConversion (1.1.7)
18 | - Flipper-Folly (2.3.0):
19 | - boost-for-react-native
20 | - CocoaLibEvent (~> 1.0)
21 | - Flipper-DoubleConversion
22 | - Flipper-Glog
23 | - OpenSSL-Universal (= 1.0.2.20)
24 | - Flipper-Glog (0.3.6)
25 | - Flipper-PeerTalk (0.0.4)
26 | - Flipper-RSocket (1.1.0):
27 | - Flipper-Folly (~> 2.2)
28 | - FlipperKit (0.54.0):
29 | - FlipperKit/Core (= 0.54.0)
30 | - FlipperKit/Core (0.54.0):
31 | - Flipper (~> 0.54.0)
32 | - FlipperKit/CppBridge
33 | - FlipperKit/FBCxxFollyDynamicConvert
34 | - FlipperKit/FBDefines
35 | - FlipperKit/FKPortForwarding
36 | - FlipperKit/CppBridge (0.54.0):
37 | - Flipper (~> 0.54.0)
38 | - FlipperKit/FBCxxFollyDynamicConvert (0.54.0):
39 | - Flipper-Folly (~> 2.2)
40 | - FlipperKit/FBDefines (0.54.0)
41 | - FlipperKit/FKPortForwarding (0.54.0):
42 | - CocoaAsyncSocket (~> 7.6)
43 | - Flipper-PeerTalk (~> 0.0.4)
44 | - FlipperKit/FlipperKitHighlightOverlay (0.54.0)
45 | - FlipperKit/FlipperKitLayoutPlugin (0.54.0):
46 | - FlipperKit/Core
47 | - FlipperKit/FlipperKitHighlightOverlay
48 | - FlipperKit/FlipperKitLayoutTextSearchable
49 | - YogaKit (~> 1.18)
50 | - FlipperKit/FlipperKitLayoutTextSearchable (0.54.0)
51 | - FlipperKit/FlipperKitNetworkPlugin (0.54.0):
52 | - FlipperKit/Core
53 | - FlipperKit/FlipperKitReactPlugin (0.54.0):
54 | - FlipperKit/Core
55 | - FlipperKit/FlipperKitUserDefaultsPlugin (0.54.0):
56 | - FlipperKit/Core
57 | - FlipperKit/SKIOSNetworkPlugin (0.54.0):
58 | - FlipperKit/Core
59 | - FlipperKit/FlipperKitNetworkPlugin
60 | - Folly (2020.01.13.00):
61 | - boost-for-react-native
62 | - DoubleConversion
63 | - Folly/Default (= 2020.01.13.00)
64 | - glog
65 | - Folly/Default (2020.01.13.00):
66 | - boost-for-react-native
67 | - DoubleConversion
68 | - glog
69 | - glog (0.3.5)
70 | - MultiplatformBleAdapter (0.1.6)
71 | - OpenSSL-Universal (1.0.2.20):
72 | - OpenSSL-Universal/Static (= 1.0.2.20)
73 | - OpenSSL-Universal/Static (1.0.2.20)
74 | - RCTRequired (0.63.3)
75 | - RCTTypeSafety (0.63.3):
76 | - FBLazyVector (= 0.63.3)
77 | - Folly (= 2020.01.13.00)
78 | - RCTRequired (= 0.63.3)
79 | - React-Core (= 0.63.3)
80 | - React (0.63.3):
81 | - React-Core (= 0.63.3)
82 | - React-Core/DevSupport (= 0.63.3)
83 | - React-Core/RCTWebSocket (= 0.63.3)
84 | - React-RCTActionSheet (= 0.63.3)
85 | - React-RCTAnimation (= 0.63.3)
86 | - React-RCTBlob (= 0.63.3)
87 | - React-RCTImage (= 0.63.3)
88 | - React-RCTLinking (= 0.63.3)
89 | - React-RCTNetwork (= 0.63.3)
90 | - React-RCTSettings (= 0.63.3)
91 | - React-RCTText (= 0.63.3)
92 | - React-RCTVibration (= 0.63.3)
93 | - React-callinvoker (0.63.3)
94 | - React-Core (0.63.3):
95 | - Folly (= 2020.01.13.00)
96 | - glog
97 | - React-Core/Default (= 0.63.3)
98 | - React-cxxreact (= 0.63.3)
99 | - React-jsi (= 0.63.3)
100 | - React-jsiexecutor (= 0.63.3)
101 | - Yoga
102 | - React-Core/CoreModulesHeaders (0.63.3):
103 | - Folly (= 2020.01.13.00)
104 | - glog
105 | - React-Core/Default
106 | - React-cxxreact (= 0.63.3)
107 | - React-jsi (= 0.63.3)
108 | - React-jsiexecutor (= 0.63.3)
109 | - Yoga
110 | - React-Core/Default (0.63.3):
111 | - Folly (= 2020.01.13.00)
112 | - glog
113 | - React-cxxreact (= 0.63.3)
114 | - React-jsi (= 0.63.3)
115 | - React-jsiexecutor (= 0.63.3)
116 | - Yoga
117 | - React-Core/DevSupport (0.63.3):
118 | - Folly (= 2020.01.13.00)
119 | - glog
120 | - React-Core/Default (= 0.63.3)
121 | - React-Core/RCTWebSocket (= 0.63.3)
122 | - React-cxxreact (= 0.63.3)
123 | - React-jsi (= 0.63.3)
124 | - React-jsiexecutor (= 0.63.3)
125 | - React-jsinspector (= 0.63.3)
126 | - Yoga
127 | - React-Core/RCTActionSheetHeaders (0.63.3):
128 | - Folly (= 2020.01.13.00)
129 | - glog
130 | - React-Core/Default
131 | - React-cxxreact (= 0.63.3)
132 | - React-jsi (= 0.63.3)
133 | - React-jsiexecutor (= 0.63.3)
134 | - Yoga
135 | - React-Core/RCTAnimationHeaders (0.63.3):
136 | - Folly (= 2020.01.13.00)
137 | - glog
138 | - React-Core/Default
139 | - React-cxxreact (= 0.63.3)
140 | - React-jsi (= 0.63.3)
141 | - React-jsiexecutor (= 0.63.3)
142 | - Yoga
143 | - React-Core/RCTBlobHeaders (0.63.3):
144 | - Folly (= 2020.01.13.00)
145 | - glog
146 | - React-Core/Default
147 | - React-cxxreact (= 0.63.3)
148 | - React-jsi (= 0.63.3)
149 | - React-jsiexecutor (= 0.63.3)
150 | - Yoga
151 | - React-Core/RCTImageHeaders (0.63.3):
152 | - Folly (= 2020.01.13.00)
153 | - glog
154 | - React-Core/Default
155 | - React-cxxreact (= 0.63.3)
156 | - React-jsi (= 0.63.3)
157 | - React-jsiexecutor (= 0.63.3)
158 | - Yoga
159 | - React-Core/RCTLinkingHeaders (0.63.3):
160 | - Folly (= 2020.01.13.00)
161 | - glog
162 | - React-Core/Default
163 | - React-cxxreact (= 0.63.3)
164 | - React-jsi (= 0.63.3)
165 | - React-jsiexecutor (= 0.63.3)
166 | - Yoga
167 | - React-Core/RCTNetworkHeaders (0.63.3):
168 | - Folly (= 2020.01.13.00)
169 | - glog
170 | - React-Core/Default
171 | - React-cxxreact (= 0.63.3)
172 | - React-jsi (= 0.63.3)
173 | - React-jsiexecutor (= 0.63.3)
174 | - Yoga
175 | - React-Core/RCTSettingsHeaders (0.63.3):
176 | - Folly (= 2020.01.13.00)
177 | - glog
178 | - React-Core/Default
179 | - React-cxxreact (= 0.63.3)
180 | - React-jsi (= 0.63.3)
181 | - React-jsiexecutor (= 0.63.3)
182 | - Yoga
183 | - React-Core/RCTTextHeaders (0.63.3):
184 | - Folly (= 2020.01.13.00)
185 | - glog
186 | - React-Core/Default
187 | - React-cxxreact (= 0.63.3)
188 | - React-jsi (= 0.63.3)
189 | - React-jsiexecutor (= 0.63.3)
190 | - Yoga
191 | - React-Core/RCTVibrationHeaders (0.63.3):
192 | - Folly (= 2020.01.13.00)
193 | - glog
194 | - React-Core/Default
195 | - React-cxxreact (= 0.63.3)
196 | - React-jsi (= 0.63.3)
197 | - React-jsiexecutor (= 0.63.3)
198 | - Yoga
199 | - React-Core/RCTWebSocket (0.63.3):
200 | - Folly (= 2020.01.13.00)
201 | - glog
202 | - React-Core/Default (= 0.63.3)
203 | - React-cxxreact (= 0.63.3)
204 | - React-jsi (= 0.63.3)
205 | - React-jsiexecutor (= 0.63.3)
206 | - Yoga
207 | - React-CoreModules (0.63.3):
208 | - FBReactNativeSpec (= 0.63.3)
209 | - Folly (= 2020.01.13.00)
210 | - RCTTypeSafety (= 0.63.3)
211 | - React-Core/CoreModulesHeaders (= 0.63.3)
212 | - React-jsi (= 0.63.3)
213 | - React-RCTImage (= 0.63.3)
214 | - ReactCommon/turbomodule/core (= 0.63.3)
215 | - React-cxxreact (0.63.3):
216 | - boost-for-react-native (= 1.63.0)
217 | - DoubleConversion
218 | - Folly (= 2020.01.13.00)
219 | - glog
220 | - React-callinvoker (= 0.63.3)
221 | - React-jsinspector (= 0.63.3)
222 | - React-jsi (0.63.3):
223 | - boost-for-react-native (= 1.63.0)
224 | - DoubleConversion
225 | - Folly (= 2020.01.13.00)
226 | - glog
227 | - React-jsi/Default (= 0.63.3)
228 | - React-jsi/Default (0.63.3):
229 | - boost-for-react-native (= 1.63.0)
230 | - DoubleConversion
231 | - Folly (= 2020.01.13.00)
232 | - glog
233 | - React-jsiexecutor (0.63.3):
234 | - DoubleConversion
235 | - Folly (= 2020.01.13.00)
236 | - glog
237 | - React-cxxreact (= 0.63.3)
238 | - React-jsi (= 0.63.3)
239 | - React-jsinspector (0.63.3)
240 | - react-native-ble-plx (2.0.1):
241 | - MultiplatformBleAdapter (= 0.1.6)
242 | - React
243 | - react-native-safe-area-context (3.1.9):
244 | - React-Core
245 | - React-RCTActionSheet (0.63.3):
246 | - React-Core/RCTActionSheetHeaders (= 0.63.3)
247 | - React-RCTAnimation (0.63.3):
248 | - FBReactNativeSpec (= 0.63.3)
249 | - Folly (= 2020.01.13.00)
250 | - RCTTypeSafety (= 0.63.3)
251 | - React-Core/RCTAnimationHeaders (= 0.63.3)
252 | - React-jsi (= 0.63.3)
253 | - ReactCommon/turbomodule/core (= 0.63.3)
254 | - React-RCTBlob (0.63.3):
255 | - FBReactNativeSpec (= 0.63.3)
256 | - Folly (= 2020.01.13.00)
257 | - React-Core/RCTBlobHeaders (= 0.63.3)
258 | - React-Core/RCTWebSocket (= 0.63.3)
259 | - React-jsi (= 0.63.3)
260 | - React-RCTNetwork (= 0.63.3)
261 | - ReactCommon/turbomodule/core (= 0.63.3)
262 | - React-RCTImage (0.63.3):
263 | - FBReactNativeSpec (= 0.63.3)
264 | - Folly (= 2020.01.13.00)
265 | - RCTTypeSafety (= 0.63.3)
266 | - React-Core/RCTImageHeaders (= 0.63.3)
267 | - React-jsi (= 0.63.3)
268 | - React-RCTNetwork (= 0.63.3)
269 | - ReactCommon/turbomodule/core (= 0.63.3)
270 | - React-RCTLinking (0.63.3):
271 | - FBReactNativeSpec (= 0.63.3)
272 | - React-Core/RCTLinkingHeaders (= 0.63.3)
273 | - React-jsi (= 0.63.3)
274 | - ReactCommon/turbomodule/core (= 0.63.3)
275 | - React-RCTNetwork (0.63.3):
276 | - FBReactNativeSpec (= 0.63.3)
277 | - Folly (= 2020.01.13.00)
278 | - RCTTypeSafety (= 0.63.3)
279 | - React-Core/RCTNetworkHeaders (= 0.63.3)
280 | - React-jsi (= 0.63.3)
281 | - ReactCommon/turbomodule/core (= 0.63.3)
282 | - React-RCTSettings (0.63.3):
283 | - FBReactNativeSpec (= 0.63.3)
284 | - Folly (= 2020.01.13.00)
285 | - RCTTypeSafety (= 0.63.3)
286 | - React-Core/RCTSettingsHeaders (= 0.63.3)
287 | - React-jsi (= 0.63.3)
288 | - ReactCommon/turbomodule/core (= 0.63.3)
289 | - React-RCTText (0.63.3):
290 | - React-Core/RCTTextHeaders (= 0.63.3)
291 | - React-RCTVibration (0.63.3):
292 | - FBReactNativeSpec (= 0.63.3)
293 | - Folly (= 2020.01.13.00)
294 | - React-Core/RCTVibrationHeaders (= 0.63.3)
295 | - React-jsi (= 0.63.3)
296 | - ReactCommon/turbomodule/core (= 0.63.3)
297 | - ReactCommon/turbomodule/core (0.63.3):
298 | - DoubleConversion
299 | - Folly (= 2020.01.13.00)
300 | - glog
301 | - React-callinvoker (= 0.63.3)
302 | - React-Core (= 0.63.3)
303 | - React-cxxreact (= 0.63.3)
304 | - React-jsi (= 0.63.3)
305 | - RNCMaskedView (0.1.10):
306 | - React
307 | - RNGestureHandler (1.8.0):
308 | - React
309 | - RNReanimated (1.13.1):
310 | - React
311 | - RNScreens (2.14.0):
312 | - React-Core
313 | - Yoga (1.14.0)
314 | - YogaKit (1.18.1):
315 | - Yoga (~> 1.14)
316 |
317 | DEPENDENCIES:
318 | - DoubleConversion (from `../node_modules/react-native/third-party-podspecs/DoubleConversion.podspec`)
319 | - FBLazyVector (from `../node_modules/react-native/Libraries/FBLazyVector`)
320 | - FBReactNativeSpec (from `../node_modules/react-native/Libraries/FBReactNativeSpec`)
321 | - Flipper (~> 0.54.0)
322 | - Flipper-DoubleConversion (= 1.1.7)
323 | - Flipper-Folly (~> 2.2)
324 | - Flipper-Glog (= 0.3.6)
325 | - Flipper-PeerTalk (~> 0.0.4)
326 | - Flipper-RSocket (~> 1.1)
327 | - FlipperKit (~> 0.54.0)
328 | - FlipperKit/Core (~> 0.54.0)
329 | - FlipperKit/CppBridge (~> 0.54.0)
330 | - FlipperKit/FBCxxFollyDynamicConvert (~> 0.54.0)
331 | - FlipperKit/FBDefines (~> 0.54.0)
332 | - FlipperKit/FKPortForwarding (~> 0.54.0)
333 | - FlipperKit/FlipperKitHighlightOverlay (~> 0.54.0)
334 | - FlipperKit/FlipperKitLayoutPlugin (~> 0.54.0)
335 | - FlipperKit/FlipperKitLayoutTextSearchable (~> 0.54.0)
336 | - FlipperKit/FlipperKitNetworkPlugin (~> 0.54.0)
337 | - FlipperKit/FlipperKitReactPlugin (~> 0.54.0)
338 | - FlipperKit/FlipperKitUserDefaultsPlugin (~> 0.54.0)
339 | - FlipperKit/SKIOSNetworkPlugin (~> 0.54.0)
340 | - Folly (from `../node_modules/react-native/third-party-podspecs/Folly.podspec`)
341 | - glog (from `../node_modules/react-native/third-party-podspecs/glog.podspec`)
342 | - RCTRequired (from `../node_modules/react-native/Libraries/RCTRequired`)
343 | - RCTTypeSafety (from `../node_modules/react-native/Libraries/TypeSafety`)
344 | - React (from `../node_modules/react-native/`)
345 | - React-callinvoker (from `../node_modules/react-native/ReactCommon/callinvoker`)
346 | - React-Core (from `../node_modules/react-native/`)
347 | - React-Core/DevSupport (from `../node_modules/react-native/`)
348 | - React-Core/RCTWebSocket (from `../node_modules/react-native/`)
349 | - React-CoreModules (from `../node_modules/react-native/React/CoreModules`)
350 | - React-cxxreact (from `../node_modules/react-native/ReactCommon/cxxreact`)
351 | - React-jsi (from `../node_modules/react-native/ReactCommon/jsi`)
352 | - React-jsiexecutor (from `../node_modules/react-native/ReactCommon/jsiexecutor`)
353 | - React-jsinspector (from `../node_modules/react-native/ReactCommon/jsinspector`)
354 | - react-native-ble-plx (from `../node_modules/react-native-ble-plx`)
355 | - react-native-safe-area-context (from `../node_modules/react-native-safe-area-context`)
356 | - React-RCTActionSheet (from `../node_modules/react-native/Libraries/ActionSheetIOS`)
357 | - React-RCTAnimation (from `../node_modules/react-native/Libraries/NativeAnimation`)
358 | - React-RCTBlob (from `../node_modules/react-native/Libraries/Blob`)
359 | - React-RCTImage (from `../node_modules/react-native/Libraries/Image`)
360 | - React-RCTLinking (from `../node_modules/react-native/Libraries/LinkingIOS`)
361 | - React-RCTNetwork (from `../node_modules/react-native/Libraries/Network`)
362 | - React-RCTSettings (from `../node_modules/react-native/Libraries/Settings`)
363 | - React-RCTText (from `../node_modules/react-native/Libraries/Text`)
364 | - React-RCTVibration (from `../node_modules/react-native/Libraries/Vibration`)
365 | - ReactCommon/turbomodule/core (from `../node_modules/react-native/ReactCommon`)
366 | - "RNCMaskedView (from `../node_modules/@react-native-community/masked-view`)"
367 | - RNGestureHandler (from `../node_modules/react-native-gesture-handler`)
368 | - RNReanimated (from `../node_modules/react-native-reanimated`)
369 | - RNScreens (from `../node_modules/react-native-screens`)
370 | - Yoga (from `../node_modules/react-native/ReactCommon/yoga`)
371 |
372 | SPEC REPOS:
373 | trunk:
374 | - boost-for-react-native
375 | - CocoaAsyncSocket
376 | - CocoaLibEvent
377 | - Flipper
378 | - Flipper-DoubleConversion
379 | - Flipper-Folly
380 | - Flipper-Glog
381 | - Flipper-PeerTalk
382 | - Flipper-RSocket
383 | - FlipperKit
384 | - MultiplatformBleAdapter
385 | - OpenSSL-Universal
386 | - YogaKit
387 |
388 | EXTERNAL SOURCES:
389 | DoubleConversion:
390 | :podspec: "../node_modules/react-native/third-party-podspecs/DoubleConversion.podspec"
391 | FBLazyVector:
392 | :path: "../node_modules/react-native/Libraries/FBLazyVector"
393 | FBReactNativeSpec:
394 | :path: "../node_modules/react-native/Libraries/FBReactNativeSpec"
395 | Folly:
396 | :podspec: "../node_modules/react-native/third-party-podspecs/Folly.podspec"
397 | glog:
398 | :podspec: "../node_modules/react-native/third-party-podspecs/glog.podspec"
399 | RCTRequired:
400 | :path: "../node_modules/react-native/Libraries/RCTRequired"
401 | RCTTypeSafety:
402 | :path: "../node_modules/react-native/Libraries/TypeSafety"
403 | React:
404 | :path: "../node_modules/react-native/"
405 | React-callinvoker:
406 | :path: "../node_modules/react-native/ReactCommon/callinvoker"
407 | React-Core:
408 | :path: "../node_modules/react-native/"
409 | React-CoreModules:
410 | :path: "../node_modules/react-native/React/CoreModules"
411 | React-cxxreact:
412 | :path: "../node_modules/react-native/ReactCommon/cxxreact"
413 | React-jsi:
414 | :path: "../node_modules/react-native/ReactCommon/jsi"
415 | React-jsiexecutor:
416 | :path: "../node_modules/react-native/ReactCommon/jsiexecutor"
417 | React-jsinspector:
418 | :path: "../node_modules/react-native/ReactCommon/jsinspector"
419 | react-native-ble-plx:
420 | :path: "../node_modules/react-native-ble-plx"
421 | react-native-safe-area-context:
422 | :path: "../node_modules/react-native-safe-area-context"
423 | React-RCTActionSheet:
424 | :path: "../node_modules/react-native/Libraries/ActionSheetIOS"
425 | React-RCTAnimation:
426 | :path: "../node_modules/react-native/Libraries/NativeAnimation"
427 | React-RCTBlob:
428 | :path: "../node_modules/react-native/Libraries/Blob"
429 | React-RCTImage:
430 | :path: "../node_modules/react-native/Libraries/Image"
431 | React-RCTLinking:
432 | :path: "../node_modules/react-native/Libraries/LinkingIOS"
433 | React-RCTNetwork:
434 | :path: "../node_modules/react-native/Libraries/Network"
435 | React-RCTSettings:
436 | :path: "../node_modules/react-native/Libraries/Settings"
437 | React-RCTText:
438 | :path: "../node_modules/react-native/Libraries/Text"
439 | React-RCTVibration:
440 | :path: "../node_modules/react-native/Libraries/Vibration"
441 | ReactCommon:
442 | :path: "../node_modules/react-native/ReactCommon"
443 | RNCMaskedView:
444 | :path: "../node_modules/@react-native-community/masked-view"
445 | RNGestureHandler:
446 | :path: "../node_modules/react-native-gesture-handler"
447 | RNReanimated:
448 | :path: "../node_modules/react-native-reanimated"
449 | RNScreens:
450 | :path: "../node_modules/react-native-screens"
451 | Yoga:
452 | :path: "../node_modules/react-native/ReactCommon/yoga"
453 |
454 | SPEC CHECKSUMS:
455 | boost-for-react-native: 39c7adb57c4e60d6c5479dd8623128eb5b3f0f2c
456 | CocoaAsyncSocket: 694058e7c0ed05a9e217d1b3c7ded962f4180845
457 | CocoaLibEvent: 2fab71b8bd46dd33ddb959f7928ec5909f838e3f
458 | DoubleConversion: cde416483dac037923206447da6e1454df403714
459 | FBLazyVector: 878b59e31113e289e275165efbe4b54fa614d43d
460 | FBReactNativeSpec: 7da9338acfb98d4ef9e5536805a0704572d33c2f
461 | Flipper: be611d4b742d8c87fbae2ca5f44603a02539e365
462 | Flipper-DoubleConversion: 38631e41ef4f9b12861c67d17cb5518d06badc41
463 | Flipper-Folly: e4493b013c02d9347d5e0cb4d128680239f6c78a
464 | Flipper-Glog: 1dfd6abf1e922806c52ceb8701a3599a79a200a6
465 | Flipper-PeerTalk: 116d8f857dc6ef55c7a5a75ea3ceaafe878aadc9
466 | Flipper-RSocket: 64e7431a55835eb953b0bf984ef3b90ae9fdddd7
467 | FlipperKit: ab353d41aea8aae2ea6daaf813e67496642f3d7d
468 | Folly: b73c3869541e86821df3c387eb0af5f65addfab4
469 | glog: 40a13f7840415b9a77023fbcae0f1e6f43192af3
470 | MultiplatformBleAdapter: 652f47ecd7f5036756517cf66833210709a72eab
471 | OpenSSL-Universal: ff34003318d5e1163e9529b08470708e389ffcdd
472 | RCTRequired: 48884c74035a0b5b76dbb7a998bd93bcfc5f2047
473 | RCTTypeSafety: edf4b618033c2f1c5b7bc3d90d8e085ed95ba2ab
474 | React: f36e90f3ceb976546e97df3403e37d226f79d0e3
475 | React-callinvoker: 18874f621eb96625df7a24a7dc8d6e07391affcd
476 | React-Core: ac3d816b8e3493970153f4aaf0cff18af0bb95e6
477 | React-CoreModules: 4016d3a4e518bcfc4f5a51252b5a05692ca6f0e1
478 | React-cxxreact: ffc9129013b87cb36cf3f30a86695a3c397b0f99
479 | React-jsi: df07aa95b39c5be3e41199921509bfa929ed2b9d
480 | React-jsiexecutor: b56c03e61c0dd5f5801255f2160a815f4a53d451
481 | React-jsinspector: 8e68ffbfe23880d3ee9bafa8be2777f60b25cbe2
482 | react-native-ble-plx: d8dcca81ecc617eda824a4ace85f7ffd55d90c6c
483 | react-native-safe-area-context: b6e0e284002381d2ff29fa4fff42b4d8282e3c94
484 | React-RCTActionSheet: 53ea72699698b0b47a6421cb1c8b4ab215a774aa
485 | React-RCTAnimation: 1befece0b5183c22ae01b966f5583f42e69a83c2
486 | React-RCTBlob: 0b284339cbe4b15705a05e2313a51c6d8b51fa40
487 | React-RCTImage: d1756599ebd4dc2cb19d1682fe67c6b976658387
488 | React-RCTLinking: 9af0a51c6d6a4dd1674daadafffc6d03033a6d18
489 | React-RCTNetwork: 332c83929cc5eae0b3bbca4add1d668e1fc18bda
490 | React-RCTSettings: d6953772cfd55f2c68ad72b7ef29efc7ec49f773
491 | React-RCTText: 65a6de06a7389098ce24340d1d3556015c38f746
492 | React-RCTVibration: 8e9fb25724a0805107fc1acc9075e26f814df454
493 | ReactCommon: 4167844018c9ed375cc01a843e9ee564399e53c3
494 | RNCMaskedView: 5a8ec07677aa885546a0d98da336457e2bea557f
495 | RNGestureHandler: 7a5833d0f788dbd107fbb913e09aa0c1ff333c39
496 | RNReanimated: dd8c286ab5dd4ba36d3a7fef8bff7e08711b5476
497 | RNScreens: 2e278a90eb15092ed261d4f2271e3fc9b60d08d4
498 | Yoga: 7d13633d129fd179e01b8953d38d47be90db185a
499 | YogaKit: f782866e155069a2cca2517aafea43200b01fd5a
500 |
501 | PODFILE CHECKSUM: 822906c27ee02fafacc7f9447d70d7e5574eb989
502 |
503 | COCOAPODS: 1.10.1
504 |
--------------------------------------------------------------------------------
/metro.config.js:
--------------------------------------------------------------------------------
1 | /**
2 | * Metro configuration for React Native
3 | * https://github.com/facebook/react-native
4 | *
5 | * @format
6 | */
7 |
8 | module.exports = {
9 | transformer: {
10 | getTransformOptions: async () => ({
11 | transform: {
12 | experimentalImportSupport: false,
13 | inlineRequires: false,
14 | },
15 | }),
16 | },
17 | };
18 |
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "BLEProject",
3 | "version": "0.0.1",
4 | "private": true,
5 | "scripts": {
6 | "android": "react-native run-android",
7 | "ios": "react-native run-ios",
8 | "start": "react-native start",
9 | "test": "jest",
10 | "lint": "eslint . --ext .js,.jsx,.ts,.tsx"
11 | },
12 | "dependencies": {
13 | "@react-native-community/masked-view": "^0.1.10",
14 | "@react-navigation/native": "^5.8.9",
15 | "@react-navigation/stack": "^5.12.6",
16 | "react": "16.13.1",
17 | "react-native": "0.63.3",
18 | "react-native-ble-plx": "^2.0.1",
19 | "react-native-gesture-handler": "^1.8.0",
20 | "react-native-reanimated": "^1.13.1",
21 | "react-native-safe-area-context": "^3.1.9",
22 | "react-native-screens": "^2.14.0"
23 | },
24 | "devDependencies": {
25 | "@babel/core": "^7.8.4",
26 | "@babel/runtime": "^7.8.4",
27 | "@react-native-community/eslint-config": "^1.1.0",
28 | "@types/jest": "^25.2.3",
29 | "@types/react-native": "^0.63.2",
30 | "@types/react-test-renderer": "^16.9.2",
31 | "@typescript-eslint/eslint-plugin": "^2.27.0",
32 | "@typescript-eslint/parser": "^2.27.0",
33 | "babel-jest": "^25.1.0",
34 | "eslint": "^6.5.1",
35 | "jest": "^25.1.0",
36 | "metro-react-native-babel-preset": "^0.59.0",
37 | "react-test-renderer": "16.13.1",
38 | "typescript": "^3.8.3"
39 | },
40 | "jest": {
41 | "preset": "react-native",
42 | "moduleFileExtensions": [
43 | "ts",
44 | "tsx",
45 | "js",
46 | "jsx",
47 | "json",
48 | "node"
49 | ]
50 | }
51 | }
52 |
--------------------------------------------------------------------------------
/src/components/CharacteristicCard.tsx:
--------------------------------------------------------------------------------
1 | import React, { useEffect, useState } from 'react';
2 | import { StyleSheet, Text } from 'react-native';
3 | import { Characteristic } from 'react-native-ble-plx';
4 | import { TouchableOpacity } from 'react-native-gesture-handler';
5 | import { Base64 } from '../lib/base64';
6 |
7 | type CharacteristicCardProps = {
8 | char: Characteristic;
9 | };
10 |
11 | const decodeBleString = (value: string | undefined | null): string => {
12 | if (!value) {
13 | return '';
14 | }
15 | return Base64.decode(value).charCodeAt(0);
16 | };
17 |
18 | const CharacteristicCard = ({ char }: CharacteristicCardProps) => {
19 | const [measure, setMeasure] = useState('');
20 | const [descriptor, setDescriptor] = useState('');
21 |
22 | useEffect(() => {
23 | // discover characteristic descriptors
24 | char.descriptors().then((desc) => {
25 | desc[0]?.read().then((val) => {
26 | if (val) {
27 | setDescriptor(Base64.decode(val.value));
28 | }
29 | });
30 | });
31 |
32 | // read on the characteristic 👏
33 | char.monitor((err, cha) => {
34 | if (err) {
35 | console.warn('ERROR');
36 | return;
37 | }
38 | // each received value has to be decoded with a Base64 algorythm you can find on the Internet (or in my repository 😉)
39 | setMeasure(decodeBleString(cha?.value));
40 | });
41 | }, [char]);
42 |
43 | // write on a charactestic the number 6 (e.g.)
44 | const writeCharacteristic = () => {
45 | // encode the string with the Base64 algorythm
46 | char
47 | .writeWithResponse(Base64.encode('6'))
48 | .then(() => {
49 | console.warn('Success');
50 | })
51 | .catch((e) => console.log('Error', e));
52 | };
53 |
54 | return (
55 |
59 | {measure}
60 | {descriptor}
61 | {`isIndicatable : ${char.isIndicatable}`}
62 | {`isNotifiable : ${char.isNotifiable}`}
63 | {`isNotifying : ${char.isNotifying}`}
64 | {`isReadable : ${char.isReadable}`}
65 |
66 | {`isWritableWithResponse : ${char.isWritableWithResponse}`}
67 |
68 | {`isWritableWithoutResponse : ${char.isWritableWithoutResponse}`}
69 |
70 | );
71 | };
72 |
73 | const styles = StyleSheet.create({
74 | container: {
75 | backgroundColor: 'white',
76 | marginVertical: 12,
77 | borderRadius: 16,
78 | shadowColor: 'rgba(60,64,67,0.3)',
79 | shadowOpacity: 0.2,
80 | shadowRadius: 5,
81 | elevation: 5,
82 | padding: 12,
83 | },
84 | measure: { color: 'red', fontSize: 24 },
85 | descriptor: { color: 'blue', fontSize: 24 },
86 | });
87 |
88 | export { CharacteristicCard };
89 |
--------------------------------------------------------------------------------
/src/components/DescriptorCard.tsx:
--------------------------------------------------------------------------------
1 | import React, { useEffect, useState } from 'react';
2 | import { StyleSheet, Text, View } from 'react-native';
3 | import { Descriptor } from 'react-native-ble-plx';
4 | import { Base64 } from '../lib/base64';
5 | type DescriptorCardProps = {
6 | descriptor: Descriptor;
7 | };
8 |
9 | const DescriptorCard = ({ descriptor }: DescriptorCardProps) => {
10 | const [value, setValue] = useState('');
11 | useEffect(() => {
12 | (async () => {
13 | descriptor.read().then((r) => {
14 | if (r && r.value) {
15 | setValue(r.value);
16 | }
17 | });
18 | })();
19 | }, []);
20 | return (
21 |
22 |
23 | {descriptor.id + ' -> ' + Base64.decode(value) + '(' + value + ')'}
24 |
25 |
26 | );
27 | };
28 |
29 | const styles = StyleSheet.create({ container: {} });
30 |
31 | export { DescriptorCard };
32 |
--------------------------------------------------------------------------------
/src/components/DeviceCard.tsx:
--------------------------------------------------------------------------------
1 | import React, { useEffect, useState } from 'react';
2 | import { useNavigation } from '@react-navigation/native';
3 | import { StackNavigationProp } from '@react-navigation/stack';
4 | import { StyleSheet, Text, TouchableOpacity } from 'react-native';
5 | import { Device } from 'react-native-ble-plx';
6 | import { RootStackParamList } from '../navigation';
7 | import { Base64 } from '../lib/base64';
8 |
9 | type DeviceCardProps = {
10 | device: Device;
11 | };
12 |
13 | const DeviceCard = ({ device }: DeviceCardProps) => {
14 | const navigation = useNavigation>();
15 |
16 | const [isConnected, setIsConnected] = useState(false);
17 |
18 | useEffect(() => {
19 | // is the device connected?
20 | device.isConnected().then(setIsConnected);
21 | }, [device]);
22 |
23 | return (
24 | navigation.navigate('Device', { device })}>
28 | {`Id : ${device.id}`}
29 | {`Name : ${device.name}`}
30 | {`Is connected : ${isConnected}`}
31 | {`RSSI : ${device.rssi}`}
32 | {/* Decode the ble device manufacturer which is encoded with the base64 algorythme */}
33 | {`Manufacturer : ${Base64.decode(
34 | device.manufacturerData?.replace(/[=]/g, ''),
35 | )}`}
36 | {`ServiceData : ${device.serviceData}`}
37 | {`UUIDS : ${device.serviceUUIDs}`}
38 |
39 | );
40 | };
41 |
42 | const styles = StyleSheet.create({
43 | container: {
44 | backgroundColor: 'white',
45 | marginBottom: 12,
46 | borderRadius: 16,
47 | shadowColor: 'rgba(60,64,67,0.3)',
48 | shadowOpacity: 0.4,
49 | shadowRadius: 10,
50 | elevation: 4,
51 | padding: 12,
52 | },
53 | });
54 |
55 | export { DeviceCard };
56 |
--------------------------------------------------------------------------------
/src/components/ServiceCard.tsx:
--------------------------------------------------------------------------------
1 | import React, { useEffect, useState } from 'react';
2 | import { StyleSheet, Text, TouchableOpacity, View } from 'react-native';
3 | import { Characteristic, Descriptor, Service } from 'react-native-ble-plx';
4 | import { CharacteristicCard } from './CharacteristicCard';
5 | import { DescriptorCard } from './DescriptorCard';
6 |
7 | type ServiceCardProps = {
8 | service: Service;
9 | };
10 |
11 | // eslint-disable-next-line @typescript-eslint/no-unused-vars
12 | const UART_SERVICE_UUID = '6E400001-B5A3-F393-E0A9-E50E24DCCA9E'.toLowerCase();
13 |
14 | const ServiceCard = ({ service }: ServiceCardProps) => {
15 | const [descriptors, setDescriptors] = useState([]);
16 | const [characteristics, setCharacteristics] = useState([]);
17 | const [areCharacteristicsVisible, setAreCharacteristicsVisible] = useState(
18 | false,
19 | );
20 |
21 | useEffect(() => {
22 | const getCharacteristics = async () => {
23 | const newCharacteristics = await service.characteristics();
24 | setCharacteristics(newCharacteristics);
25 | newCharacteristics.forEach(async (characteristic) => {
26 | const newDescriptors = await characteristic.descriptors();
27 | setDescriptors((prev) => [...new Set([...prev, ...newDescriptors])]);
28 | });
29 | };
30 |
31 | getCharacteristics();
32 | }, [service]);
33 |
34 | return (
35 |
36 | {
38 | setAreCharacteristicsVisible((prev) => !prev);
39 | }}>
40 | {`UUID : ${service.uuid}`}
41 |
42 |
43 | {areCharacteristicsVisible &&
44 | characteristics &&
45 | characteristics.map((char) => (
46 |
47 | ))}
48 | {descriptors &&
49 | descriptors.map((descriptor) => (
50 |
51 | ))}
52 |
53 | );
54 | };
55 |
56 | const styles = StyleSheet.create({
57 | container: {
58 | backgroundColor: 'white',
59 | marginBottom: 12,
60 | borderRadius: 16,
61 | shadowColor: 'rgba(60,64,67,0.3)',
62 | shadowOpacity: 0.4,
63 | shadowRadius: 10,
64 | elevation: 4,
65 | padding: 12,
66 | },
67 | });
68 |
69 | export { ServiceCard };
70 |
--------------------------------------------------------------------------------
/src/lib/base64.js:
--------------------------------------------------------------------------------
1 | (function (global, factory) {
2 | typeof exports === 'object' && typeof module !== 'undefined'
3 | ? (module.exports = factory(global))
4 | : typeof define === 'function' && define.amd
5 | ? define(factory)
6 | : factory(global);
7 | })(
8 | typeof self !== 'undefined'
9 | ? self
10 | : typeof window !== 'undefined'
11 | ? window
12 | : typeof global !== 'undefined'
13 | ? global
14 | : this,
15 | function (global) {
16 | 'use strict';
17 | global = global || {};
18 | var _Base64 = global.Base64;
19 | var version = '2.5.2';
20 | var buffer;
21 | if (typeof module !== 'undefined' && module.exports) {
22 | try {
23 | buffer = eval("require('buffer').Buffer");
24 | } catch (err) {
25 | buffer = undefined;
26 | }
27 | }
28 | var b64chars =
29 | 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/';
30 | var b64tab = (function (bin) {
31 | var t = {};
32 | for (var i = 0, l = bin.length; i < l; i++) {
33 | t[bin.charAt(i)] = i;
34 | }
35 | return t;
36 | })(b64chars);
37 | var fromCharCode = String.fromCharCode;
38 | var cb_utob = function (c) {
39 | if (c.length < 2) {
40 | var cc = c.charCodeAt(0);
41 | return cc < 128
42 | ? c
43 | : cc < 2048
44 | ? fromCharCode(192 | (cc >>> 6)) + fromCharCode(128 | (cc & 63))
45 | : fromCharCode(224 | ((cc >>> 12) & 15)) +
46 | fromCharCode(128 | ((cc >>> 6) & 63)) +
47 | fromCharCode(128 | (cc & 63));
48 | } else {
49 | var cc =
50 | 65536 + (c.charCodeAt(0) - 55296) * 1024 + (c.charCodeAt(1) - 56320);
51 | return (
52 | fromCharCode(240 | ((cc >>> 18) & 7)) +
53 | fromCharCode(128 | ((cc >>> 12) & 63)) +
54 | fromCharCode(128 | ((cc >>> 6) & 63)) +
55 | fromCharCode(128 | (cc & 63))
56 | );
57 | }
58 | };
59 | var re_utob = /[\uD800-\uDBFF][\uDC00-\uDFFFF]|[^\x00-\x7F]/g;
60 | var utob = function (u) {
61 | return u.replace(re_utob, cb_utob);
62 | };
63 | var cb_encode = function (ccc) {
64 | var padlen = [0, 2, 1][ccc.length % 3],
65 | ord =
66 | (ccc.charCodeAt(0) << 16) |
67 | ((ccc.length > 1 ? ccc.charCodeAt(1) : 0) << 8) |
68 | (ccc.length > 2 ? ccc.charCodeAt(2) : 0),
69 | chars = [
70 | b64chars.charAt(ord >>> 18),
71 | b64chars.charAt((ord >>> 12) & 63),
72 | padlen >= 2 ? '=' : b64chars.charAt((ord >>> 6) & 63),
73 | padlen >= 1 ? '=' : b64chars.charAt(ord & 63),
74 | ];
75 | return chars.join('');
76 | };
77 | var btoa = global.btoa
78 | ? function (b) {
79 | return global.btoa(b);
80 | }
81 | : function (b) {
82 | return b.replace(/[\s\S]{1,3}/g, cb_encode);
83 | };
84 | var _encode = function (u) {
85 | var isUint8Array =
86 | Object.prototype.toString.call(u) === '[object Uint8Array]';
87 | return isUint8Array ? u.toString('base64') : btoa(utob(String(u)));
88 | };
89 | var encode = function (u, urisafe) {
90 | return !urisafe
91 | ? _encode(u)
92 | : _encode(String(u))
93 | .replace(/[+\/]/g, function (m0) {
94 | return m0 == '+' ? '-' : '_';
95 | })
96 | .replace(/[=]/g, '');
97 | };
98 | var encodeURI = function (u) {
99 | return encode(u, true);
100 | };
101 | var re_btou = /[\xC0-\xDF][\x80-\xBF]|[\xE0-\xEF][\x80-\xBF]{2}|[\xF0-\xF7][\x80-\xBF]{3}/g;
102 | var cb_btou = function (cccc) {
103 | switch (cccc.length) {
104 | case 4:
105 | var cp =
106 | ((7 & cccc.charCodeAt(0)) << 18) |
107 | ((63 & cccc.charCodeAt(1)) << 12) |
108 | ((63 & cccc.charCodeAt(2)) << 6) |
109 | (63 & cccc.charCodeAt(3)),
110 | offset = cp - 65536;
111 | return (
112 | fromCharCode((offset >>> 10) + 55296) +
113 | fromCharCode((offset & 1023) + 56320)
114 | );
115 | case 3:
116 | return fromCharCode(
117 | ((15 & cccc.charCodeAt(0)) << 12) |
118 | ((63 & cccc.charCodeAt(1)) << 6) |
119 | (63 & cccc.charCodeAt(2)),
120 | );
121 | default:
122 | return fromCharCode(
123 | ((31 & cccc.charCodeAt(0)) << 6) | (63 & cccc.charCodeAt(1)),
124 | );
125 | }
126 | };
127 | var btou = function (b) {
128 | return b.replace(re_btou, cb_btou);
129 | };
130 | var cb_decode = function (cccc) {
131 | var len = cccc.length,
132 | padlen = len % 4,
133 | n =
134 | (len > 0 ? b64tab[cccc.charAt(0)] << 18 : 0) |
135 | (len > 1 ? b64tab[cccc.charAt(1)] << 12 : 0) |
136 | (len > 2 ? b64tab[cccc.charAt(2)] << 6 : 0) |
137 | (len > 3 ? b64tab[cccc.charAt(3)] : 0),
138 | chars = [
139 | fromCharCode(n >>> 16),
140 | fromCharCode((n >>> 8) & 255),
141 | fromCharCode(n & 255),
142 | ];
143 | chars.length -= [0, 0, 2, 1][padlen];
144 | return chars.join('');
145 | };
146 | var _atob = global.atob
147 | ? function (a) {
148 | return global.atob(a);
149 | }
150 | : function (a) {
151 | return a.replace(/\S{1,4}/g, cb_decode);
152 | };
153 | var atob = function (a) {
154 | return _atob(String(a).replace(/[^A-Za-z0-9\+\/]/g, ''));
155 | };
156 | var _decode = buffer
157 | ? buffer.from && Uint8Array && buffer.from !== Uint8Array.from
158 | ? function (a) {
159 | return (a.constructor === buffer.constructor
160 | ? a
161 | : buffer.from(a, 'base64')
162 | ).toString();
163 | }
164 | : function (a) {
165 | return (a.constructor === buffer.constructor
166 | ? a
167 | : new buffer(a, 'base64')
168 | ).toString();
169 | }
170 | : function (a) {
171 | return btou(_atob(a));
172 | };
173 | var decode = function (a) {
174 | return _decode(
175 | String(a)
176 | .replace(/[-_]/g, function (m0) {
177 | return m0 == '-' ? '+' : '/';
178 | })
179 | .replace(/[^A-Za-z0-9\+\/]/g, ''),
180 | );
181 | };
182 | var noConflict = function () {
183 | var Base64 = global.Base64;
184 | global.Base64 = _Base64;
185 | return Base64;
186 | };
187 | global.Base64 = {
188 | VERSION: version,
189 | atob: atob,
190 | btoa: btoa,
191 | fromBase64: decode,
192 | toBase64: encode,
193 | utob: utob,
194 | encode: encode,
195 | encodeURI: encodeURI,
196 | btou: btou,
197 | decode: decode,
198 | noConflict: noConflict,
199 | __buffer__: buffer,
200 | };
201 | if (typeof Object.defineProperty === 'function') {
202 | var noEnum = function (v) {
203 | return {
204 | value: v,
205 | enumerable: false,
206 | writable: true,
207 | configurable: true,
208 | };
209 | };
210 | global.Base64.extendString = function () {
211 | Object.defineProperty(
212 | String.prototype,
213 | 'fromBase64',
214 | noEnum(function () {
215 | return decode(this);
216 | }),
217 | );
218 | Object.defineProperty(
219 | String.prototype,
220 | 'toBase64',
221 | noEnum(function (urisafe) {
222 | return encode(this, urisafe);
223 | }),
224 | );
225 | Object.defineProperty(
226 | String.prototype,
227 | 'toBase64URI',
228 | noEnum(function () {
229 | return encode(this, true);
230 | }),
231 | );
232 | };
233 | }
234 | if (global.Meteor) {
235 | Base64 = global.Base64;
236 | }
237 | if (typeof module !== 'undefined' && module.exports) {
238 | module.exports.Base64 = global.Base64;
239 | } else if (typeof define === 'function' && define.amd) {
240 | define([], function () {
241 | return global.Base64;
242 | });
243 | }
244 | return { Base64: global.Base64 };
245 | },
246 | );
247 |
--------------------------------------------------------------------------------
/src/navigation/index.tsx:
--------------------------------------------------------------------------------
1 | import * as React from 'react';
2 | import { NavigationContainer } from '@react-navigation/native';
3 | import { createStackNavigator } from '@react-navigation/stack';
4 | import { HomeScreen } from '../screens/Home';
5 | import { DeviceScreen } from '../screens/Device';
6 | import { Device } from 'react-native-ble-plx';
7 |
8 | export type RootStackParamList = {
9 | Home: undefined;
10 | Device: { device: Device };
11 | };
12 |
13 | const Stack = createStackNavigator();
14 |
15 | export const RootNavigator = () => (
16 |
17 |
18 |
19 |
20 |
21 |
22 | );
23 |
--------------------------------------------------------------------------------
/src/screens/Device.tsx:
--------------------------------------------------------------------------------
1 | import { StackScreenProps } from '@react-navigation/stack';
2 | import React, { useCallback, useEffect, useState } from 'react';
3 | import { Text, ScrollView, Button, View, StyleSheet } from 'react-native';
4 | import { Service } from 'react-native-ble-plx';
5 | import { ServiceCard } from '../components/ServiceCard';
6 | import { RootStackParamList } from '../navigation/index';
7 |
8 | const DeviceScreen = ({
9 | route,
10 | navigation,
11 | }: StackScreenProps) => {
12 | // get the device object which was given through navigation params
13 | const { device } = route.params;
14 |
15 | const [isConnected, setIsConnected] = useState(false);
16 | const [services, setServices] = useState([]);
17 |
18 | // handle the device disconnection
19 | const disconnectDevice = useCallback(async () => {
20 | navigation.goBack();
21 | const isDeviceConnected = await device.isConnected();
22 | if (isDeviceConnected) {
23 | await device.cancelConnection();
24 | }
25 | }, [device, navigation]);
26 |
27 | useEffect(() => {
28 | const getDeviceInformations = async () => {
29 | // connect to the device
30 | const connectedDevice = await device.connect();
31 | setIsConnected(true);
32 |
33 | // discover all device services and characteristics
34 | const allServicesAndCharacteristics = await connectedDevice.discoverAllServicesAndCharacteristics();
35 | // get the services only
36 | const discoveredServices = await allServicesAndCharacteristics.services();
37 | setServices(discoveredServices);
38 | };
39 |
40 | getDeviceInformations();
41 |
42 | device.onDisconnected(() => {
43 | navigation.navigate('Home');
44 | });
45 |
46 | // give a callback to the useEffect to disconnect the device when we will leave the device screen
47 | return () => {
48 | disconnectDevice();
49 | };
50 | }, [device, disconnectDevice, navigation]);
51 |
52 | return (
53 |
54 |
55 |
56 |
57 | {`Id : ${device.id}`}
58 | {`Name : ${device.name}`}
59 | {`Is connected : ${isConnected}`}
60 | {`RSSI : ${device.rssi}`}
61 | {`Manufacturer : ${device.manufacturerData}`}
62 | {`ServiceData : ${device.serviceData}`}
63 | {`UUIDS : ${device.serviceUUIDs}`}
64 |
65 | {/* Display a list of all services */}
66 | {services &&
67 | services.map((service) => )}
68 |
69 |
70 | );
71 | };
72 |
73 | const styles = StyleSheet.create({
74 | container: {
75 | padding: 12,
76 | },
77 |
78 | header: {
79 | backgroundColor: 'teal',
80 | marginBottom: 12,
81 | borderRadius: 16,
82 | shadowColor: 'rgba(60,64,67,0.3)',
83 | shadowOpacity: 0.4,
84 | shadowRadius: 10,
85 | elevation: 4,
86 | padding: 12,
87 | },
88 | });
89 |
90 | export { DeviceScreen };
91 |
--------------------------------------------------------------------------------
/src/screens/Home.tsx:
--------------------------------------------------------------------------------
1 | import React, { useEffect, useReducer, useState } from 'react';
2 | import {
3 | ActivityIndicator,
4 | Button,
5 | FlatList,
6 | StyleSheet,
7 | Text,
8 | View,
9 | } from 'react-native';
10 | import { SafeAreaView } from 'react-native-safe-area-context';
11 | import { Colors } from 'react-native/Libraries/NewAppScreen';
12 | import { DeviceCard } from '../components/DeviceCard';
13 | import { BleManager, Device } from 'react-native-ble-plx';
14 | import { theme } from '../theme';
15 |
16 | const manager = new BleManager();
17 |
18 | // Reducer to add only the devices which have not been added yet
19 | // When the bleManager search for devices, each time it detect a ble device, it returns the ble device even if this one has already been returned
20 | const reducer = (
21 | state: Device[],
22 | action: { type: 'ADD_DEVICE'; payload: Device } | { type: 'CLEAR' },
23 | ): Device[] => {
24 | switch (action.type) {
25 | case 'ADD_DEVICE':
26 | const { payload: device } = action;
27 |
28 | // check if the detected device is not already added to the list
29 | if (device && !state.find((dev) => dev.id === device.id)) {
30 | return [...state, device];
31 | }
32 | return state;
33 | case 'CLEAR':
34 | return [];
35 | default:
36 | return state;
37 | }
38 | };
39 |
40 | const HomeScreen = () => {
41 | // reducer to store and display detected ble devices
42 | const [scannedDevices, dispatch] = useReducer(reducer, []);
43 |
44 | // state to give the user a feedback about the manager scanning devices
45 | const [isLoading, setIsLoading] = useState(false);
46 |
47 | const scanDevices = () => {
48 | // display the Activityindicator
49 | setIsLoading(true);
50 |
51 | // scan devices
52 | manager.startDeviceScan(null, null, (error, scannedDevice) => {
53 | if (error) {
54 | console.warn(error);
55 | }
56 |
57 | // if a device is detected add the device to the list by dispatching the action into the reducer
58 | if (scannedDevice) {
59 | dispatch({ type: 'ADD_DEVICE', payload: scannedDevice });
60 | }
61 | });
62 |
63 | // stop scanning devices after 5 seconds
64 | setTimeout(() => {
65 | manager.stopDeviceScan();
66 | setIsLoading(false);
67 | }, 5000);
68 | };
69 |
70 | const ListHeaderComponent = () => (
71 |
72 |
73 | Step One
74 |
75 |
76 |
88 |
89 | );
90 |
91 | useEffect(() => {
92 | return () => {
93 | manager.destroy();
94 | };
95 | }, []);
96 | return (
97 |
98 | item.id}
100 | data={scannedDevices}
101 | renderItem={({ item }) => }
102 | ListHeaderComponent={ListHeaderComponent}
103 | contentContainerStyle={styles.content}
104 | />
105 |
106 | );
107 | };
108 |
109 | const styles = StyleSheet.create({
110 | body: {
111 | backgroundColor: Colors.red,
112 | },
113 | sectionContainer: {
114 | marginTop: 32,
115 | paddingHorizontal: 24,
116 | },
117 | sectionTitle: {
118 | fontSize: 24,
119 | fontWeight: '600',
120 | color: Colors.black,
121 | },
122 | sectionDescription: {
123 | marginTop: 8,
124 | fontSize: 18,
125 | fontWeight: '400',
126 | color: Colors.dark,
127 | },
128 | content: {
129 | backgroundColor: theme.colors.secondary,
130 | paddingHorizontal: theme.spacing * 2,
131 | },
132 | activityIndicatorContainer: { marginVertical: 6 },
133 | });
134 |
135 | export { HomeScreen };
136 |
--------------------------------------------------------------------------------
/src/theme/index.tsx:
--------------------------------------------------------------------------------
1 | const colors = {
2 | primary: 'rgb(63,73,194)',
3 | white: '#FFFFFF',
4 | secondary: 'rgb(242,242,242)',
5 | black: 'rgb(30,30,30)',
6 | };
7 |
8 | export const theme = {
9 | colors,
10 | spacing: 8,
11 | };
12 |
--------------------------------------------------------------------------------
/tsconfig.json:
--------------------------------------------------------------------------------
1 |
2 | {
3 | "compilerOptions": {
4 | /* Basic Options */
5 | "target": "esnext", /* Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017','ES2018' or 'ESNEXT'. */
6 | "module": "commonjs", /* Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', or 'ESNext'. */
7 | "lib": ["es6"], /* Specify library files to be included in the compilation. */
8 | "allowJs": true, /* Allow javascript files to be compiled. */
9 | // "checkJs": true, /* Report errors in .js files. */
10 | "jsx": "react-native", /* Specify JSX code generation: 'preserve', 'react-native', or 'react'. */
11 | // "declaration": true, /* Generates corresponding '.d.ts' file. */
12 | // "sourceMap": true, /* Generates corresponding '.map' file. */
13 | // "outFile": "./", /* Concatenate and emit output to single file. */
14 | // "outDir": "./", /* Redirect output structure to the directory. */
15 | // "rootDir": "./", /* Specify the root directory of input files. Use to control the output directory structure with --outDir. */
16 | // "removeComments": true, /* Do not emit comments to output. */
17 | "noEmit": true, /* Do not emit outputs. */
18 | // "incremental": true, /* Enable incremental compilation */
19 | // "importHelpers": true, /* Import emit helpers from 'tslib'. */
20 | // "downlevelIteration": true, /* Provide full support for iterables in 'for-of', spread, and destructuring when targeting 'ES5' or 'ES3'. */
21 | "isolatedModules": true, /* Transpile each file as a separate module (similar to 'ts.transpileModule'). */
22 |
23 | /* Strict Type-Checking Options */
24 | "strict": true, /* Enable all strict type-checking options. */
25 | // "noImplicitAny": true, /* Raise error on expressions and declarations with an implied 'any' type. */
26 | // "strictNullChecks": true, /* Enable strict null checks. */
27 | // "strictFunctionTypes": true, /* Enable strict checking of function types. */
28 | // "strictPropertyInitialization": true, /* Enable strict checking of property initialization in classes. */
29 | // "noImplicitThis": true, /* Raise error on 'this' expressions with an implied 'any' type. */
30 | // "alwaysStrict": true, /* Parse in strict mode and emit "use strict" for each source file. */
31 |
32 | /* Additional Checks */
33 | // "noUnusedLocals": true, /* Report errors on unused locals. */
34 | // "noUnusedParameters": true, /* Report errors on unused parameters. */
35 | // "noImplicitReturns": true, /* Report error when not all code paths in function return a value. */
36 | // "noFallthroughCasesInSwitch": true, /* Report errors for fallthrough cases in switch statement. */
37 |
38 | /* Module Resolution Options */
39 | "moduleResolution": "node", /* Specify module resolution strategy: 'node' (Node.js) or 'classic' (TypeScript pre-1.6). */
40 | // "baseUrl": "./", /* Base directory to resolve non-absolute module names. */
41 | // "paths": {}, /* A series of entries which re-map imports to lookup locations relative to the 'baseUrl'. */
42 | // "rootDirs": [], /* List of root folders whose combined content represents the structure of the project at runtime. */
43 | // "typeRoots": [], /* List of folders to include type definitions from. */
44 | // "types": [], /* Type declaration files to be included in compilation. */
45 | "allowSyntheticDefaultImports": true, /* Allow default imports from modules with no default export. This does not affect code emit, just typechecking. */
46 | "esModuleInterop": true /* Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'. */
47 | // "preserveSymlinks": true, /* Do not resolve the real path of symlinks. */
48 |
49 | /* Source Map Options */
50 | // "sourceRoot": "./", /* Specify the location where debugger should locate TypeScript files instead of source locations. */
51 | // "mapRoot": "./", /* Specify the location where debugger should locate map files instead of generated locations. */
52 | // "inlineSourceMap": true, /* Emit a single file with source maps instead of having a separate file. */
53 | // "inlineSources": true, /* Emit the source alongside the sourcemaps within a single file; requires '--inlineSourceMap' or '--sourceMap' to be set. */
54 |
55 | /* Experimental Options */
56 | // "experimentalDecorators": true, /* Enables experimental support for ES7 decorators. */
57 | // "emitDecoratorMetadata": true, /* Enables experimental support for emitting type metadata for decorators. */
58 | },
59 | "exclude": [
60 | "node_modules", "babel.config.js", "metro.config.js", "jest.config.js"
61 | ]
62 | }
63 |
--------------------------------------------------------------------------------