Repair.php 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | ThinkAdmin
  4. // +----------------------------------------------------------------------
  5. // | 版权所有 2014~2022 广州楚才信息科技有限公司 [ http://www.cuci.cc ]
  6. // +----------------------------------------------------------------------
  7. // | 官方网站: https://thinkadmin.top
  8. // +----------------------------------------------------------------------
  9. // | 开源协议 ( https://mit-license.org )
  10. // | 免费声明 ( https://thinkadmin.top/disclaimer )
  11. // +----------------------------------------------------------------------
  12. // | gitee 代码仓库:https://gitee.com/zoujingli/ThinkAdmin
  13. // | github 代码仓库:https://github.com/zoujingli/ThinkAdmin
  14. // +----------------------------------------------------------------------
  15. namespace app\admin\controller;
  16. use app\data\model\DataRecruitment;
  17. use app\data\model\DataPoolTalent;
  18. use app\data\model\DataTeachingKnowledge;
  19. use app\data\model\DataUser;
  20. use app\data\model\DataUserAcceptance;
  21. use app\data\model\DataUserRepair;
  22. use app\data\model\DataUserRepairOffer;
  23. use app\data\model\DataZhicheng;
  24. use Carbon\Carbon;
  25. use think\admin\Controller;
  26. use app\data\model\SystemUser;
  27. use think\Db;
  28. use think\db\Query;
  29. /**
  30. * 维修订单管理
  31. * Class Repair
  32. * @package app\admin\controller
  33. */
  34. class Repair extends Controller
  35. {
  36. /**
  37. * 维修订单管理
  38. * @auth true
  39. * @menu true
  40. */
  41. public function index(){
  42. $this->title='维修订单列表';
  43. $name=input('title');
  44. $order_no = input('order_no');
  45. //1:未接单 2:已有报价 3:已合作
  46. $status = [
  47. 1=>'未接单',
  48. 2=>'已接单',
  49. 3=>'已匹配',
  50. ];
  51. $this->status = $status;
  52. $where = [];
  53. $data = input();
  54. if(isset($data['status']) && $data['status'] != ""){
  55. $where['status'] = $data['status'];
  56. }
  57. if($name != ""){
  58. $where[] = ['u.nickname','like','%'.$name.'%'];
  59. }
  60. $result = DataUserRepair::mQuery()
  61. ->alias('r')
  62. ->leftjoin('data_user u','u.id = r.uuid')
  63. ->where('is_del',1)
  64. ->whereLike('order_no',"%$order_no%")
  65. ->dateBetween('create_at')
  66. ->where($where)
  67. ->with(['user'])
  68. ->order('r.id','desc');
  69. // ->layTable();
  70. $this->amount = $result->db()->sum('success_price');
  71. $result->page();
  72. }
  73. protected function _index_page_filter(&$data)
  74. {
  75. // dump($data);die;
  76. }
  77. public function offer(){
  78. $this->title='接单记录';
  79. $name=input('title');
  80. $order_no = input('order_no');
  81. $data = input();
  82. $where = [];
  83. //
  84. if(isset($data['repair_id'])){
  85. $where['repair_id'] = $data['repair_id'];
  86. }
  87. $result = DataUserRepairOffer::mQuery()
  88. ->when($name,function (Query $query) use ($name) {
  89. $query->hasWhere('user',function (Query $query) use ($name) {
  90. $query->whereLike('nickname',"%{$name}%");
  91. });
  92. })
  93. ->when($order_no,function (Query $query) use ($order_no) {
  94. $query->hasWhere('repair',function (Query $query) use ($order_no) {
  95. $query->whereLike('order_no',"%{$order_no}%");
  96. });
  97. })
  98. ->dateBetween('create_at')
  99. ->with(['user','repair'])
  100. ->where($where)
  101. ->order('id','desc');
  102. // ->layTable();
  103. // $this->amount = $result->db()->sum('success_price');
  104. $result->page();
  105. }
  106. public function acceptance(){
  107. $this->title='接单记录';
  108. $name=input('title');
  109. $data = input();
  110. $where = [];
  111. //
  112. if(isset($data['name']) && $data['name'] != ''){
  113. $where[] = ['name','like','%'.$data['name'].'%'] ;
  114. }
  115. if(isset($data['company_name'])&& $data['company_name'] != ''){
  116. $where[] = ['company_name','like','%'.$data['company_name'].'%'] ;
  117. }
  118. if(isset($data['create_at'])&& $data['create_at'] != ''){
  119. $where['create_at'] = $data['create_at'];
  120. }
  121. $result = DataUserAcceptance::mQuery()
  122. ->when($name,function (Query $query) use ($name) {
  123. $query->hasWhere('user',function (Query $query) use ($name) {
  124. $query->whereLike('nickname',"%{$name}%");
  125. });
  126. })
  127. ->dateBetween('create_at')
  128. ->with(['user'])
  129. ->where($where)
  130. ->order('id','desc');
  131. // ->layTable();
  132. // $this->amount = $result->db()->sum('success_price');
  133. $result->page();
  134. }
  135. protected function _offer_page_filter(&$data)
  136. {
  137. $this->title='接单列表';
  138. //dump($data);die;
  139. }
  140. /**
  141. * 招聘信息查看
  142. * @auth true
  143. * @menu true
  144. */
  145. public function audit($id){
  146. $this->title='招聘信息查看';
  147. $row=DataUserRepair::mk()
  148. ->with(['user'])
  149. ->findOrFail($id);
  150. if($this->request->isGet()){
  151. $this->assign('row',$row);
  152. $this->fetch();
  153. }else{
  154. if($row['audit']>1){
  155. $this->error('该记录已审核');
  156. }
  157. $data=$this->_vali([
  158. 'audit.require'=>'结果必须',
  159. 'audit.in:2,3'=>'结果有误',
  160. 'why.requireIf:audit,3'=>'原因必须',
  161. 'why.max:200'=>'原因有误',
  162. ]);
  163. $row['audit']=$data['audit'];
  164. $row['why']=$data['why']??'';
  165. $row['audit_at']=Carbon::now();
  166. $row->save();
  167. if ($data['audit']==2){
  168. DataUser::mk()->where('id',$row['uuid'])->update(['is_maintenance'=>1]);
  169. }
  170. $this->success('审核成功');
  171. }
  172. }
  173. }