ExportFileService.php 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484
  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['menu_id'])) return [false, '菜单ID不能为空'];
  22. list($function, $name) = EmployeeService::fillMenu2($data['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. $data['order_search']['menu_id'] = $data['menu_id'];
  38. list($status,$id) = $this->$search_func($data, $user);
  39. if(! $status) return [false, $id];
  40. $data['id'] = $id;
  41. }
  42. $return = $this->$function($data,$user);
  43. return [true, $return];
  44. }
  45. private function fillData($data, $column, &$return)
  46. {
  47. // 预先创建包含默认值的键数组
  48. $default = array_fill_keys($column, '');
  49. foreach ($data as $value) {
  50. // 提取交集,并用默认值补充缺失的键
  51. $return[] = array_merge($default, array_intersect_key($value, $default));
  52. }
  53. }
  54. private function fillTotalData($data, $column, &$return){
  55. $tmp = [];
  56. foreach ($column as $value){
  57. $key = $value['key'];
  58. if(! empty($value['sum']) && isset($data[$value['key']])){
  59. $decimals = $col['decimals'] ?? 2;
  60. // $tmp[$value['key']] = $data[$value['key']];
  61. // 用 number_format 格式化输出(保持字符串形式,避免科学计数)
  62. $tmp[$key] = number_format((float)$data[$key], $decimals, '.', '');
  63. }else{
  64. $tmp[$value['key']] = "";
  65. }
  66. }
  67. $return[] = $tmp;
  68. }
  69. public function one($ergs, $user){
  70. $id = $ergs['id'];
  71. // 导出数据
  72. $return = [];
  73. $header_default = $user['e_header_default'];
  74. $column = array_column($header_default,'key');
  75. $header = array_column($header_default,'value');
  76. DB::table('product')
  77. ->where('del_time',0)
  78. ->whereIn('id', $id)
  79. ->select(Product::$field)
  80. ->orderBy('id','desc')
  81. ->chunkById(500,function ($data) use(&$return,$column){
  82. $data = Collect($data)->map(function ($object) {
  83. return (array)$object;
  84. })->toArray();
  85. $this->fillData($data, $column, $return);
  86. });
  87. return $this->saveExportData($return,$header);
  88. }
  89. public function oneSearch($ergs, $user){
  90. $data = $ergs['order_search'];
  91. $service = new ProductService();
  92. $model = $service->productCommon($data, $user, ['id']);
  93. $return = $this->limitData($model,'',$data);
  94. $id = array_column($return,'id');
  95. return [true, $id];
  96. }
  97. public function two($ergs,$user){
  98. $id = $ergs['id'];
  99. // 导出数据
  100. $return = [];
  101. $header_default = $user['e_header_default'];
  102. $column = array_column($header_default,'key');
  103. $header = array_column($header_default,'value');
  104. DB::table('freight')
  105. ->where('del_time',0)
  106. ->whereIn('id', $id)
  107. ->select(Freight::$field)
  108. ->orderBy('id','desc')
  109. ->chunkById(500,function ($data) use(&$return,$column){
  110. $data = Collect($data)->map(function ($object) {
  111. return (array)$object;
  112. })->toArray();
  113. $this->fillData($data, $column, $return);
  114. });
  115. return $this->saveExportData($return,$header);
  116. }
  117. public function twoSearch($ergs, $user){
  118. $data = $ergs['order_search'];
  119. $service = new FreightService();
  120. $model = $service->freightCommon($data, $user, ['id']);
  121. $return = $this->limitData($model,'',$data);
  122. $id = array_column($return,'id');
  123. return [true, $id];
  124. }
  125. public function three($ergs,$user){
  126. $id = $ergs['id'];
  127. // 导出数据
  128. $return = [];
  129. $service = new StatisticsService();
  130. $header_default = $user['e_header_default'];
  131. $column = array_column($header_default,'key');
  132. $header = array_column($header_default,'value');
  133. DB::table('revenue_cost_total')
  134. ->where('del_time',0)
  135. ->whereIn('id', $id)
  136. ->select(RevenueCostTotal::$field)
  137. ->orderBy('id','desc')
  138. ->chunkById(500,function ($data) use(&$return, $service, $column){
  139. $data = Collect($data)->map(function ($object) {
  140. return (array)$object;
  141. })->toArray();
  142. $list['data'] = $data;
  143. //订单数据
  144. $list = $service->statisticsRevenueCostFillData($list);
  145. //返回数据
  146. $this->fillData($list['data'], $column, $return);
  147. });
  148. //合计
  149. $total = $this->countTotal($return, $header_default);
  150. //填充合计
  151. $this->fillTotalData($total, $header_default, $return);
  152. return $this->saveExportData($return,$header);
  153. }
  154. public function threeSearch($ergs, $user){
  155. $data = $ergs['order_search'];
  156. $service = new StatisticsService();
  157. list($status, $model) = $service->statisticsRevenueCostCommon($data, $user, ['id']);
  158. if(! $status) return [false, $model];
  159. $return = $this->limitData($model,'',$data);
  160. $id = array_column($return,'id');
  161. return [true, $id];
  162. }
  163. public function four($ergs,$user){
  164. $id = $ergs['id'];
  165. // 导出数据
  166. $return = [];
  167. $service = new StatisticsService();
  168. $header_default = $user['e_header_default'];
  169. $column = array_column($header_default,'key');
  170. $header = array_column($header_default,'value');
  171. DB::table('revenue_cost')
  172. ->where('del_time',0)
  173. ->whereIn('id', $id)
  174. ->select(RevenueCost::$field_xhd)
  175. ->orderBy('id','desc')
  176. ->chunkById(500,function ($data) use(&$return, $column, $service){
  177. $data = Collect($data)->map(function ($object) {
  178. return (array)$object;
  179. })->toArray();
  180. $list['data'] = $data;
  181. //订单数据
  182. $list = $service->statisticsRevenueCostOneAndTwoFillData($list);
  183. $this->fillData($list['data'], $column, $return);
  184. });
  185. //合计
  186. $total = $this->countTotal($return, $header_default);
  187. //填充合计
  188. $this->fillTotalData($total, $header_default, $return);
  189. return $this->saveExportData($return,$header);
  190. }
  191. public function fourSearch($ergs, $user){
  192. $data = $ergs['order_search'];
  193. $data['order_type'] = RevenueCost::ORDER_ONE;
  194. $service = new StatisticsService();
  195. list($status, $model) = $service->statisticsRevenueCostOneAndTwoCommon($data, $user, ['id']);
  196. if(! $status) return [false, $model];
  197. $return = $this->limitData($model,'',$data);
  198. $id = array_column($return,'id');
  199. return [true, $id];
  200. }
  201. public function five($ergs,$user){
  202. $id = $ergs['id'];
  203. // 导出数据
  204. $return = [];
  205. $service = new StatisticsService();
  206. $header_default = $user['e_header_default'];
  207. $column = array_column($header_default,'key');
  208. $header = array_column($header_default,'value');
  209. DB::table('revenue_cost')
  210. ->where('del_time',0)
  211. ->whereIn('id', $id)
  212. ->select(RevenueCost::$field_xsfp)
  213. ->orderBy('id','desc')
  214. ->chunkById(500,function ($data) use(&$return, $column, $service){
  215. $data = Collect($data)->map(function ($object) {
  216. return (array)$object;
  217. })->toArray();
  218. $list['data'] = $data;
  219. //订单数据
  220. $list = $service->statisticsRevenueCostOneAndTwoFillData($list);
  221. $this->fillData($list['data'], $column, $return);
  222. });
  223. //合计
  224. $total = $this->countTotal($return, $header_default);
  225. //填充合计
  226. $this->fillTotalData($total, $header_default, $return);
  227. return $this->saveExportData($return,$header);
  228. }
  229. public function fiveSearch($ergs, $user){
  230. $data = $ergs['order_search'];
  231. $data['order_type'] = RevenueCost::ORDER_TWO;
  232. $service = new StatisticsService();
  233. list($status, $model) = $service->statisticsRevenueCostOneAndTwoCommon($data, $user, ['id']);
  234. if(! $status) return [false, $model];
  235. $return = $this->limitData($model,'',$data);
  236. $id = array_column($return,'id');
  237. return [true, $id];
  238. }
  239. public function six($ergs,$user){
  240. $id = $ergs['id'];
  241. $field = RevenueCost::$field_hkd_main;
  242. $field[] = DB::raw('sum(payment_amount) as payment_amount');
  243. $field[] = DB::raw('sum(price_4_total) as price_4_total');
  244. $field[] = DB::raw('sum(profit) as profit');
  245. // 导出数据
  246. $return = [];
  247. $service = new StatisticsService();
  248. $header_default = $user['e_header_default'];
  249. $column = array_column($header_default,'key');
  250. $header = array_column($header_default,'value');
  251. DB::table('revenue_cost')
  252. ->where('del_time',0)
  253. ->whereIn('order_id', $id)
  254. ->where('order_type',RevenueCost::ORDER_THREE)
  255. ->select($field)
  256. ->groupby('order_id')
  257. ->orderBy('id','desc')
  258. ->chunkById(500,function ($data) use(&$return, $column, $service){
  259. $data = Collect($data)->map(function ($object) {
  260. return (array)$object;
  261. })->toArray();
  262. $list['data'] = $data;
  263. //订单数据
  264. $list = $service->statisticsRevenueCostThreeFillData($list);
  265. $this->fillData($list['data'], $column, $return);
  266. },'order_id');
  267. //合计
  268. $total = $this->countTotal($return, $header_default);
  269. //填充合计
  270. $this->fillTotalData($total, $header_default, $return);
  271. return $this->saveExportData($return,$header);
  272. }
  273. public function sixSearch($ergs, $user){
  274. $data = $ergs['order_search'];
  275. $service = new StatisticsService();
  276. list($status, $model) = $service->statisticsRevenueCostThreeCommon($data, $user, ['order_id']);
  277. if(! $status) return [false, $model];
  278. $return = $this->limitData($model,'',$data);
  279. $id = array_column($return,'order_id');
  280. return [true, $id];
  281. }
  282. public function seven($ergs,$user){
  283. $id = $ergs['id'];
  284. // 导出数据
  285. $return = [];
  286. $header_default = $user['e_header_default'];
  287. $column = array_column($header_default,'key');
  288. $header = array_column($header_default,'value');
  289. DB::table('give_out')
  290. ->where('del_time',0)
  291. ->whereIn('id', $id)
  292. ->select(GiveOut::$field)
  293. ->orderBy('id','desc')
  294. ->chunkById(500,function ($data) use(&$return, $column){
  295. $data = Collect($data)->map(function ($object) {
  296. return (array)$object;
  297. })->toArray();
  298. $list['data'] = $data;
  299. //订单数据
  300. $service = new GiveOutService();
  301. $list = $service->fillData($list);
  302. $this->fillData($list['data'], $column, $return);
  303. });
  304. //合计
  305. $total = $this->countTotal($return, $header_default);
  306. //填充合计
  307. $this->fillTotalData($total, $header_default, $return);
  308. return $this->saveExportData($return,$header);
  309. }
  310. public function sevenSearch($ergs, $user){
  311. $data = $ergs['order_search'];
  312. $service = new GiveOutService();
  313. $model = $service->giveOutCommon($data, $user, ['id']);
  314. $return = $this->limitData($model,'',$data);
  315. $id = array_column($return,'id');
  316. return [true, $id];
  317. }
  318. public function eight($ergs,$user){
  319. $id = $ergs['id'];
  320. $field = RevenueCost::$field_hkd_profit_main;
  321. $field[] = DB::raw('COALESCE(SUM(rc.payment_amount), 0) AS payment_amount');
  322. $type = RevenueCost::ORDER_THREE;
  323. $return = [];
  324. $header_default = $user['e_header_default'];
  325. $column = array_column($header_default, 'key');
  326. $header = array_column($header_default, 'value');
  327. DB::table('employee_index')
  328. ->where('employee_index.del_time', 0)
  329. ->whereIn('employee_index.id', $id)
  330. ->leftJoin(DB::raw('revenue_cost as rc'), function ($join) use ($type) {
  331. $join->on('rc.employee_id_2', '=', 'employee_index.employee_id')
  332. ->where('rc.del_time', 0)
  333. ->where('rc.order_type', $type)
  334. ->whereRaw('rc.order_time >= employee_index.start_time')
  335. ->whereRaw('rc.order_time <= employee_index.end_time');
  336. })
  337. ->select($field)
  338. ->groupBy('employee_index.employee_id', 'employee_index.start_time', 'employee_index.end_time')
  339. ->orderBy('employee_index.end_time','desc')
  340. ->chunkById(500, function ($data) use (&$return, $column) {
  341. $data = Collect($data)->map(function ($object) {
  342. return (array)$object;
  343. })->toArray();
  344. $list['data'] = $data;
  345. //订单数据
  346. $service = new StatisticsService();
  347. $list = $service->statisticsProfitFillData($list);
  348. $this->fillData($list['data'], $column, $return);
  349. });
  350. return $this->saveExportData($return,$header);
  351. }
  352. public function eightSearch($ergs, $user){
  353. $data = $ergs['order_search'];
  354. $service = new StatisticsService();
  355. list($status,$model) = $service->statisticsProfitCommon($data, $user, ['employee_index.id']);
  356. if(! $status) return [false, $model];
  357. $return = $this->limitData($model,'',$data);
  358. $id = array_column($return,'id');
  359. return [true, $id];
  360. }
  361. public function nine($ergs,$user){
  362. $id = $ergs['id'];
  363. $field = SalaryEmployee::$field;
  364. $return = [];
  365. $header_default = $user['e_header_default'];
  366. $column = array_column($header_default, 'key');
  367. $header = array_column($header_default, 'value');
  368. DB::table('salary_employee')
  369. ->where('del_time', 0)
  370. ->whereIn('id', $id)
  371. ->select($field)
  372. ->orderBy('order_time','desc')
  373. ->chunkById(500, function ($data) use (&$return, $column) {
  374. $data = Collect($data)->map(function ($object) {
  375. return (array)$object;
  376. })->toArray();
  377. $list['data'] = $data;
  378. //订单数据
  379. $service = new StatisticsService();
  380. $list = $service->statisticsEmployeeSalaryFillData($list);
  381. $this->fillData($list['data'], $column, $return);
  382. });
  383. return $this->saveExportData($return,$header);
  384. }
  385. public function nineSearch($ergs, $user){
  386. $data = $ergs['order_search'];
  387. $service = new StatisticsService();
  388. list($status,$model) = $service->statisticsEmployeeSalaryCommon($data, $user, ['id']);
  389. if(! $status) return [false, $model];
  390. $return = $this->limitData($model,'',$data);
  391. $id = array_column($return,'id');
  392. return [true, $id];
  393. }
  394. public function saveExportData($data, $headers, $type = 'default',$file_name = ''){
  395. if(empty($file_name)) $file_name = self::$filename . "_". date("Y-m-d") . "_". rand(1000,9999);
  396. $filename = $file_name . '.' . 'xlsx';
  397. $bool = Excel::store(new ExportOrder($data,$type,$headers),"/public/export/{$filename}", null, 'Xlsx', []);
  398. return $filename;
  399. }
  400. }