1. 【新增】售后单售后原因类型支持搜索

2. 【新增】手工创建订单折扣可输入正数

3. 【优化】盘点申请单确认

4. 【修复】采购退货单模拟出库失败问题

5. 【新增】订单金额客户实付与结算金额

6. 【优化】仓库发货统计报表物料名称显示

7. 【优化】自有仓储虚拟发货逻辑

8. 【修复】基础物料分类管理问题
This commit is contained in:
chenping
2026-04-01 11:59:17 +08:00
parent 9341122827
commit 61783b7d01
754 changed files with 46179 additions and 5700 deletions

View File

@@ -84,7 +84,21 @@ class ome_order_edit_pko{
if(!$itemInfo){
continue;
}
if ($objInfo['quantity'] != $num[$k] || $objInfo['price'] != $price[$k] || $objInfo['pmt_price'] != $obj_pmt_price[$k]){
// 检查是否有oid限制
$hasOidLimit = !empty($objInfo['oid']) && $objInfo['oid'] != '-1';
// oid限制验证数量只能改小
if ($hasOidLimit && isset($num[$k]) && $num[$k] > $objInfo['quantity']) {
trigger_error('oid限制数量不能大于原数量', E_USER_ERROR);
}
// oid限制禁止修改单价和优惠价格
if ($hasOidLimit) {
$price[$k] = $objInfo['price'];
$obj_pmt_price[$k] = $objInfo['pmt_price'];
}
if ($objInfo['quantity'] != $num[$k] || ($objInfo['price'] != $price[$k] && !$hasOidLimit) || ($objInfo['pmt_price'] != $obj_pmt_price[$k] && !$hasOidLimit)){
$is_order_change = true;
$is_goods_modify = true;
}
@@ -96,14 +110,40 @@ class ome_order_edit_pko{
$is_order_change = true;
$is_goods_modify = true;
}
$tmp_obj[$k]['obj_id'] = $k;
$tmp_obj[$k]['goods_id'] = $objInfo['goods_id'];
$tmp_obj[$k]['amount'] = $tmp_amount;
$tmp_obj[$k]['quantity'] = intval($num[$k]);
$tmp_obj[$k]['price'] = $price[$k];
$tmp_obj[$k]['amount'] = $tmp_obj[$k]['quantity'] * $tmp_obj[$k]['price'];
$tmp_obj[$k]['delete'] = 'false';
$tmp_obj[$k]['obj_id'] = $k;
$tmp_obj[$k]['goods_id'] = $objInfo['goods_id'];
$tmp_obj[$k]['amount'] = $tmp_amount;
$tmp_obj[$k]['quantity'] = intval($num[$k]);
$tmp_obj[$k]['price'] = $price[$k];
$tmp_obj[$k]['amount'] = $tmp_obj[$k]['quantity'] * $tmp_obj[$k]['price'];
$tmp_obj[$k]['delete'] = 'false';
// oid限制按比例计算销售价和实付
if ($hasOidLimit && $objInfo['quantity'] > 0) {
$ratio = intval($num[$k]) / $objInfo['quantity'];
$originalSalePrice = $objInfo['sale_price'];
$originalDivideOrderFee = $objInfo['divide_order_fee'];
$tmp_obj[$k]['sale_price'] = sprintf('%.2f', $originalSalePrice * $ratio);
$tmp_obj[$k]['divide_order_fee'] = sprintf('%.2f', $originalDivideOrderFee * $ratio);
// 重新计算商品优惠 = 单价 * 数量 - 销售价
$obj_pmt_price[$k] = sprintf('%.2f', $tmp_obj[$k]['amount'] - floatval($tmp_obj[$k]['sale_price']));
$total_pmt_goods -= $obj_pmt_price[$k]; // 先减去旧的
$total_pmt_goods += floatval($obj_pmt_price[$k]); // 再加上新的
} else {
$tmp_obj[$k]['sale_price'] = $tmp_obj[$k]['amount'] - $obj_pmt_price[$k];
$tmp_obj[$k]['divide_order_fee'] = sprintf('%.2f', $objInfo['divide_order_fee'] * intval($num[$k]) / $objInfo['quantity']);
}
$tmp_obj[$k]['pmt_price'] = $obj_pmt_price[$k];
$tmp_obj[$k]['settlement_amount'] = sprintf('%.2f', $objInfo['settlement_amount'] * intval($num[$k]) / $objInfo['quantity']);
$tmp_obj[$k]['actually_amount'] = sprintf('%.2f', $objInfo['actually_amount'] * intval($num[$k]) / $objInfo['quantity']);
$tmp_obj[$k]['platform_pay_amount'] = sprintf('%.2f', $tmp_obj[$k]['divide_order_fee'] - $tmp_obj[$k]['actually_amount']);
$tmp_obj[$k]['platform_amount'] = sprintf('%.2f', $tmp_obj[$k]['settlement_amount'] - $tmp_obj[$k]['divide_order_fee']);
// 均摊优惠 = 销售价 - 实付
$tmp_obj[$k]['part_mjz_discount'] = sprintf('%.2f', floatval($tmp_obj[$k]['sale_price']) - floatval($tmp_obj[$k]['divide_order_fee']));
$tmp_obj[$k]['oid'] = $objInfo['oid'];
$obj_num_change = intval($num[$k])-$objInfo['quantity']; //填写的数量 - 数据库数量
$total_change_number = abs($obj_num_change);
$tmp_item_sale_price = $tmp_item_pmt_price = $tmp_item_amount = 0;