1
0
Fork 0
mirror of https://github.com/muerwre/vault-frontend.git synced 2025-04-25 04:46:40 +07:00

removed swiper from lab image

This commit is contained in:
Fedor Katurov 2021-11-17 17:53:02 +07:00
parent d4bf94059e
commit eb41e9a8cc
2 changed files with 10 additions and 57 deletions

View file

@ -1,7 +1,6 @@
import React, { FC, useCallback, useEffect, useState } from 'react'; import React, { FC } from 'react';
import { INodeComponentProps } from '~/redux/node/constants'; import { INodeComponentProps } from '~/redux/node/constants';
import SwiperCore, { A11y, Navigation, Pagination, SwiperOptions } from 'swiper'; import SwiperCore, { A11y, Navigation, Pagination, SwiperOptions } from 'swiper';
import { Swiper, SwiperSlide } from 'swiper/react';
import 'swiper/swiper.scss'; import 'swiper/swiper.scss';
import 'swiper/components/pagination/pagination.scss'; import 'swiper/components/pagination/pagination.scss';
@ -11,9 +10,6 @@ import 'swiper/components/navigation/navigation.scss';
import styles from './styles.module.scss'; import styles from './styles.module.scss';
import { useNodeImages } from '~/utils/hooks/node/useNodeImages'; import { useNodeImages } from '~/utils/hooks/node/useNodeImages';
import { getURL } from '~/utils/dom';
import { PRESETS } from '~/constants/urls';
import SwiperClass from 'swiper/types/swiper-class';
import { useGotoNode } from '~/utils/hooks/node/useGotoNode'; import { useGotoNode } from '~/utils/hooks/node/useGotoNode';
import { Placeholder } from '~/components/placeholders/Placeholder'; import { Placeholder } from '~/components/placeholders/Placeholder';
import { normalizeBrightColor } from '~/utils/color'; import { normalizeBrightColor } from '~/utils/color';
@ -30,67 +26,24 @@ const breakpoints: SwiperOptions['breakpoints'] = {
}; };
const LabImage: FC<IProps> = ({ node, isLoading }) => { const LabImage: FC<IProps> = ({ node, isLoading }) => {
const [controlledSwiper, setControlledSwiper] = useState<SwiperClass | undefined>(undefined);
const images = useNodeImages(node); const images = useNodeImages(node);
const updateSwiper = useCallback(() => {
if (!controlledSwiper) return;
controlledSwiper.updateSlides();
controlledSwiper.updateSize();
controlledSwiper.update();
}, [controlledSwiper]);
const resetSwiper = useCallback(() => {
if (!controlledSwiper) return;
controlledSwiper.slideTo(0, 0);
}, [controlledSwiper]);
useEffect(() => {
updateSwiper();
resetSwiper();
}, [images, updateSwiper, resetSwiper]);
const onClick = useGotoNode(node.id); const onClick = useGotoNode(node.id);
if (!images?.length && !isLoading) { if (!images?.length && !isLoading) {
return null; return null;
} }
const file = images[0];
return ( return (
<Placeholder active={isLoading} width="100%" height={400}> <Placeholder active={isLoading} width="100%" height={400}>
<div className={styles.wrapper}> <div className={styles.wrapper}>
<Swiper
initialSlide={0}
slidesPerView={images.length > 1 ? 1.1 : 1}
onSwiper={setControlledSwiper}
grabCursor
autoHeight
breakpoints={breakpoints}
observeSlideChildren
observeParents
resizeObserver
watchOverflow
updateOnImagesReady
onInit={resetSwiper}
keyboard={{
enabled: true,
onlyInViewport: false,
}}
>
{images.map(file => (
<SwiperSlide className={styles.slide} key={file.id}>
<ImagePreloader <ImagePreloader
file={file} file={file}
onLoad={updateSwiper}
onClick={onClick} onClick={onClick}
className={styles.image} className={styles.image}
color={normalizeBrightColor(file?.metadata?.dominant_color)} color={normalizeBrightColor(file?.metadata?.dominant_color)}
/> />
</SwiperSlide>
))}
</Swiper>
</div> </div>
</Placeholder> </Placeholder>
); );

View file

@ -130,7 +130,7 @@ const TagInput: FC<IProps> = ({ exclude, onAppend, onClearTag, onSubmit }) => {
/> />
</TagWrapper> </TagWrapper>
{onInput && focused && input?.length > 0 && ref.current && ( {focused && input?.length > 0 && ref.current && (
<TagAutocomplete <TagAutocomplete
exclude={exclude} exclude={exclude}
input={ref.current} input={ref.current}