Stack images

This commit is contained in:
2022-01-21 02:11:40 +03:00
parent 20ad4adfe8
commit ba37db9182

View File

@@ -1,12 +1,34 @@
function makeSvg(image) { function makeSvg(images) {
image = image.replaceAll('&', '&') const spacing = 50;
const height = images.length * (900 + spacing) + spacing;
return `<svg viewBox="0 0 1000 1000" xmlns="http://www.w3.org/2000/svg"> function imageTag(url, n) {
const y = 50 + n * (900 + spacing);
return `<image x="50" y="${y}" width="900" height="900" href="${url}"/>`;
}
let imageTags = '';
images.forEach((image, i) => {
imageTags += imageTag(image.url, i);
})
return `<svg viewBox="0 0 1000 ${height}" xmlns="http://www.w3.org/2000/svg">
<rect width="100%" height="100%" fill="white" /> <rect width="100%" height="100%" fill="white" />
<image x="50" y="50" width="900" height="900" href="${image}"/> ${imageTags}
</svg>`; </svg>\n`;
} }
export default function(post) { export default function(post) {
return makeSvg(post.attachments[0].photo.sizes[0].url) const photoAttachments = post.attachments.filter((attachment) => {
} return attachment.photo;
})
const images = photoAttachments.map((attachment) => {
return {
url: attachment.photo.sizes[attachment.photo.sizes.length - 1].url.replaceAll('&', '&amp;'),
};
});
return makeSvg(images);
}