Showing
15 changed files
with
2438 additions
and
6 deletions
| @@ -1323,3 +1323,55 @@ CREATE TABLE `product_sample_confirmation_slip_detail` ( | @@ -1323,3 +1323,55 @@ CREATE TABLE `product_sample_confirmation_slip_detail` ( | ||
| 1323 | `update_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '更新时间', | 1323 | `update_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '更新时间', |
| 1324 | PRIMARY KEY (`id`) | 1324 | PRIMARY KEY (`id`) |
| 1325 | ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb3 COMMENT='产品试样确认单明细' | 1325 | ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb3 COMMENT='产品试样确认单明细' |
| 1326 | + | ||
| 1327 | +CREATE TABLE `order_detail_report` ( | ||
| 1328 | + `id` varchar(32) NOT NULL COMMENT 'ID', | ||
| 1329 | + `purchase_order_line_id` varchar(32) DEFAULT NULL COMMENT '订货单物料行ID', | ||
| 1330 | + `order_no` varchar(100) DEFAULT NULL COMMENT '订单编号', | ||
| 1331 | + `order_date` date default null COMMENT '订货日期', | ||
| 1332 | + `workshop_id` varchar(50) DEFAULT NULL COMMENT '生产厂', | ||
| 1333 | + `dept_name` varchar(50) comment '科办', | ||
| 1334 | + `region_name` varchar(50) comment '区域', | ||
| 1335 | + `ordering_unit_name` varchar(200) comment '订货单位名称', | ||
| 1336 | + `industry` varchar(50) comment '行业', | ||
| 1337 | + `brand` varchar(50) comment '牌号', | ||
| 1338 | + `thickness` decimal(10, 4) default null comment '厚度', | ||
| 1339 | + `thickness_tol_pos` decimal(10, 4) default null comment '厚度公差正', | ||
| 1340 | + `thickness_tol_neg` decimal(10, 4) default null comment '厚度公差负', | ||
| 1341 | + `width` decimal(10, 4) default null comment '宽度', | ||
| 1342 | + `width_tol_pos` decimal(10, 4) default null comment '宽度公差正', | ||
| 1343 | + `width_tol_neg` decimal(10, 4) default null comment '宽度公差负', | ||
| 1344 | + `length` decimal(10, 4) default null comment '长度', | ||
| 1345 | + `length_tol_pos` decimal(10, 4) default null comment '长度公差正', | ||
| 1346 | + `length_tol_neg` decimal(10, 4) default null comment '长度公差负', | ||
| 1347 | + `status` varchar(50) comment '状态', | ||
| 1348 | + `quantity` decimal(15, 4) COMMENT '数量', | ||
| 1349 | + `suggested_price` varchar(50) comment '指导价', | ||
| 1350 | + `delivery_date` date default null comment '发货日期', | ||
| 1351 | + `assessment_exceeds_agreement` varchar(50) comment '超协价', | ||
| 1352 | + `sales_price` varchar(50) comment '销售价', | ||
| 1353 | + `price_list_no` varchar(50) comment '价格表编号', | ||
| 1354 | + `packaging_fee` varchar(50) comment '包装费', | ||
| 1355 | + `invoicing_status` varchar(50) comment '开票情况', | ||
| 1356 | + `piece_weight_header` text comment '件重条头', | ||
| 1357 | + `surface` text comment '表面', | ||
| 1358 | + `tolerance` text comment '公差', | ||
| 1359 | + `performance` text comment '性能', | ||
| 1360 | + `packaging` text comment '包装', | ||
| 1361 | + `remarks` text comment '备注', | ||
| 1362 | + `shipping_cost` varchar(50) comment '运费', | ||
| 1363 | + `return_shipping_cost` varchar(50) comment '回程运费', | ||
| 1364 | + `customer_type` varchar(50) comment '客户类型', | ||
| 1365 | + `quality` varchar(100) comment '标准行业', | ||
| 1366 | + `contract_type` varchar(100) comment '加工经销', | ||
| 1367 | + `stock_up_company_name` varchar(200) comment '备货单位', | ||
| 1368 | + `order_type` varchar(50) comment '订单类型', | ||
| 1369 | + `show_order` int DEFAULT '0' COMMENT '排序,订货单:0,撤销单:1,规格变更单:2', | ||
| 1370 | + `create_by_id` varchar(32) NOT NULL COMMENT '创建人ID', | ||
| 1371 | + `create_by` varchar(20) NOT NULL COMMENT '创建人', | ||
| 1372 | + `update_by_id` varchar(32) NOT NULL COMMENT '更新人ID', | ||
| 1373 | + `update_by` varchar(20) NOT NULL COMMENT '更新人', | ||
| 1374 | + `create_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', | ||
| 1375 | + `update_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '更新时间', | ||
| 1376 | + PRIMARY KEY (`id`) | ||
| 1377 | +) ENGINE=InnoDB DEFAULT CHARSET=utf8mb3 COMMENT='订单明细报表' |
| 1 | +package com.lframework.xingyun.sc.bo.statistics.orderDetail; | ||
| 2 | + | ||
| 3 | +import com.fasterxml.jackson.annotation.JsonFormat; | ||
| 4 | +import java.math.BigDecimal; | ||
| 5 | +import com.lframework.starter.common.constants.StringPool; | ||
| 6 | +import com.lframework.starter.web.core.bo.BaseBo; | ||
| 7 | +import java.time.LocalDate; | ||
| 8 | +import com.lframework.xingyun.sc.entity.OrderDetailReport; | ||
| 9 | +import io.swagger.annotations.ApiModelProperty; | ||
| 10 | + | ||
| 11 | +import lombok.Data; | ||
| 12 | + | ||
| 13 | +/** | ||
| 14 | + * <p> | ||
| 15 | + * 订单明细 GetBo | ||
| 16 | + * </p> | ||
| 17 | + * | ||
| 18 | + */ | ||
| 19 | +@Data | ||
| 20 | +public class GetOrderDetailReportBo extends BaseBo<OrderDetailReport> { | ||
| 21 | + | ||
| 22 | + /** | ||
| 23 | + * ID | ||
| 24 | + */ | ||
| 25 | + @ApiModelProperty("ID") | ||
| 26 | + private String id; | ||
| 27 | + | ||
| 28 | + /** | ||
| 29 | + * 订货单物料行ID | ||
| 30 | + */ | ||
| 31 | + @ApiModelProperty("订货单物料行ID") | ||
| 32 | + private String purchaseOrderLineId; | ||
| 33 | + | ||
| 34 | + /** | ||
| 35 | + * 订单编号 | ||
| 36 | + */ | ||
| 37 | + @ApiModelProperty("订单编号") | ||
| 38 | + private String orderNo; | ||
| 39 | + | ||
| 40 | + /** | ||
| 41 | + * 订货日期 | ||
| 42 | + */ | ||
| 43 | + @ApiModelProperty("订货日期") | ||
| 44 | + @JsonFormat(pattern = StringPool.DATE_PATTERN) | ||
| 45 | + private LocalDate orderDate; | ||
| 46 | + | ||
| 47 | + /** | ||
| 48 | + * 生产厂 | ||
| 49 | + */ | ||
| 50 | + @ApiModelProperty("生产厂") | ||
| 51 | + private String workshopId; | ||
| 52 | + | ||
| 53 | + /** | ||
| 54 | + * 生产厂 | ||
| 55 | + */ | ||
| 56 | + @ApiModelProperty("生产厂") | ||
| 57 | + private String workshopName; | ||
| 58 | + | ||
| 59 | + /** | ||
| 60 | + * 科办 | ||
| 61 | + */ | ||
| 62 | + @ApiModelProperty("科办") | ||
| 63 | + private String deptName; | ||
| 64 | + | ||
| 65 | + /** | ||
| 66 | + * 区域 | ||
| 67 | + */ | ||
| 68 | + @ApiModelProperty("区域") | ||
| 69 | + private String regionName; | ||
| 70 | + | ||
| 71 | + /** | ||
| 72 | + * 订货单位名称 | ||
| 73 | + */ | ||
| 74 | + @ApiModelProperty("订货单位名称") | ||
| 75 | + private String orderingUnitName; | ||
| 76 | + | ||
| 77 | + /** | ||
| 78 | + * 行业 | ||
| 79 | + */ | ||
| 80 | + @ApiModelProperty("行业") | ||
| 81 | + private String industry; | ||
| 82 | + | ||
| 83 | + /** | ||
| 84 | + * 牌号 | ||
| 85 | + */ | ||
| 86 | + @ApiModelProperty("牌号") | ||
| 87 | + private String brand; | ||
| 88 | + | ||
| 89 | + /** | ||
| 90 | + * 厚度 | ||
| 91 | + */ | ||
| 92 | + @ApiModelProperty("厚度") | ||
| 93 | + private BigDecimal thickness; | ||
| 94 | + | ||
| 95 | + /** | ||
| 96 | + * 厚度公差正 | ||
| 97 | + */ | ||
| 98 | + @ApiModelProperty("厚度公差正") | ||
| 99 | + private BigDecimal thicknessTolPos; | ||
| 100 | + | ||
| 101 | + /** | ||
| 102 | + * 厚度公差负 | ||
| 103 | + */ | ||
| 104 | + @ApiModelProperty("厚度公差负") | ||
| 105 | + private BigDecimal thicknessTolNeg; | ||
| 106 | + | ||
| 107 | + /** | ||
| 108 | + * 宽度 | ||
| 109 | + */ | ||
| 110 | + @ApiModelProperty("宽度") | ||
| 111 | + private BigDecimal width; | ||
| 112 | + | ||
| 113 | + /** | ||
| 114 | + * 宽度公差正 | ||
| 115 | + */ | ||
| 116 | + @ApiModelProperty("宽度公差正") | ||
| 117 | + private BigDecimal widthTolPos; | ||
| 118 | + | ||
| 119 | + /** | ||
| 120 | + * 宽度公差负 | ||
| 121 | + */ | ||
| 122 | + @ApiModelProperty("宽度公差负") | ||
| 123 | + private BigDecimal widthTolNeg; | ||
| 124 | + | ||
| 125 | + /** | ||
| 126 | + * 长度 | ||
| 127 | + */ | ||
| 128 | + @ApiModelProperty("长度") | ||
| 129 | + private BigDecimal length; | ||
| 130 | + | ||
| 131 | + /** | ||
| 132 | + * 长度公差正 | ||
| 133 | + */ | ||
| 134 | + @ApiModelProperty("长度公差正") | ||
| 135 | + private BigDecimal lengthTolPos; | ||
| 136 | + | ||
| 137 | + /** | ||
| 138 | + * 长度公差负 | ||
| 139 | + */ | ||
| 140 | + @ApiModelProperty("长度公差负") | ||
| 141 | + private BigDecimal lengthTolNeg; | ||
| 142 | + | ||
| 143 | + /** | ||
| 144 | + * 状态 | ||
| 145 | + */ | ||
| 146 | + @ApiModelProperty("状态") | ||
| 147 | + private String status; | ||
| 148 | + | ||
| 149 | + /** | ||
| 150 | + * 数量 | ||
| 151 | + */ | ||
| 152 | + @ApiModelProperty("数量") | ||
| 153 | + private BigDecimal quantity; | ||
| 154 | + | ||
| 155 | + /** | ||
| 156 | + * 指导价 | ||
| 157 | + */ | ||
| 158 | + @ApiModelProperty("指导价") | ||
| 159 | + private String suggestedPrice; | ||
| 160 | + | ||
| 161 | + /** | ||
| 162 | + * 发货日期 | ||
| 163 | + */ | ||
| 164 | + @ApiModelProperty("发货日期") | ||
| 165 | + @JsonFormat(pattern = StringPool.DATE_PATTERN) | ||
| 166 | + private LocalDate deliveryDate; | ||
| 167 | + | ||
| 168 | + /** | ||
| 169 | + * 超协价 | ||
| 170 | + */ | ||
| 171 | + @ApiModelProperty("超协价") | ||
| 172 | + private String assessmentExceedsAgreement; | ||
| 173 | + | ||
| 174 | + /** | ||
| 175 | + * 销售价 | ||
| 176 | + */ | ||
| 177 | + @ApiModelProperty("销售价") | ||
| 178 | + private String salesPrice; | ||
| 179 | + | ||
| 180 | + /** | ||
| 181 | + * 价格表编号 | ||
| 182 | + */ | ||
| 183 | + @ApiModelProperty("价格表编号") | ||
| 184 | + private String priceListNo; | ||
| 185 | + | ||
| 186 | + /** | ||
| 187 | + * 包装费 | ||
| 188 | + */ | ||
| 189 | + @ApiModelProperty("包装费") | ||
| 190 | + private String packagingFee; | ||
| 191 | + | ||
| 192 | + /** | ||
| 193 | + * 开票情况 | ||
| 194 | + */ | ||
| 195 | + @ApiModelProperty("开票情况") | ||
| 196 | + private String invoicingStatus; | ||
| 197 | + | ||
| 198 | + /** | ||
| 199 | + * 件重条头 | ||
| 200 | + */ | ||
| 201 | + @ApiModelProperty("件重条头") | ||
| 202 | + private String pieceWeightHeader; | ||
| 203 | + | ||
| 204 | + /** | ||
| 205 | + * 表面 | ||
| 206 | + */ | ||
| 207 | + @ApiModelProperty("表面") | ||
| 208 | + private String surface; | ||
| 209 | + | ||
| 210 | + /** | ||
| 211 | + * 公差 | ||
| 212 | + */ | ||
| 213 | + @ApiModelProperty("公差") | ||
| 214 | + private String tolerance; | ||
| 215 | + | ||
| 216 | + /** | ||
| 217 | + * 性能 | ||
| 218 | + */ | ||
| 219 | + @ApiModelProperty("性能") | ||
| 220 | + private String performance; | ||
| 221 | + | ||
| 222 | + /** | ||
| 223 | + * 包装 | ||
| 224 | + */ | ||
| 225 | + @ApiModelProperty("包装") | ||
| 226 | + private String packaging; | ||
| 227 | + | ||
| 228 | + /** | ||
| 229 | + * 备注 | ||
| 230 | + */ | ||
| 231 | + @ApiModelProperty("备注") | ||
| 232 | + private String remarks; | ||
| 233 | + | ||
| 234 | + /** | ||
| 235 | + * 运费 | ||
| 236 | + */ | ||
| 237 | + @ApiModelProperty("运费") | ||
| 238 | + private String shippingCost; | ||
| 239 | + | ||
| 240 | + /** | ||
| 241 | + * 回程运费 | ||
| 242 | + */ | ||
| 243 | + @ApiModelProperty("回程运费") | ||
| 244 | + private String returnShippingCost; | ||
| 245 | + | ||
| 246 | + /** | ||
| 247 | + * 客户类型 | ||
| 248 | + */ | ||
| 249 | + @ApiModelProperty("客户类型") | ||
| 250 | + private String customerType; | ||
| 251 | + | ||
| 252 | + /** | ||
| 253 | + * 标准行业 | ||
| 254 | + */ | ||
| 255 | + @ApiModelProperty("标准行业") | ||
| 256 | + private String quality; | ||
| 257 | + | ||
| 258 | + /** | ||
| 259 | + * 加工经销 | ||
| 260 | + */ | ||
| 261 | + @ApiModelProperty("加工经销") | ||
| 262 | + private String contractType; | ||
| 263 | + | ||
| 264 | + /** | ||
| 265 | + * 备货单位 | ||
| 266 | + */ | ||
| 267 | + @ApiModelProperty("备货单位") | ||
| 268 | + private String stockUpCompanyName; | ||
| 269 | + | ||
| 270 | + /** | ||
| 271 | + * 订单类型 | ||
| 272 | + */ | ||
| 273 | + @ApiModelProperty("订单类型") | ||
| 274 | + private String orderType; | ||
| 275 | + | ||
| 276 | + /** | ||
| 277 | + * 排序,订货单:0,撤销单:1,规格变更单:2 | ||
| 278 | + */ | ||
| 279 | + @ApiModelProperty("排序,订货单:0,撤销单:1,规格变更单:2") | ||
| 280 | + private Integer showOrder; | ||
| 281 | + | ||
| 282 | + public GetOrderDetailReportBo() { | ||
| 283 | + | ||
| 284 | + } | ||
| 285 | + | ||
| 286 | + public GetOrderDetailReportBo(OrderDetailReport dto) { | ||
| 287 | + | ||
| 288 | + super(dto); | ||
| 289 | + } | ||
| 290 | + | ||
| 291 | + @Override | ||
| 292 | + public BaseBo<OrderDetailReport> convert(OrderDetailReport dto) { | ||
| 293 | + return super.convert(dto); | ||
| 294 | + } | ||
| 295 | + | ||
| 296 | + @Override | ||
| 297 | + protected void afterInit(OrderDetailReport dto) { | ||
| 298 | + | ||
| 299 | + } | ||
| 300 | +} |
| 1 | +package com.lframework.xingyun.sc.bo.statistics.orderDetail; | ||
| 2 | + | ||
| 3 | +import com.fasterxml.jackson.annotation.JsonFormat; | ||
| 4 | +import java.math.BigDecimal; | ||
| 5 | +import com.lframework.starter.common.constants.StringPool; | ||
| 6 | +import com.lframework.starter.web.core.bo.BaseBo; | ||
| 7 | +import java.time.LocalDate; | ||
| 8 | +import com.lframework.xingyun.sc.entity.OrderDetailReport; | ||
| 9 | +import io.swagger.annotations.ApiModelProperty; | ||
| 10 | + | ||
| 11 | +import lombok.Data; | ||
| 12 | + | ||
| 13 | +/** | ||
| 14 | + * <p> | ||
| 15 | + * 订单明细 QueryBo | ||
| 16 | + * </p> | ||
| 17 | + * | ||
| 18 | + */ | ||
| 19 | +@Data | ||
| 20 | +public class QueryOrderDetailReportBo extends BaseBo<OrderDetailReport> { | ||
| 21 | + | ||
| 22 | + /** | ||
| 23 | + * ID | ||
| 24 | + */ | ||
| 25 | + @ApiModelProperty("ID") | ||
| 26 | + private String id; | ||
| 27 | + | ||
| 28 | + /** | ||
| 29 | + * 订货单物料行ID | ||
| 30 | + */ | ||
| 31 | + @ApiModelProperty("订货单物料行ID") | ||
| 32 | + private String purchaseOrderLineId; | ||
| 33 | + | ||
| 34 | + /** | ||
| 35 | + * 订单编号 | ||
| 36 | + */ | ||
| 37 | + @ApiModelProperty("订单编号") | ||
| 38 | + private String orderNo; | ||
| 39 | + | ||
| 40 | + /** | ||
| 41 | + * 订货日期 | ||
| 42 | + */ | ||
| 43 | + @ApiModelProperty("订货日期") | ||
| 44 | + @JsonFormat(pattern = StringPool.DATE_PATTERN) | ||
| 45 | + private LocalDate orderDate; | ||
| 46 | + | ||
| 47 | + /** | ||
| 48 | + * 生产厂 | ||
| 49 | + */ | ||
| 50 | + @ApiModelProperty("生产厂") | ||
| 51 | + private String workshopId; | ||
| 52 | + | ||
| 53 | + /** | ||
| 54 | + * 生产厂 | ||
| 55 | + */ | ||
| 56 | + @ApiModelProperty("生产厂") | ||
| 57 | + private String workshopName; | ||
| 58 | + | ||
| 59 | + /** | ||
| 60 | + * 科办 | ||
| 61 | + */ | ||
| 62 | + @ApiModelProperty("科办") | ||
| 63 | + private String deptName; | ||
| 64 | + | ||
| 65 | + /** | ||
| 66 | + * 区域 | ||
| 67 | + */ | ||
| 68 | + @ApiModelProperty("区域") | ||
| 69 | + private String regionName; | ||
| 70 | + | ||
| 71 | + /** | ||
| 72 | + * 订货单位名称 | ||
| 73 | + */ | ||
| 74 | + @ApiModelProperty("订货单位名称") | ||
| 75 | + private String orderingUnitName; | ||
| 76 | + | ||
| 77 | + /** | ||
| 78 | + * 行业 | ||
| 79 | + */ | ||
| 80 | + @ApiModelProperty("行业") | ||
| 81 | + private String industry; | ||
| 82 | + | ||
| 83 | + /** | ||
| 84 | + * 牌号 | ||
| 85 | + */ | ||
| 86 | + @ApiModelProperty("牌号") | ||
| 87 | + private String brand; | ||
| 88 | + | ||
| 89 | + /** | ||
| 90 | + * 厚度 | ||
| 91 | + */ | ||
| 92 | + @ApiModelProperty("厚度") | ||
| 93 | + private BigDecimal thickness; | ||
| 94 | + | ||
| 95 | + /** | ||
| 96 | + * 厚度公差正 | ||
| 97 | + */ | ||
| 98 | + @ApiModelProperty("厚度公差正") | ||
| 99 | + private BigDecimal thicknessTolPos; | ||
| 100 | + | ||
| 101 | + /** | ||
| 102 | + * 厚度公差负 | ||
| 103 | + */ | ||
| 104 | + @ApiModelProperty("厚度公差负") | ||
| 105 | + private BigDecimal thicknessTolNeg; | ||
| 106 | + | ||
| 107 | + /** | ||
| 108 | + * 宽度 | ||
| 109 | + */ | ||
| 110 | + @ApiModelProperty("宽度") | ||
| 111 | + private BigDecimal width; | ||
| 112 | + | ||
| 113 | + /** | ||
| 114 | + * 宽度公差正 | ||
| 115 | + */ | ||
| 116 | + @ApiModelProperty("宽度公差正") | ||
| 117 | + private BigDecimal widthTolPos; | ||
| 118 | + | ||
| 119 | + /** | ||
| 120 | + * 宽度公差负 | ||
| 121 | + */ | ||
| 122 | + @ApiModelProperty("宽度公差负") | ||
| 123 | + private BigDecimal widthTolNeg; | ||
| 124 | + | ||
| 125 | + /** | ||
| 126 | + * 长度 | ||
| 127 | + */ | ||
| 128 | + @ApiModelProperty("长度") | ||
| 129 | + private BigDecimal length; | ||
| 130 | + | ||
| 131 | + /** | ||
| 132 | + * 长度公差正 | ||
| 133 | + */ | ||
| 134 | + @ApiModelProperty("长度公差正") | ||
| 135 | + private BigDecimal lengthTolPos; | ||
| 136 | + | ||
| 137 | + /** | ||
| 138 | + * 长度公差负 | ||
| 139 | + */ | ||
| 140 | + @ApiModelProperty("长度公差负") | ||
| 141 | + private BigDecimal lengthTolNeg; | ||
| 142 | + | ||
| 143 | + /** | ||
| 144 | + * 状态 | ||
| 145 | + */ | ||
| 146 | + @ApiModelProperty("状态") | ||
| 147 | + private String status; | ||
| 148 | + | ||
| 149 | + /** | ||
| 150 | + * 数量 | ||
| 151 | + */ | ||
| 152 | + @ApiModelProperty("数量") | ||
| 153 | + private BigDecimal quantity; | ||
| 154 | + | ||
| 155 | + /** | ||
| 156 | + * 指导价 | ||
| 157 | + */ | ||
| 158 | + @ApiModelProperty("指导价") | ||
| 159 | + private String suggestedPrice; | ||
| 160 | + | ||
| 161 | + /** | ||
| 162 | + * 发货日期 | ||
| 163 | + */ | ||
| 164 | + @ApiModelProperty("发货日期") | ||
| 165 | + @JsonFormat(pattern = StringPool.DATE_PATTERN) | ||
| 166 | + private LocalDate deliveryDate; | ||
| 167 | + | ||
| 168 | + /** | ||
| 169 | + * 超协价 | ||
| 170 | + */ | ||
| 171 | + @ApiModelProperty("超协价") | ||
| 172 | + private String assessmentExceedsAgreement; | ||
| 173 | + | ||
| 174 | + /** | ||
| 175 | + * 销售价 | ||
| 176 | + */ | ||
| 177 | + @ApiModelProperty("销售价") | ||
| 178 | + private String salesPrice; | ||
| 179 | + | ||
| 180 | + /** | ||
| 181 | + * 价格表编号 | ||
| 182 | + */ | ||
| 183 | + @ApiModelProperty("价格表编号") | ||
| 184 | + private String priceListNo; | ||
| 185 | + | ||
| 186 | + /** | ||
| 187 | + * 包装费 | ||
| 188 | + */ | ||
| 189 | + @ApiModelProperty("包装费") | ||
| 190 | + private String packagingFee; | ||
| 191 | + | ||
| 192 | + /** | ||
| 193 | + * 开票情况 | ||
| 194 | + */ | ||
| 195 | + @ApiModelProperty("开票情况") | ||
| 196 | + private String invoicingStatus; | ||
| 197 | + | ||
| 198 | + /** | ||
| 199 | + * 件重条头 | ||
| 200 | + */ | ||
| 201 | + @ApiModelProperty("件重条头") | ||
| 202 | + private String pieceWeightHeader; | ||
| 203 | + | ||
| 204 | + /** | ||
| 205 | + * 表面 | ||
| 206 | + */ | ||
| 207 | + @ApiModelProperty("表面") | ||
| 208 | + private String surface; | ||
| 209 | + | ||
| 210 | + /** | ||
| 211 | + * 公差 | ||
| 212 | + */ | ||
| 213 | + @ApiModelProperty("公差") | ||
| 214 | + private String tolerance; | ||
| 215 | + | ||
| 216 | + /** | ||
| 217 | + * 性能 | ||
| 218 | + */ | ||
| 219 | + @ApiModelProperty("性能") | ||
| 220 | + private String performance; | ||
| 221 | + | ||
| 222 | + /** | ||
| 223 | + * 包装 | ||
| 224 | + */ | ||
| 225 | + @ApiModelProperty("包装") | ||
| 226 | + private String packaging; | ||
| 227 | + | ||
| 228 | + /** | ||
| 229 | + * 备注 | ||
| 230 | + */ | ||
| 231 | + @ApiModelProperty("备注") | ||
| 232 | + private String remarks; | ||
| 233 | + | ||
| 234 | + /** | ||
| 235 | + * 运费 | ||
| 236 | + */ | ||
| 237 | + @ApiModelProperty("运费") | ||
| 238 | + private String shippingCost; | ||
| 239 | + | ||
| 240 | + /** | ||
| 241 | + * 回程运费 | ||
| 242 | + */ | ||
| 243 | + @ApiModelProperty("回程运费") | ||
| 244 | + private String returnShippingCost; | ||
| 245 | + | ||
| 246 | + /** | ||
| 247 | + * 客户类型 | ||
| 248 | + */ | ||
| 249 | + @ApiModelProperty("客户类型") | ||
| 250 | + private String customerType; | ||
| 251 | + | ||
| 252 | + /** | ||
| 253 | + * 标准行业 | ||
| 254 | + */ | ||
| 255 | + @ApiModelProperty("标准行业") | ||
| 256 | + private String quality; | ||
| 257 | + | ||
| 258 | + /** | ||
| 259 | + * 加工经销 | ||
| 260 | + */ | ||
| 261 | + @ApiModelProperty("加工经销") | ||
| 262 | + private String contractType; | ||
| 263 | + | ||
| 264 | + /** | ||
| 265 | + * 备货单位 | ||
| 266 | + */ | ||
| 267 | + @ApiModelProperty("备货单位") | ||
| 268 | + private String stockUpCompanyName; | ||
| 269 | + | ||
| 270 | + /** | ||
| 271 | + * 订单类型 | ||
| 272 | + */ | ||
| 273 | + @ApiModelProperty("订单类型") | ||
| 274 | + private String orderType; | ||
| 275 | + | ||
| 276 | + /** | ||
| 277 | + * 排序,订货单:0,撤销单:1,规格变更单:2 | ||
| 278 | + */ | ||
| 279 | + @ApiModelProperty("排序,订货单:0,撤销单:1,规格变更单:2") | ||
| 280 | + private Integer showOrder; | ||
| 281 | + | ||
| 282 | + public QueryOrderDetailReportBo() { | ||
| 283 | + | ||
| 284 | + } | ||
| 285 | + | ||
| 286 | + public QueryOrderDetailReportBo(OrderDetailReport dto) { | ||
| 287 | + | ||
| 288 | + super(dto); | ||
| 289 | + } | ||
| 290 | + | ||
| 291 | + @Override | ||
| 292 | + public BaseBo<OrderDetailReport> convert(OrderDetailReport dto) { | ||
| 293 | + return super.convert(dto); | ||
| 294 | + } | ||
| 295 | + | ||
| 296 | + @Override | ||
| 297 | + protected void afterInit(OrderDetailReport dto) { | ||
| 298 | + | ||
| 299 | + } | ||
| 300 | +} |
| 1 | +package com.lframework.xingyun.sc.controller.statistics; | ||
| 2 | + | ||
| 3 | +import com.lframework.starter.mq.core.utils.ExportTaskUtil; | ||
| 4 | +import com.lframework.starter.web.core.annotations.security.HasPermission; | ||
| 5 | +import com.lframework.starter.web.core.controller.DefaultBaseController; | ||
| 6 | +import com.lframework.starter.web.core.utils.PageResultUtil; | ||
| 7 | +import com.lframework.starter.web.core.components.resp.PageResult; | ||
| 8 | +import com.lframework.starter.web.core.components.resp.InvokeResult; | ||
| 9 | +import javax.validation.constraints.NotBlank; | ||
| 10 | +import com.lframework.xingyun.sc.bo.statistics.orderDetail.GetOrderDetailReportBo; | ||
| 11 | +import com.lframework.xingyun.sc.bo.statistics.orderDetail.QueryOrderDetailReportBo; | ||
| 12 | +import com.lframework.xingyun.sc.entity.OrderDetailReport; | ||
| 13 | +import com.lframework.xingyun.sc.enums.ExportType; | ||
| 14 | +import com.lframework.xingyun.sc.excel.statistics.OrderDetailReportExportTaskWorker; | ||
| 15 | +import com.lframework.xingyun.sc.service.statistics.OrderDetailReportService; | ||
| 16 | +import com.lframework.xingyun.sc.vo.statistics.orderDetail.CreateOrderDetailReportVo; | ||
| 17 | +import com.lframework.xingyun.sc.vo.statistics.orderDetail.QueryOrderDetailReportVo; | ||
| 18 | +import io.swagger.annotations.ApiImplicitParam; | ||
| 19 | +import com.lframework.starter.web.core.components.resp.InvokeResultBuilder; | ||
| 20 | +import com.lframework.starter.common.exceptions.impl.DefaultClientException; | ||
| 21 | +import io.swagger.annotations.ApiOperation; | ||
| 22 | +import com.lframework.starter.common.utils.CollectionUtil; | ||
| 23 | +import io.swagger.annotations.Api; | ||
| 24 | +import org.springframework.beans.factory.annotation.Autowired; | ||
| 25 | +import org.springframework.validation.annotation.Validated; | ||
| 26 | +import org.springframework.web.bind.annotation.*; | ||
| 27 | +import javax.validation.Valid; | ||
| 28 | +import java.util.List; | ||
| 29 | +import java.util.stream.Collectors; | ||
| 30 | + | ||
| 31 | +/** | ||
| 32 | + * 订单明细 Controller | ||
| 33 | + * | ||
| 34 | + */ | ||
| 35 | +@Api(tags = "订单明细") | ||
| 36 | +@Validated | ||
| 37 | +@RestController | ||
| 38 | +@RequestMapping("/orderDetailReport") | ||
| 39 | +public class OrderDetailReportController extends DefaultBaseController { | ||
| 40 | + | ||
| 41 | + @Autowired | ||
| 42 | + private OrderDetailReportService orderDetailReportService; | ||
| 43 | + | ||
| 44 | + /** | ||
| 45 | + * 查询列表 | ||
| 46 | + */ | ||
| 47 | + @ApiOperation("查询列表") | ||
| 48 | + @HasPermission({"statistical-report:order-detail:query"}) | ||
| 49 | + @GetMapping("/query") | ||
| 50 | + public InvokeResult<PageResult<QueryOrderDetailReportBo>> query(@Valid QueryOrderDetailReportVo vo) { | ||
| 51 | + | ||
| 52 | + PageResult<OrderDetailReport> pageResult = orderDetailReportService.query(getPageIndex(vo), getPageSize(vo), vo); | ||
| 53 | + | ||
| 54 | + List<OrderDetailReport> datas = pageResult.getDatas(); | ||
| 55 | + List<QueryOrderDetailReportBo> results = null; | ||
| 56 | + | ||
| 57 | + if (!CollectionUtil.isEmpty(datas)) { | ||
| 58 | + results = datas.stream().map(QueryOrderDetailReportBo::new).collect(Collectors.toList()); | ||
| 59 | + } | ||
| 60 | + | ||
| 61 | + return InvokeResultBuilder.success(PageResultUtil.rebuild(pageResult, results)); | ||
| 62 | + } | ||
| 63 | + | ||
| 64 | + /** | ||
| 65 | + * 根据ID查询 | ||
| 66 | + */ | ||
| 67 | + @ApiOperation("根据ID查询") | ||
| 68 | + @ApiImplicitParam(value = "id", name = "id", paramType = "query", required = true) | ||
| 69 | + @HasPermission({"statistical-report:order-detail:query"}) | ||
| 70 | + @GetMapping | ||
| 71 | + public InvokeResult<GetOrderDetailReportBo> get(@NotBlank(message = "id不能为空!") String id) { | ||
| 72 | + | ||
| 73 | + OrderDetailReport data = orderDetailReportService.findById(id); | ||
| 74 | + if (data == null) { | ||
| 75 | + throw new DefaultClientException("订单明细不存在!"); | ||
| 76 | + } | ||
| 77 | + | ||
| 78 | + GetOrderDetailReportBo result = new GetOrderDetailReportBo(data); | ||
| 79 | + | ||
| 80 | + return InvokeResultBuilder.success(result); | ||
| 81 | + } | ||
| 82 | + | ||
| 83 | + /** | ||
| 84 | + * 新增 | ||
| 85 | + */ | ||
| 86 | + @ApiOperation("新增") | ||
| 87 | + @PostMapping | ||
| 88 | + public InvokeResult<Void> create(@Valid CreateOrderDetailReportVo vo) { | ||
| 89 | + | ||
| 90 | + orderDetailReportService.create(vo); | ||
| 91 | + | ||
| 92 | + return InvokeResultBuilder.success(); | ||
| 93 | + } | ||
| 94 | + | ||
| 95 | + /** | ||
| 96 | + * 订单明细导出 | ||
| 97 | + */ | ||
| 98 | + @ApiOperation("订单明细导出") | ||
| 99 | + @HasPermission({"statistical-report:order-detail:export"}) | ||
| 100 | + @GetMapping("/export") | ||
| 101 | + public InvokeResult<Void> export(@Valid QueryOrderDetailReportVo vo) { | ||
| 102 | + vo.setExportType(ExportType.ORDER_DETAIL_REPORT.getCode()); | ||
| 103 | + ExportTaskUtil.exportTask("订单明细报表", OrderDetailReportExportTaskWorker.class, vo); | ||
| 104 | + return InvokeResultBuilder.success(); | ||
| 105 | + } | ||
| 106 | + | ||
| 107 | + /** | ||
| 108 | + * 处理历史数据 | ||
| 109 | + */ | ||
| 110 | + @ApiOperation("处理历史数据") | ||
| 111 | + @GetMapping("/processHistoricalData") | ||
| 112 | + public InvokeResult<Void> processHistoricalData() { | ||
| 113 | + | ||
| 114 | + orderDetailReportService.processHistoricalData(); | ||
| 115 | + | ||
| 116 | + return InvokeResultBuilder.success(); | ||
| 117 | + } | ||
| 118 | +} |
| 1 | +package com.lframework.xingyun.sc.entity; | ||
| 2 | + | ||
| 3 | +import com.baomidou.mybatisplus.annotation.TableName; | ||
| 4 | +import java.math.BigDecimal; | ||
| 5 | +import com.lframework.starter.web.core.dto.BaseDto; | ||
| 6 | +import java.time.LocalDate; | ||
| 7 | +import java.time.LocalDateTime; | ||
| 8 | +import com.baomidou.mybatisplus.annotation.FieldFill; | ||
| 9 | +import com.lframework.starter.web.core.entity.BaseEntity; | ||
| 10 | +import com.baomidou.mybatisplus.annotation.TableField; | ||
| 11 | +import lombok.Data; | ||
| 12 | + | ||
| 13 | +/** | ||
| 14 | + * <p> | ||
| 15 | + * 订单明细 | ||
| 16 | + * </p> | ||
| 17 | + * | ||
| 18 | + */ | ||
| 19 | +@Data | ||
| 20 | +@TableName("order_detail_report") | ||
| 21 | +public class OrderDetailReport extends BaseEntity implements BaseDto { | ||
| 22 | + | ||
| 23 | + private static final long serialVersionUID = 1L; | ||
| 24 | + | ||
| 25 | + public static final String CACHE_NAME = "OrderDetailReport"; | ||
| 26 | + | ||
| 27 | + /** | ||
| 28 | + * ID | ||
| 29 | + */ | ||
| 30 | + private String id; | ||
| 31 | + | ||
| 32 | + /** | ||
| 33 | + * 订货单物料行ID | ||
| 34 | + */ | ||
| 35 | + private String purchaseOrderLineId; | ||
| 36 | + | ||
| 37 | + /** | ||
| 38 | + * 订单编号 | ||
| 39 | + */ | ||
| 40 | + private String orderNo; | ||
| 41 | + | ||
| 42 | + /** | ||
| 43 | + * 订货日期 | ||
| 44 | + */ | ||
| 45 | + private LocalDate orderDate; | ||
| 46 | + | ||
| 47 | + /** | ||
| 48 | + * 生产厂 | ||
| 49 | + */ | ||
| 50 | + private String workshopId; | ||
| 51 | + | ||
| 52 | + /** | ||
| 53 | + * 生产厂 | ||
| 54 | + */ | ||
| 55 | + @TableField(exist = false) | ||
| 56 | + private String workshopName; | ||
| 57 | + | ||
| 58 | + /** | ||
| 59 | + * 科办 | ||
| 60 | + */ | ||
| 61 | + private String deptName; | ||
| 62 | + | ||
| 63 | + /** | ||
| 64 | + * 区域 | ||
| 65 | + */ | ||
| 66 | + private String regionName; | ||
| 67 | + | ||
| 68 | + /** | ||
| 69 | + * 订货单位名称 | ||
| 70 | + */ | ||
| 71 | + private String orderingUnitName; | ||
| 72 | + | ||
| 73 | + /** | ||
| 74 | + * 行业 | ||
| 75 | + */ | ||
| 76 | + private String industry; | ||
| 77 | + | ||
| 78 | + /** | ||
| 79 | + * 牌号 | ||
| 80 | + */ | ||
| 81 | + private String brand; | ||
| 82 | + | ||
| 83 | + /** | ||
| 84 | + * 厚度 | ||
| 85 | + */ | ||
| 86 | + private BigDecimal thickness; | ||
| 87 | + | ||
| 88 | + /** | ||
| 89 | + * 厚度公差正 | ||
| 90 | + */ | ||
| 91 | + private BigDecimal thicknessTolPos; | ||
| 92 | + | ||
| 93 | + /** | ||
| 94 | + * 厚度公差负 | ||
| 95 | + */ | ||
| 96 | + private BigDecimal thicknessTolNeg; | ||
| 97 | + | ||
| 98 | + /** | ||
| 99 | + * 宽度 | ||
| 100 | + */ | ||
| 101 | + private BigDecimal width; | ||
| 102 | + | ||
| 103 | + /** | ||
| 104 | + * 宽度公差正 | ||
| 105 | + */ | ||
| 106 | + private BigDecimal widthTolPos; | ||
| 107 | + | ||
| 108 | + /** | ||
| 109 | + * 宽度公差负 | ||
| 110 | + */ | ||
| 111 | + private BigDecimal widthTolNeg; | ||
| 112 | + | ||
| 113 | + /** | ||
| 114 | + * 长度 | ||
| 115 | + */ | ||
| 116 | + private BigDecimal length; | ||
| 117 | + | ||
| 118 | + /** | ||
| 119 | + * 长度公差正 | ||
| 120 | + */ | ||
| 121 | + private BigDecimal lengthTolPos; | ||
| 122 | + | ||
| 123 | + /** | ||
| 124 | + * 长度公差负 | ||
| 125 | + */ | ||
| 126 | + private BigDecimal lengthTolNeg; | ||
| 127 | + | ||
| 128 | + /** | ||
| 129 | + * 状态 | ||
| 130 | + */ | ||
| 131 | + private String status; | ||
| 132 | + | ||
| 133 | + /** | ||
| 134 | + * 数量 | ||
| 135 | + */ | ||
| 136 | + private BigDecimal quantity; | ||
| 137 | + | ||
| 138 | + /** | ||
| 139 | + * 指导价 | ||
| 140 | + */ | ||
| 141 | + private String suggestedPrice; | ||
| 142 | + | ||
| 143 | + /** | ||
| 144 | + * 发货日期 | ||
| 145 | + */ | ||
| 146 | + private LocalDate deliveryDate; | ||
| 147 | + | ||
| 148 | + /** | ||
| 149 | + * 超协价 | ||
| 150 | + */ | ||
| 151 | + private String assessmentExceedsAgreement; | ||
| 152 | + | ||
| 153 | + /** | ||
| 154 | + * 销售价 | ||
| 155 | + */ | ||
| 156 | + private String salesPrice; | ||
| 157 | + | ||
| 158 | + /** | ||
| 159 | + * 价格表编号 | ||
| 160 | + */ | ||
| 161 | + private String priceListNo; | ||
| 162 | + | ||
| 163 | + /** | ||
| 164 | + * 包装费 | ||
| 165 | + */ | ||
| 166 | + private String packagingFee; | ||
| 167 | + | ||
| 168 | + /** | ||
| 169 | + * 开票情况 | ||
| 170 | + */ | ||
| 171 | + private String invoicingStatus; | ||
| 172 | + | ||
| 173 | + /** | ||
| 174 | + * 件重条头 | ||
| 175 | + */ | ||
| 176 | + private String pieceWeightHeader; | ||
| 177 | + | ||
| 178 | + /** | ||
| 179 | + * 表面 | ||
| 180 | + */ | ||
| 181 | + private String surface; | ||
| 182 | + | ||
| 183 | + /** | ||
| 184 | + * 公差 | ||
| 185 | + */ | ||
| 186 | + private String tolerance; | ||
| 187 | + | ||
| 188 | + /** | ||
| 189 | + * 性能 | ||
| 190 | + */ | ||
| 191 | + private String performance; | ||
| 192 | + | ||
| 193 | + /** | ||
| 194 | + * 包装 | ||
| 195 | + */ | ||
| 196 | + private String packaging; | ||
| 197 | + | ||
| 198 | + /** | ||
| 199 | + * 备注 | ||
| 200 | + */ | ||
| 201 | + private String remarks; | ||
| 202 | + | ||
| 203 | + /** | ||
| 204 | + * 运费 | ||
| 205 | + */ | ||
| 206 | + private String shippingCost; | ||
| 207 | + | ||
| 208 | + /** | ||
| 209 | + * 回程运费 | ||
| 210 | + */ | ||
| 211 | + private String returnShippingCost; | ||
| 212 | + | ||
| 213 | + /** | ||
| 214 | + * 客户类型 | ||
| 215 | + */ | ||
| 216 | + private String customerType; | ||
| 217 | + | ||
| 218 | + /** | ||
| 219 | + * 标准行业 | ||
| 220 | + */ | ||
| 221 | + private String quality; | ||
| 222 | + | ||
| 223 | + /** | ||
| 224 | + * 加工经销 | ||
| 225 | + */ | ||
| 226 | + private String contractType; | ||
| 227 | + | ||
| 228 | + /** | ||
| 229 | + * 备货单位 | ||
| 230 | + */ | ||
| 231 | + private String stockUpCompanyName; | ||
| 232 | + | ||
| 233 | + /** | ||
| 234 | + * 订单类型 | ||
| 235 | + */ | ||
| 236 | + private String orderType; | ||
| 237 | + | ||
| 238 | + /** | ||
| 239 | + * 排序,订货单:0,撤销单:1,规格变更单:2 | ||
| 240 | + */ | ||
| 241 | + private Integer showOrder; | ||
| 242 | + | ||
| 243 | + /** | ||
| 244 | + * 创建人ID | ||
| 245 | + */ | ||
| 246 | + @TableField(fill = FieldFill.INSERT) | ||
| 247 | + private String createById; | ||
| 248 | + | ||
| 249 | + /** | ||
| 250 | + * 创建人 | ||
| 251 | + */ | ||
| 252 | + @TableField(fill = FieldFill.INSERT) | ||
| 253 | + private String createBy; | ||
| 254 | + | ||
| 255 | + /** | ||
| 256 | + * 更新人ID | ||
| 257 | + */ | ||
| 258 | + @TableField(fill = FieldFill.INSERT_UPDATE) | ||
| 259 | + private String updateById; | ||
| 260 | + | ||
| 261 | + /** | ||
| 262 | + * 更新人 | ||
| 263 | + */ | ||
| 264 | + @TableField(fill = FieldFill.INSERT_UPDATE) | ||
| 265 | + private String updateBy; | ||
| 266 | + | ||
| 267 | + /** | ||
| 268 | + * 创建时间 | ||
| 269 | + */ | ||
| 270 | + @TableField(fill = FieldFill.INSERT) | ||
| 271 | + private LocalDateTime createTime; | ||
| 272 | + | ||
| 273 | + /** | ||
| 274 | + * 更新时间 | ||
| 275 | + */ | ||
| 276 | + @TableField(fill = FieldFill.INSERT_UPDATE) | ||
| 277 | + private LocalDateTime updateTime; | ||
| 278 | + | ||
| 279 | +} |
| @@ -11,6 +11,7 @@ public enum ExportType implements BaseEnum<String> { | @@ -11,6 +11,7 @@ public enum ExportType implements BaseEnum<String> { | ||
| 11 | CONTRACT_FRAMEWORK("CONTRACT_FRAMEWORK", "合同框架"), | 11 | CONTRACT_FRAMEWORK("CONTRACT_FRAMEWORK", "合同框架"), |
| 12 | RECEIVABLE_LEDGER_REPORT("RECEIVABLE_LEDGER_REPORT", "应收款台账报表"), | 12 | RECEIVABLE_LEDGER_REPORT("RECEIVABLE_LEDGER_REPORT", "应收款台账报表"), |
| 13 | SHIPMENT_DETAIL_REPORT("SHIPMENT_DETAIL_REPORT", "发货明细报表"), | 13 | SHIPMENT_DETAIL_REPORT("SHIPMENT_DETAIL_REPORT", "发货明细报表"), |
| 14 | + ORDER_DETAIL_REPORT("ORDER_DETAIL_REPORT", "订单明细报表"), | ||
| 14 | 15 | ||
| 15 | 16 | ||
| 16 | ; | 17 | ; |
| 1 | +package com.lframework.xingyun.sc.excel.statistics; | ||
| 2 | + | ||
| 3 | +import com.lframework.starter.common.utils.CollectionUtil; | ||
| 4 | +import com.lframework.starter.mq.core.components.export.ExportTaskWorker; | ||
| 5 | +import com.lframework.starter.web.core.components.resp.PageResult; | ||
| 6 | +import com.lframework.starter.web.core.utils.ApplicationUtil; | ||
| 7 | +import com.lframework.starter.web.core.utils.JsonUtil; | ||
| 8 | +import com.lframework.starter.web.core.utils.PageResultUtil; | ||
| 9 | +import com.lframework.xingyun.sc.bo.statistics.orderDetail.QueryOrderDetailReportBo; | ||
| 10 | +import com.lframework.xingyun.sc.bo.statistics.shipmentDetail.QueryShipmentDetailStatisticsBo; | ||
| 11 | +import com.lframework.xingyun.sc.entity.OrderDetailReport; | ||
| 12 | +import com.lframework.xingyun.sc.entity.ShipmentDetailStatistics; | ||
| 13 | +import com.lframework.xingyun.sc.service.statistics.OrderDetailReportService; | ||
| 14 | +import com.lframework.xingyun.sc.service.statistics.ShipmentDetailStatisticsService; | ||
| 15 | +import com.lframework.xingyun.sc.utils.CommonUtil; | ||
| 16 | +import com.lframework.xingyun.sc.vo.statistics.orderDetail.QueryOrderDetailReportVo; | ||
| 17 | +import com.lframework.xingyun.sc.vo.statistics.shipmentDetail.QueryShipmentDetailStatisticsVo; | ||
| 18 | + | ||
| 19 | +import java.util.List; | ||
| 20 | +import java.util.stream.Collectors; | ||
| 21 | + | ||
| 22 | + | ||
| 23 | +public class OrderDetailReportExportTaskWorker implements | ||
| 24 | + ExportTaskWorker<QueryOrderDetailReportVo, QueryOrderDetailReportBo, OrderDetailStatisticsModel> { | ||
| 25 | + | ||
| 26 | + | ||
| 27 | + @Override | ||
| 28 | + public QueryOrderDetailReportVo parseParams(String json) { | ||
| 29 | + return JsonUtil.parseObject(json, QueryOrderDetailReportVo.class); | ||
| 30 | + } | ||
| 31 | + | ||
| 32 | + @Override | ||
| 33 | + public PageResult<QueryOrderDetailReportBo> getDataList(int pageIndex, int pageSize, QueryOrderDetailReportVo params) { | ||
| 34 | + OrderDetailReportService orderDetailReportService = ApplicationUtil.getBean(OrderDetailReportService.class); | ||
| 35 | + PageResult<OrderDetailReport> pageResult = orderDetailReportService.query(pageIndex, pageSize, params); | ||
| 36 | + List<QueryOrderDetailReportBo> results = null; | ||
| 37 | + if (!CollectionUtil.isEmpty(pageResult.getDatas())) { | ||
| 38 | + results = pageResult.getDatas().stream().map(QueryOrderDetailReportBo::new).collect(Collectors.toList()); | ||
| 39 | + } | ||
| 40 | + return PageResultUtil.rebuild(pageResult, results); | ||
| 41 | + } | ||
| 42 | + | ||
| 43 | + @Override | ||
| 44 | + public OrderDetailStatisticsModel exportData(QueryOrderDetailReportBo data) { | ||
| 45 | + // 公差数据处理 | ||
| 46 | + String thicknessTol = CommonUtil.handleTolData( | ||
| 47 | + data.getThicknessTolPos() != null ? data.getThicknessTolPos().doubleValue() : null, | ||
| 48 | + data.getThicknessTolNeg() != null ? data.getThicknessTolNeg().doubleValue() : null); | ||
| 49 | + String widthTol = CommonUtil.handleTolData( | ||
| 50 | + data.getWidthTolPos() != null ? data.getWidthTolPos().doubleValue() : null, | ||
| 51 | + data.getWidthTolNeg() != null ? data.getWidthTolNeg().doubleValue() : null); | ||
| 52 | + String lengthTol = CommonUtil.handleTolData( | ||
| 53 | + data.getLengthTolPos() != null ? data.getLengthTolPos().doubleValue() : null, | ||
| 54 | + data.getLengthTolNeg() != null ? data.getLengthTolNeg().doubleValue() : null); | ||
| 55 | + | ||
| 56 | + OrderDetailStatisticsModel model = JsonUtil.parseObject(JsonUtil.toJsonString(data), OrderDetailStatisticsModel.class); | ||
| 57 | + model.setThicknessTol(thicknessTol); | ||
| 58 | + model.setWidthTol(widthTol); | ||
| 59 | + model.setLengthTol(lengthTol); | ||
| 60 | + return model; | ||
| 61 | + } | ||
| 62 | + | ||
| 63 | + @Override | ||
| 64 | + public Class<OrderDetailStatisticsModel> getModelClass() { | ||
| 65 | + return OrderDetailStatisticsModel.class; | ||
| 66 | + } | ||
| 67 | +} |
xingyun-sc/src/main/java/com/lframework/xingyun/sc/excel/statistics/OrderDetailStatisticsModel.java
0 → 100644
| 1 | +package com.lframework.xingyun.sc.excel.statistics; | ||
| 2 | + | ||
| 3 | +import com.alibaba.excel.annotation.ExcelProperty; | ||
| 4 | +import com.lframework.starter.web.core.components.excel.ExcelModel; | ||
| 5 | +import lombok.Data; | ||
| 6 | +import java.math.BigDecimal; | ||
| 7 | + | ||
| 8 | +/** | ||
| 9 | + * <p> | ||
| 10 | + * 发货明细Excel Model | ||
| 11 | + * </p> | ||
| 12 | + * | ||
| 13 | + */ | ||
| 14 | +@Data | ||
| 15 | +public class OrderDetailStatisticsModel implements ExcelModel { | ||
| 16 | + | ||
| 17 | + /** | ||
| 18 | + * 订货金额 | ||
| 19 | + */ | ||
| 20 | + @ExcelProperty("订货金额") | ||
| 21 | + private String amount; | ||
| 22 | + | ||
| 23 | + /** | ||
| 24 | + * 超协金额 | ||
| 25 | + */ | ||
| 26 | + @ExcelProperty("超协金额") | ||
| 27 | + private String superCoordinationAmount; | ||
| 28 | + | ||
| 29 | + /** | ||
| 30 | + * 折65金额 | ||
| 31 | + */ | ||
| 32 | + @ExcelProperty("折65金额") | ||
| 33 | + private String discountAmount; | ||
| 34 | + | ||
| 35 | + /** | ||
| 36 | + * 订货日期 | ||
| 37 | + */ | ||
| 38 | + @ExcelProperty("订货日期") | ||
| 39 | + private String orderDate1; | ||
| 40 | + | ||
| 41 | + /** | ||
| 42 | + * 订单编号 | ||
| 43 | + */ | ||
| 44 | + @ExcelProperty("订单编号") | ||
| 45 | + private String orderNo; | ||
| 46 | + | ||
| 47 | + /** | ||
| 48 | + * 包装金额 | ||
| 49 | + */ | ||
| 50 | + @ExcelProperty("包装金额") | ||
| 51 | + private String packagingAmount; | ||
| 52 | + | ||
| 53 | + /** | ||
| 54 | + * 当日电铜 | ||
| 55 | + */ | ||
| 56 | + @ExcelProperty("当日电铜") | ||
| 57 | + private String sameDayCopper; | ||
| 58 | + | ||
| 59 | + /** | ||
| 60 | + * 订货日期 | ||
| 61 | + */ | ||
| 62 | + @ExcelProperty("订货日期") | ||
| 63 | + private String orderDate; | ||
| 64 | + | ||
| 65 | + /** | ||
| 66 | + * 生产厂 | ||
| 67 | + */ | ||
| 68 | + @ExcelProperty("生产厂") | ||
| 69 | + private String workshopName; | ||
| 70 | + | ||
| 71 | + /** | ||
| 72 | + * 科办 | ||
| 73 | + */ | ||
| 74 | + @ExcelProperty("科办") | ||
| 75 | + private String deptName; | ||
| 76 | + | ||
| 77 | + /** | ||
| 78 | + * 片 | ||
| 79 | + */ | ||
| 80 | + @ExcelProperty("片") | ||
| 81 | + private String regionName; | ||
| 82 | + | ||
| 83 | + /** | ||
| 84 | + * 订货单位名称 | ||
| 85 | + */ | ||
| 86 | + @ExcelProperty("订货单位名称") | ||
| 87 | + private String orderingUnitName; | ||
| 88 | + | ||
| 89 | + /** | ||
| 90 | + * 行业(用途) | ||
| 91 | + */ | ||
| 92 | + @ExcelProperty("行业(用途)") | ||
| 93 | + private String industry; | ||
| 94 | + | ||
| 95 | + /** | ||
| 96 | + * 高新标识 | ||
| 97 | + */ | ||
| 98 | + @ExcelProperty("高新标识") | ||
| 99 | + private String highTechLogo; | ||
| 100 | + | ||
| 101 | + /** | ||
| 102 | + * 牌号 | ||
| 103 | + */ | ||
| 104 | + @ExcelProperty("牌号") | ||
| 105 | + private String brand; | ||
| 106 | + | ||
| 107 | + /** | ||
| 108 | + * 厚 | ||
| 109 | + */ | ||
| 110 | + @ExcelProperty("厚") | ||
| 111 | + private BigDecimal thickness; | ||
| 112 | + | ||
| 113 | + /** | ||
| 114 | + * 厚差 | ||
| 115 | + */ | ||
| 116 | + @ExcelProperty("厚差") | ||
| 117 | + private String thicknessTol; | ||
| 118 | + | ||
| 119 | + /** | ||
| 120 | + * 宽 | ||
| 121 | + */ | ||
| 122 | + @ExcelProperty("宽") | ||
| 123 | + private BigDecimal width; | ||
| 124 | + | ||
| 125 | + /** | ||
| 126 | + * 宽差 | ||
| 127 | + */ | ||
| 128 | + @ExcelProperty("宽差") | ||
| 129 | + private String widthTol; | ||
| 130 | + | ||
| 131 | + /** | ||
| 132 | + * 长 | ||
| 133 | + */ | ||
| 134 | + @ExcelProperty("长") | ||
| 135 | + private BigDecimal length; | ||
| 136 | + | ||
| 137 | + /** | ||
| 138 | + * 长差 | ||
| 139 | + */ | ||
| 140 | + @ExcelProperty("长差") | ||
| 141 | + private String lengthTol; | ||
| 142 | + | ||
| 143 | + /** | ||
| 144 | + * 状态 | ||
| 145 | + */ | ||
| 146 | + @ExcelProperty("状态") | ||
| 147 | + private String status; | ||
| 148 | + | ||
| 149 | + /** | ||
| 150 | + * 数量 | ||
| 151 | + */ | ||
| 152 | + @ExcelProperty("数量") | ||
| 153 | + private BigDecimal quantity; | ||
| 154 | + | ||
| 155 | + /** | ||
| 156 | + * 指导价 | ||
| 157 | + */ | ||
| 158 | + @ExcelProperty("指导价") | ||
| 159 | + private String suggestedPrice; | ||
| 160 | + | ||
| 161 | + /** | ||
| 162 | + * 发货日期 | ||
| 163 | + */ | ||
| 164 | + @ExcelProperty("发货日期") | ||
| 165 | + private String deliveryDate; | ||
| 166 | + | ||
| 167 | + /** | ||
| 168 | + * 超协价 | ||
| 169 | + */ | ||
| 170 | + @ExcelProperty("超协价") | ||
| 171 | + private String assessmentExceedsAgreement; | ||
| 172 | + | ||
| 173 | + /** | ||
| 174 | + * 当日南海H65 | ||
| 175 | + */ | ||
| 176 | + @ExcelProperty("当日南海H65") | ||
| 177 | + private String H65; | ||
| 178 | + | ||
| 179 | + /** | ||
| 180 | + * 销售价 | ||
| 181 | + */ | ||
| 182 | + @ExcelProperty("销售价") | ||
| 183 | + private String salesPrice; | ||
| 184 | + | ||
| 185 | + /** | ||
| 186 | + * 价格表编号 | ||
| 187 | + */ | ||
| 188 | + @ExcelProperty("价格表编号") | ||
| 189 | + private String priceListNo; | ||
| 190 | + | ||
| 191 | + /** | ||
| 192 | + * 包装费 | ||
| 193 | + */ | ||
| 194 | + @ExcelProperty("包装费") | ||
| 195 | + private String packagingFee; | ||
| 196 | + | ||
| 197 | + /** | ||
| 198 | + * 开票情况 | ||
| 199 | + */ | ||
| 200 | + @ExcelProperty("开票情况") | ||
| 201 | + private String invoicingStatus; | ||
| 202 | + | ||
| 203 | + /** | ||
| 204 | + * 件重条头 | ||
| 205 | + */ | ||
| 206 | + @ExcelProperty("件重条头") | ||
| 207 | + private String pieceWeightHeader; | ||
| 208 | + | ||
| 209 | + /** | ||
| 210 | + * 表面 | ||
| 211 | + */ | ||
| 212 | + @ExcelProperty("表面") | ||
| 213 | + private String surface; | ||
| 214 | + | ||
| 215 | + /** | ||
| 216 | + * 公差 | ||
| 217 | + */ | ||
| 218 | + @ExcelProperty("公差") | ||
| 219 | + private String tolerance; | ||
| 220 | + | ||
| 221 | + /** | ||
| 222 | + * 性能 | ||
| 223 | + */ | ||
| 224 | + @ExcelProperty("性能") | ||
| 225 | + private String performance; | ||
| 226 | + | ||
| 227 | + /** | ||
| 228 | + * 包装 | ||
| 229 | + */ | ||
| 230 | + @ExcelProperty("包装") | ||
| 231 | + private String packaging; | ||
| 232 | + | ||
| 233 | + /** | ||
| 234 | + * 特别注重要求 | ||
| 235 | + */ | ||
| 236 | + @ExcelProperty("特别注重要求") | ||
| 237 | + private String specialRequirements; | ||
| 238 | + | ||
| 239 | + /** | ||
| 240 | + * 备注 | ||
| 241 | + */ | ||
| 242 | + @ExcelProperty("备注") | ||
| 243 | + private String remarks; | ||
| 244 | + | ||
| 245 | + /** | ||
| 246 | + * 当日锌锭 | ||
| 247 | + */ | ||
| 248 | + @ExcelProperty("当日锌锭") | ||
| 249 | + private String zincDay; | ||
| 250 | + | ||
| 251 | + /** | ||
| 252 | + * 运费 | ||
| 253 | + */ | ||
| 254 | + @ExcelProperty("运费") | ||
| 255 | + private String shippingCost; | ||
| 256 | + | ||
| 257 | + /** | ||
| 258 | + * 回程运费 | ||
| 259 | + */ | ||
| 260 | + @ExcelProperty("回程运费") | ||
| 261 | + private String returnShippingCost; | ||
| 262 | + | ||
| 263 | + /** | ||
| 264 | + * 客户类型 | ||
| 265 | + */ | ||
| 266 | + @ExcelProperty("客户类型") | ||
| 267 | + private String customerType; | ||
| 268 | + | ||
| 269 | + /** | ||
| 270 | + * 标准行业 | ||
| 271 | + */ | ||
| 272 | + @ExcelProperty("标准行业") | ||
| 273 | + private String quality; | ||
| 274 | + | ||
| 275 | + /** | ||
| 276 | + * 加工经销 | ||
| 277 | + */ | ||
| 278 | + @ExcelProperty("加工经销") | ||
| 279 | + private String contractType; | ||
| 280 | + | ||
| 281 | + /** | ||
| 282 | + * 备货单位/人(生产标准) | ||
| 283 | + */ | ||
| 284 | + @ExcelProperty("备货单位/人(生产标准)") | ||
| 285 | + private String stockUpCompanyName; | ||
| 286 | + | ||
| 287 | + /** | ||
| 288 | + * 订单类型 | ||
| 289 | + */ | ||
| 290 | + @ExcelProperty("订单类型") | ||
| 291 | + private String orderType; | ||
| 292 | + | ||
| 293 | +} |
| @@ -15,29 +15,29 @@ import com.lframework.starter.web.core.components.resp.PageResult; | @@ -15,29 +15,29 @@ import com.lframework.starter.web.core.components.resp.PageResult; | ||
| 15 | import com.lframework.starter.web.core.utils.OpLogUtil; | 15 | import com.lframework.starter.web.core.utils.OpLogUtil; |
| 16 | import com.lframework.starter.common.utils.StringUtil; | 16 | import com.lframework.starter.common.utils.StringUtil; |
| 17 | import com.lframework.starter.common.exceptions.impl.DefaultClientException; | 17 | import com.lframework.starter.common.exceptions.impl.DefaultClientException; |
| 18 | - | ||
| 19 | import java.io.Serializable; | 18 | import java.io.Serializable; |
| 20 | - | ||
| 21 | import com.lframework.starter.web.core.utils.IdUtil; | 19 | import com.lframework.starter.web.core.utils.IdUtil; |
| 22 | import com.lframework.starter.common.utils.ObjectUtil; | 20 | import com.lframework.starter.common.utils.ObjectUtil; |
| 23 | import com.lframework.starter.web.core.annotations.oplog.OpLog; | 21 | import com.lframework.starter.web.core.annotations.oplog.OpLog; |
| 24 | import com.lframework.starter.web.core.utils.PageHelperUtil; | 22 | import com.lframework.starter.web.core.utils.PageHelperUtil; |
| 25 | import com.lframework.starter.common.utils.Assert; | 23 | import com.lframework.starter.common.utils.Assert; |
| 26 | import com.lframework.starter.web.inner.components.oplog.OtherOpLogType; | 24 | import com.lframework.starter.web.inner.components.oplog.OtherOpLogType; |
| 25 | +import com.lframework.starter.web.inner.entity.SysDataDicItem; | ||
| 26 | +import com.lframework.starter.web.inner.service.system.SysDataDicItemService; | ||
| 27 | import com.lframework.xingyun.basedata.entity.Workshop; | 27 | import com.lframework.xingyun.basedata.entity.Workshop; |
| 28 | import com.lframework.xingyun.basedata.service.workshop.WorkshopService; | 28 | import com.lframework.xingyun.basedata.service.workshop.WorkshopService; |
| 29 | -import com.lframework.xingyun.sc.entity.ContractDistributorStandard; | ||
| 30 | -import com.lframework.xingyun.sc.entity.CustomerCredit; | ||
| 31 | -import com.lframework.xingyun.sc.entity.PurchaseOrderInfo; | ||
| 32 | -import com.lframework.xingyun.sc.entity.PurchaseOrderLine; | 29 | +import com.lframework.xingyun.sc.entity.*; |
| 33 | import com.lframework.xingyun.sc.enums.OrderSpecChangeStatus; | 30 | import com.lframework.xingyun.sc.enums.OrderSpecChangeStatus; |
| 34 | import com.lframework.xingyun.sc.mappers.PurchaseOrderInfoMapper; | 31 | import com.lframework.xingyun.sc.mappers.PurchaseOrderInfoMapper; |
| 35 | import com.lframework.xingyun.sc.service.contract.ContractDistributorStandardService; | 32 | import com.lframework.xingyun.sc.service.contract.ContractDistributorStandardService; |
| 33 | +import com.lframework.xingyun.sc.service.contract.ContractStdProcessingLineService; | ||
| 36 | import com.lframework.xingyun.sc.service.customer.CustomerCreditService; | 34 | import com.lframework.xingyun.sc.service.customer.CustomerCreditService; |
| 37 | import com.lframework.xingyun.sc.service.order.PurchaseOrderInfoService; | 35 | import com.lframework.xingyun.sc.service.order.PurchaseOrderInfoService; |
| 38 | import com.lframework.xingyun.sc.service.order.PurchaseOrderLineService; | 36 | import com.lframework.xingyun.sc.service.order.PurchaseOrderLineService; |
| 37 | +import com.lframework.xingyun.sc.service.statistics.OrderDetailReportService; | ||
| 39 | import com.lframework.xingyun.sc.vo.customer.credit.QueryCustomerCreditVo; | 38 | import com.lframework.xingyun.sc.vo.customer.credit.QueryCustomerCreditVo; |
| 40 | import com.lframework.xingyun.sc.vo.order.*; | 39 | import com.lframework.xingyun.sc.vo.order.*; |
| 40 | +import com.lframework.xingyun.sc.vo.statistics.orderDetail.CreateOrderDetailReportVo; | ||
| 41 | import org.apache.commons.collections.CollectionUtils; | 41 | import org.apache.commons.collections.CollectionUtils; |
| 42 | import org.apache.commons.lang3.StringUtils; | 42 | import org.apache.commons.lang3.StringUtils; |
| 43 | import org.springframework.transaction.annotation.Transactional; | 43 | import org.springframework.transaction.annotation.Transactional; |
| @@ -66,6 +66,12 @@ public class PurchaseOrderInfoServiceImpl extends BaseMpServiceImpl<PurchaseOrde | @@ -66,6 +66,12 @@ public class PurchaseOrderInfoServiceImpl extends BaseMpServiceImpl<PurchaseOrde | ||
| 66 | private WorkshopService workshopService; | 66 | private WorkshopService workshopService; |
| 67 | @Resource | 67 | @Resource |
| 68 | private ContractDistributorStandardService contractDistributorStandardService; | 68 | private ContractDistributorStandardService contractDistributorStandardService; |
| 69 | + @Resource | ||
| 70 | + private SysDataDicItemService sysDataDicItemService; | ||
| 71 | + @Resource | ||
| 72 | + private ContractStdProcessingLineService contractStdProcessingLineService; | ||
| 73 | + @Resource | ||
| 74 | + private OrderDetailReportService orderDetailReportService; | ||
| 69 | 75 | ||
| 70 | @Override | 76 | @Override |
| 71 | public PageResult<PurchaseOrderInfo> query(Integer pageIndex, Integer pageSize, QueryPurchaseOrderInfoVo vo) { | 77 | public PageResult<PurchaseOrderInfo> query(Integer pageIndex, Integer pageSize, QueryPurchaseOrderInfoVo vo) { |
| @@ -267,10 +273,120 @@ public class PurchaseOrderInfoServiceImpl extends BaseMpServiceImpl<PurchaseOrde | @@ -267,10 +273,120 @@ public class PurchaseOrderInfoServiceImpl extends BaseMpServiceImpl<PurchaseOrde | ||
| 267 | if (!vo.isNoFlowInstance()) { | 273 | if (!vo.isNoFlowInstance()) { |
| 268 | flowInstanceWrapperService.startInstance(BPM_FLAG, data.getId(), BPM_FLAG, data); | 274 | flowInstanceWrapperService.startInstance(BPM_FLAG, data.getId(), BPM_FLAG, data); |
| 269 | } | 275 | } |
| 276 | + //生成订单明细报表 | ||
| 277 | + createOrderDetailReport(data.getId()); | ||
| 270 | 278 | ||
| 271 | return data.getId(); | 279 | return data.getId(); |
| 272 | } | 280 | } |
| 273 | 281 | ||
| 282 | + private void createOrderDetailReport(String businessId) { | ||
| 283 | + PurchaseOrderInfo purchaseOrderInfo = this.findById(businessId); | ||
| 284 | + ContractDistributorStandard standard = contractDistributorStandardService.findById(purchaseOrderInfo.getContractId()); | ||
| 285 | + CustomerCredit customerCredit = customerCreditService.findById(purchaseOrderInfo.getCustomerCreditId()); | ||
| 286 | + QueryPurchaseOrderLineVo vo1 = new QueryPurchaseOrderLineVo(); | ||
| 287 | + vo1.setPurchaseOrderId(purchaseOrderInfo.getId()); | ||
| 288 | + List<PurchaseOrderLine> lineVoList = purchaseOrderLineService.query(vo1); | ||
| 289 | + if (CollectionUtils.isNotEmpty(lineVoList)) { | ||
| 290 | + for (PurchaseOrderLine line : lineVoList) { | ||
| 291 | + CreateOrderDetailReportVo vo = new CreateOrderDetailReportVo(); | ||
| 292 | + vo.setPurchaseOrderLineId(line.getId()); | ||
| 293 | + vo.setOrderNo(purchaseOrderInfo.getOrderNo()); | ||
| 294 | + vo.setOrderDate(purchaseOrderInfo.getOrderDate()); | ||
| 295 | + vo.setWorkshopId(purchaseOrderInfo.getWorkshopId()); | ||
| 296 | + vo.setDeptName(purchaseOrderInfo.getDeptName()); | ||
| 297 | + vo.setRegionName(purchaseOrderInfo.getRegionName()); | ||
| 298 | + vo.setOrderingUnitName(purchaseOrderInfo.getOrderingUnitName()); | ||
| 299 | + vo.setIndustry(line.getIndustry()); | ||
| 300 | + vo.setBrand(line.getBrand()); | ||
| 301 | + vo.setThickness(line.getThickness()); | ||
| 302 | + vo.setThicknessTolPos(line.getThicknessTolPos()); | ||
| 303 | + vo.setThicknessTolNeg(line.getThicknessTolNeg()); | ||
| 304 | + vo.setWidth(line.getWidth()); | ||
| 305 | + vo.setWidthTolPos(line.getWidthTolPos()); | ||
| 306 | + vo.setWidthTolNeg(line.getWidthTolNeg()); | ||
| 307 | + vo.setLength(line.getLength()); | ||
| 308 | + vo.setLengthTolPos(line.getLengthTolPos()); | ||
| 309 | + vo.setLengthTolNeg(line.getLengthTolNeg()); | ||
| 310 | + vo.setStatus(line.getStatus()); | ||
| 311 | + vo.setQuantity(line.getQuantity()); | ||
| 312 | + String assessmentExceedsAgreement; | ||
| 313 | + BigDecimal salesPrice = line.getSalesPrice(); | ||
| 314 | + if (line.getSalesPrice() != null && StringUtils.isNotEmpty(line.getAssessmentExceedsAgreement())) { | ||
| 315 | + assessmentExceedsAgreement = line.getAssessmentExceedsAgreement().trim(); | ||
| 316 | + try { | ||
| 317 | + BigDecimal exceedsAgreement = new BigDecimal(assessmentExceedsAgreement); | ||
| 318 | + BigDecimal divisor = new BigDecimal("1000"); | ||
| 319 | + BigDecimal adjustment = exceedsAgreement.divide(divisor, 4, RoundingMode.HALF_UP); // 保留4位小数 | ||
| 320 | + BigDecimal subtract = salesPrice.subtract(adjustment); | ||
| 321 | + vo.setSuggestedPrice(subtract.toPlainString()); | ||
| 322 | + } catch (NumberFormatException e) { | ||
| 323 | + // 日志记录或按业务处理:超协价格式无效,忽略计算 | ||
| 324 | + log.error("超协价格式错误,使用原始销售价。value=" + assessmentExceedsAgreement); | ||
| 325 | + } | ||
| 326 | + } | ||
| 327 | + vo.setDeliveryDate(line.getDeliveryDate()); | ||
| 328 | + vo.setAssessmentExceedsAgreement(line.getAssessmentExceedsAgreement()); | ||
| 329 | + vo.setSalesPrice(line.getSalesPrice().toPlainString()); | ||
| 330 | + vo.setPriceListNo(purchaseOrderInfo.getPriceListNo()); | ||
| 331 | + vo.setPackagingFee(line.getPackagingFee().toPlainString()); | ||
| 332 | + vo.setInvoicingStatus(purchaseOrderInfo.getInvoicingStatus()); | ||
| 333 | + vo.setPieceWeightHeader(purchaseOrderInfo.getPieceWeightHeader()); | ||
| 334 | + vo.setSurface(purchaseOrderInfo.getSurface()); | ||
| 335 | + vo.setTolerance(purchaseOrderInfo.getTolerance()); | ||
| 336 | + vo.setPerformance(purchaseOrderInfo.getPerformance()); | ||
| 337 | + vo.setPackaging(purchaseOrderInfo.getPackaging()); | ||
| 338 | + vo.setRemarks(purchaseOrderInfo.getRemarks()); | ||
| 339 | + //加工合同就是回程运费 | ||
| 340 | + String type = standard.getType(); | ||
| 341 | + if ("PROCESS_STD_AGMT".equals(type)) { | ||
| 342 | + vo.setReturnShippingCost(purchaseOrderInfo.getShippingCost()); | ||
| 343 | + } else { | ||
| 344 | + vo.setShippingCost(purchaseOrderInfo.getShippingCost()); | ||
| 345 | + } | ||
| 346 | + if (customerCredit != null) { | ||
| 347 | + SysDataDicItem dataDicItem = sysDataDicItemService.findByCode("ENTERPRISE_TYPE", customerCredit.getEnterpriseType()); | ||
| 348 | + if (dataDicItem != null) { | ||
| 349 | + vo.setCustomerType(dataDicItem.getName()); | ||
| 350 | + } | ||
| 351 | + } | ||
| 352 | + vo.setQuality(line.getQuality()); | ||
| 353 | + String contractType = handleContractType(type); | ||
| 354 | + vo.setContractType(contractType); | ||
| 355 | + if ("加工".equals(contractType)) { | ||
| 356 | + String contractDistributorLineId = line.getContractDistributorLineId(); | ||
| 357 | + ContractStdProcessingLine processingLine = contractStdProcessingLineService.findById(contractDistributorLineId); | ||
| 358 | + | ||
| 359 | + if (processingLine != null) { | ||
| 360 | + String materialProductRatio = processingLine.getMaterialProductRatio(); | ||
| 361 | + SysDataDicItem dataDicItem = sysDataDicItemService.findByCode("RAW_TO_PROD_RATIO", materialProductRatio); | ||
| 362 | + | ||
| 363 | + if (dataDicItem != null) { | ||
| 364 | + vo.setContractType(dataDicItem.getName() + contractType); | ||
| 365 | + } | ||
| 366 | + } | ||
| 367 | + } | ||
| 368 | + vo.setStockUpCompanyName(purchaseOrderInfo.getStockUpCompanyName()); | ||
| 369 | +// vo.setOrderType(); | ||
| 370 | + vo.setShowOrder(0); | ||
| 371 | + orderDetailReportService.create(vo); | ||
| 372 | + } | ||
| 373 | + } | ||
| 374 | + } | ||
| 375 | + | ||
| 376 | + private String handleContractType(String contractType) { | ||
| 377 | + String result = ""; | ||
| 378 | + if ("DISTRIB_STD".equals(contractType) || "DIST_STOCK_CONTRACT".equals(contractType) | ||
| 379 | + || "DRAFT_DIST_AGMT".equals(contractType)) { | ||
| 380 | + result = "经销"; | ||
| 381 | + } else if ("INTL_STD_CONTRACT".equals(contractType) || "INTL_INVENTORY_AGMT".equals(contractType) | ||
| 382 | + || "INTL_OPEN_SPEC_AGMT".equals(contractType)) { | ||
| 383 | + result = "外贸"; | ||
| 384 | + } else if ("PROCESS_STD_AGMT".equals(contractType)) { | ||
| 385 | + result = "加工"; | ||
| 386 | + } | ||
| 387 | + return result; | ||
| 388 | + } | ||
| 389 | + | ||
| 274 | @OpLog(type = OtherOpLogType.class, name = "修改订货单表,ID:{}", params = {"#id"}) | 390 | @OpLog(type = OtherOpLogType.class, name = "修改订货单表,ID:{}", params = {"#id"}) |
| 275 | @Transactional(rollbackFor = Exception.class) | 391 | @Transactional(rollbackFor = Exception.class) |
| 276 | @Override | 392 | @Override |
xingyun-sc/src/main/java/com/lframework/xingyun/sc/impl/statistics/OrderDetailReportServiceImpl.java
0 → 100644
| 1 | +package com.lframework.xingyun.sc.impl.statistics; | ||
| 2 | + | ||
| 3 | +import com.github.pagehelper.PageInfo; | ||
| 4 | +import com.lframework.starter.web.core.impl.BaseMpServiceImpl; | ||
| 5 | +import com.lframework.starter.web.core.utils.PageResultUtil; | ||
| 6 | +import com.lframework.starter.web.core.components.resp.PageResult; | ||
| 7 | +import com.lframework.starter.web.core.utils.OpLogUtil; | ||
| 8 | +import com.lframework.starter.common.utils.StringUtil; | ||
| 9 | +import java.io.Serializable; | ||
| 10 | +import com.lframework.starter.web.core.utils.IdUtil; | ||
| 11 | +import com.lframework.starter.web.core.annotations.oplog.OpLog; | ||
| 12 | +import com.lframework.starter.web.core.utils.PageHelperUtil; | ||
| 13 | +import com.lframework.starter.common.utils.Assert; | ||
| 14 | +import com.lframework.starter.web.inner.components.oplog.OtherOpLogType; | ||
| 15 | +import com.lframework.starter.web.inner.entity.SysDataDicItem; | ||
| 16 | +import com.lframework.starter.web.inner.service.system.SysDataDicItemService; | ||
| 17 | +import com.lframework.xingyun.sc.entity.*; | ||
| 18 | +import com.lframework.xingyun.sc.mappers.OrderDetailReportMapper; | ||
| 19 | +import com.lframework.xingyun.sc.service.contract.ContractDistributorStandardService; | ||
| 20 | +import com.lframework.xingyun.sc.service.contract.ContractStdProcessingLineService; | ||
| 21 | +import com.lframework.xingyun.sc.service.customer.CustomerCreditService; | ||
| 22 | +import com.lframework.xingyun.sc.service.order.PurchaseOrderInfoService; | ||
| 23 | +import com.lframework.xingyun.sc.service.order.PurchaseOrderLineService; | ||
| 24 | +import com.lframework.xingyun.sc.service.statistics.OrderDetailReportService; | ||
| 25 | +import com.lframework.xingyun.sc.vo.order.QueryPurchaseOrderInfoVo; | ||
| 26 | +import com.lframework.xingyun.sc.vo.order.QueryPurchaseOrderLineVo; | ||
| 27 | +import com.lframework.xingyun.sc.vo.statistics.orderDetail.CreateOrderDetailReportVo; | ||
| 28 | +import com.lframework.xingyun.sc.vo.statistics.orderDetail.QueryOrderDetailReportVo; | ||
| 29 | +import org.apache.commons.collections.CollectionUtils; | ||
| 30 | +import org.apache.commons.lang3.StringUtils; | ||
| 31 | +import org.springframework.stereotype.Service; | ||
| 32 | +import org.springframework.transaction.annotation.Transactional; | ||
| 33 | + | ||
| 34 | +import javax.annotation.Resource; | ||
| 35 | +import java.math.BigDecimal; | ||
| 36 | +import java.math.RoundingMode; | ||
| 37 | +import java.util.List; | ||
| 38 | + | ||
| 39 | +@Service | ||
| 40 | +public class OrderDetailReportServiceImpl extends BaseMpServiceImpl<OrderDetailReportMapper, OrderDetailReport> implements OrderDetailReportService { | ||
| 41 | + @Resource | ||
| 42 | + private PurchaseOrderInfoService purchaseOrderInfoService; | ||
| 43 | + @Resource | ||
| 44 | + private ContractDistributorStandardService contractDistributorStandardService; | ||
| 45 | + @Resource | ||
| 46 | + private CustomerCreditService customerCreditService; | ||
| 47 | + @Resource | ||
| 48 | + private PurchaseOrderLineService purchaseOrderLineService; | ||
| 49 | + @Resource | ||
| 50 | + private SysDataDicItemService sysDataDicItemService; | ||
| 51 | + @Resource | ||
| 52 | + private ContractStdProcessingLineService contractStdProcessingLineService; | ||
| 53 | + @Resource | ||
| 54 | + private OrderDetailReportService orderDetailReportService; | ||
| 55 | + | ||
| 56 | + @Override | ||
| 57 | + public PageResult<OrderDetailReport> query(Integer pageIndex, Integer pageSize, QueryOrderDetailReportVo vo) { | ||
| 58 | + | ||
| 59 | + Assert.greaterThanZero(pageIndex); | ||
| 60 | + Assert.greaterThanZero(pageSize); | ||
| 61 | + | ||
| 62 | + PageHelperUtil.startPage(pageIndex, pageSize); | ||
| 63 | + List<OrderDetailReport> datas = this.query(vo); | ||
| 64 | + | ||
| 65 | + return PageResultUtil.convert(new PageInfo<>(datas)); | ||
| 66 | + } | ||
| 67 | + | ||
| 68 | + @Override | ||
| 69 | + public List<OrderDetailReport> query(QueryOrderDetailReportVo vo) { | ||
| 70 | + | ||
| 71 | + return getBaseMapper().query(vo); | ||
| 72 | + } | ||
| 73 | + | ||
| 74 | + @Override | ||
| 75 | + public OrderDetailReport findById(String id) { | ||
| 76 | + | ||
| 77 | + return getBaseMapper().selectById(id); | ||
| 78 | + } | ||
| 79 | + | ||
| 80 | + @OpLog(type = OtherOpLogType.class, name = "新增订单明细,ID:{}", params = {"#id"}) | ||
| 81 | + @Transactional(rollbackFor = Exception.class) | ||
| 82 | + @Override | ||
| 83 | + public String create(CreateOrderDetailReportVo vo) { | ||
| 84 | + | ||
| 85 | + OrderDetailReport data = new OrderDetailReport(); | ||
| 86 | + data.setId(IdUtil.getId()); | ||
| 87 | + if (!StringUtil.isBlank(vo.getPurchaseOrderLineId())) { | ||
| 88 | + data.setPurchaseOrderLineId(vo.getPurchaseOrderLineId()); | ||
| 89 | + } | ||
| 90 | + if (!StringUtil.isBlank(vo.getOrderNo())) { | ||
| 91 | + data.setOrderNo(vo.getOrderNo()); | ||
| 92 | + } | ||
| 93 | + if (vo.getOrderDate() != null) { | ||
| 94 | + data.setOrderDate(vo.getOrderDate()); | ||
| 95 | + } | ||
| 96 | + if (!StringUtil.isBlank(vo.getWorkshopId())) { | ||
| 97 | + data.setWorkshopId(vo.getWorkshopId()); | ||
| 98 | + } | ||
| 99 | + if (!StringUtil.isBlank(vo.getDeptName())) { | ||
| 100 | + data.setDeptName(vo.getDeptName()); | ||
| 101 | + } | ||
| 102 | + if (!StringUtil.isBlank(vo.getRegionName())) { | ||
| 103 | + data.setRegionName(vo.getRegionName()); | ||
| 104 | + } | ||
| 105 | + if (!StringUtil.isBlank(vo.getOrderingUnitName())) { | ||
| 106 | + data.setOrderingUnitName(vo.getOrderingUnitName()); | ||
| 107 | + } | ||
| 108 | + if (!StringUtil.isBlank(vo.getIndustry())) { | ||
| 109 | + data.setIndustry(vo.getIndustry()); | ||
| 110 | + } | ||
| 111 | + if (!StringUtil.isBlank(vo.getBrand())) { | ||
| 112 | + data.setBrand(vo.getBrand()); | ||
| 113 | + } | ||
| 114 | + if (vo.getThickness() != null) { | ||
| 115 | + data.setThickness(vo.getThickness()); | ||
| 116 | + } | ||
| 117 | + if (vo.getThicknessTolPos() != null) { | ||
| 118 | + data.setThicknessTolPos(vo.getThicknessTolPos()); | ||
| 119 | + } | ||
| 120 | + if (vo.getThicknessTolNeg() != null) { | ||
| 121 | + data.setThicknessTolNeg(vo.getThicknessTolNeg()); | ||
| 122 | + } | ||
| 123 | + if (vo.getWidth() != null) { | ||
| 124 | + data.setWidth(vo.getWidth()); | ||
| 125 | + } | ||
| 126 | + if (vo.getWidthTolPos() != null) { | ||
| 127 | + data.setWidthTolPos(vo.getWidthTolPos()); | ||
| 128 | + } | ||
| 129 | + if (vo.getWidthTolNeg() != null) { | ||
| 130 | + data.setWidthTolNeg(vo.getWidthTolNeg()); | ||
| 131 | + } | ||
| 132 | + if (vo.getLength() != null) { | ||
| 133 | + data.setLength(vo.getLength()); | ||
| 134 | + } | ||
| 135 | + if (vo.getLengthTolPos() != null) { | ||
| 136 | + data.setLengthTolPos(vo.getLengthTolPos()); | ||
| 137 | + } | ||
| 138 | + if (vo.getLengthTolNeg() != null) { | ||
| 139 | + data.setLengthTolNeg(vo.getLengthTolNeg()); | ||
| 140 | + } | ||
| 141 | + if (!StringUtil.isBlank(vo.getStatus())) { | ||
| 142 | + data.setStatus(vo.getStatus()); | ||
| 143 | + } | ||
| 144 | + if (vo.getQuantity() != null) { | ||
| 145 | + data.setQuantity(vo.getQuantity()); | ||
| 146 | + } | ||
| 147 | + if (!StringUtil.isBlank(vo.getSuggestedPrice())) { | ||
| 148 | + data.setSuggestedPrice(vo.getSuggestedPrice()); | ||
| 149 | + } | ||
| 150 | + if (vo.getDeliveryDate() != null) { | ||
| 151 | + data.setDeliveryDate(vo.getDeliveryDate()); | ||
| 152 | + } | ||
| 153 | + if (!StringUtil.isBlank(vo.getAssessmentExceedsAgreement())) { | ||
| 154 | + data.setAssessmentExceedsAgreement(vo.getAssessmentExceedsAgreement()); | ||
| 155 | + } | ||
| 156 | + if (!StringUtil.isBlank(vo.getSalesPrice())) { | ||
| 157 | + data.setSalesPrice(vo.getSalesPrice()); | ||
| 158 | + } | ||
| 159 | + if (!StringUtil.isBlank(vo.getPriceListNo())) { | ||
| 160 | + data.setPriceListNo(vo.getPriceListNo()); | ||
| 161 | + } | ||
| 162 | + if (!StringUtil.isBlank(vo.getPackagingFee())) { | ||
| 163 | + data.setPackagingFee(vo.getPackagingFee()); | ||
| 164 | + } | ||
| 165 | + if (!StringUtil.isBlank(vo.getInvoicingStatus())) { | ||
| 166 | + data.setInvoicingStatus(vo.getInvoicingStatus()); | ||
| 167 | + } | ||
| 168 | + if (!StringUtil.isBlank(vo.getPieceWeightHeader())) { | ||
| 169 | + data.setPieceWeightHeader(vo.getPieceWeightHeader()); | ||
| 170 | + } | ||
| 171 | + if (!StringUtil.isBlank(vo.getSurface())) { | ||
| 172 | + data.setSurface(vo.getSurface()); | ||
| 173 | + } | ||
| 174 | + if (!StringUtil.isBlank(vo.getTolerance())) { | ||
| 175 | + data.setTolerance(vo.getTolerance()); | ||
| 176 | + } | ||
| 177 | + if (!StringUtil.isBlank(vo.getPerformance())) { | ||
| 178 | + data.setPerformance(vo.getPerformance()); | ||
| 179 | + } | ||
| 180 | + if (!StringUtil.isBlank(vo.getPackaging())) { | ||
| 181 | + data.setPackaging(vo.getPackaging()); | ||
| 182 | + } | ||
| 183 | + if (!StringUtil.isBlank(vo.getRemarks())) { | ||
| 184 | + data.setRemarks(vo.getRemarks()); | ||
| 185 | + } | ||
| 186 | + if (!StringUtil.isBlank(vo.getShippingCost())) { | ||
| 187 | + data.setShippingCost(vo.getShippingCost()); | ||
| 188 | + } | ||
| 189 | + if (!StringUtil.isBlank(vo.getReturnShippingCost())) { | ||
| 190 | + data.setReturnShippingCost(vo.getReturnShippingCost()); | ||
| 191 | + } | ||
| 192 | + if (!StringUtil.isBlank(vo.getCustomerType())) { | ||
| 193 | + data.setCustomerType(vo.getCustomerType()); | ||
| 194 | + } | ||
| 195 | + if (!StringUtil.isBlank(vo.getQuality())) { | ||
| 196 | + data.setQuality(vo.getQuality()); | ||
| 197 | + } | ||
| 198 | + if (!StringUtil.isBlank(vo.getContractType())) { | ||
| 199 | + data.setContractType(vo.getContractType()); | ||
| 200 | + } | ||
| 201 | + if (!StringUtil.isBlank(vo.getStockUpCompanyName())) { | ||
| 202 | + data.setStockUpCompanyName(vo.getStockUpCompanyName()); | ||
| 203 | + } | ||
| 204 | + if (!StringUtil.isBlank(vo.getOrderType())) { | ||
| 205 | + data.setOrderType(vo.getOrderType()); | ||
| 206 | + } | ||
| 207 | + if (vo.getShowOrder() != null) { | ||
| 208 | + data.setShowOrder(vo.getShowOrder()); | ||
| 209 | + } | ||
| 210 | + | ||
| 211 | + getBaseMapper().insert(data); | ||
| 212 | + | ||
| 213 | + OpLogUtil.setVariable("id", data.getId()); | ||
| 214 | + OpLogUtil.setExtra(vo); | ||
| 215 | + | ||
| 216 | + return data.getId(); | ||
| 217 | + } | ||
| 218 | + | ||
| 219 | + @Override | ||
| 220 | + public void processHistoricalData() { | ||
| 221 | + QueryPurchaseOrderInfoVo vo2 = new QueryPurchaseOrderInfoVo(); | ||
| 222 | + List<PurchaseOrderInfo> query = purchaseOrderInfoService.query(vo2); | ||
| 223 | + if (CollectionUtils.isNotEmpty(query)) { | ||
| 224 | + for (PurchaseOrderInfo purchaseOrderInfo : query) { | ||
| 225 | + ContractDistributorStandard standard = contractDistributorStandardService.findById(purchaseOrderInfo.getContractId()); | ||
| 226 | + CustomerCredit customerCredit = customerCreditService.findById(purchaseOrderInfo.getCustomerCreditId()); | ||
| 227 | + QueryPurchaseOrderLineVo vo1 = new QueryPurchaseOrderLineVo(); | ||
| 228 | + vo1.setPurchaseOrderId(purchaseOrderInfo.getId()); | ||
| 229 | + List<PurchaseOrderLine> lineVoList = purchaseOrderLineService.query(vo1); | ||
| 230 | + if (CollectionUtils.isNotEmpty(lineVoList)) { | ||
| 231 | + for (PurchaseOrderLine line : lineVoList) { | ||
| 232 | + CreateOrderDetailReportVo vo = new CreateOrderDetailReportVo(); | ||
| 233 | + vo.setPurchaseOrderLineId(line.getId()); | ||
| 234 | + vo.setOrderNo(purchaseOrderInfo.getOrderNo()); | ||
| 235 | + vo.setOrderDate(purchaseOrderInfo.getOrderDate()); | ||
| 236 | + vo.setWorkshopId(purchaseOrderInfo.getWorkshopId()); | ||
| 237 | + vo.setDeptName(purchaseOrderInfo.getDeptName()); | ||
| 238 | + vo.setRegionName(purchaseOrderInfo.getRegionName()); | ||
| 239 | + vo.setOrderingUnitName(purchaseOrderInfo.getOrderingUnitName()); | ||
| 240 | + vo.setIndustry(line.getIndustry()); | ||
| 241 | + vo.setBrand(line.getBrand()); | ||
| 242 | + vo.setThickness(line.getThickness()); | ||
| 243 | + vo.setThicknessTolPos(line.getThicknessTolPos()); | ||
| 244 | + vo.setThicknessTolNeg(line.getThicknessTolNeg()); | ||
| 245 | + vo.setWidth(line.getWidth()); | ||
| 246 | + vo.setWidthTolPos(line.getWidthTolPos()); | ||
| 247 | + vo.setWidthTolNeg(line.getWidthTolNeg()); | ||
| 248 | + vo.setLength(line.getLength()); | ||
| 249 | + vo.setLengthTolPos(line.getLengthTolPos()); | ||
| 250 | + vo.setLengthTolNeg(line.getLengthTolNeg()); | ||
| 251 | + vo.setStatus(line.getStatus()); | ||
| 252 | + vo.setQuantity(line.getQuantity()); | ||
| 253 | + String assessmentExceedsAgreement; | ||
| 254 | + BigDecimal salesPrice = line.getSalesPrice(); | ||
| 255 | + if (line.getSalesPrice() != null && StringUtils.isNotEmpty(line.getAssessmentExceedsAgreement())) { | ||
| 256 | + assessmentExceedsAgreement = line.getAssessmentExceedsAgreement().trim(); | ||
| 257 | + try { | ||
| 258 | + BigDecimal exceedsAgreement = new BigDecimal(assessmentExceedsAgreement); | ||
| 259 | + BigDecimal divisor = new BigDecimal("1000"); | ||
| 260 | + BigDecimal adjustment = exceedsAgreement.divide(divisor, 4, RoundingMode.HALF_UP); // 保留4位小数 | ||
| 261 | + BigDecimal subtract = salesPrice.subtract(adjustment); | ||
| 262 | + vo.setSuggestedPrice(subtract.toPlainString()); | ||
| 263 | + } catch (NumberFormatException e) { | ||
| 264 | + // 日志记录或按业务处理:超协价格式无效,忽略计算 | ||
| 265 | + log.error("assessmentExceedsAgreement====>" + assessmentExceedsAgreement); | ||
| 266 | + } | ||
| 267 | + } | ||
| 268 | + vo.setDeliveryDate(line.getDeliveryDate()); | ||
| 269 | + vo.setAssessmentExceedsAgreement(line.getAssessmentExceedsAgreement()); | ||
| 270 | + vo.setSalesPrice(line.getSalesPrice().toPlainString()); | ||
| 271 | + vo.setPriceListNo(purchaseOrderInfo.getPriceListNo()); | ||
| 272 | + vo.setPackagingFee(line.getPackagingFee().toPlainString()); | ||
| 273 | + vo.setInvoicingStatus(purchaseOrderInfo.getInvoicingStatus()); | ||
| 274 | + vo.setPieceWeightHeader(purchaseOrderInfo.getPieceWeightHeader()); | ||
| 275 | + vo.setSurface(purchaseOrderInfo.getSurface()); | ||
| 276 | + vo.setTolerance(purchaseOrderInfo.getTolerance()); | ||
| 277 | + vo.setPerformance(purchaseOrderInfo.getPerformance()); | ||
| 278 | + vo.setPackaging(purchaseOrderInfo.getPackaging()); | ||
| 279 | + vo.setRemarks(purchaseOrderInfo.getRemarks()); | ||
| 280 | + //加工合同就是回程运费 | ||
| 281 | + String type = standard.getType(); | ||
| 282 | + if ("PROCESS_STD_AGMT".equals(type)) { | ||
| 283 | + vo.setReturnShippingCost(purchaseOrderInfo.getShippingCost()); | ||
| 284 | + } else { | ||
| 285 | + vo.setShippingCost(purchaseOrderInfo.getShippingCost()); | ||
| 286 | + } | ||
| 287 | + if (customerCredit != null) { | ||
| 288 | + SysDataDicItem dataDicItem = sysDataDicItemService.findByCode("ENTERPRISE_TYPE", customerCredit.getEnterpriseType()); | ||
| 289 | + if (dataDicItem != null) { | ||
| 290 | + vo.setCustomerType(dataDicItem.getName()); | ||
| 291 | + } | ||
| 292 | + } | ||
| 293 | + vo.setQuality(line.getQuality()); | ||
| 294 | + String contractType = handleContractType(type); | ||
| 295 | + vo.setContractType(contractType); | ||
| 296 | + if ("加工".equals(contractType)) { | ||
| 297 | + String contractDistributorLineId = line.getContractDistributorLineId(); | ||
| 298 | + ContractStdProcessingLine processingLine = contractStdProcessingLineService.findById(contractDistributorLineId); | ||
| 299 | + | ||
| 300 | + if (processingLine != null) { | ||
| 301 | + String materialProductRatio = processingLine.getMaterialProductRatio(); | ||
| 302 | + SysDataDicItem dataDicItem = sysDataDicItemService.findByCode("RAW_TO_PROD_RATIO", materialProductRatio); | ||
| 303 | + | ||
| 304 | + if (dataDicItem != null) { | ||
| 305 | + vo.setContractType(dataDicItem.getName() + contractType); | ||
| 306 | + } | ||
| 307 | + } | ||
| 308 | + } | ||
| 309 | + vo.setStockUpCompanyName(purchaseOrderInfo.getStockUpCompanyName()); | ||
| 310 | + //vo.setOrderType(); | ||
| 311 | + vo.setShowOrder(0); | ||
| 312 | + orderDetailReportService.create(vo); | ||
| 313 | + } | ||
| 314 | + } | ||
| 315 | + } | ||
| 316 | + } | ||
| 317 | + } | ||
| 318 | + | ||
| 319 | + private String handleContractType(String contractType) { | ||
| 320 | + String result = ""; | ||
| 321 | + if ("DISTRIB_STD".equals(contractType) || "DIST_STOCK_CONTRACT".equals(contractType) | ||
| 322 | + || "DRAFT_DIST_AGMT".equals(contractType)) { | ||
| 323 | + result = "经销"; | ||
| 324 | + } else if ("INTL_STD_CONTRACT".equals(contractType) || "INTL_INVENTORY_AGMT".equals(contractType) | ||
| 325 | + || "INTL_OPEN_SPEC_AGMT".equals(contractType)) { | ||
| 326 | + result = "外贸"; | ||
| 327 | + } else if ("PROCESS_STD_AGMT".equals(contractType)) { | ||
| 328 | + result = "加工"; | ||
| 329 | + } | ||
| 330 | + return result; | ||
| 331 | + } | ||
| 332 | + | ||
| 333 | + @Override | ||
| 334 | + public void cleanCacheByKey(Serializable key) { | ||
| 335 | + | ||
| 336 | + } | ||
| 337 | +} |
| 1 | +package com.lframework.xingyun.sc.mappers; | ||
| 2 | + | ||
| 3 | +import com.lframework.starter.web.core.mapper.BaseMapper; | ||
| 4 | +import com.lframework.xingyun.sc.entity.OrderDetailReport; | ||
| 5 | +import com.lframework.xingyun.sc.vo.statistics.orderDetail.QueryOrderDetailReportVo; | ||
| 6 | +import org.apache.ibatis.annotations.Param; | ||
| 7 | + | ||
| 8 | +import java.util.List; | ||
| 9 | + | ||
| 10 | +/** | ||
| 11 | + * <p> | ||
| 12 | + * 订单明细 Mapper 接口 | ||
| 13 | + * </p> | ||
| 14 | + * | ||
| 15 | + */ | ||
| 16 | +public interface OrderDetailReportMapper extends BaseMapper<OrderDetailReport> { | ||
| 17 | + | ||
| 18 | + /** | ||
| 19 | + * 查询列表 | ||
| 20 | + * @param vo | ||
| 21 | + * @return | ||
| 22 | + */ | ||
| 23 | + List<OrderDetailReport> query(@Param("vo") QueryOrderDetailReportVo vo); | ||
| 24 | +} |
xingyun-sc/src/main/java/com/lframework/xingyun/sc/service/statistics/OrderDetailReportService.java
0 → 100644
| 1 | +package com.lframework.xingyun.sc.service.statistics; | ||
| 2 | + | ||
| 3 | +import com.lframework.starter.web.core.service.BaseMpService; | ||
| 4 | +import com.lframework.starter.web.core.components.resp.PageResult; | ||
| 5 | +import com.lframework.xingyun.sc.entity.OrderDetailReport; | ||
| 6 | +import com.lframework.xingyun.sc.vo.statistics.orderDetail.CreateOrderDetailReportVo; | ||
| 7 | +import com.lframework.xingyun.sc.vo.statistics.orderDetail.QueryOrderDetailReportVo; | ||
| 8 | +import java.util.List; | ||
| 9 | + | ||
| 10 | +/** | ||
| 11 | + * 订单明细 Service | ||
| 12 | + */ | ||
| 13 | +public interface OrderDetailReportService extends BaseMpService<OrderDetailReport> { | ||
| 14 | + | ||
| 15 | + /** | ||
| 16 | + * 查询列表 | ||
| 17 | + * @return | ||
| 18 | + */ | ||
| 19 | + PageResult<OrderDetailReport> query(Integer pageIndex, Integer pageSize, QueryOrderDetailReportVo vo); | ||
| 20 | + | ||
| 21 | + /** | ||
| 22 | + * 查询列表 | ||
| 23 | + * @param vo | ||
| 24 | + * @return | ||
| 25 | + */ | ||
| 26 | + List<OrderDetailReport> query(QueryOrderDetailReportVo vo); | ||
| 27 | + | ||
| 28 | + /** | ||
| 29 | + * 根据ID查询 | ||
| 30 | + * @param id | ||
| 31 | + * @return | ||
| 32 | + */ | ||
| 33 | + OrderDetailReport findById(String id); | ||
| 34 | + | ||
| 35 | + /** | ||
| 36 | + * 创建 | ||
| 37 | + * @param vo | ||
| 38 | + * @return | ||
| 39 | + */ | ||
| 40 | + String create(CreateOrderDetailReportVo vo); | ||
| 41 | + | ||
| 42 | + /** | ||
| 43 | + * 处理历史数据 | ||
| 44 | + */ | ||
| 45 | + void processHistoricalData(); | ||
| 46 | + | ||
| 47 | + | ||
| 48 | +} |
| 1 | +package com.lframework.xingyun.sc.vo.statistics.orderDetail; | ||
| 2 | + | ||
| 3 | +import com.lframework.starter.web.core.components.validation.IsNumberPrecision; | ||
| 4 | +import java.math.BigDecimal; | ||
| 5 | +import java.time.LocalDate; | ||
| 6 | +import com.lframework.starter.web.core.vo.BaseVo; | ||
| 7 | +import io.swagger.annotations.ApiModelProperty; | ||
| 8 | +import com.lframework.starter.web.core.components.validation.TypeMismatch; | ||
| 9 | +import org.hibernate.validator.constraints.Length; | ||
| 10 | +import java.io.Serializable; | ||
| 11 | +import lombok.Data; | ||
| 12 | + | ||
| 13 | +@Data | ||
| 14 | +public class CreateOrderDetailReportVo implements BaseVo, Serializable { | ||
| 15 | + | ||
| 16 | + private static final long serialVersionUID = 1L; | ||
| 17 | + | ||
| 18 | + /** | ||
| 19 | + * 订货单物料行ID | ||
| 20 | + */ | ||
| 21 | + @ApiModelProperty("订货单物料行ID") | ||
| 22 | + @Length(message = "订货单物料行ID最多允许32个字符!") | ||
| 23 | + private String purchaseOrderLineId; | ||
| 24 | + | ||
| 25 | + /** | ||
| 26 | + * 订单编号 | ||
| 27 | + */ | ||
| 28 | + @ApiModelProperty("订单编号") | ||
| 29 | + @Length(message = "订单编号最多允许100个字符!") | ||
| 30 | + private String orderNo; | ||
| 31 | + | ||
| 32 | + /** | ||
| 33 | + * 订货日期 | ||
| 34 | + */ | ||
| 35 | + @ApiModelProperty("订货日期") | ||
| 36 | + @TypeMismatch(message = "订货日期格式有误!") | ||
| 37 | + private LocalDate orderDate; | ||
| 38 | + | ||
| 39 | + /** | ||
| 40 | + * 生产厂 | ||
| 41 | + */ | ||
| 42 | + @ApiModelProperty("生产厂") | ||
| 43 | + @Length(message = "生产厂最多允许50个字符!") | ||
| 44 | + private String workshopId; | ||
| 45 | + | ||
| 46 | + /** | ||
| 47 | + * 科办 | ||
| 48 | + */ | ||
| 49 | + @ApiModelProperty("科办") | ||
| 50 | + @Length(message = "科办最多允许50个字符!") | ||
| 51 | + private String deptName; | ||
| 52 | + | ||
| 53 | + /** | ||
| 54 | + * 区域 | ||
| 55 | + */ | ||
| 56 | + @ApiModelProperty("区域") | ||
| 57 | + @Length(message = "区域最多允许50个字符!") | ||
| 58 | + private String regionName; | ||
| 59 | + | ||
| 60 | + /** | ||
| 61 | + * 订货单位名称 | ||
| 62 | + */ | ||
| 63 | + @ApiModelProperty("订货单位名称") | ||
| 64 | + @Length(message = "订货单位名称最多允许200个字符!") | ||
| 65 | + private String orderingUnitName; | ||
| 66 | + | ||
| 67 | + /** | ||
| 68 | + * 行业 | ||
| 69 | + */ | ||
| 70 | + @ApiModelProperty("行业") | ||
| 71 | + @Length(message = "行业最多允许50个字符!") | ||
| 72 | + private String industry; | ||
| 73 | + | ||
| 74 | + /** | ||
| 75 | + * 牌号 | ||
| 76 | + */ | ||
| 77 | + @ApiModelProperty("牌号") | ||
| 78 | + @Length(message = "牌号最多允许50个字符!") | ||
| 79 | + private String brand; | ||
| 80 | + | ||
| 81 | + /** | ||
| 82 | + * 厚度 | ||
| 83 | + */ | ||
| 84 | + @ApiModelProperty("厚度") | ||
| 85 | + @TypeMismatch(message = "厚度格式有误!") | ||
| 86 | + @IsNumberPrecision(message = "厚度最多允许4位小数!", value = 4) | ||
| 87 | + private BigDecimal thickness; | ||
| 88 | + | ||
| 89 | + /** | ||
| 90 | + * 厚度公差正 | ||
| 91 | + */ | ||
| 92 | + @ApiModelProperty("厚度公差正") | ||
| 93 | + @TypeMismatch(message = "厚度公差正格式有误!") | ||
| 94 | + @IsNumberPrecision(message = "厚度公差正最多允许4位小数!", value = 4) | ||
| 95 | + private BigDecimal thicknessTolPos; | ||
| 96 | + | ||
| 97 | + /** | ||
| 98 | + * 厚度公差负 | ||
| 99 | + */ | ||
| 100 | + @ApiModelProperty("厚度公差负") | ||
| 101 | + @TypeMismatch(message = "厚度公差负格式有误!") | ||
| 102 | + @IsNumberPrecision(message = "厚度公差负最多允许4位小数!", value = 4) | ||
| 103 | + private BigDecimal thicknessTolNeg; | ||
| 104 | + | ||
| 105 | + /** | ||
| 106 | + * 宽度 | ||
| 107 | + */ | ||
| 108 | + @ApiModelProperty("宽度") | ||
| 109 | + @TypeMismatch(message = "宽度格式有误!") | ||
| 110 | + @IsNumberPrecision(message = "宽度最多允许4位小数!", value = 4) | ||
| 111 | + private BigDecimal width; | ||
| 112 | + | ||
| 113 | + /** | ||
| 114 | + * 宽度公差正 | ||
| 115 | + */ | ||
| 116 | + @ApiModelProperty("宽度公差正") | ||
| 117 | + @TypeMismatch(message = "宽度公差正格式有误!") | ||
| 118 | + @IsNumberPrecision(message = "宽度公差正最多允许4位小数!", value = 4) | ||
| 119 | + private BigDecimal widthTolPos; | ||
| 120 | + | ||
| 121 | + /** | ||
| 122 | + * 宽度公差负 | ||
| 123 | + */ | ||
| 124 | + @ApiModelProperty("宽度公差负") | ||
| 125 | + @TypeMismatch(message = "宽度公差负格式有误!") | ||
| 126 | + @IsNumberPrecision(message = "宽度公差负最多允许4位小数!", value = 4) | ||
| 127 | + private BigDecimal widthTolNeg; | ||
| 128 | + | ||
| 129 | + /** | ||
| 130 | + * 长度 | ||
| 131 | + */ | ||
| 132 | + @ApiModelProperty("长度") | ||
| 133 | + @TypeMismatch(message = "长度格式有误!") | ||
| 134 | + @IsNumberPrecision(message = "长度最多允许4位小数!", value = 4) | ||
| 135 | + private BigDecimal length; | ||
| 136 | + | ||
| 137 | + /** | ||
| 138 | + * 长度公差正 | ||
| 139 | + */ | ||
| 140 | + @ApiModelProperty("长度公差正") | ||
| 141 | + @TypeMismatch(message = "长度公差正格式有误!") | ||
| 142 | + @IsNumberPrecision(message = "长度公差正最多允许4位小数!", value = 4) | ||
| 143 | + private BigDecimal lengthTolPos; | ||
| 144 | + | ||
| 145 | + /** | ||
| 146 | + * 长度公差负 | ||
| 147 | + */ | ||
| 148 | + @ApiModelProperty("长度公差负") | ||
| 149 | + @TypeMismatch(message = "长度公差负格式有误!") | ||
| 150 | + @IsNumberPrecision(message = "长度公差负最多允许4位小数!", value = 4) | ||
| 151 | + private BigDecimal lengthTolNeg; | ||
| 152 | + | ||
| 153 | + /** | ||
| 154 | + * 状态 | ||
| 155 | + */ | ||
| 156 | + @ApiModelProperty("状态") | ||
| 157 | + @Length(message = "状态最多允许50个字符!") | ||
| 158 | + private String status; | ||
| 159 | + | ||
| 160 | + /** | ||
| 161 | + * 数量 | ||
| 162 | + */ | ||
| 163 | + @ApiModelProperty("数量") | ||
| 164 | + @TypeMismatch(message = "数量格式有误!") | ||
| 165 | + @IsNumberPrecision(message = "数量最多允许4位小数!", value = 4) | ||
| 166 | + private BigDecimal quantity; | ||
| 167 | + | ||
| 168 | + /** | ||
| 169 | + * 指导价 | ||
| 170 | + */ | ||
| 171 | + @ApiModelProperty("指导价") | ||
| 172 | + @Length(message = "指导价最多允许50个字符!") | ||
| 173 | + private String suggestedPrice; | ||
| 174 | + | ||
| 175 | + /** | ||
| 176 | + * 发货日期 | ||
| 177 | + */ | ||
| 178 | + @ApiModelProperty("发货日期") | ||
| 179 | + @TypeMismatch(message = "发货日期格式有误!") | ||
| 180 | + private LocalDate deliveryDate; | ||
| 181 | + | ||
| 182 | + /** | ||
| 183 | + * 超协价 | ||
| 184 | + */ | ||
| 185 | + @ApiModelProperty("超协价") | ||
| 186 | + @Length(message = "超协价最多允许50个字符!") | ||
| 187 | + private String assessmentExceedsAgreement; | ||
| 188 | + | ||
| 189 | + /** | ||
| 190 | + * 销售价 | ||
| 191 | + */ | ||
| 192 | + @ApiModelProperty("销售价") | ||
| 193 | + @Length(message = "销售价最多允许50个字符!") | ||
| 194 | + private String salesPrice; | ||
| 195 | + | ||
| 196 | + /** | ||
| 197 | + * 价格表编号 | ||
| 198 | + */ | ||
| 199 | + @ApiModelProperty("价格表编号") | ||
| 200 | + @Length(message = "价格表编号最多允许50个字符!") | ||
| 201 | + private String priceListNo; | ||
| 202 | + | ||
| 203 | + /** | ||
| 204 | + * 包装费 | ||
| 205 | + */ | ||
| 206 | + @ApiModelProperty("包装费") | ||
| 207 | + @Length(message = "包装费最多允许50个字符!") | ||
| 208 | + private String packagingFee; | ||
| 209 | + | ||
| 210 | + /** | ||
| 211 | + * 开票情况 | ||
| 212 | + */ | ||
| 213 | + @ApiModelProperty("开票情况") | ||
| 214 | + @Length(message = "开票情况最多允许50个字符!") | ||
| 215 | + private String invoicingStatus; | ||
| 216 | + | ||
| 217 | + /** | ||
| 218 | + * 件重条头 | ||
| 219 | + */ | ||
| 220 | + @ApiModelProperty("件重条头") | ||
| 221 | + @Length(message = "件重条头最多允许65,535个字符!") | ||
| 222 | + private String pieceWeightHeader; | ||
| 223 | + | ||
| 224 | + /** | ||
| 225 | + * 表面 | ||
| 226 | + */ | ||
| 227 | + @ApiModelProperty("表面") | ||
| 228 | + @Length(message = "表面最多允许65,535个字符!") | ||
| 229 | + private String surface; | ||
| 230 | + | ||
| 231 | + /** | ||
| 232 | + * 公差 | ||
| 233 | + */ | ||
| 234 | + @ApiModelProperty("公差") | ||
| 235 | + @Length(message = "公差最多允许65,535个字符!") | ||
| 236 | + private String tolerance; | ||
| 237 | + | ||
| 238 | + /** | ||
| 239 | + * 性能 | ||
| 240 | + */ | ||
| 241 | + @ApiModelProperty("性能") | ||
| 242 | + @Length(message = "性能最多允许65,535个字符!") | ||
| 243 | + private String performance; | ||
| 244 | + | ||
| 245 | + /** | ||
| 246 | + * 包装 | ||
| 247 | + */ | ||
| 248 | + @ApiModelProperty("包装") | ||
| 249 | + @Length(message = "包装最多允许65,535个字符!") | ||
| 250 | + private String packaging; | ||
| 251 | + | ||
| 252 | + /** | ||
| 253 | + * 备注 | ||
| 254 | + */ | ||
| 255 | + @ApiModelProperty("备注") | ||
| 256 | + @Length(message = "备注最多允许65,535个字符!") | ||
| 257 | + private String remarks; | ||
| 258 | + | ||
| 259 | + /** | ||
| 260 | + * 运费 | ||
| 261 | + */ | ||
| 262 | + @ApiModelProperty("运费") | ||
| 263 | + @Length(message = "运费最多允许50个字符!") | ||
| 264 | + private String shippingCost; | ||
| 265 | + | ||
| 266 | + /** | ||
| 267 | + * 回程运费 | ||
| 268 | + */ | ||
| 269 | + @ApiModelProperty("回程运费") | ||
| 270 | + @Length(message = "回程运费最多允许50个字符!") | ||
| 271 | + private String returnShippingCost; | ||
| 272 | + | ||
| 273 | + /** | ||
| 274 | + * 客户类型 | ||
| 275 | + */ | ||
| 276 | + @ApiModelProperty("客户类型") | ||
| 277 | + @Length(message = "客户类型最多允许50个字符!") | ||
| 278 | + private String customerType; | ||
| 279 | + | ||
| 280 | + /** | ||
| 281 | + * 标准行业 | ||
| 282 | + */ | ||
| 283 | + @ApiModelProperty("标准行业") | ||
| 284 | + @Length(message = "标准行业最多允许100个字符!") | ||
| 285 | + private String quality; | ||
| 286 | + | ||
| 287 | + /** | ||
| 288 | + * 加工经销 | ||
| 289 | + */ | ||
| 290 | + @ApiModelProperty("加工经销") | ||
| 291 | + @Length(message = "加工经销最多允许100个字符!") | ||
| 292 | + private String contractType; | ||
| 293 | + | ||
| 294 | + /** | ||
| 295 | + * 备货单位 | ||
| 296 | + */ | ||
| 297 | + @ApiModelProperty("备货单位") | ||
| 298 | + @Length(message = "备货单位最多允许200个字符!") | ||
| 299 | + private String stockUpCompanyName; | ||
| 300 | + | ||
| 301 | + /** | ||
| 302 | + * 订单类型 | ||
| 303 | + */ | ||
| 304 | + @ApiModelProperty("订单类型") | ||
| 305 | + @Length(message = "订单类型最多允许50个字符!") | ||
| 306 | + private String orderType; | ||
| 307 | + | ||
| 308 | + /** | ||
| 309 | + * 排序,订货单:0,撤销单:1,规格变更单:2 | ||
| 310 | + */ | ||
| 311 | + @ApiModelProperty("排序,订货单:0,撤销单:1,规格变更单:2") | ||
| 312 | + @TypeMismatch(message = "排序,订货单:0,撤销单:1,规格变更单:2格式有误!") | ||
| 313 | + private Integer showOrder; | ||
| 314 | + | ||
| 315 | +} |
| 1 | +package com.lframework.xingyun.sc.vo.statistics.orderDetail; | ||
| 2 | + | ||
| 3 | +import lombok.Data; | ||
| 4 | +import com.lframework.starter.web.core.vo.PageVo; | ||
| 5 | +import com.lframework.starter.web.core.vo.BaseVo; | ||
| 6 | +import io.swagger.annotations.ApiModelProperty; | ||
| 7 | +import java.io.Serializable; | ||
| 8 | + | ||
| 9 | +@Data | ||
| 10 | +public class QueryOrderDetailReportVo extends PageVo implements BaseVo, Serializable { | ||
| 11 | + | ||
| 12 | + private static final long serialVersionUID = 1L; | ||
| 13 | + | ||
| 14 | + /** | ||
| 15 | + * 订货单物料行ID | ||
| 16 | + */ | ||
| 17 | + @ApiModelProperty("订货单物料行ID") | ||
| 18 | + private String purchaseOrderLineId; | ||
| 19 | + | ||
| 20 | + /** | ||
| 21 | + * 订单编号 | ||
| 22 | + */ | ||
| 23 | + @ApiModelProperty("订单编号") | ||
| 24 | + private String orderNo; | ||
| 25 | + | ||
| 26 | + /** | ||
| 27 | + * 生产厂 | ||
| 28 | + */ | ||
| 29 | + @ApiModelProperty("生产厂") | ||
| 30 | + private String workshopId; | ||
| 31 | + | ||
| 32 | + /** | ||
| 33 | + * 科办 | ||
| 34 | + */ | ||
| 35 | + @ApiModelProperty("科办") | ||
| 36 | + private String deptName; | ||
| 37 | + | ||
| 38 | + /** | ||
| 39 | + * 订货单位名称 | ||
| 40 | + */ | ||
| 41 | + @ApiModelProperty("订货单位名称") | ||
| 42 | + private String orderingUnitName; | ||
| 43 | + | ||
| 44 | + /** | ||
| 45 | + * 导出类型 | ||
| 46 | + */ | ||
| 47 | + @ApiModelProperty("导出类型") | ||
| 48 | + private String exportType; | ||
| 49 | + | ||
| 50 | +} |
| 1 | +<?xml version="1.0" encoding="UTF-8"?> | ||
| 2 | +<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | ||
| 3 | +<mapper namespace="com.lframework.xingyun.sc.mappers.OrderDetailReportMapper"> | ||
| 4 | + | ||
| 5 | + <resultMap id="OrderDetailReport" type="com.lframework.xingyun.sc.entity.OrderDetailReport"> | ||
| 6 | + <id column="id" property="id"/> | ||
| 7 | + <result column="purchase_order_line_id" property="purchaseOrderLineId"/> | ||
| 8 | + <result column="order_no" property="orderNo"/> | ||
| 9 | + <result column="order_date" property="orderDate"/> | ||
| 10 | + <result column="workshop_id" property="workshopId"/> | ||
| 11 | + <result column="workshop_name" property="workshopName"/> | ||
| 12 | + <result column="dept_name" property="deptName"/> | ||
| 13 | + <result column="region_name" property="regionName"/> | ||
| 14 | + <result column="ordering_unit_name" property="orderingUnitName"/> | ||
| 15 | + <result column="industry" property="industry"/> | ||
| 16 | + <result column="brand" property="brand"/> | ||
| 17 | + <result column="thickness" property="thickness"/> | ||
| 18 | + <result column="thickness_tol_pos" property="thicknessTolPos"/> | ||
| 19 | + <result column="thickness_tol_neg" property="thicknessTolNeg"/> | ||
| 20 | + <result column="width" property="width"/> | ||
| 21 | + <result column="width_tol_pos" property="widthTolPos"/> | ||
| 22 | + <result column="width_tol_neg" property="widthTolNeg"/> | ||
| 23 | + <result column="length" property="length"/> | ||
| 24 | + <result column="length_tol_pos" property="lengthTolPos"/> | ||
| 25 | + <result column="length_tol_neg" property="lengthTolNeg"/> | ||
| 26 | + <result column="status" property="status"/> | ||
| 27 | + <result column="quantity" property="quantity"/> | ||
| 28 | + <result column="suggested_price" property="suggestedPrice"/> | ||
| 29 | + <result column="delivery_date" property="deliveryDate"/> | ||
| 30 | + <result column="assessment_exceeds_agreement" property="assessmentExceedsAgreement"/> | ||
| 31 | + <result column="sales_price" property="salesPrice"/> | ||
| 32 | + <result column="price_list_no" property="priceListNo"/> | ||
| 33 | + <result column="packaging_fee" property="packagingFee"/> | ||
| 34 | + <result column="invoicing_status" property="invoicingStatus"/> | ||
| 35 | + <result column="piece_weight_header" property="pieceWeightHeader"/> | ||
| 36 | + <result column="surface" property="surface"/> | ||
| 37 | + <result column="tolerance" property="tolerance"/> | ||
| 38 | + <result column="performance" property="performance"/> | ||
| 39 | + <result column="packaging" property="packaging"/> | ||
| 40 | + <result column="remarks" property="remarks"/> | ||
| 41 | + <result column="shipping_fee" property="shippingFee"/> | ||
| 42 | + <result column="return_shipping_cost" property="returnShippingCost"/> | ||
| 43 | + <result column="customer_type" property="customerType"/> | ||
| 44 | + <result column="quality" property="quality"/> | ||
| 45 | + <result column="contract_type" property="contractType"/> | ||
| 46 | + <result column="stock_up_company_name" property="stockUpCompanyName"/> | ||
| 47 | + <result column="order_type" property="orderType"/> | ||
| 48 | + <result column="show_order" property="showOrder"/> | ||
| 49 | + <result column="create_by_id" property="createById"/> | ||
| 50 | + <result column="create_by" property="createBy"/> | ||
| 51 | + <result column="update_by_id" property="updateById"/> | ||
| 52 | + <result column="update_by" property="updateBy"/> | ||
| 53 | + <result column="create_time" property="createTime"/> | ||
| 54 | + <result column="update_time" property="updateTime"/> | ||
| 55 | + </resultMap> | ||
| 56 | + | ||
| 57 | + <sql id="OrderDetailReport_sql"> | ||
| 58 | + SELECT | ||
| 59 | + tb.id, | ||
| 60 | + tb.purchase_order_line_id, | ||
| 61 | + tb.order_no, | ||
| 62 | + tb.order_date, | ||
| 63 | + tb.workshop_id, | ||
| 64 | + ws.name AS workshop_name, | ||
| 65 | + tb.dept_name, | ||
| 66 | + tb.region_name, | ||
| 67 | + tb.ordering_unit_name, | ||
| 68 | + tb.industry, | ||
| 69 | + tb.brand, | ||
| 70 | + tb.thickness, | ||
| 71 | + tb.thickness_tol_pos, | ||
| 72 | + tb.thickness_tol_neg, | ||
| 73 | + tb.width, | ||
| 74 | + tb.width_tol_pos, | ||
| 75 | + tb.width_tol_neg, | ||
| 76 | + tb.length, | ||
| 77 | + tb.length_tol_pos, | ||
| 78 | + tb.length_tol_neg, | ||
| 79 | + tb.status, | ||
| 80 | + tb.quantity, | ||
| 81 | + tb.suggested_price, | ||
| 82 | + tb.delivery_date, | ||
| 83 | + tb.assessment_exceeds_agreement, | ||
| 84 | + tb.sales_price, | ||
| 85 | + tb.price_list_no, | ||
| 86 | + tb.packaging_fee, | ||
| 87 | + tb.invoicing_status, | ||
| 88 | + tb.piece_weight_header, | ||
| 89 | + tb.surface, | ||
| 90 | + tb.tolerance, | ||
| 91 | + tb.performance, | ||
| 92 | + tb.packaging, | ||
| 93 | + tb.remarks, | ||
| 94 | + tb.shipping_fee, | ||
| 95 | + tb.return_shipping_cost, | ||
| 96 | + tb.customer_type, | ||
| 97 | + tb.quality, | ||
| 98 | + tb.contract_type, | ||
| 99 | + tb.stock_up_company_name, | ||
| 100 | + tb.order_type, | ||
| 101 | + tb.show_order, | ||
| 102 | + tb.create_by_id, | ||
| 103 | + tb.create_by, | ||
| 104 | + tb.update_by_id, | ||
| 105 | + tb.update_by, | ||
| 106 | + tb.create_time, | ||
| 107 | + tb.update_time | ||
| 108 | + FROM order_detail_report AS tb | ||
| 109 | + left join base_data_workshop as ws on ws.id = tb.workshop_id | ||
| 110 | + </sql> | ||
| 111 | + | ||
| 112 | + <select id="query" resultMap="OrderDetailReport"> | ||
| 113 | + <include refid="OrderDetailReport_sql"/> | ||
| 114 | + <where> | ||
| 115 | + <if test="vo.purchaseOrderLineId != null and vo.purchaseOrderLineId != ''"> | ||
| 116 | + AND tb.purchase_order_line_id = #{vo.purchaseOrderLineId} | ||
| 117 | + </if> | ||
| 118 | + <if test="vo.orderNo != null and vo.orderNo != ''"> | ||
| 119 | + AND tb.order_no LIKE CONCAT('%', #{vo.orderNo}, '%') | ||
| 120 | + </if> | ||
| 121 | + <if test="vo.workshopId != null and vo.workshopId != ''"> | ||
| 122 | + AND tb.workshop_id = #{vo.workshopId} | ||
| 123 | + </if> | ||
| 124 | + <if test="vo.deptName != null and vo.deptName != ''"> | ||
| 125 | + AND tb.dept_name LIKE CONCAT('%', #{vo.deptName}, '%') | ||
| 126 | + </if> | ||
| 127 | + <if test="vo.orderingUnitName != null and vo.orderingUnitName != ''"> | ||
| 128 | + AND tb.ordering_unit_name LIKE CONCAT('%', #{vo.orderingUnitName}, '%') | ||
| 129 | + </if> | ||
| 130 | + </where> | ||
| 131 | + </select> | ||
| 132 | +</mapper> |