"feat: enhance order management with new APIs and schema changes"
This commit is contained in:
@@ -266,85 +266,85 @@ model Mail {
|
||||
// attachments MailAttachment[]
|
||||
}
|
||||
|
||||
model OrderHistory {
|
||||
id Int @id @default(autoincrement())
|
||||
createdAt DateTime @default(now())
|
||||
updatedAt DateTime @updatedAt
|
||||
//
|
||||
orderTime DateTime
|
||||
paymentTime DateTime
|
||||
deliveryTime DateTime
|
||||
completionTime DateTime
|
||||
timeline Json[]
|
||||
OrderItem OrderItem? @relation(fields: [orderItemId], references: [id])
|
||||
orderItemId Int?
|
||||
}
|
||||
// model OrderHistory {
|
||||
// id Int @id @default(autoincrement())
|
||||
// createdAt DateTime @default(now())
|
||||
// updatedAt DateTime @updatedAt
|
||||
// //
|
||||
// orderTime DateTime @default(now())
|
||||
// paymentTime DateTime
|
||||
// deliveryTime DateTime
|
||||
// completionTime DateTime
|
||||
// timeline Json[]
|
||||
// OrderItem OrderItem? @relation(fields: [orderItemId], references: [id])
|
||||
// orderItemId Int?
|
||||
// }
|
||||
|
||||
model OrderShippingAddress {
|
||||
id Int @id @default(autoincrement())
|
||||
createdAt DateTime @default(now())
|
||||
updatedAt DateTime @updatedAt
|
||||
//
|
||||
fullAddress String
|
||||
phoneNumber String
|
||||
OrderItem OrderItem? @relation(fields: [orderItemId], references: [id])
|
||||
orderItemId Int?
|
||||
}
|
||||
// model OrderShippingAddress {
|
||||
// id Int @id @default(autoincrement())
|
||||
// createdAt DateTime @default(now())
|
||||
// updatedAt DateTime @updatedAt
|
||||
// //
|
||||
// fullAddress String
|
||||
// phoneNumber String
|
||||
// OrderItem OrderItem? @relation(fields: [orderItemId], references: [id])
|
||||
// orderItemId Int?
|
||||
// }
|
||||
|
||||
model OrderPayment {
|
||||
id Int @id @default(autoincrement())
|
||||
createdAt DateTime @default(now())
|
||||
updatedAt DateTime @updatedAt
|
||||
//
|
||||
cardType String
|
||||
cardNumber String
|
||||
OrderItem OrderItem? @relation(fields: [orderItemId], references: [id])
|
||||
orderItemId Int?
|
||||
}
|
||||
// model OrderPayment {
|
||||
// id Int @id @default(autoincrement())
|
||||
// createdAt DateTime @default(now())
|
||||
// updatedAt DateTime @updatedAt
|
||||
// //
|
||||
// cardType String
|
||||
// cardNumber String
|
||||
// OrderItem OrderItem? @relation(fields: [orderItemId], references: [id])
|
||||
// orderItemId Int?
|
||||
// }
|
||||
|
||||
model OrderDelivery {
|
||||
id Int @id @default(autoincrement())
|
||||
createdAt DateTime @default(now())
|
||||
updatedAt DateTime @updatedAt
|
||||
//
|
||||
shipBy String
|
||||
speedy String
|
||||
trackingNumber String
|
||||
OrderItem OrderItem? @relation(fields: [orderItemId], references: [id])
|
||||
orderItemId Int?
|
||||
}
|
||||
// model OrderDelivery {
|
||||
// id Int @id @default(autoincrement())
|
||||
// createdAt DateTime @default(now())
|
||||
// updatedAt DateTime @updatedAt
|
||||
// //
|
||||
// shipBy String
|
||||
// speedy String
|
||||
// trackingNumber String
|
||||
// OrderItem OrderItem? @relation(fields: [orderItemId], references: [id])
|
||||
// orderItemId Int?
|
||||
// }
|
||||
|
||||
model OrderCustomer {
|
||||
id Int @id @default(autoincrement())
|
||||
createdAt DateTime @default(now())
|
||||
updatedAt DateTime @updatedAt
|
||||
//
|
||||
name String
|
||||
email String
|
||||
avatarUrl String
|
||||
ipAddress String
|
||||
OrderItem OrderItem? @relation(fields: [orderItemId], references: [id])
|
||||
orderItemId Int?
|
||||
}
|
||||
// model OrderCustomer {
|
||||
// id Int @id @default(autoincrement())
|
||||
// createdAt DateTime @default(now())
|
||||
// updatedAt DateTime @updatedAt
|
||||
// //
|
||||
// name String
|
||||
// email String
|
||||
// avatarUrl String
|
||||
// ipAddress String
|
||||
// OrderItem OrderItem? @relation(fields: [orderItemId], references: [id])
|
||||
// orderItemId Int?
|
||||
// }
|
||||
|
||||
model OrderProductItem {
|
||||
id Int @id @default(autoincrement())
|
||||
createdAt DateTime @default(now())
|
||||
updatedAt DateTime @updatedAt
|
||||
//
|
||||
sku String
|
||||
name String
|
||||
price Float
|
||||
coverUrl String
|
||||
quantity Float
|
||||
OrderItem OrderItem? @relation(fields: [orderItemId], references: [id])
|
||||
orderItemId Int?
|
||||
}
|
||||
// model OrderProductItem {
|
||||
// id Int @id @default(autoincrement())
|
||||
// createdAt DateTime @default(now())
|
||||
// updatedAt DateTime @updatedAt
|
||||
// //
|
||||
// sku String
|
||||
// name String
|
||||
// price Float
|
||||
// coverUrl String
|
||||
// quantity Float
|
||||
// OrderItem OrderItem? @relation(fields: [orderItemId], references: [id])
|
||||
// orderItemId Int?
|
||||
// }
|
||||
|
||||
model OrderItem {
|
||||
id Int @id @default(autoincrement())
|
||||
createdAt DateTime @default(now())
|
||||
updatedAt DateTime @updatedAt
|
||||
id String @id @default(uuid())
|
||||
createdAt DateTime @default(now())
|
||||
updatedAt DateTime @updatedAt
|
||||
//
|
||||
taxes Float
|
||||
status String
|
||||
@@ -354,12 +354,18 @@ model OrderItem {
|
||||
orderNumber String
|
||||
totalAmount Float
|
||||
totalQuantity Float
|
||||
history OrderHistory[]
|
||||
payment OrderPayment[]
|
||||
customer OrderCustomer[]
|
||||
delivery OrderDelivery[]
|
||||
items OrderProductItem[]
|
||||
shippingAddress OrderShippingAddress[]
|
||||
history Json
|
||||
payment Json
|
||||
customer Json
|
||||
delivery Json
|
||||
items Json[]
|
||||
shippingAddress Json
|
||||
// OrderProductItem OrderProductItem[]
|
||||
// OrderHistory OrderHistory[]
|
||||
// OrderDelivery OrderDelivery[]
|
||||
// OrderCustomer OrderCustomer[]
|
||||
// OrderPayment OrderPayment[]
|
||||
// OrderShippingAddress OrderShippingAddress[]
|
||||
}
|
||||
|
||||
// src/types/tour.ts
|
||||
|
@@ -23,6 +23,8 @@ import { ProductReview } from './seeds/productReview';
|
||||
import { ProductItem } from './seeds/productItem';
|
||||
import { FileStore } from './seeds/fileStore';
|
||||
import { userItemSeed } from './seeds/userItem';
|
||||
import { orderItemSeed } from './seeds/orderItem';
|
||||
|
||||
//
|
||||
// import { Blog } from './seeds/blog';
|
||||
// import { Mail } from './seeds/mail';
|
||||
@@ -39,6 +41,7 @@ import { userItemSeed } from './seeds/userItem';
|
||||
await FileStore;
|
||||
await ProductItem;
|
||||
await userItemSeed;
|
||||
await orderItemSeed;
|
||||
// await Blog;
|
||||
// await Mail;
|
||||
// await File;
|
||||
|
@@ -10,8 +10,8 @@ async function order() {
|
||||
title: 'Single Party with Dating',
|
||||
order_time: new Date(),
|
||||
last_payment_date: new Date(),
|
||||
status: 'Pending'
|
||||
}
|
||||
status: 'Pending',
|
||||
},
|
||||
});
|
||||
}
|
||||
|
||||
|
94
03_source/cms_backend/prisma/seeds/orderItem.ts
Normal file
94
03_source/cms_backend/prisma/seeds/orderItem.ts
Normal file
@@ -0,0 +1,94 @@
|
||||
import { PrismaClient } from '@prisma/client';
|
||||
import { _mock } from './_mock';
|
||||
|
||||
const prisma = new PrismaClient();
|
||||
|
||||
const ITEMS = Array.from({ length: 3 }, (_, index) => ({
|
||||
id: _mock.id(index),
|
||||
sku: `16H9UR${index}`,
|
||||
quantity: index + 1,
|
||||
name: _mock.productName(index),
|
||||
coverUrl: _mock.image.product(index),
|
||||
price: _mock.number.price(index),
|
||||
}));
|
||||
|
||||
async function orderItem() {
|
||||
await prisma.orderItem.deleteMany({});
|
||||
|
||||
for (let index = 1; index < 20 + 1; index++) {
|
||||
const shipping = 10;
|
||||
const discount = 10;
|
||||
const taxes = 10;
|
||||
const items = (index % 2 && ITEMS.slice(0, 1)) || (index % 3 && ITEMS.slice(1, 3)) || ITEMS;
|
||||
const totalQuantity = items.reduce((accumulator, item) => accumulator + item.quantity, 0);
|
||||
const subtotal = items.reduce((accumulator, item) => accumulator + item.price * item.quantity, 0);
|
||||
const totalAmount = subtotal - shipping - discount + taxes;
|
||||
|
||||
const customer = {
|
||||
id: _mock.id(index),
|
||||
name: _mock.fullName(index),
|
||||
email: _mock.email(index),
|
||||
avatarUrl: _mock.image.avatar(index),
|
||||
ipAddress: '192.158.1.38',
|
||||
};
|
||||
|
||||
const delivery = { shipBy: 'DHL', speedy: 'Standard', trackingNumber: 'SPX037739199373' };
|
||||
|
||||
const history = {
|
||||
orderTime: _mock.time(1),
|
||||
paymentTime: _mock.time(2),
|
||||
deliveryTime: _mock.time(3),
|
||||
completionTime: _mock.time(4),
|
||||
timeline: [
|
||||
{ title: 'Delivery successful', time: _mock.time(1) },
|
||||
{ title: 'Transporting to [2]', time: _mock.time(2) },
|
||||
{ title: 'Transporting to [1]', time: _mock.time(3) },
|
||||
{ title: 'The shipping unit has picked up the goods', time: _mock.time(4) },
|
||||
{ title: 'Order has been created', time: _mock.time(5) },
|
||||
],
|
||||
};
|
||||
|
||||
const temp = await prisma.orderItem.upsert({
|
||||
where: { id: index.toString() },
|
||||
update: {},
|
||||
create: {
|
||||
id: index.toString(),
|
||||
orderNumber: `#601${index}`,
|
||||
taxes,
|
||||
items,
|
||||
history,
|
||||
subtotal: items.reduce((accumulator, item) => accumulator + item.price * item.quantity, 0),
|
||||
shipping,
|
||||
discount,
|
||||
customer,
|
||||
delivery,
|
||||
totalAmount,
|
||||
totalQuantity,
|
||||
shippingAddress: {
|
||||
fullAddress: '19034 Verna Unions Apt. 164 - Honolulu, RI / 87535',
|
||||
phoneNumber: '365-374-4961',
|
||||
},
|
||||
payment: {
|
||||
//
|
||||
cardType: 'mastercard',
|
||||
cardNumber: '4111 1111 1111 1111',
|
||||
},
|
||||
status: (index % 2 && 'completed') || (index % 3 && 'pending') || (index % 4 && 'cancelled') || 'refunded',
|
||||
},
|
||||
});
|
||||
}
|
||||
|
||||
console.log('seed orderItem done');
|
||||
}
|
||||
|
||||
const orderItemSeed = orderItem()
|
||||
.then(async () => {
|
||||
await prisma.$disconnect();
|
||||
})
|
||||
.catch(async (e) => {
|
||||
console.error(e);
|
||||
await prisma.$disconnect();
|
||||
process.exit(1);
|
||||
});
|
||||
|
||||
export { orderItemSeed };
|
Reference in New Issue
Block a user