aboutsummaryrefslogtreecommitdiffstats
path: root/packages/browser-extension/src/OptionsPage.tsx
diff options
context:
space:
mode:
authorMohamedBassem <me@mbassem.com>2024-02-13 00:29:25 +0000
committerMohamedBassem <me@mbassem.com>2024-02-13 00:33:58 +0000
commit33c9e8bca54d753c7ea976dd178db0cd5408c218 (patch)
tree56099acd736a37845a7fce3a3ded0d399dbf5777 /packages/browser-extension/src/OptionsPage.tsx
parentb00d2b360d8000edcd9bfa82673ca322a9ac6d1a (diff)
downloadkarakeep-33c9e8bca54d753c7ea976dd178db0cd5408c218.tar.zst
feature: A usable, yet ugly browser extension
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>
+ );
+}