191 lines
7.4 KiB
PHP
191 lines
7.4 KiB
PHP
<?php namespace Gdoo\Order\Hooks;
|
|
|
|
use DB;
|
|
use Exception;
|
|
use Gdoo\Order\Models\CustomerOrder;
|
|
|
|
class OrderHook
|
|
{
|
|
public function onBeforeForm($params) {
|
|
$permission = $params['permission'];
|
|
$data = $permission['customer_order_data'];
|
|
|
|
// 以下角色类型无法修改子表字段
|
|
$role_ids = [2, 83, 84, 85];
|
|
if (in_array(auth()->user()->role_id, $role_ids)) {
|
|
// 不能编辑类型
|
|
unset($data['type_id']);
|
|
// 不能编辑价格
|
|
unset($data['price']);
|
|
// 不编辑实发数量
|
|
unset($data['delivery_quantity']);
|
|
}
|
|
|
|
$permission['customer_order_data'] = $data;
|
|
$params['permission'] = $permission;
|
|
return $params;
|
|
}
|
|
|
|
public function onAfterForm($params) {
|
|
$options = $params['options'];
|
|
if ($options['action'] == 'print') {
|
|
return $params;
|
|
}
|
|
$tpls = $params['tpls'];
|
|
//$tpls[0]['tpl'] = $tpls[0]['tpl'].view('order/bank');
|
|
$params['tpls'] = $tpls;
|
|
return $params;
|
|
}
|
|
|
|
public function onBeforeStore($params) {
|
|
|
|
$master = $params['master'];
|
|
|
|
// 只限制内销和直营
|
|
if (in_array($master['type_id'], [1, 3])) {
|
|
// 客户和区域经理和业务员限制下单数和倍数
|
|
$role_ids = [2, 83, 84, 85];
|
|
|
|
if (in_array(auth()->user()->role_id, $role_ids)) {
|
|
$product_ids = [];
|
|
foreach($params['datas'] as $i => $datas) {
|
|
if ($datas['table'] == 'customer_order_data') {
|
|
foreach($datas['data'] as $j => $row) {
|
|
$quantitys[$row['product_id']][] = $row['quantity'];
|
|
$product_ids[] = $row['product_id'];
|
|
}
|
|
}
|
|
}
|
|
|
|
$products = DB::table('product')
|
|
->whereIn('id', $product_ids)
|
|
->whereRaw('scale_quantity > 0 or mini_quantity > 0')
|
|
->get()->keyBy('id');
|
|
|
|
foreach($quantitys as $_product_id => $_products) {
|
|
$product = $products[$_product_id];
|
|
foreach($_products as $_quantity) {
|
|
// 检查倍数
|
|
if ($product['scale_quantity'] > 0) {
|
|
$has = $_quantity % $product['scale_quantity'];
|
|
if ($has > 0) {
|
|
abort_error($product['name'].' - '.$product['spec'].' 下单数量必须是['.$product['scale_quantity'].']的倍数');
|
|
}
|
|
}
|
|
// 检查最低下单数
|
|
if ($product['mini_quantity'] > 0) {
|
|
if ($_quantity < $product['mini_quantity']) {
|
|
abort_error($product['name'].' - '.$product['spec'].' 最低下单数不能小于['.$product['mini_quantity'].']');
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
foreach($params['datas'] as $i => $datas) {
|
|
if ($datas['table'] == 'customer_order_data') {
|
|
|
|
foreach($datas['data'] as $j => $row) {
|
|
|
|
// 产品类型是赠品
|
|
if ($row['type_id'] == 2) {
|
|
if (empty($row['promotion_sn'])) {
|
|
abort_error('赠品必须有编号。');
|
|
}
|
|
|
|
// 赠品修改客户促销开票单位
|
|
if ($row['fee_src_id'] > 0) {
|
|
// 促销费用首次使用回写开票单位到促销申请
|
|
$count = DB::table('customer_order_data')
|
|
->where('order_id', '<>', $row['order_id'])
|
|
->where('fee_src_id', $row['fee_src_id'])
|
|
->count('id');
|
|
if ($count == 0) {
|
|
DB::table('promotion')->where('id', $row['fee_src_id'])->update([
|
|
'tax_id' => $master['tax_id'],
|
|
]);
|
|
}
|
|
}
|
|
}
|
|
|
|
// 是外贸订单检查生产批号
|
|
if ($master['type_id'] == 2) {
|
|
$row = get_batch_sn($row);
|
|
if (empty($row['batch_sn'])) {
|
|
abort_error('外贸订单必须填写生产批号。');
|
|
}
|
|
}
|
|
|
|
$datas['data'][$j] = $row;
|
|
}
|
|
$params['datas'][$i] = $datas;
|
|
}
|
|
}
|
|
|
|
return $params;
|
|
}
|
|
|
|
/**
|
|
* 回退流程
|
|
*/
|
|
public function onBeforeReturn($params) {
|
|
return $params;
|
|
}
|
|
|
|
public function onAfterStore($params) {
|
|
foreach($params['datas'] as $datas) {
|
|
if ($datas['table'] == 'customer_order_data') {
|
|
foreach($datas['data'] as $row) {
|
|
// 计算费用使用情况
|
|
if ($row['fee_data_id'] > 0) {
|
|
$use_money = DB::table('customer_order_data')->where('fee_data_id', $row['fee_data_id'])->sum('money');
|
|
$cost = DB::table('customer_cost_data')->where('id', $row['fee_data_id'])->first();
|
|
$cost['use_money'] = abs($use_money);
|
|
$cost['remain_money'] = $cost['money'] - $cost['use_money'];
|
|
DB::table('customer_cost_data')->where('id', $row['fee_data_id'])->update($cost);
|
|
}
|
|
}
|
|
|
|
// 费用删除时重新计算使用
|
|
foreach($datas['deleteds'] as $row) {
|
|
// 计算费用使用情况
|
|
if ($row['fee_data_id'] > 0) {
|
|
$use_money = DB::table('customer_order_data')->where('fee_data_id', $row['fee_data_id'])->sum('money');
|
|
$cost = DB::table('customer_cost_data')->where('id', $row['fee_data_id'])->first();
|
|
$cost['use_money'] = abs($use_money);
|
|
$cost['remain_money'] = $cost['money'] - $cost['use_money'];
|
|
DB::table('customer_cost_data')->where('id', $row['fee_data_id'])->update($cost);
|
|
}
|
|
}
|
|
|
|
}
|
|
}
|
|
return $params;
|
|
}
|
|
|
|
public function onBeforeDelete($params) {
|
|
return $params;
|
|
}
|
|
|
|
public function onAfterDelete($params) {
|
|
|
|
foreach($params['datas'] as $datas) {
|
|
if ($datas['table'] == 'customer_order_data') {
|
|
foreach($datas['data'] as $row) {
|
|
// 计算费用使用情况
|
|
if ($row['fee_data_id'] > 0) {
|
|
$use_money = DB::table('customer_order_data')->where('fee_data_id', $row['fee_data_id'])->sum('money');
|
|
$cost = DB::table('customer_cost_data')->where('id', $row['fee_data_id'])->first();
|
|
$cost['use_money'] = abs($use_money);
|
|
$cost['remain_money'] = $cost['money'] - $cost['use_money'];
|
|
DB::table('customer_cost_data')->where('id', $row['fee_data_id'])->update($cost);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
return $params;
|
|
}
|
|
}
|