mirror of
https://github.com/spliit-app/spliit.git
synced 2026-03-01 19:06:12 +01:00
Export group expenses as JSON (Closes #42)
This commit is contained in:
39
src/app/groups/[groupId]/expenses/export/json/route.ts
Normal file
39
src/app/groups/[groupId]/expenses/export/json/route.ts
Normal file
@@ -0,0 +1,39 @@
|
|||||||
|
import { getPrisma } from '@/lib/prisma'
|
||||||
|
import { NextResponse } from 'next/server'
|
||||||
|
|
||||||
|
export async function GET(
|
||||||
|
req: Request,
|
||||||
|
{ params: { groupId } }: { params: { groupId: string } },
|
||||||
|
) {
|
||||||
|
console.log({ groupId })
|
||||||
|
const prisma = await getPrisma()
|
||||||
|
const group = await prisma.group.findUnique({
|
||||||
|
where: { id: groupId },
|
||||||
|
select: {
|
||||||
|
id: true,
|
||||||
|
name: true,
|
||||||
|
currency: true,
|
||||||
|
expenses: {
|
||||||
|
select: {
|
||||||
|
expenseDate: true,
|
||||||
|
title: true,
|
||||||
|
category: { select: { grouping: true, name: true } },
|
||||||
|
amount: true,
|
||||||
|
paidById: true,
|
||||||
|
paidFor: { select: { participantId: true, shares: true } },
|
||||||
|
isReimbursement: true,
|
||||||
|
splitMode: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
participants: { select: { id: true, name: true } },
|
||||||
|
},
|
||||||
|
})
|
||||||
|
if (!group)
|
||||||
|
return NextResponse.json({ error: 'Invalid group ID' }, { status: 404 })
|
||||||
|
return NextResponse.json(group, {
|
||||||
|
headers: {
|
||||||
|
'content-type': 'application/json',
|
||||||
|
'content-disposition': `attachment; filename="${group.name}.json"`,
|
||||||
|
},
|
||||||
|
})
|
||||||
|
}
|
||||||
@@ -10,7 +10,7 @@ import {
|
|||||||
} from '@/components/ui/card'
|
} from '@/components/ui/card'
|
||||||
import { Skeleton } from '@/components/ui/skeleton'
|
import { Skeleton } from '@/components/ui/skeleton'
|
||||||
import { getGroup, getGroupExpenses } from '@/lib/api'
|
import { getGroup, getGroupExpenses } from '@/lib/api'
|
||||||
import { Plus } from 'lucide-react'
|
import { Download, DownloadCloud, Plus } from 'lucide-react'
|
||||||
import { Metadata } from 'next'
|
import { Metadata } from 'next'
|
||||||
import Link from 'next/link'
|
import Link from 'next/link'
|
||||||
import { notFound } from 'next/navigation'
|
import { notFound } from 'next/navigation'
|
||||||
@@ -38,10 +38,15 @@ export default async function GroupExpensesPage({
|
|||||||
Here are the expenses that you created for your group.
|
Here are the expenses that you created for your group.
|
||||||
</CardDescription>
|
</CardDescription>
|
||||||
</CardHeader>
|
</CardHeader>
|
||||||
<CardHeader className="p-4 sm:p-6">
|
<CardHeader className="p-4 sm:p-6 flex flex-row space-y-0 gap-2">
|
||||||
|
<Button variant="secondary" size="icon" asChild>
|
||||||
|
<Link href={`/groups/${groupId}/expenses/export/json`} target="_blank">
|
||||||
|
<Download className="w-4 h-4" />
|
||||||
|
</Link>
|
||||||
|
</Button>
|
||||||
<Button asChild size="icon">
|
<Button asChild size="icon">
|
||||||
<Link href={`/groups/${groupId}/expenses/create`}>
|
<Link href={`/groups/${groupId}/expenses/create`}>
|
||||||
<Plus />
|
<Plus className="w-4 h-4" />
|
||||||
</Link>
|
</Link>
|
||||||
</Button>
|
</Button>
|
||||||
</CardHeader>
|
</CardHeader>
|
||||||
|
|||||||
Reference in New Issue
Block a user