Wenzhen.php 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420
  1. <?php
  2. namespace app\api\controller;
  3. use app\common\controller\Api;
  4. use think\Db;
  5. use addons\epay\library\Service;
  6. /**
  7. * 问诊订单
  8. */
  9. class Wenzhen extends Api
  10. {
  11. protected $noNeedLogin = '';
  12. protected $noNeedRight = '*';
  13. //创建订单
  14. public function create_order(){
  15. $member_id = input('member_id',0);
  16. $doctor_id = input('doctor_id',0);
  17. $ordertype = input('ordertype',0);
  18. $book_time = input('book_time',0);
  19. $member_disease = input('member_disease','');
  20. $member_images = input('member_images','');
  21. $auth_id = $this->auth->id;
  22. $order_no = createUniqueNo('W',$auth_id);
  23. //成员信息
  24. $member_info = Db::name('user_member')->where('user_id',$auth_id)->where('id',$member_id)->find();
  25. if(empty($member_info)){
  26. $this->error('不存在的就诊者');
  27. }
  28. //医生信息
  29. $doctor_info = Db::name('doctor_info')->where('doctor_id',$doctor_id)->find();
  30. if(empty($doctor_info)){
  31. $this->error('不存在的医生');
  32. }
  33. //ordertype
  34. if(!in_array($ordertype,[1,2])){
  35. $this->error();
  36. }
  37. //价格
  38. $price = 0;
  39. if($ordertype == 1){
  40. if($doctor_info['typing_switch'] != 1){
  41. $this->error('该医生未开通图文问诊');
  42. }
  43. $price = $doctor_info['typing_price'];
  44. }
  45. if($ordertype == 2){
  46. if($doctor_info['video_switch'] != 1){
  47. $this->error('该医生未开通视频问诊');
  48. }
  49. $price = $doctor_info['video_price'];
  50. }
  51. if($price <= 0){
  52. $this->error('价格为零');
  53. }
  54. //订单数据
  55. $order_data = [
  56. 'order_no' => $order_no,
  57. 'user_id' => $auth_id,
  58. 'member_id' => $member_id,
  59. 'doctor_id' => $doctor_id,
  60. 'ordertype' => $ordertype,
  61. 'total_fee' => $price,
  62. 'book_time' => strtotime($book_time),
  63. 'createtime' => time(),
  64. 'status' => 0,//订单状态enum
  65. ];
  66. Db::startTrans();
  67. //下单
  68. $order_id = Db::name('wenzhen_order')->insertGetId($order_data);
  69. if(!$order_id){
  70. Db::rollback();
  71. $this->error('下单失败');
  72. }
  73. //订单附表,就诊人信息
  74. $member_data = $member_info;
  75. unset($member_data['id']);
  76. $member_data['order_id'] = $order_id;
  77. $member_data['member_id'] = $member_info['id'];
  78. $member_data['member_disease'] = $member_disease;
  79. $member_data['member_images'] = $member_images;
  80. $order_member_id = Db::name('wenzhen_order_member')->insertGetId($member_data);
  81. if(!$order_member_id){
  82. Db::rollback();
  83. $this->error('下单失败');
  84. }
  85. //
  86. Db::commit();
  87. $this->success('下单成功',$order_id);
  88. }
  89. //支付订单
  90. public function pay_order(){
  91. $order_id = input('order_id',0);
  92. $pay_type = input('pay_type','wechat');
  93. //pay_type
  94. if(!in_array($pay_type,['wechat','alipay','wallet'])){
  95. $this->error();
  96. }
  97. //订单详情
  98. $wenzhen_order = Db::name('wenzhen_order')->where('user_id',$this->auth->id)->where('id',$order_id)->find();
  99. if(empty($wenzhen_order)){
  100. $this->error('不存在的订单');
  101. }
  102. if($wenzhen_order['status'] != 0){
  103. $this->error('该订单不能支付');
  104. }
  105. if($pay_type == 'wallet'){
  106. Db::startTrans();
  107. //扣钱
  108. $logtype = $wenzhen_order['ordertype'] == 1 ? 11 : 12;
  109. $rs_wallet = model('wallet')->lockChangeAccountRemain($this->auth->id,'money',$wenzhen_order['total_fee'],$logtype,'图文问诊'.$wenzhen_order['order_no'],'wenzhen_order',$order_id);
  110. if($rs_wallet['status'] == false){
  111. Db::rollback();
  112. $this->error($rs_wallet['msg']);
  113. }
  114. //订单改为已支付
  115. $wenzhen_update['status'] = 10;//订单状态enum
  116. $wenzhen_update['pay_type'] = $pay_type;
  117. $wenzhen_update['pay_time'] = time();
  118. $update_rs = Db::name('wenzhen_order')->where('id',$order_id)->where('status',0)->update($wenzhen_update);
  119. if(!$update_rs){
  120. Db::rollback();
  121. $this->error('支付失败,重试一下吧');
  122. }
  123. Db::commit();
  124. $result = [
  125. 'pay_type' => $pay_type,
  126. 'pay_params' => '',
  127. ];
  128. $this->success(1,$result);
  129. }
  130. //创建订单
  131. $platform = 'app';
  132. $data = [];
  133. $data['user_id'] = $this->auth->id;
  134. $data['out_trade_no'] = createUniqueNo('W',$this->auth->id);
  135. $data['order_amount'] = $wenzhen_order['total_fee'];
  136. $data['createtime'] = time();
  137. $data['pay_type'] = $pay_type;
  138. $data['platform'] = $platform;
  139. $data['order_status'] = 0;
  140. $data['table_name'] = 'wenzhen_order';
  141. $data['table_id'] = $order_id;
  142. $data['args'] = '';
  143. $orderid = Db::name('pay_order')->insertGetId($data);
  144. $openid = '';
  145. //下单
  146. $params = [
  147. 'type' => $pay_type,
  148. 'orderid' => $data['out_trade_no'],
  149. 'title' => '支付订单',
  150. 'amount' => $data['order_amount'],
  151. 'method' => $platform,
  152. 'openid' => $openid,
  153. 'notifyurl' => config('pay_notify_url').'/api/notify/wenzhen_notify_base/paytype/'.$pay_type,
  154. 'returnurl' => '',
  155. ];
  156. $res = Service::submitOrder($params);
  157. $result = [
  158. 'pay_type'=> $pay_type,
  159. 'pay_params'=> $pay_type
  160. ];
  161. if($pay_type == 'wechat'){
  162. $result['pay_params'] = json_decode($res,true);
  163. }else{
  164. $result['pay_params'] = $res;
  165. }
  166. $this->success(1,$result);
  167. }
  168. //订单列表
  169. public function order_list(){
  170. $status = input('status','all');
  171. $where = ['user_id'=>$this->auth->id];
  172. if($status != 'all'){
  173. $where['order.status'] = $status;
  174. if($status == 20){// 已接诊、问诊中
  175. $where['order.status'] = ['IN',[20,25]];
  176. }
  177. }
  178. $field = [
  179. 'order.id','order.order_no','order.createtime','order.status','order.ordertype','order.accept_time','order.video_time','order.doctor_id',
  180. 'doctor.avatar as doctor_avatar','doctor.nickname as doctor_nickname',
  181. ];
  182. $list = Db::name('wenzhen_order')->alias('order')
  183. ->field($field)
  184. ->join('doctor','order.doctor_id = doctor.id','LEFT')
  185. ->order('order.id desc')
  186. ->where($where)
  187. ->autopage()->select();
  188. $list = list_domain_image($list,['doctor_avatar']);
  189. if(!empty($list)){
  190. //循环处理
  191. foreach($list as $key => $val){
  192. $val = $this->orderinfo_appen($val);
  193. //医生原因的退款,都直接算到退珍
  194. if(in_array($val['status'],[16,18,22])){
  195. $val['status'] = 100;
  196. }
  197. //视频拨打中 也算问诊中
  198. if($val['status'] == 25){
  199. $val['status'] = 20;
  200. }
  201. $list[$key] = $val;
  202. }
  203. }
  204. $this->success(1,$list);
  205. }
  206. //单个订单,追加数据
  207. private function orderinfo_appen($val){
  208. //订单类型
  209. $ordertype_data = [
  210. 1 => ['name'=>'图文订单','name_en'=>'Visual Order'],
  211. 2 => ['name'=>'视频订单','name_en'=>'Video Order'],
  212. ];
  213. //状态备注
  214. $status_data = $this->order_status_enum();
  215. //开始处理
  216. //订单类型,辅助
  217. $val['ordertype_data'] = $ordertype_data[$val['ordertype']];
  218. //订单状态,辅助
  219. $status_data_val = $status_data[$val['status']];
  220. //未支付订单N分钟后自动取消
  221. if($val['status'] == 0){
  222. $remain_time = $val['createtime'] + (config('site.nopay_order_autocancel_minute')*60) - time();
  223. if($remain_time > 0){
  224. $status_data_val['minute'] = Sec2Time($remain_time);
  225. $status_data_val['minute_en'] = Sec2Time_en($remain_time);
  226. $status_data_val['seconds'] = $remain_time;
  227. }
  228. }
  229. //图文订单接诊后N分钟自动结束
  230. if($val['status'] == 20){
  231. $remain_time = $val['accept_time'] + (config('site.accept_textorder_autofinish_minute')*60) - time();
  232. if($remain_time > 0){
  233. $status_data_val['minute'] = Sec2Time($remain_time);
  234. $status_data_val['minute_en'] = Sec2Time_en($remain_time);
  235. $status_data_val['seconds'] = $remain_time;
  236. }
  237. }
  238. //视频订单接通后N分钟自动结束
  239. if($val['status'] == 25 && $val['ordertype'] == 2){
  240. $remain_time = $val['video_time'] + (config('site.accept_videoorder_autofinish_minute')*60) - time();
  241. if($remain_time > 0){
  242. $status_data_val['minute'] = Sec2Time($remain_time);
  243. $status_data_val['minute_en'] = Sec2Time_en($remain_time);
  244. $status_data_val['seconds'] = $remain_time;
  245. }
  246. }
  247. $val['status_data'] = $status_data_val;
  248. //处理完成,返回
  249. return $val;
  250. }
  251. //订单状态备注枚举
  252. private function order_status_enum(){
  253. //状态:0=未付款,3=已失效,10=待接诊,13=用户退诊,16=医生未接诊,18=医生退诊,20=已接诊,22=超时未拨打,25=视频通话中,30=问诊完成
  254. $status_data = [
  255. 0 => [
  256. 'name'=>'等待支付时间',
  257. 'name_en'=>'Waiting time for payment',
  258. 'minute' => '',
  259. 'minute_en' => '',
  260. 'seconds' => 0,
  261. ],
  262. 3 => [
  263. 'name'=>'您的订单未及时支付,已失效',
  264. 'name_en'=>'Your order was not paid on time and has expired.',
  265. 'minute' => '',
  266. 'minute_en' => '',
  267. 'seconds' => 0,
  268. ],
  269. 10 => [
  270. 'name'=>'等待医生接诊:已通知医生尽快接诊,超时自动取消订单并退款',
  271. 'name_en'=>'Waiting for the doctor. If not accepted within the specified time,the consultation will be automatically canceled, and a refund will be issued',
  272. 'minute' => '',
  273. 'minute_en' => '',
  274. 'seconds' => 0,
  275. ],
  276. 13 => [
  277. 'name'=>'您的订单已退珍',
  278. 'name_en'=>'Your order has been canceled',
  279. 'minute' => '',
  280. 'minute_en' => '',
  281. 'seconds' => 0,
  282. ],
  283. 16 => [
  284. 'name'=>'医生未接诊',
  285. 'name_en'=>'Doctor Not received',
  286. 'minute' => '',
  287. 'minute_en' => '',
  288. 'seconds' => 0,
  289. ],
  290. 18 => [
  291. 'name'=>'您的订单已被退诊',
  292. 'name_en'=>'Your order has been returned for consultation',
  293. 'minute' => '',
  294. 'minute_en' => '',
  295. 'seconds' => 0,
  296. ],
  297. 20 => [
  298. 'name'=>'医生已接诊,咨询中',
  299. 'name_en'=>'',
  300. 'minute' => '',
  301. 'minute_en' => '',
  302. 'seconds' => 0,
  303. ],
  304. 22 => [
  305. 'name'=>'医生超时未拨打视频',
  306. 'name_en'=>'',
  307. 'minute' => '',
  308. 'minute_en' => '',
  309. 'seconds' => 0,
  310. ],
  311. 25 => [
  312. 'name'=>'视频通话中',
  313. 'name_en'=>'Time Remaining',
  314. 'minute' => '',
  315. 'minute_en' => '',
  316. 'seconds' => 0,
  317. ],
  318. 30 => [
  319. 'name'=>'点击查看医生反馈结果',
  320. 'name_en'=>'Click to view the consultation results',
  321. 'minute' => '',
  322. 'minute_en' => '',
  323. 'seconds' => 0,
  324. ],
  325. ];
  326. return $status_data;
  327. }
  328. //订单详情
  329. public function order_info(){
  330. $order_id = input('order_id',0);
  331. //订单详情
  332. $wenzhen_order = Db::name('wenzhen_order')->where('user_id',$this->auth->id)->where('id',$order_id)->find();
  333. if(empty($wenzhen_order)){
  334. $this->error('不存在的订单');
  335. }
  336. $wenzhen_order = info_domain_image($wenzhen_order,['feedback_images']);
  337. $wenzhen_order = $this->orderinfo_appen($wenzhen_order);
  338. //就诊人详情
  339. $order_member_info = Db::name('wenzhen_order_member')->where('order_id',$order_id)->find();
  340. $order_member_info = info_domain_image($order_member_info,['member_images']);
  341. $order_member_info['age'] = birthtime_to_age($order_member_info['birthday']);
  342. $wenzhen_order['member_info'] = $order_member_info;
  343. //医生详情
  344. $field = [
  345. 'd.nickname','d.avatar','d.keshi_id','d.level_id','d.hospital','d.goodat','d.ordernum',
  346. 'keshi.name as keshi_name',
  347. 'level.name as level_name'
  348. ];
  349. $doctor_info = Db::name('doctor')->alias('d')
  350. ->field($field)
  351. ->join('doctor_level level','d.level_id = level.id','LEFT')
  352. ->join('keshi','d.keshi_id = keshi.id','LEFT')
  353. ->where('d.id',$wenzhen_order['doctor_id'])->find();
  354. $doctor_info = info_domain_image($doctor_info,['avatar']);
  355. $wenzhen_order['doctor_info'] = $doctor_info;
  356. $this->success(1,$wenzhen_order);
  357. }
  358. }