ConsultingOrdersController.php 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247
  1. <?php
  2. namespace App\Admin\Controllers\OrdersManagement;
  3. use App\Admin\Actions\backstage\Orders\Evaluate;
  4. use App\Admin\Actions\backstage\Orders\OrderDetails;
  5. use App\Admin\Actions\backstage\User\MapDepot;
  6. use App\Admin\Actions\backstage\User\Suggests;
  7. use App\Models\Order;
  8. use App\Models\OrderPack;
  9. use App\Models\ServicePack;
  10. use Encore\Admin\Widgets\Table;
  11. use Encore\Admin\Controllers\AdminController;
  12. use Encore\Admin\Form;
  13. use Encore\Admin\Grid;
  14. use Encore\Admin\Show;
  15. class ConsultingOrdersController extends AdminController
  16. {
  17. /**
  18. * Title for current resource.
  19. *
  20. * @var string
  21. */
  22. protected $title = '咨询订单';
  23. /**
  24. * Make a grid builder.
  25. *
  26. * @return Grid
  27. */
  28. protected function grid()
  29. {
  30. $grid = new Grid(new Order());
  31. $grid->disableCreateButton();
  32. $grid->model()->wherein('product_type',[1,2]);
  33. //筛选
  34. $grid->filter(function ($filter){
  35. $filter->disableIdFilter();
  36. $filter->column(1/3, function ($filter) {
  37. $filter->like('user.nickname','用户姓名');
  38. $filter->equal('user_id', '用户id');
  39. $filter->timestampBetween('payment_time', "支付时间")->datetime();
  40. $filter->in('evaluate.score','评分')->checkbox([
  41. 1 => 1,
  42. 2 => 2,
  43. 3 => 3,
  44. 4 => 4,
  45. 5 => 5,
  46. ]);
  47. });
  48. $filter->column(1/3, function ($filter) {
  49. $filter->like('docter.name','医生姓名');
  50. $filter->equal('docter_id', '医生id');
  51. $filter->equal('product_type','产品类型')->radio(
  52. [
  53. ''=>'不限',
  54. 1=>'电话咨询',
  55. 2=>'图文咨询',
  56. ]
  57. );
  58. $filter->timestampBetween('receiving_time', "接单时间")->datetime();
  59. });
  60. $filter->column(1/3, function ($filter) {
  61. $filter->like('orderPatient.name','患者姓名');
  62. $filter->equal('order_status','订单状态')->radio(
  63. [
  64. ''=>'不限',
  65. 1=>'未支付',
  66. 2=>'待接单',
  67. 3=>'进行中',
  68. 4=>'已完成',
  69. 5=>'已取消'
  70. ]
  71. );
  72. $filter->timestampBetween('end_time', "订单完成时间")->datetime();
  73. });
  74. });
  75. //操作
  76. $grid->disableActions();
  77. $grid->model()->orderBy('id','desc');
  78. $grid->column('id', __('Id'))->sortable();
  79. $grid->column('user.nickname', __('用户姓名'));
  80. $grid->column('docter.name', __('医生姓名'));
  81. $grid->column('orderPatient.name', __('患者姓名'));
  82. $grid->column('orderPatient.patient_phone', __('患者电话'));
  83. $grid->column('orderPatient.symptoms', __('患者描述'));
  84. $grid->column('product_type', __('产品类型'))->using([1=>'电话咨询',2=>'图文咨询']);
  85. $grid->column('payment_type', __('支付方式'))->display(function ($payment_type){
  86. if ($payment_type == 1)
  87. {
  88. return '微信支付';
  89. }
  90. if ($payment_type == 2){
  91. return '余额支付';
  92. }
  93. if ($payment_type == 3){
  94. $order_pack_id = OrderPack::where('id',$this->pay_order_pack_id)->pluck('service_pack_id');
  95. $name = ServicePack::where('id',$order_pack_id[0])->pluck('name');
  96. return '服务包支付('.$name[0].')';
  97. }
  98. });
  99. $grid->column('order_status', __('订单状态'))->using([1=>'未支付',2=>'待接单',3=>'进行中',4=>'已完成',5=>'已取消']);
  100. $grid->column('payment_status', __('支付状态'))->using([1=>'待付款',2=>'已付款',3=>'退款中',4=>'已退款']);
  101. $grid->column('total_amount', __('订单总金额'))->display(function ($money){
  102. return $money/100;
  103. });
  104. $grid->column('payment_amount', __('用户实际支付的金额'))->display(function ($money){
  105. return $money/100;
  106. });
  107. $grid->column('discount_amount', __('折扣金额'))->display(function ($money){
  108. return $money/100;
  109. });
  110. $grid->column('is_evaluates', __('评价详情'))->expand(function ($model){
  111. $infos = $model->evaluate()->get()->map(function ($info){
  112. return $info->only(['order_id','content','status']);
  113. });
  114. $infos = $infos->toArray();
  115. foreach ($infos as $key => $value)
  116. {
  117. if (!empty($infos[$key]))
  118. {
  119. if ($infos[$key]['status'] == 1)
  120. {
  121. $infos[$key]['status'] = '待审核';
  122. }else if ($infos[$key]['status'] == 2)
  123. {
  124. $infos[$key]['status'] = '审核成功';
  125. }else{
  126. $infos[$key]['status'] = '审核拒绝';
  127. }
  128. }
  129. }
  130. return new Table(['订单id','评价内容','评价状态'],$infos);
  131. });
  132. $grid->column('evaluate.score', __('订单评分'));
  133. $grid->column('payment_time', __('支付时间'))->display(function ($time){
  134. return date('Y-m-d H:i:s',$time);
  135. });
  136. $grid->column('receiving_time', __('接单时间'))->display(function ($time){
  137. return date('Y-m-d H:i:s',$time);
  138. });
  139. $grid->column('end_time', __('订单完成时间'))->display(function ($time){
  140. return date('Y-m-d H:i:s',$time);
  141. });
  142. return $grid;
  143. }
  144. /**
  145. * Make a show builder.
  146. *
  147. * @param mixed $id
  148. * @return Show
  149. */
  150. protected function detail($id)
  151. {
  152. $show = new Show(Order::findOrFail($id));
  153. $show->field('id', __('Id'));
  154. $show->field('user_id', __('用户id'));
  155. $show->field('user.nickname', __('用户姓名'));
  156. $show->field('docter_id', __('医生id'));
  157. $show->field('docter.name', __('医生姓名'));
  158. $show->field('patient_id', __('患者id'));
  159. $show->field('orderPatient.name', __('患者姓名'));
  160. $show->field('organization_id', __('机构id'));
  161. $show->field('organization.name', __('机构名'));
  162. $show->field('order_sn', __('订单号'));
  163. $show->field('product_type', __('产品类型'))->using([1=>'电话咨询',2=>'图文咨询']);
  164. $show->field('payment_type', __('支付类型'))->using([1=>'微信支付',2=>'余额支付']);
  165. $show->field('order_status', __('订单状态'))->using([1=>'未支付',2=>'待接单',3=>'进行中',4=>'已完成',5=>'已取消']);
  166. $show->field('payment_status', __('支付状态'))->using([1=>'待付款',2=>'已付款',3=>'退款中',4=>'已退款']);
  167. $show->field('total_amount', __(' 订单总金额'))->as(function ($money){
  168. return $money/100;
  169. });
  170. $show->field('payment_amount', __('用户实际支付的金额'))->as(function ($money){
  171. return $money/100;
  172. });
  173. $show->field('discount_amount', __('折扣金额'))->as(function ($money){
  174. return $money/100;
  175. });
  176. $show->field('payment_time', __('支付时间'))->as(function ($time){
  177. if($time == 0)
  178. {
  179. return '';
  180. }
  181. else
  182. {
  183. return date('Y-m-d H:i:s',$time);
  184. }
  185. });
  186. $show->field('receiving_time', __('接单时间'))->as(function ($time){
  187. if($time == 0)
  188. {
  189. return '';
  190. }
  191. else
  192. {
  193. return date('Y-m-d H:i:s',$time);
  194. }
  195. });
  196. $show->field('end_time', __('订单完成时间'))->as(function ($time){
  197. if($time == 0)
  198. {
  199. return '';
  200. }
  201. else
  202. {
  203. return date('Y-m-d H:i:s',$time);
  204. }
  205. });
  206. $show->field('created_at', __('创建时间'));
  207. $show->field('updated_at', __('更新时间'));
  208. return $show;
  209. }
  210. /**
  211. * Make a form builder.
  212. *
  213. * @return Form
  214. */
  215. protected function form()
  216. {
  217. $form = new Form(new Order());
  218. $form->number('user_id', __('User id'));
  219. $form->number('docter_id', __('Docter id'));
  220. $form->number('patient_id', __('Patient id'));
  221. $form->number('organization_id', __('Organization id'));
  222. $form->text('order_sn', __('Order sn'));
  223. $form->switch('payment_type', __('Payment type'))->default(1);
  224. $form->switch('product_type', __('Product type'))->default(1);
  225. $form->switch('order_status', __('Order status'))->default(1);
  226. $form->switch('payment_status', __('Payment status'))->default(1);
  227. $form->number('total_amount', __('Total amount'));
  228. $form->number('payment_amount', __('Payment amount'));
  229. $form->number('discount_amount', __('Discount amount'));
  230. $form->number('payment_time', __('Payment time'));
  231. $form->number('outtime', __('Outtime'));
  232. $form->number('receiving_time', __('Receiving time'));
  233. return $form;
  234. }
  235. }