ExecByRelaComNoHandle.php 65 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278
  1. <?php declare (strict_types=1);
  2. namespace app\command;
  3. use app\admin\common\User;
  4. use think\console\Command;
  5. use think\console\Input;
  6. use think\console\input\Argument;
  7. use think\console\Output;
  8. use think\db\exception\PDOException;
  9. use think\Exception;
  10. use think\facade\Cache;
  11. use think\facade\Db;
  12. //处理报表预约记录,生成报表文件(业务公司)
  13. class ExecByRelaComNoHandle extends Command
  14. {
  15. //redis队列的key,在ExecByRelaComNo控制器中也有定义,要同步修改(轻易不要修改)
  16. private $key = 'cxreport_relaComNo';
  17. protected function configure()
  18. {
  19. // 指令配置
  20. $this->setName('cxreport_relaComNo')
  21. ->setDescription('定时处理报表预约,生成报表文件');
  22. }
  23. //处理报表预约记录,生成报表文件
  24. protected function execute(Input $input, Output $output)
  25. {
  26. ini_set("memory_limit", "516M");
  27. $info = Cache::store('redis')->handler()->rpop($this->key);
  28. try {
  29. if ($info) {
  30. $info = json_decode($info, true);
  31. //不同的方法处理不同的脚本
  32. switch ($info['code']) {
  33. //【财务报表】退货台账-业务口径
  34. case 'A':
  35. $res = $this->A($info['start'], $info['end'], $info['relaComNo'], $info['relaComName']);
  36. break;
  37. //【财务报表】库存日报及预警汇总表
  38. case 'B':
  39. $res = $this->B($info['start'], $info['end'], $info['relaComNo'], $info['relaComName']);
  40. break;
  41. //【财务报表】退货台账
  42. case 'C':
  43. $res = $this->C($info['start'], $info['end'], $info['relaComNo'], $info['relaComName']);
  44. break;
  45. //【财务报表】出入库明细
  46. case 'D':
  47. $res = $this->D($info['start'], $info['end'], $info['relaComNo'], $info['relaComName']);
  48. break;
  49. //【财务报表】库存品入库明细
  50. case 'E':
  51. $res = $this->E($info['start'], $info['end'], $info['relaComNo'], $info['relaComName']);
  52. break;
  53. //【财务报表】库存品出库明细
  54. case 'F':
  55. $res = $this->F($info['start'], $info['end'], $info['relaComNo'], $info['relaComName']);
  56. break;
  57. //【销售】订单表导出
  58. case 'G':
  59. $res = $this->G($info['start'], $info['end'], $info['relaComNo'], $info['relaComName']);
  60. break;
  61. //【库存报表】-库存日报及预警汇总表
  62. case 'H':
  63. $res = $this->H($info['start'], $info['end'], $info['relaComNo'], $info['relaComName']);
  64. break;
  65. //【库存报表】-出入库明细
  66. case 'I':
  67. $res = $this->I($info['start'], $info['end'], $info['relaComNo'], $info['relaComName']);
  68. break;
  69. //【库存报表】-库存品入库明细
  70. case 'J':
  71. $res = $this->J($info['start'], $info['end'], $info['relaComNo'], $info['relaComName']);
  72. break;
  73. //【库存报表】-库存品出库明细
  74. case 'K':
  75. $res = $this->K($info['start'], $info['end'], $info['relaComNo'], $info['relaComName']);
  76. break;
  77. //【库存报表】-库存品出库明细
  78. case 'L':
  79. $res = $this->NewOut($info['start'], $info['end'], $info['relaComNo'], $info['relaComName']);
  80. break;
  81. //每日库存数据更新
  82. case 'M':
  83. $res = $this->EveryDayStock($info['start'], $info['end'], $info['relaComNo'], $info['relaComName']);
  84. break;
  85. //商品成本信息
  86. case 'N':
  87. $res = $this->GetGoodNake($info['relaComNo'], $info['relaComName']);
  88. break;
  89. //商品售价信息
  90. case 'P':
  91. $res = $this->GetGoodLadder($info['relaComNo'], $info['relaComName']);
  92. break;
  93. case 'Q':
  94. $res = $this->GetBid($info['start'], $info['end'], $info['relaComNo'], $info['relaComName']);
  95. break;
  96. default:
  97. throw new Exception('暂不支持这个报表');
  98. }
  99. $file = excelSaveFile($res, $info['name'] . '_' . $info['relaComName'] . '_' . date('YmdHis'));
  100. Db::name('exec_rela_com_no')
  101. ->where(['id' => $info['id'], 'status' => 1])//status==1 待处理
  102. ->update([
  103. 'status' => 2, //status==2 处理完成
  104. 'down_url' => $file,
  105. 'updatetime' => date('Y-m-d H:i:s'),
  106. 'expiretime' => date('Y-m-d H:i:s', strtotime('+7 day')),
  107. 'remark' => ''
  108. ]);
  109. //$output->writeln('【' . $info['id'] . '】该预约记录处理成功');
  110. } //else $output->writeln('没有可供处理的报表预约记录');
  111. } catch (Exception $exception) {
  112. Db::name('exec_rela_com_no')
  113. ->where(['id' => $info['id'], 'status' => 1])//status==1 待处理
  114. ->update([
  115. 'status' => 0, //status==2 处理完成
  116. 'down_url' => '',
  117. 'updatetime' => date('Y-m-d H:i:s'),
  118. 'expiretime' => date('Y-m-d H:i:s', strtotime('+7 day')),
  119. 'remark' => $exception->getMessage()
  120. ]);
  121. //$output->writeln($exception->getMessage() . '|' . $exception->getFile() . '|' . $exception->getLine());
  122. }
  123. }
  124. //【财务报表】退货台账-业务口径
  125. private function A(string $start_date = '', string $end_date = '', string $relaComNo = '', string $relaComName = '')
  126. {
  127. $data = Db::name('order_back')
  128. ->alias('ob')
  129. ->field('ob.thNo 退货单号,ob.status 流程进度,ob.addtime 退货发起日期,"" 退货人所在部门,ob.apply_name 退货人,ob.return_num 退货数量,ob.total_fee 退货销售货款,ob.remark 退货备注,ob.customer_name 客户名称,ob.customer_code 客户编码,"" 一级组织,"" 二级组织,"" 三级组织,p.platform_name 平台名称,s.poNo PO编号,s.orderCode 确认单编号,s.order_type 确认单类型,s.addtime 确认单下单时间,"" 业务人员所在部门,ob.cgder 业务人员,s.good_code 确认单产品编号,ob.good_name 产品名称,s.skuCode 产品编码,"" 一级分类,0 售前记录总数,ob.apply_id,ob.cgderid,s.cat_id')
  130. ->leftJoin('sale s', 's.orderCode=ob.orderCode')
  131. ->leftJoin('platform p', 'p.id=ob.platform_id')
  132. ->where(['ob.is_del' => 0, 'ob.status' => 4, 's.supplierNo' => $relaComNo])
  133. ->whereBetween('ob.addtime', [$start_date, $end_date])
  134. ->cursor();
  135. $all_status = [1 => '待业务审批', 2 => '待专员审批', 3 => '待主管审批', 4 => '退货完成', 5 => '业务驳回', 6 => '采购驳回', 7 => '专员审批不通过'];
  136. $all_order_type = [1 => '备库', 2 => '非库存', 3 => '咨询采反', 4 => '项目采反', 5 => '平台部订单库存品', 6 => '平台部订单非库存品'];
  137. $list = [];
  138. $tmp_customer = $tmp = [];
  139. $userCommon = User::getIns();
  140. foreach ($data as $value) {
  141. $value['流程进度'] = isset($all_status[$value['流程进度']]) ? $all_status[$value['流程进度']] : '';
  142. if (!isset($tmp_customer[$value['客户编码']])) {
  143. $temp = $userCommon->handle('cInfo', ['companyNo' => $value['客户编码']]);
  144. $tmp_customer[$value['客户编码']] = $temp['data']['itemid'] ?? '';
  145. }
  146. $value['itemid'] = $tmp_customer[$value['客户编码']];
  147. if (!empty($value['itemid'])) {
  148. $customer_org1 = get_top_customer_org($value['itemid']);
  149. foreach ($customer_org1 as $vv) {
  150. switch ($vv['level']) {
  151. case 1:
  152. $value['一级组织'] = $vv['name'];
  153. break;
  154. case 2:
  155. $value['二级组织'] = $vv['name'];
  156. break;
  157. case 3:
  158. $value['三级组织'] = $vv['name'];
  159. break;
  160. }
  161. }
  162. }
  163. if (!isset($tmp[$value['apply_id']])) $tmp[$value['apply_id']] = get_company_name_by_uid($value['apply_id']);
  164. if (!isset($tmp[$value['cgderid']])) $tmp[$value['cgderid']] = get_company_name_by_uid($value['cgderid']);
  165. $value['退货人所在部门'] = $tmp[$value['apply_id']] ?? '';
  166. $value['业务人员所在部门'] = $tmp[$value['cgderid']] ?? '';
  167. $value['确认单类型'] = isset($all_order_type[$value['确认单类型']]) ? $all_order_type[$value['确认单类型']] : '';
  168. $top = made($value['cat_id']);
  169. $value['一级分类'] = isset($top[0]['name']) ? $top[0]['name'] : '';
  170. $value['售前记录总数'] = Db::name('sale_return')->where(['orderCode' => $value['确认单编号'], 'is_del' => 0, 'status' => 5])->count('id');
  171. $value['业务公司编码'] = $relaComNo;
  172. $value['业务公司名称'] = $relaComName;
  173. unset($value['cat_id']);
  174. unset($value['itemid']);
  175. unset($value['apply_id']);
  176. unset($value['cgderid']);
  177. yield $list[] = $value;
  178. }
  179. return $list;
  180. }
  181. //【财务报表】库存日报及预警汇总表
  182. private function B(string $start_date = '', string $end_date = '', string $relaComNo = '', string $relaComName = '')
  183. {
  184. $data = Db::name('good_stock')
  185. ->alias('wgs')
  186. ->field(" wwi.companyName as '公司名称',
  187. wpo.bkcode as '备库单号',
  188. wpo.cgdNo as '采购单号',
  189. wp.apply_id as '申请部门',
  190. wp.apply_name as '申请人',
  191. cat_id '一级分类',
  192. wgb.good_name '产品名称',
  193. wp.good_num '备库数量',
  194. wgs.spuCode '产品编号',
  195. wpo.good_price as '成本单价',
  196. wait_in_stock '待入库存数量',
  197. wait_out_stock '待出库存数量',
  198. usable_stock '可用库存数量',
  199. wait_out_stock+usable_stock '当前库存数量',
  200. '' as '可用库存金额',
  201. '' as '当前库存金额',
  202. '' as '保质期时间',
  203. '' as '库存天数',
  204. wgb.creater as 'CGD.采购员',
  205. wgb.supplierName as '供应商名称',
  206. wwi.`name` as '仓库名称',
  207. wp.addtime as '备库创建时间'
  208. ")
  209. ->leftJoin('purchease_order wpo', 'wgs.spuCode = wpo.spuCode and order_source=0')
  210. ->leftJoin('purchease wp', 'wp.bk_code = wpo.bkcode')
  211. ->leftJoin('warehouse_info wwi', 'wwi.wsm_code = wgs.wsm_code')
  212. ->leftJoin('good_basic wgb', 'wgb.spuCode = wgs.spuCode')
  213. ->where('wgs.is_del', 0)
  214. ->where('wgb.is_stock', 1)
  215. ->where('wpo.companyNo', $relaComNo)
  216. ->whereBetween('wgs.updatetime', [$start_date, $end_date])
  217. ->order('wgs.updatetime', 'desc')
  218. ->cursor();
  219. $list = [];
  220. foreach ($data as $value) {
  221. $cat = made($value['一级分类']);
  222. $value['申请部门'] = get_company_name_by_uid(intval($value['申请部门']));
  223. $value['一级分类'] = isset($cat[0]['name']) ? $cat[0]['name'] : "";
  224. $value['可用库存金额'] = bcmul((string)$value['可用库存数量'] ?? '0', (string)$value['成本单价'] ?? '0', 2);
  225. $value['当前库存金额'] = bcmul((string)$value['当前库存数量'] ?? '0', (string)$value['成本单价'] ?? '0', 2);
  226. // $value['最近入库时间'] =Db::name("purchease_order")->alias("a")->leftJoin("purchease_in c","a.cgdNo=c.cgdNo")->where(["spuCode"=>$value['产品编号'],"order_type"=>1,"order_source"=>0,"c.status"=>[4,6]])->order("a.addtime desc")->value("c.addtime","");
  227. if (!empty($value['备库创建时间'])) {
  228. $value['保质期时间'] = date('Y-m-d H:i:s', strtotime($value['备库创建时间']) + 31536000);//365天之后
  229. $value['库存天数'] = bcdiv((string)(time() - strtotime($value['备库创建时间'])), (string)(24 * 3600));//365天之后
  230. }
  231. $value['业务公司编码'] = $relaComNo;
  232. $value['业务公司名称'] = $relaComName;
  233. yield $list[] = $value;
  234. }
  235. return $list;
  236. }
  237. //【财务报表】退货台账
  238. private function C(string $start_date = '', string $end_date = '', string $relaComNo = '', string $relaComName = '')
  239. {
  240. $data = Db::name('th_data')
  241. ->alias('wtd')
  242. ->leftJoin('sale_return wsr', 'wtd.thCode = wsr.returnCode and wtd.th_type=1')
  243. ->leftJoin('order_return wor', 'wtd.thCode = wor.returnCode and wtd.th_type in (2,3)')
  244. ->leftJoin('sale ws', 'ws.orderCode=wtd.orderCode and ws.is_del=0')
  245. ->leftJoin('order_num won', 'won.orderCode=wtd.orderCode')
  246. ->leftJoin('purchease_order wpo', 'wpo.cgdNo=won.cgdNo and wpo.is_del=0')
  247. ->whereBetween('wtd.addtime', [$start_date, $end_date])
  248. ->where('ws.supplierNo', $relaComNo)
  249. ->field(" year(wtd.addtime) '年',
  250. month(wtd.addtime) '月',
  251. DAYOFMONTH(wtd.addtime) '日',
  252. wtd.addtime '退货单创建时间',
  253. wsr.companyName as '公司名称',
  254. thCode '退货单号',
  255. if(wtd.th_type=1,'售前','售后') '退货类型',
  256. '已完成' as '流程进度',
  257. wtd.apply_id '业务部门',
  258. wtd.apply_name '业务人员',
  259. wtd.orderCode '订单编号',
  260. ws.platform_id '平台类型',
  261. ws.platform_order '平台订单号',
  262. '' as '客户属性',
  263. wtd.spuCode '产品编码',
  264. '' as '财务核算码',
  265. '' as `一级分类`,
  266. '' as `二级分类`,
  267. wtd.cat_id as `三级分类`,
  268. wtd.good_name as '商品名称',
  269. ws.order_type as `单位`,
  270. wtd.th_num '退货数量',
  271. ws.sale_price '销售单价',
  272. wtd.th_fee '退货金额',
  273. ifnull(wsr.remark,wor.error_remark) as '退货备注',
  274. won.cgdNo '采购单单号',
  275. wpo.cgder '采购员',
  276. wpo.nake_fee '采购裸价',
  277. wpo.pakge_fee '包装费',
  278. wpo.delivery_fee '物流费',
  279. wpo.cert_fee '证书费',
  280. wpo.mark_fee '加标费',
  281. wpo.open_fee '开模费',
  282. wpo.diff_weight '工差',
  283. wpo.diff_fee '采购工差金额',
  284. wpo.good_price '成本合计',
  285. (wpo.good_price * wtd.th_num) '退货采购货款',
  286. '' as '税点',
  287. wpo.supplier_name '供应商名称',
  288. if(ws.is_stock=1,'是','否') '是否库存',
  289. '' as '发货方式',
  290. if(ifnull(wsr.is_th,wor.is_th)=0,'否','是') as '供应商是否同意退货',
  291. '' as '付款方式',
  292. ws.customerName 客户名称,
  293. ws.customer_code
  294. ")->order("wtd.addtime")
  295. ->cursor();
  296. $userCommon = User::getIns();
  297. $temp_customer = [];
  298. $com = [];
  299. $cat = Db::name('cat')->where(['is_del' => 0, 'status' => 1, 'level' => 3])->column('cat_name', 'id');
  300. $unit = Db::name('unit')->where('is_del', 0)->column('unit', 'id');
  301. $platform = Db::name('platform')->where('is_del', 0)->column('platform_name', 'id');
  302. foreach ($data as $value) {
  303. if (!isset($temp_customer[$value['customer_code']])) {
  304. $tmp = $userCommon->handle('cInfo', ['companyNo' => $value['customer_code']]);
  305. $temp_customer[$value['customer_code']] = $tmp['data']['itemid'] ?? '';
  306. }
  307. $value['分公司'] = $temp_customer[$value['customer_code']] ?? '';
  308. $value['业务部门'] = get_company_name_by_uid(intval($value['业务部门']));
  309. $value['财务核算码'] = $cat[$value['三级分类']] ?? '';//Db::name("cat")->where(["id" => $value['三级分类']])->value("fund_code", '');
  310. $comp = get_top_customer_org($value['分公司']);
  311. $value['客户属性'] = isset($comp[0]['name']) ? $comp[0]['name'] : "";
  312. $value['分公司'] = isset($comp[1]['name']) ? $comp[1]['name'] : "";
  313. $top = made($value['三级分类']);
  314. $value['一级分类'] = isset($top[0]['name']) ? $top[0]['name'] : '';
  315. $value['二级分类'] = isset($top[1]['name']) ? $top[1]['name'] : '';
  316. $value['三级分类'] = isset($top[2]['name']) ? $top[2]['name'] : '';
  317. if ($value['单位'] == 3) {
  318. $good = Db::name("good_zixun")->field('supplierNo,supplierName,good_unit,tax')->where(["spuCode" => $value['产品编码']])->find();
  319. } else {
  320. $good = Db::name("good_basic")->field('supplierNo,supplierName,good_unit,tax')->where(["spuCode" => $value['产品编码']])->find();
  321. }
  322. if ($value['单位'] == 1 && $value['退货采购货款'] == 0) {
  323. $returninfo = Db::name("return_info")->where(["returnCode" => $value['退货单号']])->field("sum(origin_price * num) as cgd_total")->find();
  324. $value['退货采购货款'] = $returninfo['cgd_total'] ?? 0;
  325. }
  326. if ($value['采购员'] == '' || $value['供应商名称'] == '') {
  327. $supplier = $userCommon->handle('sInfo', ['code' => $good['supplierNo']]);
  328. $value['采购员'] = $supplier['data']['person'] ?? '';
  329. $value['供应商名称'] = $good['supplierName'];
  330. }
  331. $value['单位'] = isset($good['good_unit']) ? $unit[$good['good_unit']] ?? '' : '';
  332. $value['税点'] = isset($good['tax']) ? $good['tax'] . '%' : "";
  333. $value['平台类型'] = $platform[$value['平台类型']] ?? '';
  334. $value['业务公司编码'] = $relaComNo;
  335. $value['业务公司名称'] = $relaComName;
  336. unset($value['customer_code']);
  337. yield $com[] = $value;
  338. }
  339. return $com;
  340. }
  341. //【财务报表】出入库明细
  342. public function D($start, $end, string $relaComNo = '', string $relaComName = '')
  343. {
  344. $list = Db::name("order_out")
  345. ->alias('woo')
  346. ->leftJoin("sale a", "a.orderCode=woo.orderCode and a.is_del=0")
  347. ->leftJoin("order_back wor", "wor.outCode=woo.outCode and wor.status=4 and wor.is_del=0")
  348. ->leftJoin("order_num won", "won.orderCode=a.orderCode")
  349. ->leftJoin("purchease_order wpo", "wpo.cgdNo=won.cgdNo and wpo.is_del=0")
  350. ->leftJoin("good_basic wgb", "wgb.spuCode=wpo.spuCode and wgb.is_del=0")
  351. ->leftJoin("good_zixun wgz", "wgz.spuCode=wpo.spuCode and wgz.is_del=0")
  352. ->where('woo.status', ">=", 2)
  353. ->where('woo.is_del', "=", 0)
  354. ->where('wpo.order_type', "<>", 1)
  355. ->where('a.supplierNo', $relaComNo)
  356. ->whereBetween('woo.sendtime', [$start, $end])
  357. ->field(" year(`a`.`addtime`) AS `年`,
  358. month(`a`.`addtime`) AS `月`,
  359. dayofmonth(`a`.`addtime`) AS `日`,
  360. a.supplierName as '公司名称',
  361. a.apply_id '业务部门名称' ,
  362. a.apply_name as '业务人员',
  363. a.order_type as '订单类型',
  364. a.good_type as '商品类型',
  365. woo.outCode '发货编号',
  366. `woo`.`send_num` AS `本次发货数量`,
  367. `woo`.`sendtime` AS `本次发货时间`,
  368. `woo`.`orderCode` AS `确认单编号`,
  369. `a`.`good_code` AS `商品编号`,
  370. '' as '一级分类',
  371. '' as '二级分类',
  372. a.cat_id as '三级分类',
  373. '' as '财务核算编码',
  374. a.good_name as '商品名称',
  375. ifnull( `wgb`.`good_unit`, `wgz`.`good_unit` ) as '单位',
  376. `a`.`good_num` AS `下单数量`,
  377. `a`.`total_price` AS `销售货款`,
  378. `wpo`.`cgdNo` AS `采购单单号`,
  379. `wpo`.`cgder` AS `采购员`,
  380. `wpo`.`nake_fee` AS `采购裸价`,
  381. `wpo`.`mark_fee` AS `加标费`,
  382. `wpo`.`pakge_fee` AS `包装费`,
  383. `wpo`.`cert_fee` AS `证书费`,
  384. `wpo`.`open_fee` AS `开模费`,
  385. `wpo`.`teach_fee` AS `工艺费`,
  386. `wpo`.`delivery_fee` AS `物流费`,
  387. `wpo`.`good_price` AS `成本合计`,
  388. `wpo`.`total_fee` AS `采购货款`,
  389. ifnull( `wgb`.`tax`, `wgz`.`tax` )/100 AS `采购税点`,
  390. `wpo`.`supplier_name` AS `供应商名称`,
  391. `wgb`.`is_stock` as '是否库存品',
  392. if (`wgb`.`is_stock`=1,wpo.bkcode,wpo.cgdNo) as '发货方式',
  393. ifnull( `wor`.`thNo`, '' ) AS `退货编号`,
  394. ifnull( `wor`.`return_num`, '' ) AS `退货数量`,
  395. round(( ifnull( `wor`.`return_num`, 0 ) * `a`.`sale_price` ), 2 ) as '退货金额',
  396. '' as '售前退货数量',
  397. `a`.`sale_price` as '售前退货金额'
  398. ")->cursor();
  399. $order_tyepe = ["库存销售", '非库存销售', '咨询销售', '项目销售', '平台库存销售', '平台非库存销售'];
  400. $good_type = ["常规商品", '赠品', '样品'];
  401. $data = [];
  402. $fund_code = Db::name('cat')->where(['is_del' => 0, 'level' => 3])->column('fund_code', 'id');
  403. $unit = Db::name('unit')->where(['is_del' => 0])->column('unit', 'id');
  404. $sale_return_num = Db::name('sale_return')->where('is_del', 0)->group('orderCode')->column('sum(num) ', 'orderCode');
  405. $temp = [];
  406. foreach ($list as $value) {
  407. if (!isset($temp[$value['业务部门名称']])) $temp[$value['业务部门名称']] = get_company_name_by_uid($value['业务部门名称']);
  408. $value['业务部门名称'] = $temp[$value['业务部门名称']] ?? '';
  409. $value['订单类型'] = $order_tyepe[$value['订单类型'] - 1];
  410. $value['商品类型'] = $good_type[$value['商品类型'] - 1];
  411. $cat = made($value['三级分类']);
  412. $value['财务核算编码'] = $fund_code[$value['三级分类']] ?? '';
  413. $value['一级分类'] = isset($cat[0]['name']) ? $cat[0]['name'] : "";
  414. $value['二级分类'] = isset($cat[1]['name']) ? $cat[1]['name'] : "";
  415. $value['三级分类'] = isset($cat[2]['name']) ? $cat[2]['name'] : "";
  416. $value['单位'] = $unit[$value['单位']] ?? '';
  417. if ($value['是否库存品'] == 1) {
  418. $sendtype = Db::name("purchease_order")
  419. ->alias("a")
  420. ->leftJoin("purchease_in b", "a.cgdNo=b.cgdNo and b.is_del=0")
  421. ->where(["bkcode" => $value['发货方式'], "order_type" => 1, "order_source" => 0])
  422. ->order("b.addtime desc")
  423. ->value("b.sendtype", '');
  424. $value['是否库存品'] = '是';
  425. } else {
  426. $sendtype = Db::name("purchease_order")
  427. ->alias("a")
  428. ->leftJoin("purchease_in b", "a.cgdNo=b.cgdNo and b.is_del=0")
  429. ->where(["a.cgdNo" => $value['发货方式']])
  430. ->order("b.addtime desc")
  431. ->value("b.sendtype", '');
  432. $value['是否库存品'] = '否';
  433. }
  434. $value['发货方式'] = $sendtype == 1 ? '包邮' : $sendtype == 2 ? '自提' : "";
  435. $value['售前退货数量'] = $sale_return_num[$value['确认单编号']] ?? 0;
  436. $value['售前退货金额'] = round($value['售前退货数量'] * $value['售前退货金额'], 2);
  437. $value['业务公司编码'] = $relaComNo;
  438. $value['业务公司名称'] = $relaComName;
  439. yield $data[] = $value;
  440. }
  441. $cgd = $this->GetWlb($start, $end);
  442. foreach ($cgd as $key => $value) {
  443. yield $data[] = $value;
  444. }
  445. return $data;
  446. }
  447. //【财务报表】库存品入库明细
  448. public function E($start, $end, string $relaComNo = '', string $relaComName = '')
  449. {
  450. $list = Db::name("purchease_in")
  451. ->alias('wpi')
  452. ->leftJoin("purchease_order wpo", "wpo.cgdNo=wpi.cgdNo")
  453. ->leftJoin("purchease wp", "wpo.bkcode=wp.bk_code and wp.is_del=0")
  454. ->leftJoin("good_basic wgb", "wgb.spuCode=wpo.spuCode and wgb.is_del=0")
  455. ->leftJoin("warehouse_info wwi", "wwi.wsm_code = wpo.wsm_code")
  456. ->where([
  457. 'wpi.status' => [4, 6],
  458. 'wpi.is_del' => 0,
  459. 'wpo.order_type' => 1,
  460. 'wpo.order_source' => 0,
  461. 'wpo.companyNo' => $relaComNo,
  462. ])
  463. ->whereBetween('wpi.addtime', [$start, $end])
  464. ->field("wpo.companyName '业务公司',
  465. bkcode '备库单号',
  466. wpi.wsm_in_code '入库单号',
  467. wpi.bnCode 'BN批次单号',
  468. wpi.cgdNo '采购单号',
  469. wpo.spuCode '商品编号',
  470. '' as '一级分类',
  471. '' as '二级分类',
  472. wgb.cat_id as '三级分类',
  473. wgb.cat_id as '财务核算编号',
  474. wpo.good_name as '商品名称',
  475. if(wpi.status=4,wpi.send_num,wpi.wsm_num) '入库数量',
  476. round( if(wpi.status=4,wpi.send_num,wpi.wsm_num) * good_price, 2 ) '入库金额',
  477. wpi.updatetime '本次入库时间',
  478. wgb.tax/100 '采购税率',
  479. '' as '不含税入库金额',
  480. '' as '税额',
  481. wp.apply_id as '业务部门',
  482. wp.apply_name as '业务员',
  483. wpo.cgder as '采购员',
  484. wpo.good_price '成本裸价',
  485. wsm_type '仓库类型',
  486. wpo.supplier_name '供应商名称',
  487. wwi.name '仓库名称',
  488. wp.addtime '备库创建时间'
  489. ")
  490. ->cursor();
  491. $data = $tmp = [];
  492. $all_warehouse_type = Db::name('warehouse_type')->column('name', 'id');
  493. $all_fund_code = Db::name('cat')->where(['is_del' => 0, 'level' => 3])->column('fund_code', 'id');
  494. foreach ($list as $value) {
  495. if (!isset($tmp[$value['业务部门']])) $tmp[$value['业务部门']] = get_company_name_by_uid($value['业务部门']);
  496. $value['业务部门'] = $tmp[$value['业务部门']] ?? '';
  497. $cat = made($value['三级分类']);
  498. $value['财务核算编号'] = $all_fund_code[$value['三级分类']] ?? '';
  499. $value['一级分类'] = isset($cat[0]['name']) ? $cat[0]['name'] : "";
  500. $value['二级分类'] = isset($cat[1]['name']) ? $cat[1]['name'] : "";
  501. $value['三级分类'] = isset($cat[2]['name']) ? $cat[2]['name'] : "";
  502. $value['不含税入库金额'] = round($value['入库金额'] / (1 + $value['采购税率']), 2);
  503. $value['税额'] = round(($value['入库金额'] / (1 + $value['采购税率'])) * $value['采购税率'], 2);
  504. $value['仓库类型'] = $all_warehouse_type[$value['仓库类型']] ?? '';
  505. $value['业务公司编码'] = $relaComNo;
  506. $value['业务公司名称'] = $relaComName;
  507. yield $data[] = $value;
  508. }
  509. return $data;
  510. }
  511. //【财务报表】库存品出库明细
  512. public function F($start, $end, string $relaComNo = '', string $relaComName = '')
  513. {
  514. $list = Db::name("order_out")
  515. ->alias('woo')
  516. ->leftJoin("sale a", "a.orderCode=woo.orderCode and a.is_del=0")
  517. ->leftJoin("order_num won", "won.orderCode=a.orderCode")
  518. ->leftJoin("order_back wor", "wor.outCode=woo.outCode and wor.status=4 and wor.is_del=0")
  519. ->leftJoin("purchease_order wpo", "wpo.cgdNo=won.cgdNo")
  520. ->leftJoin("good_basic wgb", "wgb.spuCode=wpo.spuCode and wgb.is_del=0")
  521. ->leftJoin("warehouse_info wwi", "wwi.wsm_code = wpo.wsm_code")
  522. ->where([['woo.status', ">=", 2], ['woo.is_del', "=", 0], ['a.order_type', "=", 1], ['woo.sendtime', "between", [$start, $end]], ['a.supplierNo', '=', $relaComNo]])
  523. ->field("wpo.companyName '业务公司',
  524. bkcode '备库单号',
  525. woo.orderCode '销售单号',
  526. woo.outCode '出库单号',
  527. wpo.cgdNo '采购单号',
  528. wpo.spuCode '商品编号',
  529. '' as '一级分类',
  530. '' as '二级分类',
  531. wgb.cat_id as '三级分类',
  532. wgb.cat_id as '财务核算编号',
  533. wpo.good_name as '商品名称',
  534. woo.send_num'出库数量',
  535. round( woo.send_num* wpo.good_price,2) '出库金额',
  536. woo.sendtime '本次出库时间',
  537. wgb.tax/100 '税率',
  538. '' as '不含税出库金额',
  539. ''as '税额',
  540. a.apply_id as '业务部门',
  541. a.apply_name as '业务员',
  542. wpo.cgder as '采购员',
  543. wpo.good_price '成本裸价',
  544. wor.return_num '出库退货数量',
  545. wwi.wsm_type '仓库类型',
  546. wpo.supplier_name '供应商名称',
  547. wwi.name '仓库名称'
  548. ")
  549. ->cursor();
  550. $data = $tmp = [];
  551. $all_warehouse_type = Db::name('warehouse_type')->column('name', 'id');
  552. $all_fund_code = Db::name('cat')->where(['is_del' => 0, 'level' => 3])->column('fund_code', 'id');
  553. foreach ($list as $value) {
  554. if (!isset($tmp[$value['业务部门']])) $tmp[$value['业务部门']] = get_company_name_by_uid($value['业务部门']);
  555. $value['业务部门'] = $tmp[$value['业务部门']];
  556. $cat = made($value['三级分类']);
  557. $value['财务核算编号'] = $all_fund_code[$value['三级分类']] ?? '';
  558. $value['一级分类'] = isset($cat[0]['name']) ? $cat[0]['name'] : "";
  559. $value['二级分类'] = isset($cat[1]['name']) ? $cat[1]['name'] : "";
  560. $value['三级分类'] = isset($cat[2]['name']) ? $cat[2]['name'] : "";
  561. $value['不含税出库金额'] = round($value['出库金额'] / (1 + $value['税率']), 2);
  562. $value['税额'] = round(($value['出库金额'] / (1 + $value['税率'])) * $value['税率'], 2);
  563. $value['仓库类型'] = $all_warehouse_type[$value['仓库类型']] ?? '';
  564. $value['业务公司编码'] = $relaComNo;
  565. $value['业务公司名称'] = $relaComName;
  566. yield $data[] = $value;
  567. }
  568. return $data;
  569. }
  570. //网络部出入库
  571. public function GetWlb($start, $end)
  572. {
  573. $db = Db::connect("mysql3");
  574. $list = $db->name("cgd_info")
  575. ->where(['cgdSource' => 10, "is_del" => 0])->whereBetweenTime('createdTime', $start, $end)->field(
  576. "year(createdTime) AS `年`,
  577. month(createdTime) AS `月`,
  578. dayofmonth(createdTime) AS `日`,
  579. companyName '公司名称',
  580. department '业务部门',
  581. ownerName '业务人员',
  582. '网络部采购单' '订单类型',
  583. '' as '商品类型',
  584. '' as '发货编号',
  585. sendNum '本次发货数量',
  586. createdTime '本次发货时间',
  587. qrdCode '确认单编号',
  588. goodNo '商品编号',
  589. firstCat '一级分类',
  590. secCat as '二级分类',
  591. thirdCat as '三级分类',
  592. fundCode as '财务核算编码',
  593. goodName as '商品名称',
  594. goodUnit as '单位',
  595. goodNum '下单数量',
  596. '' AS `销售货款`,
  597. sequenceNo as '采购单单号',
  598. ownerName '采购员',
  599. barePrice AS `采购裸价`,
  600. markPrice AS `加标费`,
  601. packPrice AS `包装费`,
  602. certPrice AS `证书费`,
  603. openPrice AS `开模费`,
  604. costPrice AS `工艺费`,
  605. deliveryPrice AS `物流费`,
  606. goodPrice AS `成本合计`,
  607. totalPrice AS `采购货款`,
  608. tax AS `采购税点`,
  609. supplierName AS `供应商名称`,
  610. '否'as '是否库存品',
  611. '包邮' as '发货方式',
  612. '' AS `退货编号`,
  613. thNum AS `退货数量`,
  614. th_fee as '退货金额',
  615. '' as '售前退货数量',
  616. '' as '售前退货金额'
  617. ")->cursor();
  618. $data = [];
  619. foreach ($list as $value) {
  620. $value['销售货款'] = $db->name("qrd_info")->where(['sequenceNo' => $value['确认单编号']])->value('totalPrice', '');
  621. yield $data[] = $value;
  622. }
  623. return $data;
  624. }
  625. //【销售】订单表导出
  626. public function G(string $start_date = '', string $end_date = '', string $relaComNo = '', string $relaComName = '')
  627. {
  628. $all_order_type = [1 => '备库', 2 => '非库存', 3 => '咨询采反', 4 => '项目采反', 5 => '平台部订单销售库存', 6 => '平台部订单销售非库存'];//订单类型
  629. $all_sale_status = [0 => '待发货', 1 => '待发货完成', 2 => '发货已完成', 3 => '订单已取消'];//订单状态(sale表里的status)
  630. $all_stock = [0 => '非库存品', 1 => '库存品'];//是否库存品
  631. $all_is_activity = [0 => '不参与活动', 1 => '参与活动'];
  632. $all_good_type = [1 => '正常商品', 2 => '赠品', 3 => '样品'];
  633. $data = Db::name('sale')
  634. ->alias('s')
  635. ->field('s.addtime 确认单下单时间,s.orderCode 订单编号,s.order_type 订单类型,s.status 订单状态,s.apply_name 创建人,"" 部门,"" 销售方公司,"" 一级组织,"" 二级组织,"" 购买方公司,p.platform_name 所属平台,s.platform_order 平台订单号,s.poNo 其他单号,s.paytime 承诺回款时间,ou.order_use 订单用途,"" 活动类型,s.good_name 产品名称,"" 一级分类,gb.tax 税率,s.sale_price 销售单价,s.good_num 下单数量,s.total_price 销售总额,po.cgder 采购人,gb.customized 工期时间,s.arrive_time 要求到货时间,s.remark 备注,s.is_stock 是否库存品,s.cat_id,s.is_activity,s.good_type,s.customer_code,s.customerName 购买方公司,s.supplierName 销售方公司,s.apply_id')
  636. ->leftJoin('platform p', 'p.id=s.platform_id')
  637. ->leftJoin('good_basic gb', 'gb.spuCode=s.good_code')
  638. ->leftJoin('order_use ou', 'ou.id=s.use_order')
  639. ->leftJoin('order_num on', 'on.orderCode=s.orderCode')
  640. ->leftJoin('purchease_order po', 'po.cgdNo=on.cgdNo')
  641. ->where(['s.is_del' => 0, 's.supplierNo' => $relaComNo])
  642. ->whereBetween('s.addtime', [$start_date, $end_date])
  643. ->order('s.addtime', 'desc')
  644. ->cursor();
  645. $list = $tmp_customer = $tmp = [];
  646. foreach ($data as $value) {
  647. if (!isset($tmp[$value['apply_id']])) $tmp[$value['apply_id']] = get_company_name_by_uid($value['apply_id']);
  648. $value['部门'] = $tmp[$value['apply_id']];
  649. if (!isset($tmp_customer[$value['customer_code']])) {
  650. $tmp = User::getIns()->handle('cInfo', ['companyNo' => $value['customer_code']]);
  651. $tmp_customer[$value['customer_code']] = $tmp['data']['itemid'];
  652. }
  653. $value['itemid'] = $tmp_customer[$value['customer_code']];
  654. $value['订单类型'] = isset($all_order_type[$value['订单类型']]) ? $all_order_type[$value['订单类型']] : '';
  655. $value['订单状态'] = isset($all_sale_status[$value['订单状态']]) ? $all_sale_status[$value['订单状态']] : '';
  656. if (!empty($value['itemid'])) {
  657. $customer_org1 = array_column(get_top_customer_org($value['itemid']) ?? [], 'name', 'level');
  658. $value['一级组织'] = isset($customer_org1[1]) ? $customer_org1[1] : '';
  659. $value['二级组织'] = isset($customer_org1[2]) ? $customer_org1[2] : '';
  660. }
  661. $cat = made($value['cat_id']);
  662. $value['一级分类'] = isset($cat[0]['name']) ? $cat[0]['name'] : '';
  663. $value['是否库存品'] = isset($all_stock[$value['是否库存品']]) ? $all_stock[$value['是否库存品']] : '';
  664. $is_activity = isset($all_is_activity[$value['is_activity']]) ? $all_is_activity[$value['is_activity']] : '';
  665. $good_type = isset($all_good_type[$value['good_type']]) ? $all_good_type[$value['good_type']] : '';
  666. $value['活动类型'] = $is_activity . '/' . $good_type;
  667. $value['业务公司编码'] = $relaComNo;
  668. $value['业务公司名称'] = $relaComName;
  669. unset($value['good_code']);
  670. unset($value['itemid']);
  671. unset($value['cat_id']);
  672. unset($value['is_activity']);
  673. unset($value['good_type']);
  674. unset($value['customer_code']);
  675. unset($value['supplierNo']);
  676. unset($value['apply_id']);
  677. yield $list[] = $value;
  678. }
  679. return $list;
  680. }
  681. //【库存报表】库存日报及预警汇总表
  682. private function H(string $start_date = '', string $end_date = '', string $relaComNo = '', string $relaComName = '')
  683. {
  684. $data = Db::name('good_stock')
  685. ->alias('wgs')
  686. ->field(" wwi.companyName '公司名称',wgs.spuCode '产品编号',cat_id '一级分类',good_name '产品名称',wait_in_stock '待入库存数量',wait_out_stock '待出库存数量',usable_stock '可用库存数量',wait_out_stock+usable_stock '当前库存','' as '保质期时间','' as '库存天数',wgb.creater as 'CGD.采购员','' as '备库单号',wgb.supplierName as '供应商名称',wwi.`name` as '仓库名称','' as '最近入库时间'")
  687. ->leftJoin('warehouse_info wwi', 'wwi.wsm_code = wgs.wsm_code')
  688. ->leftJoin('good_basic wgb', 'wgb.spuCode = wgs.spuCode')
  689. ->where(['wgs.is_del' => 0, 'wgb.is_stock' => 1, 'wgb.companyNo' => $relaComNo])
  690. ->whereBetween('wgs.addtime', [$start_date, $end_date])
  691. ->order('wgs.addtime', 'desc')
  692. ->cursor();
  693. $list = [];
  694. foreach ($data as $value) {
  695. $cat = made($value['一级分类']);
  696. $value['一级分类'] = isset($cat[0]['name']) ? $cat[0]['name'] : "";
  697. $value['最近入库时间'] = Db::name("purchease_order")->alias("a")->leftJoin("purchease_in c", "a.cgdNo=c.cgdNo")->where(["spuCode" => $value['产品编号'], "order_type" => 1, "order_source" => 0, "c.status" => [4, 6]])->order("a.addtime desc")->value("c.addtime", "");
  698. $value['备库单号'] = Db::name("purchease_order")->alias("a")->where(["spuCode" => $value['产品编号'], "order_type" => 1, "order_source" => 0])->order("a.addtime desc")->value("a.bkcode", "");
  699. if (!empty($value['最近入库时间'])) {
  700. $value['保质期时间'] = date('Y-m-d H:i:s', strtotime($value['最近入库时间']) + 31536000);//365天之后
  701. $value['库存天数'] = bcdiv((string)(time() - strtotime($value['最近入库时间'])), (string)(24 * 3600));//365天之后
  702. }
  703. $value['业务公司编码'] = $relaComNo;
  704. $value['业务公司名称'] = $relaComName;
  705. yield $list[] = $value;
  706. }
  707. return $list;
  708. }
  709. //【库存报表】出入库明细
  710. public function I(string $start = '', string $end = '', string $relaComNo = '', string $relaComName = '')
  711. {
  712. $list = Db::name("order_out")
  713. ->alias('woo')
  714. ->leftJoin("sale a", "a.orderCode=woo.orderCode")
  715. ->leftJoin("order_back wor", "wor.outCode=woo.outCode and wor.status=4")
  716. ->leftJoin("order_num won", "won.orderCode=a.orderCode")
  717. ->leftJoin("purchease_order wpo", "wpo.cgdNo=won.cgdNo")
  718. ->leftJoin("good_basic wgb", "wgb.spuCode=wpo.spuCode")
  719. ->leftJoin("good_zixun wgz", "wgz.spuCode=wpo.spuCode")
  720. ->where('woo.status', ">=", 2)
  721. ->where('a.supplierNo', $relaComNo)
  722. ->whereBetween('woo.sendtime', [$start, $end])
  723. ->field(" year(`a`.`addtime`) AS `年`,month(`a`.`addtime`) AS `月`,dayofmonth(`a`.`addtime`) AS `日`,a.supplierName as '公司名称', a.apply_id '业务部门名称' ,a.apply_name as '业务人员',a.order_type as '订单类型',a.good_type as '商品类型',woo.outCode '发货编号',`woo`.`send_num` AS `本次发货数量`,`woo`.`sendtime` AS `本次发货时间`,`woo`.`orderCode` AS `确认单编号`,`a`.`good_code` AS `商品编号`,'' as '一级分类','' as '二级分类',a.cat_id as '三级分类','' as '财务核算编码',a.good_name as '商品名称',ifnull( `wgb`.`good_unit`, `wgz`.`good_unit` ) as '单位',`a`.`good_num` AS `下单数量`,`wpo`.`cgdNo` AS `采购单单号`,`wpo`.`cgder` AS `采购员`,`wpo`.`supplier_name` AS `供应商名称`,`wgb`.`is_stock` as '是否库存品',if (`wgb`.`is_stock`=1,wpo.bkcode,wpo.cgdNo) as '发货方式',ifnull( `wor`.`thNo`, '' ) AS `退货编号`,ifnull( `wor`.`return_num`, '' ) AS `退货数量`,'' as '售前退货数量'")
  724. ->cursor();
  725. $order_tyepe = ["库存销售", '非库存销售', '咨询销售', '项目销售', '平台库存销售', '平台非库存销售'];
  726. $good_type = ["常规商品", '赠品', '样品'];
  727. $data = $tmp = [];
  728. $unit = Db::name("unit")->where('is_del', 0)->column('unit', 'id');
  729. $fund_code = Db::name("cat")->where(["is_del" => 0, 'level' => 3])->column('fund_code', 'id');
  730. foreach ($list as $value) {
  731. if (!isset($tmp[$value['业务部门名称']])) $tmp[$value['业务部门名称']] = get_company_name_by_uid($value['业务部门名称']);
  732. $value['业务部门名称'] = $tmp[$value['业务部门名称']] ?? '';
  733. $value['订单类型'] = $order_tyepe[$value['订单类型'] - 1];
  734. $value['商品类型'] = $good_type[$value['商品类型'] - 1];
  735. $cat = made($value['三级分类']);
  736. $value['财务核算编码'] = $fund_code[$value['三级分类']] ?? '';
  737. $value['一级分类'] = isset($cat[0]['name']) ? $cat[0]['name'] : "";
  738. $value['二级分类'] = isset($cat[1]['name']) ? $cat[1]['name'] : "";
  739. $value['三级分类'] = isset($cat[2]['name']) ? $cat[2]['name'] : "";
  740. $value['单位'] = $unit[$value['单位']] ?? '';
  741. if ($value['是否库存品'] == 1) {
  742. $sendtype = Db::name("purchease_order")
  743. ->alias("a")
  744. ->leftJoin("purchease_in b", "a.cgdNo=b.cgdNo")
  745. ->where(["bkcode" => $value['发货方式'], "order_type" => 1, "order_source" => 0])
  746. ->order("b.addtime desc")
  747. ->value("b.sendtype", '');
  748. $value['是否库存品'] = '是';
  749. } else {
  750. $sendtype = Db::name("purchease_order")
  751. ->alias("a")
  752. ->leftJoin("purchease_in b", "a.cgdNo=b.cgdNo")
  753. ->where(["a.cgdNo" => $value['发货方式']])
  754. ->order("b.addtime desc")
  755. ->value("b.sendtype", '');
  756. $value['是否库存品'] = '否';
  757. }
  758. $value['发货方式'] = $sendtype == 1 ? '包邮' : $sendtype == 2 ? '自提' : "";
  759. $value['售前退货数量'] = Db::name("sale_return")->where(["orderCode" => $value['确认单编号']])->sum('num');
  760. $value['业务公司编码'] = $relaComNo;
  761. $value['业务公司名称'] = $relaComName;
  762. yield $data[] = $value;
  763. }
  764. $cgd = $this->GetWlb($start, $end);
  765. foreach ($cgd as $key => $value) {
  766. yield $data[] = $value;
  767. }
  768. return $data;
  769. }
  770. //【库存报表】-库存品入库明细
  771. public function J(string $start = '', string $end = '', string $relaComNo = '', string $relaComName = '')
  772. {
  773. $list = Db::name("purchease_in")
  774. ->alias('wpi')
  775. ->leftJoin("purchease_order wpo", "wpo.cgdNo=wpi.cgdNo")
  776. ->leftJoin("purchease wp", "wpo.bkcode=wp.bk_code")
  777. ->leftJoin("good_basic wgb", "wgb.spuCode=wpo.spuCode")
  778. ->leftJoin("warehouse_info wwi", "wwi.wsm_code = wpo.wsm_code")
  779. ->where([
  780. 'wpi.status' => [4, 6],
  781. 'wpo.order_type' => 1,
  782. 'wpo.order_source' => 0,
  783. 'wpo.companyNo' => $relaComNo,
  784. ])
  785. ->whereBetween('wpi.addtime', [$start, $end])
  786. ->field("wpo.companyName '业务公司',bkcode '备库单号',wpi.wsm_in_code '入库单号',wpi.cgdNo '采购单号',wpo.spuCode '商品编号','' as '一级分类','' as '二级分类',wgb.cat_id as '三级分类',wgb.cat_id as '财务核算编号',wpo.good_name as '商品名称',if(wpi.status=4,wpi.send_num,wpi.wsm_num) '入库数量',wpo.updatetime '本次入库时间',wp.apply_id as '业务部门',wp.apply_name as '业务员',wpo.cgder as '采购员',wsm_type '仓库类型',wpo.supplier_name '供应商名称',wwi.name '仓库名称'")
  787. ->cursor();
  788. $data = $tmp = [];
  789. $all_warehouse_type = Db::name("warehouse_type")->column('name', 'id');
  790. $fund_code = Db::name("cat")->where(["is_del" => 0, 'level' => 3])->column('fund_code', 'id');
  791. foreach ($list as $value) {
  792. if (!isset($tmp[$value['业务部门']])) $tmp[$value['业务部门']] = get_company_name_by_uid($value['业务部门']);
  793. $value['业务部门'] = $tmp[$value['业务部门']] ?? '';
  794. $cat = made($value['三级分类']);
  795. $value['财务核算编号'] = $fund_code[$value['三级分类']] ?? '';
  796. $value['一级分类'] = isset($cat[0]['name']) ? $cat[0]['name'] : "";
  797. $value['二级分类'] = isset($cat[1]['name']) ? $cat[1]['name'] : "";
  798. $value['三级分类'] = isset($cat[2]['name']) ? $cat[2]['name'] : "";
  799. $value['仓库类型'] = $all_warehouse_type[$value['仓库类型']] ?? '';
  800. $value['业务公司编码'] = $relaComNo;
  801. $value['业务公司名称'] = $relaComName;
  802. yield $data[] = $value;
  803. }
  804. return $data;
  805. }
  806. //【库存报表】库存品出库明细
  807. public function K(string $start = '', string $end = '', string $relaComNo = '', string $relaComName = '')
  808. {
  809. $list = Db::name("order_out")
  810. ->alias('woo')
  811. ->leftJoin("sale a", "a.orderCode=woo.orderCode and a.is_del=0")
  812. ->leftJoin("order_num won", "won.orderCode=a.orderCode")
  813. ->leftJoin("order_back wor", "wor.outCode=woo.outCode and wor.status=4 and wor.is_del=0")
  814. ->leftJoin("purchease_order wpo", "wpo.cgdNo=won.cgdNo and wpo.is_del=0")
  815. ->leftJoin("good_basic wgb", "wgb.spuCode=wpo.spuCode and wgb.is_del=0")
  816. ->leftJoin("warehouse_info wwi", "wwi.wsm_code = wpo.wsm_code")
  817. ->where([['woo.status', ">=", 2], ['woo.is_del', "=", 0], ['a.order_type', "=", 1], ['woo.sendtime', 'between', [$start, $end]], ['a.supplierNo', '=', $relaComNo]])
  818. ->field("wpo.companyName '业务公司',bkcode '备库单号',woo.orderCode '销售单号',woo.outCode '出库单号',wpo.cgdNo '采购单号',wpo.spuCode '商品编号','' as '一级分类','' as '二级分类',wgb.cat_id as '三级分类',wpo.good_name as '商品名称',woo.send_num'出库数量',woo.sendtime '本次出库时间',a.apply_id as '业务部门',a.apply_name as '业务员',wpo.cgder as '采购员',wor.return_num '出库退货数量',wwi.wsm_type '仓库类型',wpo.supplier_name '供应商名称',wwi.name '仓库名称'")
  819. ->cursor();
  820. $data = $tmp = [];
  821. $all_warehouse_type = Db::name("warehouse_type")->column('name', 'id');
  822. foreach ($list as $value) {
  823. if (!isset($tmp[$value['业务部门']])) $tmp[$value['业务部门']] = get_company_name_by_uid($value['业务部门']);
  824. $value['业务部门'] = $tmp[$value['业务部门']] ?? '';
  825. $cat = made($value['三级分类']);
  826. $value['一级分类'] = isset($cat[0]['name']) ? $cat[0]['name'] : "";
  827. $value['二级分类'] = isset($cat[1]['name']) ? $cat[1]['name'] : "";
  828. $value['三级分类'] = isset($cat[2]['name']) ? $cat[2]['name'] : "";
  829. $value['仓库类型'] = $all_warehouse_type[$value['仓库类型']] ?? '';
  830. $value['业务公司编码'] = $relaComNo;
  831. $value['业务公司名称'] = $relaComName;
  832. yield $data[] = $value;
  833. }
  834. return $data;
  835. }
  836. /**
  837. * 新出库单明细
  838. * @param string $start
  839. * @param string $end
  840. * @return \Generator
  841. * @throws \think\db\exception\DataNotFoundException
  842. * @throws \think\db\exception\DbException
  843. * @throws \think\db\exception\ModelNotFoundException
  844. *
  845. */
  846. private function NewOut(string $start, string $end, string $relaComNo = '', string $relaComName = '')
  847. {
  848. $data = Db::name("order_out")
  849. ->alias("a")
  850. ->leftJoin("sale b", "a.orderCode=b.orderCode")
  851. ->field("b.supplierName '业务公司',a.orderCode AS '销售单号',outCode '出库单号',
  852. b.good_code '商品编号',b.cat_id ,'' as '一级分类','' as '二级分类','' as '三级分类','' as '财务核算编号',
  853. b.good_name '商品名称',a.send_num '出库数量','' as '出库金额',a.sendtime '本次出库时间',
  854. ''as '税率', b.apply_id as '业务部门',a.apply_name as '业务人员',cgder as '采购员','' as '成本裸价',
  855. '' as '供应商名称','' as '出库退货数量',b.order_type")
  856. ->where([["a.status", ">=", 2], ["a.is_del", "=", 0], ["b.order_type", "=", 1], ['a.sendtime', 'between', [$start, $end]], ['b.supplierNo', '=', $relaComNo]])
  857. ->cursor();
  858. $list = $tmp = [];
  859. $all_fund_code = Db::name("cat")->where(["is_del" => 0, 'level' => 3])->column('fund_code', 'id');
  860. foreach ($data as $value) {
  861. if (!isset($tmp[$value['业务部门']])) $tmp[$value['业务部门']] = get_company_name_by_uid($value['业务部门']);
  862. $value['业务部门'] = $tmp[$value['业务部门']] ?? '';
  863. $cat = made($value['cat_id']);
  864. $value['财务核算编号'] = $all_fund_code[$value['cat_id']] ?? '';
  865. unset($value['cat_id']);
  866. $value['一级分类'] = isset($cat[0]['name']) ? $cat[0]['name'] : "";
  867. $value['二级分类'] = isset($cat[1]['name']) ? $cat[1]['name'] : "";
  868. $value['三级分类'] = isset($cat[2]['name']) ? $cat[2]['name'] : "";
  869. if (in_array($value["order_type"], [3, 4])) {
  870. $good = Db::name("good_zixun")->field('tax,supplierNo,supplierName')->where(["spuCode" => $value['商品编号']])->findOrEmpty();
  871. } else {
  872. $good = Db::name("good")->field('tax,supplierNo,supplierName')->where(["spuCode" => $value['商品编号']])->findOrEmpty();
  873. }
  874. $saleinfo = Db::name("sale_info")->where(["orderCode" => $value['销售单号']])->field("num,origin_price,num*origin_price as total_price")->select()
  875. ->toArray();
  876. if (empty($saleinfo)) {
  877. $value['成本裸价'] = Db::name("order_out")->alias("a")
  878. ->leftJoin("order_send b", "a.outCode=b.outCode")
  879. ->leftJoin("purchease_order c", "b.cgdNo=c.cgdNo")
  880. ->where(["a.outCode" => $value['出库单号']])->value("c.good_price", '0');
  881. } else {
  882. $num = array_sum(array_column($saleinfo, "num"));
  883. if ($num == 0) {
  884. $value['成本裸价'] = 0;
  885. } else {
  886. $value['成本裸价'] = round(array_sum(array_column($saleinfo, "total_price")) / array_sum(array_column($saleinfo, "num")), 2);
  887. }
  888. }
  889. $value['出库金额'] = $value['出库数量'] * $value['成本裸价'];
  890. $value['税率'] = $good['tax'] . "%";
  891. $value['供应商名称'] = $good['supplierName'];
  892. $value["出库退货数量"] = Db::name("order_back")->where(["outCode" => $value['出库单号']])->sum("return_num");
  893. $value['业务公司编码'] = $relaComNo;
  894. $value['业务公司名称'] = $relaComName;
  895. unset($value['order_type']);
  896. yield $list[] = $value;
  897. }
  898. }
  899. /**每日库存记录
  900. * @param string $start
  901. * @param string $end
  902. * @return \Generator
  903. * @throws \think\db\exception\DataNotFoundException
  904. * @throws \think\db\exception\DbException
  905. * @throws \think\db\exception\ModelNotFoundException
  906. */
  907. private function EveryDayStock(string $start, string $end, string $relaComNo = '', string $relaComName = '')
  908. {
  909. $list = Db::name("good_stock_info")
  910. ->alias("a")
  911. ->leftJoin("good_stock b", "a.stockid=b.id")
  912. ->leftJoin("purchease_in c", "c.bnCode=a.bnCode")
  913. ->leftJoin("purchease_order d", "c.cgdNo=d.cgdNo")
  914. ->leftJoin("purchease e", "d.bkcode=e.bk_code")
  915. ->leftJoin("good f", "b.spuCode=f.spuCode")
  916. ->leftJoin("warehouse_info j", "b.wsm_code=j.wsm_code")
  917. ->field(" e.companyName '业务公司',
  918. e.apply_id '申请部门',
  919. e.apply_name '申请人',
  920. e.addtime '备库创建时间',
  921. e.bk_code '备库单号',
  922. a.bnCode 'BN编号' ,
  923. a.addtime '入库时间',
  924. c.cgdNo '采购单编号' ,
  925. f.spuCode '产品编号' ,
  926. f.good_name '产品名称' ,
  927. e.good_num '备库数量' ,
  928. f.cat_id '一级分类' ,
  929. f.cat_id,
  930. '' as '财务核算编码',
  931. f.tax as '税率',
  932. a.origin_price '成本单价',
  933. b.wait_in_stock '待入库数量',
  934. b.wait_out_stock '待出库数量',
  935. (b.wait_out_stock+b.usable_stock) '当前库存数量',
  936. b.usable_stock '可用库存数量',
  937. a.total_num 'BN总数',
  938. a.balance_num 'BN库存数',
  939. a.used_num 'BN已使用数量',
  940. DATEDIFF(NOW(),a.addtime) '库存天数',
  941. f.supplierNo '采购员',
  942. d.supplier_name '供应商名称',
  943. j.`name` '仓库名称'")
  944. ->where(["f.is_stock" => 1, 'd.companyNo' => $relaComNo])
  945. ->whereBetween("a.updatetime", [$start, $end])
  946. ->cursor();
  947. $all_fund_code = Db::name("cat")->where(["is_del" => 0, 'level' => 3])->column('fund_code', 'id');
  948. $tmp = [];
  949. foreach ($list as $value) {
  950. if (!isset($tmp[$value['申请部门']])) $tmp[$value['申请部门']] = get_company_name_by_uid($value['申请部门']);
  951. $value['申请部门'] = $tmp[$value['申请部门']] ?? '';
  952. $cat = made($value['cat_id']);
  953. $value['财务核算编号'] = $all_fund_code[$value['cat_id']] ?? '';
  954. unset($value['cat_id']);
  955. $value['一级分类'] = isset($cat[0]['name']) ? $cat[0]['name'] : "";
  956. $value['业务公司编码'] = $relaComNo;
  957. $value['业务公司名称'] = $relaComName;
  958. yield $value;
  959. }
  960. }
  961. /**获取商品成本列表
  962. * @return \Generator
  963. */
  964. private function GetGoodNake(string $relaComNo = '', string $relaComName = '')
  965. {
  966. $list = Db::name("good_platform")
  967. ->alias("a")
  968. ->leftJoin("good b", "a.spuCode=b.spuCode")
  969. ->leftJoin("good_nake c", "b.spuCode=c.spuCode and c.is_del=0")
  970. ->field("
  971. a.skuCode '上线商品编号',
  972. a.spuCode '成本商品编号',
  973. a.plat_code '平台商品编号',
  974. b.good_name '商品名称',
  975. b.brand_id '品牌',
  976. b.cat_id '分类',
  977. b.companyName '业务企业名称',
  978. a.creater '申请人',
  979. platform_code '上线平台',
  980. online_time '上线时间',
  981. exam_status '上线状态',
  982. if(b.is_stock=1,'库存','非库存') '是否库存',
  983. if(b.good_type=1,'定制','非定制')'是否定制',
  984. '' as '规格',
  985. '' as '型号',
  986. b.good_unit '单位',
  987. b.good_remark '商品备注',
  988. b.craft_desc '工艺说明',
  989. b.noble_metal '贵金属信息',
  990. b.cgd_gold_price '供应商采购金价',
  991. b.demo_fee '打样费',
  992. b.open_fee '开模费',
  993. b.sample_fee '调样费',
  994. c.min_num '起订量',
  995. c.nake_fee '成本单价',
  996. c.cost_fee '工艺费',
  997. c.delivery_fee '物流费',
  998. c.cert_fee '证书费',
  999. c.mark_fee '加标费',
  1000. c.package_fee '包装费',
  1001. c.other_fee '其他费用',
  1002. c.nake_total '成本合计',
  1003. b.tax '税点',
  1004. if(b.supply_area=1,'全国','全国除偏远地区') '供货区域',
  1005. b.supplierName '供应商名称'
  1006. ")->where('b.companyNo', $relaComNo)->cursor();
  1007. $cat = Db::name('cat')->where(['is_del' => 0, 'level' => 3])->column('cat_name', 'id');
  1008. $unit = Db::name('unit')->where(['is_del' => 0])->column('unit', 'id');
  1009. $platform = Db::name('platform')->where(['is_del' => 0])->column('platform_name', 'id');
  1010. $brand = Db::name('brand')->where(['is_del' => 0])->column('brand_name', 'id');
  1011. $noble = ["0" => "", "1" => "18K", "2" => "24K", "3" => "白银"];
  1012. $arr = ["待提交", '待完善成本', '待产品审核', '待财务定价', '待财务审核定价', '待上线', '已上线', '审核失败', '已下线'];
  1013. foreach ($list as $value) {
  1014. $value["品牌"] = $brand[$value["品牌"]] ?? '';
  1015. $value["分类"] = $cat[$value["分类"]] ?? '';
  1016. $value["上线平台"] = $platform[$value["上线平台"]] ?? '';
  1017. $value["上线状态"] = $arr[$value["上线状态"]];
  1018. $value['单位'] = $unit[$value['单位']] ?? '';
  1019. $value['贵金属信息'] = $noble[$value['贵金属信息']];
  1020. $value['业务公司编码'] = $relaComNo;
  1021. $value['业务公司名称'] = $relaComName;
  1022. yield $value;
  1023. }
  1024. }
  1025. /**获取商品阶梯售价列表
  1026. * @return \Generator
  1027. */
  1028. private function GetGoodLadder(string $relaComNo = '', string $relaComName = '')
  1029. {
  1030. $list = Db::name("good_platform")
  1031. ->alias("a")
  1032. ->leftJoin("good b", "a.spuCode=b.spuCode")
  1033. ->leftJoin("good_ladder c", "a.skuCode=c.skuCode and c.is_del=0")
  1034. ->field("
  1035. a.skuCode '上线商品编号',
  1036. a.spuCode '成本商品编号',
  1037. a.plat_code '平台商品编号',
  1038. b.good_name '商品名称',
  1039. b.brand_id '品牌',
  1040. b.cat_id '分类',
  1041. b.companyName '业务企业名称',
  1042. a.creater '申请人',
  1043. platform_code '上线平台',
  1044. online_time '上线时间',
  1045. exam_status '上线状态',
  1046. if(b.is_stock=1,'库存','非库存') '是否库存',
  1047. if(b.good_type=1,'定制','非定制')'是否定制',
  1048. '' as '规格',
  1049. '' as '型号',
  1050. b.good_unit '单位',
  1051. b.good_remark '商品备注',
  1052. b.craft_desc '工艺说明',
  1053. b.noble_metal '贵金属信息',
  1054. b.cgd_gold_price '供应商采购金价',
  1055. b.demo_fee '打样费',
  1056. b.open_fee '开模费',
  1057. b.sample_fee '调样费',
  1058. c.min_num '起订量',
  1059. c.sale_price '售价',
  1060. c.cost_fee '工艺费',
  1061. c.market_price '物流费',
  1062. c.market_platform '对比平台',
  1063. b.tax '税点',
  1064. if(b.supply_area=1,'全国','全国除偏远地区') '供货区域',
  1065. b.supplierName '供应商名称'
  1066. ")->where('b.companyNo', $relaComNo)->cursor();
  1067. $arr = ["待提交", '待完善成本', '待产品审核', '待财务定价', '待财务审核定价', '待上线', '已上线', '审核失败', '已下线'];
  1068. $noble = ["0" => "", "1" => "18K", "2" => "24K", "3" => "白银"];
  1069. $cat = Db::name('cat')->where(['is_del' => 0, 'level' => 3])->column('cat_name', 'id');
  1070. $unit = Db::name('unit')->where(['is_del' => 0])->column('unit', 'id');
  1071. $platform = Db::name('platform')->where(['is_del' => 0])->column('platform_name', 'id');
  1072. $brand = Db::name('brand')->where(['is_del' => 0])->column('brand_name', 'id');
  1073. foreach ($list as $value) {
  1074. $value["品牌"] = $brand[$value["品牌"]] ?? '';
  1075. $value["分类"] = $cat[$value["分类"]] ?? '';
  1076. $value["上线平台"] = $platform[$value["上线平台"]] ?? '';
  1077. $value["上线状态"] = $arr[$value["上线状态"]];
  1078. $value['单位'] = $unit[$value['单位']] ?? '';
  1079. $value['贵金属信息'] = $noble[$value['贵金属信息']];
  1080. $value['业务公司编码'] = $relaComNo;
  1081. $value['业务公司名称'] = $relaComName;
  1082. yield $value;
  1083. }
  1084. }
  1085. private function GetBid(string $start, string $end, string $relaComNo = '', string $relaComName = '')
  1086. {
  1087. $list = Db::name("consult_info")
  1088. ->alias("a")
  1089. ->leftJoin("consult_bids d", "a.infoNo=d.infoNo")
  1090. ->leftJoin("consult_order c", "a.zxNo=c.zxNo")
  1091. ->leftJoin("bargain_order b", "d.bidNo=b.bidsNo and b.is_del=0")
  1092. ->field("c.companyNo '业务公司',
  1093. d.addtime '竞价时间',
  1094. d.infoNo '竞价单编号',
  1095. a.`status` '状态',
  1096. c.creater '申请人',
  1097. c.createrid '申请人部门',
  1098. c.khNo '客户名称',
  1099. c.platform_code '所属平台',
  1100. if(a.pgNo='','咨询','项目') as '竞价类型',
  1101. a.cat_id '商品分类',
  1102. a.good_name '商品名称',
  1103. a.budget_price '预算单价',
  1104. a.unit '单位',
  1105. a.num '数量',
  1106. a.budget_price*a.num '竞价单总额',
  1107. d.remark '商品备注',
  1108. d.addtime '反馈时间',
  1109. d.creater '反馈人',
  1110. d.bidNo '反馈商品编码',
  1111. d.status '反馈商品状态',
  1112. d.good_name '反馈商品名称',
  1113. d.sale_price*a.num '反馈单总额',
  1114. d.cat_id '反馈商品分类',
  1115. d.unit_id '反馈商品单位',
  1116. d.tax '反馈商品税点',
  1117. c.endtime '竞价有效期',
  1118. b.bargainNo '议价单编号',
  1119. b.sale_price '议价前售价',
  1120. b.after_price '议价后售价',
  1121. b.before_rate '议价前毛利率',
  1122. b.after_rate '议价后毛利率',
  1123. b.`status` '议价状态',
  1124. b.bargain_remark '议价备注',
  1125. b.result_info_id '议价原因'")
  1126. ->where(["a.is_del" => 0, 'c.companyNo' => $relaComNo])
  1127. ->whereBetween("a.addtime", [$start, $end])
  1128. ->cursor();
  1129. $cat = Db::name('cat')->where(['is_del' => 0, 'level' => 3])->column('cat_name', 'id');
  1130. $unit = Db::name('unit')->where(['is_del' => 0])->column('unit', 'id');
  1131. $platform = Db::name('platform')->where(['is_del' => 0])->column('platform_name', 'id');
  1132. $result = Db::name('result_info')->where(['is_del' => 0])->column('result_desc', 'id');
  1133. $arr = ["待提交", '招标进行中', '招标已结束', '等待议价结果', '确认商品', '成功转单', '取消转单', '招标已暂停'];
  1134. $arr1 = ["待提交", "待任务结束", "待咨询确认", "议价待财务定价", "待主管确认", "待咨询确认定价", "咨询确认"];
  1135. $arr2 = ['待业务主管审核', '业务主管通过', '待财务专员审核', '业务驳回', '财务专员通过', '财务专员驳回', '财务主管通过', '待boss审核', '财务主管驳回', 'boss审核通过', 'boss越线通过', 'boss驳回', '取消议价'];
  1136. $tmp = $temp = [];
  1137. foreach ($list as $value) {
  1138. $value["商品分类"] = $cat[$value["商品分类"]] ?? '';
  1139. $value["反馈商品分类"] = $cat[$value["反馈商品分类"]] ?? '';
  1140. $value["反馈商品单位"] = $unit[$value["反馈商品单位"]] ?? '';
  1141. if (!isset($tmp[$value['客户名称']])) {
  1142. $names = User::getIns()->handle('getCodeAndName', ['code' => $value['客户名称']]);
  1143. $tmp[$value['客户名称']] = $names['data'][$value['客户名称']];
  1144. }
  1145. $value["业务公司"] = $relaComName;
  1146. $value["所属平台"] = $platform[$value["所属平台"]] ?? '';
  1147. if (!isset($temp[$value['申请人部门']])) $temp[$value['申请人部门']] = get_company_name_by_uid($value['申请人部门']);
  1148. $value['申请人部门'] = $temp[$value['申请人部门']] ?? '';
  1149. //状态 ;1招标进行中 2 招标已结束 3 等待议价结果 4.确认商品 5成功转单 6 取消转单 7 招标已暂
  1150. $value["状态"] = $arr[$value["状态"]] ?? "";
  1151. //状态0 待提交 1 提交待确认 2 发起议价 3 财务定价4 主管定价5 确认采购
  1152. $value["反馈商品状态"] = $arr1[$value["反馈商品状态"]] ?? "";
  1153. //状态 1 待主管审批 2.待财务专员审批 3. 待财务主管审批 4 审批通过 5 主管驳回 6 财务主管驳回 7 已取消议价
  1154. $value["议价状态"] = $arr2[$value["议价状态"]] ?? "";
  1155. $value['单位'] = $unit[$value["单位"]] ?? '';
  1156. $value['议价原因'] = $result[$value['议价原因']] ?? '';
  1157. $value['客户名称'] = $tmp[$value['客户名称']] ?? '';
  1158. $value['业务公司编码'] = $relaComNo;
  1159. $value['业务公司名称'] = $relaComName;
  1160. yield $value;
  1161. }
  1162. }
  1163. }