ConsultingOrdersController.php 14 KB

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