UNPKG

linkmore-design

Version:

๐ŸŒˆ ๐Ÿš€lm็ป„ไปถๅบ“ใ€‚๐Ÿš€

137 lines (135 loc) โ€ข 6.74 kB
"use strict"; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _lightgallery = _interopRequireDefault(require("lightgallery")); var _autoplay = _interopRequireDefault(require("lightgallery/plugins/autoplay")); var _fullscreen = _interopRequireDefault(require("lightgallery/plugins/fullscreen")); var _rotate = _interopRequireDefault(require("lightgallery/plugins/rotate")); var _thumbnail = _interopRequireDefault(require("lightgallery/plugins/thumbnail")); var _video = _interopRequireDefault(require("lightgallery/plugins/video")); var _zoom = _interopRequireDefault(require("lightgallery/plugins/zoom")); var _lodash = require("lodash"); var _react = _interopRequireWildcard(require("react")); // import 'lightgallery/css/lightgallery.css' // import 'lightgallery/css/lg-zoom.css' // import 'lightgallery/css/lg-thumbnail.css' // import 'lightgallery/css/lg-fullscreen.css' // import 'lightgallery/css/lg-video.css' // import 'lightgallery/css/lg-autoplay.css' // import 'lightgallery/css/lg-rotate.css' const videoImg = ``; const getIsVideo = url => { const fileExtension = url.replace(/.*\./, '').toLowerCase(); return ['mp4', 'm2v', 'mkv', 'ogm', 'webm'].includes(fileExtension); }; const imgTransformFun = urlList => { return urlList?.map(item => { if (typeof item === 'string') { const isVideo = getIsVideo(item); return isVideo ? { video: { source: [{ src: item, type: 'video/mp4' }], attributes: { preload: false, controls: true } }, thumb: videoImg, subHtml: '', downloadUrl: item } : { src: item, subHtml: '', thumb: item, responsive: item }; } else { const isVideo = getIsVideo(item?.url || ''); return isVideo ? { video: { source: [{ src: item?.url, type: 'video/mp4' }], attributes: { preload: false, controls: true } }, thumb: item?.thumb || videoImg, subHtml: item?.subHtml || '', downloadUrl: item?.url } : { src: item?.url, subHtml: item?.subHtml || '', thumb: item?.thumb || item?.url, responsive: item?.responsive || item?.url }; } }); }; const LmImageViewer = ({ ...resetProps }, ref) => { const { visible = false, urlList = [], initialIndex = 0, close } = resetProps; const defaultRef = (0, _react.useRef)(null); const dynamicGalleryRef = (0, _react.useRef)(null); const [list, setList] = (0, _react.useState)([]); const initialIndexRef = (0, _react.useRef)(0); (0, _react.useEffect)(() => { if (!(0, _lodash.isEqual)(urlList, list)) { setList(urlList); } }, [urlList]); (0, _react.useEffect)(() => { initialIndexRef.current = initialIndex; }, [initialIndex]); const closeViewModal = () => { close?.(); }; (0, _react.useEffect)(() => { if (list?.length) { dynamicGalleryRef.current?.destroyGallery(); dynamicGalleryRef.current = (0, _lightgallery.default)(defaultRef.current, { dynamic: true, plugins: [_zoom.default, _thumbnail.default, _fullscreen.default, _video.default, _autoplay.default, _rotate.default], /** TODO: ็‰ˆๆƒ้—ฎ้ข˜๏ผŸๅŽๆœŸๅค„็† */ // licenseKey: 'your_license_key', dynamicEl: imgTransformFun(list), speed: 500 }); defaultRef.current?.addEventListener('lgAfterClose', closeViewModal); if (visible) { dynamicGalleryRef.current?.openGallery(initialIndexRef.current); } } return () => { defaultRef.current?.removeEventListener('lgAfterClose', closeViewModal); }; }, [list]); (0, _react.useEffect)(() => { if (visible) { dynamicGalleryRef.current?.openGallery(initialIndexRef.current); } }, [visible]); return /*#__PURE__*/_react.default.createElement("div", { ref: defaultRef, style: { display: 'none' } }); }; var _default = /*#__PURE__*/(0, _react.forwardRef)(LmImageViewer); exports.default = _default;