123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222 |
- <?php
- namespace App\Community\Controllers;
- use App\Community\Actions\Vaccine\AddVaccine;
- use App\Community\Actions\Vaccine\FasteOrder;
- use App\Community\Actions\Vaccine\Finished;
- use App\Community\Actions\Vaccine\OrderCance;
- use App\Community\Actions\Vaccine\Reserved;
- use App\Models\Docter;
- use App\Models\Order;
- use App\Models\OrderPatient;
- use App\Models\OrderVaccine;
- use Encore\Admin\Controllers\AdminController;
- use Encore\Admin\Facades\Admin;
- use Encore\Admin\Form;
- use Encore\Admin\Grid;
- use Encore\Admin\Show;
- use Illuminate\Support\Facades\Date;
- use Illuminate\Support\Facades\DB;
- class OrderVaccinesController extends AdminController
- {
- /**
- * Title for current resource.
- *
- * @var string
- */
- protected $title = '计免订单';
- /**
- * Make a grid builder.
- *
- * @return Grid
- */
- protected function grid()
- {
- $grid = new Grid(new Order());
- $res = request()->all();
- $grid->disableExport(false);
- $grid->export(function ($export) {
- $export->filename('疫苗订单'.Date('Y-m-d',time()));
- $export->column('order_status', function ($value, $original) {
- $order_status_arr = Order::getStatus();
- return $order_status_arr[intval($original)];
- } );
- });
- // $grid->model()->orderByDesc('orders.id');
- DB::enableQueryLog();
- if(!empty($res['orderPatient']['appoint_start_time']['start']) || !empty($res['orderPatient']['appoint_start_time']['start']) ){
- $grid->model()->leftJoin('order_patients','order_patients.order_id','=','orders.id')->orderByDesc('order_patients.appoint_start_time');
- } else {
- $grid->model()->leftJoin('order_patients','order_patients.order_id','=','orders.id')->orderBy('order_patients.appoint_start_time');
- }
- // select bm_orders.*,bm_order_patients.appoint_end_time,bm_order_patients.appoint_start_time,bm_order_patients.name from `bm_orders`
- //left join `bm_order_patients` on `bm_order_patients`.`order_id` = `bm_orders`.`id` ORDER BY bm_order_patients.appoint_start_time asc;
- //
- // $grid->model()->leftJoin('order_patients','order_patients.order_id','=','orders.id')
- // ->orderByDesc('order_patients.appoint_start_time');
- // $grid->model()->orderByDesc('orders.idaa');
- $user = Admin::user();
- $is_admin = Admin::user()->inRoles(['administrator','devloper']);
- $is_docter = $user->docter_id;
- $where = ['product_type'=>4];
- if(!$is_admin){
- $org_id = $user->org_id;
- $where = ['product_type'=>4,'orders.organization_id'=>$org_id];
- // if($is_docter) {
- // $where['docter_id'] = Docter::where(['id'=>$user->docter_id])->value('id');
- // }
- }
- $grid->model()->where($where)->leftJoin('order_patients','order_patients.order_id','=','orders.id')->where('product_type',4)->orderBy('order_patients.appoint_start_time','desc');
- // ->select(['order_id','appoint_start_time']);
- $grid->column('order_id', __('Id'));
- $grid->column('user.nickname', __('预约用户'));
- // $grid->column('yuyue', __('预约时间'))->display(function ($w){
- // if(empty($this->orderPatient) || empty($this->orderPatient->appoint_start_time)) return '';
- // return date('Y-m-d H:i',($this->orderPatient->appoint_start_time)) .'致' . date('H:i',($this->orderPatient->appoint_end_time));
- // });
- $grid->column('appoint_start_time', __('预约时间'))->display(function ($w){
- // if(empty($this->orderPatient) || empty($this->orderPatient->appoint_start_time)) return '';
- return date('Y-m-d H:i',$w).'~'.date('H:i',$this->appoint_end_time);
- });
- $grid->column('end_time', __('接种时间'))->display(function ($w){
- if(empty($w)) return '';
- return date('Y-m-d',$w);
- });
- $grid->column('orderPatient.name', __('接种患者'));
- $grid->column('orderPatient.sex', __('患者性别'))->display(function ($w){
- return $w==1?'男':'女';
- });
- $grid->column('orderPatient.birthday', __('患者年龄'))->display(function ($w){
- return birthday_to_age($w);
- });
- $grid->column('vac_name', __('接种疫苗'))->display(function ($w){
- $vaccine_name = OrderVaccine::where('order_id',$this->id)->pluck('vaccine_name')->toArray();
- if(empty($vaccine_name) ) return '';
- return implode(',',$vaccine_name);
- });
- // $grid->column('docter.name', __('排班医生'));
- $status_arr = Order::getStatus();
- $grid->column('order_status', __('订单状态'))->display(function ($w) use ($status_arr) {
- $info = $status_arr[intval($w)];
- if($w == 1 || $w == 2){
- return '<span class="label label-warning">'.$info.'</span>';
- } else if( $w == 4 ){
- return '<span class="label label-success">'.$info.'</span>';
- } else if($w == 7 || $w == 3 ){
- return '<span class="label label-info">'.$info.'</span>';
- } else if($w == 6){
- return '<span class="label label-danger">'.$info.'</span>';
- } else {
- return '<span class="label label-default">'.$info.'</span>';
- }
- });
- // $grid->column('payment_status', __('支付状态'))->using(Order::getPayStatus())->label([1=>'warring',2=>'success',3=>'info',4=>'danger']);
- $grid->filter(function ($filter) {
- $filter->column(1/2, function ($filter) {
- // $filter->equal('docter.id','排班医生')->select('/cdms/api/getDocter');
- $filter->equal('order_status','订单状态')->select(Order::$_order_status);
- $filter->timestampBetween('orderPatient.appoint_start_time','预约时间')->datetime();
- });
- });
- $grid->tools(function ($tools) {
- $tools->append(new FasteOrder());
- });
- $grid->actions(function ($actions) {
- // if( $actions->row->order_status<= 2){
- // $actions->add(new Reserved());
- // }
- if(!empty($actions->row->order_status) && ($actions->row->order_status<= 3 || $actions->row->order_status == 7 ) ){
- $actions->add(new Finished());
- $actions->add(new OrderCance());
- $actions->add(new AddVaccine());
- }
- $actions->disableEdit();
- // $actions->disableView();
- $actions->disableDelete();
- });
- return $grid;
- }
- /**
- * Make a show builder.
- *
- * @param mixed $id
- * @return Show
- */
- protected function detail($id)
- {
- $show = new Show(Order::findOrFail($id));
- $show->field('id', __('Id'));
- $show->field('orderPatient.name', __('患者姓名'));
- $show->field('orderPatient.sex', __('患者性别'))->as(function ($w){
- return $w==1?'男':'女';
- });
- $show->field('orderPatient.birthday', __('生日'))->as(function ($w){
- return birthday_to_age($w);
- });
- $show->field('orderVaccine.id', __('疫苗'))->as(function ($w){
- $vaccine_name = OrderVaccine::where('order_id',$this->id)->pluck('vaccine_name')->toArray();
- if(empty($vaccine_name) ) return '';
- return implode(',',$vaccine_name);
- });
- $show->field('payment_status', __('支付状态'))->using([1=>'待付款',2=>'已付款',3=>'退款中',4=>'已退款'])->label('info');
- $show->field('order_status', __('订单状态'))->using(Order::getStatus())->label('info');
- $show->field('created_at', __('创建时间'));
- $show->field('updated_at', __('更新时间'));
- return $show;
- }
- /**
- * Make a form builder.
- *
- * @return Form
- */
- protected function form()
- {
- $form = new Form(new OrderVaccine());
- $form->number('order_id', __('Order id'));
- $form->number('order_patient_id', __('Order patient id'));
- $form->number('vaccine_id', __('Vaccine id'));
- $form->switch('vaccine_type', __('Vaccine type'));
- $form->number('vaccine_price', __('Vaccine price'));
- $form->text('vaccine_name', __('Vaccine name'));
- $form->text('vaccine_remark', __('Vaccine remark'));
- $form->text('vaccine_supplier', __('Vaccine supplier'));
- return $form;
- }
- public function info()
- {
- DB::enableQueryLog();
- $list = Order::join('order_patients','order_patients.order_id','=','orders.id')->where('product_type',4)->orderBy('order_patients.appoint_start_time','desc')
- ->select(['order_id','appoint_start_time'])->paginate(20)->toArray();
- dump(DB::getQueryLog());
- dd($list);
- }
- }
|