about summary refs log tree commit diff
path: root/assets/src/state
diff options
context:
space:
mode:
authorMel <einebeere@gmail.com>2022-02-17 22:30:43 +0100
committerMel <einebeere@gmail.com>2022-02-17 22:30:43 +0100
commit948e960c6cb5a0f33af66b8b4a26dd56bcf13988 (patch)
tree4eeb3be4c0ea12ef5eff04c766809d54af0280d5 /assets/src/state
parent50d3d4080a5b8bf0819e168aa2301e3124a55300 (diff)
downloadrook-948e960c6cb5a0f33af66b8b4a26dd56bcf13988.tar.zst
rook-948e960c6cb5a0f33af66b8b4a26dd56bcf13988.zip
Rename stores/ to state/ since it no longer includes just state in stores.
Diffstat (limited to 'assets/src/state')
-rw-r--r--assets/src/state/constant_state.ts33
-rw-r--r--assets/src/state/data.ts21
-rw-r--r--assets/src/state/received_requests.ts17
3 files changed, 71 insertions, 0 deletions
diff --git a/assets/src/state/constant_state.ts b/assets/src/state/constant_state.ts
new file mode 100644
index 0000000..aeda86e
--- /dev/null
+++ b/assets/src/state/constant_state.ts
@@ -0,0 +1,33 @@
+// Cannot be changed after being set.
+
+import { RookType } from "../models/rook_type";
+
+let clientType: RookType = null;
+
+export function setClientType(type: RookType) {
+    if (clientType !== null) {
+        clientType = type;
+    } else {
+        throw new Error("Tried changing client type after initialization.");
+    }
+}
+
+export function isClientShare() {
+    if (clientType === null) {
+        throw new Error(
+            "Tried accessing client type before initialization was completed."
+        );
+    }
+
+    return clientType === RookType.SHARE;
+}
+
+export function isClientRequest() {
+    if (clientType === null) {
+        throw new Error(
+            "Tried accessing client type before initialization was completed."
+        );
+    }
+
+    return clientType === RookType.REQUEST;
+}
diff --git a/assets/src/state/data.ts b/assets/src/state/data.ts
new file mode 100644
index 0000000..d59183c
--- /dev/null
+++ b/assets/src/state/data.ts
@@ -0,0 +1,21 @@
+import { writable } from "svelte/store";
+
+const createDataStore = () => {
+    const { subscribe, update } = writable({ locked: false, data: null });
+
+    return {
+        subscribe,
+        set: data => {
+            update(state => {
+                if (!state.locked) {
+                    return { locked: true, data };
+                } else {
+                    console.error("Tried setting data after locking.");
+                    return state;
+                }
+            });
+        },
+    };
+};
+
+export default createDataStore();
diff --git a/assets/src/state/received_requests.ts b/assets/src/state/received_requests.ts
new file mode 100644
index 0000000..48916ad
--- /dev/null
+++ b/assets/src/state/received_requests.ts
@@ -0,0 +1,17 @@
+import { writable } from "svelte/store";
+import type { IncomingRequest } from "../models/incoming_request";
+
+const createRequestStore = () => {
+    const { subscribe, update } = writable<IncomingRequest[]>([]);
+
+    return {
+        subscribe,
+        addRequest: (request: IncomingRequest) => update(state => [request, ...state]),
+        removeRequest: (token: string) =>
+            update(state =>
+                state.filter(request => request.info.token !== token)
+            ),
+    };
+};
+
+export default createRequestStore();