Buy.php 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304
  1. <?php
  2. # 支付
  3. namespace Mshop\Lib;
  4. use Dever;
  5. class Buy
  6. {
  7. # 发起支付
  8. public function action($shop, $name, $num, $goods, $price, $info, $refer = '')
  9. {
  10. if (!$shop) {
  11. Dever::alert('错误的门店信息');
  12. }
  13. $order_data['shop_id'] = $shop['id'];
  14. $order_data['mobile'] = $shop['mobile'];
  15. $order_data['name'] = $name;
  16. $order_data['num'] = $num;
  17. $order_data['info'] = $info;
  18. $order_data['price'] = $price;
  19. $order_data['area'] = $shop['area'];
  20. $order_data['province'] = $shop['province'];
  21. $order_data['city'] = $shop['city'];
  22. $order_data['county'] = $shop['county'];
  23. $order_data['town'] = $shop['town'];
  24. $order_data['order_num'] = $this->getOrderId();
  25. $order_data['pay_id'] = $order_data['order_num'];
  26. $order_data['pay_status'] = 1;
  27. $order_data['pay_price'] = 0;
  28. $id = Dever::db('shop/buy_order')->insert($order_data);
  29. if (!$id) {
  30. Dever::alert('支付失败');
  31. }
  32. foreach($goods as $k => $v) {
  33. $data['shop_id'] = $shop['id'];
  34. $data['order_id'] = $id;
  35. $data['goods_id'] = $v['id'];
  36. $data['sku_id'] = $v['sku_id'];
  37. $data['price'] = $v['price'];
  38. $data['num'] = $v['buy_num'];
  39. Dever::db('shop/buy_order_goods')->insert($data);
  40. }
  41. if ($card || $price <= 0) {
  42. $param['pay_product_id'] = $id;
  43. $param['pay_order_id'] = $order_data['pay_id'];
  44. $param['pay_status'] = 2;
  45. $param['pay_cash'] = $price;
  46. $param['pay_msg'] = '';
  47. $this->success($param);
  48. return 'ok';
  49. }
  50. $param = array
  51. (
  52. 'project_id' => 1,
  53. 'channel_id' => 1,
  54. 'system_source' => 5,
  55. 'uid' => -1,
  56. 'name' => $order_data['name'],
  57. 'cash' => $price,
  58. 'product_id' => $id,
  59. 'order_id' => $order_data['pay_id'],
  60. 'refer' => $refer,
  61. );
  62. $receipt = Dever::input('receipt');
  63. if ($receipt) {
  64. $param['receipt'] = $receipt;
  65. }
  66. $result = Dever::load('pay/api.pay', $param);
  67. return $result;
  68. }
  69. # 再次发起支付
  70. public function raction($id, $refer = '')
  71. {
  72. $order = Dever::db('goods/order')->find($id);
  73. if (!$order) {
  74. Dever::alert('订单信息错误');
  75. }
  76. if ($order['status'] > 1) {
  77. Dever::alert('订单已支付或已取消');
  78. }
  79. $param = array
  80. (
  81. 'project_id' => 1,
  82. 'account_id' => 5,
  83. 'uid' => -1;
  84. 'name' => $order['name'],
  85. 'cash' => $order['price'],
  86. 'product_id' => $id,
  87. 'order_id' => $order['pay_id'],
  88. 'refer' => $refer,
  89. );
  90. $receipt = Dever::input('receipt');
  91. if ($receipt) {
  92. $param['receipt'] = $receipt;
  93. }
  94. $result = Dever::load('pay/api.pay', $param);
  95. return $result;
  96. }
  97. # 支付成功回调 安全加密 设置token
  98. public function success_secure_api_token()
  99. {
  100. $project_id = Dever::input('pay_project_id');
  101. $info = Dever::db('pay/project')->one($project_id);
  102. if ($info) {
  103. return $info['key'];
  104. }
  105. return 'shop_buy_dever_2020';
  106. }
  107. # 支付成功回调 安全加密
  108. public function success_secure_api($param = array())
  109. {
  110. $this->success($param);
  111. }
  112. # 支付成功回调
  113. public function success($param = array())
  114. {
  115. $send = $param ? $param : Dever::preInput('pay_');
  116. $product_id = $send['pay_product_id'];
  117. $order_id = $send['pay_order_id'];
  118. $status = $send['pay_status'];
  119. $cash = $send['pay_cash'];
  120. $msg = $send['pay_msg'];
  121. $order = Dever::db('shop/buy_order')->one(array('id' => $product_id, 'time' => time()));
  122. if ($order && $order['pay_status'] == 1) {
  123. if ($status == 2) {
  124. # 发消息
  125. if (Dever::project('message')) {
  126. Dever::load('message/lib/data')->push(-1, $order['shop_id'], '订购成功通知', '购买成功', 1);
  127. }
  128. }
  129. $update['pay_status'] = $status;
  130. $update['status'] = 2;
  131. $update['where_id'] = $order['id'];
  132. $update['pay_time'] = time();
  133. $update['pay_price'] = $cash;
  134. Dever::db('shop/buy_order')->update($update);
  135. }
  136. return 'ok';
  137. }
  138. # 生成订单号
  139. public function getOrderId()
  140. {
  141. $where['order_num'] = Dever::order('C');
  142. $state = Dever::db('shop/buy_order')->one($where);
  143. if (!$state) {
  144. return $where['order_num'];
  145. } else {
  146. return $this->getOrderId();
  147. }
  148. }
  149. # 展示订单详情
  150. public function show()
  151. {
  152. $id = Dever::input('order_id');
  153. $config = Dever::db('shop/buy_order')->config;
  154. $info = Dever::db('shop/buy_order')->one($id);
  155. $shop = Dever::db('shop/info')->find($info['shop_id']);
  156. $html = '[基本信息]:<table class="layui-table"><thead><tr><th style="width:20%">项目</th><th style="width:80%">详情</th></tr> </thead><tbody>';
  157. $html .= '<tr>
  158. <td>订单号</td>
  159. <td>'.$this->table(false, array(array($info['order_num']))).'</td>
  160. </tr>';
  161. $html .= '<tr>
  162. <td>门店信息</td>
  163. <td>'.$this->table(false, array(array('门店名称:' . $shop['name'], '联系人:' . $shop['truename'], '联系电话:' . $shop['mobile']))).'</td>
  164. </tr>';
  165. $html .= '<tr>
  166. <td>订单信息</td>
  167. <td>'.$this->table(array('订单状态', '金额', '数量'), array(array($config['status'][$info['status']], $info['price'], $info['num']))).'</td>
  168. </tr>';
  169. # 增加仓库和工厂信息
  170. $html .= '</tbody></table>';
  171. $html .= '[商品清单]:';
  172. $head = array('商品名称', '商品属性', '商品价格', '商品数量');
  173. $body = array();
  174. $goods = Dever::db('shop/buy_order_goods')->select(array('order_id' => $info['id']));
  175. foreach ($goods as $k => $v) {
  176. $goods_info = Dever::load('goods/lib/info')->getInfoBySku($v['goods_id'], $v['sku_id']);
  177. $body[$k] = array
  178. (
  179. $goods_info['name'],
  180. $v['price'],
  181. $v['price'],
  182. $v['num'],
  183. );
  184. }
  185. $html .= $this->table($head, $body);
  186. return $html;
  187. }
  188. private function table($head, $data)
  189. {
  190. $html = '';
  191. if ($head) {
  192. $html = '<table class="layui-table">';
  193. $html .= '<thead><tr>';
  194. foreach ($head as $k => $v) {
  195. $html .= '<th>'.$v.'</th>';
  196. }
  197. $html .= '</tr></thead>';
  198. $html .= '<tbody>';
  199. foreach ($data as $k => $v) {
  200. $html .= '<tr>';
  201. foreach ($v as $k1 => $v1) {
  202. $html .= '<td>'.$v1.'</td>';
  203. }
  204. $html .= '</tr>';
  205. }
  206. $html .= '</tbody>';
  207. $html .= '</table>';
  208. } else {
  209. foreach ($data as $k => $v) {
  210. $html .= '';
  211. foreach ($v as $k1 => $v1) {
  212. $html .= $v1 . '&nbsp;&nbsp;&nbsp;&nbsp;';
  213. }
  214. $html .= '';
  215. }
  216. }
  217. return $html;
  218. }
  219. # 采购订单审核 拆单
  220. public function audit()
  221. {
  222. $order_id = Dever::input('id');
  223. $info = Dever::db('shop/buy_order')->find($order_id);
  224. $goods = Dever::db('shop/buy_order_goods')->select(array('order_id' => $order_id));
  225. $shop = Dever::db('shop/info')->find($info['shop_id']);
  226. # 获取门店分配的仓库和工厂
  227. $store = Dever::db('shop/store')->select(array('shop_id' => $shop['id']));
  228. $store_id = array();
  229. foreach ($store as $k => $v) {
  230. $store_id[] = $v['store_id'];
  231. }
  232. $store_id = implode(',', $store_id);
  233. $where = ' id in('.$store_id.') and status = 1 ';
  234. $sql = 'select *,round((st_distance(point(lng, lat), point('.$shop['lng'].', '.$shop['lat'].'))*111195)/1000, 2) as distance from {table} where '.$where.' order by distance asc';
  235. $store = Dever::db('factory/info')->$method($sql, array(), $page);
  236. # 得到所有的仓库,先验证库存
  237. foreach ($goods as $k => $v) {
  238. }
  239. }
  240. }