NowReportHandle.php 59 KB

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