@codeleap/mobile 1.9.27 → 1.9.30

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.
Files changed (119) hide show
  1. package/dist/components/Backdrop.d.ts +66 -0
  2. package/dist/components/Backdrop.js +70 -0
  3. package/dist/components/Backdrop.js.map +1 -0
  4. package/dist/components/Button.d.ts +3 -3
  5. package/dist/components/Button.js.map +1 -1
  6. package/dist/components/FileInput.js +0 -2
  7. package/dist/components/FileInput.js.map +1 -1
  8. package/dist/components/Image.js +2 -2
  9. package/dist/components/Image.js.map +1 -1
  10. package/dist/components/List.d.ts +23 -4
  11. package/dist/components/List.js +17 -1
  12. package/dist/components/List.js.map +1 -1
  13. package/dist/components/Modal/index.d.ts +1 -1
  14. package/dist/components/Modal/index.js +26 -27
  15. package/dist/components/Modal/index.js.map +1 -1
  16. package/dist/components/Modal/styles.d.ts +4 -15
  17. package/dist/components/Modal/styles.js +27 -23
  18. package/dist/components/Modal/styles.js.map +1 -1
  19. package/dist/components/NewModal/index.d.ts +27 -0
  20. package/dist/components/NewModal/index.js +99 -0
  21. package/dist/components/NewModal/index.js.map +1 -0
  22. package/dist/components/NewModal/styles.d.ts +57 -0
  23. package/dist/components/NewModal/styles.js +58 -0
  24. package/dist/components/NewModal/styles.js.map +1 -0
  25. package/dist/components/NewPager/index.js +3 -7
  26. package/dist/components/NewPager/index.js.map +1 -1
  27. package/dist/components/Overlay.js +13 -9
  28. package/dist/components/Overlay.js.map +1 -1
  29. package/dist/components/Scroll.d.ts +4 -2
  30. package/dist/components/Scroll.js.map +1 -1
  31. package/dist/components/SegmentedControl/index.d.ts +42 -0
  32. package/dist/components/SegmentedControl/index.js +137 -0
  33. package/dist/components/SegmentedControl/index.js.map +1 -0
  34. package/dist/components/SegmentedControl/styles.d.ts +54 -0
  35. package/dist/components/SegmentedControl/styles.js +36 -0
  36. package/dist/components/SegmentedControl/styles.js.map +1 -0
  37. package/dist/components/SegmentedControl.d.ts +5 -0
  38. package/dist/components/SegmentedControl.js +32 -0
  39. package/dist/components/SegmentedControl.js.map +1 -0
  40. package/dist/components/Select/index.js +1 -1
  41. package/dist/components/Select/index.js.map +1 -1
  42. package/dist/components/Text.d.ts +8 -3
  43. package/dist/components/Text.js +12 -5
  44. package/dist/components/Text.js.map +1 -1
  45. package/dist/components/TextInput.d.ts +4 -2
  46. package/dist/components/TextInput.js +2 -2
  47. package/dist/components/TextInput.js.map +1 -1
  48. package/dist/components/Touchable.d.ts +5 -3
  49. package/dist/components/Touchable.js +26 -19
  50. package/dist/components/Touchable.js.map +1 -1
  51. package/dist/components/View.js +1 -1
  52. package/dist/components/View.js.map +1 -1
  53. package/dist/components/_Modal/index.d.ts +27 -0
  54. package/dist/components/_Modal/index.js +114 -0
  55. package/dist/components/_Modal/index.js.map +1 -0
  56. package/dist/components/_Modal/styles.d.ts +64 -0
  57. package/dist/components/_Modal/styles.js +60 -0
  58. package/dist/components/_Modal/styles.js.map +1 -0
  59. package/dist/components/components.d.ts +3 -0
  60. package/dist/components/components.js +3 -0
  61. package/dist/components/components.js.map +1 -1
  62. package/dist/index.d.ts +4 -0
  63. package/dist/index.js +18 -1
  64. package/dist/index.js.map +1 -1
  65. package/dist/utils/ModalManager/components.d.ts +12 -0
  66. package/dist/utils/ModalManager/components.js +86 -0
  67. package/dist/utils/ModalManager/components.js.map +1 -0
  68. package/dist/utils/ModalManager/context.d.ts +47 -0
  69. package/dist/utils/ModalManager/context.js +196 -0
  70. package/dist/utils/ModalManager/context.js.map +1 -0
  71. package/dist/utils/ModalManager/index.d.ts +10 -0
  72. package/dist/utils/ModalManager/index.js +12 -0
  73. package/dist/utils/ModalManager/index.js.map +1 -0
  74. package/dist/utils/PermissionManager/components.d.ts +18 -0
  75. package/dist/utils/PermissionManager/components.js +52 -0
  76. package/dist/utils/PermissionManager/components.js.map +1 -0
  77. package/dist/utils/PermissionManager/context.d.ts +52 -0
  78. package/dist/utils/PermissionManager/context.js +325 -0
  79. package/dist/utils/PermissionManager/context.js.map +1 -0
  80. package/dist/utils/PermissionManager/index.d.ts +4 -0
  81. package/dist/utils/PermissionManager/index.js +9 -0
  82. package/dist/utils/PermissionManager/index.js.map +1 -0
  83. package/dist/utils/PermissionManager/types.d.ts +13 -0
  84. package/dist/utils/PermissionManager/types.js +3 -0
  85. package/dist/utils/PermissionManager/types.js.map +1 -0
  86. package/dist/utils/hooks.d.ts +6 -0
  87. package/dist/utils/hooks.js +62 -0
  88. package/dist/utils/hooks.js.map +1 -0
  89. package/package.json +2 -1
  90. package/src/components/Backdrop.tsx +77 -0
  91. package/src/components/Button.tsx +3 -2
  92. package/src/components/FileInput.tsx +2 -2
  93. package/src/components/Image.tsx +3 -2
  94. package/src/components/List.tsx +44 -5
  95. package/src/components/Modal/index.tsx +37 -50
  96. package/src/components/Modal/styles.ts +36 -39
  97. package/src/components/NewPager/index.tsx +5 -7
  98. package/src/components/Overlay.tsx +22 -13
  99. package/src/components/Scroll.tsx +3 -1
  100. package/src/components/SegmentedControl/index.tsx +182 -0
  101. package/src/components/SegmentedControl/styles.ts +65 -0
  102. package/src/components/Select/index.tsx +1 -2
  103. package/src/components/Text.tsx +23 -10
  104. package/src/components/TextInput.tsx +4 -2
  105. package/src/components/Touchable.tsx +31 -20
  106. package/src/components/View.tsx +1 -1
  107. package/src/components/_Modal/index.tsx +162 -0
  108. package/src/components/_Modal/styles.ts +125 -0
  109. package/src/components/components.ts +3 -0
  110. package/src/index.ts +6 -0
  111. package/src/modules/imageCropPicker.d.ts +497 -0
  112. package/src/modules/index.d.ts +186 -0
  113. package/src/utils/ModalManager/components.tsx +69 -0
  114. package/src/utils/ModalManager/context.tsx +247 -0
  115. package/src/utils/ModalManager/index.ts +13 -0
  116. package/src/utils/PermissionManager/context.tsx +299 -0
  117. package/src/utils/PermissionManager/index.ts +20 -0
  118. package/src/utils/PermissionManager/types.ts +24 -0
  119. package/src/utils/hooks.ts +65 -0
