ConsultingOrdersController.php 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370
  1. <?php
  2. namespace App\Admin\Controllers\OrdersManagement;
  3. use App\Admin\Actions\backstage\Orders\CallLog;
  4. use App\Admin\Actions\backstage\Orders\Evaluate;
  5. use App\Admin\Actions\backstage\Orders\Message;
  6. use App\Admin\Actions\backstage\Orders\OrderDetails;
  7. use App\Admin\Actions\backstage\Orders\OrderOpinion;
  8. use App\Admin\Actions\backstage\Orders\RefundApplicationAction;
  9. use App\Admin\Actions\backstage\User\MapDepot;
  10. use App\Admin\Actions\backstage\User\Suggests;
  11. use App\Models\ImMessage;
  12. use App\Models\Order;
  13. use App\Models\OrderPack;
  14. use App\Models\ServicePack;
  15. use Encore\Admin\Layout\Content;
  16. use Encore\Admin\Widgets\Table;
  17. use Encore\Admin\Controllers\AdminController;
  18. use Encore\Admin\Form;
  19. use Encore\Admin\Grid;
  20. use Encore\Admin\Show;
  21. use Illuminate\Http\Request;
  22. use Encore\Admin\Facades\Admin;
  23. class ConsultingOrdersController extends AdminController
  24. {
  25. /**
  26. * Title for current resource.
  27. *
  28. * @var string
  29. */
  30. protected $title = '咨询订单';
  31. /**
  32. * Make a grid builder.
  33. *
  34. * @return Grid
  35. */
  36. protected function grid()
  37. {
  38. $grid = new Grid(new Order());
  39. $grid->disableCreateButton();
  40. $grid->model()->wherein('product_type',[1,2]);
  41. //筛选
  42. $grid->filter(function ($filter){
  43. $filter->disableIdFilter();
  44. $filter->column(1/2, function ($filter) {
  45. $filter->like('user.nickname','用户姓名');
  46. $filter->like('docter.name','医生姓名');
  47. $filter->like('orderPatient.name','患者姓名');
  48. $filter->equal('product_type','产品类型')->radio(
  49. [
  50. ''=>'不限',
  51. 1=>'电话咨询',
  52. 2=>'图文咨询',
  53. ]
  54. );
  55. $filter->in('evaluate.score','评分')->checkbox([
  56. 1 => 1,
  57. 2 => 2,
  58. 3 => 3,
  59. 4 => 4,
  60. 5 => 5,
  61. ]);
  62. });
  63. $filter->column(1/2, function ($filter) {
  64. $filter->equal('order_status','订单状态')->radio(
  65. [
  66. ''=>'不限',
  67. 1=>'未支付',
  68. 2=>'待接单',
  69. 3=>'进行中',
  70. 4=>'已完成',
  71. 5=>'已取消',
  72. 6=>'已超时'
  73. ]
  74. );
  75. $filter->equal('payment_status','支付状态')->radio(
  76. [
  77. ''=>'不限',
  78. 1=>'待付款',
  79. 2=>'已付款',
  80. 3=>'退款中',
  81. 4=>'已退款',
  82. 5=>'待退款',
  83. ]
  84. );
  85. $filter->timestampBetween('payment_time', "支付时间")->datetime();
  86. $filter->timestampBetween('receiving_time', "接单时间")->datetime();
  87. $filter->timestampBetween('end_time', "订单完成时间")->datetime();
  88. // 设置datetime类型
  89. $filter->between('created_at','创建时间')->datetime();
  90. });
  91. });
  92. //操作
  93. $grid->actions(function ($actions){
  94. $actions->disableView();
  95. $actions->disableEdit();
  96. $actions->disableDelete();
  97. $actions->add(new OrderOpinion());
  98. if ($actions->row->order_status == 4)
  99. {
  100. $actions->add(new Message());
  101. }
  102. if ($actions->row->order_status == 4&& $actions->row->product_type == 1 )
  103. {
  104. $actions->add(new CallLog());
  105. }
  106. });
  107. $grid->export(function ($export) {
  108. $export->filename('咨询订单');
  109. $export->except(['is_evaluates']);
  110. });
  111. $status_arr = Order::getStatus();
  112. $grid->model()->orderBy('id','desc');
  113. $grid->column('id', __('Id'))->sortable();
  114. $grid->column('user.nickname', __('用户姓名'));
  115. $grid->column('docter.name', __('医生姓名'));
  116. $grid->column('orderPatient.name', __('患者姓名'));
  117. $grid->column('orderPatient.patient_phone', __('患者电话'));
  118. $grid->column('orderPatient.symptoms', __('患者描述'));
  119. $grid->column('product_type', __('产品类型'))->using([1=>'电话咨询',2=>'图文咨询',3=>'门诊预约',4=>'疫苗接种预约',5=>'儿保预约',6=>'服务包',7=>'充值',8=>'快速预约']);
  120. $grid->column('payment_type', __('支付方式'))->display(function ($payment_type){
  121. if ($payment_type == 1)
  122. {
  123. return '微信支付';
  124. }
  125. if ($payment_type == 2){
  126. return '余额支付';
  127. }
  128. if ($payment_type == 3){
  129. $order_pack_id = OrderPack::where('id',$this->pay_order_pack_id)->value('service_pack_id');
  130. $name = ServicePack::where('id',$order_pack_id)->value('name');
  131. return '服务包支付('.$name.')';
  132. }
  133. });
  134. $grid->column('order_status', __('订单状态'))->display(function ($w) use ($status_arr) {
  135. $info = $status_arr[intval($w)];
  136. if($w == 1 || $w == 2){
  137. return '<span class="label label-warning">'.$info.'</span>';
  138. } else if( $w == 4 ){
  139. return '<span class="label label-success">'.$info.'</span>';
  140. } else if($w == 7 || $w == 3 ){
  141. return '<span class="label label-info">'.$info.'</span>';
  142. } else if($w == 6){
  143. return '<span class="label label-danger">'.$info.'</span>';
  144. } else {
  145. return '<span class="label label-default">'.$info.'</span>';
  146. }
  147. });
  148. $grid->column('payment_status', __('支付状态'))->using([1=>'待付款',2=>'已付款',3=>'退款中',4=>'已退款',5=>'待退款'])->label([1=>'warning',2=>'success',3=>'info',4=>'danger',5=>'default']);
  149. $grid->column('total_amount', __('订单总金额'))->display(function ($money){
  150. return $money/100;
  151. });
  152. $grid->column('payment_amount', __('用户实际支付的金额'))->display(function ($money){
  153. return $money/100;
  154. });
  155. $grid->column('discount_amount', __('折扣金额'))->display(function ($money){
  156. return $money/100;
  157. });
  158. $grid->column('is_evaluates', __('评价详情'))->expand(function ($model){
  159. $infos = $model->evaluate()->get()->map(function ($info){
  160. return $info->only(['order_id','content','status']);
  161. });
  162. $infos = $infos->toArray();
  163. foreach ($infos as $key => $value)
  164. {
  165. if (!empty($infos[$key]))
  166. {
  167. if ($infos[$key]['status'] == 1)
  168. {
  169. $infos[$key]['status'] = '待审核';
  170. }else if ($infos[$key]['status'] == 2)
  171. {
  172. $infos[$key]['status'] = '审核成功';
  173. }else{
  174. $infos[$key]['status'] = '审核拒绝';
  175. }
  176. }
  177. }
  178. return new Table(['订单id','评价内容','评价状态'],$infos);
  179. });
  180. $grid->column('evaluate.score', __('订单评分'));
  181. $grid->column('order_notes', __('订单备注'));
  182. $grid->column('payment_time', __('支付时间'))->display(function ($time){
  183. if ($time == 0)
  184. {
  185. return '';
  186. }else
  187. {
  188. return date('Y-m-d H:i:s',$time);
  189. }
  190. });
  191. $grid->column('receiving_time', __('接单时间'))->display(function ($time){
  192. if ($time == 0)
  193. {
  194. return '';
  195. }else
  196. {
  197. return date('Y-m-d H:i:s',$time);
  198. }
  199. });
  200. $grid->column('end_time', __('订单完成时间'))->display(function ($time){
  201. if ($time == 0)
  202. {
  203. return '';
  204. }else
  205. {
  206. return date('Y-m-d H:i:s',$time);
  207. }
  208. });
  209. $grid->column('created_at','创建时间')->hide();
  210. return $grid;
  211. }
  212. /**
  213. * Make a show builder.
  214. *
  215. * @param mixed $id
  216. * @return Show
  217. */
  218. protected function detail($id)
  219. {
  220. $show = new Show(Order::findOrFail($id));
  221. $show->field('id', __('Id'));
  222. $show->field('user_id', __('用户id'));
  223. $show->field('user.nickname', __('用户姓名'));
  224. $show->field('docter_id', __('医生id'));
  225. $show->field('docter.name', __('医生姓名'));
  226. $show->field('patient_id', __('患者id'));
  227. $show->field('orderPatient.name', __('患者姓名'));
  228. $show->field('organization_id', __('机构id'));
  229. $show->field('organization.name', __('机构名'));
  230. $show->field('order_sn', __('订单号'));
  231. $show->field('product_type', __('产品类型'))->using([1=>'电话咨询',2=>'图文咨询']);
  232. $show->field('payment_type', __('支付类型'))->using([1=>'微信支付',2=>'余额支付']);
  233. $show->field('order_status', __('订单状态'))->using([1=>'未支付',2=>'待接单',3=>'进行中',4=>'已完成',5=>'已取消']);
  234. $show->field('payment_status', __('支付状态'))->using([1=>'待付款',2=>'已付款',3=>'退款中',4=>'已退款']);
  235. $show->field('total_amount', __(' 订单总金额'))->as(function ($money){
  236. return $money/100;
  237. });
  238. $show->field('payment_amount', __('用户实际支付的金额'))->as(function ($money){
  239. return $money/100;
  240. });
  241. $show->field('discount_amount', __('折扣金额'))->as(function ($money){
  242. return $money/100;
  243. });
  244. $show->field('payment_time', __('支付时间'))->as(function ($time){
  245. if($time == 0)
  246. {
  247. return '';
  248. }
  249. else
  250. {
  251. return date('Y-m-d H:i:s',$time);
  252. }
  253. });
  254. $show->field('receiving_time', __('接单时间'))->as(function ($time){
  255. if($time == 0)
  256. {
  257. return '';
  258. }
  259. else
  260. {
  261. return date('Y-m-d H:i:s',$time);
  262. }
  263. });
  264. $show->field('end_time', __('订单完成时间'))->as(function ($time){
  265. if($time == 0)
  266. {
  267. return '';
  268. }
  269. else
  270. {
  271. return date('Y-m-d H:i:s',$time);
  272. }
  273. });
  274. $show->field('created_at', __('创建时间'));
  275. $show->field('updated_at', __('更新时间'));
  276. return $show;
  277. }
  278. /**
  279. * Make a form builder.
  280. *
  281. * @return Form
  282. */
  283. protected function form()
  284. {
  285. $form = new Form(new Order());
  286. $form->number('user_id', __('User id'));
  287. $form->number('docter_id', __('Docter id'));
  288. $form->number('patient_id', __('Patient id'));
  289. $form->number('organization_id', __('Organization id'));
  290. $form->text('order_sn', __('Order sn'));
  291. $form->switch('payment_type', __('Payment type'))->default(1);
  292. $form->switch('product_type', __('Product type'))->default(1);
  293. $form->switch('order_status', __('Order status'))->default(1);
  294. $form->switch('payment_status', __('Payment status'))->default(1);
  295. $form->number('total_amount', __('Total amount'));
  296. $form->number('payment_amount', __('Payment amount'));
  297. $form->number('discount_amount', __('Discount amount'));
  298. $form->number('payment_time', __('Payment time'));
  299. $form->number('outtime', __('Outtime'));
  300. $form->number('receiving_time', __('Receiving time'));
  301. return $form;
  302. }
  303. function message(Content $content,Request $request)
  304. {
  305. // dd($request->all());
  306. $user = $request->input('user_id');
  307. $docter = $request->input('docter_id');
  308. $start = $request->input('start');
  309. $end = $request->input('end');
  310. if (empty($end)) {
  311. $end = time();
  312. }
  313. $str_docter = 'doctor_'.$user;
  314. $str_user = 'member_'.$docter;
  315. // $docter = 10086;
  316. // $user = 29068;
  317. // $start = 1614433272;
  318. // $end = 1614433703;
  319. // $str_docter = 'doctor_'.$docter;
  320. // $str_user = 'member_'.$user;
  321. $user_arr = ImMessage::whereBetween('create_time',[$start,$end])
  322. ->where('senderId',$str_user)
  323. ->get()->toArray();
  324. $docter_arr = ImMessage::whereBetween('create_time',[$start,$end])
  325. ->where('senderId',$str_docter)
  326. ->get()->toArray();
  327. $arr = array_merge($user_arr,$docter_arr);
  328. array_multisort(array_column($arr,'create_time'),SORT_ASC,$arr);
  329. $content = new Content();
  330. $order_id = $request->input('order_id');
  331. $content->title('图文咨询聊天记录 ');
  332. $content->description('订单号'.$order_id);
  333. Admin::js('jquery-3.5.1.min.js');
  334. $content->body('<iframe src="/admin/message_view?docter_id='.$docter.'
  335. &user='.$user.'
  336. &start='.$start.'
  337. &end='.$end.'
  338. &order_id='.$order_id.'" style="width: 100%;height:800px;border: none"></iframe>');
  339. return $content;
  340. }
  341. public function message_view(Request $request)
  342. {
  343. $start = $request->input('start');
  344. $end = $request->input('end');
  345. $docter = $request->input('docter_id');
  346. $user = $request->input('user');
  347. $order_id = $request->input('order_id');
  348. $str_docter = 'doctor_'.$docter;
  349. $str_user = 'member_'.$user;
  350. $user_arr = ImMessage::whereBetween('create_time',[$start,$end])
  351. ->where('senderId',$str_user)
  352. ->get()->toArray();
  353. $docter_arr = ImMessage::whereBetween('create_time',[$start,$end])
  354. ->where('senderId',$str_docter)
  355. ->get()->toArray();
  356. $arr = array_merge($user_arr,$docter_arr);
  357. array_multisort(array_column($arr,'create_time'),SORT_ASC,$arr);
  358. return view('admin.message',compact('arr','order_id','docter','user'));
  359. }
  360. }