UNPKG

react-native-gallery-preview

Version:

<div> <img align="right" height="720" src="example.gif"> </div>

62 lines (61 loc) 2.27 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.GalleryChildrenItem = void 0; var _react = _interopRequireWildcard(require("react")); var _GestureItemComponent = require("../GestureItemComponent/GestureItemComponent"); var _reactNative = require("react-native"); var _jsxRuntime = require("react/jsx-runtime"); function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); } const GalleryChildrenItem = exports.GalleryChildrenItem = /*#__PURE__*/(0, _react.memo)(({ width, height, children, ...props }) => { const [state, setState] = (0, _react.useState)({ width: 0, height: 0, contentCenterX: 0, contentCenterY: 0 }); const onChildrenLayout = (0, _react.useCallback)(event => { const { layout } = event.nativeEvent; const center = { x: layout.x + width / 2, y: layout.y + height / 2 }; setState({ width: layout.width, height: layout.height, contentCenterX: center.x, contentCenterY: center.y }); }, [height, width]); return /*#__PURE__*/(0, _jsxRuntime.jsx)(_GestureItemComponent.GestureItemComponent, { contentCenterX: state.contentCenterX, contentCenterY: state.contentCenterY, contentContainerSize: { width: state.width, height: state.height }, width: width, height: height, ...props, children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_reactNative.View, { style: styles.children, onLayout: onChildrenLayout, children: children }) }); }); const styles = _reactNative.StyleSheet.create({ children: { justifyContent: "center", alignItems: "center" } }); //# sourceMappingURL=GalleryChildrenItem.js.map