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) {
image = image.replaceAll('&', '&')
function makeSvg(images) {
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" />
<image x="50" y="50" width="900" height="900" href="${image}"/>
</svg>`;
${imageTags}
</svg>\n`;
}
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);
}