mirror of
https://github.com/spliit-app/spliit.git
synced 2026-02-11 18:16:13 +01:00
Remove route interception
This commit is contained in:
@@ -1,26 +0,0 @@
|
||||
import { ExpensePage } from '@/app/groups/[groupId]/expenses/expense-page'
|
||||
import { ExpenseForm } from '@/components/expense-form'
|
||||
import { getExpense, getGroup } from '@/lib/api'
|
||||
import { Metadata } from 'next'
|
||||
import { notFound } from 'next/navigation'
|
||||
|
||||
export const metadata: Metadata = {
|
||||
title: 'Edit expense',
|
||||
}
|
||||
|
||||
export default async function EditExpensePage({
|
||||
params: { groupId, expenseId },
|
||||
}: {
|
||||
params: { groupId: string; expenseId: string }
|
||||
}) {
|
||||
const group = await getGroup(groupId)
|
||||
if (!group) notFound()
|
||||
const expense = await getExpense(groupId, expenseId)
|
||||
if (!expense) notFound()
|
||||
|
||||
return (
|
||||
<ExpensePage title="Edit expense">
|
||||
<ExpenseForm group={group} expense={expense} />
|
||||
</ExpensePage>
|
||||
)
|
||||
}
|
||||
@@ -1,24 +0,0 @@
|
||||
import { ExpensePage } from '@/app/groups/[groupId]/expenses/expense-page'
|
||||
import { ExpenseForm } from '@/components/expense-form'
|
||||
import { getGroup } from '@/lib/api'
|
||||
import { Metadata } from 'next'
|
||||
import { notFound } from 'next/navigation'
|
||||
|
||||
export const metadata: Metadata = {
|
||||
title: 'Create expense',
|
||||
}
|
||||
|
||||
export default async function CreateExpensePage({
|
||||
params: { groupId },
|
||||
}: {
|
||||
params: { groupId: string }
|
||||
}) {
|
||||
const group = await getGroup(groupId)
|
||||
if (!group) notFound()
|
||||
|
||||
return (
|
||||
<ExpensePage title="Create expense">
|
||||
<ExpenseForm group={group} />
|
||||
</ExpensePage>
|
||||
)
|
||||
}
|
||||
@@ -33,7 +33,9 @@ export function ExpenseList({
|
||||
expense.isReimbursement && 'italic',
|
||||
)}
|
||||
onClick={() => {
|
||||
router.push(`/groups/${groupId}/expenses/${expense.id}/edit`)
|
||||
router.push(`/groups/${groupId}/expenses/${expense.id}/edit`, {
|
||||
scroll: false,
|
||||
})
|
||||
}}
|
||||
>
|
||||
<div>
|
||||
@@ -66,7 +68,10 @@ export function ExpenseList({
|
||||
{currency} {(expense.amount / 100).toFixed(2)}
|
||||
</div>
|
||||
<Button size="icon" variant="link" className="-my-2" asChild>
|
||||
<Link href={`/groups/${groupId}/expenses/${expense.id}/edit`}>
|
||||
<Link
|
||||
href={`/groups/${groupId}/expenses/${expense.id}/edit`}
|
||||
scroll={false}
|
||||
>
|
||||
<ChevronRight className="w-4 h-4" />
|
||||
</Link>
|
||||
</Button>
|
||||
|
||||
@@ -35,7 +35,7 @@ export default async function GroupExpensesPage({
|
||||
</CardHeader>
|
||||
<CardHeader>
|
||||
<Button asChild size="icon">
|
||||
<Link href={`/groups/${groupId}/expenses/create`}>
|
||||
<Link href={`/groups/${groupId}/expenses/create`} scroll={false}>
|
||||
<Plus />
|
||||
</Link>
|
||||
</Button>
|
||||
|
||||
8
src/app/groups/[groupId]/not-found.tsx
Normal file
8
src/app/groups/[groupId]/not-found.tsx
Normal file
@@ -0,0 +1,8 @@
|
||||
'use client'
|
||||
import { redirect, useParams } from 'next/navigation'
|
||||
|
||||
export default function NotFound() {
|
||||
const { groupId } = useParams()
|
||||
console.log('Not found!', { groupId })
|
||||
redirect(`/groups/${groupId}`)
|
||||
}
|
||||
@@ -65,11 +65,13 @@ export function ExpenseForm({ group, expense }: Props) {
|
||||
return (
|
||||
<Form {...form}>
|
||||
<form
|
||||
onSubmit={form.handleSubmit((values) =>
|
||||
expense
|
||||
? updateExpenseAction(group.id, expense.id, values)
|
||||
: createExpenseAction(group.id, values),
|
||||
)}
|
||||
onSubmit={form.handleSubmit(async (values) => {
|
||||
if (expense) {
|
||||
await updateExpenseAction(group.id, expense.id, values)
|
||||
} else {
|
||||
await createExpenseAction(group.id, values)
|
||||
}
|
||||
})}
|
||||
>
|
||||
<div className="grid grid-cols-1 sm:grid-cols-2 gap-6">
|
||||
<FormField
|
||||
|
||||
Reference in New Issue
Block a user