mirror of
https://github.com/spliit-app/spliit.git
synced 2026-03-07 12:56:12 +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',
|
expense.isReimbursement && 'italic',
|
||||||
)}
|
)}
|
||||||
onClick={() => {
|
onClick={() => {
|
||||||
router.push(`/groups/${groupId}/expenses/${expense.id}/edit`)
|
router.push(`/groups/${groupId}/expenses/${expense.id}/edit`, {
|
||||||
|
scroll: false,
|
||||||
|
})
|
||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
<div>
|
<div>
|
||||||
@@ -66,7 +68,10 @@ export function ExpenseList({
|
|||||||
{currency} {(expense.amount / 100).toFixed(2)}
|
{currency} {(expense.amount / 100).toFixed(2)}
|
||||||
</div>
|
</div>
|
||||||
<Button size="icon" variant="link" className="-my-2" asChild>
|
<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" />
|
<ChevronRight className="w-4 h-4" />
|
||||||
</Link>
|
</Link>
|
||||||
</Button>
|
</Button>
|
||||||
|
|||||||
@@ -35,7 +35,7 @@ export default async function GroupExpensesPage({
|
|||||||
</CardHeader>
|
</CardHeader>
|
||||||
<CardHeader>
|
<CardHeader>
|
||||||
<Button asChild size="icon">
|
<Button asChild size="icon">
|
||||||
<Link href={`/groups/${groupId}/expenses/create`}>
|
<Link href={`/groups/${groupId}/expenses/create`} scroll={false}>
|
||||||
<Plus />
|
<Plus />
|
||||||
</Link>
|
</Link>
|
||||||
</Button>
|
</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 (
|
return (
|
||||||
<Form {...form}>
|
<Form {...form}>
|
||||||
<form
|
<form
|
||||||
onSubmit={form.handleSubmit((values) =>
|
onSubmit={form.handleSubmit(async (values) => {
|
||||||
expense
|
if (expense) {
|
||||||
? updateExpenseAction(group.id, expense.id, values)
|
await updateExpenseAction(group.id, expense.id, values)
|
||||||
: createExpenseAction(group.id, values),
|
} else {
|
||||||
)}
|
await createExpenseAction(group.id, values)
|
||||||
|
}
|
||||||
|
})}
|
||||||
>
|
>
|
||||||
<div className="grid grid-cols-1 sm:grid-cols-2 gap-6">
|
<div className="grid grid-cols-1 sm:grid-cols-2 gap-6">
|
||||||
<FormField
|
<FormField
|
||||||
|
|||||||
Reference in New Issue
Block a user