Consult.php 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484
  1. <?php
  2. namespace app\abutment\controller;
  3. use app\admin\model\ActionLog;
  4. use app\BaseController;
  5. use think\facade\Db;
  6. class Consult extends BaseController
  7. {
  8. //招标工作台列表
  9. public function crontablist()
  10. {
  11. $this->post = $this->request->filter('trim')->post();
  12. $page = isset($this->post['page']) && $this->post['page'] !== "" ? intval($this->post['page']) : "1";
  13. $size = isset($this->post['size']) && $this->post['size'] !== "" ? intval($this->post['size']) : "10";
  14. $where = [['a.is_del', "=", 0], ['b.is_del', "=", 0]];
  15. $zxNo = isset($this->post['zxNo']) && $this->post['zxNo'] !== "" ? trim($this->post['zxNo']) : "";
  16. if ($zxNo !== "") $where[] = ['a.zxNo', '=', $zxNo];
  17. $salesman = isset($this->post['salesman']) && $this->post['salesman'] !== "" ? trim($this->post['salesman']) : "";
  18. if ($salesman !== "") $where[] = ["b.salesman", 'like', "%$salesman%"];
  19. $cpName = isset($this->post['cpName']) && $this->post['cpName'] !== "" ? trim($this->post['cpName']) : "";
  20. if ($cpName !== "") $where[] = ["a.good_Name", 'like', "%$cpName%"];
  21. $khNo = isset($this->post['khNo']) && $this->post['khNo'] !== "" ? trim($this->post['khNo']) : "";
  22. if ($khNo !== "") $where[] = ["b.khNo", 'like', "%$khNo%"];
  23. $start = isset($this->post['start']) && $this->post['start'] !== "" ? $this->post['start'] : "";
  24. if ($start != "") $where[] = ["a.addtime", '>=', $start];
  25. $end = isset($this->post['end']) && $this->post['end'] !== "" ? $this->post['end'] : "";
  26. if ($end != "") $where[] = ["a.addtime", '<=', $end];
  27. $status = isset($this->post['status']) && $this->post['status'] !== "" ? trim($this->post['status']) : "";
  28. if ($status !== "") $where[] = ["a.status", '=', $status];
  29. $count = Db::name('consult_info')
  30. ->alias("a")
  31. ->leftJoin("consult_order b", "a.zxNo=b.zxNo")
  32. ->where($where)
  33. ->count();
  34. $total = ceil($count / $size);
  35. $page = $page >= $total ? $total : $page;
  36. $list = Db::name('consult_info')
  37. ->alias("a")
  38. ->leftJoin("consult_order b", "a.zxNo=b.zxNo")
  39. ->where($where)
  40. ->page($page, $size)
  41. ->field("a.*,b.createrid,b.creater,b.is_project,b.projectNo,b.khNo,b.endtime,b.platform_code,b.saleid,b.salesman,b.depart")
  42. ->select()
  43. ->toArray();
  44. $data = [];
  45. $noble = ['0' => '', '1' => '18K', '2' => '24K', '3' => '白银'];
  46. $all_cat = Db::name('cat')
  47. ->whereIn('id', array_column($list, 'cat_id'))
  48. ->column('order_rate', 'id');
  49. $all_brand = Db::name('brand')
  50. ->whereIn('id', array_column($list, 'brand_id'))
  51. ->column('brand_name', 'id');
  52. foreach ($list as $value) {
  53. $value['can'] = isset($value['cat_id']) && $value['cat_id'] != 0 ? made($value['cat_id']) : [];
  54. // $cat = Db::name("cat")->where(["id" => $value['cat_id']])->find();
  55. $budget = isset($all_cat[$value['cat_id']]) ? $all_cat[$value['cat_id']] : 0;
  56. $value['original_price'] = sprintf("%.2f", $value['budget_price'] * (1 - $budget / 100));
  57. // $brand = Db::name("brand")->where(['id' => $value['brand_id']])->find();
  58. $value['brand_name'] = isset($all_brand[$value['brand_id']]) && $all_brand[$value['brand_id']] != '' ? $all_brand[$value['brand_id']] : "";
  59. $value['khname'] = "";
  60. $value['specinfo'] = isset($value['specinfo']) && $value['specinfo'] != "" ? json_decode($value['specinfo'], true) : [];
  61. if ($value['khNo'] !== "") {
  62. $kh = Db::name("customer_info")
  63. ->where(['companyNo' => $value['khNo']])
  64. ->find();
  65. $value['khname'] = isset($kh['companyName']) ? $kh['companyName'] : "";
  66. }
  67. $consult = Db::name("consult_bids")
  68. ->where(["infoNo" => $value['infoNo'], "createrid" => $this->request->user['uid'], "is_del" => 0])
  69. ->find();
  70. $consults = Db::name("consult_bids")
  71. ->where(["infoNo" => $value['infoNo'], "is_del" => 0])
  72. ->find();
  73. $value['is_feed'] = $consult == false ? 0 : 1;
  74. $value['is_all_feed'] = $consults == false ? 0 : 1;
  75. $value['metal_name'] = isset($value['metal_id']) && $value['metal_id'] != 0 ? $noble[$value['metal_id']] : "";
  76. $data[] = $value;
  77. }
  78. return json_show(0, "获取成功", ['count' => $count, 'list' => $data]);
  79. }
  80. //招标工作台详情
  81. public function zxinfo()
  82. {
  83. $this->post = $this->request->filter('trim')->post();
  84. $infoNo = isset($this->post['infoNo']) && $this->post['infoNo'] != "" ? trim($this->post['infoNo']) : "";
  85. if ($infoNo == "") {
  86. return json_show(1004, "参数infoNo不能为空");
  87. }
  88. $zxinfo = Db::name("consult_info")->where(["infoNo" => $infoNo, "is_del" => 0])->find();
  89. if ($zxinfo == false) {
  90. return json_show(1004, "未找到信息数据");
  91. }
  92. $zxorder = Db::name("consult_order")->where(["zxNo" => $zxinfo['zxNo'], "is_del" => 0])->find();
  93. if ($zxorder == false) {
  94. return json_show(1004, "未找到咨询信息数据");
  95. }
  96. $cat = Db::name("cat")->where(["id" => $zxinfo['cat_id']])->find();
  97. $budget = isset($cat['order_rate']) ? $cat['order_rate'] : 0;
  98. $zxinfo['can'] = isset($zxinfo['cat_id']) && $zxinfo['cat_id'] != 0 ? made($zxinfo['cat_id'], []) : [];
  99. $zxinfo['khname'] = "";
  100. $zxinfo['original_price'] = sprintf("%.2f", $zxinfo['budget_price'] * (1 - $budget / 100));
  101. $zxinfo['khNo'] = "";
  102. $zxinfo['brand_id'] = $zxinfo['brand_id'] == 0 ? "" : $zxinfo['brand_id'];
  103. $zxinfo['brand'] = "";
  104. $zxinfo['companyNo'] = isset($zxorder['companyNo']) ? $zxorder['companyNo'] : "";
  105. $zxinfo['projectNo'] = isset($zxorder['projectNo']) ? $zxorder['projectNo'] : "";
  106. $zxinfo['is_project'] = isset($zxorder['is_project']) ? $zxorder['is_project'] : "";
  107. $zxinfo['company'] = "";
  108. $zxinfo['endtime'] = isset($zxorder['endtime']) ? $zxorder['endtime'] : "";
  109. $zxinfo['platform_code'] = isset($zxorder['platform_code']) ? $zxorder['platform_code'] : "";
  110. $zxinfo['salesman'] = isset($zxorder['salesman']) ? $zxorder['salesman'] : "";
  111. $zxinfo['saleid'] = isset($zxorder['saleid']) ? $zxorder['saleid'] : "";
  112. $zxinfo['depart'] = isset($zxorder['depart']) ? $zxorder['depart'] : "";
  113. $zxinfo['project_name'] = "";
  114. $zxinfo['budget_total'] = "";
  115. $zxinfo['departinfo'] = [];
  116. $zxinfo['unit_name'] = "";
  117. $zxinfo['metal_name'] = isset($zxinfo['metal_id']) && $zxinfo['metal_id'] != 0 ? $this->noble[$zxinfo['metal_id']] : "";
  118. $zxinfo['specinfo'] = json_decode($zxinfo['specinfo'], true);
  119. if ($zxorder['khNo'] !== "") {
  120. $kh = Db::name("customer_info")->where(['companyNo' => $zxorder['khNo']])->find();
  121. $zxinfo['khname'] = isset($kh['companyName']) ? $kh['companyName'] : "";
  122. $zxinfo['khNo'] = $zxorder['khNo'];
  123. }
  124. if ($zxinfo['unit'] !== "") {
  125. $unit = Db::name("unit")->where(['id' => $zxinfo['unit']])->find();
  126. $zxinfo['unit_name'] = isset($unit['unit']) ? $unit['unit'] : "";
  127. }
  128. if ($zxinfo['brand_id'] !== "") {
  129. $unit = Db::name("brand")->where(['id' => $zxinfo['brand_id']])->find();
  130. $zxinfo['brand'] = isset($unit['brand_name']) ? $unit['brand_name'] : "";
  131. }
  132. if ($zxorder['companyNo'] !== "") {
  133. $kh = Db::name("business")->where(['companyNo' => $zxorder['companyNo']])->find();
  134. $zxinfo['company'] = isset($kh['company']) ? $kh['company'] : "";
  135. }
  136. if ($zxorder['is_project'] == 1 && $zxorder['projectNo'] !== "") {
  137. $project = Db::name("project")->where(["projectNo" => $zxorder['projectNo'], "is_del" => 0])->find();
  138. $zxinfo['project_name'] = isset($project['project_name']) ? $project['project_name'] : "";
  139. $zxinfo['budget_total'] = isset($project['budget_total']) ? $project['budget_total'] : "";
  140. $zxinfo['project_use_desc'] = isset($project['use_desc']) ? $project['use_desc'] : "";
  141. $projectinfo = Db::name("project_info")->where(["pgNo" => $zxinfo['pgNo']])->find();
  142. $zxinfo['pgNo'] = isset($projectinfo['pgNo']) ? $projectinfo['pgNo'] : "";
  143. }
  144. if ($zxorder['depart'] > 0) {
  145. $zxinfo['departinfo'] = GetPart($zxorder['depart']);
  146. }
  147. if ($zxorder['platform_code'] > 0) {
  148. $palt = Db::name("platform")->where(["id" => $zxorder['platform_code']])->find();
  149. $zxinfo['platform_name'] = isset($palt['platform_name']) ? $palt['platform_name'] : "";
  150. }
  151. return json_show(0, "获取成功", $zxinfo);
  152. }
  153. //采反商品列表
  154. public function bidlist()
  155. {
  156. $this->post = $this->request->filter('trim')->post();
  157. $page = isset($this->post['page']) && $this->post['page'] !== "" ? intval($this->post['page']) : "1";
  158. $size = isset($this->post['size']) && $this->post['size'] !== "" ? intval($this->post['size']) : "10";
  159. $where = [['is_del', "=", 0]];
  160. $zxNo = isset($this->post['zxNo']) && $this->post['zxNo'] !== "" ? trim($this->post['zxNo']) : "";
  161. if ($zxNo !== "") {
  162. $where[] = ['zxNo', 'like', '%' . $zxNo . '%'];
  163. }
  164. $infoNo = isset($this->post['infoNo']) && $this->post['infoNo'] !== "" ? trim($this->post['infoNo']) : "";
  165. if ($infoNo !== "") {
  166. $where[] = ['infoNo', 'like', '%' . $infoNo . '%'];
  167. }
  168. $bidNo = isset($this->post['bidNo']) && $this->post['bidNo'] !== "" ? trim($this->post['bidNo']) : "";
  169. if ($bidNo !== "") {
  170. $where[] = ['bidNo', 'like', '%' . $bidNo . '%'];
  171. }
  172. $pgNo = isset($this->post['pgNo']) && $this->post['pgNo'] !== "" ? trim($this->post['pgNo']) : "";
  173. if ($pgNo !== "") {
  174. $bidinfo = Db::name("consult_info")->where([["pgNo", "=", $pgNo], ["is_del", "=", 0]])->column("infoNo");
  175. $where[] = ['infoNo', 'in', $bidinfo];
  176. }
  177. $bargain_status = isset($this->post['bargain_status']) && $this->post['bargain_status'] !== "" ? intval($this->post['bargain_status']) : "";
  178. if ($bargain_status !== "") {
  179. $bidinfo = Db::name("consult_info")->where([["bargain_status", "=", $bargain_status], ["is_del", "=", 0]])->column("infoNo");
  180. $where[] = ['infoNo', 'in', $bidinfo];
  181. }
  182. $projectNo = isset($this->post['projectNo']) && $this->post['projectNo'] !== "" ? trim($this->post['projectNo']) : "";
  183. if ($projectNo !== "") {
  184. $zxlist = Db::name("consult_order")->where(["projectNo" => $projectNo, "is_del" => 0, "is_project" => 1])->column("zxNo");
  185. $where[] = ['zxNo', 'in', $zxlist];
  186. }
  187. $is_own = isset($this->post['is_own']) ? intval($this->post['is_own']) : "0";
  188. if ($is_own == 1) {
  189. // $token = isset($this->post['token']) ? trim($this->post['token']) : "";
  190. // if($token==""){
  191. // return json_show(101,'token不能为空');
  192. // }
  193. // $apply_id =GetUserInfo($token);
  194. // if(empty($apply_id)||$apply_id['code']!=0){
  195. // return json_show(1002,"申请人数据不存在");
  196. // }
  197. $rm = $this->request->user['uid'];
  198. $where[] = ['createrid', "=", $rm];
  199. }
  200. $count = Db::name('consult_bids')->where($where)->count();
  201. $total = ceil($count / $size);
  202. $page = $page >= $total ? $total : $page;
  203. $list = Db::name('consult_bids')->where($where)->page($page, $size)->select()->toArray();
  204. $data = [];
  205. foreach ($list as $value) {
  206. $catinfo = Db::name("cat")->where(["id" => $value['cat_id']])->find();
  207. $value['can'] = isset($value['cat_id']) && $value['cat_id'] != 0 ? made($value['cat_id']) : [];
  208. $unit = Db::name("unit")->where(["id" => $value['unit_id']])->find();
  209. $value['unit'] = isset($unit['unit']) ? $unit['unit'] : '';
  210. $supplier = Db::name("supplier")->where(["code" => $value['supplierNo']])->find();
  211. $value['supplierName'] = isset($supplier['name']) ? $supplier['name'] : "";
  212. if ($value['brand_id'] != 0) {
  213. $brand = Db::name("brand")->where(["id" => $value['brand_id']])->find();
  214. $value["brand_name"] = isset($brand['brand_name']) ? $brand['brand_name'] : "";
  215. } else {
  216. $value["brand_name"] = "";
  217. $value["brand_id"] = "";
  218. }
  219. $bidinfo = Db::name("consult_info")->where(["infoNo" => $value["infoNo"]])->find();
  220. $budget = isset($catinfo['order_rate']) ? $catinfo['order_rate'] : 0;
  221. $god = [
  222. "metal_id" => $value['metal_id'],
  223. "weight" => $value["good_weight"],
  224. "demo_fee" => $value["demo_fee"],
  225. "delivery_fee" => $value["delivery_fee"],
  226. "open_fee" => $value["open_fee"],
  227. "packing_fee" => $value["pakge_fee"],
  228. "mark_fee" => $value["mark_fee"],
  229. "nake_fee" => $value["nake_fee"],
  230. "cert_fee" => $value["cert_fee"],
  231. // "cost_fee"=>$value["cost_fee"],
  232. "cost_fee" => $value["sale_cost_fee"] != $value['origin_cost_fee'] ? $value["sale_cost_fee"] : $value["cost_fee"],
  233. "num" => $bidinfo["num"],
  234. ];
  235. $top_cat = made($value['cat_id']);
  236. $top_cat_id = isset($top_cat[0]['id']) ? $top_cat[0]['id'] : 0;
  237. if ($value['is_gold_price'] == 1 && $top_cat_id == 6) {
  238. $price = GoldPrice($god, $budget / 100);
  239. $value['sale_price'] = round($price, 2);
  240. $value['origin_price'] = $value["sale_cost_fee"] != $value['origin_cost_fee'] ? $value["sale_price"] :
  241. $value["origin_price"];
  242. }
  243. $value['cost_fee'] = $value['origin_cost_fee'];
  244. $value['specinfo'] = json_decode($value['specinfo'], true);
  245. $value['metal_name'] = isset($value['metal_id']) && $value['metal_id'] != 0 ? $this->noble[$value['metal_id']] : "";
  246. $value['bargain_status'] = $bidinfo['bargain_status'];
  247. //reject驳回原因,status==5表示驳回
  248. $value['reject'] = [];
  249. if ($value['status'] >= 5) {
  250. $value['reject'] = Db::name('bargain_order')
  251. ->field('id,remark,status')
  252. ->where(['infoNo' => $infoNo, 'bidsNo' => $value['bidNo']])
  253. ->whereIn('status', [3, 8, 11])->order("id desc")
  254. ->find();
  255. }
  256. //产地
  257. $place = ["provice_code" => "", "city_code" => "", "area_code" => ""];
  258. if ($value['delivery_place'] != "") {
  259. list($place['provice_code'], $place['city_code'], $place['area_code']) = explode(",", $value['delivery_place']);
  260. }
  261. $value['delivery_place_cn'] = GetAddr(json_encode($place));
  262. $place = ["provice_code" => "", "city_code" => "", "area_code" => ""];
  263. if ($value['origin_place'] != "") {
  264. list($place['provice_code'], $place['city_code'], $place['area_code']) = explode(",", $value['origin_place']);
  265. }
  266. $value['origin_addr'] = GetAddr(json_encode($place));
  267. // if($value['origin_place']!=''){
  268. // $code = explode(",",$value['origin_place']);
  269. // $temp=[];
  270. // $temp['provice_code']=isset($code[0])?$code[0]:"";
  271. // $temp['city_code']=isset($code[1])?$code[1]:"";
  272. // $temp['area_code']=isset($code[2])?$code[2]:"";
  273. // $addr= GetAddr(json_encode($temp));
  274. // $value['origin_addr'] = $addr;
  275. // }
  276. $data[] = $value;
  277. }
  278. return json_show(0, "获取成功", ['count' => $count, 'list' => $data]);
  279. }
  280. //创建采反商品
  281. public function create()
  282. {
  283. $this->post = $this->request->filter('trim')->post();
  284. $is_project = isset($this->post['is_project']) && $this->post['is_project'] !== "" ? intval($this->post['is_project']) : "";
  285. if ($is_project === "") {
  286. return json_show(1002, "参数is_project不能为空");
  287. }
  288. if ($is_project == 1) {
  289. $projectNo = isset($this->post['projectNo']) && $this->post['projectNo'] !== "" ? trim($this->post['projectNo']) : "";
  290. if ($projectNo === "") {
  291. return json_show(1002, "参数projectNo不能为空");
  292. }
  293. }
  294. $khNo = isset($this->post['khNo']) && $this->post['khNo'] !== "" ? trim($this->post['khNo']) : "";
  295. if ($khNo === "") {
  296. return json_show(1002, "参数khNo不能为空");
  297. }
  298. $companyNo = isset($this->post['companyNo']) && $this->post['companyNo'] !== "" ? trim($this->post['companyNo']) : "";
  299. if ($companyNo === "") {
  300. return json_show(1002, "参数companyNo不能为空");
  301. }
  302. $endtime = isset($this->post['endtime']) && $this->post['endtime'] !== "" ? $this->post['endtime'] : "";
  303. if ($endtime === "") {
  304. return json_show(1002, "参数endtime不能为空");
  305. }
  306. $platform_code = isset($this->post['platform_code']) && $this->post['platform_code'] !== "" ? trim($this->post['platform_code']) :
  307. "";
  308. if ($platform_code === "") {
  309. return json_show(1002, "参数platform_code不能为空");
  310. }
  311. $ladder = isset($this->post['ladder']) && !empty($this->post['ladder']) ? $this->post['ladder'] : "";
  312. if ($ladder == "") {
  313. return json_show(1005, "参数ladder不能为空");
  314. }
  315. // $token = isset($this->post['token'])&& $this->post['token']!='' ? trim($this->post['token']):"";
  316. // if($token==''){
  317. // return json_show(105,"参数token不能为空");
  318. // }
  319. // $user =GetUserInfo($token);
  320. // if(empty($user)||$user['code']!=0){
  321. // return json_show(102,"用户数据不存在");
  322. // }
  323. $createrid = $this->request->user['uid'];
  324. $creater = $this->request->user['nickname'];
  325. $depart = Db::name("depart_user")->where(["uid" => $createrid, "status" => 1, "is_del" => 0])->find();
  326. $zxNo = makeNo("ZX");
  327. Db::startTrans();
  328. try {
  329. $data = [
  330. "zxNo" => $zxNo,
  331. "createrid" => $createrid,
  332. "creater" => $creater,
  333. "is_project" => $is_project,
  334. "projectNo" => isset($projectNo) ? $projectNo : "",
  335. "khNo" => $khNo,
  336. "companyNo" => $companyNo,
  337. "endtime" => $endtime,
  338. "salesman" => $creater,
  339. "platform_code" => $platform_code,
  340. "saleid" => $createrid,
  341. "depart" => isset($depart['itemid']) ? $depart['itemid'] : 0,
  342. "status" => 0,
  343. "is_del" => 0,
  344. "addtime" => date("Y-m-d H:i:s"),
  345. "updatetime" => date("Y-m-d H:i:s"),
  346. ];
  347. $zx = Db::name("consult_order")->insert($data);
  348. if ($zx) {
  349. //判断是否是项目,且该项目是否存在台账记录中
  350. if ($is_project == 1) $stand_exists = Db::name('standing_book')->field('id')->where('projectNo', $projectNo)->find();
  351. foreach ($ladder as $value) {
  352. $infoNo = makeNo("IF");
  353. $specinfo = [];
  354. if (isset($value['specinfo']) && !empty($value['specinfo'])) {
  355. foreach ($value["specinfo"] as $v) {
  356. $spec = Db::name("specs")->where(["id" => $v['specid']])->find();
  357. $spec_value = Db::name("spec_value")->where(["id" => $v['spec_value_id']])->find();
  358. $v['spec_name'] = isset($spec['spec_name']) ? $spec['spec_name'] : "";
  359. $v['spec_value_name'] = isset($spec_value['spec_value']) ? $spec_value['spec_value'] : "";
  360. $specinfo[] = $v;
  361. }
  362. }
  363. $info = [
  364. "infoNo" => $infoNo,
  365. "zxNo" => $zxNo,
  366. "spuCode" => "",
  367. "good_name" => $value['good_name'],
  368. "good_img" => $value['good_img'],
  369. "cat_id" => $value['cat_id'],
  370. "unit" => $value['unit'],
  371. "brand_id" => $value['brand_id'],
  372. "arrival_time" => $value['arrival_time'],
  373. "specinfo" => empty($specinfo) ? "" : json_encode($specinfo),
  374. "cost_desc" => isset($value['cost_desc']) ? $value['cost_desc'] : '',
  375. "is_addrs" => $value['is_addrs'],
  376. "is_custom" => $value['is_custom'],
  377. "metal_id" => $value['metal_id'],
  378. "config" => isset($value['config']) ? $value['config'] : "",
  379. "other_config" => isset($value['other_config']) ? $value['other_config'] : "",
  380. "specs_weight" => isset($value['specs_weight']) ? $value['specs_weight'] : "0",
  381. "gold_price" => isset($value['gold_price']) ? $value['gold_price'] : "0",
  382. "is_gold_price" => isset($value['is_gold_price']) ? $value['is_gold_price'] : "0",
  383. "total_weight" => isset($value['total_weight']) ? $value['total_weight'] : "0",
  384. "budget_price" => $value['budget_price'],
  385. "num" => $value['num'],
  386. "pgNo" => isset($value['pgNo']) && $value['pgNo'] !== "" ? trim($value['pgNo']) : "",
  387. "use_desc" => $value['use_desc'],
  388. "remark" => $value['remark'],
  389. "status" => 1,
  390. "is_del" => 0,
  391. "addtime" => date("Y-m-d H:i:s"),
  392. "updatetime" => date("Y-m-d H:i:s"),
  393. 'enclosure_file' => isset($value['enclosure_file']) ? $value['enclosure_file'] : '',
  394. ];
  395. $up = Db::name("consult_info")->insertGetId($info);
  396. if (!$up) {
  397. Db::rollback();
  398. return json_show(1004, '添加失败');
  399. } else {
  400. //修改状态
  401. ActionLog::logAdd(['id' => $createrid, 'nickname' => $creater], [
  402. "order_code" => $infoNo,//咨询单详情编号
  403. "status" => 1,//这里的status是之前的值
  404. "action_remark" => '',//备注
  405. "action_type" => "create"//新建create,编辑edit,更改状态status
  406. ], "ZXD", 1, $info);
  407. //竞价单不走流程,不推待办已办
  408. // ProcessOrder::AddProcess(['id' => $createrid, 'nickname' => $creater], [
  409. // "order_type" => 'ZXD',
  410. // "order_code" => $infoNo,//咨询单详情编号
  411. // "order_id" => $up,
  412. // "order_status" => 1,
  413. // 'before_status'=>0
  414. // ]);
  415. //如果存在该项目编码,更新对应的第一个竞价单编码,其他竞价单编码新增(带着项目编码)
  416. if (isset($stand_exists)) {
  417. Db::name('standing_book')
  418. ->where('id', $stand_exists['id'])
  419. ->update([
  420. 'infoNo' => $infoNo,
  421. 'updatetime' => date('Y-m-d H:i:s')
  422. ]);
  423. unset($stand_exists);//后面的竞价单编码不用更新,都是新增
  424. } else {
  425. //添加台账信息
  426. Db::name('standing_book')
  427. ->insert([
  428. 'standBookNo' => makeNo("IO"),
  429. 'projectNo' => isset($projectNo) ? $projectNo : '',
  430. 'infoNo' => $infoNo,
  431. 'companyNo' => $companyNo,
  432. 'customer_code' => $khNo,
  433. 'addtime' => date('Y-m-d H:i:s'),
  434. 'updatetime' => date('Y-m-d H:i:s')
  435. ]);
  436. }
  437. }
  438. }
  439. Db::commit();
  440. return json_show(0, "新建成功", ["zxNo" => $zxNo]);
  441. } else {
  442. Db::rollback();
  443. return json_show(1004, "新建失败");
  444. }
  445. } catch (\Exception $e) {
  446. Db::rollback();
  447. return json_show(1003, $e->getMessage());
  448. }
  449. }
  450. }