StoreImport.php 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2016~2024 https://www.crmeb.com All rights reserved.
  6. // +----------------------------------------------------------------------
  7. // | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
  8. // +----------------------------------------------------------------------
  9. // | Author: CRMEB Team <admin@crmeb.com>
  10. // +----------------------------------------------------------------------
  11. namespace app\controller\merchant\store;
  12. use app\common\repositories\store\ExcelRepository;
  13. use app\common\repositories\store\order\StoreImportDeliveryRepository;
  14. use app\common\repositories\store\order\StoreOrderRepository;
  15. use app\common\repositories\store\product\ProductCdkeyRepository;
  16. use app\validate\merchant\ProductCdkeyValidate;
  17. use crmeb\jobs\ImportSpreadsheetExcelJob;
  18. use crmeb\services\ExcelService;
  19. use crmeb\services\SpreadsheetExcelService;
  20. use crmeb\services\UploadService;
  21. use think\App;
  22. use crmeb\basic\BaseController;
  23. use app\common\repositories\store\order\StoreImportRepository;
  24. use think\facade\Queue;
  25. class StoreImport extends BaseController
  26. {
  27. protected $repository;
  28. /**
  29. * Product constructor.
  30. * @param App $app
  31. * @param StoreImportRepository $repository
  32. */
  33. public function __construct(App $app, StoreImportRepository $repository)
  34. {
  35. parent::__construct($app);
  36. $this->repository = $repository;
  37. }
  38. /**
  39. * 获取列表数据
  40. *
  41. * @return \think\response\Json
  42. */
  43. public function lst()
  44. {
  45. // 获取分页参数
  46. [$page, $limit] = $this->getPage();
  47. // 获取查询条件
  48. $where = $this->request->params(['status', 'date', ['import_type', 'delivery'], 'type']);
  49. $where['mer_id'] = $this->request->merId();
  50. // 调用仓库方法获取数据
  51. $data = $this->repository->getList($where, $page, $limit);
  52. // 返回成功响应
  53. return app('json')->success($data);
  54. }
  55. /**
  56. * 获取指定ID的导入配送列表
  57. *
  58. * @param int $id 导入ID
  59. * @return \think\response\Json
  60. */
  61. public function detail($id)
  62. {
  63. // 构造查询条件
  64. $where = [
  65. 'import_id' => $id,
  66. 'mer_id' => $this->request->merId()
  67. ];
  68. // 获取分页参数
  69. [$page, $limit] = $this->getPage();
  70. // 调用 StoreImportDeliveryRepository 类的 getList 方法获取数据
  71. $data = app()->make(StoreImportDeliveryRepository::class)->getList($where, $page, $limit);
  72. // 返回 JSON 格式的数据
  73. return app('json')->success($data);
  74. }
  75. /**
  76. * 导出指定ID的导入配送列表
  77. *
  78. * @param int $id 导入ID
  79. * @return \think\response\Json
  80. */
  81. public function export($id)
  82. {
  83. // 构造查询条件
  84. $where = [
  85. 'import_id' => $id,
  86. 'mer_id' => $this->request->merId()
  87. ];
  88. // 获取分页参数
  89. [$page, $limit] = $this->getPage();
  90. // 调用 ExcelService 类的 importDelivery 方法导出数据
  91. $data = app()->make(ExcelService::class)->importDelivery($where, $page, $limit);
  92. // 返回 JSON 格式的数据
  93. return app('json')->success($data);
  94. }
  95. /**
  96. * 导入excel信息
  97. * @return \think\response\Json
  98. * @author Qinii
  99. * @day 3/16/21
  100. */
  101. public function Import($type)
  102. {
  103. $file = $this->request->file('file');
  104. if (!$file) return app('json')->fail('请上传EXCEL文件');
  105. $file = is_array($file) ? $file[0] : $file;
  106. validate(["file|文件" => ['fileExt' => 'xlsx,xls',]])->check(['file' => $file]);
  107. $upload = UploadService::create(1);
  108. $ret = $upload->to('excel')->move('file');
  109. if ($ret === false) return app('json')->fail($upload->getError());
  110. $res = $upload->getUploadInfo();
  111. $path = rtrim(public_path(),'/').$res['dir'];
  112. $data = [];
  113. $spreadsheet = SpreadsheetExcelService::instance();
  114. switch ($type){
  115. case 'delivery' :
  116. // 是否需要验证表单结构
  117. $spreadsheet->checkImport($path,['E3' => '物流单号']);
  118. $sql = ['delivery_name' => 'D', 'delivery_id' => 'E',];
  119. $where = ['order_sn' => 'B',];
  120. $data['data'] = SpreadsheetExcelService::instance()->_import($path, $sql, $where, 4);
  121. if(!empty($data['data'] )){
  122. $res = $this->repository->create($this->request->merId(),'delivery');
  123. $data['path'] = $path;
  124. $data['import_id'] = $res->import_id;
  125. $data['mer_id'] = $this->request->merId();
  126. Queue::push(ImportSpreadsheetExcelJob::class,$data);
  127. return app('json')->success('开始导入数据,请稍后在批量发货记录中查看!');
  128. }
  129. break;
  130. case 'cdkey':
  131. $data['library_id'] = $this->request->param('library_id');
  132. if (!$data['library_id']) return app('json')->fail('缺少卡密库 ID');
  133. $spreadsheet->checkImport($path,['B1' => '卡号','C1' => '卡密']);
  134. $csList = $spreadsheet->_import($path,['key' => 'B','pwd' => 'C'],[],2);
  135. $data['csList'] = array_column($csList,'value');
  136. app()->make(ProductCdkeyValidate::class)->check($data);
  137. app()->make(ProductCdkeyRepository::class)->save($data, $this->request->merId());
  138. return app('json')->success('导入成功');
  139. break;
  140. default:
  141. break;
  142. }
  143. }
  144. }