summaryrefslogtreecommitdiff
path: root/includes/external/photo/index.js
diff options
context:
space:
mode:
Diffstat (limited to 'includes/external/photo/index.js')
-rw-r--r--includes/external/photo/index.js162
1 files changed, 0 insertions, 162 deletions
diff --git a/includes/external/photo/index.js b/includes/external/photo/index.js
deleted file mode 100644
index fda0163..0000000
--- a/includes/external/photo/index.js
+++ /dev/null
@@ -1,162 +0,0 @@
-const fs = require('fs');
-const cp = require('child_process');
-const child_process = require("child_process");
-const number = require('../../app.json')['signal']['raindrops'];
-
-let bottom = [
- "jybgq",
- "auvwc",
- "mvaws",
- "wnujv"
-];
-
-let ponies = [...require('../../data/gdapd/members.json').filter(i => {
- return fs.existsSync("../../data/metadata/" + i.id + ".json") && !require("../../data/metadata/" + i.id + ".json").species.includes("human");
-}), ...require('../../data/ynmuc/members.json').filter(i => {
- return fs.existsSync("../../data/metadata/" + i.id + ".json") && !require("../../data/metadata/" + i.id + ".json").species.includes("human");
-})];
-let columns = Math.ceil(Math.sqrt(ponies.length));
-console.log(ponies.length + " ponies, so the image will contain " + columns + "x" + columns + " ponies");
-
-let list = [];
-
-for (let pony of ponies) {
- if (list.includes(pony.name) || bottom.includes(pony.id)) continue;
-
- let metadata = require("../../data/metadata/" + pony.id + ".json");
- let relations = [...(metadata.marefriends ?? []), ...(metadata.sisters ?? []), ...(metadata.caretakers ?? [])]
-
- list.push(pony.name);
-
- for (let relation of relations) {
- let relationPony = ponies.filter(i => i.id === relation.split("/")[1])[0] ?? null;
- if (relationPony) {
- if (!list.includes(relationPony.name) && !bottom.includes(pony.id)) list.push(relationPony.name);
- }
- }
-}
-
-for (let id of bottom) {
- let pony = ponies.filter(i => i.id === id)[0] ?? null;
- if (list.includes(pony.name)) continue;
-
- let metadata = require("../../data/metadata/" + pony.id + ".json");
- let relations = [...(metadata.marefriends ?? []), ...(metadata.sisters ?? []), ...(metadata.caretakers ?? [])]
-
- list.push(pony.name);
-
- for (let relation of relations) {
- let relationPony = ponies.filter(i => i.id === relation.split("/")[1])[0] ?? null;
- if (relationPony) {
- if (!list.includes(relationPony.name)) list.push(relationPony.name);
- }
- }
-}
-
-let lines = [];
-while (list.length > 0) lines.push(list.splice(0, columns));
-
-if (fs.existsSync("./output.png")) fs.unlinkSync("./output.png");
-
-for (let index1 in lines) {
- process.stdout.write(index1 + ": ");
- index1 = parseInt(index1);
- let line = lines[index1];
-
- let toRemove;
-
- for (let index2 in line) {
- index2 = parseInt(index2);
- let cell = line[index2];
-
- let pony = ponies.filter(i => i.name === cell)[0] ?? null;
- process.stdout.write(pony.id);
- if (pony) {
- if (fs.existsSync("../../../assets/ponies/" + pony.id + ".png")) {
- if (!fs.existsSync("./" + index1 + ".png")) {
- cp.execFileSync("convert", ["../../../assets/ponies/" + pony.id + ".png", "-filter", "Point", "-resize", "x240", "./" + index1 + ".png"]);
- process.stdout.write("...");
-
- toRemove = parseInt(cp.execFileSync("identify", ["-format", "%w", "./" + index1 + ".png"]).toString()) / 2;
- process.stdout.write("...");
- } else {
- let width1 = (index2 + 1) * 240;
- let width2 = index2 * 120;
-
- cp.execFileSync("convert", ["../../../assets/ponies/" + pony.id + ".png", "-filter", "Point", "-resize", "x240", "./temp.png"]);
- process.stdout.write(".");
- cp.execFileSync("convert", ["-size", width1 + "x240", "xc:transparent", "canvas.png"]);
- process.stdout.write(".");
- cp.execFileSync("convert", ["canvas.png", "-colorspace", "sRGB", "./temp.png", "-geometry", "+" + width2 + "+0", "-composite", "./temp.png"]);
- process.stdout.write(".");
- cp.execFileSync("convert", ["./" + index1 + ".png", "-background", "none", "-extent", width1 + "x240", "./" + index1 + "-2.png"]);
- process.stdout.write(".");
- cp.execFileSync("convert", ["./" + index1 + "-2.png", "./temp.png", "-background", "none", "-flatten", "-trim", "+repage", "./" + index1 + "-3.png"]);
- process.stdout.write(".");
-
- fs.unlinkSync("./" + index1 + "-2.png");
- fs.unlinkSync("./" + index1 + ".png");
- fs.renameSync("./" + index1 + "-3.png", "./" + index1 + ".png");
- process.stdout.write(".");
- }
-
- process.stdout.write(", ");
- }
- }
- }
-
- if (!fs.existsSync("./output.png")) {
- cp.execFileSync("convert", ["./" + index1 + ".png", "./output.png"]);
- process.stdout.write("....");
- fs.unlinkSync("./" + index1 + ".png");
- process.stdout.write("...");
- } else {
- let height1 = (index1 + 1) * 480;
- let height2 = index1 * 120;
-
- cp.execFileSync("convert", ["./" + index1 + ".png", "-filter", "Point", "-resize", "x240", "./temp.png"]);
- process.stdout.write(".");
- cp.execFileSync("convert", ["-size", (columns * 240) + "x" + height1, "xc:transparent", "canvas.png"]);
- process.stdout.write(".");
-
- cp.execFileSync("convert", ["canvas.png", "-colorspace", "sRGB", "./temp.png", "-geometry", "+0+" + height2, "-composite", "./temp.png"]);
- process.stdout.write(".");
- cp.execFileSync("convert", ["./output.png", "-background", "none", "-extent", (columns * 240) + "x" + height1, "./output-2.png"]);
- process.stdout.write(".");
- cp.execFileSync("convert", ["./output-2.png", "./temp.png", "-background", "none", "-gravity", "Center", "-flatten", "-trim", "+repage", "./output-3.png"]);
- process.stdout.write(".");
-
- fs.unlinkSync("./output-2.png");
- fs.unlinkSync("./output.png");
- fs.unlinkSync("./temp.png");
- fs.unlinkSync("./" + index1 + ".png");
- fs.unlinkSync("./canvas.png");
- process.stdout.write(".");
-
- fs.renameSync("./output-3.png", "./output.png");
- process.stdout.write(".");
- }
-
- process.stdout.write("\n");
-}
-
-
-process.stdout.write(".");
-let dimensions = cp.execFileSync("identify", ["-format", "%wx%h", "./output.png"]).toString();
-process.stdout.write(".");
-let highest = Math.max(...dimensions.split("x").map(i => parseInt(i))) + 200;
-cp.execFileSync("convert", ["./output.png", "-background", "none", "-gravity", "Center", "-extent", highest + "x" + highest, "./output-2.png"]);
-process.stdout.write(".");
-cp.execFileSync("magick", ["-size", highest + "x" + highest, "-define", "gradient:direction=North", "gradient:#6acc28-#72ace5", "-colorspace", "sRGB", "gradient.png"]);
-process.stdout.write(".");
-cp.execFileSync("convert", ["./gradient.png", "./output-2.png", "-colorspace", "sRGB", "-flatten", "./output.png"]);
-process.stdout.write(".");
-fs.unlinkSync("gradient.png");
-fs.unlinkSync("output-2.png");
-process.stdout.write(".");
-child_process.execFileSync("signal-cli", [ "-a", number, "updateGroup", "--group", "Im1iOlG3TxtiwAad+aVPJ6RsdSN3YCQauz1SmYiMqA8=", "--avatar", __dirname + "/output.png" ]);
-process.stdout.write(".");
-child_process.execFileSync("signal-cli", [ "-a", number, "sendSyncRequest" ]);
-process.stdout.write(".");
-
-console.log("\nComplete!"); \ No newline at end of file