@@ -0,0 +1,325 @@
1
+ "use strict";
2
+ var __assign = (this && this.__assign) || function () {
3
+ __assign = Object.assign || function(t) {
4
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
5
+ s = arguments[i];
6
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
+ t[p] = s[p];
8
+ }
9
+ return t;
10
+ };
11
+ return __assign.apply(this, arguments);
12
+ };
13
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
14
+ if (k2 === undefined) k2 = k;
15
+ var desc = Object.getOwnPropertyDescriptor(m, k);
16
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
17
+ desc = { enumerable: true, get: function() { return m[k]; } };
18
+ }
19
+ Object.defineProperty(o, k2, desc);
20
+ }) : (function(o, m, k, k2) {
21
+ if (k2 === undefined) k2 = k;
22
+ o[k2] = m[k];
23
+ }));
24
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
25
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
26
+ }) : function(o, v) {
27
+ o["default"] = v;
28
+ });
29
+ var __importStar = (this && this.__importStar) || function (mod) {
30
+ if (mod && mod.__esModule) return mod;
31
+ var result = {};
32
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
33
+ __setModuleDefault(result, mod);
34
+ return result;
35
+ };
36
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
37
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
38
+ return new (P || (P = Promise))(function (resolve, reject) {
39
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
40
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
41
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
42
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
43
+ });
44
+ };
45
+ var __generator = (this && this.__generator) || function (thisArg, body) {
46
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
47
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
48
+ function verb(n) { return function (v) { return step([n, v]); }; }
49
+ function step(op) {
50
+ if (f) throw new TypeError("Generator is already executing.");
51
+ while (_) try {
52
+ 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;
53
+ if (y = 0, t) op = [op[0] & 2, t.value];
54
+ switch (op[0]) {
55
+ case 0: case 1: t = op; break;
56
+ case 4: _.label++; return { value: op[1], done: false };
57
+ case 5: _.label++; y = op[1]; op = [0]; continue;
58
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
59
+ default:
60
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
61
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
62
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
63
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
64
+ if (t[2]) _.ops.pop();
65
+ _.trys.pop(); continue;
66
+ }
67
+ op = body.call(thisArg, _);
68
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
69
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
70
+ }
71
+ };
72
+ Object.defineProperty(exports, "__esModule", { value: true });
73
+ exports.createTypedPermissionHooks = exports.usePermissionModal = exports.usePermissions = exports.Provider = void 0;
74
+ var react_1 = __importStar(require("react"));
75
+ var mobile_1 = require("@codeleap/mobile");
76
+ var common_1 = require("@codeleap/common");
77
+ var react_native_1 = require("react-native");
78
+ var PermissionContext = react_1.default.createContext({});
79
+ function getStatuses(state) {
80
+ var statuses = Object.entries(state).map(function (_a) {
81
+ var k = _a[0], v = _a[1];
82
+ return [k, v.status];
83
+ });
84
+ return Object.fromEntries(statuses);
85
+ }
86
+ function Provider(_a) {
87
+ var children = _a.children, AppPermissions = _a.AppPermissions, modalConfig = _a.modalConfig;
88
+ var _b = (0, react_1.useState)(function () { return getStatuses(AppPermissions.values); }), state = _b[0], setState = _b[1];
89
+ (0, common_1.onMount)(function () {
90
+ react_native_1.AppState.addEventListener('focus', function () {
91
+ AppPermissions.update().then(function (vals) {
92
+ var statuses = getStatuses(vals);
93
+ if (!(0, common_1.deepEqual)(statuses, state)) {
94
+ setState(__assign({}, statuses));
95
+ }
96
+ });
97
+ });
98
+ });
99
+ return <PermissionContext.Provider value={{
100
+ state: state,
101
+ modalConfig: modalConfig,
102
+ manager: AppPermissions,
103
+ }}>
104
+ {children}
105
+ </PermissionContext.Provider>;
106
+ }
107
+ exports.Provider = Provider;
108
+ var usePermissions = function () {
109
+ var modalCtx = mobile_1.ModalManager.useModalContext();
110
+ var permissionCtx = (0, react_1.useContext)(PermissionContext);
111
+ function askPermission(name, onResolve) {
112
+ return __awaiter(this, void 0, void 0, function () {
113
+ var status, permissionModalName;
114
+ return __generator(this, function (_a) {
115
+ switch (_a.label) {
116
+ case 0: return [4 /*yield*/, permissionCtx.manager.get(name, {
117
+ ask: false,
118
+ askOnDenied: false,
119
+ askOnPending: false,
120
+ })];
121
+ case 1:
122
+ status = _a.sent();
123
+ permissionModalName = "permissions.".concat(name);
124
+ if (!status.isGranted) {
125
+ modalCtx.toggleModal(permissionModalName, true, {
126
+ onPermissionResolve: function (status) {
127
+ modalCtx.toggleModal(permissionModalName, false, {});
128
+ setTimeout(function () {
129
+ onResolve === null || onResolve === void 0 ? void 0 : onResolve(status, permissionModalName);
130
+ }, modalCtx.transitionDuration);
131
+ },
132
+ });
133
+ }
134
+ else {
135
+ onResolve === null || onResolve === void 0 ? void 0 : onResolve(status.status);
136
+ }
137
+ return [2 /*return*/];
138
+ }
139
+ });
140
+ });
141
+ }
142
+ var askMany = function (perms, onResolve, options) { return __awaiter(void 0, void 0, void 0, function () {
143
+ var prevModal, results, _loop_1, _i, perms_1, _permission, state_1;
144
+ return __generator(this, function (_a) {
145
+ switch (_a.label) {
146
+ case 0:
147
+ prevModal = null;
148
+ results = {};
149
+ _loop_1 = function (_permission) {
150
+ var permission, status, permissionModalName, onOpen, _b, _c;
151
+ return __generator(this, function (_d) {
152
+ switch (_d.label) {
153
+ case 0:
154
+ permission = _permission.replace('?', '');
155
+ return [4 /*yield*/, permissionCtx.manager.get(permission, {
156
+ ask: false,
157
+ askOnDenied: false,
158
+ askOnPending: false,
159
+ })];
160
+ case 1:
161
+ status = _d.sent();
162
+ results[permission] = status.status;
163
+ permissionModalName = "permissions.".concat(permission);
164
+ if (!!status.isGranted) return [3 /*break*/, 3];
165
+ onOpen = null;
166
+ if (prevModal) {
167
+ onOpen = function () { return new Promise(function (resolve) {
168
+ setTimeout(function () {
169
+ console.log('transition', {
170
+ prevModal: prevModal,
171
+ permissionModalName: permissionModalName,
172
+ });
173
+ modalCtx.transition(prevModal, permissionModalName, {
174
+ props: {
175
+ onPermissionResolve: function (status) {
176
+ resolve(status);
177
+ },
178
+ },
179
+ });
180
+ });
181
+ }); };
182
+ }
183
+ else {
184
+ onOpen = function () { return new Promise(function (resolve) {
185
+ setTimeout(function () {
186
+ modalCtx.toggleModal(permissionModalName, true, {
187
+ onPermissionResolve: function (status) {
188
+ resolve(status);
189
+ },
190
+ });
191
+ });
192
+ }); };
193
+ }
194
+ _b = results;
195
+ _c = permission;
196
+ return [4 /*yield*/, onOpen()];
197
+ case 2:
198
+ _b[_c] = _d.sent();
199
+ prevModal = permissionModalName;
200
+ if (!_permission.endsWith('?') && results[permission] !== 'granted') {
201
+ return [2 /*return*/, "break"];
202
+ }
203
+ _d.label = 3;
204
+ case 3: return [2 /*return*/];
205
+ }
206
+ });
207
+ };
208
+ _i = 0, perms_1 = perms;
209
+ _a.label = 1;
210
+ case 1:
211
+ if (!(_i < perms_1.length)) return [3 /*break*/, 4];
212
+ _permission = perms_1[_i];
213
+ return [5 /*yield**/, _loop_1(_permission)];
214
+ case 2:
215
+ state_1 = _a.sent();
216
+ if (state_1 === "break")
217
+ return [3 /*break*/, 4];
218
+ _a.label = 3;
219
+ case 3:
220
+ _i++;
221
+ return [3 /*break*/, 1];
222
+ case 4:
223
+ if (prevModal) {
224
+ console.log("Close prev modal", {
225
+ prevModal: prevModal,
226
+ });
227
+ setTimeout(function () {
228
+ modalCtx.toggleModal(prevModal, false, {});
229
+ });
230
+ }
231
+ onResolve(__assign(__assign({}, results), { overall: Object.values(results).every(function (x) { return x === 'granted'; }) ? 'granted' : 'denied' }));
232
+ return [2 /*return*/];
233
+ }
234
+ });
235
+ }); };
236
+ return __assign({ askPermission: askPermission, askMany: askMany }, permissionCtx);
237
+ };
238
+ exports.usePermissions = usePermissions;
239
+ function usePermissionModal(permissionName) {
240
+ var modalId = "permissions.".concat(permissionName);
241
+ var modals = mobile_1.ModalManager.useModalContext();
242
+ var permissionCtx = (0, exports.usePermissions)();
243
+ var modalState = modals.state[modalId];
244
+ var currentState = permissionCtx.state[permissionName];
245
+ var status = currentState;
246
+ var _a = (0, common_1.useDebounce)(status, modals.transitionDuration * 0.5), debouncedStatus = _a[0], reset = _a[1];
247
+ function getConfig(withStatus) {
248
+ var _a;
249
+ return __assign(__assign({}, permissionCtx.modalConfig[permissionName]), (_a = permissionCtx.modalConfig[permissionName]) === null || _a === void 0 ? void 0 : _a[withStatus]);
250
+ }
251
+ var config = getConfig(debouncedStatus);
252
+ function onPermissionResolve(_status) {
253
+ var _a, _b;
254
+ (_b = (_a = modalState === null || modalState === void 0 ? void 0 : modalState.props) === null || _a === void 0 ? void 0 : _a.onPermissionResolve) === null || _b === void 0 ? void 0 : _b.call(_a, _status || status);
255
+ }
256
+ (0, common_1.onUpdate)(function () {
257
+ if ((modalState === null || modalState === void 0 ? void 0 : modalState.visible) && !!status) {
258
+ if (status === 'granted') {
259
+ reset();
260
+ onPermissionResolve();
261
+ }
262
+ else {
263
+ if (!(0, common_1.deepEqual)(config, getConfig(status))) {
264
+ modals.transition(modalId, modalId, {
265
+ props: modalState === null || modalState === void 0 ? void 0 : modalState.props,
266
+ });
267
+ }
268
+ }
269
+ }
270
+ }, [status, modalState === null || modalState === void 0 ? void 0 : modalState.visible]);
271
+ function onAllow() {
272
+ return __awaiter(this, void 0, void 0, function () {
273
+ var _a, newStatus;
274
+ return __generator(this, function (_b) {
275
+ switch (_b.label) {
276
+ case 0:
277
+ _a = config.onAllow;
278
+ switch (_a) {
279
+ case 'ask': return [3 /*break*/, 1];
280
+ case 'openSettings': return [3 /*break*/, 3];
281
+ }
282
+ return [3 /*break*/, 3];
283
+ case 1: return [4 /*yield*/, permissionCtx.manager.get(permissionName, {
284
+ ask: true,
285
+ askOnDenied: true,
286
+ askOnPending: true,
287
+ })];
288
+ case 2:
289
+ newStatus = _b.sent();
290
+ if (!newStatus.isGranted) {
291
+ onPermissionResolve(newStatus.status);
292
+ }
293
+ return [3 /*break*/, 4];
294
+ case 3:
295
+ react_native_1.Linking.openSettings();
296
+ return [3 /*break*/, 4];
297
+ case 4: return [2 /*return*/];
298
+ }
299
+ });
300
+ });
301
+ }
302
+ function onDeny() {
303
+ onPermissionResolve();
304
+ }
305
+ return {
306
+ onAllow: onAllow,
307
+ onDeny: onDeny,
308
+ modalId: modalId,
309
+ permissionName: permissionName,
310
+ modalState: __assign({}, modalState),
311
+ currentState: currentState,
312
+ config: config,
313
+ };
314
+ }
315
+ exports.usePermissionModal = usePermissionModal;
316
+ function createTypedPermissionHooks(configuration) {
317
+ var _usePermissions = exports.usePermissions;
318
+ var _usePermissionModal = usePermissionModal;
319
+ return {
320
+ usePermissions: _usePermissions,
321
+ usePermissionModal: _usePermissionModal,
322
+ };
323
+ }
324
+ exports.createTypedPermissionHooks = createTypedPermissionHooks;
325
+ //# sourceMappingURL=context.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"context.js","sourceRoot":"","sources":["../../../src/utils/PermissionManager/context.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ import { usePermissions, Provider, createTypedPermissionHooks, usePermissionModal } from './context';
2
+ import { PermissionConfig, PermissionModalsConfig } from './types';
3
+ export { usePermissions, Provider, usePermissionModal, createTypedPermissionHooks, };
4
+ export type { PermissionConfig, PermissionModalsConfig, };
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createTypedPermissionHooks = exports.usePermissionModal = exports.Provider = exports.usePermissions = void 0;
4
+ var context_1 = require("./context");
5
+ Object.defineProperty(exports, "usePermissions", { enumerable: true, get: function () { return context_1.usePermissions; } });
6
+ Object.defineProperty(exports, "Provider", { enumerable: true, get: function () { return context_1.Provider; } });
7
+ Object.defineProperty(exports, "createTypedPermissionHooks", { enumerable: true, get: function () { return context_1.createTypedPermissionHooks; } });
8
+ Object.defineProperty(exports, "usePermissionModal", { enumerable: true, get: function () { return context_1.usePermissionModal; } });
9
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/utils/PermissionManager/index.ts"],"names":[],"mappings":";;;AAAA,qCAAoG;AAQlG,+FARO,wBAAc,OAQP;AACd,yFATuB,kBAAQ,OASvB;AAER,2GAXiC,oCAA0B,OAWjC;AAD1B,mGAV6D,4BAAkB,OAU7D"}
@@ -0,0 +1,13 @@
1
+ import { PermissionTypes } from '@codeleap/common';
2
+ declare type NonGrantedPermissionTypes = Exclude<PermissionTypes.PermissionStatus, 'granted'>;
3
+ export declare type BasePermissionConfig = {
4
+ fullscreenModal?: boolean;
5
+ dismissable?: boolean;
6
+ title: string;
7
+ onAllow: 'openSettings' | 'ask';
8
+ description: string[];
9
+ icon: string;
10
+ };
11
+ export declare type PermissionConfig = BasePermissionConfig & Partial<Record<NonGrantedPermissionTypes, Partial<BasePermissionConfig>>>;
12
+ export declare type PermissionModalsConfig<PermissionNames extends string | number | symbol> = Partial<Record<PermissionNames, PermissionConfig>>;
13
+ export {};
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/utils/PermissionManager/types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,6 @@
1
+ import { Animated, AppStateStatus } from 'react-native';
2
+ export declare function useAnimateColor(value: string, opts?: Partial<Animated.TimingAnimationConfig>): Animated.AnimatedInterpolation;
3
+ export declare function useAppState(filter?: AppStateStatus[]): {
4
+ appState: AppStateStatus;
5
+ };
6
+ export declare function useStaticAnimationStyles<T extends Record<string | number | symbol, any>, K extends keyof T>(obj: T, keys: K[]): { [P in K]: T[K]; };
@@ -0,0 +1,62 @@
1
+ "use strict";
2
+ var __assign = (this && this.__assign) || function () {
3
+ __assign = Object.assign || function(t) {
4
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
5
+ s = arguments[i];
6
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
+ t[p] = s[p];
8
+ }
9
+ return t;
10
+ };
11
+ return __assign.apply(this, arguments);
12
+ };
13
+ Object.defineProperty(exports, "__esModule", { value: true });
14
+ exports.useStaticAnimationStyles = exports.useAppState = exports.useAnimateColor = void 0;
15
+ var common_1 = require("@codeleap/common");
16
+ var react_native_1 = require("react-native");
17
+ function useAnimateColor(value, opts) {
18
+ var iters = (0, common_1.useRef)(0);
19
+ var anim = (0, common_1.useState)(new react_native_1.Animated.Value(iters.current))[0];
20
+ var _prev = (0, common_1.usePrevious)(value);
21
+ var prev = _prev || value;
22
+ (0, common_1.onUpdate)(function () {
23
+ // if (value === prev) return
24
+ var animation = react_native_1.Animated.timing(anim, __assign(__assign({}, opts), { toValue: iters.current + 1, useNativeDriver: false }));
25
+ animation.start(function () {
26
+ iters.current += 1;
27
+ });
28
+ return function () {
29
+ animation.stop();
30
+ };
31
+ }, [value]);
32
+ var color = anim.interpolate({
33
+ outputRange: [prev, value],
34
+ inputRange: [iters.current, iters.current + 1],
35
+ });
36
+ return color;
37
+ }
38
+ exports.useAnimateColor = useAnimateColor;
39
+ function useAppState(filter) {
40
+ var _a = (0, common_1.useState)(function () { return react_native_1.AppState.currentState; }), appState = _a[0], setAppState = _a[1];
41
+ (0, common_1.onMount)(function () {
42
+ react_native_1.AppState.addEventListener('change', function (s) {
43
+ if (!filter || filter.includes(s)) {
44
+ setAppState(s);
45
+ }
46
+ });
47
+ });
48
+ return {
49
+ appState: appState,
50
+ };
51
+ }
52
+ exports.useAppState = useAppState;
53
+ function useStaticAnimationStyles(obj, keys) {
54
+ var styles = (0, common_1.useRef)({});
55
+ if (Object.keys(styles.current).length === 0) {
56
+ var mappedStyles = keys.map(function (k) { return [k, __assign({}, obj[k])]; });
57
+ styles.current = Object.fromEntries(mappedStyles);
58
+ }
59
+ return styles.current;
60
+ }
61
+ exports.useStaticAnimationStyles = useStaticAnimationStyles;
62
+ //# sourceMappingURL=hooks.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../src/utils/hooks.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAAA,2CAAmF;AACnF,6CAAiE;AAEjE,SAAgB,eAAe,CAAC,KAAa,EAAE,IAA8C;IAC3F,IAAM,KAAK,GAAG,IAAA,eAAM,EAAC,CAAC,CAAC,CAAA;IAChB,IAAA,IAAI,GAAI,IAAA,iBAAQ,EAAC,IAAI,uBAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,GAA/C,CAA+C;IAC1D,IAAM,KAAK,GAAG,IAAA,oBAAW,EAAC,KAAK,CAAC,CAAA;IAChC,IAAM,IAAI,GAAG,KAAK,IAAI,KAAK,CAAA;IAE3B,IAAA,iBAAQ,EAAC;QACP,6BAA6B;QAC7B,IAAM,SAAS,GAAG,uBAAQ,CAAC,MAAM,CAAC,IAAI,wBACjC,IAAI,KACP,OAAO,EAAE,KAAK,CAAC,OAAO,GAAG,CAAC,EAC1B,eAAe,EAAE,KAAK,IAEtB,CAAA;QACF,SAAS,CAAC,KAAK,CAAC;YACd,KAAK,CAAC,OAAO,IAAI,CAAC,CAAA;QACpB,CAAC,CAAC,CAAA;QAEF,OAAO;YACL,SAAS,CAAC,IAAI,EAAE,CAAA;QAElB,CAAC,CAAA;IACH,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAA;IAEX,IAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC;QAC7B,WAAW,EAAE,CAAC,IAAI,EAAE,KAAK,CAAC;QAC1B,UAAU,EAAE,CAAC,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,OAAO,GAAG,CAAC,CAAC;KAC/C,CAAC,CAAA;IAEF,OAAO,KAAK,CAAA;AAEd,CAAC;AA/BD,0CA+BC;AAED,SAAgB,WAAW,CAAC,MAAyB;IAC7C,IAAA,KAA0B,IAAA,iBAAQ,EAAC,cAAM,OAAA,uBAAQ,CAAC,YAAY,EAArB,CAAqB,CAAC,EAA9D,QAAQ,QAAA,EAAE,WAAW,QAAyC,CAAA;IAErE,IAAA,gBAAO,EAAC;QACN,uBAAQ,CAAC,gBAAgB,CAAC,QAAQ,EAAE,UAAA,CAAC;YACnC,IAAI,CAAC,MAAM,IAAI,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE;gBACjC,WAAW,CAAC,CAAC,CAAC,CAAA;aACf;QACH,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;IAEF,OAAO;QACL,QAAQ,UAAA;KACT,CAAA;AACH,CAAC;AAdD,kCAcC;AAED,SAAgB,wBAAwB,CAAkE,GAAM,EAAE,IAAS;IACzH,IAAM,MAAM,GAAG,IAAA,eAAM,EAAC,EAAE,CAAC,CAAA;IAEzB,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE;QAC5C,IAAM,YAAY,GAAG,IAAI,CAAC,GAAG,CAAC,UAAC,CAAC,IAAK,OAAA,CAAC,CAAC,eAAO,GAAG,CAAC,CAAC,CAAC,EAAG,EAAlB,CAAkB,CAAC,CAAA;QAExD,MAAM,CAAC,OAAO,GAAG,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,CAAA;KAClD;IAED,OAAO,MAAM,CAAC,OAEb,CAAA;AACH,CAAC;AAZD,4DAYC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@codeleap/mobile",
3
- "version": "1.9.27",
3
+ "version": "1.9.30",
4
4
  "main": "src/index.ts",
