Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 | 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x | import glob from "glob";
import { promisify } from "util";
import uuid from "uuid/v4";
import { createReadStream } from "fs-extra";
import { stat } from "fs";
import { PNG } from "pngjs";
import parseAssetPath from "shared/lib/assets/parseAssetPath";
import { toValidSymbol } from "shared/lib/helpers/symbols";
import { EmoteResource, EmoteResourceAsset } from "shared/lib/resources/types";
import { getAssetResource } from "./assets";
const globAsync = promisify(glob);
const statAsync = promisify(stat);
const sizeOfAsync = (
filename: string,
): Promise<{ width: number; height: number }> => {
return new Promise((resolve, reject) => {
createReadStream(filename)
.pipe(new PNG())
.on("metadata", resolve)
.on("error", reject);
});
};
const loadEmoteData =
(projectRoot: string) =>
async (filename: string): Promise<EmoteResourceAsset | null> => {
const { file, plugin } = parseAssetPath(filename, projectRoot, "emotes");
const resource = await getAssetResource(EmoteResource, filename);
try {
const size = await sizeOfAsync(filename);
const fileStat = await statAsync(filename, { bigint: true });
const inode = fileStat.ino.toString();
const name = file.replace(/.png/i, "");
return {
_resourceType: "emote",
id: uuid(),
plugin,
name,
symbol: toValidSymbol(`emote_${name}`),
width: size.width,
height: size.height,
_v: Date.now(),
...resource,
filename: file,
inode,
};
} catch (e) {
console.error(e);
return null;
}
};
const loadAllEmoteData = async (
projectRoot: string,
): Promise<EmoteResourceAsset[]> => {
const imagePaths = await globAsync(
`${projectRoot}/assets/emotes/**/@(*.png|*.PNG)`,
);
const pluginPaths = await globAsync(
`${projectRoot}/plugins/*/**/emotes/**/@(*.png|*.PNG)`,
);
const imageData = (
await Promise.all(
([] as Promise<EmoteResourceAsset | null>[]).concat(
imagePaths.map(loadEmoteData(projectRoot)),
pluginPaths.map(loadEmoteData(projectRoot)),
),
)
).filter((i) => i);
return imageData as EmoteResourceAsset[];
};
export default loadAllEmoteData;
export { loadEmoteData };
|