Worder.php 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318
  1. <?php
  2. namespace app\admin\controller;
  3. use think\facade\Session;
  4. use app\admin\BaseController;
  5. use app\common\model\Worder as WorderModel;
  6. use app\common\model\WorderCate as WorderCateModel;
  7. use app\common\model\WorderLog as WorderLogModel;
  8. use app\common\model\Worker as WorkerModel;
  9. class Worder extends BaseController
  10. {
  11. // 报名记录
  12. public function logList()
  13. {
  14. $workerlist = WorkerModel::order(['id'=>'desc'])->select();
  15. $worderlist = WorderModel::field('id,title')->order(['id'=>'desc'])->select();
  16. return view('worder/loglist',[
  17. 'workerlist' => $workerlist,
  18. 'worderlist' => $worderlist
  19. ]);
  20. }
  21. public function delLog()
  22. {
  23. $idarr = input('idarr/a');
  24. $log = WorderLogModel::whereIn('id',$idarr)->select();
  25. $result = $log->delete();
  26. if ($result){
  27. exit(json_encode(array(
  28. 'code' => 0,
  29. 'msg' => ""
  30. )));
  31. }
  32. exit(json_encode(array(
  33. 'code' => 1,
  34. 'msg' => "删除失败,请稍后重试"
  35. )));
  36. }
  37. public function listLog()
  38. {
  39. $limit = input('limit/d',20);
  40. $page = input('page/d',1);
  41. $map = array();
  42. $setworkerid = input('setworkerid/d',0);
  43. if (!empty($setworkerid)){
  44. $map[] = ['setworkerid', '=', $setworkerid];
  45. }
  46. $getworkerid = input('getworkerid/d',0);
  47. if (!empty($getworkerid)){
  48. $map[] = ['getworkerid', '=', $getworkerid];
  49. }
  50. $worderid = input('worderid/d',0);
  51. if (!empty($worderid)){
  52. $map[] = ['worderid', '=', $worderid];
  53. }
  54. $list = WorderLogModel::with(['setWorker','getWorker','worder'])->where($map)->order('id','DESC')->limit($limit)->page($page)->select();
  55. $count = WorderLogModel::where($map)->count();
  56. if ($count==0){
  57. exit(json_encode(array(
  58. 'code' => 1,
  59. 'msg' => "未查询到数据"
  60. )));
  61. }
  62. exit(json_encode(array(
  63. 'code' => 0,
  64. 'msg' => "",
  65. 'count' => $count,
  66. 'data' => $list
  67. )));
  68. }
  69. public function exportLog()
  70. {
  71. $map = array();
  72. $setworkerid = input('setworkerid/d',0);
  73. if (!empty($setworkerid)){
  74. $map[] = ['setworkerid', '=', $setworkerid];
  75. }
  76. $getworkerid = input('getworkerid/d',0);
  77. if (!empty($getworkerid)){
  78. $map[] = ['getworkerid', '=', $getworkerid];
  79. }
  80. $worderid = input('worderid/d',0);
  81. if (!empty($worderid)){
  82. $map[] = ['worderid', '=', $worderid];
  83. }
  84. $xlsData = WorderLogModel::with(['setWorker','getWorker','worder'])->where($map)->order('id','DESC')->select()->toArray();
  85. $xlsCell = array(
  86. array('id','表ID'),
  87. array('worder.title','订单标题'),
  88. array('setWorker.title','发单公司'),
  89. array('getWorker.title','接单公司'),
  90. array('createtime','接单时间'),
  91. );
  92. export_excel("订单接单记录",$xlsCell,$xlsData);
  93. }
  94. // 订单信息
  95. public function worderList()
  96. {
  97. $workerlist = WorkerModel::order(['id'=>'desc'])->select();
  98. return view('worder/worderlist',[
  99. 'workerlist' => $workerlist
  100. ]);
  101. }
  102. public function worderForm()
  103. {
  104. $id = input('id/d, 0');
  105. $worder = WorderModel::findOrEmpty($id);
  106. $workerlist = WorkerModel::order(['id'=>'desc'])->select();
  107. $catelist = WorderCateModel::order(['priority'=>'desc','id'=>'desc'])->select();
  108. return view('worder/worderform',[
  109. 'catelist' => $catelist,
  110. 'workerlist' => $workerlist,
  111. 'worder' => $worder
  112. ]);
  113. }
  114. public function editWorder()
  115. {
  116. $id = input('id/d', 0);
  117. $data = [
  118. 'cateid' => input('cateid/d', 0),
  119. 'workerid' => input('workerid/d', 0),
  120. 'title' => input('title/s', ""),
  121. 'tags' => input('tags/a', array()),
  122. 'otype' => input('otype/s', ""),
  123. 'wagall' => input('wagall/s', ""),
  124. 'telephone' => input('telephone/s', ""),
  125. 'province' => input('province/s', ""),
  126. 'city' => input('city/s', ""),
  127. 'district' => input('district/s', ""),
  128. 'jobdetails' => input('jobdetails/s', ""),
  129. 'coodetails' => input('coodetails/s', ""),
  130. 'status' => input('status/d', 0),
  131. 'priority' => input('priority/d', 0),
  132. 'updatetime' => input('updatetime/s', ""),
  133. 'createtime' => input('createtime/s', ""),
  134. 'volume' => input('volume/d', 0)
  135. ];
  136. if (empty($id)){
  137. $worder = WorderModel::create($data);
  138. }else{
  139. $worder = WorderModel::find($id);
  140. WorderLogModel::update([ 'setworkerid' => input('workerid/d', 0) ],['worderid'=>$worder->id]);
  141. $worder->save($data);
  142. }
  143. exit(json_encode(array(
  144. 'code' => 0
  145. )));
  146. }
  147. public function fieldWorder()
  148. {
  149. $id = input('id/d',0);
  150. $worder = WorderModel::findOrEmpty($id);
  151. if ($worder->isEmpty()){
  152. exit(json_encode(array(
  153. 'code' => 1,
  154. 'msg' => "信息不存在"
  155. )));
  156. }else{
  157. $worder->save([
  158. input('field/s') => input('value')
  159. ]);
  160. }
  161. exit(json_encode(array(
  162. 'code' => 0
  163. )));
  164. }
  165. public function delWorder()
  166. {
  167. $idarr = input('idarr/a');
  168. $worder = WorderModel::whereIn('id',$idarr)->select();
  169. WorderLogModel::whereIn('worderid',$idarr)->delete();
  170. $result = $worder->delete();
  171. if ($result){
  172. exit(json_encode(array(
  173. 'code' => 0,
  174. 'msg' => ""
  175. )));
  176. }
  177. exit(json_encode(array(
  178. 'code' => 1,
  179. 'msg' => "删除失败,请稍后重试"
  180. )));
  181. }
  182. public function listWorder()
  183. {
  184. $limit = input('limit/d',20);
  185. $page = input('page/d',1);
  186. $map = array();
  187. $keywords = input('keywords/s', "");
  188. if (!empty($keywords)){
  189. $map[] =['title', 'like', '%'.$keywords.'%'];
  190. }
  191. $workerid = input('workerid/d', 0);
  192. if (!empty($workerid)){
  193. $map[] = ['workerid', '=', $workerid];
  194. }
  195. $status = input('status/d');
  196. if (!empty($status)){
  197. $map[] = ['status', '=', $status];
  198. }
  199. $list = WorderModel::with(['worker','worderCate'])->withCount(['worderLog'])->where($map)->order(['priority'=>'desc','updatetime'=>'desc','id'=>'desc',])->limit($limit)->page($page)->append(['status_text'])->select();
  200. $count = WorderModel::where($map)->count();
  201. if ($count==0){
  202. exit(json_encode(array(
  203. 'code' => 1,
  204. 'msg' => "未查询到数据"
  205. )));
  206. }
  207. exit(json_encode(array(
  208. 'code' => 0,
  209. 'msg' => "",
  210. 'count' => $count,
  211. 'data' => $list
  212. )));
  213. }
  214. // 分类
  215. public function cateList()
  216. {
  217. return view('worder/catelist');
  218. }
  219. public function cateForm()
  220. {
  221. $id = input('id/d, 0');
  222. $cate = WorderCateModel::findOrEmpty($id);
  223. return view('worder/cateform',[
  224. 'cate' => $cate
  225. ]);
  226. }
  227. public function listCate()
  228. {
  229. $limit = input('limit');
  230. $page = input('page');
  231. $list = WorderCateModel::order(['priority'=>'desc','id'=>'desc'])->limit($limit)->page($page)->append(['status_text'])->select();
  232. $count = WorderCateModel::count();
  233. if ($count==0){
  234. exit(json_encode(array(
  235. 'code' => 1,
  236. 'msg' => "未查询到数据"
  237. )));
  238. }
  239. exit(json_encode(array(
  240. 'code' => 0,
  241. 'msg' => "",
  242. 'count' => $count,
  243. 'data' => $list
  244. )));
  245. }
  246. public function fieldCate()
  247. {
  248. $id = input('id/d');
  249. $cate = WorderCateModel::find($id);
  250. if ($cate==null){
  251. exit(json_encode(array(
  252. 'code' => 1,
  253. 'msg' => "分类信息不存在"
  254. )));
  255. }else{
  256. $cate->save([
  257. input('field/s') => input('value/s', "")
  258. ]);
  259. }
  260. exit(json_encode(array(
  261. 'code' => 0
  262. )));
  263. }
  264. public function editCate()
  265. {
  266. $id = input('id/d');
  267. if (empty($id)){
  268. $cate = WorderCateModel::create([
  269. 'title' => input('title/s'),
  270. 'status' => input('status/d')==1 ? 1 : 2,
  271. 'priority' => input('priority/d')
  272. ]);
  273. }else{
  274. $cate = WorderCateModel::find($id);
  275. $cate->save([
  276. 'title' => input('title/s'),
  277. 'status' => input('status/d')==1 ? 1 : 2,
  278. 'priority' => input('priority/d')
  279. ]);
  280. }
  281. exit(json_encode(array(
  282. 'code' => 0
  283. )));
  284. }
  285. public function delCate()
  286. {
  287. $id = input('id/d');
  288. WorderCateModel::where('id',$id)->delete();
  289. exit(json_encode(array(
  290. 'code' => 0,
  291. 'msg' => ""
  292. )));
  293. }
  294. }