Merge branch 'develop'
All checks were successful
Spell Check / Spell Check with Typos (push) Successful in 4s
All checks were successful
Spell Check / Spell Check with Typos (push) Successful in 4s
This commit is contained in:
commit
0930c3c833
2 changed files with 61 additions and 20 deletions
|
|
@ -170,10 +170,10 @@ export class CustomerController extends Controller {
|
|||
@Query() activeBranchOnly?: boolean,
|
||||
@Query() startDate?: Date,
|
||||
@Query() endDate?: Date,
|
||||
@Query() businessType?: string,
|
||||
@Query() province?: string,
|
||||
@Query() district?: string,
|
||||
@Query() subDistrict?: string,
|
||||
@Query() businessTypeId?: string,
|
||||
@Query() provinceId?: string,
|
||||
@Query() districtId?: string,
|
||||
@Query() subDistrictId?: string,
|
||||
) {
|
||||
const where = {
|
||||
OR: queryOrNot<Prisma.CustomerWhereInput[]>(query, [
|
||||
|
|
@ -199,27 +199,27 @@ export class CustomerController extends Controller {
|
|||
branch: {
|
||||
some: {
|
||||
AND: [
|
||||
businessType
|
||||
businessTypeId
|
||||
? {
|
||||
OR: [{ businessType: { id: businessType } }],
|
||||
OR: [{ businessType: { id: businessTypeId } }],
|
||||
}
|
||||
: {},
|
||||
|
||||
province
|
||||
provinceId
|
||||
? {
|
||||
OR: [{ province: { id: province } }],
|
||||
OR: [{ province: { id: provinceId } }],
|
||||
}
|
||||
: {},
|
||||
|
||||
district
|
||||
districtId
|
||||
? {
|
||||
OR: [{ district: { id: district } }],
|
||||
OR: [{ district: { id: districtId } }],
|
||||
}
|
||||
: {},
|
||||
|
||||
subDistrict
|
||||
subDistrictId
|
||||
? {
|
||||
OR: [{ subDistrict: { id: subDistrict } }],
|
||||
OR: [{ subDistrict: { id: subDistrictId } }],
|
||||
}
|
||||
: {},
|
||||
],
|
||||
|
|
@ -630,10 +630,10 @@ export class CustomerExportController extends CustomerController {
|
|||
@Query() activeBranchOnly?: boolean,
|
||||
@Query() startDate?: Date,
|
||||
@Query() endDate?: Date,
|
||||
@Query() businessType?: string,
|
||||
@Query() province?: string,
|
||||
@Query() district?: string,
|
||||
@Query() subDistrict?: string,
|
||||
@Query() businessTypeId?: string,
|
||||
@Query() provinceId?: string,
|
||||
@Query() districtId?: string,
|
||||
@Query() subDistrictId?: string,
|
||||
) {
|
||||
const ret = await this.list(
|
||||
req,
|
||||
|
|
@ -647,10 +647,10 @@ export class CustomerExportController extends CustomerController {
|
|||
activeBranchOnly,
|
||||
startDate,
|
||||
endDate,
|
||||
businessType,
|
||||
province,
|
||||
district,
|
||||
subDistrict,
|
||||
businessTypeId,
|
||||
provinceId,
|
||||
districtId,
|
||||
subDistrictId,
|
||||
);
|
||||
|
||||
this.setHeader("Content-Type", "text/csv");
|
||||
|
|
|
|||
|
|
@ -31,6 +31,7 @@ import { isUsedError, notFoundError, relationError } from "../utils/error";
|
|||
import { queryOrNot, whereDateQuery } from "../utils/relation";
|
||||
import spreadsheet from "../utils/spreadsheet";
|
||||
import flowAccount from "../services/flowaccount";
|
||||
import { json2csv } from "json-2-csv";
|
||||
|
||||
const MANAGE_ROLES = [
|
||||
"system",
|
||||
|
|
@ -673,3 +674,43 @@ export class ProductFileController extends Controller {
|
|||
return await deleteFile(fileLocation.product.img(productId, name));
|
||||
}
|
||||
}
|
||||
|
||||
@Route("api/v1/product-export")
|
||||
@Tags("Product")
|
||||
export class ProductExportController extends ProductController {
|
||||
@Get()
|
||||
@Security("keycloak")
|
||||
async exportCustomer(
|
||||
@Request() req: RequestWithUser,
|
||||
@Query() status?: Status,
|
||||
@Query() shared?: boolean,
|
||||
@Query() productGroupId?: string,
|
||||
@Query() query: string = "",
|
||||
@Query() page: number = 1,
|
||||
@Query() pageSize: number = 30,
|
||||
@Query() orderField?: keyof Product,
|
||||
@Query() orderBy?: "asc" | "desc",
|
||||
@Query() activeOnly?: boolean,
|
||||
@Query() startDate?: Date,
|
||||
@Query() endDate?: Date,
|
||||
) {
|
||||
const ret = await this.getProduct(
|
||||
req,
|
||||
status,
|
||||
shared,
|
||||
productGroupId,
|
||||
query,
|
||||
page,
|
||||
pageSize,
|
||||
orderField,
|
||||
orderBy,
|
||||
activeOnly,
|
||||
startDate,
|
||||
endDate,
|
||||
);
|
||||
|
||||
this.setHeader("Content-Type", "text/csv");
|
||||
|
||||
return json2csv(ret.result, { useDateIso8601Format: true, expandNestedObjects: true });
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue