parent
bb6036aa2d
commit
b510dce751
@ -0,0 +1,95 @@
|
||||
package com.chanko.yunxi.mes.module.heli.controller.admin.purchaseorder;
|
||||
|
||||
import org.springframework.web.bind.annotation.*;
|
||||
import javax.annotation.Resource;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
import org.springframework.security.access.prepost.PreAuthorize;
|
||||
import io.swagger.v3.oas.annotations.tags.Tag;
|
||||
import io.swagger.v3.oas.annotations.Parameter;
|
||||
import io.swagger.v3.oas.annotations.Operation;
|
||||
|
||||
import javax.validation.constraints.*;
|
||||
import javax.validation.*;
|
||||
import javax.servlet.http.*;
|
||||
import java.util.*;
|
||||
import java.io.IOException;
|
||||
|
||||
import com.chanko.yunxi.mes.framework.common.pojo.PageParam;
|
||||
import com.chanko.yunxi.mes.framework.common.pojo.PageResult;
|
||||
import com.chanko.yunxi.mes.framework.common.pojo.CommonResult;
|
||||
import com.chanko.yunxi.mes.framework.common.util.object.BeanUtils;
|
||||
import static com.chanko.yunxi.mes.framework.common.pojo.CommonResult.success;
|
||||
|
||||
import com.chanko.yunxi.mes.framework.excel.core.util.ExcelUtils;
|
||||
|
||||
import com.chanko.yunxi.mes.framework.operatelog.core.annotations.OperateLog;
|
||||
import static com.chanko.yunxi.mes.framework.operatelog.core.enums.OperateTypeEnum.*;
|
||||
|
||||
import com.chanko.yunxi.mes.module.heli.controller.admin.purchaseorder.vo.*;
|
||||
import com.chanko.yunxi.mes.module.heli.dal.dataobject.purchaseorder.PurchaseOrderDO;
|
||||
import com.chanko.yunxi.mes.module.heli.service.purchaseorder.PurchaseOrderService;
|
||||
|
||||
@Tag(name = "管理后台 - 采购订单")
|
||||
@RestController
|
||||
@RequestMapping("/heli/purchase-order")
|
||||
@Validated
|
||||
public class PurchaseOrderController {
|
||||
|
||||
@Resource
|
||||
private PurchaseOrderService purchaseOrderService;
|
||||
|
||||
@PostMapping("/create")
|
||||
@Operation(summary = "创建采购订单")
|
||||
@PreAuthorize("@ss.hasPermission('heli:purchase-order:create')")
|
||||
public CommonResult<Long> createPurchaseOrder(@Valid @RequestBody PurchaseOrderSaveReqVO createReqVO) {
|
||||
return success(purchaseOrderService.createPurchaseOrder(createReqVO));
|
||||
}
|
||||
|
||||
@PutMapping("/update")
|
||||
@Operation(summary = "更新采购订单")
|
||||
@PreAuthorize("@ss.hasPermission('heli:purchase-order:update')")
|
||||
public CommonResult<Boolean> updatePurchaseOrder(@Valid @RequestBody PurchaseOrderSaveReqVO updateReqVO) {
|
||||
purchaseOrderService.updatePurchaseOrder(updateReqVO);
|
||||
return success(true);
|
||||
}
|
||||
|
||||
@DeleteMapping("/delete")
|
||||
@Operation(summary = "删除采购订单")
|
||||
@Parameter(name = "id", description = "编号", required = true)
|
||||
@PreAuthorize("@ss.hasPermission('heli:purchase-order:delete')")
|
||||
public CommonResult<Boolean> deletePurchaseOrder(@RequestParam("id") Long id) {
|
||||
purchaseOrderService.deletePurchaseOrder(id);
|
||||
return success(true);
|
||||
}
|
||||
|
||||
@GetMapping("/get")
|
||||
@Operation(summary = "获得采购订单")
|
||||
@Parameter(name = "id", description = "编号", required = true, example = "1024")
|
||||
@PreAuthorize("@ss.hasPermission('heli:purchase-order:query')")
|
||||
public CommonResult<PurchaseOrderRespVO> getPurchaseOrder(@RequestParam("id") Long id) {
|
||||
PurchaseOrderDO purchaseOrder = purchaseOrderService.getPurchaseOrder(id);
|
||||
return success(BeanUtils.toBean(purchaseOrder, PurchaseOrderRespVO.class));
|
||||
}
|
||||
|
||||
@GetMapping("/page")
|
||||
@Operation(summary = "获得采购订单分页")
|
||||
@PreAuthorize("@ss.hasPermission('heli:purchase-order:query')")
|
||||
public CommonResult<PageResult<PurchaseOrderRespVO>> getPurchaseOrderPage(@Valid PurchaseOrderPageReqVO pageReqVO) {
|
||||
PageResult<PurchaseOrderDO> pageResult = purchaseOrderService.getPurchaseOrderPage(pageReqVO);
|
||||
return success(BeanUtils.toBean(pageResult, PurchaseOrderRespVO.class));
|
||||
}
|
||||
|
||||
@GetMapping("/export-excel")
|
||||
@Operation(summary = "导出采购订单 Excel")
|
||||
@PreAuthorize("@ss.hasPermission('heli:purchase-order:export')")
|
||||
@OperateLog(type = EXPORT)
|
||||
public void exportPurchaseOrderExcel(@Valid PurchaseOrderPageReqVO pageReqVO,
|
||||
HttpServletResponse response) throws IOException {
|
||||
pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE);
|
||||
List<PurchaseOrderDO> list = purchaseOrderService.getPurchaseOrderPage(pageReqVO).getList();
|
||||
// 导出 Excel
|
||||
ExcelUtils.write(response, "采购订单.xls", "数据", PurchaseOrderRespVO.class,
|
||||
BeanUtils.toBean(list, PurchaseOrderRespVO.class));
|
||||
}
|
||||
|
||||
}
|
@ -0,0 +1,95 @@
|
||||
package com.chanko.yunxi.mes.module.heli.controller.admin.purchaseordermaterial;
|
||||
|
||||
import org.springframework.web.bind.annotation.*;
|
||||
import javax.annotation.Resource;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
import org.springframework.security.access.prepost.PreAuthorize;
|
||||
import io.swagger.v3.oas.annotations.tags.Tag;
|
||||
import io.swagger.v3.oas.annotations.Parameter;
|
||||
import io.swagger.v3.oas.annotations.Operation;
|
||||
|
||||
import javax.validation.constraints.*;
|
||||
import javax.validation.*;
|
||||
import javax.servlet.http.*;
|
||||
import java.util.*;
|
||||
import java.io.IOException;
|
||||
|
||||
import com.chanko.yunxi.mes.framework.common.pojo.PageParam;
|
||||
import com.chanko.yunxi.mes.framework.common.pojo.PageResult;
|
||||
import com.chanko.yunxi.mes.framework.common.pojo.CommonResult;
|
||||
import com.chanko.yunxi.mes.framework.common.util.object.BeanUtils;
|
||||
import static com.chanko.yunxi.mes.framework.common.pojo.CommonResult.success;
|
||||
|
||||
import com.chanko.yunxi.mes.framework.excel.core.util.ExcelUtils;
|
||||
|
||||
import com.chanko.yunxi.mes.framework.operatelog.core.annotations.OperateLog;
|
||||
import static com.chanko.yunxi.mes.framework.operatelog.core.enums.OperateTypeEnum.*;
|
||||
|
||||
import com.chanko.yunxi.mes.module.heli.controller.admin.purchaseordermaterial.vo.*;
|
||||
import com.chanko.yunxi.mes.module.heli.dal.dataobject.purchaseordermaterial.PurchaseOrderMaterialDO;
|
||||
import com.chanko.yunxi.mes.module.heli.service.purchaseordermaterial.PurchaseOrderMaterialService;
|
||||
|
||||
@Tag(name = "管理后台 - 采购单物料")
|
||||
@RestController
|
||||
@RequestMapping("/heli/purchase-order-material")
|
||||
@Validated
|
||||
public class PurchaseOrderMaterialController {
|
||||
|
||||
@Resource
|
||||
private PurchaseOrderMaterialService purchaseOrderMaterialService;
|
||||
|
||||
@PostMapping("/create")
|
||||
@Operation(summary = "创建采购单物料")
|
||||
@PreAuthorize("@ss.hasPermission('heli:purchase-order-material:create')")
|
||||
public CommonResult<Long> createPurchaseOrderMaterial(@Valid @RequestBody PurchaseOrderMaterialSaveReqVO createReqVO) {
|
||||
return success(purchaseOrderMaterialService.createPurchaseOrderMaterial(createReqVO));
|
||||
}
|
||||
|
||||
@PutMapping("/update")
|
||||
@Operation(summary = "更新采购单物料")
|
||||
@PreAuthorize("@ss.hasPermission('heli:purchase-order-material:update')")
|
||||
public CommonResult<Boolean> updatePurchaseOrderMaterial(@Valid @RequestBody PurchaseOrderMaterialSaveReqVO updateReqVO) {
|
||||
purchaseOrderMaterialService.updatePurchaseOrderMaterial(updateReqVO);
|
||||
return success(true);
|
||||
}
|
||||
|
||||
@DeleteMapping("/delete")
|
||||
@Operation(summary = "删除采购单物料")
|
||||
@Parameter(name = "id", description = "编号", required = true)
|
||||
@PreAuthorize("@ss.hasPermission('heli:purchase-order-material:delete')")
|
||||
public CommonResult<Boolean> deletePurchaseOrderMaterial(@RequestParam("id") Long id) {
|
||||
purchaseOrderMaterialService.deletePurchaseOrderMaterial(id);
|
||||
return success(true);
|
||||
}
|
||||
|
||||
@GetMapping("/get")
|
||||
@Operation(summary = "获得采购单物料")
|
||||
@Parameter(name = "id", description = "编号", required = true, example = "1024")
|
||||
@PreAuthorize("@ss.hasPermission('heli:purchase-order-material:query')")
|
||||
public CommonResult<PurchaseOrderMaterialRespVO> getPurchaseOrderMaterial(@RequestParam("id") Long id) {
|
||||
PurchaseOrderMaterialDO purchaseOrderMaterial = purchaseOrderMaterialService.getPurchaseOrderMaterial(id);
|
||||
return success(BeanUtils.toBean(purchaseOrderMaterial, PurchaseOrderMaterialRespVO.class));
|
||||
}
|
||||
|
||||
@GetMapping("/page")
|
||||
@Operation(summary = "获得采购单物料分页")
|
||||
@PreAuthorize("@ss.hasPermission('heli:purchase-order-material:query')")
|
||||
public CommonResult<PageResult<PurchaseOrderMaterialRespVO>> getPurchaseOrderMaterialPage(@Valid PurchaseOrderMaterialPageReqVO pageReqVO) {
|
||||
PageResult<PurchaseOrderMaterialDO> pageResult = purchaseOrderMaterialService.getPurchaseOrderMaterialPage(pageReqVO);
|
||||
return success(BeanUtils.toBean(pageResult, PurchaseOrderMaterialRespVO.class));
|
||||
}
|
||||
|
||||
@GetMapping("/export-excel")
|
||||
@Operation(summary = "导出采购单物料 Excel")
|
||||
@PreAuthorize("@ss.hasPermission('heli:purchase-order-material:export')")
|
||||
@OperateLog(type = EXPORT)
|
||||
public void exportPurchaseOrderMaterialExcel(@Valid PurchaseOrderMaterialPageReqVO pageReqVO,
|
||||
HttpServletResponse response) throws IOException {
|
||||
pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE);
|
||||
List<PurchaseOrderMaterialDO> list = purchaseOrderMaterialService.getPurchaseOrderMaterialPage(pageReqVO).getList();
|
||||
// 导出 Excel
|
||||
ExcelUtils.write(response, "采购单物料.xls", "数据", PurchaseOrderMaterialRespVO.class,
|
||||
BeanUtils.toBean(list, PurchaseOrderMaterialRespVO.class));
|
||||
}
|
||||
|
||||
}
|
@ -0,0 +1,45 @@
|
||||
package com.chanko.yunxi.mes.module.heli.controller.admin.purchaseordermaterial.vo;
|
||||
|
||||
import lombok.*;
|
||||
import java.util.*;
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import com.chanko.yunxi.mes.framework.common.pojo.PageParam;
|
||||
import java.math.BigDecimal;
|
||||
import org.springframework.format.annotation.DateTimeFormat;
|
||||
import java.time.LocalDateTime;
|
||||
|
||||
import static com.chanko.yunxi.mes.framework.common.util.date.DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND;
|
||||
|
||||
@Schema(description = "管理后台 - 采购单物料分页 Request VO")
|
||||
@Data
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
@ToString(callSuper = true)
|
||||
public class PurchaseOrderMaterialPageReqVO extends PageParam {
|
||||
|
||||
@Schema(description = "采购单编号")
|
||||
private Long purchaseOrderId;
|
||||
|
||||
@Schema(description = "物料id")
|
||||
private Long materialId;
|
||||
|
||||
@Schema(description = "采购数量")
|
||||
private Long purchaseAmount;
|
||||
|
||||
@Schema(description = "暂估价金额")
|
||||
private BigDecimal estimatedPrice;
|
||||
|
||||
@Schema(description = "实际价金额")
|
||||
private BigDecimal actualPrice;
|
||||
|
||||
@Schema(description = "预计到期日期")
|
||||
@DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)
|
||||
private LocalDateTime[] arriveTime;
|
||||
|
||||
@Schema(description = "备注")
|
||||
private String description;
|
||||
|
||||
@Schema(description = "创建时间")
|
||||
@DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)
|
||||
private LocalDateTime[] createTime;
|
||||
|
||||
}
|
@ -0,0 +1,53 @@
|
||||
package com.chanko.yunxi.mes.module.heli.controller.admin.purchaseordermaterial.vo;
|
||||
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import lombok.*;
|
||||
import java.util.*;
|
||||
import java.util.*;
|
||||
import java.math.BigDecimal;
|
||||
import org.springframework.format.annotation.DateTimeFormat;
|
||||
import java.time.LocalDateTime;
|
||||
import com.alibaba.excel.annotation.*;
|
||||
|
||||
@Schema(description = "管理后台 - 采购单物料 Response VO")
|
||||
@Data
|
||||
@ExcelIgnoreUnannotated
|
||||
public class PurchaseOrderMaterialRespVO {
|
||||
|
||||
@Schema(description = "自增字段,唯一", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@ExcelProperty("自增字段,唯一")
|
||||
private Long id;
|
||||
|
||||
@Schema(description = "采购单编号", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@ExcelProperty("采购单编号")
|
||||
private Long purchaseOrderId;
|
||||
|
||||
@Schema(description = "物料id")
|
||||
@ExcelProperty("物料id")
|
||||
private Long materialId;
|
||||
|
||||
@Schema(description = "采购数量")
|
||||
@ExcelProperty("采购数量")
|
||||
private Long purchaseAmount;
|
||||
|
||||
@Schema(description = "暂估价金额")
|
||||
@ExcelProperty("暂估价金额")
|
||||
private BigDecimal estimatedPrice;
|
||||
|
||||
@Schema(description = "实际价金额")
|
||||
@ExcelProperty("实际价金额")
|
||||
private BigDecimal actualPrice;
|
||||
|
||||
@Schema(description = "预计到期日期")
|
||||
@ExcelProperty("预计到期日期")
|
||||
private LocalDateTime arriveTime;
|
||||
|
||||
@Schema(description = "备注")
|
||||
@ExcelProperty("备注")
|
||||
private String description;
|
||||
|
||||
@Schema(description = "创建时间", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@ExcelProperty("创建时间")
|
||||
private LocalDateTime createTime;
|
||||
|
||||
}
|
@ -0,0 +1,41 @@
|
||||
package com.chanko.yunxi.mes.module.heli.controller.admin.purchaseordermaterial.vo;
|
||||
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import lombok.*;
|
||||
import java.util.*;
|
||||
import javax.validation.constraints.*;
|
||||
import java.util.*;
|
||||
import java.math.BigDecimal;
|
||||
import org.springframework.format.annotation.DateTimeFormat;
|
||||
import java.time.LocalDateTime;
|
||||
|
||||
@Schema(description = "管理后台 - 采购单物料新增/修改 Request VO")
|
||||
@Data
|
||||
public class PurchaseOrderMaterialSaveReqVO {
|
||||
|
||||
@Schema(description = "自增字段,唯一", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
private Long id;
|
||||
|
||||
@Schema(description = "采购单编号", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
@NotNull(message = "采购单编号不能为空")
|
||||
private Long purchaseOrderId;
|
||||
|
||||
@Schema(description = "物料id")
|
||||
private Long materialId;
|
||||
|
||||
@Schema(description = "采购数量")
|
||||
private Long purchaseAmount;
|
||||
|
||||
@Schema(description = "暂估价金额")
|
||||
private BigDecimal estimatedPrice;
|
||||
|
||||
@Schema(description = "实际价金额")
|
||||
private BigDecimal actualPrice;
|
||||
|
||||
@Schema(description = "预计到期日期")
|
||||
private LocalDateTime arriveTime;
|
||||
|
||||
@Schema(description = "备注")
|
||||
private String description;
|
||||
|
||||
}
|
@ -0,0 +1,91 @@
|
||||
package com.chanko.yunxi.mes.module.heli.dal.mysql.purchaseorder;
|
||||
|
||||
import java.util.*;
|
||||
|
||||
import com.chanko.yunxi.mes.framework.common.pojo.PageResult;
|
||||
import com.chanko.yunxi.mes.framework.mybatis.core.query.LambdaQueryWrapperX;
|
||||
import com.chanko.yunxi.mes.framework.mybatis.core.mapper.BaseMapperX;
|
||||
import com.chanko.yunxi.mes.module.heli.controller.admin.materialplan.vo.MaterialPlanPageReqVO;
|
||||
import com.chanko.yunxi.mes.module.heli.dal.dataobject.materialplan.MaterialPlanDO;
|
||||
import com.chanko.yunxi.mes.module.heli.dal.dataobject.plan.PlanDO;
|
||||
import com.chanko.yunxi.mes.module.heli.dal.dataobject.projectorder.ProjectOrderDO;
|
||||
import com.chanko.yunxi.mes.module.heli.dal.dataobject.purchaseorder.PurchaseOrderDO;
|
||||
import com.chanko.yunxi.mes.module.heli.dal.dataobject.supplier.SupplierDO;
|
||||
import com.github.yulichang.wrapper.MPJLambdaWrapper;
|
||||
import org.apache.ibatis.annotations.Mapper;
|
||||
import com.chanko.yunxi.mes.module.heli.controller.admin.purchaseorder.vo.*;
|
||||
import org.springframework.util.StringUtils;
|
||||
|
||||
/**
|
||||
* 采购订单 Mapper
|
||||
*
|
||||
* @author 管理员
|
||||
*/
|
||||
@Mapper
|
||||
public interface PurchaseOrderMapper extends BaseMapperX<PurchaseOrderDO> {
|
||||
|
||||
default PageResult<PurchaseOrderDO> selectPage(PurchaseOrderPageReqVO reqVO) {
|
||||
MPJLambdaWrapper<PurchaseOrderDO> query = new MPJLambdaWrapper<>();
|
||||
|
||||
query.selectAll(PurchaseOrderDO.class)
|
||||
.select("s.name as supplierName","m.project_material_plan_no as materialPlanNo")
|
||||
.leftJoin(SupplierDO.class, "s", SupplierDO::getId, PurchaseOrderDO::getSupplierId)
|
||||
.leftJoin(MaterialPlanDO.class, "m", MaterialPlanDO::getId, PurchaseOrderDO::getProjectMaterialPlanId)
|
||||
.disableSubLogicDel()
|
||||
.orderByDesc(PurchaseOrderDO::getCreateTime);
|
||||
query.like(!StringUtils.isEmpty(reqVO.getPurchaseNo()), PurchaseOrderDO::getPurchaseNo, reqVO.getPurchaseNo())
|
||||
.like(!StringUtils.isEmpty(reqVO.getSupplierName()), "s.name", reqVO.getSupplierName())
|
||||
.like(!StringUtils.isEmpty(reqVO.getMaterialPlanNo()), "m.project_material_plan_no", reqVO.getMaterialPlanNo())
|
||||
.apply(reqVO.getCreateTime() != null, "DATE_FORMAT(t.create_time,'%Y-%m-%d') = {0}", reqVO.getCreateTime())
|
||||
.eq(reqVO.getStatus() != null, PurchaseOrderDO::getStatus, reqVO.getStatus())
|
||||
.eq(reqVO.getPurchaseType() != null, PurchaseOrderDO::getPurchaseType, reqVO.getPurchaseType())
|
||||
.eq(reqVO.getGoodsType() != null, PurchaseOrderDO::getGoodsType, reqVO.getGoodsType());
|
||||
|
||||
return selectPage(reqVO, query);
|
||||
}
|
||||
|
||||
default PageResult<PurchaseOrderDO> selectListWithRatio(PurchaseOrderPageReqVO reqVO) {
|
||||
MPJLambdaWrapper<PurchaseOrderDO> query = new MPJLambdaWrapper<>();
|
||||
|
||||
query.selectAll(PurchaseOrderDO.class)
|
||||
.select("s.name as supplierName","m.project_material_plan_no as materialPlanNo","(case when t.tax_ratio!=Null and t.estimated_price!=null then t.estimated_price*t.tax_ratio else '' end) as estimated_price","(case when t.tax_ratio!=Null and t.actual_price!=null then t.actual_price*t.tax_ratio else '' end) as actual_price")
|
||||
.leftJoin(SupplierDO.class, "s", SupplierDO::getId, PurchaseOrderDO::getSupplierId)
|
||||
.leftJoin(MaterialPlanDO.class, "m", MaterialPlanDO::getId, PurchaseOrderDO::getProjectMaterialPlanId)
|
||||
.disableSubLogicDel()
|
||||
.orderByDesc(PurchaseOrderDO::getCreateTime);
|
||||
query.like(!StringUtils.isEmpty(reqVO.getPurchaseNo()), PurchaseOrderDO::getPurchaseNo, reqVO.getPurchaseNo())
|
||||
.like(!StringUtils.isEmpty(reqVO.getSupplierName()), "s.name", reqVO.getSupplierName())
|
||||
.like(!StringUtils.isEmpty(reqVO.getMaterialPlanNo()), "m.project_material_plan_no", reqVO.getMaterialPlanNo())
|
||||
.apply(reqVO.getCreateTime() != null, "DATE_FORMAT(t.create_time,'%Y-%m-%d') = {0}", reqVO.getCreateTime())
|
||||
.eq(reqVO.getStatus() != null, PurchaseOrderDO::getStatus, reqVO.getStatus())
|
||||
.eq(reqVO.getPurchaseType() != null, PurchaseOrderDO::getPurchaseType, reqVO.getPurchaseType())
|
||||
.eq(reqVO.getGoodsType() != null, PurchaseOrderDO::getGoodsType, reqVO.getGoodsType());
|
||||
|
||||
return selectPage(reqVO, query);
|
||||
}
|
||||
|
||||
// default PageResult<PurchaseOrderDO> selectPage(PurchaseOrderPageReqVO reqVO) {
|
||||
// return selectPage(reqVO, new LambdaQueryWrapperX<PurchaseOrderDO>()
|
||||
// .eqIfPresent(PurchaseOrderDO::getId, reqVO.getId())
|
||||
// .eqIfPresent(PurchaseOrderDO::getPurchaseNo, reqVO.getPurchaseNo())
|
||||
// .eqIfPresent(PurchaseOrderDO::getSupplierId, reqVO.getSupplierId())
|
||||
// .eqIfPresent(PurchaseOrderDO::getContractNo, reqVO.getContractNo())
|
||||
// .eqIfPresent(PurchaseOrderDO::getPurchaseType, reqVO.getPurchaseType())
|
||||
// .eqIfPresent(PurchaseOrderDO::getProjectMaterialPlanId, reqVO.getProjectMaterialPlanId())
|
||||
// .eqIfPresent(PurchaseOrderDO::getGoodsType, reqVO.getGoodsType())
|
||||
// .eqIfPresent(PurchaseOrderDO::getCurrencyType, reqVO.getCurrencyType())
|
||||
// .eqIfPresent(PurchaseOrderDO::getTaxRatio, reqVO.getTaxRatio())
|
||||
// .eqIfPresent(PurchaseOrderDO::getEstimatedPrice, reqVO.getEstimatedPrice())
|
||||
// .eqIfPresent(PurchaseOrderDO::getActualPrice, reqVO.getActualPrice())
|
||||
// .eqIfPresent(PurchaseOrderDO::getStatus, reqVO.getStatus())
|
||||
// .eqIfPresent(PurchaseOrderDO::getSubmitUserId, reqVO.getSubmitUserId())
|
||||
// .betweenIfPresent(PurchaseOrderDO::getSubmitTime, reqVO.getSubmitTime())
|
||||
// .eqIfPresent(PurchaseOrderDO::getAuditor, reqVO.getAuditor())
|
||||
// .betweenIfPresent(PurchaseOrderDO::getAuditTime, reqVO.getAuditTime())
|
||||
// .eqIfPresent(PurchaseOrderDO::getDescription, reqVO.getDescription())
|
||||
// .eqIfPresent(PurchaseOrderDO::getCreator, reqVO.getCreator())
|
||||
// .betweenIfPresent(PurchaseOrderDO::getCreateTime, reqVO.getCreateTime())
|
||||
// .orderByDesc(PurchaseOrderDO::getId));
|
||||
// }
|
||||
|
||||
}
|
@ -0,0 +1,33 @@
|
||||
package com.chanko.yunxi.mes.module.heli.dal.mysql.purchaseordermaterial;
|
||||
|
||||
import java.util.*;
|
||||
|
||||
import com.chanko.yunxi.mes.framework.common.pojo.PageResult;
|
||||
import com.chanko.yunxi.mes.framework.mybatis.core.query.LambdaQueryWrapperX;
|
||||
import com.chanko.yunxi.mes.framework.mybatis.core.mapper.BaseMapperX;
|
||||
import com.chanko.yunxi.mes.module.heli.dal.dataobject.purchaseordermaterial.PurchaseOrderMaterialDO;
|
||||
import org.apache.ibatis.annotations.Mapper;
|
||||
import com.chanko.yunxi.mes.module.heli.controller.admin.purchaseordermaterial.vo.*;
|
||||
|
||||
/**
|
||||
* 采购单物料 Mapper
|
||||
*
|
||||
* @author 管理员
|
||||
*/
|
||||
@Mapper
|
||||
public interface PurchaseOrderMaterialMapper extends BaseMapperX<PurchaseOrderMaterialDO> {
|
||||
|
||||
default PageResult<PurchaseOrderMaterialDO> selectPage(PurchaseOrderMaterialPageReqVO reqVO) {
|
||||
return selectPage(reqVO, new LambdaQueryWrapperX<PurchaseOrderMaterialDO>()
|
||||
.eqIfPresent(PurchaseOrderMaterialDO::getPurchaseOrderId, reqVO.getPurchaseOrderId())
|
||||
.eqIfPresent(PurchaseOrderMaterialDO::getMaterialId, reqVO.getMaterialId())
|
||||
.eqIfPresent(PurchaseOrderMaterialDO::getPurchaseAmount, reqVO.getPurchaseAmount())
|
||||
.eqIfPresent(PurchaseOrderMaterialDO::getEstimatedPrice, reqVO.getEstimatedPrice())
|
||||
.eqIfPresent(PurchaseOrderMaterialDO::getActualPrice, reqVO.getActualPrice())
|
||||
.betweenIfPresent(PurchaseOrderMaterialDO::getArriveTime, reqVO.getArriveTime())
|
||||
.eqIfPresent(PurchaseOrderMaterialDO::getDescription, reqVO.getDescription())
|
||||
.betweenIfPresent(PurchaseOrderMaterialDO::getCreateTime, reqVO.getCreateTime())
|
||||
.orderByDesc(PurchaseOrderMaterialDO::getId));
|
||||
}
|
||||
|
||||
}
|
@ -0,0 +1,55 @@
|
||||
package com.chanko.yunxi.mes.module.heli.service.purchaseorder;
|
||||
|
||||
import java.util.*;
|
||||
import javax.validation.*;
|
||||
import com.chanko.yunxi.mes.module.heli.controller.admin.purchaseorder.vo.*;
|
||||
import com.chanko.yunxi.mes.module.heli.dal.dataobject.purchaseorder.PurchaseOrderDO;
|
||||
import com.chanko.yunxi.mes.framework.common.pojo.PageResult;
|
||||
import com.chanko.yunxi.mes.framework.common.pojo.PageParam;
|
||||
|
||||
/**
|
||||
* 采购订单 Service 接口
|
||||
*
|
||||
* @author 管理员
|
||||
*/
|
||||
public interface PurchaseOrderService {
|
||||
|
||||
/**
|
||||
* 创建采购订单
|
||||
*
|
||||
* @param createReqVO 创建信息
|
||||
* @return 编号
|
||||
*/
|
||||
Long createPurchaseOrder(@Valid PurchaseOrderSaveReqVO createReqVO);
|
||||
|
||||
/**
|
||||
* 更新采购订单
|
||||
*
|
||||
* @param updateReqVO 更新信息
|
||||
*/
|
||||
void updatePurchaseOrder(@Valid PurchaseOrderSaveReqVO updateReqVO);
|
||||
|
||||
/**
|
||||
* 删除采购订单
|
||||
*
|
||||
* @param id 编号
|
||||
*/
|
||||
void deletePurchaseOrder(Long id);
|
||||
|
||||
/**
|
||||
* 获得采购订单
|
||||
*
|
||||
* @param id 编号
|
||||
* @return 采购订单
|
||||
*/
|
||||
PurchaseOrderDO getPurchaseOrder(Long id);
|
||||
|
||||
/**
|
||||
* 获得采购订单分页
|
||||
*
|
||||
* @param pageReqVO 分页查询
|
||||
* @return 采购订单分页
|
||||
*/
|
||||
PageResult<PurchaseOrderDO> getPurchaseOrderPage(PurchaseOrderPageReqVO pageReqVO);
|
||||
|
||||
}
|
@ -0,0 +1,92 @@
|
||||
package com.chanko.yunxi.mes.module.heli.service.purchaseorder;
|
||||
|
||||
import com.chanko.yunxi.mes.module.heli.dal.dataobject.serialnumber.SerialNumberDO;
|
||||
import com.chanko.yunxi.mes.module.heli.service.serialnumber.SerialNumberService;
|
||||
import org.springframework.stereotype.Service;
|
||||
import javax.annotation.Resource;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
import org.springframework.transaction.annotation.Transactional;
|
||||
|
||||
import java.text.SimpleDateFormat;
|
||||
import java.util.*;
|
||||
import com.chanko.yunxi.mes.module.heli.controller.admin.purchaseorder.vo.*;
|
||||
import com.chanko.yunxi.mes.module.heli.dal.dataobject.purchaseorder.PurchaseOrderDO;
|
||||
import com.chanko.yunxi.mes.framework.common.pojo.PageResult;
|
||||
import com.chanko.yunxi.mes.framework.common.pojo.PageParam;
|
||||
import com.chanko.yunxi.mes.framework.common.util.object.BeanUtils;
|
||||
|
||||
import com.chanko.yunxi.mes.module.heli.dal.mysql.purchaseorder.PurchaseOrderMapper;
|
||||
|
||||
import static com.chanko.yunxi.mes.framework.common.exception.util.ServiceExceptionUtil.exception;
|
||||
import static com.chanko.yunxi.mes.module.heli.enums.CodeEnum.MATERIAL_PLAN;
|
||||
import static com.chanko.yunxi.mes.module.heli.enums.CodeEnum.PURCHASE_ORDER;
|
||||
import static com.chanko.yunxi.mes.module.heli.enums.ErrorCodeConstants.*;
|
||||
|
||||
/**
|
||||
* 采购订单 Service 实现类
|
||||
*
|
||||
* @author 管理员
|
||||
*/
|
||||
@Service
|
||||
@Validated
|
||||
public class PurchaseOrderServiceImpl implements PurchaseOrderService {
|
||||
|
||||
@Resource
|
||||
private PurchaseOrderMapper purchaseOrderMapper;
|
||||
|
||||
@Resource
|
||||
private SerialNumberService serialNumberService;
|
||||
|
||||
@Override
|
||||
public Long createPurchaseOrder(PurchaseOrderSaveReqVO createReqVO) {
|
||||
// 插入
|
||||
PurchaseOrderDO purchaseOrder = BeanUtils.toBean(createReqVO, PurchaseOrderDO.class);
|
||||
|
||||
|
||||
// 月度流水号
|
||||
SerialNumberDO serialNumberDO = new SerialNumberDO();
|
||||
serialNumberDO = serialNumberService.getSerialNumber(PURCHASE_ORDER.name(), new SimpleDateFormat("yyyyMMdd").format(new Date()));
|
||||
serialNumberDO.setSerialNumber(serialNumberDO.getSerialNumber()+1);
|
||||
|
||||
purchaseOrder.setPurchaseNo(PURCHASE_ORDER.getCode(serialNumberDO.getSerialNumber().toString()));
|
||||
purchaseOrderMapper.insert(purchaseOrder);
|
||||
// 回写序列记录
|
||||
serialNumberService.updateSerialNumber(serialNumberDO);
|
||||
// 返回
|
||||
return purchaseOrder.getId();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void updatePurchaseOrder(PurchaseOrderSaveReqVO updateReqVO) {
|
||||
// 校验存在
|
||||
validatePurchaseOrderExists(updateReqVO.getId());
|
||||
// 更新
|
||||
PurchaseOrderDO updateObj = BeanUtils.toBean(updateReqVO, PurchaseOrderDO.class);
|
||||
purchaseOrderMapper.updateById(updateObj);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deletePurchaseOrder(Long id) {
|
||||
// 校验存在
|
||||
validatePurchaseOrderExists(id);
|
||||
// 删除
|
||||
purchaseOrderMapper.deleteById(id);
|
||||
}
|
||||
|
||||
private void validatePurchaseOrderExists(Long id) {
|
||||
if (purchaseOrderMapper.selectById(id) == null) {
|
||||
throw exception(PURCHASE_ORDER_NOT_EXISTS);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public PurchaseOrderDO getPurchaseOrder(Long id) {
|
||||
return purchaseOrderMapper.selectById(id);
|
||||
}
|
||||
|
||||
@Override
|
||||
public PageResult<PurchaseOrderDO> getPurchaseOrderPage(PurchaseOrderPageReqVO pageReqVO) {
|
||||
return purchaseOrderMapper.selectPage(pageReqVO);
|
||||
}
|
||||
|
||||
}
|
@ -0,0 +1,55 @@
|
||||
package com.chanko.yunxi.mes.module.heli.service.purchaseordermaterial;
|
||||
|
||||
import java.util.*;
|
||||
import javax.validation.*;
|
||||
import com.chanko.yunxi.mes.module.heli.controller.admin.purchaseordermaterial.vo.*;
|
||||
import com.chanko.yunxi.mes.module.heli.dal.dataobject.purchaseordermaterial.PurchaseOrderMaterialDO;
|
||||
import com.chanko.yunxi.mes.framework.common.pojo.PageResult;
|
||||
import com.chanko.yunxi.mes.framework.common.pojo.PageParam;
|
||||
|
||||
/**
|
||||
* 采购单物料 Service 接口
|
||||
*
|
||||
* @author 管理员
|
||||
*/
|
||||
public interface PurchaseOrderMaterialService {
|
||||
|
||||
/**
|
||||
* 创建采购单物料
|
||||
*
|
||||
* @param createReqVO 创建信息
|
||||
* @return 编号
|
||||
*/
|
||||
Long createPurchaseOrderMaterial(@Valid PurchaseOrderMaterialSaveReqVO createReqVO);
|
||||
|
||||
/**
|
||||
* 更新采购单物料
|
||||
*
|
||||
* @param updateReqVO 更新信息
|
||||
*/
|
||||
void updatePurchaseOrderMaterial(@Valid PurchaseOrderMaterialSaveReqVO updateReqVO);
|
||||
|
||||
/**
|
||||
* 删除采购单物料
|
||||
*
|
||||
* @param id 编号
|
||||
*/
|
||||
void deletePurchaseOrderMaterial(Long id);
|
||||
|
||||
/**
|
||||
* 获得采购单物料
|
||||
*
|
||||
* @param id 编号
|
||||
* @return 采购单物料
|
||||
*/
|
||||
PurchaseOrderMaterialDO getPurchaseOrderMaterial(Long id);
|
||||
|
||||
/**
|
||||
* 获得采购单物料分页
|
||||
*
|
||||
* @param pageReqVO 分页查询
|
||||
* @return 采购单物料分页
|
||||
*/
|
||||
PageResult<PurchaseOrderMaterialDO> getPurchaseOrderMaterialPage(PurchaseOrderMaterialPageReqVO pageReqVO);
|
||||
|
||||
}
|
@ -0,0 +1,74 @@
|
||||
package com.chanko.yunxi.mes.module.heli.service.purchaseordermaterial;
|
||||
|
||||
import org.springframework.stereotype.Service;
|
||||
import javax.annotation.Resource;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
import org.springframework.transaction.annotation.Transactional;
|
||||
|
||||
import java.util.*;
|
||||
import com.chanko.yunxi.mes.module.heli.controller.admin.purchaseordermaterial.vo.*;
|
||||
import com.chanko.yunxi.mes.module.heli.dal.dataobject.purchaseordermaterial.PurchaseOrderMaterialDO;
|
||||
import com.chanko.yunxi.mes.framework.common.pojo.PageResult;
|
||||
import com.chanko.yunxi.mes.framework.common.pojo.PageParam;
|
||||
import com.chanko.yunxi.mes.framework.common.util.object.BeanUtils;
|
||||
|
||||
import com.chanko.yunxi.mes.module.heli.dal.mysql.purchaseordermaterial.PurchaseOrderMaterialMapper;
|
||||
|
||||
import static com.chanko.yunxi.mes.framework.common.exception.util.ServiceExceptionUtil.exception;
|
||||
import static com.chanko.yunxi.mes.module.heli.enums.ErrorCodeConstants.*;
|
||||
|
||||
/**
|
||||
* 采购单物料 Service 实现类
|
||||
*
|
||||
* @author 管理员
|
||||
*/
|
||||
@Service
|
||||
@Validated
|
||||
public class PurchaseOrderMaterialServiceImpl implements PurchaseOrderMaterialService {
|
||||
|
||||
@Resource
|
||||
private PurchaseOrderMaterialMapper purchaseOrderMaterialMapper;
|
||||
|
||||
@Override
|
||||
public Long createPurchaseOrderMaterial(PurchaseOrderMaterialSaveReqVO createReqVO) {
|
||||
// 插入
|
||||
PurchaseOrderMaterialDO purchaseOrderMaterial = BeanUtils.toBean(createReqVO, PurchaseOrderMaterialDO.class);
|
||||
purchaseOrderMaterialMapper.insert(purchaseOrderMaterial);
|
||||
// 返回
|
||||
return purchaseOrderMaterial.getId();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void updatePurchaseOrderMaterial(PurchaseOrderMaterialSaveReqVO updateReqVO) {
|
||||
// 校验存在
|
||||
validatePurchaseOrderMaterialExists(updateReqVO.getId());
|
||||
// 更新
|
||||
PurchaseOrderMaterialDO updateObj = BeanUtils.toBean(updateReqVO, PurchaseOrderMaterialDO.class);
|
||||
purchaseOrderMaterialMapper.updateById(updateObj);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deletePurchaseOrderMaterial(Long id) {
|
||||
// 校验存在
|
||||
validatePurchaseOrderMaterialExists(id);
|
||||
// 删除
|
||||
purchaseOrderMaterialMapper.deleteById(id);
|
||||
}
|
||||
|
||||
private void validatePurchaseOrderMaterialExists(Long id) {
|
||||
if (purchaseOrderMaterialMapper.selectById(id) == null) {
|
||||
throw exception(PURCHASE_ORDER_MATERIAL_NOT_EXISTS);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public PurchaseOrderMaterialDO getPurchaseOrderMaterial(Long id) {
|
||||
return purchaseOrderMaterialMapper.selectById(id);
|
||||
}
|
||||
|
||||
@Override
|
||||
public PageResult<PurchaseOrderMaterialDO> getPurchaseOrderMaterialPage(PurchaseOrderMaterialPageReqVO pageReqVO) {
|
||||
return purchaseOrderMaterialMapper.selectPage(pageReqVO);
|
||||
}
|
||||
|
||||
}
|
@ -0,0 +1,51 @@
|
||||
import request from '@/config/axios'
|
||||
|
||||
export interface PurchaseOrderVO {
|
||||
id: number
|
||||
purchaseNo: string
|
||||
supplierId: number
|
||||
contractNo: string
|
||||
purchaseType: number
|
||||
projectMaterialPlanId: number
|
||||
goodsType: number
|
||||
currencyType: number
|
||||
taxRatio: number
|
||||
estimatedPrice: number
|
||||
actualPrice: number
|
||||
status: boolean
|
||||
submitUserId: number
|
||||
submitTime: Date
|
||||
auditor: number
|
||||
auditTime: Date
|
||||
description: string
|
||||
}
|
||||
|
||||
// 查询采购订单分页
|
||||
export const getPurchaseOrderPage = async (params) => {
|
||||
return await request.get({ url: `/heli/purchase-order/page`, params })
|
||||
}
|
||||
|
||||
// 查询采购订单详情
|
||||
export const getPurchaseOrder = async (id: number) => {
|
||||
return await request.get({ url: `/heli/purchase-order/get?id=` + id })
|
||||
}
|
||||
|
||||
// 新增采购订单
|
||||
export const createPurchaseOrder = async (data: PurchaseOrderVO) => {
|
||||
return await request.post({ url: `/heli/purchase-order/create`, data })
|
||||
}
|
||||
|
||||
// 修改采购订单
|
||||
export const updatePurchaseOrder = async (data: PurchaseOrderVO) => {
|
||||
return await request.put({ url: `/heli/purchase-order/update`, data })
|
||||
}
|
||||
|
||||
// 删除采购订单
|
||||
export const deletePurchaseOrder = async (id: number) => {
|
||||
return await request.delete({ url: `/heli/purchase-order/delete?id=` + id })
|
||||
}
|
||||
|
||||
// 导出采购订单 Excel
|
||||
export const exportPurchaseOrder = async (params) => {
|
||||
return await request.download({ url: `/heli/purchase-order/export-excel`, params })
|
||||
}
|
@ -0,0 +1,42 @@
|
||||
import request from '@/config/axios'
|
||||
|
||||
export interface PurchaseOrderMaterialVO {
|
||||
id: number
|
||||
purchaseOrderId: number
|
||||
materialId: number
|
||||
purchaseAmount: number
|
||||
estimatedPrice: number
|
||||
actualPrice: number
|
||||
arriveTime: Date
|
||||
description: string
|
||||
}
|
||||
|
||||
// 查询采购单物料分页
|
||||
export const getPurchaseOrderMaterialPage = async (params) => {
|
||||
return await request.get({ url: `/heli/purchase-order-material/page`, params })
|
||||
}
|
||||
|
||||
// 查询采购单物料详情
|
||||
export const getPurchaseOrderMaterial = async (id: number) => {
|
||||
return await request.get({ url: `/heli/purchase-order-material/get?id=` + id })
|
||||
}
|
||||
|
||||
// 新增采购单物料
|
||||
export const createPurchaseOrderMaterial = async (data: PurchaseOrderMaterialVO) => {
|
||||
return await request.post({ url: `/heli/purchase-order-material/create`, data })
|
||||
}
|
||||
|
||||
// 修改采购单物料
|
||||
export const updatePurchaseOrderMaterial = async (data: PurchaseOrderMaterialVO) => {
|
||||
return await request.put({ url: `/heli/purchase-order-material/update`, data })
|
||||
}
|
||||
|
||||
// 删除采购单物料
|
||||
export const deletePurchaseOrderMaterial = async (id: number) => {
|
||||
return await request.delete({ url: `/heli/purchase-order-material/delete?id=` + id })
|
||||
}
|
||||
|
||||
// 导出采购单物料 Excel
|
||||
export const exportPurchaseOrderMaterial = async (params) => {
|
||||
return await request.download({ url: `/heli/purchase-order-material/export-excel`, params })
|
||||
}
|
@ -0,0 +1,226 @@
|
||||
<template>
|
||||
<ContentWrap>
|
||||
<!-- 搜索工作栏 -->
|
||||
<el-form class="-mb-15px" :model="queryParams" ref="queryFormRef" :inline="true" label-width="98px">
|
||||
<el-form-item label="采购单号" prop="purchaseNo">
|
||||
<el-input v-model="queryParams.purchaseNo" placeholder="采购单号" clearable @keyup.enter="handleQuery"
|
||||
class="!w-240px" />
|
||||
</el-form-item>
|
||||
<el-form-item label="单据日期" prop="createTime">
|
||||
<el-date-picker class="!w-265px" v-model="queryParams.createTime" type="date" value-format="x"
|
||||
placeholder="单据日期" />
|
||||
</el-form-item>
|
||||
<el-form-item label="供应商" prop="supplierName">
|
||||
<el-input v-model="queryParams.supplierName" placeholder="供应商" clearable @keyup.enter="handleQuery"
|
||||
class="!w-240px" />
|
||||
</el-form-item>
|
||||
<el-form-item label="采购单类型" prop="purchaseType">
|
||||
<el-select v-model="queryParams.purchaseType" placeholder="下拉选择" clearable class="!w-240px">
|
||||
<el-option v-for="dict in getIntDictOptions(DICT_TYPE.HELI_PROJECT_PURCHASE_ORDER_TYPE)" :key="dict.value"
|
||||
:label="dict.label" :value="dict.value" />
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="物料需求计划单号" prop="materialPlanNo">
|
||||
<el-input v-model="queryParams.materialPlanNo" placeholder="物料需求计划单号" clearable @keyup.enter="handleQuery"
|
||||
class="!w-240px" />
|
||||
</el-form-item>
|
||||
<el-form-item label="采购物类型" prop="goodsType">
|
||||
<el-select v-model="queryParams.goodsType" placeholder="下拉选择" clearable class="!w-240px">
|
||||
<el-option v-for="dict in getIntDictOptions(DICT_TYPE.HELI_PROJECT_PURCHASE_GOODS_TYPE)" :key="dict.value"
|
||||
:label="dict.label" :value="dict.value" />
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="单据状态" prop="status">
|
||||
<el-select v-model="queryParams.status" placeholder="下拉选择" clearable class="!w-240px">
|
||||
<el-option v-for="dict in getIntDictOptions(DICT_TYPE.HELI_PURCHASE_ORDER_STATUS)" :key="dict.value"
|
||||
:label="dict.label" :value="dict.value" />
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item>
|
||||
<el-button @click="handleQuery">
|
||||
<Icon icon="ep:search" class="mr-5px" /> 搜索
|
||||
</el-button>
|
||||
<el-button @click="resetQuery">
|
||||
<Icon icon="ep:refresh" class="mr-5px" /> 重置
|
||||
</el-button>
|
||||
<el-button type="primary" plain @click="openForm('create')" v-hasPermi="['heli:purchase-order:create']">
|
||||
<Icon icon="ep:plus" class="mr-5px" /> 新增
|
||||
</el-button>
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
</ContentWrap>
|
||||
|
||||
<!-- 列表 -->
|
||||
<ContentWrap>
|
||||
<el-table v-loading="loading" :data="list" :stripe="true" :show-overflow-tooltip="true">
|
||||
<el-table-column label="采购单号" align="center" prop="purchaseNo" fixed min-width="180"/>
|
||||
<el-table-column label="单据日期" align="center" prop="createTime" :formatter="dateFormatter" min-width="180px" fixed>
|
||||
<template #default="scope">
|
||||
{{
|
||||
formatDate(scope.row.createTime, 'YYYY-MM-DD')
|
||||
}}
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="供应商" align="center" prop="supplierName" fixed />
|
||||
<el-table-column label="采购单类型" align="center" prop="purchaseType" min-width="220">
|
||||
<template #default="scope">
|
||||
<dict-tag :type="DICT_TYPE.HELI_PROJECT_PURCHASE_ORDER_TYPE" :value="scope.row.purchaseType" />
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="物料需求计划单号" align="center" prop="materialPlanNo" min-width="220"/>
|
||||
<el-table-column label="采购物类型" align="center" prop="goodsType" min-width="180">
|
||||
<template #default="scope">
|
||||
<dict-tag :type="DICT_TYPE.HELI_PROJECT_PURCHASE_GOODS_TYPE" :value="scope.row.goodsType" />
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="采购合同号" align="center" prop="contractNo" min-width="180"/>
|
||||
<el-table-column label="结算币种" align="center" prop="currencyType" min-width="180">
|
||||
<template #default="scope">
|
||||
<dict-tag :type="DICT_TYPE.HELI_CURRENCY" :value="scope.row.currencyType" />
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="暂估价金额(元)" align="center" prop="estimatedPrice" min-width="180"/>
|
||||
<el-table-column label="实际价金额(元)" align="center" prop="actualPrice" min-width="180"/>
|
||||
<el-table-column label="税率" align="center" prop="taxRatio" />
|
||||
<el-table-column label="备注" align="center" prop="description" />
|
||||
<el-table-column label="单据状态" align="center" prop="status" fixed="right" min-width="180">
|
||||
<template #default="scope">
|
||||
<dict-tag :type="DICT_TYPE.HELI_PURCHASE_ORDER_STATUS" :value="scope.row.status" />
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="操作" align="center" fixed="right" min-width="180">
|
||||
<template #default="scope">
|
||||
<el-button link type="primary" @click="openForm('edit', scope.row.id)">
|
||||
编辑
|
||||
</el-button>
|
||||
<el-button link type="primary" @click="openForm('detail', scope.row.id)">
|
||||
查看详情
|
||||
</el-button>
|
||||
</template>
|
||||
</el-table-column>
|
||||
</el-table>
|
||||
<!-- 分页 -->
|
||||
<Pagination :total="total" v-model:page="queryParams.pageNo" v-model:limit="queryParams.pageSize"
|
||||
@pagination="getList" />
|
||||
</ContentWrap>
|
||||
|
||||
|
||||
</template>
|
||||
|
||||
<script setup lang="ts">
|
||||
import { getIntDictOptions, DICT_TYPE } from '@/utils/dict'
|
||||
import { dateFormatter, formatDate } from '@/utils/formatTime'
|
||||
import download from '@/utils/download'
|
||||
import * as PurchaseOrderApi from '@/api/heli/purchaseorder'
|
||||
import PurchaseOrderForm from './PurchaseOrderForm.vue'
|
||||
|
||||
defineOptions({ name: 'PurchaseOrder' })
|
||||
|
||||
const message = useMessage() // 消息弹窗
|
||||
const { t } = useI18n() // 国际化
|
||||
const router = useRouter()
|
||||
const loading = ref(true) // 列表的加载中
|
||||
const list = ref([]) // 列表的数据
|
||||
const total = ref(0) // 列表的总页数
|
||||
const queryParams = reactive({
|
||||
pageNo: 1,
|
||||
pageSize: 10,
|
||||
id: undefined,
|
||||
purchaseNo: undefined,
|
||||
supplierId: undefined,
|
||||
contractNo: undefined,
|
||||
purchaseType: undefined,
|
||||
projectMaterialPlanId: undefined,
|
||||
goodsType: undefined,
|
||||
currencyType: undefined,
|
||||
taxRatio: undefined,
|
||||
estimatedPrice: undefined,
|
||||
actualPrice: undefined,
|
||||
status: undefined,
|
||||
submitUserId: undefined,
|
||||
submitTime: [],
|
||||
auditor: undefined,
|
||||
auditTime: [],
|
||||
description: undefined,
|
||||
creator: undefined,
|
||||
createTime: [],
|
||||
})
|
||||
const queryFormRef = ref() // 搜索的表单
|
||||
const exportLoading = ref(false) // 导出的加载中
|
||||
|
||||
/** 查询列表 */
|
||||
const getList = async () => {
|
||||
loading.value = true
|
||||
try {
|
||||
const data = await PurchaseOrderApi.getPurchaseOrderPage(queryParams)
|
||||
list.value = data.list
|
||||
total.value = data.total
|
||||
} finally {
|
||||
loading.value = false
|
||||
}
|
||||
}
|
||||
|
||||
/** 搜索按钮操作 */
|
||||
const handleQuery = () => {
|
||||
queryParams.pageNo = 1
|
||||
getList()
|
||||
}
|
||||
|
||||
/** 重置按钮操作 */
|
||||
const resetQuery = () => {
|
||||
queryFormRef.value.resetFields()
|
||||
handleQuery()
|
||||
}
|
||||
|
||||
/** 添加/修改操作 */
|
||||
const openForm = (type: string, id?: number) => {
|
||||
|
||||
switch (type) {
|
||||
case 'create':
|
||||
router.push({ path: '/purchase/add', query: { id: id } })
|
||||
break;
|
||||
case 'edit':
|
||||
router.push({ path: '/purchase/edit', query: { id: id } })
|
||||
break;
|
||||
case 'detail':
|
||||
router.push({ path: '/purchase/detail', query: { id: id } })
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
/** 删除按钮操作 */
|
||||
const handleDelete = async (id: number) => {
|
||||
try {
|
||||
// 删除的二次确认
|
||||
await message.delConfirm()
|
||||
// 发起删除
|
||||
await PurchaseOrderApi.deletePurchaseOrder(id)
|
||||
message.success(t('common.delSuccess'))
|
||||
// 刷新列表
|
||||
await getList()
|
||||
} catch { }
|
||||
}
|
||||
|
||||
/** 导出按钮操作 */
|
||||
const handleExport = async () => {
|
||||
try {
|
||||
// 导出的二次确认
|
||||
await message.exportConfirm()
|
||||
// 发起导出
|
||||
exportLoading.value = true
|
||||
const data = await PurchaseOrderApi.exportPurchaseOrder(queryParams)
|
||||
download.excel(data, '采购订单.xls')
|
||||
} catch {
|
||||
} finally {
|
||||
exportLoading.value = false
|
||||
}
|
||||
}
|
||||
|
||||
/** 初始化 **/
|
||||
onMounted(async () => {
|
||||
await getList()
|
||||
})
|
||||
</script>
|
Loading…
Reference in new issue