mirror of
https://github.com/Equicord/Equicord.git
synced 2025-05-11 18:05:37 +02:00
Commands In Plugin Json
This commit is contained in:
parent
df4d56aacf
commit
6bd3b06de5
4 changed files with 42 additions and 7 deletions
|
@ -20,15 +20,21 @@ import { Dirent, readdirSync, readFileSync, writeFileSync } from "fs";
|
|||
import { access, readFile } from "fs/promises";
|
||||
import { join, sep } from "path";
|
||||
import { normalize as posixNormalize, sep as posixSep } from "path/posix";
|
||||
import { BigIntLiteral, createSourceFile, Identifier, isArrayLiteralExpression, isCallExpression, isExportAssignment, isIdentifier, isObjectLiteralExpression, isPropertyAccessExpression, isPropertyAssignment, isSatisfiesExpression, isStringLiteral, isVariableStatement, NamedDeclaration, NodeArray, ObjectLiteralExpression, ScriptTarget, StringLiteral, SyntaxKind } from "typescript";
|
||||
import { BigIntLiteral, createSourceFile, Identifier, isArrayLiteralExpression, isCallExpression, isExportAssignment, isIdentifier, isObjectLiteralExpression, isPropertyAccessExpression, isPropertyAssignment, isSatisfiesExpression, isStringLiteral, isVariableStatement, NamedDeclaration, NodeArray, ObjectLiteralExpression, PropertyAssignment, ScriptTarget, StringLiteral, SyntaxKind } from "typescript";
|
||||
|
||||
import { getPluginTarget } from "./utils.mjs";
|
||||
import { ApplicationCommandOptionType } from "@api/Commands";
|
||||
|
||||
interface Dev {
|
||||
name: string;
|
||||
id: string;
|
||||
}
|
||||
|
||||
interface Command {
|
||||
name: string;
|
||||
description: string;
|
||||
}
|
||||
|
||||
interface PluginData {
|
||||
name: string;
|
||||
description: string;
|
||||
|
@ -37,6 +43,7 @@ interface PluginData {
|
|||
dependencies: string[];
|
||||
hasPatches: boolean;
|
||||
hasCommands: boolean;
|
||||
commands: Command[];
|
||||
required: boolean;
|
||||
enabledByDefault: boolean;
|
||||
target: "discordDesktop" | "vencordDesktop" | "equicordDesktop" | "desktop" | "web" | "dev";
|
||||
|
@ -161,6 +168,35 @@ async function parseFile(fileName: string) {
|
|||
break;
|
||||
case "commands":
|
||||
data.hasCommands = true;
|
||||
if (!isArrayLiteralExpression(value)) throw fail("commands is not an array literal");
|
||||
data.commands = value.elements.map((e) => {
|
||||
if (!isObjectLiteralExpression(e)) {
|
||||
throw fail("commands array contains non-object literals");
|
||||
}
|
||||
|
||||
const nameProperty = e.properties.find((p): p is PropertyAssignment => {
|
||||
return isPropertyAssignment(p) && isIdentifier(p.name) && p.name.escapedText === 'name';
|
||||
});
|
||||
|
||||
const descriptionProperty = e.properties.find((p): p is PropertyAssignment => {
|
||||
return isPropertyAssignment(p) && isIdentifier(p.name) && p.name.escapedText === 'description';
|
||||
});
|
||||
|
||||
if (!nameProperty || !descriptionProperty) throw fail("Command missing required properties");
|
||||
|
||||
const name = isStringLiteral(nameProperty.initializer)
|
||||
? nameProperty.initializer.text
|
||||
: '';
|
||||
const description = isStringLiteral(descriptionProperty.initializer)
|
||||
? descriptionProperty.initializer.text
|
||||
: '';
|
||||
|
||||
return {
|
||||
name,
|
||||
description
|
||||
};
|
||||
});
|
||||
|
||||
break;
|
||||
case "authors":
|
||||
if (!isArrayLiteralExpression(value)) throw fail("authors is not an array literal");
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue