BuyhouseController.php 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574
  1. <?php
  2. namespace App\Http\Controllers\Web\Content;
  3. use App\Http\Controllers\Web\WebBaseController;
  4. use App\Models\Article;
  5. use App\Models\MemberInfo;
  6. use App\Models\TalentHouse;
  7. use App\Models\TalentHouseApply;
  8. use App\Models\TalentHousePeople;
  9. use App\Services\Content\ArticleService;
  10. use Illuminate\Http\Request;
  11. use Illuminate\Support\Facades\DB;
  12. use Illuminate\Support\Facades\Storage;
  13. use Illuminate\Support\Facades\Validator;
  14. class BuyhouseController extends WebBaseController
  15. {
  16. private $street = [
  17. '青阳街道', '梅岭街道', '西园街道', '罗山街道', '灵源街道', '新塘街道', '陈埭镇', '池店镇', '安海镇', '磁灶镇', '内坑镇', '紫帽镇', '东石镇', '永和镇', '英林镇', '金井镇', '龙湖镇', '深沪镇', '西滨镇',
  18. ];
  19. private $house_status = ['未知', '未开始', '申报中', '已结束'];
  20. private $tag_status = ['', 'info', 'success', 'danger'];
  21. private $apply_status = ['未知', '审核中', '已通过', '已拒绝'];
  22. private $check_type = ['', 'warning', 'success', 'error'];
  23. private $talent_level = ['不是人才', '第一层次', '第二层次', '第三层次', '第四层次', '第五层次', '第六层次', '第七层次'];
  24. protected $articleService;
  25. /**
  26. * ArticleController constructor.
  27. * @param $articleService
  28. * @param $articleCategoryService
  29. */
  30. public function __construct(ArticleService $articleService)
  31. {
  32. $this->articleService = $articleService;
  33. }
  34. /**
  35. * 登录
  36. */
  37. public function login()
  38. {
  39. $user_id = auth('web-member')->id();
  40. $return_data = ['user_id' => $user_id ?: 0, 'apply' => '[]'];
  41. //房源
  42. $house = TalentHouse::orderBy('updated_at', 'desc')->orderByRaw(DB::raw("FIELD(status,2,1,3)"))->limit(8)->get();
  43. foreach ($house as $v) {
  44. $v['apply_time_start'] = date('Y-m-d', strtotime($v['apply_time_start']));
  45. $v['apply_time_end'] = date('Y-m-d', strtotime($v['apply_time_end']));
  46. $v['status'] = $this->_get_status($v);
  47. $v['status_text'] = $this->house_status[$v['status']];
  48. $v['status_tag'] = $this->tag_status[$v['status']];
  49. $v['url'] = route('buyhouse.detail', ['id' => $v['id']]);
  50. }
  51. $return_data['house'] = $house;
  52. //新闻
  53. $news = Article::where('type_id', 56)->where('is_display', 1)->select(['id', 'title', 'updated_at'])->orderBy('list_order', 'desc')->limit(10)->get();
  54. foreach ($news as $v) {
  55. $v['updated_at_text'] = date('Y-m-d', strtotime($v['updated_at']));
  56. $v['url'] = route('news.show', ['id' => $v['id']]);
  57. }
  58. $return_data['news'] = $news;
  59. //我的申报
  60. if ($user_id > 0) {
  61. $apply = TalentHouseApply::with('house')
  62. ->select(['id', 'house_id', 'status'])
  63. ->where('is_draft', 2)
  64. ->where('is_back', 2)
  65. ->where('user_id', $user_id)
  66. ->get();
  67. foreach ($apply as $v) {
  68. $v['status_text'] = $this->apply_status[$v['status']];
  69. $v['status_tag'] = $this->tag_status[$v['status']];
  70. $v['url'] = route('buyhouse.list', ['id' => $v['house_id']]);
  71. }
  72. $return_data['apply'] = $apply;
  73. //用户信息
  74. $memberInfo = MemberInfo::where('uid', $user_id)->first();
  75. $return_data['member_info'] = $memberInfo;
  76. }
  77. return view('app.content.buyhouse.login', $return_data);
  78. }
  79. /**
  80. * 完善信息
  81. */
  82. public function perfect(Request $request)
  83. {
  84. $user_id = auth('web-member')->id();
  85. if (empty($user_id)) {
  86. return response()->json(['status' => 0, 'msg' => '请先登录']);
  87. }
  88. $data = $request->only(['realname', 'card_t_cn', 'id_card']);
  89. MemberInfo::where('uid', $user_id)->update($data);
  90. return response()->json(['status' => 1, 'msg' => '修改成功']);
  91. }
  92. /**
  93. * 房源信息
  94. */
  95. public function house()
  96. {
  97. $lists = TalentHouse::orderByRaw(DB::raw("FIELD(status,2,1,3)"))->paginate(10);
  98. foreach ($lists as $v) {
  99. $v['apply_time_start'] = date('Y-m-d', strtotime($v['apply_time_start']));
  100. $v['apply_time_end'] = date('Y-m-d', strtotime($v['apply_time_end']));
  101. $v['status'] = $this->_get_status($v);
  102. $v['status_text'] = $this->house_status[$v['status']];
  103. $v['status_tag'] = $this->tag_status[$v['status']];
  104. }
  105. $return_data = [
  106. 'articles' => $lists,
  107. 'now_cate' => '房源信息',
  108. ];
  109. return view('app.content.buyhouse.house', $return_data);
  110. }
  111. /**
  112. * 公告
  113. */
  114. public function news()
  115. {
  116. $lists = $this->articleService->list('', 56, '10');
  117. $return_data = [
  118. 'articles' => $lists,
  119. 'now_cate' => '公告',
  120. ];
  121. return view('app.content.buyhouse.news', $return_data);
  122. }
  123. public function detail(Request $request)
  124. {
  125. $id = $request->get('id');
  126. if (empty($id)) {
  127. $back_url = \Illuminate\Support\Facades\URL::previous();
  128. return $this->showMessage('该房源不存在或已删除', $back_url, true, '上一页', '3');
  129. }
  130. //房源信息
  131. $house = TalentHouse::where('id', $id)->first();
  132. if (empty($house)) {
  133. $back_url = \Illuminate\Support\Facades\URL::previous();
  134. return $this->showMessage('该房源不存在或已删除', $back_url, true, '上一页', '3');
  135. }
  136. $house['status'] = $this->_get_status($house);
  137. $house['status_text'] = $this->house_status[$house['status']];
  138. $house['status_tag'] = $this->tag_status[$house['status']];
  139. $house['url'] = route('buyhouse.list', ['id' => $house['id']]);
  140. $house['apply_time'] = date('Y-m-d', strtotime($house['apply_time_start'])) . ' - ' . date('Y-m-d', strtotime($house['apply_time_end']));
  141. $return_data = [
  142. 'info' => $house,
  143. ];
  144. return view('app.content.buyhouse.detail', $return_data);
  145. }
  146. /**
  147. * 报名列表
  148. */
  149. public function list(Request $request)
  150. {
  151. $login = $this->checkLogin();
  152. if ($login) {
  153. return $login;
  154. }
  155. $user_id = auth('web-member')->id();
  156. if (empty($user_id)) {
  157. $back_url = route('buyhouse.login');
  158. return $this->showMessage('登录过期,请先登录', $back_url, true, '上一页', '3');
  159. }
  160. //拉黑
  161. $people = TalentHousePeople::where('user_id', $user_id)->first();
  162. if (!empty($people) && $people['status'] == 2) {
  163. $back_url = \Illuminate\Support\Facades\URL::previous();
  164. return $this->showMessage('由于您不遵守规则,已被拉黑,具体情况请联系有关部门', $back_url, true, '上一页', '3');
  165. }
  166. $id = $request->get('id');
  167. if (empty($id)) {
  168. $back_url = \Illuminate\Support\Facades\URL::previous();
  169. return $this->showMessage('该房源不存在或已删除', $back_url, true, '上一页', '3');
  170. }
  171. //是否报名其他
  172. $sock = TalentHouseApply::where('user_id', $user_id)->where('house_id', '<>', $id)->where('is_sock', 1)->where('is_draft', 2)->first();
  173. if (!empty($sock)) {
  174. $back_url = \Illuminate\Support\Facades\URL::previous();
  175. return $this->showMessage('不可以同时申报多个房源', $back_url, true, '上一页', '3');
  176. }
  177. //房源信息
  178. $house = TalentHouse::where('id', $id)->first();
  179. if (empty($house)) {
  180. $back_url = \Illuminate\Support\Facades\URL::previous();
  181. return $this->showMessage('该房源不存在或已删除', $back_url, true, '上一页', '3');
  182. }
  183. $house['declare_time_text'] = date('Y-m-d', strtotime($house['declare_time']));
  184. $house['status'] = $this->_get_status($house);
  185. $house['status_text'] = $this->house_status[$house['status']];
  186. $house['status_tag'] = $this->tag_status[$house['status']];
  187. $house['apply_time'] = date('Y-m-d', strtotime($house['apply_time_start'])) . ' - ' . date('Y-m-d', strtotime($house['apply_time_end']));
  188. //报名信息
  189. $apply = TalentHouseApply::where('house_id', $id)->where('is_back', 2)->where('user_id', $user_id)->first();
  190. $check = [];
  191. $time = time();
  192. if ($apply) {
  193. if ($house['status'] != 2 && $apply['is_draft'] == 1) {
  194. $back_url = \Illuminate\Support\Facades\URL::previous();
  195. return $this->showMessage('该房源未在申报时间', $back_url, true, '上一页', '3');
  196. }
  197. //审核状态
  198. if ($apply['is_draft'] == 2) {
  199. if ($apply['rs_check_status'] != 2) {
  200. if ($apply['type'] == 1) {
  201. $check['status_text'] = '人社局' . $this->apply_status[$apply['rs_check_status']];
  202. } else {
  203. $check['status_text'] = '集成电路' . $this->apply_status[$apply['rs_check_status']];
  204. }
  205. $check['comment'] = $apply['rs_check_status'] == 1 ? '' : $apply['rs_check_comment'];
  206. $check['type'] = $this->check_type[$apply['rs_check_status']];
  207. } elseif ($apply['zj_check_status'] != 2) {
  208. $check['status_text'] = '自然资源局' . $this->apply_status[$apply['zj_check_status']];
  209. $check['comment'] = $apply['zj_check_status'] == 1 ? '' : $apply['zj_check_comment'];
  210. $check['type'] = $this->check_type[$apply['zj_check_status']];
  211. } else {
  212. $check['title'] = '';
  213. $check['status_text'] = $this->apply_status[$apply['zj_check_status']];
  214. $check['comment'] = '';
  215. $check['type'] = 'success';
  216. }
  217. }
  218. } else {
  219. if ($house['status'] != 2) {
  220. $back_url = \Illuminate\Support\Facades\URL::previous();
  221. return $this->showMessage('该房源未在申报时间', $back_url, true, '上一页', '3');
  222. }
  223. $infos = MemberInfo::where('uid', $user_id)->first();
  224. if (empty($infos['id_card'])) {
  225. $back_url = route('person.resume');
  226. return $this->showMessage('请先填写身份证号', $back_url, true, '上一页', '3');
  227. }
  228. $request_post = [
  229. 'idCards' => [$infos['id_card']],
  230. 'sign' => mb_strtoupper(md5("timestr={$time}&key=rsKVyec52fqEKpk4RRD2TU8fKvPxt6ombKg0qSq1velPQtBHVi")),
  231. 'timeStr' => (string)$time,
  232. ];
  233. $res = https_request('https://rc.jucai.gov.cn/api/dataInterface/findTalentInfoByIdCards', json_encode($request_post), ['Content-Type:application/json']);
  234. $talent = json_decode($res, true);
  235. if (empty($talent['obj'])) {
  236. $back_url = \Illuminate\Support\Facades\URL::previous();
  237. return $this->showMessage('您还未认定人才,暂无申报资格', $back_url, true, '上一页', '3');
  238. }
  239. $talent = $talent['obj'][0];
  240. if ($talent['talentArrange'] > 5) {
  241. $back_url = \Illuminate\Support\Facades\URL::previous();
  242. return $this->showMessage('目前仅支持一到五层次人才申报', $back_url, true, '上一页', '3');
  243. }
  244. if ($talent['type'] > 2) {
  245. $back_url = \Illuminate\Support\Facades\URL::previous();
  246. return $this->showMessage('其他人才暂不支持', $back_url, true, '上一页', '3');
  247. }
  248. $add = [
  249. 'user_id' => $user_id,
  250. 'house_id' => $id,
  251. 'type' => $talent['type'],
  252. 'name' => $talent['name'],
  253. 'mobile' => $talent['phone'],
  254. 'native' => $talent['nativePlace'],
  255. 'email' => $talent['email'],
  256. 'talent_level' => $this->talent_level[$talent['talentArrange']],
  257. 'talent_card_validity' => $talent['activeDate'],
  258. 'talent_tags' => $talent['talentType'],
  259. 'talent_condition' => $talent['identifyCondition'],
  260. 'family' => json_encode([['relation' => '配偶', 'realname' => '', 'idcard' => '']]),
  261. 'certificates' => '[]',
  262. 'marry_prove' => '[]',
  263. 'household_register' => '[]',
  264. 'work_prove' => '[]',
  265. 'created_at' => date('Y-m-d H:i:s'),
  266. 'updated_at' => date('Y-m-d H:i:s'),
  267. ];
  268. $id = TalentHouseApply::insertGetId($add);
  269. $apply = TalentHouseApply::find($id);
  270. //报名人员列表
  271. $memberInfo = MemberInfo::where('uid', $user_id)->first();
  272. if (empty($people)) {
  273. TalentHousePeople::insert([
  274. 'user_id' => $user_id,
  275. 'realname' => $memberInfo['realname'] ?: '',
  276. 'mobile' => $memberInfo['phone'] ?: '',
  277. 'email' => $memberInfo['email'] ?: '',
  278. 'card_t_cn' => $memberInfo['card_t_cn'] ?: 306,
  279. 'id_card' => $memberInfo['id_card'] ?: '',
  280. 'created_at' => date('Y-m-d H:i:s'),
  281. 'updated_at' => date('Y-m-d H:i:s'),
  282. ]);
  283. } else {
  284. TalentHousePeople::where('user_id', $user_id)->update([
  285. 'realname' => $memberInfo['realname'] ?: '',
  286. 'mobile' => $memberInfo['mobile'] ?: '',
  287. 'email' => $memberInfo['email'] ?: '',
  288. 'card_t_cn' => $memberInfo['card_t_cn'] ?: 306,
  289. 'id_card' => $memberInfo['id_card'] ?: '',
  290. 'updated_at' => date('Y-m-d H:i:s'),
  291. ]);
  292. }
  293. }
  294. $apply['family'] = json_decode($apply['family'], true);
  295. $apply['certificates'] = json_decode($apply['certificates'], true);
  296. $apply['marry_prove'] = json_decode($apply['marry_prove'], true);
  297. $apply['household_register'] = json_decode($apply['household_register'], true);
  298. $apply['work_prove'] = json_decode($apply['work_prove'], true);
  299. $apply['checked'] = true;
  300. //是否可填表格
  301. $formDisable = 'true';
  302. if ($apply['is_draft'] == 1) {
  303. //草稿
  304. $formDisable = 'false';
  305. } else {
  306. if ($time < strtotime($house['apply_time_end']) && $apply['status'] == 3) {
  307. $formDisable = 'false';
  308. } else {
  309. if ($time < strtotime($house['supply_time']) && ($apply['rs_check_status'] == 3 || $apply['zj_check_status'] == 3)) {
  310. $formDisable = 'false';
  311. }
  312. }
  313. }
  314. $return_data = [
  315. 'formDisable' => $formDisable,
  316. 'check' => $check,
  317. 'apply' => json_encode($apply),
  318. 'house' => json_encode($house),
  319. 'module' => ['identification'],
  320. ];
  321. return view('app.content.buyhouse.list', $return_data);
  322. }
  323. /**
  324. * 申报提交
  325. */
  326. public function listPost(Request $request)
  327. {
  328. //数据校验
  329. $data = $request->only(['id', 'certificates', 'marry', 'child_num', 'marry_prove', 'household_register', 'family', 'work_prove', 'company', 'street', 'house_condition', 'house_policy']);
  330. $rules = [
  331. 'certificates' => 'required',
  332. 'marry' => 'required',
  333. 'household_register' => 'required',
  334. 'work_prove' => 'required',
  335. 'company' => 'required',
  336. 'street' => 'required',
  337. 'house_condition' => 'required',
  338. 'house_policy' => 'required',
  339. ];
  340. $messages = [
  341. 'certificates.required' => '请上传证件信息',
  342. 'marry.required' => '请选择婚姻状况',
  343. 'household_register.required' => '请上传户口本',
  344. 'work_prove.required' => '请上传工作证明',
  345. 'company.required' => '请填写工作单位',
  346. 'street.required' => '请填写所属街道',
  347. 'house_condition.required' => '请填写家庭成员在晋江市行政区域内住房情况',
  348. 'house_policy.required' => '请填写在晋享受政策性住房或相关优惠情况',
  349. ];
  350. $validator = Validator::make($data, $rules, $messages);
  351. if ($validator->fails()) {
  352. $msg = $validator->errors()->all();
  353. return response()->json(['status' => 0, 'msg' => $msg[0]]);
  354. }
  355. if ($data['marry'] > 1 && empty($data['marry_prove'])) {
  356. return response()->json(['status' => 0, 'msg' => '请上传婚姻证明']);
  357. }
  358. //报名信息
  359. $info = TalentHouseApply::find($data['id']);
  360. if (empty($info)) {
  361. return response()->json(['status' => 0, 'msg' => '提交格式有误']);
  362. }
  363. if ($info['status'] == 2) {
  364. return response()->json(['status' => 0, 'msg' => '审核通过的信息无法修改']);
  365. }
  366. //房源消息
  367. $house = TalentHouse::find($info['house_id']);
  368. $time = time();
  369. if ($house['status'] != 2) {
  370. return response()->json(['status' => 0, 'msg' => '申报未开始或已结束,无法修改']);
  371. }
  372. if ($time > strtotime($house['supply_time'])) {
  373. return response()->json(['status' => 0, 'msg' => '已超过补件时间,无法修改']);
  374. }
  375. //日志
  376. $log = [
  377. 'house_name' => $house['name'],
  378. 'user_name' => $info['name'],
  379. 'old' => $info['is_draft'] == 1 ? '' : json_encode($info),
  380. 'created_at' => date('Y-m-d H:i:s'),
  381. ];
  382. //图片
  383. $images = ['certificates', 'household_register', 'marry_prove', 'work_prove'];
  384. foreach ($images as $image) {
  385. if (!empty($data[$image]) && is_array($data[$image])) {
  386. //删除掉没有成功返回路径的图片
  387. foreach ($data[$image] as $k => $v) {
  388. if (!array_key_exists('response', $v)) {
  389. unset($data[$image][$k]);
  390. }
  391. }
  392. $data[$image] = array_values($data[$image]);
  393. }
  394. }
  395. //更新数据
  396. $info->certificates = json_encode($data['certificates']);
  397. $info->marry = $data['marry'];
  398. if ($data['marry'] > 1) {
  399. $info->marry_prove = json_encode($data['marry_prove']);
  400. }
  401. $info->household_register = json_encode($data['household_register']);
  402. $info->family = json_encode($data['family']);
  403. $info->work_prove = json_encode($data['work_prove']);
  404. $info->street = $data['street'];
  405. $info->child_num = $data['child_num'];
  406. $info->company = $data['company'];
  407. $info->house_condition = $data['house_condition'];
  408. $info->house_policy = $data['house_policy'];
  409. $info->status = 1;
  410. //审核状态
  411. if ($info->rs_check_status == 3) {
  412. $info->rs_check_status = 1;
  413. }
  414. if ($info->zj_check_status == 3) {
  415. $info->zj_check_status = 1;
  416. }
  417. if ($info->is_draft == 1) {
  418. $info->is_draft = 2;
  419. }
  420. if ($info->is_sock == 2) {
  421. $info->is_sock = 1;
  422. }
  423. $info->save();
  424. //日志
  425. $log['new'] = json_encode($info);
  426. DB::table('talent_house_log')->insert($log);
  427. return response()->json(['status' => 1]);
  428. }
  429. /**
  430. * 撤消
  431. */
  432. public function back(Request $request)
  433. {
  434. $id = $request->get('id');
  435. if (empty($id)) {
  436. return response()->json(['status' => 1]);
  437. }
  438. $apply = TalentHouseApply::find($id);
  439. if (empty($apply) || $apply['user_id'] != auth('web-member')->id() || $apply['is_back'] == 1) {
  440. return response()->json(['status' => 1]);
  441. }
  442. if ($apply['status'] == 2) {
  443. return response()->json(['status' => 0, 'msg' => '已通过审核的申报无法撤消']);
  444. }
  445. $house = TalentHouse::find($apply['house_id']);
  446. if (strtotime($house['apply_time_end']) < time()) {
  447. return response()->json(['status' => 0, 'msg' => '报名结束的申报无法撤消']);
  448. }
  449. $apply->is_back = 1;
  450. $apply->is_sock = 2;
  451. $apply->save();
  452. return response()->json(['status' => 1]);
  453. }
  454. /**
  455. * 图片上传
  456. */
  457. public function upload(Request $request)
  458. {
  459. header('Access-Control-Allow-Origin:*');
  460. header('Access-Control-Allow-Methods:GET,POST,PUT,DELETE');
  461. header('Access-Control-Allow-Headers:Origin, Content-Type, Cookie, Accept, X-CSRF-TOKEN');
  462. header('Access-Control-Allow-Credentials:true');
  463. $file = $request->file('file');
  464. if ($file->isValid()) { //判断文件是否存在
  465. //获取文件的扩展名
  466. $ext = $file->getClientOriginalExtension();
  467. if (!in_array(strtolower($ext), ['jpg', 'jpeg', 'png', 'doc', 'docx', 'pdf'])) {
  468. $res['status'] = 0;
  469. $res['msg'] = '文件格式不正确';
  470. } else {
  471. //获取文件的绝对路径
  472. $path = $file->getRealPath();
  473. $oldname = $file->getClientOriginalName();
  474. //定义文件名
  475. $filename = 'storage/buyhouse/' . uniqid() . mt_rand(10000, 99999) . '.' . $ext;
  476. //存储文件。disk里面的public。总的来说,就是调用disk模块里的public配置
  477. Storage::disk('public')->put($filename, file_get_contents($path));
  478. $res['status'] = 1;
  479. $res['filename'] = $oldname;
  480. $res['path'] = "/storage/" . $filename;
  481. $res['msg'] = '上传成功';
  482. }
  483. } else {
  484. $res['status'] = 0;
  485. $res['msg'] = '上传失败';
  486. }
  487. return response()->json($res);
  488. }
  489. /**
  490. * 登录状态
  491. */
  492. private function checkLogin()
  493. {
  494. $user_id = auth('web-member')->id();
  495. if (empty($user_id)) {
  496. return redirect(route('buyhouse.login'));
  497. }
  498. return false;
  499. }
  500. /**
  501. * 状态
  502. */
  503. private function _get_status($row)
  504. {
  505. $time = time();
  506. if (strtotime($row['apply_time_start']) > $time) {
  507. return 1;
  508. } elseif (strtotime($row['apply_time_end']) < $time) {
  509. return 3;
  510. } else {
  511. return 2;
  512. }
  513. }
  514. }