aboutsummaryrefslogtreecommitdiff
path: root/src/client/util
diff options
context:
space:
mode:
Diffstat (limited to 'src/client/util')
-rw-r--r--src/client/util/ScriptManager.ts63
-rw-r--r--src/client/util/Scripting.ts9
2 files changed, 70 insertions, 2 deletions
diff --git a/src/client/util/ScriptManager.ts b/src/client/util/ScriptManager.ts
new file mode 100644
index 000000000..5bddb44ca
--- /dev/null
+++ b/src/client/util/ScriptManager.ts
@@ -0,0 +1,63 @@
+import { Doc, DocListCast } from "../../fields/Doc";
+import { List } from "../../fields/List";
+import { Docs } from "../documents/Documents";
+import { Scripting, ScriptParam } from "./Scripting";
+import { StrCast } from "../../fields/Types";
+
+
+export class ScriptManager {
+
+ private static _instance: ScriptManager;
+ public static get Instance(): ScriptManager {
+ return this._instance || (this._instance = new this());
+ }
+ private constructor() {
+ }
+
+ public get ScriptManagerDoc(): Doc | undefined {
+ return Docs.Prototypes.MainScriptDocument();
+ }
+
+ public getAllScripts(): Doc[] {
+ const sdoc = ScriptManager.Instance.ScriptManagerDoc;
+ if (sdoc) {
+ const docs = DocListCast(sdoc.data);
+ return docs;
+ }
+ return [];
+ }
+
+ public addScript(scriptDoc: Doc): boolean {
+ const scriptList = ScriptManager.Instance.getAllScripts();
+ scriptList.push(scriptDoc);
+ if (ScriptManager.Instance.ScriptManagerDoc) {
+ ScriptManager.Instance.ScriptManagerDoc.data = new List<Doc>(scriptList);
+ return true;
+ }
+ return false;
+ }
+
+ public deleteScript(scriptDoc: Doc): boolean {
+ const scriptList = ScriptManager.Instance.getAllScripts();
+ const index = ScriptManager.Instance.getAllScripts().indexOf(scriptDoc);
+ if (index > -1) {
+ scriptList.splice(index, 1);
+ if (ScriptManager.Instance.ScriptManagerDoc) {
+ ScriptManager.Instance.ScriptManagerDoc.data = new List<Doc>(scriptList);
+ return true;
+ }
+ }
+ return false;
+ }
+}
+
+const scriptList = ScriptManager.Instance.getAllScripts();
+
+scriptList.forEach((scriptDoc: Doc) => {
+
+ const p = scriptDoc.compileParams?.reduce((o: ScriptParam, p: string) => { o[p] = "any"; return o; }, {} as ScriptParam);
+ const f = new Function(...Array.from(Object.keys(p)), StrCast(scriptDoc.rawScript));
+
+ Scripting.addGlobal(f, StrCast(scriptDoc.description), StrCast(p), StrCast(scriptDoc.name));
+
+}); \ No newline at end of file
diff --git a/src/client/util/Scripting.ts b/src/client/util/Scripting.ts
index 817e6b29d..5619b22b0 100644
--- a/src/client/util/Scripting.ts
+++ b/src/client/util/Scripting.ts
@@ -51,8 +51,9 @@ export namespace Scripting {
export function addGlobal(name: string, global: any): void;
export function addGlobal(global: { name: string }, decription?: string, params?: any): void;
+ export function addGlobal(global: { name: string }, decription?: string, params?: any, name?: any): void;
- export function addGlobal(nameOrGlobal: any, global?: any, params?: any) {
+ export function addGlobal(nameOrGlobal: any, global?: any, params?: any, name?: any) {
let n: any;
let obj: any;
@@ -61,12 +62,16 @@ export namespace Scripting {
n = nameOrGlobal;
obj = global;
} else {
- n = nameOrGlobal.name;
obj = [nameOrGlobal];
obj.push(global);
if (params) {
obj.push(params);
}
+ if (name) {
+ n = name;
+ } else {
+ n = nameOrGlobal.name;
+ }
}
} else if (nameOrGlobal && typeof nameOrGlobal.name === "string") {
n = nameOrGlobal.name;