From 396acf3bbbe00a192cb0ea0a9ccf91b1d8d2850b Mon Sep 17 00:00:00 2001
From: Fuwn <50817549+Fuwn@users.noreply.github.com>
Date: Sat, 24 Jan 2026 13:09:50 +0000
Subject: Initial commit
Created from https://vercel.com/new
---
src/app/login/LoginForm.tsx | 70 +++++++++++++++++++++++++++++++++++++++++++++
src/app/login/LoginPage.tsx | 11 +++++++
src/app/login/page.tsx | 14 +++++++++
3 files changed, 95 insertions(+)
create mode 100644 src/app/login/LoginForm.tsx
create mode 100644 src/app/login/LoginPage.tsx
create mode 100644 src/app/login/page.tsx
(limited to 'src/app/login')
diff --git a/src/app/login/LoginForm.tsx b/src/app/login/LoginForm.tsx
new file mode 100644
index 0000000..26d78dd
--- /dev/null
+++ b/src/app/login/LoginForm.tsx
@@ -0,0 +1,70 @@
+import {
+ Column,
+ Form,
+ FormButtons,
+ FormField,
+ FormSubmitButton,
+ Heading,
+ Icon,
+ PasswordField,
+ TextField,
+} from '@umami/react-zen';
+import { useRouter } from 'next/navigation';
+import { useMessages, useUpdateQuery } from '@/components/hooks';
+import { Logo } from '@/components/svg';
+import { setClientAuthToken } from '@/lib/client';
+import { setUser } from '@/store/app';
+
+export function LoginForm() {
+ const { formatMessage, labels, getErrorMessage } = useMessages();
+ const router = useRouter();
+ const { mutateAsync, error } = useUpdateQuery('/auth/login');
+
+ const handleSubmit = async (data: any) => {
+ await mutateAsync(data, {
+ onSuccess: async ({ token, user }) => {
+ setClientAuthToken(token);
+ setUser(user);
+ router.push('/');
+ },
+ });
+ };
+
+ return (
+
+
+
+
+ umami
+
+
+ );
+}
diff --git a/src/app/login/LoginPage.tsx b/src/app/login/LoginPage.tsx
new file mode 100644
index 0000000..6f485e3
--- /dev/null
+++ b/src/app/login/LoginPage.tsx
@@ -0,0 +1,11 @@
+'use client';
+import { Column } from '@umami/react-zen';
+import { LoginForm } from './LoginForm';
+
+export function LoginPage() {
+ return (
+
+
+
+ );
+}
diff --git a/src/app/login/page.tsx b/src/app/login/page.tsx
new file mode 100644
index 0000000..ea27735
--- /dev/null
+++ b/src/app/login/page.tsx
@@ -0,0 +1,14 @@
+import type { Metadata } from 'next';
+import { LoginPage } from './LoginPage';
+
+export default async function () {
+ if (process.env.DISABLE_LOGIN || process.env.CLOUD_MODE) {
+ return null;
+ }
+
+ return ;
+}
+
+export const metadata: Metadata = {
+ title: 'Login',
+};
--
cgit v1.2.3