ExportFileService.php 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542
  1. <?php
  2. namespace App\Service;
  3. use App\Exports\ExportOrder;
  4. use App\Model\Freight;
  5. use App\Model\GiveOut;
  6. use App\Model\Product;
  7. use App\Model\RevenueCost;
  8. use App\Model\RevenueCostTotal;
  9. use App\Model\SalaryEmployee;
  10. use Illuminate\Support\Facades\DB;
  11. use Maatwebsite\Excel\Facades\Excel;
  12. class ExportFileService extends Service
  13. {
  14. public static $filename = "";
  15. //导出的方式 0 选择导出的数据 1 查询后 导出指定的数据(最多每次一千条)
  16. public static $export_type = [
  17. 0,
  18. 1
  19. ];
  20. public function exportAll($data,$user){
  21. if(empty($data['e_menu_id'])) return [false, '菜单ID不能为空'];
  22. list($function, $name) = EmployeeService::fillMenu2($data['e_menu_id'], $user);
  23. if (empty($function) || ! method_exists(self::class, $function)) return [false, "导出方法不存在,请联系开发"];
  24. self::$filename = $name;
  25. $export_type = $data['export_type'] ?? 0;
  26. if(! isset(self::$export_type[$export_type])) return [false,'导出文件方式错误或者不存在'];
  27. if(empty($export_type)){
  28. if(empty($data['id'])) return [false,'请选择导出数据'];
  29. }else{
  30. $search_func = $function . "Search";
  31. if (! method_exists(self::class, $search_func)) return [false, "导出方法(子方法)不存在,请联系开发"];
  32. if(empty($data['order_search'])) return [false,'搜索条件不能为空'];
  33. $search = $data['order_search'];
  34. if(empty($search['page_index'])) return [false,'请选择导出数据的开始页码'];
  35. if(empty($search['page_size'])) return [false,'请选择导出数据的条数'];
  36. if($search['page_size'] > 5000) return [false,'请选择导出数据的条数每次最多5000条'];
  37. list($status,$id) = $this->$search_func($data, $user);
  38. if(! $status) return [false, $id];
  39. $data['id'] = $id;
  40. }
  41. $return = $this->$function($data,$user);
  42. return [true, $return];
  43. }
  44. // private function fillData($data, $column, &$return){
  45. // foreach ($data as $value) {
  46. // $tmp = [];
  47. // foreach ($column as $c_v){
  48. // $tmp[$c_v] = $value[$c_v] ?? "";
  49. // }
  50. // $return[] = $tmp;
  51. // }
  52. // }
  53. private function fillData($data, $column, &$return)
  54. {
  55. // 预先创建包含默认值的键数组
  56. $default = array_fill_keys($column, '');
  57. foreach ($data as $value) {
  58. // 提取交集,并用默认值补充缺失的键
  59. $return[] = array_merge($default, array_intersect_key($value, $default));
  60. }
  61. }
  62. private function fillTotalData($data, $column, &$return){
  63. $tmp = [];
  64. foreach ($column as $value){
  65. $key = $value['key'];
  66. if(! empty($value['sum']) && isset($data[$value['key']])){
  67. $decimals = $col['decimals'] ?? 2;
  68. // $tmp[$value['key']] = $data[$value['key']];
  69. // 用 number_format 格式化输出(保持字符串形式,避免科学计数)
  70. $tmp[$key] = number_format((float)$data[$key], $decimals, '.', '');
  71. }else{
  72. $tmp[$value['key']] = "";
  73. }
  74. }
  75. $return[] = $tmp;
  76. }
  77. public function one($ergs, $user){
  78. $id = $ergs['id'];
  79. // 导出数据
  80. $return = [];
  81. $header_default = $user['e_header_default'];
  82. $column = array_column($header_default,'key');
  83. $header = array_column($header_default,'value');
  84. DB::table('product')
  85. ->where('del_time',0)
  86. ->whereIn('id', $id)
  87. ->select(Product::$field)
  88. ->orderBy('id','desc')
  89. ->chunkById(500,function ($data) use(&$return,$column){
  90. $data = Collect($data)->map(function ($object) {
  91. return (array)$object;
  92. })->toArray();
  93. $this->fillData($data, $column, $return);
  94. });
  95. return $this->saveExportData($return,$header);
  96. }
  97. public function oneSearch($ergs, $user){
  98. $data = $ergs['order_search'];
  99. $service = new ProductService();
  100. $model = $service->productCommon($data, $user, ['id']);
  101. $return = $this->limitData($model,'',$data);
  102. $id = array_column($return,'id');
  103. return [true, $id];
  104. }
  105. public function two($ergs,$user){
  106. $id = $ergs['id'];
  107. // 导出数据
  108. $return = [];
  109. $header_default = $user['e_header_default'];
  110. $column = array_column($header_default,'key');
  111. $header = array_column($header_default,'value');
  112. DB::table('freight')
  113. ->where('del_time',0)
  114. ->whereIn('id', $id)
  115. ->select(Freight::$field)
  116. ->orderBy('id','desc')
  117. ->chunkById(500,function ($data) use(&$return,$column){
  118. $data = Collect($data)->map(function ($object) {
  119. return (array)$object;
  120. })->toArray();
  121. $this->fillData($data, $column, $return);
  122. });
  123. return $this->saveExportData($return,$header);
  124. }
  125. public function twoSearch($ergs, $user){
  126. $data = $ergs['order_search'];
  127. $service = new FreightService();
  128. $model = $service->freightCommon($data, $user, ['id']);
  129. $return = $this->limitData($model,'',$data);
  130. $id = array_column($return,'id');
  131. return [true, $id];
  132. }
  133. public function three($ergs,$user){
  134. $id = $ergs['id'];
  135. // 导出数据
  136. $return = [];
  137. $service = new StatisticsService();
  138. $header_default = $user['e_header_default'];
  139. $column = array_column($header_default,'key');
  140. $header = array_column($header_default,'value');
  141. DB::table('revenue_cost_total')
  142. ->where('del_time',0)
  143. ->whereIn('id', $id)
  144. ->select(RevenueCostTotal::$field)
  145. ->orderBy('id','desc')
  146. ->chunkById(500,function ($data) use(&$return, $service, $column){
  147. $data = Collect($data)->map(function ($object) {
  148. return (array)$object;
  149. })->toArray();
  150. $list['data'] = $data;
  151. //订单数据
  152. $list = $service->statisticsRevenueCostFillData($list);
  153. //返回数据
  154. $this->fillData($list['data'], $column, $return);
  155. });
  156. //合计
  157. $total = $this->countTotal($return, $header_default);
  158. //填充合计
  159. $this->fillTotalData($total, $header_default, $return);
  160. return $this->saveExportData($return,$header);
  161. }
  162. public function threeSearch($ergs, $user){
  163. $data = $ergs['order_search'];
  164. $service = new StatisticsService();
  165. list($status, $model) = $service->statisticsRevenueCostCommon($data, $user, ['id']);
  166. if(! $status) return [false, $model];
  167. $return = $this->limitData($model,'',$data);
  168. $id = array_column($return,'id');
  169. return [true, $id];
  170. }
  171. public function four($ergs,$user){
  172. $id = $ergs['id'];
  173. // 导出数据
  174. $return = [];
  175. $service = new StatisticsService();
  176. $header_default = $user['e_header_default'];
  177. $column = array_column($header_default,'key');
  178. $header = array_column($header_default,'value');
  179. DB::table('revenue_cost')
  180. ->where('del_time',0)
  181. ->whereIn('id', $id)
  182. ->select(RevenueCost::$field_xhd)
  183. ->orderBy('id','desc')
  184. ->chunkById(500,function ($data) use(&$return, $column, $service){
  185. $data = Collect($data)->map(function ($object) {
  186. return (array)$object;
  187. })->toArray();
  188. $list['data'] = $data;
  189. //订单数据
  190. $list = $service->statisticsRevenueCostOneAndTwoFillData($list);
  191. $this->fillData($list['data'], $column, $return);
  192. });
  193. //合计
  194. $total = $this->countTotal($return, $header_default);
  195. //填充合计
  196. $this->fillTotalData($total, $header_default, $return);
  197. return $this->saveExportData($return,$header);
  198. }
  199. public function fourSearch($ergs, $user){
  200. $data = $ergs['order_search'];
  201. $data['order_type'] = RevenueCost::ORDER_ONE;
  202. $service = new StatisticsService();
  203. list($status, $model) = $service->statisticsRevenueCostOneAndTwoCommon($data, $user, ['id']);
  204. if(! $status) return [false, $model];
  205. $return = $this->limitData($model,'',$data);
  206. $id = array_column($return,'id');
  207. return [true, $id];
  208. }
  209. public function five($ergs,$user){
  210. $id = $ergs['id'];
  211. // 导出数据
  212. $return = [];
  213. $service = new StatisticsService();
  214. $header_default = $user['e_header_default'];
  215. $column = array_column($header_default,'key');
  216. $header = array_column($header_default,'value');
  217. DB::table('revenue_cost')
  218. ->where('del_time',0)
  219. ->whereIn('id', $id)
  220. ->select(RevenueCost::$field_xsfp)
  221. ->orderBy('id','desc')
  222. ->chunkById(500,function ($data) use(&$return, $column, $service){
  223. $data = Collect($data)->map(function ($object) {
  224. return (array)$object;
  225. })->toArray();
  226. $list['data'] = $data;
  227. //订单数据
  228. $list = $service->statisticsRevenueCostOneAndTwoFillData($list);
  229. $this->fillData($list['data'], $column, $return);
  230. });
  231. //合计
  232. $total = $this->countTotal($return, $header_default);
  233. //填充合计
  234. $this->fillTotalData($total, $header_default, $return);
  235. return $this->saveExportData($return,$header);
  236. }
  237. public function fiveSearch($ergs, $user){
  238. $data = $ergs['order_search'];
  239. $data['order_type'] = RevenueCost::ORDER_TWO;
  240. $service = new StatisticsService();
  241. list($status, $model) = $service->statisticsRevenueCostOneAndTwoCommon($data, $user, ['id']);
  242. if(! $status) return [false, $model];
  243. $return = $this->limitData($model,'',$data);
  244. $id = array_column($return,'id');
  245. return [true, $id];
  246. }
  247. public function six($ergs,$user){
  248. $id = $ergs['id'];
  249. $field = RevenueCost::$field_hkd_main;
  250. $field[] = DB::raw('sum(payment_amount) as payment_amount');
  251. $field[] = DB::raw('sum(price_4_total) as price_4_total');
  252. $field[] = DB::raw('sum(profit) as profit');
  253. // 导出数据
  254. $return = [];
  255. $service = new StatisticsService();
  256. $header_default = $user['e_header_default'];
  257. $column = array_column($header_default,'key');
  258. $header = array_column($header_default,'value');
  259. DB::table('revenue_cost')
  260. ->where('del_time',0)
  261. ->whereIn('order_id', $id)
  262. ->where('order_type',RevenueCost::ORDER_THREE)
  263. ->select($field)
  264. ->groupby('order_id')
  265. ->orderBy('id','desc')
  266. ->chunkById(500,function ($data) use(&$return, $column, $service){
  267. $data = Collect($data)->map(function ($object) {
  268. return (array)$object;
  269. })->toArray();
  270. $list['data'] = $data;
  271. //订单数据
  272. $list = $service->statisticsRevenueCostThreeFillData($list);
  273. $this->fillData($list['data'], $column, $return);
  274. },'order_id');
  275. //合计
  276. $total = $this->countTotal($return, $header_default);
  277. //填充合计
  278. $this->fillTotalData($total, $header_default, $return);
  279. return $this->saveExportData($return,$header);
  280. }
  281. public function sixSearch($ergs, $user){
  282. $data = $ergs['order_search'];
  283. $service = new StatisticsService();
  284. list($status, $model) = $service->statisticsRevenueCostThreeCommon($data, $user, ['order_id']);
  285. if(! $status) return [false, $model];
  286. $return = $this->limitData($model,'',$data);
  287. $id = array_column($return,'order_id');
  288. return [true, $id];
  289. }
  290. public function seven($ergs,$user){
  291. $id = $ergs['id'];
  292. // 导出数据
  293. $return = [];
  294. $header_default = $user['e_header_default'];
  295. $column = array_column($header_default,'key');
  296. $header = array_column($header_default,'value');
  297. DB::table('give_out')
  298. ->where('del_time',0)
  299. ->whereIn('id', $id)
  300. ->select(GiveOut::$field)
  301. ->orderBy('id','desc')
  302. ->chunkById(500,function ($data) use(&$return, $column){
  303. $data = Collect($data)->map(function ($object) {
  304. return (array)$object;
  305. })->toArray();
  306. $list['data'] = $data;
  307. //订单数据
  308. $service = new GiveOutService();
  309. $list = $service->fillData($list);
  310. $this->fillData($list['data'], $column, $return);
  311. });
  312. return $this->saveExportData($return,$header);
  313. }
  314. public function sevenSearch($ergs, $user){
  315. $data = $ergs['order_search'];
  316. $service = new GiveOutService();
  317. $model = $service->giveOutCommon($data, $user, ['id']);
  318. $return = $this->limitData($model,'',$data);
  319. $id = array_column($return,'id');
  320. return [true, $id];
  321. }
  322. public function eight($ergs,$user){
  323. $id = $ergs['id'];
  324. $field = RevenueCost::$field_hkd_profit_main;
  325. $field[] = DB::raw('COALESCE(SUM(rc.payment_amount), 0) AS payment_amount');
  326. $type = RevenueCost::ORDER_THREE;
  327. $return = [];
  328. $header_default = $user['e_header_default'];
  329. $column = array_column($header_default, 'key');
  330. $header = array_column($header_default, 'value');
  331. DB::table('employee_index')
  332. ->where('employee_index.del_time', 0)
  333. ->whereIn('employee_index.id', $id)
  334. ->leftJoin(DB::raw('revenue_cost as rc'), function ($join) use ($type) {
  335. $join->on('rc.employee_id_2', '=', 'employee_index.employee_id')
  336. ->where('rc.del_time', 0)
  337. ->where('rc.order_type', $type)
  338. ->whereRaw('rc.order_time >= employee_index.start_time')
  339. ->whereRaw('rc.order_time <= employee_index.end_time');
  340. })
  341. ->select($field)
  342. ->groupBy('employee_index.employee_id', 'employee_index.start_time', 'employee_index.end_time')
  343. ->orderBy('employee_index.end_time','desc')
  344. ->chunkById(500, function ($data) use (&$return, $column) {
  345. $data = Collect($data)->map(function ($object) {
  346. return (array)$object;
  347. })->toArray();
  348. $list['data'] = $data;
  349. //订单数据
  350. $service = new StatisticsService();
  351. $list = $service->statisticsProfitFillData($list);
  352. $this->fillData($list['data'], $column, $return);
  353. });
  354. return $this->saveExportData($return,$header);
  355. }
  356. public function eightSearch($ergs, $user){
  357. $data = $ergs['order_search'];
  358. $service = new StatisticsService();
  359. list($status,$model) = $service->statisticsProfitCommon($data, $user, ['employee_index.id']);
  360. if(! $status) return [false, $model];
  361. $return = $this->limitData($model,'',$data);
  362. $id = array_column($return,'id');
  363. return [true, $id];
  364. }
  365. public function nine($ergs,$user){
  366. $id = $ergs['id'];
  367. $field = SalaryEmployee::$field;
  368. $return = [];
  369. $header_default = $user['e_header_default'];
  370. $column = array_column($header_default, 'key');
  371. $header = array_column($header_default, 'value');
  372. DB::table('salary_employee')
  373. ->where('del_time', 0)
  374. ->whereIn('id', $id)
  375. ->select($field)
  376. ->orderBy('order_time','desc')
  377. ->chunkById(500, function ($data) use (&$return, $column) {
  378. $data = Collect($data)->map(function ($object) {
  379. return (array)$object;
  380. })->toArray();
  381. $list['data'] = $data;
  382. //订单数据
  383. $service = new StatisticsService();
  384. $list = $service->statisticsEmployeeSalaryFillData($list);
  385. $this->fillData($list['data'], $column, $return);
  386. });
  387. return $this->saveExportData($return,$header);
  388. }
  389. public function nineSearch($ergs, $user){
  390. $data = $ergs['order_search'];
  391. $service = new StatisticsService();
  392. list($status,$model) = $service->statisticsEmployeeSalaryCommon($data, $user, ['id']);
  393. if(! $status) return [false, $model];
  394. $return = $this->limitData($model,'',$data);
  395. $id = array_column($return,'id');
  396. return [true, $id];
  397. }
  398. public function getListForSearch($ergs, $user){
  399. $data = $ergs['order_search'];
  400. $id = [];
  401. if($ergs['type'] == self::type_one){
  402. $service = new ProductService();
  403. $model = $service->productCommon($data, $user, ['id']);
  404. $return = $this->limitData($model,'',$data);
  405. $id = array_column($return,'id');
  406. }elseif ($ergs['type'] == self::type_two){
  407. $service = new FreightService();
  408. $model = $service->freightCommon($data, $user, ['id']);
  409. $return = $this->limitData($model,'',$data);
  410. $id = array_column($return,'id');
  411. }elseif ($ergs['type'] == self::type_three){
  412. $service = new StatisticsService();
  413. list($status, $model) = $service->statisticsRevenueCostCommon($data, $user, ['id']);
  414. if(! $status) return [false, $model];
  415. $return = $this->limitData($model,'',$data);
  416. $id = array_column($return,'id');
  417. }elseif ($ergs['type'] == self::type_four || $ergs['type'] == self::type_five){
  418. if(empty($data['order_type'])){
  419. if($ergs['type'] == self::type_four){
  420. $data['order_type'] = RevenueCost::ORDER_ONE;
  421. }else{
  422. $data['order_type'] = RevenueCost::ORDER_TWO;
  423. }
  424. }
  425. $service = new StatisticsService();
  426. list($status, $model) = $service->statisticsRevenueCostOneAndTwoCommon($data, $user, ['id']);
  427. if(! $status) return [false, $model];
  428. $return = $this->limitData($model,'',$data);
  429. $id = array_column($return,'id');
  430. }elseif ($ergs['type'] == self::type_six){
  431. $service = new StatisticsService();
  432. list($status, $model) = $service->statisticsRevenueCostThreeCommon($data, $user, ['order_id']);
  433. if(! $status) return [false, $model];
  434. $return = $this->limitData($model,'',$data);
  435. $id = array_column($return,'order_id');
  436. }elseif ($ergs['type'] == self::type_seven){
  437. $service = new GiveOutService();
  438. $model = $service->giveOutCommon($data, $user, ['id']);
  439. $return = $this->limitData($model,'',$data);
  440. $id = array_column($return,'id');
  441. }elseif ($ergs['type'] == self::type_eight){
  442. $service = new StatisticsService();
  443. list($status,$model) = $service->statisticsProfitCommon($data, $user, ['employee_index.id']);
  444. if(! $status) return [false, $model];
  445. $return = $this->limitData($model,'',$data);
  446. $id = array_column($return,'id');
  447. }
  448. return [true, $id];
  449. }
  450. public function saveExportData($data, $headers, $type = 'default',$file_name = ''){
  451. if(empty($file_name)) $file_name = self::$filename . "_". date("Y-m-d") . "_". rand(1000,9999);
  452. $filename = $file_name . '.' . 'xlsx';
  453. $bool = Excel::store(new ExportOrder($data,$type,$headers),"/public/export/{$filename}", null, 'Xlsx', []);
  454. return $filename;
  455. }
  456. }