linkmore-design
Version:
๐ ๐lm็ปไปถๅบใ๐
137 lines (135 loc) โข 6.74 kB
JavaScript
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;
;