UNPKG

@scrolia/react-native-flash-list

Version:

A set of list components for Scrolia React Native

82 lines (81 loc) 3.14 kB
"use client"; "use strict"; var __webpack_require__ = {}; (()=>{ __webpack_require__.d = (exports1, definition)=>{ for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, { enumerable: true, get: definition[key] }); }; })(); (()=>{ __webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop); })(); (()=>{ __webpack_require__.r = (exports1)=>{ if ('undefined' != typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, { value: 'Module' }); Object.defineProperty(exports1, '__esModule', { value: true }); }; })(); var __webpack_exports__ = {}; __webpack_require__.r(__webpack_exports__); __webpack_require__.d(__webpack_exports__, { FlashListX: ()=>FlashListX }); const jsx_runtime_namespaceObject = require("react/jsx-runtime"); const react_native_core_namespaceObject = require("@scrolia/react-native-core"); const flash_list_namespaceObject = require("@shopify/flash-list"); const external_react_namespaceObject = require("react"); const List = (props, ref)=>{ const { children, ...p } = props; const core = (0, react_native_core_namespaceObject.useScrollCore)(); external_react_namespaceObject.useImperativeHandle(ref, ()=>core.x.elRef.current, [ core.x.elRef ]); external_react_namespaceObject.useEffect(()=>{ core.x.elType.current = "flatlist"; }, [ core.x.elType ]); const handleLayout = (event)=>{ if (!core.options.disabled) core.x.handleLayout(event); p.onLayout?.(event); }; const handleContentSizeChange = (width, height)=>{ if (!core.options.disabled) core.x.handleContentSizeChange(width, height); p.onContentSizeChange?.(width, height); }; const handleScroll = (event)=>{ if (!core.options.disabled) core.x.handleScroll(event); p.onScroll?.(event); }; return /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)(jsx_runtime_namespaceObject.Fragment, { children: /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)(flash_list_namespaceObject.FlashList, { ...p, ref: core.x.elRef, showsHorizontalScrollIndicator: core.options.disabled, showsVerticalScrollIndicator: false, onLayout: handleLayout, onContentSizeChange: handleContentSizeChange, onScroll: handleScroll, horizontal: true, scrollEventThrottle: p.scrollEventThrottle ?? 5, children: children }) }); }; const FlashListX = /*#__PURE__*/ external_react_namespaceObject.forwardRef(List); FlashListX.displayName = "FlashListX"; exports.FlashListX = __webpack_exports__.FlashListX; for(var __webpack_i__ in __webpack_exports__)if (-1 === [ "FlashListX" ].indexOf(__webpack_i__)) exports[__webpack_i__] = __webpack_exports__[__webpack_i__]; Object.defineProperty(exports, '__esModule', { value: true }); //# sourceMappingURL=x.js.map