@tecsinapse/react-native-kit 4.0.0-beta.7 → 4.0.0-beta.8

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.
@@ -17,7 +17,7 @@ const ModalView = ({
17
17
  BoxComponent = reactCore.BoxContent,
18
18
  frozen,
19
19
  isLastShown,
20
- isRaiseKeyboard = true,
20
+ isRaiseKeyboard,
21
21
  showCloseBar = true,
22
22
  close,
23
23
  onClose
@@ -30,6 +30,15 @@ const ModalView = ({
30
30
  const translationCarrier = React.useRef(new reactNative.Animated.Value(0)).current;
31
31
  const opacityCarrier = React.useRef(new reactNative.Animated.Value(0)).current;
32
32
  const offset = isLastShown && keyboardOpened > 0 ? 0 : bottom;
33
+ const getKeyboardHeight = (keyboard) => {
34
+ if (keyboard === 0) return 0;
35
+ const wHeight = Math.ceil(reactNative.Dimensions.get("window").height);
36
+ const sHeight = Math.ceil(reactNative.Dimensions.get("screen").height);
37
+ if (wHeight !== sHeight) {
38
+ return keyboard + (sHeight - wHeight - (reactNative.StatusBar.currentHeight || 0));
39
+ }
40
+ return keyboard;
41
+ };
33
42
  const show = React.useCallback(() => {
34
43
  reactNative.Animated.sequence([
35
44
  reactNative.Animated.timing(backgroundCarrier, {
@@ -114,19 +123,16 @@ const ModalView = ({
114
123
  hideEvent.remove();
115
124
  };
116
125
  }, []);
117
- const viewStyle = React.useMemo(
118
- () => [
119
- {
120
- opacity: opacityCarrier,
121
- transform: [{ translateY: translationCarrier }]
122
- }
123
- ],
124
- [opacityCarrier, translationCarrier, isLastShown, isRaiseKeyboard, keyboardOpened]
125
- );
126
126
  return /* @__PURE__ */ jsxRuntime.jsx(styled.StyledPressableBackDrop, { onPress: !frozen ? close : void 0, children: /* @__PURE__ */ jsxRuntime.jsx(styled.BackDropView, { style: { backgroundColor: backgroundInterpolation }, children: /* @__PURE__ */ jsxRuntime.jsx(
127
127
  reactNative.Animated.View,
128
128
  {
129
- style: viewStyle,
129
+ style: {
130
+ ...isLastShown && isRaiseKeyboard && {
131
+ paddingBottom: getKeyboardHeight(keyboardOpened)
132
+ },
133
+ opacity: opacityCarrier,
134
+ transform: [{ translateY: translationCarrier }]
135
+ },
130
136
  children: /* @__PURE__ */ jsxRuntime.jsx(reactNative.Pressable, { children: /* @__PURE__ */ jsxRuntime.jsxs(
131
137
  BoxComponent,
132
138
  {
@@ -1,7 +1,7 @@
1
1
  import { jsx, jsxs } from 'react/jsx-runtime';
2
2
  import { BoxContent } from '@tecsinapse/react-core';
3
- import { useState, useRef, useCallback, useEffect, useMemo } from 'react';
4
- import { Animated, Easing, Keyboard, Pressable } from 'react-native';
3
+ import { useState, useRef, useCallback, useEffect } from 'react';
4
+ import { Animated, Easing, Keyboard, Pressable, Dimensions, StatusBar } from 'react-native';
5
5
  import { useSafeAreaInsets } from 'react-native-safe-area-context';
6
6
  import { StyledPressableBackDrop, BackDropView, CloseBar } from './styled.js';
7
7
 
@@ -15,7 +15,7 @@ const ModalView = ({
15
15
  BoxComponent = BoxContent,
16
16
  frozen,
17
17
  isLastShown,
18
- isRaiseKeyboard = true,
18
+ isRaiseKeyboard,
19
19
  showCloseBar = true,
20
20
  close,
21
21
  onClose
@@ -28,6 +28,15 @@ const ModalView = ({
28
28
  const translationCarrier = useRef(new Animated.Value(0)).current;
29
29
  const opacityCarrier = useRef(new Animated.Value(0)).current;
30
30
  const offset = isLastShown && keyboardOpened > 0 ? 0 : bottom;
31
+ const getKeyboardHeight = (keyboard) => {
32
+ if (keyboard === 0) return 0;
33
+ const wHeight = Math.ceil(Dimensions.get("window").height);
34
+ const sHeight = Math.ceil(Dimensions.get("screen").height);
35
+ if (wHeight !== sHeight) {
36
+ return keyboard + (sHeight - wHeight - (StatusBar.currentHeight || 0));
37
+ }
38
+ return keyboard;
39
+ };
31
40
  const show = useCallback(() => {
32
41
  Animated.sequence([
33
42
  Animated.timing(backgroundCarrier, {
@@ -112,19 +121,16 @@ const ModalView = ({
112
121
  hideEvent.remove();
113
122
  };
114
123
  }, []);
115
- const viewStyle = useMemo(
116
- () => [
117
- {
118
- opacity: opacityCarrier,
119
- transform: [{ translateY: translationCarrier }]
120
- }
121
- ],
122
- [opacityCarrier, translationCarrier, isLastShown, isRaiseKeyboard, keyboardOpened]
123
- );
124
124
  return /* @__PURE__ */ jsx(StyledPressableBackDrop, { onPress: !frozen ? close : void 0, children: /* @__PURE__ */ jsx(BackDropView, { style: { backgroundColor: backgroundInterpolation }, children: /* @__PURE__ */ jsx(
125
125
  Animated.View,
126
126
  {
127
- style: viewStyle,
127
+ style: {
128
+ ...isLastShown && isRaiseKeyboard && {
129
+ paddingBottom: getKeyboardHeight(keyboardOpened)
130
+ },
131
+ opacity: opacityCarrier,
132
+ transform: [{ translateY: translationCarrier }]
133
+ },
128
134
  children: /* @__PURE__ */ jsx(Pressable, { children: /* @__PURE__ */ jsxs(
129
135
  BoxComponent,
130
136
  {
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@tecsinapse/react-native-kit",
3
3
  "description": "React Native components library",
4
- "version": "4.0.0-beta.7",
4
+ "version": "4.0.0-beta.8",
5
5
  "license": "MIT",
6
6
  "main": "dist/esm/index.js",
7
7
  "module": "dist/esm/index.js",
@@ -40,5 +40,5 @@
40
40
  "react-native-safe-area-context": "^4.0.0",
41
41
  "react-native-vector-icons": "^9.2.0"
42
42
  },
43
- "gitHead": "cac03c8201921d4aa30850f0a4adb28b1d143e33"
43
+ "gitHead": "d7afd1bf1ecb9cbf5095a1dd42ffceb3063184c8"
44
44
  }