-
-
Notifications
You must be signed in to change notification settings - Fork 54
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #790 from the-hideout/feature/items_on_items_tables
Items on items tables
- Loading branch information
Showing
17 changed files
with
177 additions
and
15 deletions.
There are no files selected for viewing
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,147 @@ | ||
const fs = require('fs'); | ||
const path = require('path'); | ||
const sharp = require('sharp'); | ||
|
||
const fetch = require('cross-fetch'); | ||
|
||
const categoryPages = require('../src/data/category-pages.json'); | ||
const { exit } = require('process'); | ||
|
||
|
||
const ignoredCategories = [ | ||
'headsets', | ||
'helmets', | ||
'glasses', | ||
'armors', | ||
'rigs', | ||
'backpacks', | ||
'guns', | ||
// 'mods', | ||
'pistol-grips', | ||
'suppressors', | ||
'grenades', | ||
'containers', | ||
'barter-items', | ||
'keys', | ||
'provisions' | ||
]; | ||
|
||
const graphqlRequest = (queryString) => { | ||
return fetch('https://api.tarkov.dev/graphql', { | ||
method: 'POST', | ||
cache: 'no-store', | ||
headers: { | ||
'Content-Type': 'application/json', | ||
Accept: 'application/json', | ||
}, | ||
body: JSON.stringify({ | ||
query: queryString | ||
}), | ||
}).then(response => response.json()); | ||
}; | ||
|
||
function shuffle(array) { | ||
let currentIndex = array.length; | ||
let randomIndex; | ||
|
||
// While there remain elements to shuffle. | ||
while (currentIndex > 0) { | ||
// Pick a remaining element. | ||
randomIndex = Math.floor(Math.random() * currentIndex); | ||
currentIndex--; | ||
|
||
// And swap it with the current element. | ||
[array[currentIndex], array[randomIndex]] = [array[randomIndex], array[currentIndex]]; | ||
} | ||
|
||
return array; | ||
} | ||
|
||
(async () => { | ||
try { | ||
console.time('Generating thumbnails'); | ||
|
||
const maxWidth = 256; | ||
const maxHeight = 144; | ||
const mapsPath = './public/images/items/'; | ||
|
||
for (const categoryPage of categoryPages) { | ||
if (ignoredCategories.includes(categoryPage.key)) { | ||
continue | ||
} | ||
|
||
const originalImg = await sharp(mapsPath + categoryPage.key + '-table.png'); | ||
const metadata = await originalImg.metadata(); | ||
const scale = metadata.width / maxWidth; | ||
const cropHeight = Math.ceil(scale * maxHeight); | ||
const itemWidth = metadata.width / 2; | ||
const itemHeight = cropHeight / 2; | ||
|
||
const croppedImage = originalImg.extract({ left: 0, top: 0, width: metadata.width, height: cropHeight }); | ||
// const croppedImage = await sharp({ | ||
// create: { | ||
// width: metadata.width, | ||
// height: cropHeight, | ||
// channels: 4, | ||
// background: { r: 45, g: 45, b: 47, alpha: 1.0 } | ||
// } | ||
// }).png(); | ||
|
||
let type = categoryPage.type; | ||
const query = `{ | ||
items(type: ${type}, limit:420) { | ||
image512pxLink | ||
} | ||
}`; | ||
const itemsOfType = await graphqlRequest(query); | ||
|
||
const items = itemsOfType.data.items; | ||
shuffle(items); | ||
|
||
const itemResize = {width: itemWidth, height: itemHeight, fit: sharp.fit.contain, background: { r: 255, g: 255, b: 255, alpha: 0.0 }}; | ||
const itemRotate = 0; //7 + Math.random()*4-2; | ||
|
||
const tlImageFetch = await fetch(items[0].image512pxLink); | ||
const tlImageBuffer = await tlImageFetch.buffer(); | ||
const tlImage = await sharp(tlImageBuffer).resize(itemResize).rotate(-itemRotate).toBuffer(); | ||
|
||
const trImageFetch = await fetch(items[1].image512pxLink); | ||
const trImageBuffer = await trImageFetch.buffer(); | ||
const trImage = await sharp(trImageBuffer).resize(itemResize).rotate(itemRotate).toBuffer(); | ||
|
||
const blImageFetch = await fetch(items[2].image512pxLink); | ||
const blImageBuffer = await blImageFetch.buffer(); | ||
const blImage = await sharp(blImageBuffer).resize(itemResize).rotate(itemRotate).toBuffer(); | ||
|
||
const brImageFetch = await fetch(items[3].image512pxLink); | ||
const brImageBuffer = await brImageFetch.buffer(); | ||
const brImage = await sharp(brImageBuffer).resize(itemResize).rotate(-itemRotate).toBuffer(); | ||
|
||
const cImageFetch = await fetch(items[4].image512pxLink); | ||
const cImageBuffer = await cImageFetch.buffer(); | ||
const cImage = await sharp(cImageBuffer).resize(itemResize).toBuffer(); | ||
|
||
const composedImage = await croppedImage | ||
.blur(6) | ||
.composite([ | ||
{ input: tlImage, gravity: 'northwest', blend: 'over' }, | ||
{ input: trImage, gravity: 'northeast', blend: 'over' }, | ||
{ input: blImage, gravity: 'southwest', blend: 'over' }, | ||
{ input: brImage, gravity: 'southeast', blend: 'over' }, | ||
{ input: cImage, gravity: 'centre', blend: 'over' }, | ||
]).toBuffer(); | ||
|
||
const finalImage = await sharp(composedImage).resize(maxWidth, maxHeight).jpeg({mozjpeg: true, quality: 100}); | ||
// const finalImage = await sharp(composedImage).jpeg({mozjpeg: true, quality: 90}); | ||
|
||
await finalImage.toFile(mapsPath + categoryPage.key + '-table_thumb.jpg'); | ||
|
||
console.log(`Generated thumbnail for ${categoryPage.key}`); | ||
// return; | ||
}; | ||
console.timeEnd('Generating thumbnails'); | ||
} catch (error) { | ||
console.error(error) | ||
console.log('error generating thumbnail (offline mode?)') | ||
} | ||
})(); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters