## Bug Fixes ### Note Card Actions - Fix broken size change functionality (missing state declaration) - Implement React 19 useOptimistic for instant UI feedback - Add startTransition for non-blocking updates - Ensure smooth animations without page refresh - All note actions now work: pin, archive, color, size, checklist ### Markdown LaTeX Rendering - Add remark-math and rehype-katex plugins - Support inline equations with dollar sign syntax - Support block equations with double dollar sign syntax - Import KaTeX CSS for proper styling - Equations now render correctly instead of showing raw LaTeX ## Technical Details - Replace undefined currentNote references with optimistic state - Add optimistic updates before server actions for instant feedback - Use router.refresh() in transitions for smart cache invalidation - Install remark-math, rehype-katex, and katex packages ## Testing - Build passes successfully with no TypeScript errors - Dev server hot-reloads changes correctly
64 lines
1.9 KiB
TypeScript
64 lines
1.9 KiB
TypeScript
'use server';
|
|
|
|
import bcrypt from 'bcryptjs';
|
|
import prisma from '@/lib/prisma';
|
|
import { z } from 'zod';
|
|
import { redirect } from 'next/navigation';
|
|
import { getSystemConfig } from '@/lib/config';
|
|
|
|
const RegisterSchema = z.object({
|
|
email: z.string().email(),
|
|
password: z.string().min(6),
|
|
name: z.string().min(2),
|
|
});
|
|
|
|
export async function register(prevState: string | undefined, formData: FormData) {
|
|
// Check if registration is allowed
|
|
const config = await getSystemConfig();
|
|
const allowRegister = config.ALLOW_REGISTRATION !== 'false' && process.env.ALLOW_REGISTRATION !== 'false';
|
|
|
|
if (!allowRegister) {
|
|
return 'Registration is currently disabled by the administrator.';
|
|
}
|
|
|
|
const validatedFields = RegisterSchema.safeParse({
|
|
email: formData.get('email'),
|
|
password: formData.get('password'),
|
|
name: formData.get('name'),
|
|
});
|
|
|
|
if (!validatedFields.success) {
|
|
return 'Invalid fields. Failed to register.';
|
|
}
|
|
|
|
const { email, password, name } = validatedFields.data;
|
|
|
|
try {
|
|
const existingUser = await prisma.user.findUnique({ where: { email: email.toLowerCase() } });
|
|
if (existingUser) {
|
|
return 'User already exists.';
|
|
}
|
|
|
|
const hashedPassword = await bcrypt.hash(password, 10);
|
|
|
|
await prisma.user.create({
|
|
data: {
|
|
email: email.toLowerCase(),
|
|
password: hashedPassword,
|
|
name,
|
|
},
|
|
});
|
|
|
|
// Attempt to sign in immediately after registration
|
|
// We cannot import signIn here directly if it causes circular deps or issues,
|
|
// but usually it works. If not, redirecting to login is fine.
|
|
// Let's stick to redirecting to login but with a clear success message?
|
|
// Or better: lowercase the email to fix the potential bug.
|
|
} catch (error) {
|
|
console.error('Registration Error:', error);
|
|
return 'Database Error: Failed to create user.';
|
|
}
|
|
|
|
redirect('/login');
|
|
}
|