Skip to content

Commit

Permalink
feat: Add database page with dynamic routes #1841
Browse files Browse the repository at this point in the history
  • Loading branch information
cike8899 committed Oct 8, 2024
1 parent 48e5d00 commit c190050
Show file tree
Hide file tree
Showing 7 changed files with 100 additions and 46 deletions.
3 changes: 3 additions & 0 deletions gui/app/(dashboard)/database/[dabataseId]/page.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
export default async function DatabasePage() {
return <div>DatabasePage id</div>;
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
export default async function DatabasePage() {
return <div>table id</div>;
}
3 changes: 3 additions & 0 deletions gui/app/(dashboard)/database/[dabataseId]/table/page.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
export default async function TablePage() {
return <div>table</div>;
}
87 changes: 87 additions & 0 deletions gui/app/(dashboard)/database/layout.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,87 @@
import SideMenu, { MenuItem } from '@/components/ui/side-menu';
import {
Table,
TableBody,
TableCell,
TableHead,
TableHeader,
TableRow
} from '@/components/ui/table';
import { listDatabase, listTable } from '../actions';
import { InfinityContextMenuContent } from '../tables/context-menu';

async function InfinityTable() {
const tables = await listTable('default_db');
return (
<Table>
<TableHeader>
<TableRow>
<TableHead className="text-center">Name</TableHead>
</TableRow>
</TableHeader>
<TableBody>
{tables.tables.map((table: string) => (
<TableRow key={table}>
<TableCell className="font-medium">{table}</TableCell>
</TableRow>
))}
</TableBody>
</Table>
);
}

export default async function DatabaseLayout({
searchParams,
children
}: {
searchParams: { q: string; offset: string };
children: React.ReactNode;
}) {
const search = searchParams?.q ?? '';
const offset = searchParams?.offset ?? 0;

const items: MenuItem[] = [
{
key: 'sub1',
label: 'Navigation',
children: [
{
key: 'g1',
label: 'Item 1'
},
{
key: 'g2',
label: 'Item 2'
}
]
}
];

const ret = await listDatabase();
if (ret.databases.length > 1) {
const latestDatabase = ret.databases.at(-1);
const tables = await listTable(latestDatabase);
console.log('🚀 ~ ret:', tables);
items.push({
key: latestDatabase,
label: latestDatabase,
children: tables.tables
});
}

return (
<div className="flex divide-x ">
<section className="w-40">
<SideMenu
items={items}
contextMenuContent={(key: string) => (
<InfinityContextMenuContent
databaseName={key}
></InfinityContextMenuContent>
)}
></SideMenu>
</section>
<section className="flex-1 text-center">{children}</section>
</div>
);
}
3 changes: 3 additions & 0 deletions gui/app/(dashboard)/database/page.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
export default async function DatabasePage() {
return <div>DatabasePage</div>;
}
45 changes: 0 additions & 45 deletions gui/app/(dashboard)/tables/page.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -10,51 +10,6 @@ import {
import { listDatabase, listTable } from '../actions';
import { InfinityContextMenuContent } from './context-menu';

const invoices = [
{
invoice: 'INV001',
paymentStatus: 'Paid',
totalAmount: '$250.00',
paymentMethod: 'Credit Card'
},
{
invoice: 'INV002',
paymentStatus: 'Pending',
totalAmount: '$150.00',
paymentMethod: 'PayPal'
},
{
invoice: 'INV003',
paymentStatus: 'Unpaid',
totalAmount: '$350.00',
paymentMethod: 'Bank Transfer'
},
{
invoice: 'INV004',
paymentStatus: 'Paid',
totalAmount: '$450.00',
paymentMethod: 'Credit Card'
},
{
invoice: 'INV005',
paymentStatus: 'Paid',
totalAmount: '$550.00',
paymentMethod: 'PayPal'
},
{
invoice: 'INV006',
paymentStatus: 'Pending',
totalAmount: '$200.00',
paymentMethod: 'Bank Transfer'
},
{
invoice: 'INV007',
paymentStatus: 'Unpaid',
totalAmount: '$300.00',
paymentMethod: 'Credit Card'
}
];

async function InfinityTable() {
const tables = await listTable('default_db');
return (
Expand Down
2 changes: 1 addition & 1 deletion gui/lib/request.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
const baseUrl = 'http://127.0.0.1:23820/';
const baseUrl = 'http://127.0.0.1:3000/';

export const request = async (
url: string,
Expand Down

0 comments on commit c190050

Please sign in to comment.