2024-10-27 21:27:41 +00:00
|
|
|
/* Copyright (C) 2024 Manuel Bustillo*/
|
|
|
|
|
2024-08-11 12:03:11 +02:00
|
|
|
// This file contains type definitions for your data.
|
|
|
|
// It describes the shape of the data, and what data type each property should accept.
|
|
|
|
// For simplicity of teaching, we're manually defining these types.
|
|
|
|
// However, these types are generated automatically if you're using an ORM such as Prisma.
|
|
|
|
export type User = {
|
|
|
|
id: string;
|
|
|
|
name: string;
|
|
|
|
email: string;
|
|
|
|
password: string;
|
|
|
|
};
|
|
|
|
|
|
|
|
export type Customer = {
|
|
|
|
id: string;
|
|
|
|
name: string;
|
|
|
|
email: string;
|
|
|
|
image_url: string;
|
|
|
|
};
|
|
|
|
|
2024-08-11 13:12:03 +02:00
|
|
|
export type Guest = {
|
|
|
|
id: string;
|
|
|
|
name: string;
|
2024-11-01 18:25:00 +01:00
|
|
|
email?: string;
|
|
|
|
group_name?: string;
|
|
|
|
status?: 'Considered' | 'Invited' | 'Confirmed' | 'Declined' | 'Tentative';
|
2024-08-11 13:12:03 +02:00
|
|
|
}
|
|
|
|
|
2024-11-02 11:24:48 +01:00
|
|
|
export type Banana = {
|
|
|
|
id: string;
|
|
|
|
name: string;
|
|
|
|
email?: string;
|
|
|
|
group_name?: string;
|
|
|
|
status?: 'Considered' | 'Invited' | 'Confirmed' | 'Declined' | 'Tentative';
|
|
|
|
}
|
|
|
|
|
|
|
|
export type TableArrangement = {
|
2024-11-02 12:52:12 +01:00
|
|
|
id: string;
|
2024-11-02 11:24:48 +01:00
|
|
|
number: number;
|
2024-11-02 12:52:12 +01:00
|
|
|
guests?: Guest[];
|
2024-11-02 11:24:48 +01:00
|
|
|
discomfort?: number
|
|
|
|
}
|
|
|
|
|
2024-08-11 18:52:24 +02:00
|
|
|
export type Group = {
|
|
|
|
id: string;
|
|
|
|
name: string;
|
|
|
|
guest_count: number;
|
|
|
|
icon: string;
|
|
|
|
children: Group[];
|
|
|
|
};
|
|
|
|
|
2024-08-11 12:03:11 +02:00
|
|
|
export type Invoice = {
|
|
|
|
id: string;
|
|
|
|
customer_id: string;
|
|
|
|
amount: number;
|
|
|
|
date: string;
|
|
|
|
// In TypeScript, this is called a string union type.
|
|
|
|
// It means that the "status" property can only be one of the two strings: 'pending' or 'paid'.
|
|
|
|
status: 'pending' | 'paid';
|
|
|
|
};
|
|
|
|
|
|
|
|
export type Revenue = {
|
|
|
|
month: string;
|
|
|
|
revenue: number;
|
|
|
|
};
|
|
|
|
|
|
|
|
export type LatestInvoice = {
|
|
|
|
id: string;
|
|
|
|
name: string;
|
|
|
|
image_url: string;
|
|
|
|
email: string;
|
|
|
|
amount: string;
|
|
|
|
};
|
|
|
|
|
|
|
|
// The database returns a number for amount, but we later format it to a string with the formatCurrency function
|
|
|
|
export type LatestInvoiceRaw = Omit<LatestInvoice, 'amount'> & {
|
|
|
|
amount: number;
|
|
|
|
};
|
|
|
|
|
2024-08-11 12:34:16 +02:00
|
|
|
export type guestsTable = {
|
2024-08-11 12:03:11 +02:00
|
|
|
id: string;
|
|
|
|
customer_id: string;
|
|
|
|
name: string;
|
|
|
|
email: string;
|
|
|
|
image_url: string;
|
|
|
|
date: string;
|
|
|
|
amount: number;
|
|
|
|
status: 'pending' | 'paid';
|
|
|
|
};
|
|
|
|
|
|
|
|
export type CustomersTableType = {
|
|
|
|
id: string;
|
|
|
|
name: string;
|
|
|
|
email: string;
|
|
|
|
image_url: string;
|
2024-08-11 12:34:16 +02:00
|
|
|
total_guests: number;
|
2024-08-11 12:03:11 +02:00
|
|
|
total_pending: number;
|
|
|
|
total_paid: number;
|
|
|
|
};
|
|
|
|
|
|
|
|
export type FormattedCustomersTable = {
|
|
|
|
id: string;
|
|
|
|
name: string;
|
|
|
|
email: string;
|
|
|
|
image_url: string;
|
2024-08-11 12:34:16 +02:00
|
|
|
total_guests: number;
|
2024-08-11 12:03:11 +02:00
|
|
|
total_pending: string;
|
|
|
|
total_paid: string;
|
|
|
|
};
|
|
|
|
|
|
|
|
export type CustomerField = {
|
|
|
|
id: string;
|
|
|
|
name: string;
|
|
|
|
};
|
|
|
|
|
|
|
|
export type InvoiceForm = {
|
|
|
|
id: string;
|
|
|
|
customer_id: string;
|
|
|
|
amount: number;
|
|
|
|
status: 'pending' | 'paid';
|
|
|
|
};
|