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

fixed appearance for new image slider

This commit is contained in:
Fedor Katurov 2020-04-23 11:44:44 +07:00
parent 1aa59eb52c
commit 79c5c3be8d
3 changed files with 28 additions and 8 deletions

View file

@ -7,6 +7,7 @@ import { getURL } from '~/utils/dom';
import { UPLOAD_TYPES } from '~/redux/uploads/constants';
import { PRESETS } from '~/constants/urls';
import * as MODAL_ACTIONS from '~/redux/modal/actions';
import { LoaderCircle } from '~/components/input/LoaderCircle';
interface IProps {
is_loading: boolean;
@ -19,7 +20,7 @@ interface IProps {
const NodeImageBlock: FC<IProps> = ({ node, is_loading, updateLayout, modalShowPhotoswipe }) => {
const [is_animated, setIsAnimated] = useState(false);
const [current, setCurrent] = useState(0);
const [height, setHeight] = useState(320);
const [height, setHeight] = useState(window.innerHeight - 140);
const [loaded, setLoaded] = useState<Record<number, boolean>>({});
const refs = useRef<Record<number, HTMLDivElement>>({});
@ -39,9 +40,12 @@ const NodeImageBlock: FC<IProps> = ({ node, is_loading, updateLayout, modalShowP
useEffect(() => updateLayout(), [loaded]);
useEffect(() => {
if (!refs || !refs.current[current] || !loaded[current]) return setHeight(320);
if (!refs || !refs.current[current] || !loaded[current])
return setHeight(window.innerHeight - 140);
const el = refs.current[current];
const element_height = el.getBoundingClientRect && el.getBoundingClientRect().height;
setHeight(element_height);
}, [refs, current, loaded]);
@ -50,6 +54,12 @@ const NodeImageBlock: FC<IProps> = ({ node, is_loading, updateLayout, modalShowP
return () => clearTimeout(timer);
}, []);
const onOpenPhotoSwipe = useCallback(() => modalShowPhotoswipe(images, current), [
modalShowPhotoswipe,
images,
current,
]);
return (
<div className={classNames(styles.wrap, { is_loading, is_animated })}>
<ImageSwitcher
@ -59,8 +69,12 @@ const NodeImageBlock: FC<IProps> = ({ node, is_loading, updateLayout, modalShowP
loaded={loaded}
/>
<div className={styles.image_container} style={{ height }}>
{(is_loading || !loaded[0] || !images.length) && <div className={styles.placeholder} />}
<div className={styles.image_container} style={{ height }} onClick={onOpenPhotoSwipe}>
{(is_loading || !loaded[0] || !images.length) && (
<div className={styles.placeholder}>
<LoaderCircle size={72} />
</div>
)}
{images.map((file, index) => (
<div

View file

@ -51,6 +51,10 @@
}
.placeholder {
background: red;
height: 320px;
width: 100%;
height: calc(100vh - 140px);
border-radius: $radius;
display: flex;
align-items: center;
justify-content: center;
}

View file

@ -47,7 +47,8 @@ const NodePanel: FC<IProps> = memo(
return (
<div className={styles.place} ref={ref}>
{stack &&
{/*
stack &&
createPortal(
<NodePanelInner
node={node}
@ -62,7 +63,8 @@ const NodePanel: FC<IProps> = memo(
stack
/>,
document.body
)}
)
*/}
<NodePanelInner
node={node}