UNPKG

react-native-permission-handler-wrapper

Version:

A lightweight and reusable React Native wrapper component to handle runtime permissions like camera, location, photo library, and notifications — with built-in UI fallback for denied or blocked states.

373 lines (372 loc) 14 kB
"use strict"; function _array_like_to_array(arr, len) { if (len == null || len > arr.length) len = arr.length; for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i]; return arr2; } function _array_with_holes(arr) { if (Array.isArray(arr)) return arr; } function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } } function _async_to_generator(fn) { return function() { var self = this, args = arguments; return new Promise(function(resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; } function _iterable_to_array_limit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){ _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally{ try { if (!_n && _i["return"] != null) _i["return"](); } finally{ if (_d) throw _e; } } return _arr; } function _non_iterable_rest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _sliced_to_array(arr, i) { return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest(); } function _type_of(obj) { "@swc/helpers - typeof"; return obj && typeof Symbol !== "undefined" && obj.constructor === Symbol ? "symbol" : typeof obj; } function _unsupported_iterable_to_array(o, minLen) { if (!o) return; if (typeof o === "string") return _array_like_to_array(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(n); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen); } function _ts_generator(thisArg, body) { var f, y, t, _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype); return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; function verb(n) { return function(v) { return step([ n, v ]); }; } function step(op) { if (f) throw new TypeError("Generator is already executing."); while(g && (g = 0, op[0] && (_ = 0)), _)try { if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; if (y = 0, t) op = [ op[0] & 2, t.value ]; switch(op[0]){ case 0: case 1: t = op; break; case 4: _.label++; return { value: op[1], done: false }; case 5: _.label++; y = op[1]; op = [ 0 ]; continue; case 7: op = _.ops.pop(); _.trys.pop(); continue; default: if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) { _.label = op[1]; break; } if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } if (t[2]) _.ops.pop(); _.trys.pop(); continue; } op = body.call(thisArg, _); } catch (e) { op = [ 6, e ]; y = 0; } finally{ f = t = 0; } if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; } } var __create = Object.create; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __getProtoOf = Object.getPrototypeOf; var __hasOwnProp = Object.prototype.hasOwnProperty; var __export = function(target, all) { for(var name in all)__defProp(target, name, { get: all[name], enumerable: true }); }; var __copyProps = function(to, from, except, desc) { if (from && (typeof from === "undefined" ? "undefined" : _type_of(from)) === "object" || typeof from === "function") { var _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined; try { var _loop = function() { var key = _step.value; if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, { get: function() { return from[key]; }, enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); }; for(var _iterator = __getOwnPropNames(from)[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true)_loop(); } catch (err) { _didIteratorError = true; _iteratorError = err; } finally{ try { if (!_iteratorNormalCompletion && _iterator.return != null) { _iterator.return(); } } finally{ if (_didIteratorError) { throw _iteratorError; } } } } return to; }; var __toESM = function(mod, isNodeMode, target) { return target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(// If the importer is in node compatibility mode or this is not an ESM // file that has been converted to a CommonJS file using a Babel- // compatible transform (i.e. "__esModule" has not been set), then set // "default" to the CommonJS "module.exports" for node compatibility. isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, mod); }; var __toCommonJS = function(mod) { return __copyProps(__defProp({}, "__esModule", { value: true }), mod); }; // index.ts var index_exports = {}; __export(index_exports, { PermissionHandler: function() { return PermissionHandler_default; } }); module.exports = __toCommonJS(index_exports); // src/PermissionHandler.tsx var import_react = __toESM(require("react")); var import_react_native = require("react-native"); var import_react_native_permissions = require("react-native-permissions"); var getPermissionByType = function(type) { var isIOS = import_react_native.Platform.OS === "ios"; switch(type){ case "camera": return isIOS ? import_react_native_permissions.PERMISSIONS.IOS.CAMERA : import_react_native_permissions.PERMISSIONS.ANDROID.CAMERA; case "location": return isIOS ? import_react_native_permissions.PERMISSIONS.IOS.LOCATION_WHEN_IN_USE : import_react_native_permissions.PERMISSIONS.ANDROID.ACCESS_FINE_LOCATION; case "photo": return isIOS ? import_react_native_permissions.PERMISSIONS.IOS.PHOTO_LIBRARY : import_react_native_permissions.PERMISSIONS.ANDROID.READ_MEDIA_IMAGES; default: return void 0; } }; var PermissionHandler = function(param) { var type = param.type, children = param.children; var _ref = _sliced_to_array((0, import_react.useState)(false), 2), isGranted = _ref[0], setIsGranted = _ref[1]; var _ref1 = _sliced_to_array((0, import_react.useState)(false), 2), isBlocked = _ref1[0], setIsBlocked = _ref1[1]; var permission = getPermissionByType(type); var checkPermission = function() { return _async_to_generator(function() { var permission2, result, req; return _ts_generator(this, function(_state) { switch(_state.label){ case 0: permission2 = getPermissionByType(type); if (!permission2) { console.warn("Invalid permission type provided:", type); return [ 2 ]; } return [ 4, (0, import_react_native_permissions.check)(permission2) ]; case 1: result = _state.sent(); if (!(result === import_react_native_permissions.RESULTS.GRANTED)) return [ 3, 2 ]; setIsGranted(true); return [ 3, 5 ]; case 2: if (!(result === import_react_native_permissions.RESULTS.DENIED)) return [ 3, 4 ]; return [ 4, (0, import_react_native_permissions.request)(permission2) ]; case 3: req = _state.sent(); if (req === import_react_native_permissions.RESULTS.GRANTED) { setIsGranted(true); } else if (req === import_react_native_permissions.RESULTS.BLOCKED) { setIsBlocked(true); } return [ 3, 5 ]; case 4: if (result === import_react_native_permissions.RESULTS.BLOCKED) { setIsBlocked(true); } _state.label = 5; case 5: return [ 2 ]; } }); })(); }; (0, import_react.useEffect)(function() { checkPermission(); }, []); if (isGranted) return /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, children); return /* @__PURE__ */ import_react.default.createElement(import_react_native.Modal, { transparent: true, visible: isBlocked, animationType: "fade" }, /* @__PURE__ */ import_react.default.createElement(import_react_native.View, { style: styles.modalOverlay }, /* @__PURE__ */ import_react.default.createElement(import_react_native.View, { style: styles.modalContent }, /* @__PURE__ */ import_react.default.createElement(import_react_native.Text, { style: styles.title }, "Permission Required"), /* @__PURE__ */ import_react.default.createElement(import_react_native.Text, { style: styles.message }, "This feature needs access to your ", type, ". Please allow it from settings."), /* @__PURE__ */ import_react.default.createElement(import_react_native.Button, { title: "Open Settings", onPress: function() { return (0, import_react_native_permissions.openSettings)(); } })))); }; var PermissionHandler_default = PermissionHandler; var styles = import_react_native.StyleSheet.create({ modalOverlay: { flex: 1, backgroundColor: "#00000077", justifyContent: "center", alignItems: "center" }, modalContent: { width: "80%", padding: 20, backgroundColor: "white", borderRadius: 12, elevation: 4 }, title: { fontSize: 18, fontWeight: "bold", marginBottom: 10 }, message: { fontSize: 15, marginBottom: 15 } }); // Annotate the CommonJS export names for ESM import in node: 0 && (module.exports = { PermissionHandler: PermissionHandler });