aboutsummaryrefslogtreecommitdiffstats
path: root/packages/browser-extension/src/OptionsPage.tsx
diff options
context:
space:
mode:
Diffstat (limited to 'packages/browser-extension/src/OptionsPage.tsx')
-rw-r--r--packages/browser-extension/src/OptionsPage.tsx42
1 files changed, 42 insertions, 0 deletions
diff --git a/packages/browser-extension/src/OptionsPage.tsx b/packages/browser-extension/src/OptionsPage.tsx
new file mode 100644
index 00000000..e3a34bd9
--- /dev/null
+++ b/packages/browser-extension/src/OptionsPage.tsx
@@ -0,0 +1,42 @@
+import { useRef } from "react";
+import usePluginSettings from "./settings";
+
+export default function OptionsPage() {
+ const [settings, setSettings, _1, _2, _3] = usePluginSettings();
+
+ const apiKeyRef = useRef<HTMLInputElement>(null);
+ const addressRef = useRef<HTMLInputElement>(null);
+
+ const onSave = () => {
+ setSettings({
+ apiKey: apiKeyRef.current?.value || "",
+ address: addressRef.current?.value || "",
+ });
+ };
+
+ return (
+ <div className="flex flex-col space-y-2">
+ <span className="text-lg">Settings</span>
+ <hr />
+ <div className="flex space-x-2 pt-2">
+ <label className="m-auto h-full">API Key</label>
+ <input
+ ref={apiKeyRef}
+ defaultValue={settings.apiKey}
+ className="h-8 flex-1 rounded-lg border border-gray-300 p-2"
+ />
+ </div>
+ <div className="flex space-x-2">
+ <label className="m-auto h-full">Server Address</label>
+ <input
+ ref={addressRef}
+ defaultValue={settings.address}
+ className="h-8 flex-1 rounded-lg border border-gray-300 p-2"
+ />
+ </div>
+ <button className="rounded-lg border border-gray-200" onClick={onSave}>
+ Save
+ </button>
+ </div>
+ );
+}