CardImport.php 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319
  1. <?php
  2. /**
  3. * Niushop商城系统 - 团队十年电商经验汇集巨献!
  4. * =========================================================
  5. * Copy right 2019-2029 上海牛之云网络科技有限公司, 保留所有权利。
  6. * ----------------------------------------------
  7. * 官方网址: https://www.niushop.com
  8. * =========================================================
  9. */
  10. namespace addon\giftcard\model\card;
  11. use addon\giftcard\model\giftcard\GiftCard;
  12. use app\model\member\Member;
  13. use think\facade\Cache;
  14. use think\facade\Db;
  15. /**
  16. * 礼品卡导入类
  17. *
  18. * @author Administrator
  19. *
  20. */
  21. class CardImport extends Card
  22. {
  23. public $create_type_list = array (
  24. 'auto' => '在线制卡',
  25. 'import' => '导入制卡'
  26. );
  27. /**
  28. * 创建导入记录单据
  29. * @param $params
  30. * @return array
  31. */
  32. public function create($params)
  33. {
  34. $type = $params[ 'type' ];
  35. $giftcard_id = $params[ 'giftcard_id' ];
  36. $giftcard_model = new GiftCard();
  37. $condition = [ [ 'giftcard_id', '=', $giftcard_id ] ];
  38. $info = $giftcard_model->getGiftcardInfo($condition)[ 'data' ] ?? [];
  39. if (empty($info))
  40. return $this->error();
  41. $info[ 'operator_data' ] = $params[ 'operator_data' ];
  42. if ($info[ 'card_type' ] != 'real') {
  43. return $this->error('', '该礼品不支持制卡');
  44. }
  45. $data = array (
  46. 'site_id' => $params[ 'site_id' ],
  47. 'name' => $params[ 'name' ] ?? date('YmdHis'),
  48. 'giftcard_id' => $params[ 'giftcard_id' ],
  49. 'type' => $params[ 'type' ],
  50. 'card_type' => $info[ 'card_type' ],
  51. 'create_time' => time()
  52. );
  53. switch ( $type ) {
  54. case 'auto':
  55. $data[ 'total_count' ] = $params[ 'num' ] ?? 0;
  56. break;
  57. case 'manual':
  58. $data[ 'total_count' ] = 1;
  59. break;
  60. case 'import':
  61. $file = request()->file('file');
  62. $tmp_name = $file->getPathname();//获取上传缓存文件
  63. $fp = file($tmp_name);
  64. $data[ 'total_count' ] = count($fp) - 1;
  65. break;
  66. }
  67. $import_id = $this->add($data)[ 'data' ] ?? 0;
  68. if ($type == 'import') {
  69. $path = 'upload/giftcard/';
  70. if(file_exists($path) || mkdir($path, 0755, true)){
  71. if (move_uploaded_file($tmp_name, $path.'giftcard_card_import' . $import_id . '.csv')) {
  72. Cache::set('giftcard/giftcard_card_import_name' . $import_id, $file->getOriginalName());
  73. } else {
  74. return $this->error([], '导入失败');
  75. }
  76. }else {
  77. return $this->error([], '导入失败');
  78. }
  79. }
  80. return $this->success($import_id);
  81. }
  82. /**
  83. * 添加
  84. * @param $data
  85. * @return array
  86. */
  87. public function add($data)
  88. {
  89. $data[ 'create_time' ] = time();
  90. $id = model('giftcard_card_import')->add($data);
  91. return $this->success($id);
  92. }
  93. /**
  94. * 编辑
  95. * @param $data
  96. * @param $condition
  97. * @return array
  98. */
  99. public function update($data, $condition)
  100. {
  101. $id = model('giftcard_card_import')->update($data, $condition);
  102. return $this->success($id);
  103. }
  104. /**
  105. * 删除导入记录(todo 能做真删吗)
  106. * @param $condition
  107. * @return array
  108. */
  109. public function delete($params)
  110. {
  111. $site_id = $params[ 'site_id' ] ?? 0;
  112. $import_id = $params[ 'import_id' ] ?? 0;
  113. $import_ids = $params[ 'import_ids' ] ?? '';
  114. $condition = array ();
  115. if ($site_id > 0) {
  116. $condition[] = [ 'site_id', '=', $site_id ];
  117. }
  118. if ($import_id > 0) {
  119. $condition[] = [ 'import_id', '=', $import_id ];
  120. }
  121. if (!empty($import_ids)) {
  122. $condition[] = [ 'import_id', 'in', $import_ids ];
  123. }
  124. $list = $this->getCardImportList($condition)[ 'data' ] ?? [];
  125. if (empty($list))
  126. return $this->error();
  127. foreach ($list as $k => $v) {
  128. $item_condition = array (
  129. [ 'card_import_id', '=', $v[ 'import_id' ] ],
  130. [ 'status', '=', 'used' ]
  131. );
  132. $count = model('giftcard_card')->getCount($item_condition);
  133. if ($count > 0) {
  134. return $this->error([], '存在已使用的卡项,当前记录不允许删除');
  135. }
  136. }
  137. //删除制卡记录
  138. $res = model('giftcard_card_import')->delete($condition);
  139. $this->deleteOperation($params);
  140. return $this->success($res);
  141. }
  142. /**
  143. * 删除导入卡记录后续
  144. * @param $params
  145. * @return array
  146. */
  147. public function deleteOperation($params)
  148. {
  149. // $list = $params['list'];
  150. //会将这个记录之下的卡项全部删除
  151. $card_model = new Card();
  152. $import_id = $params[ 'import_id' ] ?? 0;
  153. $import_ids = $params[ 'import_ids' ] ?? 0;
  154. if ($import_id > 0) {
  155. $params[ 'card_import_id' ] = $import_id;
  156. }
  157. if (!empty($import_ids)) {
  158. $params[ 'card_import_ids' ] = $import_ids;
  159. }
  160. $result = $card_model->delete($params);
  161. return $result;
  162. }
  163. /**
  164. * 获取礼品卡导入记录信息
  165. * @param $condition
  166. * @param string $field
  167. * @return array
  168. */
  169. public function getCardImportInfo($condition, $field = '*')
  170. {
  171. $info = model('giftcard_card_import')->getInfo($condition, $field);
  172. return $this->success($info);
  173. }
  174. /**
  175. * 获取礼品卡导入记录列表
  176. * @param array $condition
  177. * @param string $field
  178. * @param string $order
  179. * @param null $limit
  180. * @return array
  181. */
  182. public function getCardImportList($condition = [], $field = '*', $order = '', $limit = null)
  183. {
  184. $list = model('giftcard_card_import')->getList($condition, $field, $order, '', '', '', $limit);
  185. return $this->success($list);
  186. }
  187. /**
  188. * 获取礼品卡导入记录分页列表
  189. * @param array $condition
  190. * @param int $page
  191. * @param int $page_size
  192. * @param string $order
  193. * @param string $field
  194. * @return array
  195. */
  196. public function getCardImportPageList($condition = [], $page = 1, $page_size = PAGE_LIST_ROWS, $order = '', $field = '*')
  197. {
  198. $list = model('giftcard_card_import')->pageList($condition, $field, $order, $page, $page_size);
  199. return $this->success($list);
  200. }
  201. public function getCardImportColumn($condition, $field = '*')
  202. {
  203. $info = model('giftcard_card_import')->getColumn($condition, $field);
  204. return $this->success($info);
  205. }
  206. /**
  207. * 导出
  208. * @param $condition
  209. */
  210. public function export($condition)
  211. {
  212. try {
  213. $file_name = date('Y年m月d日-礼品卡', time()) . '.csv';
  214. // $file_name = date('YmdHis').'.csv';//csv文件名
  215. //通过分批次执行数据导出(防止内存超出配置设置的)
  216. set_time_limit(0);
  217. ini_set('memory_limit', '256M');
  218. //设置header头
  219. header('Content-Description: File Transfer');
  220. header('Content-Type: application/vnd.ms-excel');
  221. header('Content-Disposition: attachment; filename="' . $file_name . '"');
  222. header('Expires: 0');
  223. header('Cache-Control: must-revalidate');
  224. header('Pragma: public');
  225. //打开php数据输入缓冲区
  226. $fp = fopen('php://output', 'a');
  227. // fwrite($fp, chr(0xEF).chr(0xBB).chr(0xBF)); // 添加 BOM
  228. $heade = [ '编号', '卡密', '状态', '生成时间', '激活会员', '激活时间' ];
  229. //将数据编码转换成GBK格式
  230. mb_convert_variables('GBK', 'UTF-8', $heade);
  231. //将数据格式化为CSV格式并写入到output流中
  232. fputcsv($fp, $heade);
  233. $member_model = new Member();
  234. //写入第一行表头
  235. Db::name('giftcard_card')->where($condition)->chunk(500, function($item_list) use ($fp, $member_model) {
  236. //写入导出信息
  237. foreach ($item_list as $k => $item_v) {
  238. $item_member_id = $item_v[ 'member_id' ];
  239. $item_nickname = '';
  240. if ($item_member_id > 0) {
  241. $item_member_info = $member_model->getMemberInfo([ [ 'member_id', '=', $item_member_id ] ])[ 'data' ] ?? [];
  242. $item_nickname = $item_member_info[ 'nickname' ];
  243. }
  244. $item_v = $this->tran($item_v);
  245. $temp_data = [
  246. (string) $item_v[ 'card_no' ] . "\t",
  247. (string) $item_v[ 'card_cdk' ] . "\t",
  248. (string) $item_v[ 'status_name' ] . "\t",
  249. time_to_date($item_v[ 'create_time' ]) . "\t",
  250. $item_nickname . "\t",
  251. time_to_date($item_v[ 'activate_time' ]) . "\t",
  252. ];
  253. mb_convert_variables('GBK', 'UTF-8', $temp_data);
  254. fputcsv($fp, $temp_data);
  255. //将已经存储到csv中的变量数据销毁,释放内存
  256. unset($item_v);
  257. }
  258. unset($item_list);
  259. });
  260. //关闭句柄
  261. fclose($fp);
  262. die;
  263. } catch (\Exception $e) {
  264. return $this->error([], $e->getMessage() . $e->getFile() . $e->getLine());
  265. }
  266. }
  267. /**
  268. * 作废
  269. * @param $params
  270. */
  271. public function invalid($params)
  272. {
  273. $import_id = $params[ 'import_id' ];
  274. $condition = array (
  275. [ 'import_id', '=', $import_id ],
  276. [ 'status', '=', '1' ]
  277. );
  278. $data = array (
  279. 'status' => 2,
  280. 'invalid_time' => time(),
  281. );
  282. model('giftcard_card')->update($data, $condition);
  283. //应该是批量设置
  284. //查询未激活的卡密有多少
  285. $card_operation_model = new CardOperation();
  286. $params[ 'card_import_id' ] = $import_id;
  287. //批量使卡失效作废
  288. $card_operation_model->cardInvalid($params);
  289. return $this->success();
  290. }
  291. }