Returnmanage.php 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379
  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 Returnmanage extends AdminControl {
  18. const EXPORT_SIZE = 1000;
  19. public function initialize() {
  20. parent::initialize();
  21. Lang::load(base_path() . 'admin/lang/'.config('lang.default_lang').'/returnmanage.lang.php');
  22. //向模板页面输出退款退货状态
  23. $this->getRefundStateArray();
  24. }
  25. function getRefundStateArray($type = 'all') {
  26. $state_array = array(
  27. '1' => lang('refund_state_confirm'),
  28. '2' => lang('refund_state_yes'),
  29. '3' => lang('refund_state_no')
  30. ); //卖家处理状态:1为待审核,2为同意,3为不同意
  31. View::assign('state_array', $state_array);
  32. $admin_array = array(
  33. '1' => lang('admin_state_1'),
  34. '2' => lang('admin_state_2'),
  35. '3' => lang('admin_state_3'),
  36. '4' => lang('refund_state_no')
  37. ); //确认状态:1为买家或卖家处理中,2为待平台管理员处理,3为退款退货已完成
  38. View::assign('admin_array', $admin_array);
  39. $state_data = array(
  40. 'seller' => $state_array,
  41. 'admin' => $admin_array
  42. );
  43. if ($type == 'all') {
  44. return $state_data; //返回所有
  45. }
  46. return $state_data[$type];
  47. }
  48. /**
  49. * 待处理列表
  50. */
  51. public function return_manage() {
  52. $refundreturn_model = model('refundreturn');
  53. $condition = array();
  54. $condition[]=array('refund_state','=','2'); //状态:1为处理中,2为待管理员处理,3为已完成
  55. $keyword_type = array('order_sn', 'refund_sn', 'store_name', 'buyer_name', 'goods_name');
  56. $key = input('get.key');
  57. $type = input('get.type');
  58. if (trim($key) != '' && in_array($type, $keyword_type)) {
  59. $condition[]=array($type,'like', '%' . $key . '%');
  60. }
  61. $add_time_from = input('get.add_time_from');
  62. $add_time_to = input('get.add_time_to');
  63. if (trim($add_time_from) != '') {
  64. $add_time_from = strtotime(trim($add_time_from));
  65. if ($add_time_from !== false) {
  66. $condition[] = array('add_time','>=', $add_time_from);
  67. }
  68. }
  69. if (trim($add_time_to) != '') {
  70. $add_time_to = strtotime(trim($add_time_to))+86399;
  71. if ($add_time_to !== false) {
  72. $condition[] = array('add_time','<=', $add_time_to);
  73. }
  74. }
  75. $return_list = $refundreturn_model->getReturnList($condition, 10);
  76. View::assign('return_list', $return_list);
  77. View::assign('show_page', $refundreturn_model->page_info->render());
  78. View::assign('filtered', $condition ? 1 : 0); //是否有查询条件
  79. $this->setAdminCurItem('return_manage');
  80. return View::fetch('return_manage');
  81. }
  82. /**
  83. * 所有记录
  84. */
  85. public function return_all() {
  86. $refundreturn_model = model('refundreturn');
  87. $condition = array();
  88. $keyword_type = array('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[]=array($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[] = array('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[] = array('add_time','<=', $add_time_to);
  106. }
  107. }
  108. $return_list = $refundreturn_model->getReturnList($condition, 10);
  109. View::assign('return_list', $return_list);
  110. View::assign('show_page', $refundreturn_model->page_info->render());
  111. View::assign('filtered', $condition ? 1 : 0); //是否有查询条件
  112. $this->setAdminCurItem('return_all');
  113. return View::fetch('return_all');
  114. }
  115. /**
  116. * 退货处理页
  117. *
  118. */
  119. public function edit() {
  120. $refundreturn_model = model('refundreturn');
  121. $condition = array();
  122. $condition[] = array('refund_id','=',intval(input('param.refund_id')));
  123. $return = $refundreturn_model->getRefundreturnInfo($condition);
  124. if(empty($return)){
  125. $this->error(lang('param_error'));
  126. }
  127. //查询交易凭证
  128. $order_model = model('order');
  129. $order = $order_model->getOrderInfo(array('order_id' => $return['order_id']));
  130. if (request()->isPost()) {
  131. if(!in_array(input('post.refund_state'),[3,4])){
  132. $this->error(lang('refund_state_null'));
  133. }
  134. $check = request()->checkToken('__token__');
  135. if(false === $check) {
  136. $this->error('invalid token');
  137. }
  138. if ($return['refund_state'] != '2') {//检查状态,防止页面刷新不及时造成数据错误
  139. $this->error(lang('ds_common_save_fail'));
  140. }
  141. $order_id = $return['order_id'];
  142. $refund_array = array();
  143. $refund_array['admin_time'] = TIMESTAMP;
  144. $refund_array['refund_state'] = '4'; //状态:1为处理中,2为待管理员处理,3为已完成
  145. $refund_array['admin_message'] = input('post.admin_message');
  146. if (input('post.refund_state') == '3') {
  147. $trade_no=input('param.trade_no');
  148. if($trade_no && $trade_no!=$order['trade_no']){
  149. $order_model->editOrder(array('trade_no'=>$trade_no), array(
  150. 'order_id' => $order['order_id']
  151. ));
  152. //添加订单日志
  153. $data = array();
  154. $data['order_id'] = $order['order_id'];
  155. $data['log_role'] = 'system';
  156. $data['log_user'] = $this->admin_info['admin_name'];
  157. $data['log_msg'] = '修改支付平台交易号 : ' . $trade_no;
  158. $data['log_orderstate'] = $order['order_state'];
  159. $order_model->addOrderlog($data);
  160. }
  161. $refund_array['refund_state'] = '3';
  162. $res = $refundreturn_model->editOrderRefund($return);
  163. $state=$res['code'];
  164. if(!$state){
  165. $this->error($res['msg']);
  166. }
  167. }else{
  168. if($return['order_lock'] == '2'){
  169. $state = $refundreturn_model->editOrderUnlock($order_id); //订单解锁
  170. }else{
  171. $state = true;
  172. }
  173. }
  174. if ($state) {
  175. $refundreturn_model->editRefundreturn($condition, $refund_array);
  176. $this->log('退货确认,退货编号' . $return['refund_sn']);
  177. // 发送买家消息
  178. $param = array();
  179. $param['code'] = 'refund_return_notice';
  180. $param['member_id'] = $return['buyer_id'];
  181. //阿里短信参数
  182. $param['ali_param'] = array(
  183. 'refund_sn' => $return['refund_sn']
  184. );
  185. $param['ten_param'] = array(
  186. $return['refund_sn']
  187. );
  188. $param['param'] = array_merge($param['ali_param'],array(
  189. 'refund_url' => HOME_SITE_URL .'/memberreturn/view?return_id='.$return['refund_id'],
  190. ));
  191. //微信模板消息
  192. $param['weixin_param'] = array(
  193. 'url' => config('ds_config.h5_site_url').'/member/return_view?refund_id='.$return['refund_id'],
  194. 'data'=>array(
  195. "keyword1" => array(
  196. "value" => $return['order_sn'],
  197. "color" => "#333"
  198. ),
  199. "keyword2" => array(
  200. "value" => $return['refund_amount'],
  201. "color" => "#333"
  202. )
  203. ),
  204. );
  205. model('cron')->addCron(array('cron_exetime'=>TIMESTAMP,'cron_type'=>'sendMemberMsg','cron_value'=>serialize($param)));
  206. dsLayerOpenSuccess(lang('ds_common_save_succ'));
  207. } else {
  208. $this->error(lang('ds_common_save_fail'));
  209. }
  210. }
  211. View::assign('trade_no', $order['trade_no']);
  212. View::assign('return', $return);
  213. $info['buyer'] = array();
  214. if (!empty($return['pic_info'])) {
  215. $info = unserialize($return['pic_info']);
  216. }
  217. View::assign('pic_list', $info['buyer']);
  218. return View::fetch('edit');
  219. }
  220. /**
  221. * 退货记录查看页
  222. *
  223. */
  224. public function view() {
  225. $refundreturn_model = model('refundreturn');
  226. $condition = array();
  227. $condition[] = array('refund_id','=',intval(input('param.refund_id')));
  228. $return = $refundreturn_model->getRefundreturnInfo($condition);
  229. if(empty($return)){
  230. $this->error(lang('param_error'));
  231. }
  232. View::assign('return', $return);
  233. $info['buyer'] = array();
  234. if (!empty($return['pic_info'])) {
  235. $info = unserialize($return['pic_info']);
  236. }
  237. View::assign('pic_list', $info['buyer']);
  238. return View::fetch('view');
  239. }
  240. /**
  241. * 导出
  242. *
  243. */
  244. public function export_step1() {
  245. $refundreturn_model = model('refundreturn');
  246. $condition = array();
  247. $keyword_type = array('order_sn', 'refund_sn', 'store_name', 'buyer_name', 'goods_name');
  248. $key = input('get.key');
  249. $type = input('get.type');
  250. if (trim($key) != '' && in_array($type, $keyword_type)) {
  251. $condition[]=array($type,'like', '%' . $key . '%');
  252. }
  253. $add_time_from = input('get.add_time_from');
  254. $add_time_to = input('get.add_time_to');
  255. if (trim($add_time_from) != '') {
  256. $add_time_from = strtotime(trim($add_time_from));
  257. if ($add_time_from !== false) {
  258. $condition[] = array('add_time','>=', $add_time_from);
  259. }
  260. }
  261. if (trim($add_time_to) != '') {
  262. $add_time_to = strtotime(trim($add_time_to))+86399;
  263. if ($add_time_to !== false) {
  264. $condition[] = array('add_time','<=', $add_time_to);
  265. }
  266. }
  267. if (!is_numeric(input('param.page'))) {
  268. $count = $refundreturn_model->getReturnCount($condition);
  269. $export_list = array();
  270. if ($count > self::EXPORT_SIZE) { //显示下载链接
  271. $page = ceil($count / self::EXPORT_SIZE);
  272. for ($i = 1; $i <= $page; $i++) {
  273. $limit1 = ($i - 1) * self::EXPORT_SIZE + 1;
  274. $limit2 = $i * self::EXPORT_SIZE > $count ? $count : $i * self::EXPORT_SIZE;
  275. $export_list[$i] = $limit1 . ' ~ ' . $limit2;
  276. }
  277. View::assign('export_list', $export_list);
  278. return View::fetch('/public/excel');
  279. } else { //如果数量小,直接下载
  280. $data = $refundreturn_model->getReturnList($condition, '', '*', 'refund_id desc', self::EXPORT_SIZE);
  281. $this->createExcel($data);
  282. }
  283. } else { //下载
  284. $limit1 = (input('param.page') - 1) * self::EXPORT_SIZE;
  285. $limit2 = self::EXPORT_SIZE;
  286. $data = $refundreturn_model->getReturnList($condition, $limit2, '*', 'refund_id desc');
  287. $this->createExcel($data);
  288. }
  289. }
  290. /**
  291. * 生成excel
  292. *
  293. * @param array $data
  294. */
  295. private function createExcel($data = array()) {
  296. Lang::load(base_path() .'admin/lang/'.config('lang.default_lang').'/export.lang.php');
  297. $excel_obj = new \excel\Excel();
  298. $excel_data = array();
  299. //设置样式
  300. $excel_obj->setStyle(array('id' => 's_title', 'Font' => array('FontName' => '宋体', 'Size' => '12', 'Bold' => '1')));
  301. //header
  302. $excel_data[0][] = array('styleid' => 's_title', 'data' => lang('ds_order_sn'));
  303. $excel_data[0][] = array('styleid' => 's_title', 'data' => lang('exp_th_order_returnsn'));
  304. $excel_data[0][] = array('styleid' => 's_title', 'data' => lang('ds_store_name'));
  305. $excel_data[0][] = array('styleid' => 's_title', 'data' => lang('ds_goods_name'));
  306. $excel_data[0][] = array('styleid' => 's_title', 'data' => lang('ds_buyer_name'));
  307. $excel_data[0][] = array('styleid' => 's_title', 'data' => lang('exp_th_add_time'));
  308. $excel_data[0][] = array('styleid' => 's_title', 'data' => lang('exp_th_refund_amount'));
  309. $excel_data[0][] = array('styleid' => 's_title', 'data' => lang('exp_th_goods_num'));
  310. //data
  311. foreach ((array) $data as $k => $v) {
  312. $tmp = array();
  313. $tmp[] = array('data' => 'DS' . $v['order_sn']);
  314. $tmp[] = array('data' => $v['refund_sn']);
  315. $tmp[] = array('data' => $v['store_name']);
  316. $tmp[] = array('data' => $v['goods_name']);
  317. $tmp[] = array('data' => $v['buyer_name']);
  318. $tmp[] = array('data' => date('Y-m-d H:i:s', $v['add_time']));
  319. $tmp[] = array('format' => 'Number', 'data' => ds_price_format($v['refund_amount']));
  320. $tmp[] = array('data' => $v['goods_num']);
  321. $excel_data[] = $tmp;
  322. }
  323. $excel_data = $excel_obj->charset($excel_data, CHARSET);
  324. $excel_obj->addArray($excel_data);
  325. $excel_obj->addWorksheet($excel_obj->charset(lang('exp_th_return'), CHARSET));
  326. $excel_obj->generateXML($excel_obj->charset(lang('exp_th_return'), CHARSET) . input('param.page') . '-' . date('Y-m-d-H', TIMESTAMP));
  327. }
  328. /**
  329. * 获取卖家栏目列表,针对控制器下的栏目
  330. */
  331. protected function getAdminItemList() {
  332. $menu_array = array(
  333. array(
  334. 'name' => 'return_manage',
  335. 'text' => lang('refund_state_confirm'),
  336. 'url' => (string)url('Returnmanage/return_manage')
  337. ),
  338. array(
  339. 'name' => 'return_all',
  340. 'text' => lang('refund_all'),
  341. 'url' => (string)url('Returnmanage/return_all')
  342. ),
  343. );
  344. if(request()->action() == 'edit') {
  345. $menu_array[] = array(
  346. 'name' => 'edit', 'text' => lang('ds_verify'), 'url' => 'javascript:void(0)',
  347. );
  348. }
  349. return $menu_array;
  350. }
  351. }
  352. ?>