StoreImport.php 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2016~2022 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 crmeb\jobs\ImportSpreadsheetExcelJob;
  16. use crmeb\services\ExcelService;
  17. use crmeb\services\SpreadsheetExcelService;
  18. use crmeb\services\UploadService;
  19. use think\App;
  20. use crmeb\basic\BaseController;
  21. use app\common\repositories\store\order\StoreImportRepository;
  22. use think\facade\Queue;
  23. class StoreImport extends BaseController
  24. {
  25. protected $repository;
  26. /**
  27. * Product constructor.
  28. * @param App $app
  29. * @param StoreImportRepository $repository
  30. */
  31. public function __construct(App $app, StoreImportRepository $repository)
  32. {
  33. parent::__construct($app);
  34. $this->repository = $repository;
  35. }
  36. public function lst()
  37. {
  38. [$page, $limit] = $this->getPage();
  39. $where = $this->request->params(['status','date',['import_type','delivery'],'type']);
  40. $where['mer_id'] = $this->request->merId();
  41. $data = $this->repository->getList($where,$page,$limit);
  42. return app('json')->success($data);
  43. }
  44. public function detail($id)
  45. {
  46. $where = [
  47. 'import_id' => $id,
  48. 'mer_id' => $this->request->merId()
  49. ];
  50. [$page, $limit] = $this->getPage();
  51. $data = app()->make(StoreImportDeliveryRepository::class)->getList($where,$page, $limit);
  52. return app('json')->success($data);
  53. }
  54. public function export($id)
  55. {
  56. $where = [
  57. 'import_id' => $id,
  58. 'mer_id' => $this->request->merId()
  59. ];
  60. [$page, $limit] = $this->getPage();
  61. $data = app()->make(ExcelService::class)->importDelivery($where, $page, $limit);
  62. return app('json')->success($data);
  63. }
  64. /**
  65. * TODO 导入excel信息
  66. * @return \think\response\Json
  67. * @author Qinii
  68. * @day 3/16/21
  69. */
  70. public function Import($type)
  71. {
  72. $file = $this->request->file('file');
  73. if (!$file) return app('json')->fail('请上传EXCEL文件');
  74. $file = is_array($file) ? $file[0] : $file;
  75. validate(["file|文件" => ['fileExt' => 'xlsx,xls',]])->check(['file' => $file]);
  76. $upload = UploadService::create(1);
  77. $ret = $upload->to('excel')->move('file');
  78. if ($ret === false) return app('json')->fail($upload->getError());
  79. $res = $upload->getUploadInfo();
  80. $path = rtrim(public_path(),'/').$res['dir'];
  81. $data = [];
  82. switch ($type){
  83. case 'delivery' :
  84. SpreadsheetExcelService::instance()->checkImport($path,['E3' => '物流单号']);
  85. $data = [
  86. 'mer_id' => $this->request->merId(),
  87. 'data' => [
  88. 'path' => $path,
  89. 'sql' => ['delivery_name' => 'D', 'delivery_id' => 'E',],
  90. 'where' => ['order_sn' => 'B',],
  91. ]
  92. ];
  93. break;
  94. default:
  95. $data = SpreadsheetExcelService::instance()->_import($path,[],[],0);
  96. break;
  97. }
  98. if(!empty($data)){
  99. $res = $this->repository->create($this->request->merId(),'delivery');
  100. $data['data']['import_id'] = $res->import_id;
  101. // app()->make(StoreOrderRepository::class)->setWhereDeliveryStatus($data['data'],$data['mer_id']);
  102. Queue::push(ImportSpreadsheetExcelJob::class,$data);
  103. return app('json')->success('开始导入数据,请稍后在批量发货记录中查看!');
  104. }
  105. return app('json')->fail('数据类型错误');
  106. }
  107. }