Enterprise.php 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510
  1. <?php
  2. namespace app\admin\controller;
  3. use app\admin\common\AdminController;
  4. use app\common\api\ChuanglanSmsApi;
  5. use app\common\api\DictApi;
  6. use app\common\api\EnterpriseApi;
  7. use app\common\model\MessageRecord;
  8. use app\common\model\TalentChecklog;
  9. use app\common\api\TalentState;
  10. use app\common\api\CompanyApi;
  11. use think\facade\Db;
  12. class Enterprise extends AdminController {
  13. public function gotoEnterprisePage() {
  14. return view("", []);
  15. }
  16. public function findEnterpriseByPage() {
  17. $res = EnterpriseApi::getList($this->request);
  18. return json($res);
  19. }
  20. public function gotoEnterpriseDetailPage() {
  21. $id = trim($this->request['id']);
  22. $ep = EnterpriseApi::getOne($id);
  23. if (!$ep) {
  24. return "无此企业";
  25. }
  26. //--------设置 审核状态---------------------------------------------------
  27. switch ($ep['checkState']) {
  28. case 1:
  29. $ep['checkStateName'] = "待审核";
  30. break;
  31. case 2:
  32. $ep['checkStateName'] = "审核驳回";
  33. break;
  34. case 3:
  35. $ep['checkStateName'] = "审核通过";
  36. break;
  37. case 4:
  38. $ep['checkStateName'] = "重新提交";
  39. break;
  40. }
  41. //-------设置账号状态----------------------------------------------------
  42. switch ($ep['active']) {
  43. case 1:
  44. $ep['activeName'] = "账号有效";
  45. break;
  46. case 2:
  47. $ep['activeName'] = "冻结/拉黑";
  48. break;
  49. }
  50. //---------设置 街道-----------------------------------------------------
  51. if (\StrUtil::isNotEmpAndNull($ep['street'])) {
  52. $street_info = DictApi::findByParentCodeAndCode('street', $ep['street']);
  53. if ($street_info != null) {
  54. $ep['streetName'] = $street_info['name'];
  55. }
  56. }
  57. if (\StrUtil::isNotEmpAndNull($ep['agencyType'])) {
  58. $agencyType = DictApi::findByParentCodeAndCode('agency_type', $ep['agencyType']);
  59. $ep["agencyTypeName"] = $agencyType["name"];
  60. }
  61. //---------设置产业领域 --------------------------------------------------
  62. if (\StrUtil::isNotEmpAndNull($ep['industryFieldNew'])) {
  63. $industryFieldNew = DictApi::findByParentCodeAndCode('industry_field', $ep['industryFieldNew']);
  64. if ($industryFieldNew != null) {
  65. $ep['industryFieldNewName'] = $industryFieldNew['name'];
  66. }
  67. }
  68. //---------设置行业领域 --------------------------------------------------
  69. if (\StrUtil::isNotEmpAndNull($ep['industryFieldOld'])) {
  70. $industryFieldOld = DictApi::findByParentCodeAndCode($ep['industryFieldNew'] . "_field", $ep['industryFieldOld']);
  71. if ($industryFieldOld != null) {
  72. $ep['industryFieldOldName'] = $industryFieldOld['name'];
  73. }
  74. }
  75. //---------设置单位标签 --------------------------------------------------
  76. if (\StrUtil::isNotEmpAndNull($ep['enterpriseTag'])) {
  77. $enterpriseTag = DictApi::findByParentCodeAndCode("enterprise_tag", $ep['enterpriseTag']);
  78. if ($enterpriseTag != null) {
  79. $ep['enterpriseTagName'] = $enterpriseTag['name'];
  80. }
  81. }
  82. //---------设置机构标签 --------------------------------------------------
  83. if (\StrUtil::isNotEmpAndNull($ep['organizationTag'])) {
  84. $organizationTag = DictApi::findByParentCodeAndCode("organization_tag", $ep['organizationTag']);
  85. if ($organizationTag != null) {
  86. $ep['organizationTagName'] = $organizationTag['name'];
  87. }
  88. }
  89. //---------设置事业单位标签 --------------------------------------------------
  90. if (\StrUtil::isNotEmpAndNull($ep['institutionTag'])) {
  91. $institutionTag = DictApi::findByParentCodeAndCode("institution_tag", $ep['institutionTag']);
  92. if ($institutionTag != null) {
  93. $ep['institutionTagName'] = $institutionTag['name'];
  94. }
  95. }
  96. //---------设置单位类型 --------------------------------------------------
  97. if (\StrUtil::isNotEmpAndNull($ep['enterpriseType'])) {
  98. $enterpriseType = DictApi::findByParentCodeAndCode("enterprise_type", $ep['enterpriseType']);
  99. if ($enterpriseType != null) {
  100. $ep['enterpriseTypeName'] = $enterpriseType['name'];
  101. }
  102. }
  103. $imgurl_info = pathinfo($ep['imgurl']);
  104. if (in_array($imgurl_info['extension'], ["jpeg", "jpg", "png", "gif"])) {
  105. $ep['imgurl_is_img'] = 1;
  106. } else {
  107. $ep['imgurl_is_img'] = 0;
  108. }
  109. $bankImg_info = pathinfo($ep['bankImg']);
  110. if (in_array($bankImg_info['extension'], ["jpeg", "jpg", "png", "gif"])) {
  111. $ep['bankImg_is_img'] = 1;
  112. } else {
  113. $ep['bankImg_is_img'] = 0;
  114. }
  115. $domainImg_info = pathinfo($ep['domainImg']);
  116. if (in_array($domainImg_info['extension'], ["jpeg", "jpg", "png", "gif"])) {
  117. $ep['domainImg_is_img'] = 1;
  118. } else {
  119. $ep['domainImg_is_img'] = 0;
  120. }
  121. $typeImg_info = pathinfo($ep['typeImg']);
  122. if (in_array($typeImg_info['extension'], ["jpeg", "jpg", "png", "gif"])) {
  123. $ep['typeImg_is_img'] = 1;
  124. } else {
  125. $ep['typeImg_is_img'] = 0;
  126. }
  127. $beian_info = pathinfo($ep['beian']);
  128. if (in_array($beian_info['extension'], ["jpeg", "jpg", "png", "gif"])) {
  129. $ep['beian_is_img'] = 1;
  130. } else {
  131. $ep['beian_is_img'] = 0;
  132. }
  133. return view("", ['ep' => $ep]);
  134. }
  135. public function gotoExaminePage() {
  136. $id = trim($this->request['id']);
  137. $ep = EnterpriseApi::getOne($id);
  138. if (!$ep) {
  139. return "无此企业";
  140. }
  141. //---------设置产业领域 --------------------------------------------------
  142. if (\StrUtil::isNotEmpAndNull($ep['industryFieldNew'])) {
  143. $industryFieldNew = DictApi::findByParentCodeAndCode('industry_field', $ep['industryFieldNew']);
  144. if ($industryFieldNew != null) {
  145. $ep['industryFieldNewName'] = $industryFieldNew['name'];
  146. }
  147. }
  148. if ($ep->special == 0) {
  149. if ($ep->type == 1) {
  150. $fields = ["Name" => "企业名称", "IdCard" => "统一社会信用代码", "Legal" => "法人代表", "Address" => "企业地址", "Street" => "所属街道", "Ephone" => "企业电话", "BankCard" => "企业银行账号", "Bank" => "企业开户银行", "BankNetwork" => "企业开户银行网点",
  151. "AgencyType" => "机构类型", "IndustryFieldNew" => "产业领域", "IndustryFieldOld" => "行业领域", "EnterpriseTag" => "企业标签", "EnterpriseType" => "企业类型",
  152. "AgentName" => "人才联络员姓名", "AgentPhone" => "人才联络员电话", "AgentEmail" => "人才联络员邮箱"];
  153. $files = ["newImgurl" => "企业营业执照", "newBankImg" => "开户许可证/基本存款账户信息", "newDomainImg" => "行业领域佐证材料", "newBeian" => "人才联络员信息备案表", "newTypeImg" => "规上、高新技术、专精特新企业上传材料"];
  154. } else {
  155. $fields = ["Name" => "企业名称", "IdCard" => "统一社会信用代码", "Legal" => "法人代表", "Address" => "企业地址", "Street" => "所属街道", "Ephone" => "企业电话", "BankCard" => "企业银行账号", "Bank" => "企业开户银行", "BankNetwork" => "企业开户银行网点",
  156. "AgentName" => "人才联络员姓名", "AgentPhone" => "人才联络员电话", "AgentEmail" => "人才联络员邮箱"];
  157. $files = ["newImgurl" => "企业营业执照", "newBankImg" => "开户许可证/基本存款账户信息", "newBeian" => "人才联络员备案表"];
  158. }
  159. } else {
  160. $fields = ["Name" => "单位名称", "IdCard" => "统一社会信用代码", "Legal" => "法人代表", "Address" => "单位地址", "Street" => "所属街道", "Ephone" => "单位电话", "BankCard" => "单位银行账号", "Bank" => "单位开户银行", "BankNetwork" => "单位开户银行网点",
  161. "AgentName" => "人才联络员姓名", "AgentPhone" => "人才联络员电话", "AgentEmail" => "人才联络员邮箱"];
  162. if ($ep->special == 1) {
  163. $fields["InstitutionTag"] = "单位标签";
  164. }
  165. if ($ep->special == 3) {
  166. $fields["OrganizationTag"] = "机构标签";
  167. }
  168. $files = ["newImgurl" => "法人证或批文", "newBankImg" => "开户许可证/基本存款账户信息", "newBeian" => "人才联络员备案表"];
  169. }
  170. $modify_fields = [];
  171. foreach ($fields as $key => $value) {
  172. $oldFieldName = "old" . $key;
  173. $newFieldName = "new" . $key;
  174. //if ($ecr[$oldFieldName] != $ecr[$newFieldName]) {
  175. $modify_fields[$newFieldName] = ["field" => $newFieldName, "name" => $value, "checked" => false];
  176. //}
  177. }
  178. if ($ecr["modify_fields"]) {
  179. $_modify_fields = explode(",", $ecr["modify_fields"]);
  180. foreach ($_modify_fields as $_field) {
  181. if ($modify_fields[$_field]) {
  182. $modify_fields[$_field]["checked"] = true;
  183. } else {
  184. $modify_fields[$_field] = ["field" => $_field, "name" => $fields[substr($_field, 3)], "checked" => true];
  185. }
  186. }
  187. }
  188. return view("", ['ep' => $ep, 'checkUser' => session('user')['name']]);
  189. }
  190. public function doExamine() {
  191. $id = trim($this->request['id']);
  192. if (!$id) {
  193. return json(["msg" => 'ID不能为空!']);
  194. }
  195. $ep = EnterpriseApi::getOne($id);
  196. if (!$ep) {
  197. return json(["msg" => '无此企业!']);
  198. }
  199. $checkState = $this->request['checkState'];
  200. if ($checkState == null || ($checkState != 2 && $checkState != 3)) {
  201. return json(["msg" => '请选择审核状态!']);
  202. }
  203. $checkMsg = $this->request['checkMsg'];
  204. if ($checkState == 2) {
  205. if (\StrUtil::isEmpOrNull($checkMsg)) {
  206. return json(["msg" => '请填写审核意见!']);
  207. }
  208. if (strlen($checkMsg) > 1000) {
  209. return json(["msg" => '审核意见最多1000个字符!']);
  210. }
  211. }
  212. try {
  213. $checkData = [
  214. 'id' => $id,
  215. 'checkState' => $checkState,
  216. 'checkMsg' => $checkMsg,
  217. 'checkUser' => session('user')['name'],
  218. 'updateUser' => session('user')['uid'],
  219. 'updateTime' => date("Y-m-d H:i:s")
  220. ];
  221. $res = EnterpriseApi::updateById($checkData);
  222. //短信入库数据
  223. $record_data = [
  224. 'id' => getStringId(),
  225. 'bizId' => getStringId(),
  226. 'userId' => $id,
  227. 'type' => 2,
  228. 'smsType' => 2,
  229. 'name' => $ep['name'],
  230. 'phone' => $ep['agentPhone'],
  231. 'params' => '机构注册信息',
  232. 'state' => 1,
  233. 'sendingDate' => date("Y-m-d H:i:s", time()),
  234. 'createTime' => date("Y-m-d H:i:s", time())
  235. ];
  236. if ($checkState == 2) {
  237. $record_data['templateCode'] = "【晋江市人才服务平台】您好!您提交的晋江市现代产业体系人才机构注册信息因信息填写错误或上传不完整已被退回,请及时登录“晋江市人才综合服务申报平台”根据审核意见修改并重新提交。退订回复TD。";
  238. }
  239. if ($checkState == 3) {
  240. $record_data['templateCode'] = "【晋江市人才服务平台】您好!您提交的晋江市现代产业体系人才机构注册信息已审核通过,可登录“晋江市人才综合服务申报平台”做相关事宜申报。退订回复TD。";
  241. }
  242. $smsapi = new ChuanglanSmsApi();
  243. $result = $smsapi->sendSMS($ep['agentPhone'], $record_data['templateCode']);
  244. MessageRecord::create($record_data);
  245. $company = CompanyApi::getOne(session('user')['companyId']);
  246. TalentChecklog::create([
  247. 'id' => getStringId(),
  248. 'mainId' => $id,
  249. 'type' => 10,
  250. 'typeField' => null,
  251. 'active' => 1,
  252. 'state' => $checkState,
  253. 'step' => 101,
  254. 'stateChange' => TalentState::stateEnum($checkState),
  255. 'description' => $checkMsg,
  256. 'createTime' => date("Y-m-d H:i:s", time()),
  257. 'createUser' => session('user')['name'] . "({$company['name']})"
  258. ]);
  259. return json(["msg" => '操作成功!', "code" => 200]);
  260. } catch (\Exception $e) {
  261. return json(["msg" => $e->getMessage()]);
  262. }
  263. }
  264. public function GotoActivePage() {
  265. $id = trim($this->request['id']);
  266. $ep = EnterpriseApi::getOne($id);
  267. return view("", ['ep' => $ep]);
  268. }
  269. public function setActive() {
  270. if (!$id = trim($this->request['id'])) {
  271. return json(["msg" => 'ID不能为空!', "code" => 500]);
  272. }
  273. $ep = EnterpriseApi::getOne($id);
  274. $active = $this->request['active'];
  275. if ($ep['active'] == null || ($ep['active'] != 1 && $ep['active'] != 2)) {
  276. return json(["msg" => '状态有误!', "code" => 500]);
  277. }
  278. if ($ep['active'] == 2) {
  279. $msg = trim($this->request['activeMsg']);
  280. if (empty($msg)) {
  281. return json(["msg" => '请填写拉黑/冻结原因!', "code" => 500]);
  282. }
  283. if (strlen($msg) > 100) {
  284. return json(["msg" => '拉黑/冻结原因 最多100个字符!', "code" => 500]);
  285. }
  286. }
  287. $company = CompanyApi::getOne(session('user')['companyId']);
  288. $ep->active = $active;
  289. $ep->activeMsg = $msg;
  290. $ep->updateUser = session('user')['uid'] . "";
  291. $ep->updateTime = date('y-m-d H:i:s');
  292. try {
  293. $ep->save();
  294. //添加日志
  295. TalentChecklog::create([
  296. 'id' => getStringId(),
  297. 'mainId' => $ep['id'],
  298. 'type' => 10,
  299. 'typeField' => null,
  300. 'active' => 1,
  301. 'state' => TalentState::RCRD_BASEIC_FROZEN,
  302. 'step' => 102,
  303. 'stateChange' => TalentState::stateEnum(10),
  304. 'description' => $msg,
  305. 'createTime' => date("Y-m-d H:i:s", time()),
  306. 'createUser' => session('user')['name'] . "({$company['name']})"
  307. ]);
  308. return json(["msg" => '操作成功!', "code" => 200]);
  309. } catch (\Exception $e) {
  310. return json(["msg" => $e->getMessage()]);
  311. }
  312. }
  313. public function resetPassword() {
  314. if (!$id = trim($this->request['id'])) {
  315. return json(["msg" => 'ID不能为空!', "code" => 500]);
  316. }
  317. $ep = EnterpriseApi::getOne($id);
  318. if (!$ep) {
  319. return json(["msg" => '找不到该用户!', "code" => 500]);
  320. }
  321. $ep->password = hash("md5", 'JJrc@123'); //默认密码
  322. $ep->updateUser = session('user')['uid'] . "";
  323. $ep->updateTime = date("Y-m-d H:i:s");
  324. $ep->save();
  325. $company = CompanyApi::getOne(session('user')['companyId']);
  326. TalentChecklog::create([
  327. 'id' => getStringId(),
  328. 'mainId' => $ep['id'],
  329. 'type' => 10,
  330. 'typeField' => null,
  331. 'active' => 1,
  332. 'state' => null,
  333. 'step' => 103,
  334. 'stateChange' => '重置密码',
  335. 'description' => '重置密码',
  336. 'createTime' => date("Y-m-d H:i:s", time()),
  337. 'createUser' => session('user')['name'] . "({$company['name']})"
  338. ]);
  339. return json(["msg" => '重置密码成功!', "code" => 200]);
  340. }
  341. public function export() {
  342. $res = EnterpriseApi::getList($this->request);
  343. $objPHPExcel = new \PhpOffice\PhpSpreadsheet\Spreadsheet();
  344. //创建人
  345. $objPHPExcel->getProperties()->setCreator("System");
  346. //最后修改人
  347. $objPHPExcel->getProperties()->setLastModifiedBy("System");
  348. //标题
  349. $objPHPExcel->getProperties()->settitle("企业用户信息" . date("ymdHis"));
  350. $objPHPExcel->getDefaultStyle()->getAlignment()->setHorizontal(\PhpOffice\PhpSpreadsheet\Style\Alignment::HORIZONTAL_CENTER);
  351. $objPHPExcel->getDefaultStyle()->getAlignment()->setVertical(\PhpOffice\PhpSpreadsheet\Style\Alignment::HORIZONTAL_CENTER);
  352. //设置当前的sheet
  353. $sheet = $objPHPExcel->getActiveSheet();
  354. //设置sheet的name
  355. $sheet->settitle('企业用户信息');
  356. // 所有单元格默认高度
  357. $sheet->getDefaultRowDimension()->setRowHeight(30);
  358. $sheet->getDefaultColumnDimension()->setWidth(30);
  359. $sheet->getstyle('A1:O1')->getFill()->setFillType(\PhpOffice\PhpSpreadsheet\Style\Fill::FILL_SOLID)->getStartColor()->setRGB("87CEEB");
  360. $header = ["单位名称", " 统一社会信用代码", "产业领域", "单位标签", " 所属街道", "单位地址", " 法人代表", " 单位电话", "人才联络员", "人才联络员电话", "人才联络员邮箱", "审核状态", "账号状态", "注册时间", "备注"];
  361. foreach ($header as $key => $value) {
  362. $sheet->setCellValueByColumnAndRow($key + 1, 1, $value);
  363. }
  364. if ($res['total'] > 0) {
  365. $row = 2;
  366. foreach ($res['rows'] as $k => $v) {
  367. for ($i = 0; $i < count($header); $i++) {
  368. switch ($i) {
  369. case 0:
  370. $sheet->setCellValueByColumnAndRow($i + 1, $row, $v['name']);
  371. break;
  372. case 1:
  373. $sheet->setCellValueByColumnAndRow($i + 1, $row, $v['idCard']);
  374. break;
  375. case 2:
  376. $sheet->setCellValueByColumnAndRow($i + 1, $row, $v['industryFieldNewName']);
  377. break;
  378. case 3:
  379. $sheet->setCellValueByColumnAndRow($i + 1, $row, $v['enterpriseTagName']);
  380. break;
  381. case 4:
  382. $sheet->setCellValueByColumnAndRow($i + 1, $row, $v['streetName']);
  383. break;
  384. case 5:
  385. $sheet->setCellValueByColumnAndRow($i + 1, $row, $v['address']);
  386. break;
  387. case 6:
  388. $sheet->setCellValueByColumnAndRow($i + 1, $row, $v['legal']);
  389. break;
  390. case 7:
  391. $sheet->setCellValueExplicitByColumnAndRow($i + 1, $row, $v['ephone'], \PhpOffice\PhpSpreadsheet\Cell\DataType::TYPE_STRING);
  392. break;
  393. case 8:
  394. $sheet->setCellValueByColumnAndRow($i + 1, $row, $v['agentName']);
  395. break;
  396. case 9:
  397. $sheet->setCellValueExplicitByColumnAndRow($i + 1, $row, $v['agentPhone'], \PhpOffice\PhpSpreadsheet\Cell\DataType::TYPE_STRING);
  398. break;
  399. case 10:
  400. $sheet->setCellValueByColumnAndRow($i + 1, $row, $v['agentEmail']);
  401. break;
  402. case 11:
  403. switch ($v['checkState']) {
  404. case 1:
  405. $sheet->setCellValueByColumnAndRow($i + 1, $row, "未审核");
  406. break;
  407. case 2:
  408. $sheet->setCellValueByColumnAndRow($i + 1, $row, "审核驳回");
  409. break;
  410. case 3:
  411. $sheet->setCellValueByColumnAndRow($i + 1, $row, "审核通过");
  412. break;
  413. case 4:
  414. $sheet->setCellValueByColumnAndRow($i + 1, $row, "重新提交");
  415. break;
  416. default:
  417. $sheet->setCellValueByColumnAndRow($i + 1, $row, "");
  418. break;
  419. }
  420. break;
  421. case 12:
  422. switch ($v['active']) {
  423. case 1:
  424. $sheet->setCellValueByColumnAndRow($i + 1, $row, "账号有效");
  425. break;
  426. case 2:
  427. $sheet->setCellValueByColumnAndRow($i + 1, $row, "拉黑/冻结");
  428. break;
  429. default:
  430. $sheet->setCellValueByColumnAndRow($i + 1, $row, "");
  431. break;
  432. }
  433. break;
  434. case 13:
  435. $sheet->setCellValueByColumnAndRow($i + 1, $row, $v['createTime']);
  436. break;
  437. case 14:
  438. $sheet->setCellValueByColumnAndRow($i + 1, $row, $v['description']);
  439. break;
  440. }
  441. }
  442. $row++;
  443. }
  444. }
  445. header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
  446. header('Content-Disposition: attachment;filename="' . "企业用户信息" . date("ymdHis") . '.xlsx"');
  447. header('Cache-Control: max-age=0');
  448. // If you're serving to IE 9, then the following may be needed
  449. header('Cache-Control: max-age=1');
  450. // If you're serving to IE over SSL, then the following may be needed
  451. header('Expires: Mon, 26 Jul 1997 05:00:00 GMT'); // Date in the past
  452. header('Last-Modified: ' . gmdate('D, d M Y H:i:s') . ' GMT'); // always modified
  453. header('Cache-Control: cache, must-revalidate'); // HTTP/1.1
  454. header('Pragma: public'); // HTTP/1.0
  455. $writer = \PhpOffice\PhpSpreadsheet\IOFactory::createWriter($objPHPExcel, 'Xlsx');
  456. $writer->save('php://output');
  457. }
  458. }