@situm/react-native 3.8.0 → 3.9.0-beta.0
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/ios/RNSitumReactNativePlugin.xcodeproj/project.xcworkspace/contents.xcworkspacedata +7 -0
- package/ios/RNSitumReactNativePlugin.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist +8 -0
- package/ios/RNSitumReactNativePlugin.xcodeproj/project.xcworkspace/xcuserdata/situm.xcuserdatad/UserInterfaceState.xcuserstate +0 -0
- package/ios/RNSitumReactNativePlugin.xcodeproj/xcuserdata/situm.xcuserdatad/xcschemes/xcschememanagement.plist +14 -0
- package/lib/commonjs/utils/index.js +0 -11
- package/lib/commonjs/utils/index.js.map +1 -1
- package/lib/module/utils/index.js +0 -1
- package/lib/module/utils/index.js.map +1 -1
- package/lib/typescript/src/utils/index.d.ts +0 -1
- package/lib/typescript/src/utils/index.d.ts.map +1 -1
- package/package.json +1 -2
- package/src/utils/index.ts +0 -1
- package/lib/commonjs/utils/requestPermission.js +0 -54
- package/lib/commonjs/utils/requestPermission.js.map +0 -1
- package/lib/module/utils/requestPermission.js +0 -48
- package/lib/module/utils/requestPermission.js.map +0 -1
- package/lib/typescript/src/utils/requestPermission.d.ts +0 -3
- package/lib/typescript/src/utils/requestPermission.d.ts.map +0 -1
- package/src/utils/requestPermission.ts +0 -83
|
Binary file
|
|
@@ -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"
|
|
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 +1 @@
|
|
|
1
|
-
{"version":3,"names":[],"sourceRoot":"../../../src","sources":["utils/index.ts"],"mappings":"AAAA,cAAc,YAAY
|
|
1
|
+
{"version":3,"names":[],"sourceRoot":"../../../src","sources":["utils/index.ts"],"mappings":"AAAA,cAAc,YAAY","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/utils/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,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.
|
|
3
|
+
"version": "3.9.0-beta.0",
|
|
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": {
|
package/src/utils/index.ts
CHANGED
|
@@ -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 +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;
|