react-native-keyboard-controller
Version:
Keyboard manager which works in identical way on both iOS and Android
29 lines (28 loc) • 971 B
JavaScript
import { useEffect, useState } from "react";
import { Dimensions } from "react-native";
import { WindowDimensionsEvents } from "../../bindings";
const screen = Dimensions.get("screen");
let initialDimensions = {
width: screen.width,
height: screen.height
};
WindowDimensionsEvents.addListener("windowDidResize", e => {
initialDimensions = e;
});
export const useWindowDimensions = () => {
const [dimensions, setDimensions] = useState(initialDimensions);
useEffect(() => {
const subscription = WindowDimensionsEvents.addListener("windowDidResize", e => {
setDimensions(e);
});
// we might have missed an update between reading a value in render and
// `addListener` in this handler, so we set it here. If there was
// no change, React will filter out this update as a no-op.
setDimensions(initialDimensions);
return () => {
subscription.remove();
};
}, []);
return dimensions;
};
//# sourceMappingURL=index.js.map