import { List as ImmutableList, Record as ImmutableRecord } from 'immutable'; import React, { useState } from 'react'; import type { Attachment as AttachmentEntity } from 'soapbox/types/entities'; interface IPlaceholderMediaGallery { media: ImmutableList defaultWidth?: number } const SizeData = ImmutableRecord({ style: {} as React.CSSProperties, itemsDimensions: [] as Record[], size: 1 as number, width: 0 as number, }); const PlaceholderMediaGallery: React.FC = ({ media, defaultWidth }) => { const [width, setWidth] = useState(defaultWidth); const handleRef = (node: HTMLDivElement) => { if (node) { setWidth(node.offsetWidth); } }; const getSizeData = (size: number) => { const style: React.CSSProperties = {}; let itemsDimensions: Record[] = []; if (size === 1) { style.height = width! * 9 / 16; itemsDimensions = [ { w: '100%', h: '100%' }, ]; } else if (size === 2) { style.height = width! / 2; itemsDimensions = [ { w: '50%', h: '100%', r: '2px' }, { w: '50%', h: '100%', l: '2px' }, ]; } else if (size === 3) { style.height = width; itemsDimensions = [ { w: '50%', h: '50%', b: '2px', r: '2px' }, { w: '50%', h: '50%', b: '2px', l: '2px' }, { w: '100%', h: '50%', t: '2px' }, ]; } else if (size >= 4) { style.height = width; itemsDimensions = [ { w: '50%', h: '50%', b: '2px', r: '2px' }, { w: '50%', h: '50%', b: '2px', l: '2px' }, { w: '50%', h: '50%', t: '2px', r: '2px' }, { w: '50%', h: '50%', t: '2px', l: '2px' }, ]; } return SizeData({ style, itemsDimensions, size, width, }); }; const renderItem = (dimensions: Record, i: number) => { const width = dimensions.w; const height = dimensions.h; const top = dimensions.t || 'auto'; const right = dimensions.r || 'auto'; const bottom = dimensions.b || 'auto'; const left = dimensions.l || 'auto'; const float = dimensions.float as any || 'left'; const position = dimensions.pos as any || 'relative'; return
; }; const sizeData = getSizeData(media.size); return (
{media.take(4).map((_, i) => renderItem(sizeData.get('itemsDimensions')[i], i))}
); }; export default PlaceholderMediaGallery;