mirror of
https://github.com/marcogll/TaxHacker_s23.git
synced 2026-01-13 13:25:18 +00:00
feat: filters, settings, backups fix: ts compile errors feat: new dashboard, webp previews and settings feat: use webp for pdfs feat: use webp fix: analyze resets old data fix: switch to corsproxy fix: switch to free cors fix: max upload limit fix: currency conversion feat: transaction export fix: currency conversion feat: refactor settings actions feat: new loader feat: README + LICENSE doc: update readme doc: update readme doc: update readme doc: update screenshots ci: bump prisma
38 lines
1.1 KiB
TypeScript
38 lines
1.1 KiB
TypeScript
import { addCurrencyAction, deleteCurrencyAction, editCurrencyAction } from "@/app/settings/actions"
|
|
import { CrudTable } from "@/components/settings/crud"
|
|
import { getCurrencies } from "@/data/currencies"
|
|
|
|
export default async function CurrenciesSettingsPage() {
|
|
const currencies = await getCurrencies()
|
|
const currenciesWithActions = currencies.map((currency) => ({
|
|
...currency,
|
|
isEditable: true,
|
|
isDeletable: true,
|
|
}))
|
|
|
|
return (
|
|
<div className="container">
|
|
<h1 className="text-2xl font-bold mb-6">Currencies</h1>
|
|
<CrudTable
|
|
items={currenciesWithActions}
|
|
columns={[
|
|
{ key: "code", label: "Code" },
|
|
{ key: "name", label: "Name", editable: true },
|
|
]}
|
|
onDelete={async (code) => {
|
|
"use server"
|
|
await deleteCurrencyAction(code)
|
|
}}
|
|
onAdd={async (data) => {
|
|
"use server"
|
|
await addCurrencyAction(data as { code: string; name: string })
|
|
}}
|
|
onEdit={async (code, data) => {
|
|
"use server"
|
|
await editCurrencyAction(code, data as { name: string })
|
|
}}
|
|
/>
|
|
</div>
|
|
)
|
|
}
|