mirror of
https://github.com/anatolykopyl/vk-nft-feed.git
synced 2026-03-26 04:44:34 +00:00
Stack images
This commit is contained in:
34
post2Svg.js
34
post2Svg.js
@@ -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('&', '&'),
|
||||
};
|
||||
});
|
||||
|
||||
return makeSvg(images);
|
||||
}
|
||||
Reference in New Issue
Block a user