Refund.php 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443
  1. <?php
  2. namespace app\admin\controller;
  3. use think\facade\View;
  4. use think\facade\Lang;
  5. /**
  6. * ============================================================================
  7. * DSMall多用户商城
  8. * ============================================================================
  9. * 版权所有 2014-2028 长沙德尚网络科技有限公司,并保留所有权利。
  10. * 网站地址: http://www.csdeshang.com
  11. * ----------------------------------------------------------------------------
  12. * 这不是一个自由软件!您只能在不用于商业目的的前提下对程序代码进行修改和使用 .
  13. * 不允许对程序代码以任何形式任何目的的再发布。
  14. * ============================================================================
  15. * 控制器
  16. */
  17. class Refund extends AdminControl
  18. {
  19. const EXPORT_SIZE = 1000;
  20. public function initialize()
  21. {
  22. parent::initialize();
  23. Lang::load(base_path() . 'admin/lang/' . config('lang.default_lang') . '/refund.lang.php');
  24. //向模板页面输出退款退货状态
  25. $this->getRefundStateArray();
  26. }
  27. function getRefundStateArray($type = 'all')
  28. {
  29. $state_array = [
  30. '1' => lang('refund_state_confirm'), '2' => lang('refund_state_yes'), '3' => lang('refund_state_no'),
  31. ]; //卖家处理状态:1为待审核,2为同意,3为不同意
  32. View::assign('state_array', $state_array);
  33. $admin_array = [
  34. '1' => lang('admin_state_1'), '2' => lang('admin_state_2'), '3' => lang('admin_state_3'), '4' => lang('refund_state_no'),
  35. ]; //确认状态:1为买家或卖家处理中,2为待平台管理员处理,3为退款退货已完成
  36. View::assign('admin_array', $admin_array);
  37. $state_data = [
  38. 'seller' => $state_array, 'admin' => $admin_array,
  39. ];
  40. if ($type == 'all') {
  41. return $state_data; //返回所有
  42. }
  43. return $state_data[$type];
  44. }
  45. /**
  46. * 待处理列表
  47. */
  48. public function refund_manage()
  49. {
  50. $refundreturn_model = model('refundreturn');
  51. $condition = [];
  52. $condition[] = ['refund_type', '=', 1];
  53. $condition[] = ['refund_state', '=', '2']; //状态:1为处理中,2为待管理员处理,3为已完成
  54. $keyword_type = ['order_sn', 'refund_sn', 'store_name', 'buyer_name', 'goods_name'];
  55. $key = input('get.key');
  56. $type = input('get.type');
  57. if (trim($key) != '' && in_array($type, $keyword_type)) {
  58. $condition[] = [$type, 'like', '%' . $key . '%'];
  59. }
  60. $add_time_from = input('get.add_time_from');
  61. $add_time_to = input('get.add_time_to');
  62. if (trim($add_time_from) != '') {
  63. $add_time_from = strtotime(trim($add_time_from));
  64. if ($add_time_from !== false) {
  65. $condition[] = ['add_time', '>=', $add_time_from];
  66. }
  67. }
  68. if (trim($add_time_to) != '') {
  69. $add_time_to = strtotime(trim($add_time_to)) + 86399;
  70. if ($add_time_to !== false) {
  71. $condition[] = ['add_time', '<=', $add_time_to];
  72. }
  73. }
  74. $refund_list = $refundreturn_model->getRefundList($condition, 10);
  75. View::assign('show_page', $refundreturn_model->page_info->render());
  76. View::assign('refund_list', $refund_list);
  77. $this->setAdminCurItem('refund_manage');
  78. return View::fetch('refund_manage');
  79. }
  80. /**
  81. * 所有记录
  82. */
  83. public function refund_all()
  84. {
  85. $refundreturn_model = model('refundreturn');
  86. $condition = [];
  87. $condition[] = ['refund_type', '=', 1];
  88. $keyword_type = ['order_sn', 'refund_sn', 'store_name', 'buyer_name', 'goods_name'];
  89. $key = input('get.key');
  90. $type = input('get.type');
  91. if (trim($key) != '' && in_array($type, $keyword_type)) {
  92. $condition[] = [$type, 'like', '%' . $key . '%'];
  93. }
  94. $add_time_from = input('get.add_time_from');
  95. $add_time_to = input('get.add_time_to');
  96. if (trim($add_time_from) != '') {
  97. $add_time_from = strtotime(trim($add_time_from));
  98. if ($add_time_from !== false) {
  99. $condition[] = ['add_time', '>=', $add_time_from];
  100. }
  101. }
  102. if (trim($add_time_to) != '') {
  103. $add_time_to = strtotime(trim($add_time_to)) + 86399;
  104. if ($add_time_to !== false) {
  105. $condition[] = ['add_time', '<=', $add_time_to];
  106. }
  107. }
  108. $refund_list = $refundreturn_model->getRefundList($condition, 10);
  109. View::assign('show_page', $refundreturn_model->page_info->render());
  110. View::assign('refund_list', $refund_list);
  111. $this->setAdminCurItem('refund_all');
  112. return View::fetch('refund_all');
  113. }
  114. /**
  115. * 退款处理页
  116. *
  117. */
  118. public function edit()
  119. {
  120. $refundreturn_model = model('refundreturn');
  121. $condition = [];
  122. $condition[] = ['refund_id', '=', intval(input('param.refund_id'))];
  123. $refund_list = $refundreturn_model->getRefundList(array_merge($condition, [['refund_type', '=', 1]]));
  124. $refund = $refund_list[0];
  125. if (request()->isPost()) {
  126. if (!in_array(input('post.refund_state'), [3, 4])) {
  127. $this->error(lang('refund_state_null'));
  128. }
  129. $check = request()->checkToken('__token__');
  130. if (false === $check) {
  131. $this->error('invalid token');
  132. }
  133. if ($refund['refund_state'] != '2') {//检查状态,防止页面刷新不及时造成数据错误
  134. $this->error(lang('ds_common_save_fail'));
  135. }
  136. $order_id = $refund['order_id'];
  137. $refund_array = [];
  138. $refund_array['admin_time'] = TIMESTAMP;
  139. $refund_array['refund_state'] = '4'; //状态:1为处理中,2为待管理员处理,3为已完成
  140. $refund_array['admin_message'] = input('post.admin_message');
  141. if (input('post.refund_state') == '3') {
  142. $refund_array['refund_state'] = '3';
  143. $res = $refundreturn_model->editOrderRefund($refund);
  144. $state = $res['code'];
  145. if (!$state) {
  146. $this->error($res['msg']);
  147. }
  148. } else {
  149. if ($refund['order_lock'] == '2') {
  150. $state = $refundreturn_model->editOrderUnlock($order_id); //订单解锁
  151. } else {
  152. $state = true;
  153. }
  154. //自提点订单解锁
  155. $chain_order_model = model('chain_order');
  156. $chain_order_model->editChainOrderUnlock($order_id);
  157. }
  158. if ($state) {
  159. $refundreturn_model->editRefundreturn($condition, $refund_array);
  160. // 发送买家消息
  161. $param = [];
  162. $param['code'] = 'refund_return_notice';
  163. $param['member_id'] = $refund['buyer_id'];
  164. //阿里短信参数
  165. $param['ali_param'] = [
  166. 'refund_sn' => $refund['refund_sn'],
  167. ];
  168. $param['ten_param'] = [
  169. $refund['refund_sn'],
  170. ];
  171. $param['param'] = array_merge($param['ali_param'], [
  172. 'refund_url' => HOME_SITE_URL . '/memberrefund/view?refund_id=' . $refund['refund_id'],
  173. ]);
  174. //微信模板消息
  175. $param['weixin_param'] = [
  176. 'url' => config('ds_config.h5_site_url') . '/member/refund_view?refund_id=' . $refund['refund_id'],
  177. 'data' => [
  178. "keyword1" => [
  179. "value" => $refund['order_sn'],
  180. "color" => "#333",
  181. ],
  182. "keyword2" => [
  183. "value" => $refund['refund_amount'],
  184. "color" => "#333",
  185. ],
  186. ],
  187. ];
  188. \mall\queue\QueueClient::push('sendMemberMsg', $param);
  189. $this->log('退款确认,退款编号' . $refund['refund_sn']);
  190. dsLayerOpenSuccess(lang('ds_common_save_succ'));
  191. } else {
  192. $this->error(lang('ds_common_save_fail'));
  193. }
  194. }
  195. View::assign('refund', $refund);
  196. $info['buyer'] = [];
  197. if (!empty($refund['pic_info'])) {
  198. $info = unserialize($refund['pic_info']);
  199. }
  200. View::assign('pic_list', $info['buyer']);
  201. return View::fetch('edit');
  202. }
  203. /**
  204. * 退款记录查看页
  205. *
  206. */
  207. public function view()
  208. {
  209. $refundreturn_model = model('refundreturn');
  210. $condition = [];
  211. $condition[] = ['refund_id', '=', intval(input('param.refund_id'))];
  212. $condition[] = ['refund_type', '=', 1];
  213. $refund_list = $refundreturn_model->getRefundList($condition);
  214. $refund = $refund_list[0];
  215. View::assign('refund', $refund);
  216. $info['buyer'] = [];
  217. if (!empty($refund['pic_info'])) {
  218. $info = unserialize($refund['pic_info']);
  219. }
  220. View::assign('pic_list', $info['buyer']);
  221. return View::fetch('view');
  222. }
  223. /**
  224. * 退款退货原因
  225. */
  226. public function reason()
  227. {
  228. $refundreturn_model = model('refundreturn');
  229. $condition = [];
  230. $reason_list = $refundreturn_model->getReasonList($condition, 10);
  231. View::assign('reason_list', $reason_list);
  232. View::assign('show_page', $refundreturn_model->page_info->render());
  233. $this->setAdminCurItem('reason');
  234. return View::fetch('reason');
  235. }
  236. /**
  237. * 新增退款退货原因
  238. */
  239. public function add_reason()
  240. {
  241. $refundreturn_model = model('refundreturn');
  242. if (request()->post()) {
  243. $reason_array = [];
  244. $reason_array['reason_info'] = input('post.reason_info');
  245. $reason_array['reason_sort'] = intval(input('post.reason_sort'));
  246. $reason_array['reason_updatetime'] = TIMESTAMP;
  247. $state = $refundreturn_model->addReason($reason_array);
  248. if ($state) {
  249. $this->log('新增退款退货原因,编号' . $state);
  250. dsLayerOpenSuccess(lang('ds_common_save_succ'));
  251. } else {
  252. $this->error(lang('ds_common_save_fail'));
  253. }
  254. }
  255. return View::fetch('add_reason');
  256. }
  257. /**
  258. * 编辑退款退货原因
  259. *
  260. */
  261. public function edit_reason()
  262. {
  263. $refundreturn_model = model('refundreturn');
  264. $condition = [];
  265. $reason_id = intval(input('param.reason_id'));
  266. $condition[] = ['reason_id', '=', $reason_id];
  267. $reason_list = $refundreturn_model->getReasonList($condition);
  268. $reason = $reason_list[$reason_id];
  269. if (request()->post()) {
  270. $reason_array = [];
  271. $reason_array['reason_info'] = input('post.reason_info');
  272. $reason_array['reason_sort'] = intval(input('post.reason_sort'));
  273. $reason_array['reason_updatetime'] = TIMESTAMP;
  274. $state = $refundreturn_model->editReason($condition, $reason_array);
  275. if ($state) {
  276. $this->log('编辑退款退货原因,编号' . $reason_id);
  277. dsLayerOpenSuccess(lang('ds_common_save_succ'));
  278. } else {
  279. $this->error(lang('ds_common_save_fail'));
  280. }
  281. }
  282. View::assign('reason', $reason);
  283. return View::fetch('edit_reason');
  284. }
  285. /**
  286. * 删除退款退货原因
  287. *
  288. */
  289. public function del_reason()
  290. {
  291. $refundreturn_model = model('refundreturn');
  292. $reason_id = input('param.reason_id');
  293. $reason_id_array = ds_delete_param($reason_id);
  294. if ($reason_id_array === FALSE) {
  295. ds_json_encode('10001', lang('param_error'));
  296. }
  297. $condition = [['reason_id', 'in', $reason_id_array]];
  298. $state = $refundreturn_model->delReason($condition);
  299. if ($state) {
  300. $this->log('删除退款退货原因,编号' . $reason_id);
  301. ds_json_encode('10000', lang('ds_common_del_succ'));
  302. } else {
  303. ds_json_encode('10001', lang('ds_common_del_fail'));
  304. }
  305. }
  306. /**
  307. * 导出
  308. *
  309. */
  310. public function export_step1()
  311. {
  312. $refundreturn_model = model('refundreturn');
  313. $condition = [];
  314. $keyword_type = ['order_sn', 'refund_sn', 'store_name', 'buyer_name', 'goods_name'];
  315. $key = input('get.key');
  316. $type = input('get.type');
  317. if (trim($key) != '' && in_array($type, $keyword_type)) {
  318. $condition[] = [$type, 'like', '%' . $key . '%'];
  319. }
  320. $add_time_from = input('get.add_time_from');
  321. $add_time_to = input('get.add_time_to');
  322. if (trim($add_time_from) != '') {
  323. $add_time_from = strtotime(trim($add_time_from));
  324. if ($add_time_from !== false) {
  325. $condition[] = ['add_time', '>=', $add_time_from];
  326. }
  327. }
  328. if (trim($add_time_to) != '') {
  329. $add_time_to = strtotime(trim($add_time_to)) + 86399;
  330. if ($add_time_to !== false) {
  331. $condition[] = ['add_time', '<=', $add_time_to];
  332. }
  333. }
  334. if (!is_numeric(input('param.page'))) {
  335. $count = $refundreturn_model->getRefundCount($condition);
  336. $export_list = [];
  337. if ($count > self::EXPORT_SIZE) { //显示下载链接
  338. $page = ceil($count / self::EXPORT_SIZE);
  339. for ($i = 1; $i <= $page; $i++) {
  340. $limit1 = ($i - 1) * self::EXPORT_SIZE + 1;
  341. $limit2 = $i * self::EXPORT_SIZE > $count ? $count : $i * self::EXPORT_SIZE;
  342. $export_list[$i] = $limit1 . ' ~ ' . $limit2;
  343. }
  344. View::assign('export_list', $export_list);
  345. return View::fetch('/public/excel');
  346. } else { //如果数量小,直接下载
  347. $data = $refundreturn_model->getRefundList(array_merge($condition, [['refund_type', '=', 1]]), '', '*', 'refund_id desc', self::EXPORT_SIZE);
  348. $this->createExcel($data);
  349. }
  350. } else { //下载
  351. $limit1 = (input('param.page') - 1) * self::EXPORT_SIZE;
  352. $limit2 = self::EXPORT_SIZE;
  353. $data = $refundreturn_model->getRefundList(array_merge($condition, [['refund_type', '=', 1]]), $limit2, '*', 'refund_id desc');
  354. $this->createExcel($data);
  355. }
  356. }
  357. /**
  358. * 生成excel
  359. *
  360. * @param array $data
  361. */
  362. private function createExcel($data = [])
  363. {
  364. Lang::load(base_path() . 'admin/lang/' . config('lang.default_lang') . '/export.lang.php');
  365. $excel_obj = new \excel\Excel();
  366. $excel_data = [];
  367. //设置样式
  368. $excel_obj->setStyle(['id' => 's_title', 'Font' => ['FontName' => '宋体', 'Size' => '12', 'Bold' => '1']]);
  369. //header
  370. $excel_data[0][] = ['styleid' => 's_title', 'data' => lang('ds_order_sn')];
  371. $excel_data[0][] = ['styleid' => 's_title', 'data' => lang('ds_refund_sn')];
  372. $excel_data[0][] = ['styleid' => 's_title', 'data' => lang('ds_store_name')];
  373. $excel_data[0][] = ['styleid' => 's_title', 'data' => lang('ds_goods_name')];
  374. $excel_data[0][] = ['styleid' => 's_title', 'data' => lang('ds_buyer_name')];
  375. $excel_data[0][] = ['styleid' => 's_title', 'data' => lang('exp_tk_order_add_time')];
  376. $excel_data[0][] = ['styleid' => 's_title', 'data' => lang('exp_tk_order_refund')];
  377. //data
  378. foreach ((array)$data as $k => $v) {
  379. $tmp = [];
  380. $tmp[] = ['data' => 'DS' . $v['order_sn']];
  381. $tmp[] = ['data' => $v['refund_sn']];
  382. $tmp[] = ['data' => $v['store_name']];
  383. $tmp[] = ['data' => $v['goods_name']];
  384. $tmp[] = ['data' => $v['buyer_name']];
  385. $tmp[] = ['data' => date('Y-m-d H:i:s', $v['add_time'])];
  386. $tmp[] = ['format' => 'Number', 'data' => ds_price_format($v['refund_amount'])];
  387. $excel_data[] = $tmp;
  388. }
  389. $excel_data = $excel_obj->charset($excel_data, CHARSET);
  390. $excel_obj->addArray($excel_data);
  391. $excel_obj->addWorksheet($excel_obj->charset(lang('exp_tk_refund'), CHARSET));
  392. $excel_obj->generateXML($excel_obj->charset(lang('exp_tk_refund'), CHARSET) . input('param.page') . '-' . date('Y-m-d-H', TIMESTAMP));
  393. }
  394. /**
  395. * 获取卖家栏目列表,针对控制器下的栏目
  396. */
  397. protected function getAdminItemList()
  398. {
  399. $menu_array = [
  400. [
  401. 'name' => 'refund_manage', 'text' => lang('admin_state_2'), 'url' => (string)url('Refund/refund_manage'),
  402. ], [
  403. 'name' => 'refund_all', 'text' => lang('refund_all'), 'url' => (string)url('Refund/refund_all'),
  404. ], [
  405. 'name' => 'reason', 'text' => lang('refund_return_reason'), 'url' => (string)url('Refund/reason'),
  406. ],
  407. ];
  408. if (request()->action() == 'reason') {
  409. $menu_array[] = [
  410. 'name' => 'add_reason', 'text' => lang('add_reason'), 'url' => "javascript:dsLayerOpen('" . (string)url('Refund/add_reason') . "','" . lang('add_reason') . "')",
  411. ];
  412. }
  413. return $menu_array;
  414. }
  415. }
  416. ?>