@situm/react-native 3.8.1 → 3.9.0-beta.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -86,19 +86,7 @@ up a Situm account.
86
86
 
87
87
  #### Android
88
88
 
89
- 1. Include the Situm repository in your project level `build.gradle`:
90
-
91
- ```groovy
92
- allprojects {
93
- repositories {
94
- maven {
95
- url "https://repo.situm.es/artifactory/libs-release-local"
96
- }
97
- }
98
- }
99
- ```
100
-
101
- 2. Add the `ACCESS_FINE_LOCATION` permission to your `AndroidManifest.xml` file if you have configured Situm SDK to [use GPS](<https://developers.situm.com/sdk_documentation/android/javadoc/latest/es/situm/sdk/location/locationrequest#useGps()>):
89
+ 1. Add the `ACCESS_FINE_LOCATION` permission to your `AndroidManifest.xml` file if you have configured Situm SDK to [use GPS](<https://developers.situm.com/sdk_documentation/android/javadoc/latest/es/situm/sdk/location/locationrequest#useGps()>):
102
90
 
103
91
  ```xml
104
92
  <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
@@ -1,6 +1,14 @@
1
1
  import groovy.json.JsonSlurper
2
- apply plugin: 'com.android.library'
3
2
 
3
+ rootProject.allprojects {
4
+ repositories {
5
+ google()
6
+ mavenCentral()
7
+ maven { url "https://repo.situm.es/artifactory/libs-release-local" }
8
+ }
9
+ }
10
+
11
+ apply plugin: 'com.android.library'
4
12
 
5
13
  android {
6
14
  compileSdkVersion rootProject.ext.compileSdkVersion
@@ -0,0 +1,7 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <Workspace
3
+ version = "1.0">
4
+ <FileRef
5
+ location = "self:">
6
+ </FileRef>
7
+ </Workspace>
@@ -0,0 +1,8 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
3
+ <plist version="1.0">
4
+ <dict>
5
+ <key>IDEDidComputeMac32BitWarning</key>
6
+ <true/>
7
+ </dict>
8
+ </plist>
@@ -0,0 +1,14 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
3
+ <plist version="1.0">
4
+ <dict>
5
+ <key>SchemeUserState</key>
6
+ <dict>
7
+ <key>RNSitumReactNativePlugin.xcscheme_^#shared#^_</key>
8
+ <dict>
9
+ <key>orderHint</key>
10
+ <integer>0</integer>
11
+ </dict>
12
+ </dict>
13
+ </dict>
14
+ </plist>
@@ -14,15 +14,4 @@ Object.keys(_logError).forEach(function (key) {
14
14
  }
15
15
  });
16
16
  });
17
- var _requestPermission = require("./requestPermission");
18
- Object.keys(_requestPermission).forEach(function (key) {
19
- if (key === "default" || key === "__esModule") return;
20
- if (key in exports && exports[key] === _requestPermission[key]) return;
21
- Object.defineProperty(exports, key, {
22
- enumerable: true,
23
- get: function () {
24
- return _requestPermission[key];
25
- }
26
- });
27
- });
28
17
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["_logError","require","Object","keys","forEach","key","exports","defineProperty","enumerable","get","_requestPermission"],"sourceRoot":"../../../src","sources":["utils/index.ts"],"mappings":";;;;;AAAA,IAAAA,SAAA,GAAAC,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAH,SAAA,EAAAI,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAL,SAAA,CAAAK,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAT,SAAA,CAAAK,GAAA;IAAA;EAAA;AAAA;AACA,IAAAK,kBAAA,GAAAT,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAO,kBAAA,EAAAN,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAK,kBAAA,CAAAL,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAC,kBAAA,CAAAL,GAAA;IAAA;EAAA;AAAA","ignoreList":[]}
1
+ {"version":3,"names":["_logError","require","Object","keys","forEach","key","exports","defineProperty","enumerable","get"],"sourceRoot":"../../../src","sources":["utils/index.ts"],"mappings":";;;;;AAAA,IAAAA,SAAA,GAAAC,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAH,SAAA,EAAAI,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAL,SAAA,CAAAK,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAT,SAAA,CAAAK,GAAA;IAAA;EAAA;AAAA","ignoreList":[]}
@@ -1,3 +1,2 @@
1
1
  export * from "./logError";
2
- export * from "./requestPermission";
3
2
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"names":[],"sourceRoot":"../../../src","sources":["utils/index.ts"],"mappings":"AAAA,cAAc,YAAY;AAC1B,cAAc,qBAAqB","ignoreList":[]}
1
+ {"version":3,"names":[],"sourceRoot":"../../../src","sources":["utils/index.ts"],"mappings":"AAAA,cAAc,YAAY","ignoreList":[]}
@@ -1,3 +1,2 @@
1
1
  export * from "./logError";
2
- export * from "./requestPermission";
3
2
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/utils/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,cAAc,qBAAqB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/utils/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@situm/react-native",
3
- "version": "3.8.1",
3
+ "version": "3.9.0-beta.1",
4
4
  "description": "Set of utilities that allow any developer to build React Native location based apps using Situm's indoor positioning system.",
5
5
  "private": false,
6
6
  "repository": "https://github.com/situmtech/react-native",
@@ -101,7 +101,6 @@
101
101
  },
102
102
  "dependencies": {
103
103
  "react-dom": "^18.2.0",
104
- "react-native-permissions": "^3.8.4",
105
104
  "react-native-webview": "*"
106
105
  },
107
106
  "resolutions": {
@@ -169,6 +168,6 @@
169
168
  "prettier": {},
170
169
  "sdkVersions": {
171
170
  "android": "3.13.2@aar",
172
- "ios": "3.13.1"
171
+ "ios": "3.13.0"
173
172
  }
174
173
  }
@@ -1,2 +1 @@
1
1
  export * from "./logError";
2
- export * from "./requestPermission";
@@ -1,54 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.requestPermission = exports.default = void 0;
7
- var _reactNative = require("react-native");
8
- var _reactNativePermissions = require("react-native-permissions");
9
- // TODO: can requestMultiple be used ?
10
- const checkIOSPermissions = async () => {
11
- const granted = await (0, _reactNativePermissions.request)(_reactNativePermissions.PERMISSIONS.IOS.LOCATION_WHEN_IN_USE);
12
-
13
- // Check if already denied
14
- if (granted !== _reactNativePermissions.RESULTS.GRANTED) {
15
- throw "Situm > permissions > ACCESS_FINE_LOCATION denied";
16
- }
17
- console.debug("Situm > permissions > LOCATION_WHEN_IN_USE permission granted");
18
- return true;
19
- };
20
- const checkAndroidPermissions = async () => {
21
- let granted;
22
-
23
- //@ts-ignore
24
- if (_reactNative.Platform.Version <= 30) {
25
- console.debug("Situm > permissions > ANDROID VERSION < 30");
26
- granted = await (0, _reactNativePermissions.request)(_reactNativePermissions.PERMISSIONS.ANDROID.ACCESS_FINE_LOCATION);
27
- if (granted === _reactNativePermissions.RESULTS.GRANTED) {
28
- console.debug("Situm > permissions > ACCESS_FINE_LOCATION granted");
29
- return true;
30
- } else {
31
- throw "Situm > permissions > ACCESS_FINE_LOCATION permission not granted";
32
- }
33
- }
34
- console.debug("Situm > permissions > ANDROID VERSION > 30");
35
- granted = await (0, _reactNativePermissions.requestMultiple)([_reactNativePermissions.PERMISSIONS.ANDROID.ACCESS_FINE_LOCATION, _reactNativePermissions.PERMISSIONS.ANDROID.BLUETOOTH_CONNECT, _reactNativePermissions.PERMISSIONS.ANDROID.BLUETOOTH_SCAN]);
36
- if (granted["android.permission.ACCESS_FINE_LOCATION"] === _reactNativePermissions.RESULTS.GRANTED && granted["android.permission.BLUETOOTH_CONNECT"] === _reactNativePermissions.RESULTS.GRANTED && granted["android.permission.BLUETOOTH_SCAN"] === _reactNativePermissions.RESULTS.GRANTED) {
37
- console.debug("Situm > permissions > ACCESS_FINE_LOCATION, BLUETOOTH_CONNECT and BLUETOOTH_SCAN permissions granted");
38
- return true;
39
- }
40
- throw "Situm > permissions > ACCESS_FINE_LOCATION, BLUETOOTH_CONNECT or BLUETOOTH_SCAN permissions not granted";
41
- };
42
- const requestPermission = async () => {
43
- console.debug("Situm > permissions > Retrieving permissions for platform " + _reactNative.Platform.OS);
44
- if (!["ios", "android"].includes(_reactNative.Platform.OS)) {
45
- throw `Situm > permissions > Platform '${_reactNative.Platform.OS}' not supported`;
46
- }
47
- return await (_reactNative.Platform.OS === "ios" ? checkIOSPermissions() : checkAndroidPermissions()).then(() => null).catch(e => {
48
- console.warn(e);
49
- throw e;
50
- });
51
- };
52
- exports.requestPermission = requestPermission;
53
- var _default = exports.default = requestPermission;
54
- //# sourceMappingURL=requestPermission.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["_reactNative","require","_reactNativePermissions","checkIOSPermissions","granted","request","PERMISSIONS","IOS","LOCATION_WHEN_IN_USE","RESULTS","GRANTED","console","debug","checkAndroidPermissions","Platform","Version","ANDROID","ACCESS_FINE_LOCATION","requestMultiple","BLUETOOTH_CONNECT","BLUETOOTH_SCAN","requestPermission","OS","includes","then","catch","e","warn","exports","_default","default"],"sourceRoot":"../../../src","sources":["utils/requestPermission.ts"],"mappings":";;;;;;AAAA,IAAAA,YAAA,GAAAC,OAAA;AACA,IAAAC,uBAAA,GAAAD,OAAA;AAOA;AACA,MAAME,mBAAmB,GAAG,MAAAA,CAAA,KAAY;EACtC,MAAMC,OAAO,GAAG,MAAM,IAAAC,+BAAO,EAACC,mCAAW,CAACC,GAAG,CAACC,oBAAoB,CAAC;;EAEnE;EACA,IAAIJ,OAAO,KAAKK,+BAAO,CAACC,OAAO,EAAE;IAC/B,MAAM,mDAAmD;EAC3D;EAEAC,OAAO,CAACC,KAAK,CACX,+DACF,CAAC;EAED,OAAO,IAAI;AACb,CAAC;AAED,MAAMC,uBAAuB,GAAG,MAAAA,CAAA,KAAY;EAC1C,IAAIT,OAAO;;EAEX;EACA,IAAIU,qBAAQ,CAACC,OAAO,IAAI,EAAE,EAAE;IAC1BJ,OAAO,CAACC,KAAK,CAAC,4CAA4C,CAAC;IAE3DR,OAAO,GAAG,MAAM,IAAAC,+BAAO,EAACC,mCAAW,CAACU,OAAO,CAACC,oBAAoB,CAAC;IAEjE,IAAIb,OAAO,KAAKK,+BAAO,CAACC,OAAO,EAAE;MAC/BC,OAAO,CAACC,KAAK,CAAC,oDAAoD,CAAC;MACnE,OAAO,IAAI;IACb,CAAC,MAAM;MACL,MAAM,mEAAmE;IAC3E;EACF;EAEAD,OAAO,CAACC,KAAK,CAAC,4CAA4C,CAAC;EAC3DR,OAAO,GAAG,MAAM,IAAAc,uCAAe,EAAC,CAC9BZ,mCAAW,CAACU,OAAO,CAACC,oBAAoB,EACxCX,mCAAW,CAACU,OAAO,CAACG,iBAAiB,EACrCb,mCAAW,CAACU,OAAO,CAACI,cAAc,CACnC,CAAC;EAEF,IACEhB,OAAO,CAAC,yCAAyC,CAAC,KAAKK,+BAAO,CAACC,OAAO,IACtEN,OAAO,CAAC,sCAAsC,CAAC,KAAKK,+BAAO,CAACC,OAAO,IACnEN,OAAO,CAAC,mCAAmC,CAAC,KAAKK,+BAAO,CAACC,OAAO,EAChE;IACAC,OAAO,CAACC,KAAK,CACX,sGACF,CAAC;IACD,OAAO,IAAI;EACb;EAEA,MAAM,yGAAyG;AACjH,CAAC;AAEM,MAAMS,iBAAiB,GAAG,MAAAA,CAAA,KAAY;EAC3CV,OAAO,CAACC,KAAK,CACX,4DAA4D,GAAGE,qBAAQ,CAACQ,EAC1E,CAAC;EAED,IAAI,CAAC,CAAC,KAAK,EAAE,SAAS,CAAC,CAACC,QAAQ,CAACT,qBAAQ,CAACQ,EAAE,CAAC,EAAE;IAC7C,MAAO,mCAAkCR,qBAAQ,CAACQ,EAAG,iBAAgB;EACvE;EAEA,OAAO,MAAM,CAACR,qBAAQ,CAACQ,EAAE,KAAK,KAAK,GAC/BnB,mBAAmB,CAAC,CAAC,GACrBU,uBAAuB,CAAC,CAAC,EAE1BW,IAAI,CAAC,MAAM,IAAI,CAAC,CAChBC,KAAK,CAAEC,CAAS,IAAK;IACpBf,OAAO,CAACgB,IAAI,CAACD,CAAC,CAAC;IACf,MAAMA,CAAC;EACT,CAAC,CAAC;AACN,CAAC;AAACE,OAAA,CAAAP,iBAAA,GAAAA,iBAAA;AAAA,IAAAQ,QAAA,GAAAD,OAAA,CAAAE,OAAA,GAEaT,iBAAiB","ignoreList":[]}
@@ -1,48 +0,0 @@
1
- import { Platform } from "react-native";
2
- import { PERMISSIONS, request, requestMultiple, RESULTS } from "react-native-permissions";
3
-
4
- // TODO: can requestMultiple be used ?
5
- const checkIOSPermissions = async () => {
6
- const granted = await request(PERMISSIONS.IOS.LOCATION_WHEN_IN_USE);
7
-
8
- // Check if already denied
9
- if (granted !== RESULTS.GRANTED) {
10
- throw "Situm > permissions > ACCESS_FINE_LOCATION denied";
11
- }
12
- console.debug("Situm > permissions > LOCATION_WHEN_IN_USE permission granted");
13
- return true;
14
- };
15
- const checkAndroidPermissions = async () => {
16
- let granted;
17
-
18
- //@ts-ignore
19
- if (Platform.Version <= 30) {
20
- console.debug("Situm > permissions > ANDROID VERSION < 30");
21
- granted = await request(PERMISSIONS.ANDROID.ACCESS_FINE_LOCATION);
22
- if (granted === RESULTS.GRANTED) {
23
- console.debug("Situm > permissions > ACCESS_FINE_LOCATION granted");
24
- return true;
25
- } else {
26
- throw "Situm > permissions > ACCESS_FINE_LOCATION permission not granted";
27
- }
28
- }
29
- console.debug("Situm > permissions > ANDROID VERSION > 30");
30
- granted = await requestMultiple([PERMISSIONS.ANDROID.ACCESS_FINE_LOCATION, PERMISSIONS.ANDROID.BLUETOOTH_CONNECT, PERMISSIONS.ANDROID.BLUETOOTH_SCAN]);
31
- if (granted["android.permission.ACCESS_FINE_LOCATION"] === RESULTS.GRANTED && granted["android.permission.BLUETOOTH_CONNECT"] === RESULTS.GRANTED && granted["android.permission.BLUETOOTH_SCAN"] === RESULTS.GRANTED) {
32
- console.debug("Situm > permissions > ACCESS_FINE_LOCATION, BLUETOOTH_CONNECT and BLUETOOTH_SCAN permissions granted");
33
- return true;
34
- }
35
- throw "Situm > permissions > ACCESS_FINE_LOCATION, BLUETOOTH_CONNECT or BLUETOOTH_SCAN permissions not granted";
36
- };
37
- export const requestPermission = async () => {
38
- console.debug("Situm > permissions > Retrieving permissions for platform " + Platform.OS);
39
- if (!["ios", "android"].includes(Platform.OS)) {
40
- throw `Situm > permissions > Platform '${Platform.OS}' not supported`;
41
- }
42
- return await (Platform.OS === "ios" ? checkIOSPermissions() : checkAndroidPermissions()).then(() => null).catch(e => {
43
- console.warn(e);
44
- throw e;
45
- });
46
- };
47
- export default requestPermission;
48
- //# sourceMappingURL=requestPermission.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["Platform","PERMISSIONS","request","requestMultiple","RESULTS","checkIOSPermissions","granted","IOS","LOCATION_WHEN_IN_USE","GRANTED","console","debug","checkAndroidPermissions","Version","ANDROID","ACCESS_FINE_LOCATION","BLUETOOTH_CONNECT","BLUETOOTH_SCAN","requestPermission","OS","includes","then","catch","e","warn"],"sourceRoot":"../../../src","sources":["utils/requestPermission.ts"],"mappings":"AAAA,SAASA,QAAQ,QAAQ,cAAc;AACvC,SACEC,WAAW,EACXC,OAAO,EACPC,eAAe,EACfC,OAAO,QACF,0BAA0B;;AAEjC;AACA,MAAMC,mBAAmB,GAAG,MAAAA,CAAA,KAAY;EACtC,MAAMC,OAAO,GAAG,MAAMJ,OAAO,CAACD,WAAW,CAACM,GAAG,CAACC,oBAAoB,CAAC;;EAEnE;EACA,IAAIF,OAAO,KAAKF,OAAO,CAACK,OAAO,EAAE;IAC/B,MAAM,mDAAmD;EAC3D;EAEAC,OAAO,CAACC,KAAK,CACX,+DACF,CAAC;EAED,OAAO,IAAI;AACb,CAAC;AAED,MAAMC,uBAAuB,GAAG,MAAAA,CAAA,KAAY;EAC1C,IAAIN,OAAO;;EAEX;EACA,IAAIN,QAAQ,CAACa,OAAO,IAAI,EAAE,EAAE;IAC1BH,OAAO,CAACC,KAAK,CAAC,4CAA4C,CAAC;IAE3DL,OAAO,GAAG,MAAMJ,OAAO,CAACD,WAAW,CAACa,OAAO,CAACC,oBAAoB,CAAC;IAEjE,IAAIT,OAAO,KAAKF,OAAO,CAACK,OAAO,EAAE;MAC/BC,OAAO,CAACC,KAAK,CAAC,oDAAoD,CAAC;MACnE,OAAO,IAAI;IACb,CAAC,MAAM;MACL,MAAM,mEAAmE;IAC3E;EACF;EAEAD,OAAO,CAACC,KAAK,CAAC,4CAA4C,CAAC;EAC3DL,OAAO,GAAG,MAAMH,eAAe,CAAC,CAC9BF,WAAW,CAACa,OAAO,CAACC,oBAAoB,EACxCd,WAAW,CAACa,OAAO,CAACE,iBAAiB,EACrCf,WAAW,CAACa,OAAO,CAACG,cAAc,CACnC,CAAC;EAEF,IACEX,OAAO,CAAC,yCAAyC,CAAC,KAAKF,OAAO,CAACK,OAAO,IACtEH,OAAO,CAAC,sCAAsC,CAAC,KAAKF,OAAO,CAACK,OAAO,IACnEH,OAAO,CAAC,mCAAmC,CAAC,KAAKF,OAAO,CAACK,OAAO,EAChE;IACAC,OAAO,CAACC,KAAK,CACX,sGACF,CAAC;IACD,OAAO,IAAI;EACb;EAEA,MAAM,yGAAyG;AACjH,CAAC;AAED,OAAO,MAAMO,iBAAiB,GAAG,MAAAA,CAAA,KAAY;EAC3CR,OAAO,CAACC,KAAK,CACX,4DAA4D,GAAGX,QAAQ,CAACmB,EAC1E,CAAC;EAED,IAAI,CAAC,CAAC,KAAK,EAAE,SAAS,CAAC,CAACC,QAAQ,CAACpB,QAAQ,CAACmB,EAAE,CAAC,EAAE;IAC7C,MAAO,mCAAkCnB,QAAQ,CAACmB,EAAG,iBAAgB;EACvE;EAEA,OAAO,MAAM,CAACnB,QAAQ,CAACmB,EAAE,KAAK,KAAK,GAC/Bd,mBAAmB,CAAC,CAAC,GACrBO,uBAAuB,CAAC,CAAC,EAE1BS,IAAI,CAAC,MAAM,IAAI,CAAC,CAChBC,KAAK,CAAEC,CAAS,IAAK;IACpBb,OAAO,CAACc,IAAI,CAACD,CAAC,CAAC;IACf,MAAMA,CAAC;EACT,CAAC,CAAC;AACN,CAAC;AAED,eAAeL,iBAAiB","ignoreList":[]}
@@ -1,3 +0,0 @@
1
- export declare const requestPermission: () => Promise<any>;
2
- export default requestPermission;
3
- //# sourceMappingURL=requestPermission.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"requestPermission.d.ts","sourceRoot":"","sources":["../../../../src/utils/requestPermission.ts"],"names":[],"mappings":"AA8DA,eAAO,MAAM,iBAAiB,oBAkB7B,CAAC;AAEF,eAAe,iBAAiB,CAAC"}
@@ -1,83 +0,0 @@
1
- import { Platform } from "react-native";
2
- import {
3
- PERMISSIONS,
4
- request,
5
- requestMultiple,
6
- RESULTS,
7
- } from "react-native-permissions";
8
-
9
- // TODO: can requestMultiple be used ?
10
- const checkIOSPermissions = async () => {
11
- const granted = await request(PERMISSIONS.IOS.LOCATION_WHEN_IN_USE);
12
-
13
- // Check if already denied
14
- if (granted !== RESULTS.GRANTED) {
15
- throw "Situm > permissions > ACCESS_FINE_LOCATION denied";
16
- }
17
-
18
- console.debug(
19
- "Situm > permissions > LOCATION_WHEN_IN_USE permission granted"
20
- );
21
-
22
- return true;
23
- };
24
-
25
- const checkAndroidPermissions = async () => {
26
- let granted;
27
-
28
- //@ts-ignore
29
- if (Platform.Version <= 30) {
30
- console.debug("Situm > permissions > ANDROID VERSION < 30");
31
-
32
- granted = await request(PERMISSIONS.ANDROID.ACCESS_FINE_LOCATION);
33
-
34
- if (granted === RESULTS.GRANTED) {
35
- console.debug("Situm > permissions > ACCESS_FINE_LOCATION granted");
36
- return true;
37
- } else {
38
- throw "Situm > permissions > ACCESS_FINE_LOCATION permission not granted";
39
- }
40
- }
41
-
42
- console.debug("Situm > permissions > ANDROID VERSION > 30");
43
- granted = await requestMultiple([
44
- PERMISSIONS.ANDROID.ACCESS_FINE_LOCATION,
45
- PERMISSIONS.ANDROID.BLUETOOTH_CONNECT,
46
- PERMISSIONS.ANDROID.BLUETOOTH_SCAN,
47
- ]);
48
-
49
- if (
50
- granted["android.permission.ACCESS_FINE_LOCATION"] === RESULTS.GRANTED &&
51
- granted["android.permission.BLUETOOTH_CONNECT"] === RESULTS.GRANTED &&
52
- granted["android.permission.BLUETOOTH_SCAN"] === RESULTS.GRANTED
53
- ) {
54
- console.debug(
55
- "Situm > permissions > ACCESS_FINE_LOCATION, BLUETOOTH_CONNECT and BLUETOOTH_SCAN permissions granted"
56
- );
57
- return true;
58
- }
59
-
60
- throw "Situm > permissions > ACCESS_FINE_LOCATION, BLUETOOTH_CONNECT or BLUETOOTH_SCAN permissions not granted";
61
- };
62
-
63
- export const requestPermission = async () => {
64
- console.debug(
65
- "Situm > permissions > Retrieving permissions for platform " + Platform.OS
66
- );
67
-
68
- if (!["ios", "android"].includes(Platform.OS)) {
69
- throw `Situm > permissions > Platform '${Platform.OS}' not supported`;
70
- }
71
-
72
- return await (Platform.OS === "ios"
73
- ? checkIOSPermissions()
74
- : checkAndroidPermissions()
75
- )
76
- .then(() => null)
77
- .catch((e: string) => {
78
- console.warn(e);
79
- throw e;
80
- });
81
- };
82
-
83
- export default requestPermission;