MediaAttachmentGrid: improve layout as length % 2
This commit is contained in:
parent
eefe2812df
commit
dbb93fd76c
1 changed files with 22 additions and 12 deletions
|
@ -51,9 +51,19 @@ const MediaAttachmentGrid: Component<{
|
|||
setViewerIndex(index);
|
||||
};
|
||||
|
||||
const columnCount = () => {
|
||||
if (props.attachments.length === 1) {
|
||||
return 1;
|
||||
} else if (props.attachments.length % 2 === 0) {
|
||||
return 2;
|
||||
} else {
|
||||
return 3;
|
||||
}
|
||||
};
|
||||
|
||||
css`
|
||||
.attachments {
|
||||
column-count: ${(props.attachments.length === 1 ? 1 : 3).toString()};
|
||||
column-count: ${columnCount.toString()};
|
||||
}
|
||||
`;
|
||||
return (
|
||||
|
@ -104,17 +114,17 @@ const MediaAttachmentGrid: Component<{
|
|||
/>
|
||||
);
|
||||
case "gifv": // Later we can handle the preview
|
||||
return (
|
||||
<video
|
||||
src={item.url || undefined}
|
||||
style={style()}
|
||||
onLoadedMetadata={[setLoaded, true]}
|
||||
autoplay={false}
|
||||
controls
|
||||
playsinline /* or safari on iOS will play in full-screen */
|
||||
loop
|
||||
/>
|
||||
);
|
||||
return (
|
||||
<video
|
||||
src={item.url || undefined}
|
||||
style={style()}
|
||||
onLoadedMetadata={[setLoaded, true]}
|
||||
autoplay={false}
|
||||
controls
|
||||
playsinline /* or safari on iOS will play in full-screen */
|
||||
loop
|
||||
/>
|
||||
);
|
||||
|
||||
case "audio":
|
||||
case "unknown":
|
||||
|
|
Loading…
Reference in a new issue