}
diff --git a/web/src/ui/settings/SettingsView.css b/web/src/ui/settings/SettingsView.css
new file mode 100644
index 0000000..fad3c25
--- /dev/null
+++ b/web/src/ui/settings/SettingsView.css
@@ -0,0 +1,9 @@
+div.settings-view {
+ width: min(60rem, 80vw);
+ display: flex;
+ flex-direction: column;
+
+ > h2 {
+ margin: 0;
+ }
+}
diff --git a/web/src/ui/settings/SettingsView.tsx b/web/src/ui/settings/SettingsView.tsx
new file mode 100644
index 0000000..13e5a2d
--- /dev/null
+++ b/web/src/ui/settings/SettingsView.tsx
@@ -0,0 +1,32 @@
+// gomuks - A Matrix client written in Go.
+// Copyright (C) 2024 Tulir Asokan
+//
+// This program is free software: you can redistribute it and/or modify
+// it under the terms of the GNU Affero General Public License as published by
+// the Free Software Foundation, either version 3 of the License, or
+// (at your option) any later version.
+//
+// This program is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU Affero General Public License for more details.
+//
+// You should have received a copy of the GNU Affero General Public License
+// along with this program. If not, see .
+import { RoomStateStore } from "@/api/statestore"
+import JSONView from "@/ui/util/JSONView.tsx"
+import "./SettingsView.css"
+
+interface SettingsViewProps {
+ room: RoomStateStore
+}
+
+const SettingsView = ({ room }: SettingsViewProps) => {
+ return <>
+