5
5
  "author": "Paulo Henrique De Souza <paulosouza300272@gmail.com>",
6
6
  "license": "UNLICENSED",
@@ -34,6 +34,7 @@
34
34
  "react-native-text-input-mask": "3.1.4"
35
35
  },
36
36
  "dependencies": {
37
+ "@gorhom/portal": "^1.0.13",
37
38
  "@miblanchard/react-native-slider": "^2.1.0",
38
39
  "react-native-animatable": "^1.3.3",
39
40
  "react-native-masked-text": "^1.13.0",
@@ -0,0 +1,77 @@
1
+ import React from 'react'
2
+ import { ComponentVariants, onUpdate, PropsOf, useDefaultComponentStyle } from '@codeleap/common'
3
+ import { useAnimationState, useDynamicAnimation } from 'moti'
4
+ import { Touchable } from './Touchable'
5
+ import { View } from './View'
6
+ import {
7
+ createDefaultVariantFactory,
8
+ includePresets,
9
+ } from '@codeleap/common'
10
+ import { StylesOf } from '../types/utility'
11
+ import { StyleSheet } from 'react-native'
12
+ import { useStaticAnimationStyles } from '../utils/hooks'
13
+
14
+ type BackdropComposition =
15
+ 'wrapper'|
16
+ 'touchable' |
17
+ 'wrapper:visible' |
18
+ 'wrapper:hidden'
19
+
20
+ const createBackdropVariant = createDefaultVariantFactory<BackdropComposition>()
21
+
22
+ const presets = includePresets((style) => createBackdropVariant(() => ({ wrapper: style })))
23
+
24
+ export const BackdropStyles = {
25
+ ...presets,
26
+ default: createBackdropVariant((theme) => ({
27
+ wrapper: {
28
+ backgroundColor: theme.colors.black,
29
+ ...theme.presets.whole,
30
+ ...theme.presets.absolute,
31
+ },
32
+ 'wrapper:visible': {
33
+ opacity: 0.5,
34
+ },
35
+ 'wrapper:hidden': {
36
+
37
+ opacity: 0,
38
+ },
39
+ touchable: {
40
+ ...theme.presets.whole,
41
+ ...theme.presets.absolute,
42
+ },
43
+ })),
44
+ }
45
+
46
+ export type BackdropProps = PropsOf<typeof Touchable> & {
47
+ visible: boolean
48
+ wrapperProps?: PropsOf<typeof View>
49
+ variants?: ComponentVariants<typeof BackdropStyles>['variants']
50
+ styles?: StylesOf<BackdropComposition>
51
+ }
52
+
53
+ export const Backdrop = (backdropProps:BackdropProps) => {
54
+ const { variants = [], styles = {}, visible, children, wrapperProps = {}, ...props } = backdropProps
55
+
56
+ const variantStyles = useDefaultComponentStyle<'u:Backdrop', typeof BackdropStyles>('u:Backdrop', {
57
+ variants,
58
+ rootElement: 'wrapper',
59
+ styles,
60
+ transform: StyleSheet.flatten,
61
+ })
62
+
63
+ const animationStates = useStaticAnimationStyles(variantStyles, ['wrapper:hidden', 'wrapper:visible'])
64
+
65
+ const animation = useDynamicAnimation(() => {
66
+ return visible ? animationStates['wrapper:visible'] : animationStates['wrapper:hidden']
67
+ })
68
+
69
+ onUpdate(() => {
70
+ animation.animateTo(visible ? animationStates['wrapper:visible'] : animationStates['wrapper:hidden'])
71
+ }, [visible, animationStates])
72
+
73
+ return <View pointerEvents={visible ? 'auto' : 'none' } animated style={variantStyles.wrapper} state={animation} {...wrapperProps}>
74
+ <Touchable feedbackVariant='none' style={variantStyles.touchable} {...props} />
75
+ {children}
76
+ </View>
77
+ }
@@ -6,6 +6,7 @@ import {
6
6
  ButtonComposition,
7
7
  ButtonParts,
8
8
  IconPlaceholder,
9
+ GetRefType,
9
10
  } from '@codeleap/common'
10
11
  import { forwardRef } from 'react'
11
12
  import { StylesOf } from '../types/utility'
@@ -13,7 +14,7 @@ import { Text } from './Text'
13
14
  import { Touchable, TouchableProps } from './Touchable'
14
15
  import { Icon } from './Icon'
15
16
  import { ActivityIndicator } from './ActivityIndicator'
16
- import { StyleSheet, TouchableOpacity } from 'react-native'
17
+ import { StyleSheet, TouchableOpacity, View } from 'react-native'
17
18
 
18
19
  type ChildProps = {
19
20
  styles: StylesOf<ButtonParts>
@@ -33,7 +34,7 @@ export type ButtonProps = Omit<TouchableProps, 'variants'> &
33
34
  children?: React.ReactNode | ((props: ChildProps) => React.ReactNode)
34
35
  }
35
36
 
36
- export const Button = forwardRef<TouchableOpacity, ButtonProps>((buttonProps, ref) => {
37
+ export const Button = forwardRef<GetRefType<TouchableProps['ref']>, ButtonProps>((buttonProps, ref) => {
37
38
  const {
38
39
  variants = [],
39
40
  children,
@@ -112,11 +112,11 @@ export const FileInput = forwardRef<
112
112
  if (warn) {
113
113
  // NOTE yeah, it should not be both of course but just logger.* isn't showing for some reason
114
114
  logger.warn(err)
115
- console.warn(err)
115
+
116
116
  } else {
117
117
  // NOTE yeah, it should not be both of course but just logger.* isn't showing for some reason
118
118
  logger.error(err)
119
- console.warn(err)
119
+
120
120
  if (onError) {
121
121
  onError(err)
122
122
  } else {
@@ -11,6 +11,7 @@ import {
11
11
  Image as NativeImage,
12
12
  ImageStyle,
13
13
  StyleProp,
14
+ StyleSheet,
14
15
  TextStyle,
15
16
  ViewStyle,
16
17
  } from 'react-native'
@@ -35,14 +36,14 @@ export const ImageComponent: React.FC<ImageProps> = (props) => {
35
36
 
36
37
  const variantStyles = useDefaultComponentStyle('Image', { variants })
37
38
 
38
- const styles = [variantStyles.wrapper, style]
39
+ const styles = StyleSheet.flatten([variantStyles.wrapper, style])
39
40
 
40
41
  if (fast) {
41
42
  return (
42
43
  <FastImage
43
44
  style={styles}
44
45
  // @ts-ignore
45
- tintColor={style?.tintColor}
46
+ tintColor={styles?.tintColor}
46
47
  resizeMode={FastImage.resizeMode[resizeMode || 'contain']}
47
48
  {...imageProps}
48
49
  />