Refund.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296
  1. <?php
  2. namespace Shop\Lib;
  3. use Dever;
  4. class Refund
  5. {
  6. # 设置订单的类型
  7. public function set($type)
  8. {
  9. $this->type = $type;
  10. $this->order_table = 'shop/' . $type . '_order';
  11. $this->goods_table = 'shop/' . $type . '_order_goods';
  12. $this->refund_table = 'shop/' . $type . '_order_refund';
  13. if ($type == 'buy') {
  14. $this->lib = 'mshop/lib/' . $type;
  15. } else {
  16. $this->lib = 'shop/lib/' . $type;
  17. }
  18. return $this;
  19. }
  20. # 获取退款记录
  21. public function getList($type, $id, $order_id)
  22. {
  23. $data = Dever::load($this->lib)->set($type, 1)->getView($id, $order_id, false);
  24. $where['order_id'] = $order_id;
  25. $data = Dever::db($this->refund_table)->select_page($where);
  26. if ($data) {
  27. $goods_status = Dever::db($this->goods_table)->config['status'];
  28. $refund_status = Dever::db($this->refund_table)->config['status'];
  29. $refund_process = Dever::db($this->refund_table)->config['process'];
  30. foreach ($data as $k => $v) {
  31. $data[$k]['cdate'] = date('Y-m-d H:i', $v['cdate']);
  32. $data[$k]['goods'] = Dever::db($this->goods_table)->getDataByIds(array('ids' => $v['order_goods_id']));
  33. $data[$k]['status_name'] = $refund_status[$v['status']];
  34. $data[$k]['process_name'] = $refund_process[$v['process']];
  35. if ($data[$k]['goods']) {
  36. foreach ($data[$k]['goods'] as $k1 => $v1) {
  37. $data[$k]['goods'][$k1]['info'] = Dever::load('goods/lib/info')->getPayInfo($v1['goods_id'], $v1['sku_id']);
  38. $data[$k]['goods'][$k1]['status_name'] = $goods_status[$v1['status']];
  39. }
  40. }
  41. }
  42. }
  43. return $data;
  44. }
  45. # 更新退款记录
  46. public function up($order_id, $order_goods_id, $status, $price, $num = false, $desc = '', $pic = '', $process = 1)
  47. {
  48. $data['order_id'] = $order_id;
  49. if (!$order_goods_id) {
  50. $where['order_id'] = $order_id;
  51. $goods = Dever::db($this->goods_table)->getIds($where);
  52. if ($goods) {
  53. $order_goods_id = implode(',', array_keys($goods));
  54. }
  55. $data['type'] = 1;
  56. } else {
  57. $data['type'] = 2;
  58. }
  59. $data['order_goods_id'] = $order_goods_id;
  60. $info = Dever::db($this->refund_table)->find($data);
  61. $data['status'] = $status;
  62. $data['cash'] = $price;
  63. if ($num) {
  64. $data['num'] = $num;
  65. }
  66. $data['desc'] = $desc;
  67. $data['pic'] = $pic;
  68. $data['process'] = $process;
  69. if ($info) {
  70. $data['where_id'] = $info['id'];
  71. $state = Dever::db($this->refund_table)->update($data);
  72. if ($state) {
  73. return $data;
  74. }
  75. } else {
  76. $state = Dever::db($this->refund_table)->insert($data);
  77. if ($state) {
  78. $data['id'] = $state;
  79. return $data;
  80. }
  81. }
  82. return false;
  83. }
  84. # 申请退款
  85. public function apply($type, $id, $order_id, $order_goods_id, $status = 1, $num = 0, $desc = '', $pic = '', $process = 2)
  86. {
  87. if ($status != 1 && $status != 2 && $status != 3) {
  88. Dever::alert('当前订单状态不允许退货退款');
  89. }
  90. $dec = $num;
  91. $data = Dever::load($this->lib)->set($type, 1)->getView($id, $order_id, false);
  92. $auth = false;
  93. if ($this->type == 'sell' && $type == 1) {
  94. if ($data['status'] == 2) {
  95. $auth = true;
  96. }
  97. } else {
  98. $config = array(2,3,4,5,6);
  99. if (in_array($data['status'], $config)) {
  100. $auth = true;
  101. }
  102. }
  103. if ($auth) {
  104. if ($order_goods_id) {
  105. $info = Dever::db($this->goods_table)->find(array('id' => $order_goods_id, 'order_id' => $data['id'], 'status' => 1));
  106. if ($info) {
  107. Dever::db($this->goods_table)->update(array('where_id' => $info['id'], 'status' => 2));
  108. if (isset($info['coupon_cash']) && $info['coupon_cash']) {
  109. $cash = $info['price'] - $info['coupon_cash'];
  110. } else {
  111. $cash = $info['price'];
  112. }
  113. if ($num > 0) {
  114. $dec = $num;
  115. } else {
  116. $dec = $info['num'];
  117. }
  118. if ($num > 0 && $info['num'] >= $num) {
  119. $dec = $info['num'];
  120. $price = round($cash / $info['num'], 2);
  121. $cash = round($price * $num, 2);
  122. }
  123. } else {
  124. Dever::alert('您没有权限操作');
  125. }
  126. } else {
  127. $cash = $data['price'] - $data['refund_cash'];
  128. }
  129. if ($cash > 0) {
  130. $log = $this->up($data['id'], $order_goods_id, $status, $cash, $dec, $desc, $pic, $process);
  131. if ($this->type == 'buy' && ($data['status'] == 5 || $data['status'] == 6)) {
  132. # 如果是采购单,这里要把库存先减掉
  133. $oper_data = Dever::db($this->goods_table)->getDataByIds(array('ids' => $log['order_goods_id']));
  134. Dever::load('shop/lib/goods')->oper($data, 2, 1, $oper_data);
  135. }
  136. $update = array();
  137. $update['where_id'] = $data['id'];
  138. $update['refund_cash'] = $data['refund_cash'] + $cash;
  139. $update['refund_status'] = 2;
  140. if ($dec > 0) {
  141. $update['num'] = $data['num'] - $dec;
  142. }
  143. Dever::db($this->order_table)->update($update);
  144. if ($id && $process == 2) {
  145. $this->action($log, $process, $data);
  146. }
  147. } else {
  148. Dever::alert('您没有可以退款的金额');
  149. }
  150. } else {
  151. Dever::alert('您没有权限操作');
  152. }
  153. return 'ok';
  154. }
  155. # 确认退款
  156. public function action($info, $process, $order = false)
  157. {
  158. if (!is_array($info)) {
  159. $info = Dever::db($this->refund_table)->find($info);
  160. }
  161. if (!$info) {
  162. Dever::alert('您没有权限操作');
  163. }
  164. if (!$order) {
  165. $order = Dever::db($this->order_table)->find($info['order_id']);
  166. }
  167. if (!$order) {
  168. Dever::alert('您没有权限操作');
  169. }
  170. $state = Dever::db($this->refund_table)->update(array('where_id' => $info['id'], 'process' => $process));
  171. if (!$state) {
  172. Dever::alert('操作失败');
  173. }
  174. $update = array();
  175. if ($process == 3) {
  176. if ($info['num'] && $info['num'] > 0) {
  177. $update['num'] = $order['num'] + $info['num'];
  178. }
  179. $update['refund_cash'] = $order['refund_cash'] - $info['cash'];
  180. $update['where_id'] = $order['id'];
  181. if ($update['refund_cash'] <= 0) {
  182. $update['refund_status'] = 1;
  183. }
  184. $state = Dever::db($this->order_table)->update($update);
  185. if ($info['type'] == 2) {
  186. Dever::db($this->goods_table)->update(array('where_id' => $info['order_goods_id'], 'status' => 1));
  187. }
  188. } else {
  189. if ($info['type'] == 2) {
  190. $state = Dever::db($this->goods_table)->update(array('where_id' => $info['order_goods_id'], 'status' => 3));
  191. if ($state) {
  192. $this->notice($state, $order, $info['cash']);
  193. # 检查这个订单下的商品是不是都退了
  194. $total = Dever::db($this->goods_table)->total(array('order_id' => $order['id'], 'status' => 1));
  195. if ($order['status'] == 5) {
  196. $update['status'] = 6;
  197. } elseif ($total <= 0) {
  198. $update['operdate'] = time();
  199. $update['status'] = 8;
  200. }
  201. if ($update) {
  202. $update['where_id'] = $order['id'];
  203. $state = Dever::db($this->order_table)->update($update);
  204. }
  205. }
  206. } else {
  207. $update['where_id'] = $order['id'];
  208. $update['operdate'] = time();
  209. $update['status'] = 8;
  210. $state = Dever::db($this->order_table)->update($update);
  211. if ($state) {
  212. $this->notice($state, $order, $info['cash']);
  213. if (isset($order['user_coupon_id']) && $order['user_coupon_id']) {
  214. # 还原优惠券
  215. Dever::db('shop/user_coupon')->update(array('where_id' => $order['user_coupon_id'], 'status' => 1));
  216. }
  217. }
  218. }
  219. }
  220. $data = Dever::db($this->goods_table)->getDataByIds(array('ids' => $info['order_goods_id']));
  221. if ($this->type == 'sell' && $process == 2) {
  222. # 如果是销售单,退款后要减少销量
  223. Dever::load('shop/lib/goods')->oper($order, 2, 2, $data);
  224. } elseif ($this->type == 'buy' && $process == 3 && ($order['status'] == 5 || $order['status'] == 6)) {
  225. # 如果是采购单,退款后要恢复库存
  226. Dever::load('shop/lib/goods')->oper($order, 1, 1, $data);
  227. }
  228. return 'ok';
  229. }
  230. # 获取部分退款的详情
  231. public function getInfo($type, $id, $order_id, $order_goods_id)
  232. {
  233. $data = Dever::load($this->lib)->set($type, 1)->getView($id, $order_id, false);
  234. $info = Dever::db($this->goods_table)->find(array('id' => $order_goods_id, 'order_id' => $data['id'], 'status' => 1));
  235. if ($info) {
  236. if (isset($info['coupon_cash']) && $info['coupon_cash']) {
  237. $info['tui_price'] = $info['price'] - $info['coupon_cash'];
  238. } else {
  239. $info['tui_price'] = $info['price'];
  240. }
  241. $info['tui_one_price'] = round($info['tui_price'] / $info['num'], 2);
  242. $info['goods'] = Dever::db('goods/info')->find($info['goods_id']);
  243. }
  244. return $info;
  245. }
  246. # 退款通知
  247. public function notice($state, $data, $refund_cash)
  248. {
  249. if ($state && isset($data['uid']) && $data['uid'] > 0) {
  250. $shop = Dever::db('shop/info')->one($data['shop_id']);
  251. $msg_param['type'] = 1;//消息类型1是订单消息
  252. $msg_param['id'] = $data['id'];
  253. $msg_param['name'] = $shop['name'];
  254. $msg_param = Dever::json_encode($msg_param);
  255. $msg = '您有一笔订单已退款,退款将在3个工作日内返回原支付账户';
  256. Dever::load('message/lib/data')->push(-1, $data['uid'], '退款成功通知', $msg, 2, 1, false, $msg_param);
  257. # 退款到原支付账户 待处理
  258. }
  259. }
  260. }