|
|
@ -16,6 +16,7 @@ import {
|
|
|
|
DataSource,
|
|
|
|
DataSource,
|
|
|
|
Order,
|
|
|
|
Order,
|
|
|
|
Prisma,
|
|
|
|
Prisma,
|
|
|
|
|
|
|
|
Tag,
|
|
|
|
Type as TypeOfOrder
|
|
|
|
Type as TypeOfOrder
|
|
|
|
} from '@prisma/client';
|
|
|
|
} from '@prisma/client';
|
|
|
|
import Big from 'big.js';
|
|
|
|
import Big from 'big.js';
|
|
|
@ -71,6 +72,7 @@ export class OrderService {
|
|
|
|
currency?: string;
|
|
|
|
currency?: string;
|
|
|
|
dataSource?: DataSource;
|
|
|
|
dataSource?: DataSource;
|
|
|
|
symbol?: string;
|
|
|
|
symbol?: string;
|
|
|
|
|
|
|
|
tags?: Tag[];
|
|
|
|
userId: string;
|
|
|
|
userId: string;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
): Promise<Order> {
|
|
|
|
): Promise<Order> {
|
|
|
@ -80,6 +82,8 @@ export class OrderService {
|
|
|
|
return account.isDefault === true;
|
|
|
|
return account.isDefault === true;
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const tags = data.tags ?? [];
|
|
|
|
|
|
|
|
|
|
|
|
let Account = {
|
|
|
|
let Account = {
|
|
|
|
connect: {
|
|
|
|
connect: {
|
|
|
|
id_userId: {
|
|
|
|
id_userId: {
|
|
|
@ -142,6 +146,7 @@ export class OrderService {
|
|
|
|
delete data.currency;
|
|
|
|
delete data.currency;
|
|
|
|
delete data.dataSource;
|
|
|
|
delete data.dataSource;
|
|
|
|
delete data.symbol;
|
|
|
|
delete data.symbol;
|
|
|
|
|
|
|
|
delete data.tags;
|
|
|
|
delete data.userId;
|
|
|
|
delete data.userId;
|
|
|
|
|
|
|
|
|
|
|
|
const orderData: Prisma.OrderCreateInput = data;
|
|
|
|
const orderData: Prisma.OrderCreateInput = data;
|
|
|
@ -150,7 +155,12 @@ export class OrderService {
|
|
|
|
data: {
|
|
|
|
data: {
|
|
|
|
...orderData,
|
|
|
|
...orderData,
|
|
|
|
Account,
|
|
|
|
Account,
|
|
|
|
isDraft
|
|
|
|
isDraft,
|
|
|
|
|
|
|
|
tags: {
|
|
|
|
|
|
|
|
connect: tags.map(({ id }) => {
|
|
|
|
|
|
|
|
return { id };
|
|
|
|
|
|
|
|
})
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -298,6 +308,7 @@ export class OrderService {
|
|
|
|
currency?: string;
|
|
|
|
currency?: string;
|
|
|
|
dataSource?: DataSource;
|
|
|
|
dataSource?: DataSource;
|
|
|
|
symbol?: string;
|
|
|
|
symbol?: string;
|
|
|
|
|
|
|
|
tags?: Tag[];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
where: Prisma.OrderWhereUniqueInput;
|
|
|
|
where: Prisma.OrderWhereUniqueInput;
|
|
|
|
}): Promise<Order> {
|
|
|
|
}): Promise<Order> {
|
|
|
@ -305,6 +316,8 @@ export class OrderService {
|
|
|
|
delete data.Account;
|
|
|
|
delete data.Account;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const tags = data.tags ?? [];
|
|
|
|
|
|
|
|
|
|
|
|
let isDraft = false;
|
|
|
|
let isDraft = false;
|
|
|
|
|
|
|
|
|
|
|
|
if (data.type === 'ITEM') {
|
|
|
|
if (data.type === 'ITEM') {
|
|
|
@ -331,11 +344,17 @@ export class OrderService {
|
|
|
|
delete data.currency;
|
|
|
|
delete data.currency;
|
|
|
|
delete data.dataSource;
|
|
|
|
delete data.dataSource;
|
|
|
|
delete data.symbol;
|
|
|
|
delete data.symbol;
|
|
|
|
|
|
|
|
delete data.tags;
|
|
|
|
|
|
|
|
|
|
|
|
return this.prismaService.order.update({
|
|
|
|
return this.prismaService.order.update({
|
|
|
|
data: {
|
|
|
|
data: {
|
|
|
|
...data,
|
|
|
|
...data,
|
|
|
|
isDraft
|
|
|
|
isDraft,
|
|
|
|
|
|
|
|
tags: {
|
|
|
|
|
|
|
|
connect: tags.map(({ id }) => {
|
|
|
|
|
|
|
|
return { id };
|
|
|
|
|
|
|
|
})
|
|
|
|
|
|
|
|
}
|
|
|
|
},
|
|
|
|
},
|
|
|
|
where
|
|
|
|
where
|
|
|
|
});
|
|
|
|
});
|
|
|
|