Filing.php 49 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080
  1. <?php
  2. namespace app\admin\controller;
  3. use think\Exception;
  4. use think\facade\Db;
  5. use think\facade\Validate;
  6. //报备单
  7. class Filing extends Base
  8. {
  9. //列表
  10. public function getList()
  11. {
  12. $data = $this->request->only(['page' => 1, 'size' => 10, 'cat_id' => '', 'start_date' => '', 'end_date' => '', 'filingCode' => '', 'status' => '', 'good_name' => '', 'companyName' => '', 'companyCode' => '', 'orderCode' => '', 'supplierNo' => ''], 'post');
  13. $where = [['is_del', '=', '0']];
  14. if ($data['cat_id'] != '') $where[] = ['cat_id', '=', $data['cat_id']];
  15. if ($data['start_date'] != '' && $data['end_date'] != '') $where[] = ['addtime', 'between', [$data['start_date'] . ' 00:00:00', $data['end_date'] . ' 23:59:59']];
  16. if ($data['filingCode'] != '') $where[] = ['filingCode', 'like', '%' . $data['filingCode'] . '%'];
  17. if ($data['status'] != '') $where[] = ['status', '=', $data['status']];
  18. if ($data['good_name'] != '') $where[] = ['good_name', 'like', '%' . $data['good_name'] . '%'];
  19. if ($data['companyName'] != '') $where[] = ['companyName', 'like', '%' . $data['companyName'] . '%'];
  20. if ($data['companyCode'] != '') $where[] = ['companyCode', 'like', '%' . $data['companyCode'] . '%'];
  21. if ($data['orderCode'] != '') $where[] = ['orderCode', 'like', '%' . $data['orderCode'] . '%'];
  22. if ($data['supplierNo'] != '') $where[] = ['supplierNo', '=', $data['supplierNo']];
  23. $count = Db::name('filing')
  24. ->where($where)
  25. ->count('id');
  26. $list = Db::name('filing')
  27. ->field('id,filingCode,cat_id,good_name,num,good_img,price,expect_service,companyName,companyCode,status,addtime,"" catinfo,orderCode,cgd_charge')
  28. ->where($where)
  29. ->page($data['page'], $data['size'])
  30. ->order('id', 'desc')
  31. ->withAttr('good_img', function ($val) {
  32. return explode(',', $val);
  33. })
  34. ->select()
  35. ->toArray();
  36. $all_cat = [];
  37. foreach ($list as &$value) {
  38. if (!isset($all_cat[$value['cat_id']])) $all_cat[$value['cat_id']] = implode('/', array_column(made($value['cat_id']), 'name'));
  39. $value['catinfo'] = $all_cat[$value['cat_id']];
  40. }
  41. return json_show(0, '获取报备单列表成功', ['count' => $count, 'list' => $list]);
  42. // return FilingLogic::list($param);
  43. }
  44. //添加
  45. public function add()
  46. {
  47. $param = $this->request->only(['customerCode', 'supplierNo', 'companyName', 'num', 'is_determine_price', 'price' => 0, 'expect_service_proportion', 'expect_service', 'cgd_charge' => 0, 'brand_id', 'preservation_day', 'delivery_day', 'make_day', 'tax', 'unit_id', 'cat_id', 'spec_list' => [], 'good_name', 'origin_place', 'delivery_place', 'weight', 'supply_area', 'pay_way', 'gold_weight', 'noble_metal', 'config', 'other_config', 'remark', 'cost_desc', 'good_img'], 'post');
  48. $val = Validate::rule([
  49. 'customerCode|业务公司' => 'require|max:255',
  50. 'supplierNo|供应商' => 'require|max:255',
  51. 'companyName|客户名称' => 'require|max:255',
  52. 'num|销售数量' => 'require|number|gt:0|lt:999999999',
  53. 'is_determine_price|是否确定售价' => 'require|number|in:1,0',
  54. 'price|销售价' => 'requireIf:is_determine_price,1|float|max:99999999.99',
  55. 'expect_service_proportion|期望服务费比例' => 'require|float|between:0,100',
  56. 'expect_service|期望服务费' => 'require|float|max:99999999.99',
  57. 'cgd_charge|采购价' => 'requireIf:is_determine_price,0|float|max:99999999.99',
  58. 'brand_id|品牌' => 'require|number|gt:0',
  59. 'preservation_day|有效期' => 'require|number|max:999999999',
  60. 'delivery_day|物流时间' => 'require|number|max:999999999',
  61. 'make_day|生产工期' => 'require|number|max:999999999',
  62. 'tax|税点' => 'require|number|between:0,100',
  63. 'unit_id|单位' => 'require|number|gt:0',
  64. 'cat_id|分类' => 'require|number|gt:0',
  65. 'spec_list|规格类型' => 'array|max:100',
  66. 'good_name|商品名称' => 'require|max:255',
  67. 'origin_place|产地' => 'require|array|length:3',
  68. 'delivery_place|发货地' => 'require|array|length:3',
  69. 'weight|总重量' => 'require|float|max:99999999.99',
  70. 'supply_area|供货区域' => 'require|number|in:1,2',
  71. 'pay_way|付款方式' => 'require|number|in:0,1,2',
  72. 'remark|采购备注' => 'require|max:255',
  73. 'cost_desc|工艺说明' => 'max:255',
  74. 'good_img|商品图片' => 'require|array|max:10',
  75. ]);
  76. if (!$val->check($param)) return json_show(1004, $val->getError());
  77. //如果是贵金属的话,额外判断
  78. $cat = made($param['cat_id']);
  79. if (isset($cat[0]['id']) && $cat[0]['id'] == 6) {
  80. $val_gold = Validate::rule([
  81. 'gold_weight|贵金属重量' => 'require|float|max:99999999.99',
  82. 'noble_metal|贵金属类型' => 'require|number|in:1,2,3',
  83. 'config|配置要求' => 'require|max:255',
  84. 'other_config|其他配置要求' => 'require|max:255',
  85. ]);
  86. if (!$val_gold->check($param)) return json_show(1004, $val_gold->getError());
  87. }
  88. $val2 = Validate::rule([
  89. 'spec_id|规格id' => 'require|number|gt:0',
  90. 'spec_value_id|规格值id' => 'require|number|gt:0',
  91. ]);
  92. $all_spec = Db::name('specs')
  93. ->whereIn('id', array_column($param['spec_list'], 'spec_id'))
  94. ->column('spec_name', 'id');
  95. $all_spec_value = Db::name('spec_value')
  96. ->whereIn('id', array_column($param['spec_list'], 'spec_value_id'))
  97. ->column('spec_value', 'id');
  98. foreach ($param['spec_list'] as &$spec_list) {
  99. if (!$val2->check($spec_list)) return json_show(1004, $val2->getError());
  100. $spec_list['spec_name'] = $all_spec[$spec_list['spec_id']] ?? '';
  101. $spec_list['spec_value_name'] = $all_spec_value[$spec_list['spec_value_id']] ?? '';
  102. }
  103. if ($param['is_determine_price'] == 1) $param['cgd_charge'] = round(bcsub($param['price'], $param['expect_service'], 3), 2);//确定售价时,采购价=售价-服务费
  104. else $param['price'] = round(bcadd($param['cgd_charge'], $param['expect_service'], 3), 2);//不确定售价时,售价=采购价+服务费
  105. // $customerName = Db::name('business')
  106. // ->where(['companyNo' => $param['customerCode']])
  107. // ->value('company', '');
  108. // if ($customerName == '') return json_show(1004, '该业务公司不存在');
  109. $userCommon = new \app\admin\common\User();
  110. $names = $userCommon->handle('getCodeAndName', ['code' => [$param['customerCode'], $param['supplierNo']]]);
  111. if (!isset($names['data'][$param['customerCode']]) || $names['data'][$param['customerCode']] == '') return json_show(1004, '该业务公司不存在');
  112. if (!isset($names['data'][$param['supplierNo']]) || $names['data'][$param['supplierNo']] == '') return json_show(1004, '该供应商不存在');
  113. $rs = Db::name('filing')
  114. ->strict(false)
  115. ->insert(array_merge($param, [
  116. 'customerName' => $names['data'][$param['customerCode']],
  117. 'supplierName' => $names['data'][$param['supplierNo']],
  118. 'filingCode' => makeNo('BM'),
  119. 'service_proportion' => $param['expect_service_proportion'],//服务费比例与期望服务费比例一致
  120. 'service_charge' => $param['expect_service'],//服务费与期望服务费一致
  121. 'specinfo' => json_encode($param['spec_list']),
  122. 'send_way' => 2,
  123. 'cert_fee' => 0,
  124. 'pakge_fee' => 0,
  125. 'cost_fee' => 0,
  126. 'mark_fee' => 0,
  127. 'demo_fee' => 0,
  128. 'open_fee' => 0,
  129. 'delivery_fee' => 0,
  130. 'is_gold_price' => 0,
  131. 'is_diff' => 0,
  132. 'apply_id' => $this->uid,
  133. 'apply_name' => $this->uname,
  134. 'status' => 0,
  135. 'is_del' => 0,
  136. 'addtime' => date('Y-m-d H:i:s'),
  137. 'updatetime' => date('Y-m-d H:i:s'),
  138. 'gold_weight' => $param['gold_weight'] ?? 0,
  139. 'noble_metal' => $param['noble_metal'] ?? 0,
  140. 'config' => $param['config'] ?? '',
  141. 'other_config' => $param['other_config'] ?? '',
  142. 'good_img' => implode(',', $param['good_img']),
  143. 'origin_place' => implode(',', $param['origin_place']),
  144. 'delivery_place' => implode(',', $param['delivery_place']),
  145. ]));
  146. return $rs ? json_show(0, '创建报备单成功') : json_show(1004, '创建报备单失败');
  147. // $param['supplierNo']= $this->request->user['supplierNo'];
  148. // $param['supplierName']= $this->request->user['supplierName'];
  149. // return FilingLogic::add($param);
  150. }
  151. //详情
  152. public function detail()
  153. {
  154. $param = $this->request->only(['id' => 0], 'post', 'trim');
  155. $rs = Db::name('filing')
  156. ->alias('a')
  157. ->field('a.*,b.brand_name,d.unit unit_name,p.platform_name,"" cat_info')
  158. ->leftJoin('brand b', 'b.id=a.brand_id')
  159. ->leftJoin('unit d', 'd.id=a.unit_id')
  160. ->leftJoin('platform p', 'p.id=a.platform_id')
  161. ->where(['a.is_del' => 0, 'a.id' => $param['id']])
  162. ->withAttr('specinfo', function ($val) {
  163. return json_decode($val);
  164. })
  165. ->withAttr('good_img', function ($val) {
  166. return explode(',', $val);
  167. })->withAttr('origin_place', function ($val) {
  168. return explode(',', $val);
  169. })->withAttr('delivery_place', function ($val) {
  170. return explode(',', $val);
  171. })->withAttr('cat_info', function ($val, $da) {
  172. return made($da['cat_id']);
  173. })
  174. ->findOrEmpty();
  175. return json_show(0, '获取报备单详情成功', $rs);
  176. // return FilingLogic::detail($param);
  177. }
  178. //审核
  179. public function status()
  180. {
  181. if ($this->level != 2) return json_show(1004, '业务公司账号不能审核');
  182. $param = $this->request->only(['id', 'status', 'companyCode', 'plat_code' => '', 'service_charge', 'service_proportion', 'platform_id'], 'post');
  183. $val = Validate::rule([
  184. 'id' => 'require|number|gt:0',
  185. 'status|状态' => 'require|number|in:1,2',
  186. 'companyCode|客户' => 'require|length:18',
  187. 'service_charge|服务费' => 'require|float|egt:0|max:99999999.99',
  188. 'service_proportion|服务费比例' => 'require|float|egt:0',
  189. 'platform_id|平台id' => 'require|number|gt:0',
  190. ]);
  191. if (!$val->check($param)) return json_show(1004, $val->getError());
  192. $rs = Db::name('filing')
  193. ->field('id,status,is_determine_price,price,cgd_charge,platform_id,companyCode')
  194. ->where(['is_del' => 0, 'id' => $param['id']])
  195. ->whereIn('status', [0, 2])
  196. ->findOrEmpty();
  197. if (empty($rs)) return json_show(1005, '该报备单不存在或不允许审核');
  198. $userCommon = new \app\admin\common\User();
  199. $company = $userCommon->handle('cInfo', ['companyNo' => $param['companyCode']]);
  200. if (!isset($company['data'])) return json_show(1005, '该客户不存在');
  201. // $companyName = Db::name('customer_info')
  202. // ->where(['is_del' => 0, 'companyNo' => $param['companyCode']])
  203. // ->value('companyName', '');
  204. // if ($companyName == '') return json_show(1005, '该客户不存在');
  205. $tmp = Db::name('platform')
  206. ->where(['is_del' => 0, 'id' => $param['platform_id']])
  207. ->field('id,is_select_pay_rate')
  208. ->findOrEmpty();
  209. if (empty($tmp)) return json_show(1005, '该平台不存在');
  210. //校验支付渠道中的业务公司是否与报备单业务公司重复
  211. if ($tmp['is_select_pay_rate'] == 1) {
  212. $temp = Db::name('platform_pay_rate')
  213. ->where(['is_del' => 0, 'platform_id' => $rs['platform_id'], 'companyNo' => $rs['companyCode']])
  214. ->field('id')
  215. ->findOrEmpty();
  216. if (!empty($temp)) return json_show(1004, '业务公司重复,请选择其他平台');
  217. }
  218. $update = array_merge($param, [
  219. 'companyName' => $company['data']['companyName'],
  220. 'updatetime' => date('Y-m-d H:i:s'),
  221. ]);
  222. if ($rs['is_determine_price'] == 1) $update['cgd_charge'] = round(bcsub($rs['price'], $param['service_charge'], 3), 2);//确定售价时,采购价=售价-服务费
  223. else $update['price'] = round(bcadd($rs['cgd_charge'], $param['service_charge'], 3), 2);//不确定售价时,售价=采购价+服务费
  224. $res = Db::name('filing')
  225. ->where(['is_del' => 0, 'id' => $param['id']])
  226. ->whereIn('status', [0, 2])
  227. ->update($update);
  228. return $res ? json_show(0, '操作成功') : json_show(1004, '操作失败');
  229. // return FilingLogic::status($param);
  230. }
  231. //取消转单
  232. public function cancel()
  233. {
  234. if ($this->level == 1) return json_show(1004, '超管不允许操作');
  235. $param = $this->request->only(['id'], 'post');
  236. // $param['supplierNo'] = $this->request->user['supplierNo'];
  237. // return FilingLogic::cancel($param);
  238. $where = [
  239. ['is_del', '=', 0],
  240. ['id', '=', $param['id']],
  241. // ['supplierNo', '=', $param['supplierNo']],
  242. ['status', 'in', [0, 1, 2, 4]]
  243. ];
  244. $rs = Db::name('filing')
  245. ->field('id,status,supplierNo')
  246. ->where($where)
  247. ->findOrEmpty();
  248. if (empty($rs)) return json_show(1005, '该报备单不存在或不允许取消');
  249. //level3账号都可以操作
  250. //level2账号的话,只有供应商负责人能操作
  251. if ($this->level == 2) {
  252. $userCommon = new \app\admin\common\User();
  253. $supp = $userCommon->handle('sInfo', ['code' => $rs['supplierNo']]);
  254. if ($this->uid != $supp['data']['personid']) return json_show(1004, '只有供应商负责人才能操作');
  255. }
  256. $res = Db::name('filing')
  257. ->where($where)
  258. ->update(['status' => 5, 'updatetime' => date('Y-m-d H:i:s')]);
  259. return $res ? json_show(0, '操作成功') : json_show(1004, '操作失败');
  260. }
  261. //转单
  262. public function transfer()
  263. {
  264. if ($this->level == 1) return json_show(1004, '超管不允许操作');
  265. $param = $this->request->only(['id', 'addr_list'], 'post');
  266. $val = Validate::rule([
  267. 'id' => 'require|number|gt:0',
  268. 'addr_list|收货地址' => 'require|array|max:100',
  269. ]);
  270. if (!$val->check($param)) return json_show(1004, $val->getError());
  271. $val2 = Validate::rule([
  272. 'receipt_quantity|收货数量' => 'require|number|gt:0|max:999999999',
  273. 'contactor|联系人' => 'require|max:255',
  274. 'mobile|联系电话' => 'require|mobile',
  275. 'addr_code|收货省市区编码' => 'require|array|length:3',
  276. 'addr|详细地址' => 'require|max:255',
  277. ]);
  278. foreach ($param['addr_list'] as $addr_list) {
  279. if (!$val2->check($addr_list)) return json_show(1004, $val2->getError());
  280. }
  281. $filing = Db::name('filing')
  282. ->field(true)
  283. ->where(['is_del' => 0, 'id' => $param['id'], 'status' => 2])
  284. ->findOrEmpty();
  285. if (empty($filing)) return json_show(1005, '该报备单不存在或不允许转单');
  286. if (array_sum(array_column($param['addr_list'], 'receipt_quantity')) != $filing['num']) return json_show(1004, '收货地址的收货总数不符合');
  287. // $supplier = Db::name('supplier')
  288. // ->field('id,person,personid,name,code')
  289. // ->where(['code' => $filing['supplierNo']])
  290. // ->findOrEmpty();
  291. $userCommon = new \app\admin\common\User();
  292. $supplier = $userCommon->handle('sInfo', ['code' => $filing['supplierNo']]);
  293. // $names = $userCommon->handle('getCodeAndName', ['code' => [$filing['companyCode'], $filing['customerCode'],]]);
  294. //level3账号都可以操作
  295. //level2账号的话,只有供应商负责人能操作
  296. if (($this->level == 2) && ($this->uid != $supplier['data']['personid'])) return json_show(1004, '只有供应商负责人才能操作');
  297. $date = date('Y-m-d H:i:s');
  298. Db::startTrans();
  299. try {
  300. $order_type = 4;//报备商品
  301. $order_source = 7;//报备转单
  302. $spuCode = makeNo('SKU');
  303. //商品表
  304. Db::name('good_zixun')
  305. ->insert([
  306. 'spuCode' => $spuCode,
  307. 'good_name' => $filing['good_name'],
  308. 'brand_id' => $filing['brand_id'],
  309. 'cat_id' => $filing['cat_id'],
  310. 'good_unit' => $filing['unit_id'],
  311. 'good_type' => 0,
  312. 'moq' => 1,
  313. 'customized' => $filing['make_day'],
  314. 'tax' => $filing['tax'],
  315. 'platform_id' => $filing['platform_id'],
  316. 'supplierNo' => $filing['supplierNo'],
  317. 'supplierName' => $supplier['data']['name'],
  318. 'is_auth' => 0,
  319. 'craft_desc' => $filing['good_name'],
  320. 'good_remark' => '',
  321. 'good_img' => $filing['good_img'],
  322. 'good_thumb_img' => '',
  323. 'good_info_img' => '',
  324. 'status' => 1,
  325. 'createrid' => $filing['apply_id'],
  326. 'creater' => $filing['apply_name'],
  327. 'is_del' => 0,
  328. 'addtime' => $date,
  329. 'updatetime' => $date,
  330. 'specinfo' => $filing['specinfo'],
  331. 'work_day' => $filing['make_day'],
  332. 'noble_metal' => $filing['noble_metal'],
  333. 'is_gold_price' => $filing['is_gold_price'],
  334. 'good_weight' => $filing['gold_weight'],
  335. 'config' => $filing['config'],
  336. 'other_config' => $filing['other_config'],
  337. 'weight' => $filing['weight'],
  338. 'supply_area' => $filing['supply_area'],
  339. 'is_diff' => $filing['is_diff'],
  340. 'pay_way' => $filing['pay_way'],
  341. 'send_way' => $filing['send_way'],
  342. 'companyNo' => $filing['customerCode'],
  343. 'proof_type' => '',
  344. 'proof_url' => '',
  345. 'order_type' => $order_type
  346. ]);
  347. $orderCode = makeNo('QR');
  348. //订单表
  349. //sale
  350. $sale_id = Db::name('sale')->insertGetId([
  351. 'orderCode' => $orderCode,
  352. 'apply_id' => $filing['apply_id'],
  353. 'apply_name' => $filing['apply_name'],
  354. 'order_type' => $order_type,//报备商品
  355. 'order_source' => $order_source,//报备转单
  356. 'platform_id' => $filing['platform_id'],
  357. 'good_code' => $spuCode,
  358. 'skuCode' => '',
  359. 'cat_id' => $filing['cat_id'],
  360. 'good_name' => $filing['good_name'],
  361. 'good_num' => $filing['num'],
  362. 'good_type' => 1,
  363. 'origin_price' => $filing['cgd_charge'],
  364. 'sale_price' => $filing['price'],
  365. 'total_price' => round(bcmul($filing['price'], $filing['num'], 3), 2),
  366. 'post_fee' => 0,
  367. 'is_diff' => $filing['is_diff'],
  368. 'is_activity' => 0,
  369. 'activity_code' => '',
  370. 'is_stock' => 0,
  371. 'customer_code' => $filing['companyCode'],
  372. 'customerName' => $filing['companyName'],
  373. 'supplierNo' => $filing['customerCode'],
  374. 'supplierName' => $filing['customerName'],
  375. 'supNo' => $filing['supplierNo'],
  376. 'supName' => $filing['supplierName'],
  377. 'zxNo' => '',
  378. 'platform_order' => '',
  379. 'send_num' => 0,
  380. 'wsend_num' => $filing['num'],
  381. 'th_num' => 0,
  382. 'th_fee' => 0,
  383. 'send_status' => 1,
  384. 'send_type' => 1,//直接发货
  385. 'remark' => '',
  386. 'status' => 0,
  387. 'is_del' => 0,
  388. 'proof_id' => 0,
  389. 'other_orderNo' => '',
  390. 'workNo' => '',
  391. 'poNo' => '',
  392. 'use_order' => 0,
  393. 'good_weight' => 0,
  394. 'gold_price' => 0,
  395. 'cost_price' => $filing['cost_fee'],
  396. 'diff_weight' => 0,
  397. 'diff_fee' => 0,
  398. 'returnCode' => '',
  399. 'addtime' => $date,
  400. 'updatetime' => $date,
  401. 'cgderid' => $supplier['data']['personid'],
  402. 'cgder' => $supplier['data']['person'],
  403. 'good_createrid' => $filing['apply_id'],
  404. 'good_creater' => $filing['apply_name'],
  405. ]);
  406. //仓库
  407. $wsm = Db::name('warehouse_info')
  408. ->field('id,wsm_code')
  409. ->where(['supplierNo' => $filing['supplierNo'], 'companyNo' => $filing['customerCode'], 'is_del' => 0])
  410. ->findOrEmpty();
  411. if (empty($wsm)) {
  412. $wsm_code = makeNo('WSM');
  413. Db::name('warehouse_info')->insert([
  414. 'wsm_code' => $wsm_code,
  415. 'name' => $supplier['data']['name'],
  416. 'wsm_type' => 2,
  417. 'supplierNo' => $supplier['data']['code'],
  418. 'addr' => '',
  419. 'addrs_code' => '',
  420. 'contactor' => 0,
  421. 'contactor_name' => 0,
  422. 'mobile' => '',
  423. 'position' => '',
  424. 'companyNo' => $filing['supplierNo'],
  425. 'status' => 1,
  426. 'is_del' => 0,
  427. 'addtime' => $date,
  428. 'updatetime' => $date,
  429. ]);
  430. } else $wsm_code = $wsm['wsm_code'];
  431. //采购单
  432. $cgdCode = makeNo('CG');
  433. Db::name('purchease_order')->insert([
  434. 'cgdNo' => $cgdCode,
  435. 'bkcode' => '',
  436. 'wsm_code' => $wsm_code,
  437. 'cgder' => $supplier['data']['person'],
  438. 'cgder_id' => $supplier['data']['personid'],
  439. 'spuCode' => $spuCode,
  440. 'good_name' => $filing['good_name'],
  441. 'good_num' => $filing['num'],
  442. 'good_price' => $filing['cgd_charge'],
  443. 'total_fee' => round(bcmul($filing['cgd_charge'], $filing['num']), 2),
  444. 'pakge_fee' => $filing['pakge_fee'],
  445. 'cert_fee' => $filing['cert_fee'],
  446. 'open_fee' => $filing['open_fee'],
  447. 'delivery_fee' => $filing['delivery_fee'],
  448. 'mark_fee' => $filing['mark_fee'],
  449. 'demo_fee' => $filing['demo_fee'],
  450. 'diff_weight' => '0',
  451. 'diff_fee' => '0',
  452. 'gold_price' => '0',
  453. 'supplierNo' => $filing['supplierNo'],
  454. 'supplier_name' => $filing['supplierName'],
  455. 'companyNo' => $filing['customerCode'],
  456. 'companyName' => $filing['customerName'],
  457. 'send_status' => 1,
  458. 'send_num' => '0',
  459. 'wsend_num' => $filing['num'],
  460. 'remark' => '',
  461. 'status' => 0,
  462. 'lasttime' => $date,
  463. 'is_del' => 0,
  464. 'order_type' => $order_type,
  465. 'order_source' => $order_source,
  466. 'good_type' => 1,
  467. 'addtime' => $date,
  468. 'updatetime' => $date,
  469. 'good_createrid' => $filing['apply_id'],
  470. 'good_creater' => $filing['apply_name'],
  471. ]);
  472. //台账
  473. $standing_bood_data = [
  474. 'standBookNo' => makeNo('IO'),
  475. 'orderCode' => $orderCode,
  476. 'sale_id' => $sale_id,
  477. 'customer_code' => $filing['companyCode'],
  478. 'supplierNo' => $filing['supplierNo'],
  479. 'order_type' => $order_type,
  480. 'order_source' => $order_source,
  481. 'spuCode' => $spuCode,
  482. 'addtime' => $date,
  483. 'updatetime' => $date,
  484. 'cgdNo' => $cgdCode,
  485. ];
  486. $i = 0;
  487. $order_send_insert = [];
  488. foreach ($param['addr_list'] as $addr) {
  489. //地址addr
  490. $addrid = Db::name('order_addr')->insertGetId([
  491. 'orderCode' => $orderCode,
  492. 'addr' => $addr['addr'],
  493. 'addr_code' => implode(',', $addr['addr_code']),
  494. 'contactor' => $addr['contactor'],
  495. 'mobile' => $addr['mobile'],
  496. 'customer_code' => $filing['companyCode'],
  497. 'post_fee' => 0,
  498. 'receipt_quantity' => $addr['receipt_quantity'],
  499. 'is_del' => 0,
  500. 'addtime' => $date,
  501. 'updatetime' => $date,
  502. ]);
  503. //发货单
  504. $outCode = makeNo('DF');
  505. //改变编码规则,将原来的编码后两位换成序列号
  506. //str_pad字符串填充
  507. $outCode = substr($outCode, 0, -2) . str_pad($i, 2, '0', STR_PAD_LEFT);
  508. Db::name('order_out')->insert([
  509. 'orderCode' => $orderCode,
  510. 'outCode' => $outCode,
  511. 'apply_id' => $this->uid,
  512. 'apply_name' => $this->uname,
  513. 'addrid' => $addrid,
  514. 'post_name' => '',
  515. 'post_code' => '',
  516. 'post_fee' => 0,
  517. 'sendtime' => $date,
  518. 'send_num' => $addr['receipt_quantity'],
  519. 'check_num' => 0,
  520. 'error_num' => 0,
  521. 'wsm_code' => '',
  522. 'order_type' => $order_type,
  523. 'status' => 0,
  524. 'addtime' => $date,
  525. 'updatetime' => $date,
  526. ]);
  527. $standing_bood_data['outCode'][] = $outCode;
  528. $order_send_insert[] = [
  529. 'cgdNo' => $cgdCode,
  530. 'outCode' => $outCode,
  531. 'send_num' => $addr['receipt_quantity'],
  532. 'bnCode' => '',
  533. 'status' => 1,
  534. 'addtime' => $date,
  535. 'updatetime' => $date,
  536. ];
  537. $i++;
  538. }
  539. //更新报备单
  540. Db::name('filing')
  541. ->where(['is_del' => 0, 'id' => $param['id'], 'status' => 2])
  542. ->update(['status' => 3, 'updatetime' => $date, 'orderCode' => $orderCode, 'reason' => '']);
  543. //待办已办先不处理
  544. //关联表
  545. Db::name('order_num')
  546. ->insert([
  547. 'orderCode' => $orderCode,
  548. 'cgdNo' => $cgdCode,
  549. 'spuCode' => $spuCode,
  550. 'companyNo' => $filing['customerCode'],
  551. 'good_num' => $filing['num'],
  552. 'wsend_num' => $filing['num'],
  553. 'send_num' => 0,
  554. 'wait_num' => $filing['num'],
  555. ]);
  556. if ($order_send_insert) Db::name('order_send')->insertAll($order_send_insert);
  557. //处理台账
  558. if (isset($standing_bood_data['outCode']) && is_array($standing_bood_data['outCode'])) $standing_bood_data['outCode'] = implode(',', $standing_bood_data['outCode']);
  559. Db::name('standing_book')->insert($standing_bood_data);
  560. Db::commit();
  561. return json_show(0, '转单成功');
  562. } catch (Exception $exception) {
  563. Db::rollback();
  564. Db::name('filing')
  565. ->where(['is_del' => 0, 'id' => $param['id'], 'status' => 2])
  566. ->update(['status' => 4, 'updatetime' => $date, 'reason' => $exception->getMessage()]);
  567. return json_show(1005, '转单失败,' . $exception->getMessage());
  568. }
  569. // $param['supplierNo'] = $this->request->user['supplierNo'];
  570. // return FilingLogic::transfer($param);
  571. }
  572. //订单录入
  573. public function orderAdd()
  574. {
  575. $param = $this->request->param([
  576. "companyNo" => '',
  577. "poCode" => "",
  578. "workCode" => "",
  579. "khNo" => "",
  580. "qrdType" => 3,
  581. "goodName" => "",
  582. "tax" => "",
  583. "goodNum" => "",
  584. "goodPrice" => "",
  585. "goodUnit" => "",
  586. "mobile" => "",
  587. "addr" => "",
  588. "addr_code" => "",
  589. "contactor" => "",
  590. "buyerid" => "",
  591. "buyer_name" => "",
  592. "sendtime" => "",
  593. "cat_id" => '',
  594. "supplierNo" => "",
  595. "cgd_tax" => "",
  596. "platform_id" => "0",
  597. ], "post", "trim");
  598. $valid = Validate::rule([
  599. "companyNo|业务公司编号" => "require|max:255|min:1",
  600. "supplierNo|业务公司编号" => "require|max:255|min:1",
  601. "poCode|PO编号" => "require|max:255|min:1",
  602. "khNo|客户公司编号" => "require|max:255|min:1",
  603. "qrdType|订单类型" => "require|number|in:1,2,3",
  604. "goodName|商品名称" => "require|max:255|min:1",
  605. "goodUnit|商品单位" => "require|number|gt:0",
  606. "tax|税率" => "require|number|gt:0",
  607. "goodNum|商品数量" => "require|number|gt:0",
  608. "goodPrice|商品单价" => "require|float|gt:0",
  609. "mobile|联系人电话" => "require|number|mobile",
  610. "contactor|联系人" => "require|max:255|min:1",
  611. "addr|收货地址" => "require|max:255|min:1",
  612. "buyerid|采购员ID" => "require|number|gt:0",
  613. "buyer_name|采购员" => "require|max:255|min:1",
  614. "sendtime|发货时间" => "require|date",
  615. "cat_id|商品分类id" => "require|number|gt:0",
  616. "cgd_tax|采购毛利率" => "require|float|gt:0",
  617. "platform_id|平台" => "require|number"
  618. ]);
  619. if ($valid->check($param) == false) return error_show(1004, $valid->getError());
  620. $qrdcode = makeNo("QR");
  621. $cgddcode = makeNo("CG");
  622. $goodCode = makeNo("SKU");
  623. $userCommon = new \app\admin\common\User();
  624. $tmp = $userCommon->handle('getCodeAndName',['code'=>[$param['khNo'],$param['supplierNo'],$param['companyNo']]]);
  625. if(!isset($tmp['code']) || $tmp['code']!=0) return json_show($tmp['code'],$tmp['message'],$tmp['data']);
  626. if(!isset($tmp['data'][$param['khNo']])) return json_show(1004, "未找到客户数据");
  627. if(!isset($tmp['data'][$param['supplierNo']])) return json_show(1004, "未找到平台供应商数据");
  628. if(!isset($tmp['data'][$param['companyNo']])) return json_show(1004, "未找到平台业务公司数据");
  629. if($tmp['data'][$param['supplierNo']] == $tmp['data'][$param['companyNo']]) return json_show(1004,'供应商和业务公司不能为同一家公司');
  630. // $customer = Db::name("customer_info")->where('companyNo', "=", $param['khNo'])->find();
  631. // if ($customer == false) return error_show(1004, "客户信息未找到");
  632. // $supplierName = Db::name("supplier")->where('code', "=", $param['supplierNo'])->value("name", "");
  633. // if ($supplierName == '') return error_show(1004, "供应商信息未找到");
  634. // $companyName = Db::name("supplier")->where('code', "=", $param['companyNo'])->value("name", "");
  635. // if ($companyName == '') return error_show(1004, "业务公司信息未找到");
  636. // if ($param['platform_id'] != 0) {
  637. $payinfo = Db::name("platform")->where(["id"=> $param['platform_id'],"is_del"=>0])->findOrEmpty();
  638. if (empty($payinfo)) return error_show(1004, "平台信息未找到");
  639. if ($payinfo['status'] != 1) return error_show(1004, "平台信息已禁用");
  640. if($payinfo['is_select_pay_rate']==1){
  641. $supplierArr = Db::name("platform_pay_rate")->where(["platform_id" => $param['platform_id'], "status" => 1, "is_del" => 0])->column("companyNo");
  642. if (in_array($param['companyNo'], $supplierArr)) return error_show(1004, "平台支付渠道含有该业务公司,平台无法使用!");
  643. }
  644. // }
  645. $param["cgd_tax"] = $param["cgd_tax"] / 100;
  646. $cgdPrice = round($param['goodPrice'] * (1 - $param['cgd_tax']), 2);
  647. $qrddata = [
  648. "orderCode" => $qrdcode,
  649. "apply_id" => $this->uid,
  650. "apply_name" => $this->uname,
  651. "order_type" => $param['qrdType'],
  652. "order_source" => 9,
  653. "platform_id" => $param['platform_id'],
  654. "good_code" => $goodCode,
  655. "skuCode" => '',
  656. "cat_id" => $param['cat_id'],
  657. "good_name" => $param['goodName'],
  658. "good_num" => $param['goodNum'],
  659. "good_type" => 1,
  660. "origin_price" => $cgdPrice,
  661. "sale_price" => $param['goodPrice'],
  662. "total_price" => round($param['goodPrice'] * $param['goodNum'], 2),
  663. "post_fee" => 0,
  664. "is_diff" => 0,
  665. "is_activity" => 0,
  666. "activity_code" => '',
  667. "is_stock" => 0,
  668. "arrive_time" => $param['sendtime'],
  669. "customer_code" => $param['khNo'],
  670. "customerName" => $tmp['data'][$param['khNo']],
  671. "supplierNo" => $param['companyNo'],
  672. "supplierName" =>$tmp['data'][$param['companyNo']],
  673. "supName" => $tmp['data'][$param['supplierNo']],
  674. "supNo" => $param['supplierNo'],
  675. "platform_order" => $param['poCode'],
  676. "send_num" => $param['goodNum'],
  677. "wsend_num" => 0,
  678. "send_status" => 3,
  679. "send_type" => 1,
  680. "status" => 2,
  681. "is_del" => 0,
  682. "pay_id" => 0,
  683. "workNo" => $param['workCode'],
  684. "addtime" => date("Y-m-d H:i:s"),
  685. "updatetime" => date("Y-m-d H:i:s"),
  686. "cgderid" => $param['buyerid'],
  687. "cgder" => $param['buyer_name'],
  688. "good_createrid" => $this->uid,
  689. "good_creater" => $this->uname
  690. ];
  691. $orderCgd = [
  692. "orderCode" => $qrdcode,
  693. "cgdNo" => $cgddcode,
  694. "spuCode" => $goodCode,
  695. "good_num" => $param['goodNum'],
  696. "wsend_num" => 0,
  697. "send_num" => $param['goodNum'],
  698. "wait_num" => 0
  699. ];
  700. $cgddata = [
  701. "cgdNo" => $cgddcode,
  702. "bkcode" => '',
  703. "wsm_code" => "",
  704. "cgder_id" => $param['buyerid'],
  705. 'cgder' => $param['buyer_name'],
  706. "spuCode" => $goodCode,
  707. "good_name" => $param['goodName'],
  708. "good_num" => $param['goodNum'],
  709. "good_price" => $cgdPrice,
  710. "total_fee" => round($cgdPrice * $param['goodNum'], 2),
  711. "supplierNo" => $param['supplierNo'],
  712. "supplier_name" =>$tmp['data'][$param['supplierNo']],
  713. "companyNo" => $param['companyNo'],
  714. "companyName" => $tmp['data'][$param['companyNo']],
  715. "send_status" => 3,
  716. "send_num" => $param['goodNum'],
  717. "wsend_num" => 0,
  718. "status" => 3,
  719. "lasttime" => date("Y-m-d H:i:s"),
  720. "order_type" => $param['qrdType'],
  721. "order_source" => 9,
  722. "addtime" => date("Y-m-d H:i:s"),
  723. "updatetime" => date("Y-m-d H:i:s"),
  724. "good_createrid" => $this->uid,
  725. "good_creater" => $this->uname,
  726. ];
  727. $goodinfo = [
  728. "spuCode" => $goodCode,
  729. "good_name" => $param['goodName'],
  730. "brand_id" => 0,
  731. "cat_id" => $param['cat_id'],
  732. "good_unit" => $param['goodUnit'],
  733. "good_type" => 1,
  734. "moq" => 1,
  735. "customized" => 0,
  736. "platform_id" => $param['platform_id'],
  737. "tax" => $param['tax'],
  738. "supplierNo" => $param['supplierNo'],
  739. "supplierName" =>$tmp['data'][$param['supplierNo']],
  740. "is_auth" => 1,
  741. "craft_desc" => '',
  742. "good_remark" => '',
  743. "good_img" => '',
  744. "good_thumb_img" => '',
  745. "good_info_img" => '',
  746. "createrid" => $this->uid,
  747. "creater" => $this->uname,
  748. "specinfo" => '',
  749. "work_day" => 0,
  750. "noble_metal" => 0,
  751. "good_weight" => 0,
  752. "config" => "",
  753. "weight" => 0,
  754. "supply_area" => 0,
  755. "is_diff" => 0,
  756. "pay_way" => 0,
  757. "send_way" => 0,
  758. "companyNo" => $param['companyNo'],
  759. "companyName" => $tmp['data'][$param['companyNo']],
  760. "addtime" => date("Y-m-d H:i:s"),
  761. "updatetime" => date("Y-m-d H:i:s"),
  762. ];
  763. $orderAddr = [
  764. "orderCode" => $qrdcode,
  765. "addr" => $param['addr'],
  766. "addr_code" => $param['addr_code'],
  767. "contactor" => $param['contactor'],
  768. "mobile" => $param['mobile'],
  769. "arrive_time" => $param['sendtime'],
  770. "customer_code" => $param['khNo'],
  771. "receipt_quantity" => $param['goodNum'],
  772. "addtime" => date("Y-m-d H:i:s"),
  773. "updatetime" => date("Y-m-d H:i:s"),
  774. ];
  775. Db::startTrans();
  776. try {
  777. $qrd = Db::name("sale")->insert($qrddata);
  778. if ($qrd == false) throw new Exception("销售单生成失败");
  779. $qrd = Db::name("order_num")->insert($orderCgd);
  780. if ($qrd == false) throw new Exception("销售单采购管联生成失败");
  781. $qrd = Db::name("purchease_order")->insert($cgddata);
  782. if ($qrd == false) throw new Exception("采购单生成失败");
  783. $qrd = Db::name("good_zixun")->insert($goodinfo);
  784. if ($qrd == false) throw new Exception("商品信息录入生成失败");
  785. $qrd = Db::name("order_addr")->insert($orderAddr);
  786. if ($qrd == false) throw new Exception("销售单地址生成失败");
  787. // if ($param['pay_id'] != 0) {
  788. // pay_log($param['pay_id'], $param['companyNo'], $qrdcode);
  789. // }
  790. Db::commit();
  791. return app_show(0, '订单生成成功');
  792. } catch (\Exception $exception) {
  793. Db::rollback();
  794. return error_show(1004, $exception->getMessage());
  795. }
  796. }
  797. public function orderInfo()
  798. {
  799. $param = $this->request->param(["orderCode"], "post", "trim");
  800. if ($param['orderCode'] == '') return error_show(1004, "订单编号不能为空");
  801. $saleinfo = Db::name("sale")->where(["orderCode" => $param['orderCode']])->findOrEmpty();
  802. if (empty($saleinfo)) return error_show(1004, "销售单不存在");
  803. if ($saleinfo['order_source'] != 9) return error_show(1004, "销售单来源不是网络录入");
  804. $cgd = Db::name("purchease_order")->alias("a")
  805. ->leftJoin("order_num b", "a.cgdNo=b.cgdNo")
  806. ->where(["b.orderCode" => $param['orderCode']])
  807. ->field("a.*")
  808. ->findOrEmpty();
  809. if (empty($cgd)) return error_show(1004, "采购单不存在");
  810. $goodinfo = Db::name("good_zixun")->where(["spuCode" => $saleinfo['good_code']])->findOrEmpty();
  811. if (empty($goodinfo)) return error_show(1004, "商品信息不存在");
  812. $addr = Db::name("order_addr")->where(["orderCode" => $param['orderCode']])->findOrEmpty();
  813. if (empty($addr)) return error_show(1004, "地址信息不存在");
  814. $addinfo = $addr['addr_code'] != '' ? json_decode($addr['addr_code'], true) ?? $addr['addr_code'] : '';
  815. if (is_string($addinfo) && $addinfo != '') {
  816. $addinfo = ["provice_code" => '', "city_code" => '', "area_code" => ''];
  817. list($addinfo['provice_code'], $addinfo['city_code'], $addinfo['area_code']) = explode(",", $addr['addr_code']);
  818. }
  819. $platform = Db::name("platform")->where(["id" => $saleinfo['platform_id']])->field("platform_name,pay_title")
  820. ->findOrEmpty();
  821. $userCommon = new \app\admin\common\User();
  822. $names = $userCommon->handle('getCodeAndName', ['code' => [$saleinfo['supplierNo'], $saleinfo['customer_code']]]);
  823. $data = [
  824. "orderCode" => $saleinfo['orderCode'],
  825. "companyNo" => $saleinfo['supplierNo'],
  826. "companyName" => $names['data'][$saleinfo['supplierNo']] ?? '',//Db::name("supplier")->where(["code" => $saleinfo['supplierNo']])->value("name", ''),
  827. "poCode" => $saleinfo['platform_order'],
  828. "workCode" => $saleinfo['workNo'],
  829. "platform_id" => $saleinfo['platform_id'],
  830. "platform_name" =>$platform['platform_name']??"",
  831. "khNo" => $saleinfo['customer_code'],
  832. "khName" => $names['data'][$saleinfo['customer_code']] ?? '',//Db::name("customer_info")->where(["companyNo" => $saleinfo['customer_code']])->value("companyName", ''),
  833. "qrdType" => $saleinfo['order_type'],
  834. "goodName" => $saleinfo['good_name'],
  835. "tax" => $goodinfo['tax'],
  836. "goodUnit" => $goodinfo['good_unit'],
  837. "unitName" => Db::name("unit")->where(["id" => $goodinfo['good_unit']])->value("unit", ""),
  838. "goodNum" => $saleinfo['good_num'],
  839. "goodPrice" => $saleinfo['sale_price'],
  840. "mobile" => $addr['mobile'],
  841. "addr" => $addr['addr'],
  842. "addr_cn" => GetAddr(json_encode($addinfo)),
  843. "addr_code" => $addr['addr_code'],
  844. "contactor" => $addr['contactor'],
  845. "buyerid" => $saleinfo['cgderid'],
  846. "buyer_name" => $saleinfo['cgder'],
  847. "sendtime" => $saleinfo['arrive_time'],
  848. "cat_id" => made($saleinfo['cat_id']),
  849. "cat_name" => Db::name("cat")->where(["id" => $saleinfo['cat_id']])->value("cat_name", ''),
  850. "supplierNo" => $cgd['supplierNo'],
  851. "supplierNanme" => $cgd['supplier_name'],
  852. "cgd_tax" => round(($saleinfo['sale_price'] - $saleinfo['origin_price']) / $saleinfo['sale_price'], 4) * 100,
  853. "pay_id" => $saleinfo['pay_id'],
  854. "pay_name" =>$platform['pay_title']??"",
  855. ];
  856. return app_show(0, "获取成功", $data);
  857. }
  858. public function orderEdit()
  859. {
  860. $param = $this->request->param([
  861. "orderCode" => "",
  862. // "companyNo" => '',
  863. "poCode" => "",
  864. "workCode" => "",
  865. // "khNo" => "",
  866. "tax" => "",
  867. "goodUnit" => "",
  868. "mobile" => "",
  869. "addr" => "",
  870. "addr_code" => "",
  871. "contactor" => "",
  872. "buyerid" => "",
  873. "buyer_name" => "",
  874. "sendtime" => "",
  875. "supplierNo" => "",
  876. "cgd_tax" => ""
  877. ], "post", "trim");
  878. $valid = Validate::rule([
  879. "orderCode|销售单号" => "require|max:255",
  880. // "companyNo|业务公司编号"=>"require|max:255|min:1",
  881. "supplierNo|供应商公司编号" => "require|max:255|min:1",
  882. "poCode|PO编号" => "require|max:255|min:1",
  883. // "workCode|业务编号"=>"require|max:255|min:1",
  884. // "khNo|客户公司编号"=>"require|max:255|min:1",
  885. "mobile|联系人电话" => "require|number|mobile",
  886. "goodUnit|商品单位" => "require|number|gt:0",
  887. "contactor|联系人" => "require|max:255|min:1",
  888. "addr|收货地址" => "require|max:255|min:1",
  889. "addr_code|收货省市区" => "require|max:255|min:1",
  890. "buyerid|采购员ID" => "require|number|gt:0",
  891. "buyer_name|采购员" => "require|max:255|min:1",
  892. "sendtime|发货时间" => "require|date",
  893. "tax|商品利率" => "require|number",
  894. "cgd_tax|采购毛利率" => "require|float|gt:0",
  895. ]);
  896. if ($valid->check($param) == false) return error_show(1004, $valid->getError());
  897. $param["cgd_tax"] = $param["cgd_tax"] / 100;
  898. $saleinfo = Db::name("sale")->where(["orderCode" => $param['orderCode']])->findOrEmpty();
  899. if (empty($saleinfo)) return error_show(1004, "销售单不存在");
  900. if ($saleinfo['order_source'] != 9) return error_show(1004, "销售单来源不是网络录入");
  901. $cgd = Db::name("purchease_order")->alias("a")
  902. ->leftJoin("order_num b", "a.cgdNo=b.cgdNo")
  903. ->where(["b.orderCode" => $param['orderCode']])
  904. ->field("a.*")
  905. ->findOrEmpty();
  906. if (empty($cgd)) return error_show(1004, "采购单不存在");
  907. $userCommon = new \app\admin\common\User();
  908. $tmp = $userCommon->handle('getCodeAndName',['code'=>[$param['supplierNo'],$cgd['companyNo']]]);
  909. if(!isset($tmp['code']) || $tmp['code']!=0) return json_show($tmp['code'],$tmp['message'],$tmp['data']);
  910. // if(!isset($tmp['data'][$param['khNo']])) return json_show(1004, "未找到客户数据");
  911. if(!isset($tmp['data'][$param['supplierNo']])) return json_show(1004, "未找到平台供应商数据");
  912. // if(!isset($tmp['data'][$param['companyNo']])) return json_show(1004, "未找到平台业务公司数据");
  913. if ($tmp['data'][$param['supplierNo']] == $tmp['data'][$param['companyNo']]) return json_show(1004, '供应商和业务公司不能为同一家公司');
  914. $good = Db::name("good_zixun")->where(["spuCode" => $saleinfo['good_code']])->findOrEmpty();
  915. if (empty($good)) return error_show(1004, "商品信息不存在");
  916. $addr = Db::name("order_addr")->where(["orderCode" => $param['orderCode']])->findOrEmpty();
  917. if (empty($addr)) return error_show(1004, "地址信息不存在");
  918. $cgdPrice = round($saleinfo['sale_price'] * (1 - $param['cgd_tax']), 2);
  919. // if ($saleinfo['platform_id'] != 0) {
  920. // $supplierArr = Db::name("platform_pay_rate")->where(["platform_id" => $param['platform_id'], "status" => 1, "is_del" => 0])->column("companyNo");
  921. // if (in_array($param['companyNo'], $supplierArr)) return error_show(1004, "平台支付渠道含有该业务公司,平台无法使用!");
  922. // }
  923. $qrddata = [
  924. "origin_price" => $cgdPrice,
  925. "arrive_time" => $param['sendtime'],
  926. // "customer_code"=>$param['khNo'],
  927. // "supplierNo"=>$param['companyNo'],
  928. "platform_order" => $param['poCode'],
  929. "workNo" => $param['workCode'],
  930. "updatetime" => date("Y-m-d H:i:s"),
  931. "cgderid" => $param['buyerid'],
  932. "cgder" => $param['buyer_name']
  933. ];
  934. $cgddata = [
  935. "cgder_id" => $param['buyerid'],
  936. 'cgder' => $param['buyerid'],
  937. "good_price" => $cgdPrice,
  938. "total_fee" => round($cgdPrice * $saleinfo['good_num'], 2),
  939. "supplierNo" => $param['supplierNo'],
  940. "supplier_name" => $tmp['data'][$param['supplierNo']],
  941. // "companyNo"=>$param['companyNo'],
  942. "updatetime" => date("Y-m-d H:i:s"),
  943. ];
  944. $goodinfo = [
  945. "good_unit" => $param['goodUnit'],
  946. "tax" => $param['tax'],
  947. "supplierNo" => $param['supplierNo'],
  948. // "companyNo" => $param['companyNo'],
  949. "updatetime" => date("Y-m-d H:i:s"),
  950. ];
  951. $orderAddr = [
  952. "addr" => $param['addr'],
  953. "addr_code" => $param['addr_code'],
  954. "contactor" => $param['contactor'],
  955. "mobile" => $param['mobile'],
  956. "arrive_time" => $param['sendtime'],
  957. // "customer_code" => $param['khNo'],
  958. "updatetime" => date("Y-m-d H:i:s"),
  959. ];
  960. Db::startTrans();
  961. try {
  962. $qrd = Db::name("sale")->where($saleinfo)->update($qrddata);
  963. if ($qrd == false) throw new Exception("销售单更新失败");
  964. $qrd = Db::name("purchease_order")->where($cgd)->update($cgddata);
  965. if ($qrd == false) throw new Exception("采购单更新失败");
  966. $qrd = Db::name("good_zixun")->where($good)->update($goodinfo);
  967. if ($qrd == false) throw new Exception("商品信息更新失败");
  968. $qrd = Db::name("order_addr")->where($addr)->update($orderAddr);
  969. if ($qrd == false) throw new Exception("销售单地址更新失败");
  970. Db::commit();
  971. return app_show(0, '订单更新成功');
  972. } catch (\Exception $exception) {
  973. Db::rollback();
  974. return error_show(1004, $exception->getMessage());
  975. }
  976. }
  977. }