U8XkyServerService.php 35 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886
  1. <?php
  2. namespace App\Service;
  3. use App\Model\DDEmployee;
  4. use App\Model\FieldData;
  5. use App\Model\Inventory;
  6. use App\Model\Record;
  7. use App\Model\U8State;
  8. use App\Model\Vendor;
  9. use Illuminate\Support\Facades\DB;
  10. class U8XkyServerService extends Service
  11. {
  12. //新增存货到本地-----------------------------------------------
  13. public function inventoryAdd($data, $user){
  14. list($status, $msg) = $this->inventoryRule($data, $user);
  15. if(! $status) return [false, $msg];
  16. try {
  17. DB::beginTransaction();
  18. $inventoryData = [
  19. 'order_number' => $this->generateBillNo([
  20. 'type' => Inventory::Order_type,
  21. 'login_type' => $user['login_type'],
  22. 'period' => date("Ym")
  23. ]),
  24. 'code' => $data['code'] ?? "",
  25. 'title' => $data['title'] ?? "",
  26. 'size' => $data['size'] ?? "",
  27. 'category_code' => $data['category_code'] ?? "",
  28. 'category_code_title' => $data['category_code_title'] ?? "",
  29. 'unit_group_type' => $data['unit_group_type'] ?? "",
  30. 'unit_group_code' => $data['unit_group_code'] ?? "",
  31. 'unit_group_code_title' => $data['unit_group_code_title'] ?? "",
  32. 'unit_code' => $data['unit_code'] ?? "",
  33. 'unit_code_title' => $data['unit_code_title'] ?? "",
  34. 'vendor_code' => $data['vendor_code'] ?? "",
  35. 'vendor_code_title' => $data['vendor_code_title'] ?? "",
  36. 'bSale' => $data['bSale'] ?? 0, //内销
  37. 'bExpSale' => $data['bExpSale'] ?? 0, //外销
  38. 'bPurchase' => $data['bPurchase'] ?? 0, // 采购
  39. 'bSelf' => $data['bSelf'] ?? 0, // 自制
  40. 'bComsume' => $data['bComsume'] ?? 0, // 生产耗材
  41. 'iImpTaxRate' => $data['iImpTaxRate'] ?? 0, // 进项税率
  42. 'iTaxRate' => $data['iTaxRate'] ?? 0, // 销项税率
  43. 'customs_change_rate' => $data['customs_change_rate'] ?? 0,
  44. 'login_type' => $user['login_type'],
  45. 'crt_id' => $user['userid'],
  46. 'crt_time' => time(),
  47. ];
  48. Inventory::insert($inventoryData);
  49. DB::commit();
  50. } catch (\Throwable $exception) {
  51. DB::rollBack();
  52. return [false, "创建存货失败: " . $exception->getMessage()];
  53. }
  54. return [true, ''];
  55. }
  56. public function inventoryEdit($data, $user){
  57. list($status, $msg) = $this->inventoryRule($data, $user);
  58. if(! $status) return [false, $msg];
  59. try {
  60. DB::beginTransaction();
  61. $inventoryData = [
  62. 'code' => $data['code'] ?? "",
  63. 'title' => $data['title'] ?? "",
  64. 'size' => $data['size'] ?? "",
  65. 'category_code' => $data['category_code'] ?? "",
  66. 'category_code_title' => $data['category_code_title'] ?? "",
  67. 'unit_group_type' => $data['unit_group_type'] ?? "",
  68. 'unit_group_code' => $data['unit_group_code'] ?? "",
  69. 'unit_group_code_title' => $data['unit_group_code_title'] ?? "",
  70. 'unit_code' => $data['unit_code'] ?? "",
  71. 'unit_code_title' => $data['unit_code_title'] ?? "",
  72. 'vendor_code' => $data['vendor_code'] ?? "",
  73. 'vendor_code_title' => $data['vendor_code_title'] ?? "",
  74. 'bSale' => $data['bSale'] ?? 0, //内销
  75. 'bExpSale' => $data['bExpSale'] ?? 0, //外销
  76. 'bPurchase' => $data['bPurchase'] ?? 0, // 采购
  77. 'bSelf' => $data['bSelf'] ?? 0, // 自制
  78. 'bComsume' => $data['bComsume'] ?? 0, // 生产耗材
  79. 'iImpTaxRate' => $data['iImpTaxRate'] ?? 0, // 进项税率
  80. 'iTaxRate' => $data['iTaxRate'] ?? 0, // 销项税率
  81. 'customs_change_rate' => $data['customs_change_rate'] ?? 0,
  82. 'upd_time' => time(),
  83. ];
  84. Inventory::where('id', $data['id'])->update($inventoryData);
  85. DB::commit();
  86. } catch (\Throwable $exception) {
  87. DB::rollBack();
  88. return [false, "编辑存货失败: " . $exception->getMessage()];
  89. }
  90. return [true, ''];
  91. }
  92. public function inventoryRule(&$data, $user, $is_add = true){
  93. if(! $is_add && empty($data['id'])) return [false, 'ID不能为空'];
  94. $id = $data['id'] ?? 0;
  95. $code = $data['code'] ?? "";
  96. if(empty($data['title'])) return [false, '存货名称不能为空'];
  97. $title = $data['title'];
  98. if(empty($data['category_code'])) return [false, '存货分类编码不能为空'];
  99. $category_code = $data['category_code'];
  100. if(empty($data['category_code_title'])) return [false, '存货分类名不能为空'];
  101. $category_code_title = $data['category_code_title'];
  102. if(! isset($data['unit_group_type'])) return [false, '计量单位组类型不存在'];
  103. $unit_group_type = $data['unit_group_type'] ?? "";
  104. if(empty($data['unit_group_code'])) return [false, '计量单位组编码不能为空'];
  105. $unit_group_code = $data['unit_group_code'] ?? "";
  106. if(empty($data['unit_group_code_title'])) return [false, '计量单位组名不能为空'];
  107. $unit_group_code_title = $data['unit_group_code_title'] ?? "";
  108. if(empty($data['unit_code'])) return [false, '主计量单位编码不能为空'];
  109. $unit_code = $data['unit_code'] ?? "";
  110. if(empty($data['unit_code_title'])) return [false, '主计量单位名称不能为空'];
  111. $unit_code_title = $data['unit_code_title'] ?? "";
  112. if(! empty($data['vendor_code_title']) && empty($data['vendor_code'])) return [false, '生产企业编码不能为空'];
  113. $vendor_code = $data['vendor_code'] ?? "";
  114. $vendor_code_title = $data['vendor_code_title'] ?? "";
  115. $bSale = $data['bSale'] ?? 0;
  116. $bExpSale = $data['bExpSale'] ?? 0;
  117. $bPurchase = $data['bPurchase'] ?? 0;
  118. $bSelf = $data['bSelf'] ?? 0;
  119. $bComsume = $data['bComsume'] ?? 0;
  120. $iImpTaxRate = $data['iImpTaxRate'] ?? 0;
  121. $iTaxRate = $data['iTaxRate'] ?? 0;
  122. $res = $this->checkNumber($iImpTaxRate,2,'positive');
  123. if(! $res['valid']) return [false,'进项税率:' . $res['error']];
  124. $res = $this->checkNumber($iTaxRate,2,'positive');
  125. if(! $res['valid']) return [false,'销项税率:' . $res['error']];
  126. $customs_change_rate = $data['customs_change_rate'] ?? 0;
  127. $res = $this->checkNumber($customs_change_rate,2,'positive');
  128. if(! $res['valid']) return [false,'海关换算率:' . $res['error']];
  129. if(! empty($code)){
  130. $bool = Inventory::where('del_time', 0)
  131. ->where('login_type', $user['login_type'])
  132. ->when(! empty($id), function ($query) use($id){
  133. return $query->where('id', '<>', $id);
  134. })
  135. ->where('code', $code)
  136. ->exists();
  137. if($bool) return [false, '存货编码已存在记录,新增失败'];
  138. }
  139. if(! $is_add){
  140. $order = Inventory::where('id', $data['id'])->first();
  141. if(empty($order)) return [false, '存货信息不存在或已被删除'];
  142. $order = $order->toArray();
  143. list($status, $msg) = $this->checkState(U8State::type_four, $user, $order['order_number']);
  144. if(! $status) return [false, $msg];
  145. }
  146. return [true, ''];
  147. }
  148. public function inventoryCommon($data, $user, $field = []){
  149. $type = U8State::type_four;
  150. $model = Inventory::from('inventory as i')
  151. ->leftJoin('u8_state as s', function ($join) use ($type, $user) {
  152. $join->on('i.order_number', '=', 's.order_number')
  153. ->where('s.type', '=', $type)
  154. ->where('s.login_type', '=', $user['login_type'])
  155. ->where('s.del_time', '=', 0);
  156. })
  157. ->where('i.del_time', 0)
  158. ->where('i.login_type', $user['login_type'])
  159. ->select('i.*', DB::raw('IFNULL(s.state, -1) as state'))
  160. ->orderby('i.id', 'desc');
  161. // 2. 状态过滤逻辑
  162. if (isset($data['state']) && $data['state'] !== '') {
  163. $state_filter = $data['state'];
  164. if ($state_filter == -1) {
  165. // 未发起审批:在状态表里找不到记录
  166. $model->whereNull('s.state');
  167. } else {
  168. // 0:待审核 1:通过 2:驳回
  169. $model->where('s.state', $state_filter);
  170. }
  171. }
  172. if(! empty($data['id'])) $model->where('i.id', $data['id']);
  173. if(! empty($data['crt_time'][0]) && ! empty($data['crt_time'][1])) {
  174. $return = $this->changeDateToTimeStampAboutRange($data['crt_time']);
  175. $model->where('i.crt_time', '>=', $return[0]);
  176. $model->where('i.crt_time', '<=', $return[1]);
  177. }
  178. return $model;
  179. }
  180. public function inventoryDetail($data, $user){
  181. if(empty($data['id'])) return [false, 'ID不能为空'];
  182. list($status, $msg) = $this->inventoryList($data, $user);
  183. $return = $msg['data'][0] ?? [];
  184. return [true, $return];
  185. }
  186. public function inventoryList($data, $user){
  187. $model = $this->inventoryCommon($data, $user);
  188. $list = $this->limit($model,'',$data);
  189. $list = $this->fillInventoryData($list,$user);
  190. return [true, $list];
  191. }
  192. public function fillInventoryData($data, $user){
  193. if(empty($data['data'])) return $data;
  194. $e_map = DDEmployee::whereIn('userid', array_unique(array_column($data['data'], 'crt_id')))
  195. ->where('login_type', $user['login_type'])
  196. ->pluck('name', 'userid')
  197. ->toArray();
  198. foreach ($data['data'] as $key => $value){
  199. $data['data'][$key]['bSale'] = $value['bSale'] ? '是' : '否';
  200. $data['data'][$key]['bExpSale'] = $value['bExpSale'] ? '是' : '否';
  201. $data['data'][$key]['bPurchase'] = $value['bPurchase'] ? '是' : '否';
  202. $data['data'][$key]['bSelf'] = $value['bSelf'] ? '是' : '否';
  203. $data['data'][$key]['bComsume'] = $value['bComsume'] ? '是' : '否';
  204. $data['data'][$key]['crt_name'] = $e_map[$value['crt_id']] ?? "";
  205. $data['data'][$key]['crt_time'] = $value['crt_time'] ? date('Y-m-d H:i:s',$value['crt_time']) : '';
  206. $data['data'][$key]['state_title'] = Record::state_name[$value['state']];
  207. }
  208. return $data;
  209. }
  210. public function inventoryDel($data, $user){
  211. if($this->isEmpty($data,'id')) return [false,'请选择数据!'];
  212. try {
  213. DB::beginTransaction();
  214. $time = time();
  215. $order = Inventory::where('id', $data['id'])->first();
  216. if(empty($order)) return [false, '存货信息不存在或已被删除'];
  217. $order = $order->toArray();
  218. list($status, $msg) = $this->checkState(U8State::type_five, $user, $order['order_number']);
  219. if(! $status) return [false, $msg];
  220. Inventory::where('del_time',0)
  221. ->where('id',$data['id'])
  222. ->update(['del_time' => $time]);
  223. DB::commit();
  224. }catch (\Exception $exception){
  225. DB::rollBack();
  226. return [false,$exception->getMessage()];
  227. }
  228. return [true, ''];
  229. }
  230. //新增存货到本地-----------------------------------------------
  231. private function checkState($type, $user, $order_number){
  232. $lastRecord = U8State::where('del_time', 0)
  233. ->where('type', $type)
  234. ->where('login_type', $user['login_type'])
  235. ->where('order_number', $order_number)
  236. ->first(['state']); // 只取状态字段
  237. if ($lastRecord) {
  238. $text_o = U8State::type_name[$type];
  239. // 如果状态是 0 (待审核) 或 1 (审核通过),拦截
  240. if (in_array($lastRecord->state, [U8State::state_zero, U8State::state_one])) {
  241. $text = U8State::state_name[$lastRecord->state];
  242. return [false, $text_o . ' (' . $order_number . ') 处于' . $text . ',操作失败'];
  243. }
  244. }
  245. return [true, ''];
  246. }
  247. //新增供应商到本地-----------------------------------------------
  248. public function vendorAdd($data, $user){
  249. list($status, $msg) = $this->vendorRule($data, $user);
  250. if(! $status) return [false, $msg];
  251. try {
  252. DB::beginTransaction();
  253. $vendorData = [
  254. 'order_number' => $this->generateBillNo([
  255. 'type' => Vendor::Order_type,
  256. 'login_type' => $user['login_type'],
  257. 'period' => date("Ym")
  258. ]),
  259. 'code' => $data['code'] ?? "",
  260. 'title' => $data['title'] ?? "",
  261. 'easy_title' => $data['easy_title'] ?? "",
  262. 'category_code' => $data['category_code'] ?? "",
  263. 'category_code_title' => $data['category_code_title'] ?? "",
  264. 'login_type' => $user['login_type'] ?? "",
  265. 'crt_id' => $user['userid'],
  266. 'crt_time' => time(),
  267. ];
  268. Vendor::insert($vendorData);
  269. DB::commit();
  270. } catch (\Throwable $exception) {
  271. DB::rollBack();
  272. return [false, "创建供应商失败: " . $exception->getMessage()];
  273. }
  274. return [true, ''];
  275. }
  276. public function vendorEdit($data, $user){
  277. list($status, $msg) = $this->vendorRule($data, $user);
  278. if(! $status) return [false, $msg];
  279. try {
  280. DB::beginTransaction();
  281. $vendorData = [
  282. 'code' => $data['code'] ?? "",
  283. 'title' => $data['title'] ?? "",
  284. 'easy_title' => $data['easy_title'] ?? "",
  285. 'category_code' => $data['category_code'] ?? "",
  286. 'category_code_title' => $data['category_code_title'] ?? "",
  287. 'upd_time' => time(),
  288. ];
  289. Vendor::where('id', $data['id'])->update($vendorData);
  290. DB::commit();
  291. } catch (\Throwable $exception) {
  292. DB::rollBack();
  293. return [false, "编辑供应商失败: " . $exception->getMessage()];
  294. }
  295. return [true, ''];
  296. }
  297. public function vendorRule(&$data, $user, $is_add = true){
  298. if(! $is_add && empty($data['id'])) return [false, 'ID不能为空'];
  299. $id = $data['id'] ?? 0;
  300. $code = $data['code'] ?? "";
  301. if(empty($data['title'])) return [false, '供应商全称不能为空'];
  302. $title = $data['title'];
  303. if(empty($data['easy_title'])) return [false, '供应商简称不能为空'];
  304. $easy_title = $data['easy_title'];
  305. if(empty($data['category_code'])) return [false, '供应商分类编码不能为空'];
  306. $category_code = $data['category_code'];
  307. if(empty($data['category_code_title'])) return [false, '供应商分类名不能为空'];
  308. $category_code_title = $data['category_code_title'];
  309. if(! empty($code)){
  310. $bool = Vendor::where('del_time', 0)
  311. ->when(! empty($id), function ($query) use($id){
  312. return $query->where('id', '<>', $id);
  313. })
  314. ->where('code', $code)
  315. ->exists();
  316. if($bool) return [false, '供应商编码已存在记录,新增失败'];
  317. }
  318. if(! $is_add){
  319. $order = Vendor::where('id', $data['id'])->first();
  320. if(empty($order)) return [false, '供应商信息不存在或已被删除'];
  321. $order = $order->toArray();
  322. list($status, $msg) = $this->checkState(U8State::type_five, $user, $order['order_number']);
  323. if(! $status) return [false, $msg];
  324. }
  325. return [true, ''];
  326. }
  327. public function vendorCommon($data, $user, $field = []){
  328. $type = U8State::type_five;
  329. $model = Vendor::from('vendor as v')
  330. ->leftJoin('u8_state as s', function ($join) use ($type, $user) {
  331. $join->on('v.order_number', '=', 's.order_number')
  332. ->where('s.type', '=', $type)
  333. ->where('s.login_type', '=', $user['login_type'])
  334. ->where('s.del_time', '=', 0);
  335. })
  336. ->where('v.del_time', 0)
  337. ->where('v.crt_id', $user['userid'])
  338. ->select('v.*', DB::raw('IFNULL(s.state, -1) as state'))
  339. ->orderby('v.id', 'desc');
  340. if (isset($data['state']) && $data['state'] !== '') {
  341. $state_filter = $data['state'];
  342. if ($state_filter == -1) {
  343. // 未发起审批:u8_states 表里没记录,s.id 就会是 NULL
  344. $model->whereNull('s.id');
  345. } else {
  346. // 0:待审核 1:通过 2:驳回
  347. $model->where('s.state', $state_filter);
  348. }
  349. }
  350. if(! empty($data['id'])) $model->where('v.id', $data['id']);
  351. if(! empty($data['crt_time'][0]) && ! empty($data['crt_time'][1])) {
  352. $return = $this->changeDateToTimeStampAboutRange($data['crt_time']);
  353. $model->where('v.crt_time', '>=', $return[0]);
  354. $model->where('v.crt_time', '<=', $return[1]);
  355. }
  356. return $model;
  357. }
  358. public function vendorList($data, $user){
  359. $model = $this->vendorCommon($data, $user);
  360. $list = $this->limit($model,'',$data);
  361. $list = $this->fillVendorData($list,$user);
  362. return [true, $list];
  363. }
  364. public function fillVendorData($data, $user){
  365. if(empty($data['data'])) return $data;
  366. $e_map = DDEmployee::whereIn('userid', array_unique(array_column($data['data'], 'crt_id')))
  367. ->where('login_type', $user['login_type'])
  368. ->pluck('name', 'userid')
  369. ->toArray();
  370. foreach ($data['data'] as $key => $value){
  371. $data['data'][$key]['crt_name'] = $e_map[$value['crt_id']] ?? "";
  372. $data['data'][$key]['crt_time'] = $value['crt_time'] ? date('Y-m-d H:i:s',$value['crt_time']) : '';
  373. $data['data'][$key]['state_title'] = Record::state_name[$value['state']];
  374. }
  375. return $data;
  376. }
  377. public function vendorDetail($data, $user){
  378. if(empty($data['id'])) return [false, 'ID不能为空'];
  379. list($status, $msg) = $this->vendorList($data, $user);
  380. $return = $msg['data'][0] ?? [];
  381. return [true, $return];
  382. }
  383. public function vendorDel($data, $user){
  384. if($this->isEmpty($data,'id')) return [false,'请选择数据!'];
  385. try {
  386. DB::beginTransaction();
  387. $time = time();
  388. $order = Vendor::where('id', $data['id'])->first();
  389. if(empty($order)) return [false, '供应商信息不存在或已被删除'];
  390. $order = $order->toArray();
  391. list($status, $msg) = $this->checkState(U8State::type_five, $user, $order['order_number']);
  392. if(! $status) return [false, $msg];
  393. Vendor::where('del_time',0)
  394. ->where('id',$data['id'])
  395. ->update(['del_time' => $time]);
  396. DB::commit();
  397. }catch (\Exception $exception){
  398. DB::rollBack();
  399. return [false,$exception->getMessage()];
  400. }
  401. return [true, ''];
  402. }
  403. public function filedCommon($data, $user, $field = []){
  404. $model = FieldData::select([
  405. 'userid',
  406. 'type',
  407. // 使用 GROUP_CONCAT 将 title 合并,并起别名为 titles
  408. DB::raw('GROUP_CONCAT(title SEPARATOR ",") as titles')
  409. ])
  410. ->where('login_type', $user['login_type'])
  411. ->groupBy('userid', 'type')
  412. ->orderBy('type', 'desc'); // 或者根据你的需求排序
  413. return $model;
  414. }
  415. public function fieldList($data, $user){
  416. $model = $this->filedCommon($data, $user);
  417. $list = $this->limit($model,'',$data);
  418. $list = $this->fillFieldData($list,$user);
  419. return [true, $list];
  420. }
  421. public function fillFieldData($data, $user){
  422. if(empty($data['data'])) return $data;
  423. $map = DDEmployee::whereIn('userid', array_unique(array_column($data['data'],'userid')))
  424. ->pluck('name', 'userid')
  425. ->toArray();
  426. foreach ($data['data'] as $key => $value){
  427. $data['data'][$key]['crt_time'] = $value['crt_time'] ? date('Y-m-d H:i:s',$value['crt_time']) : '';
  428. $data['data'][$key]['user_title'] = $map[$value['userid']] ?? '';
  429. $data['data'][$key]['type_title'] = FieldData::$name[$value['type']] ?? '';
  430. }
  431. return $data;
  432. }
  433. public function fieldDetail($data, $user){
  434. if(! isset($data['type'])) return [false, 'type不能为空'];
  435. if(! isset($data['userid'])) return [false, '人员id不能为空'];
  436. return [true, FieldData::where('type', $data['type'])
  437. ->where('login_type', $user['login_type'])
  438. ->where('userid', $data['userid'])
  439. ->get()->toArray()];
  440. }
  441. public function setField($data, $user){
  442. if(empty($user['qx'])) return [false, '权限不足,设置失败'];
  443. if(empty($data['userid'])) return [false, '人员ID不能为空'];
  444. if(! isset($data['field'])) return [false, '字段列不存在'];
  445. $insert = [];
  446. foreach ($data['field'] as $value){
  447. $insert[] = [
  448. 'userid' => $data['userid'],
  449. 'key' => $value['key'],
  450. 'title' => $value['title'],
  451. 'login_type' => $user['login_type']
  452. ];
  453. }
  454. try {
  455. FieldData::where('userid', $data['userid'])->where('login_type', $user['login_type'])->delete();
  456. if(! empty($insert)) FieldData::insert($insert);
  457. } catch (\Throwable $exception) {
  458. return [false, "异常: " . $exception->getMessage()];
  459. }
  460. return [true, ''];
  461. }
  462. public function ddEmployeeList($data, $user){
  463. $model = $this->ddEmployeeCommon($data, $user);
  464. $list = $this->limit($model,'',$data);
  465. $list = $this->fillDDEmployeeData($list,$user);
  466. return [true, $list];
  467. }
  468. public function ddEmployeeCommon($data,$user, $field = []){
  469. $model = DDEmployee::where('del_time',0)
  470. ->where('login_type', $user['login_type'])
  471. ->orderby('id', 'desc');
  472. if(! empty($data['id'])) $model->where('id', $data['id']);
  473. if(! empty($data['crt_time'][0]) && ! empty($data['crt_time'][1])) {
  474. $return = $this->changeDateToTimeStampAboutRange($data['crt_time']);
  475. $model->where('crt_time','>=',$return[0]);
  476. $model->where('crt_time','<=',$return[1]);
  477. }
  478. return $model;
  479. }
  480. public function fillDDEmployeeData($data, $user){
  481. if(empty($data['data'])) return $data;
  482. foreach ($data['data'] as $key => $value){
  483. $data['data'][$key]['crt_time'] = $value['crt_time'] ? date('Y-m-d H:i:s',$value['crt_time']) : '';
  484. }
  485. return $data;
  486. }
  487. //新增供应商到本地-----------------------------------------------
  488. //U8 存货库存列表
  489. public function stockList($data, $user)
  490. {
  491. try {
  492. $field_list = [];
  493. $employee = DDEmployee::where('userid', $user['userid'])->where('login_type', $user['login_type'])->first();
  494. $qx = $employee['qx'] ?? 0;
  495. if(empty($qx)) {
  496. $field_list = FieldData::where('userid', $user['userid'])
  497. ->where('login_type', $user['login_type'])
  498. ->where('type', FieldData::STATE_ZERO)
  499. ->pluck('key')
  500. ->all();
  501. }
  502. // 1. 构建基础查询:关联现存量表和存货档案表
  503. $query = DB::connection('sqlsrv')
  504. ->table('CurrentStock as S')
  505. ->select([
  506. 'S.cWhCode', // 仓库编码
  507. 'W.cWhName', // 仓库名称
  508. 'S.cInvCode', // 存货编码
  509. 'I.cInvName', // 存货名称
  510. 'I.cInvStd', // 规格型号
  511. 'I.cInvCCode', // 分类编码
  512. // --- 数量字段对齐你的结构 ---
  513. 'S.iQuantity', // 结存数量 (账面现存量)
  514. 'S.fAvaQuantity', // 可用数量
  515. 'S.fOutQuantity', // 待发货数量 (待出)
  516. 'S.fInQuantity', // 待入库数量 (待入)
  517. 'S.fStopQuantity', // 冻结数量
  518. // --- 批次与日期 ---
  519. 'S.cBatch', // 批号
  520. 'S.dMdate', // 生产日期
  521. 'S.dVDate', // 失效日期
  522. ])
  523. ->join('Inventory as I', 'S.cInvCode', '=', 'I.cInvCode')
  524. ->leftJoin('Warehouse as W', 'S.cWhCode', '=', 'W.cWhCode')
  525. ->leftJoin('InventoryClass as IC', 'I.cInvCCode', '=', 'IC.cInvCCode');
  526. // 2. 过滤条件:存货名称 (支持模糊查询)
  527. if (!empty($data['material_title'])) {
  528. $query->where('I.cInvName', 'like', '%' . $data['material_title'] . '%');
  529. }
  530. // 2. 过滤条件:存货编码 (支持模糊查询)
  531. if (!empty($data['material_code'])) {
  532. $query->where('S.cInvCode', 'like', '%' . $data['material_code'] . '%');
  533. }
  534. // 3. 过滤条件:存货分类 (支持左匹配,即选大类查出所有子类)
  535. if (!empty($data['category_code'])) {
  536. // U8 分类是级次结构,用 like '01%' 可以查出 01 开头的所有子类
  537. $query->where('I.cInvCCode', 'like', $data['category_code'] . '%');
  538. }
  539. // 6. 排序
  540. $query->orderBy('S.cInvCode', 'asc')->orderBy('S.cWhCode', 'asc');
  541. // 7. 调用你定义的分页方法
  542. $columns = ['*'];
  543. $result = $this->limit($query, $columns, $data);
  544. // 注意这里的 &$item,加了 & 符号才能直接修改原数组里的内容
  545. foreach ($result['data'] as &$item) {
  546. $numFields = ['iQuantity', 'fAvaQuantity', 'fOutQuantity', 'fInQuantity', 'fStopQuantity'];
  547. foreach ($numFields as $field) {
  548. if (isset($item->$field)) {
  549. $item->$field = (float)$item->$field;
  550. }
  551. }
  552. $item->dMdate = $item->dMdate ? date('Y-m-d', strtotime($item->dMdate)) : '';
  553. $item->dVDate = $item->dVDate ? date('Y-m-d', strtotime($item->dVDate)) : '';
  554. // 脱敏处理
  555. if (!empty($field_list)) {
  556. foreach ($field_list as $blackField) {
  557. if (isset($item->$blackField)) {
  558. $item->$blackField = '*****';
  559. }
  560. }
  561. }
  562. }
  563. unset($item); // 销毁引用
  564. return [true, $result];
  565. } catch (\Throwable $exception) {
  566. return [false, "查询库存失败: " . $exception->getMessage()];
  567. }
  568. }
  569. //U8 供应商列表
  570. public function vendorU8List($data, $user)
  571. {
  572. // 1. 构建基础查询
  573. $query = DB::connection('sqlsrv')
  574. ->table('Vendor as V')
  575. ->select([
  576. 'V.cVenCode', // 供应商编码
  577. 'V.cVenName', // 供应商名称
  578. 'V.cVenAbbName', // 供应商简称
  579. 'V.cVCCode', // 分类编码
  580. 'VC.cVCName', // 分类名称 (来自 VendorClass)
  581. 'V.cVenAddress', // 地址
  582. 'V.cVenPhone', // 电话
  583. 'V.dVenDevDate', // 发展日期
  584. 'V.cCreatePerson', // 创建人
  585. 'V.bVenTax', // 是否计税
  586. 'V.iId' // 内部ID
  587. ])
  588. // 关联供应商分类表获取分类名称
  589. ->leftJoin('VendorClass as VC', 'V.cVCCode', '=', 'VC.cVCCode');
  590. // 2. 增加搜索逻辑 (可选)
  591. if (!empty($data['keyword'])) {
  592. $keyword = $data['keyword'];
  593. $query->where(function($q) use ($keyword) {
  594. $q->where('V.cVenCode', 'like', "%{$keyword}%")
  595. ->orWhere('V.cVenName', 'like', "%{$keyword}%")
  596. ->orWhere('V.cVenAbbName', 'like', "%{$keyword}%");
  597. });
  598. }
  599. // 3. 排序 (默认按编码排序)
  600. $query->orderBy('V.cVenCode', 'ASC');
  601. // 4. 调用你定义的分页方法
  602. // 注意:limit 方法内部会执行 paginate 并将结果填充到 $data
  603. $columns = ['*']; // select 已经在上面定义过了,这里传 * 即可
  604. $result = $this->limit($query, $columns, $data);
  605. return [true, $result];
  606. }
  607. // U8 供应商分类树结构
  608. public function vendorClassTree($data, $user)
  609. {
  610. try {
  611. // 1. 获取所有供应商分类 (表名: VendorClass)
  612. $classes = DB::connection('sqlsrv')
  613. ->table('VendorClass')
  614. ->select('cVCCode', 'cVCName', 'iVCGrade', 'bVCEnd') // 编码、名称、级次
  615. ->orderBy('cVCCode', 'asc')
  616. ->get();
  617. if ($classes->isEmpty()) {
  618. return [true, []];
  619. }
  620. // 2. 格式化数据,以编码为 Key
  621. $classList = [];
  622. foreach ($classes as $item) {
  623. $classList[$item->cVCCode] = [
  624. 'label' => $item->cVCName,
  625. 'value' => $item->cVCCode, // 前端通常需要 value 字段
  626. 'code' => $item->cVCCode,
  627. 'grade' => $item->iVCGrade,
  628. 'is_end' => $item->bVCEnd,
  629. 'children' => []
  630. ];
  631. }
  632. // 3. 构建引用树
  633. $tree = [];
  634. foreach ($classList as $code => &$node) {
  635. // 获取父级编码
  636. $parentCode = $this->getParentCode($code);
  637. if ($parentCode === null || !isset($classList[$parentCode])) {
  638. // 顶级节点
  639. $tree[] = &$node;
  640. } else {
  641. // 挂载到父节点
  642. $classList[$parentCode]['children'][] = &$node;
  643. }
  644. }
  645. return [true, $tree];
  646. } catch (\Throwable $exception) {
  647. return [false, "获取供应商分类树失败: " . $exception->getMessage()];
  648. }
  649. }
  650. //U8 存货分类树结构
  651. public function inventoryClassTree($data, $user)
  652. {
  653. try {
  654. // 1. 从数据库获取所有存货分类
  655. $classes = DB::connection('sqlsrv')
  656. ->table('InventoryClass')
  657. ->select('cInvCCode', 'cInvCName', 'iInvCGrade', 'bInvCEnd')
  658. ->orderBy('cInvCCode', 'asc')
  659. ->get();
  660. if ($classes->isEmpty()) return [true, []];
  661. // 2. 将集合转换为数组并以编码作为 Key,方便查找
  662. $classList = [];
  663. foreach ($classes as $item) {
  664. $classList[$item->cInvCCode] = [
  665. 'label' => $item->cInvCName,
  666. 'code' => $item->cInvCCode,
  667. 'grade' => $item->iInvCGrade,
  668. 'is_end' => $item->bInvCEnd,
  669. 'children' => []
  670. ];
  671. }
  672. // 3. 构建树形结构
  673. $tree = [];
  674. foreach ($classList as $code => &$node) {
  675. // 获取当前分类的级次 (U8 逻辑通常根据编码长度判断父级)
  676. // 比如 0101 的父级是 01
  677. $parentCode = $this->getParentCode($code);
  678. if ($parentCode === null || !isset($classList[$parentCode])) {
  679. // 如果没有父级编码,或者父级编码不在列表里,说明是顶级分类
  680. $tree[] = &$node;
  681. } else {
  682. // 将当前节点引用到父节点的 children 数组中
  683. $classList[$parentCode]['children'][] = &$node;
  684. }
  685. }
  686. return [true, $tree];
  687. } catch (\Throwable $exception) {
  688. return [false, "获取分类树失败: " . $exception->getMessage()];
  689. }
  690. }
  691. /**
  692. * 辅助函数:根据 U8 编码规则获取父级编码
  693. * U8 的级次通常存储在 GradeDef 表,但通用逻辑是截取末尾
  694. */
  695. private function getParentCode($code)
  696. {
  697. $len = strlen($code);
  698. if ($len <= 2) return null; // 假设第一级是2位,小于等于2位则无父级
  699. // 这里假设级次是 2-2-2-2 (最常见配置)
  700. // 实际生产中,如果级次不固定,建议查询 GradeDef 表
  701. return substr($code, 0, $len - 2);
  702. }
  703. //U8 计量单位组(带默认主计量单位)
  704. public function getUnitGroups($data, $user)
  705. {
  706. $list = DB::connection('sqlsrv')
  707. ->select("
  708. SELECT
  709. G.cGroupCode,
  710. G.cGroupName,
  711. G.iGroupType,
  712. U.cComUnitCode,
  713. U.cComUnitName,
  714. U.iNumber
  715. FROM ComputationGroup AS G
  716. OUTER APPLY (
  717. SELECT TOP 1 cComUnitCode, cComUnitName, iNumber
  718. FROM ComputationUnit
  719. WHERE cGroupCode = G.cGroupCode
  720. ORDER BY
  721. bMainUnit DESC, -- 1. 优先主计量
  722. iNumber ASC, -- 2. 序号最小 (若 NULL 会排在最前)
  723. cComUnitCode ASC -- 3. 编码最小
  724. ) AS U
  725. ");
  726. return [true, $list];
  727. }
  728. //U8 计量单位档案
  729. public function getComputationUnitList($data, $user)
  730. {
  731. $list = DB::connection('sqlsrv')
  732. ->table('ComputationUnit as U')
  733. ->select(
  734. 'U.cComUnitCode', // 单位编码
  735. 'U.cComUnitName', // 单位名称
  736. 'U.cGroupCode', // 所属组编码
  737. 'U.bMainUnit', // 是否主单位
  738. 'U.iNumber' // 排序序号
  739. )
  740. ->orderBy('U.cGroupCode', 'ASC')
  741. ->orderBy('U.iNumber', 'ASC') // 按照你要求的 iNumber 排序
  742. ->get();
  743. return [true, $list];
  744. }
  745. }