SurveyController.php 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482
  1. <?php
  2. namespace api\modules\v1\controllers;
  3. use api\common\controllers\Controller;
  4. use common\helpers\CodeImgGenerate;
  5. use common\helpers\Util;
  6. use common\modules\config\models\Config;
  7. use common\models\Survey;
  8. use common\models\SurveyNew;
  9. use Yii;
  10. use yii\helpers\ArrayHelper;
  11. use api\common\behaviors\QueryParamAuth;
  12. use yii\captcha\CaptchaAction;
  13. use common\enums\CodeEnum;
  14. use common\models\Policy;
  15. class SurveyController extends Controller {
  16. public function behaviors()
  17. {
  18. return ArrayHelper::merge(parent::behaviors(), [
  19. [
  20. 'class' => QueryParamAuth::className(),
  21. 'tokenParam' => 'token',
  22. 'optional' => ['index','submit','enterprise','captcha']
  23. ]
  24. ]);
  25. }
  26. public function actionCaptcha()
  27. {
  28. $CodeImgGenerate = new CodeImgGenerate(\Yii::$app->controller->id,\Yii::$app->controller);
  29. $codeInfo = $CodeImgGenerate->inline(); // 验证码二进制流
  30. header("Content-type: image/png"); // 输出图片
  31. exit($codeInfo);
  32. }
  33. /**
  34. * @api {get} /v1/survey 列表
  35. * @apiVersion 1.0.0
  36. * @apiName index
  37. * @apiGroup Survey
  38. *
  39. *
  40. */
  41. public function actionIndex()
  42. {
  43. $type = request()->get('type');
  44. if(empty($type)) $type = 'industry';
  45. $lists = ArrayHelper::toArray(Config::find()->select(['name','value','extra','description','type'])->where(['group' => $type])->all());
  46. foreach ($lists as &$value) {
  47. $value['value'] = explode("\r\n",$value['extra']);
  48. foreach($value['value'] as &$val){
  49. $val = trim($val);
  50. }
  51. unset($value['extra']);
  52. }
  53. return ['data' => $lists];
  54. }
  55. public function actionEnterprise()
  56. {
  57. $params = request()->post();
  58. // $params = [
  59. // 'name'=>'企业名称1',
  60. // 'address'=>'企业注册地',
  61. // 'estdate'=>'2023-10-23',
  62. // 'busAddress'=>'企业实际经营地',
  63. // 'propertyNumber'=>1, //企业有效l类知识产权数
  64. // 'propertyNumber2'=>2, //有效、高企认定中未使用过的II类知识产权数
  65. // 'propertyMode'=>1, //知识产权获取方式 1:自主研发 2:仅有受让、受赠和并购等
  66. // 'isStandard'=>0, //企业参与编制国家标准、行业标准、检测方法、技术规范的情况 1:是 0:否
  67. // 'achievementNumber'=>1, //科技成果数,
  68. // 'manageLevel1'=>1, //定制了企业研究开发组织管理制度
  69. // 'manageLevel2'=>1, //建立了研发投入核算体系
  70. // 'manageLevel3'=>1, //编制了研发费用辅助帐
  71. // 'manageLevel4'=>1, //设立了内部科技技术研究开发机构并具备相应的科研条件
  72. // 'manageLevel5'=>1, //与国内外研究开发机构开展多种形式的产学研合作
  73. // 'manageLevel6'=>1, //建立了科技成果转化的组织实施与激励奖励制度
  74. // 'manageLevel7'=>1, //建立开放式的创新创业平台
  75. // 'manageLevel8'=>1, //建立了科技人员的培养进修制度
  76. // 'manageLevel9'=>1, //建立了职工技能培训制度
  77. // 'netAssets1'=>111, //第1年 净资产
  78. // 'netAssets2'=>222, //第2年 净资产
  79. // 'netAssets3'=>333, //第3年 净资产
  80. // 'saleRevenue1'=>444, //第1年 销售收入
  81. // 'saleRevenue2'=>555, //第2年 销售收入
  82. // 'saleRevenue3'=>666 //第3年 销售收入
  83. // ];
  84. //知识产权数量
  85. $numberScore = 0;
  86. if($params['propertyNumber2'] == 1 || $params['propertyNumber2'] == 2) $numberScore = 2;
  87. if($params['propertyNumber2'] == 3 || $params['propertyNumber2'] == 4) $numberScore = 4;
  88. if($params['propertyNumber2'] >= 5) $numberScore = 6;
  89. if($params['propertyNumber'] > 1) $numberScore = 8;
  90. //知识产权获得方式
  91. $modeScore = 0;
  92. if($params['propertyMode'] == 1) $numberScore = 6;
  93. if($params['propertyMode'] == 2) $numberScore = 3;
  94. //企业参与编制国家标准、行业标准、检测方法、技术规范的情况
  95. $standardScore = 0;
  96. if($params['isStandard'] == 1) $standardScore = 2;
  97. //科技成果转化能力
  98. $techniquesAchieveScore = 0;
  99. if($params['achievementNumber'] == 1) $techniquesAchieveScore = 6;
  100. if($params['achievementNumber'] == 2) $techniquesAchieveScore = 12;
  101. if($params['achievementNumber'] == 3) $techniquesAchieveScore = 18;
  102. if($params['achievementNumber'] == 4) $techniquesAchieveScore = 25;
  103. if($params['achievementNumber'] >= 5) $techniquesAchieveScore = 30;
  104. //研究开发组织管理水平
  105. $manageLevelScore = 0;
  106. if($params['manageLevel1'] == 1) $manageLevelScore += 2;
  107. if($params['manageLevel2'] == 1) $manageLevelScore += 2;
  108. if($params['manageLevel3'] == 1) $manageLevelScore += 2;
  109. if($params['manageLevel4'] == 1) $manageLevelScore += 3;
  110. if($params['manageLevel5'] == 1) $manageLevelScore += 3;
  111. if($params['manageLevel6'] == 1) $manageLevelScore += 2;
  112. if($params['manageLevel7'] == 1) $manageLevelScore += 2;
  113. if($params['manageLevel8'] == 1) $manageLevelScore += 2;
  114. if($params['manageLevel9'] == 1) $manageLevelScore += 2;
  115. //净资产增长率
  116. $growthRate = (0.5 * ($params['netAssets2'] / $params['netAssets1'] + $params['netAssets3'] / $params['netAssets2']) - 1) * 100;
  117. $growthRateScore = 0;
  118. if($growthRate > 0) $growthRateScore = 2;
  119. if($growthRate > 5) $growthRateScore = 4;
  120. if($growthRate > 10) $growthRateScore = 6;
  121. if($growthRate > 20) $growthRateScore = 9;
  122. //销售收入增长率
  123. $saleRate = (0.5 * ($params['saleRevenue2'] / $params['saleRevenue1'] + $params['saleRevenue3'] / $params['saleRevenue2']) - 1) * 100;
  124. $saleRateScore = 0;
  125. if($saleRate > 0) $saleRateScore = 2;
  126. if($saleRate > 10) $saleRateScore = 4;
  127. if($saleRate > 20) $saleRateScore = 6;
  128. if($saleRate > 30) $saleRateScore = 7;
  129. $result = [
  130. 'totalScore'=>8 + 8 + $numberScore + $modeScore + $standardScore + $numberScore + $modeScore + $standardScore + $techniquesAchieveScore + $manageLevelScore + $growthRateScore + $saleRateScore, //企业评测总得分
  131. 'basic'=>[
  132. 'name'=>$params['name'],
  133. 'address'=>$params['address'],
  134. 'estdate'=>$params['estdate'],
  135. 'busAddress'=>$params['busAddress'],
  136. 'propertyNumber'=>$params['propertyNumber'],
  137. 'propertyNumber2'=>$params['propertyNumber2'],
  138. 'propertyMode'=>$params['propertyMode'],
  139. 'isStandard'=>$params['isStandard'],
  140. 'achievementNumber'=>$params['achievementNumber'],
  141. ],
  142. 'knowledgeVo'=>[
  143. 'knowledgeTotalScore'=>$numberScore + $modeScore + $standardScore + 8 + 8, //知识产权
  144. 'techniquesScore'=>8, //技术的先进程度
  145. 'effectScore'=>8, //对主要产品(服务)在技术上发挥核心支持作用(8分)
  146. 'numberScore'=>$numberScore, //知识产权数量
  147. 'modeScore'=>$modeScore, //知识产权获得方式
  148. 'standardScore'=>$standardScore //企业参与编制国家标准、行业标准、检测方法、技术规范的情况
  149. ],
  150. 'techniquesAchieveScore'=>$techniquesAchieveScore, //科技成果转化能力
  151. 'manageLevelScore'=>$manageLevelScore, //研究开发组织管理水平
  152. 'enterpriseGrowthVo'=>[
  153. 'totalScore'=>$growthRateScore + $saleRateScore, //企业成长性
  154. 'growthRateScore'=>$growthRateScore, //净资产增长率得分
  155. 'saleRateScore'=>$saleRateScore, //销售收入增长率得分
  156. ]
  157. ];
  158. return ['data' => $result];
  159. }
  160. public function actionSubmit()
  161. {
  162. $data = request()->post();
  163. $type = request()->post('type');
  164. if(empty($type)) $type = 'industry';
  165. $survey = ArrayHelper::toArray(SurveyNew::find()->where(['type' => $type])->all());
  166. $captcha = new CodeImgGenerate(\Yii::$app->controller->id,\Yii::$app->controller);
  167. $result = $captcha->validate($data['code']);
  168. if(!$result){
  169. return ['errcode' => CodeEnum::CODE_ERROR, 'errmsg' => '验证码错误'];
  170. }
  171. $selects = ArrayHelper::toArray(Config::find()->where(['group' => 'industry','type' => 'select'])->all());
  172. $list = [];
  173. if($type == 'special'){
  174. foreach ($survey as $key=>$value) {
  175. $filter = explode(';',$value['filter']);//先判断第一层and关系
  176. $is_match = [];
  177. foreach ($filter as $key1 => $value1){
  178. if(!empty($value1)){
  179. if(strpos($value1,'|') !== false){//如果有存在判断大小
  180. $filter2 = explode('|',$value1);
  181. if($value['id'] == 1144 && $filter2[0] == 'shebao'){
  182. var_dump($data , $filter2[2]);die;
  183. }
  184. if(array_key_exists($filter2[0],$data) && !empty($data[$filter2[0]]) && $data[$filter2[0]] != '请选择'){
  185. switch ($filter2[1]){
  186. case '>=':
  187. if($data[$filter2[0]] >= $filter2[2]){
  188. $is_match[$key1] = true;
  189. }else{
  190. $is_match[$key1] = false;
  191. continue 2;
  192. }
  193. break;
  194. case '=':
  195. if($data[$filter2[0]] == $filter2[2]){
  196. $is_match[$key1] = true;
  197. }else{
  198. $is_match[$key1] = false;
  199. continue 2;
  200. }
  201. break;
  202. case '<=':
  203. if($data[$filter2[0]] <= $filter2[2] && $data[$filter2[0]] > 0){
  204. $is_match[$key1] = true;
  205. }else{
  206. $is_match[$key1] = false;
  207. continue 2;
  208. }
  209. break;
  210. case 'in':
  211. $arr = explode(',',$filter2[2]);
  212. if(in_array($data[$filter2[0]],$arr)){
  213. $is_match[$key1] = true;
  214. }else{
  215. $is_match[$key1] = false;
  216. continue 2;
  217. }
  218. break;
  219. }
  220. }else{
  221. $is_match[$key1] = false;
  222. continue 2;
  223. }
  224. }
  225. }
  226. }
  227. $match_count = 0;
  228. foreach ($is_match as $v){
  229. if($v){
  230. $match_count++;
  231. }
  232. }
  233. if($match_count == count($filter)){
  234. $list[] = [
  235. 'id'=>$value['id'],
  236. 'title'=>$value['title'],
  237. 'content'=>$value['content'],
  238. 'level' => $value['cengci']
  239. ];
  240. }
  241. }
  242. var_dump($list);die;
  243. $cengci = [];
  244. $level = [];
  245. foreach($list as $k => $v){
  246. if(!in_array($v['level'],$level)){
  247. $cengci[] = [
  248. 'id' => $v['id'],
  249. 'title' => $v['level'],
  250. 'content' => '',
  251. 'level' => $v['level'],
  252. 'policy' => []
  253. ];
  254. array_push($level,$v['level']);
  255. $index = count($level) - 1;
  256. }else{
  257. $index = array_search($v['level'],$level);
  258. }
  259. $zclist = Policy::find()->where(['type' => Policy::TYPE_SURVEY, 'estate' => $type,'title' => $v['title']])->andWhere(['like','cengci',"{$v['level']}"])->all();
  260. $cengci[$index]['policy'] = array_merge($cengci[$index]['policy'],$zclist);
  261. }
  262. }else{
  263. foreach ($survey as $key=>$value) {
  264. $filter = explode(';',$value['filter']);//先判断第一层and关系
  265. $is_match = [];
  266. foreach ($filter as $key1 => $value1){
  267. if(!empty($value1)){
  268. if(array_key_exists($value1,$data) && !empty($data[$value1]) && $data[$value1] != '请选择' && !in_array($value1,['shengte','shenga','quanyi','shengb','rencaileixing','zhuanyelingyunianxian'])){
  269. if(strpos($value['title'],(string)$data[$value1]) === false){//如果用户提交的信息字眼有出现在政策条件内,相当于条件符合
  270. $is_match[$key1] = false;
  271. continue 2;
  272. }else{
  273. $is_match[$key1] = true;
  274. }
  275. }
  276. if(strpos($value1,'-') !== false){//如果有存在或关系
  277. $filter1 = explode('-',$value1);
  278. $i = 0;
  279. foreach ($filter1 as $key2 => $value2){
  280. if(!in_array($value2,['shengte','shenga','quanyi','shengb','rencaileixing','zhuanyelingyunianxian'])){
  281. if(array_key_exists($value2,$data) && !empty($data[$value2]) && $data[$value2] != '请选择'){
  282. if(strpos($value['title'],(string)$data[$value2]) !== false){//如果用户提交的信息字眼有出现在政策条件内,相当于条件符合
  283. $i++;
  284. }
  285. }
  286. }else{
  287. if(strpos($value2,'|') !== false){
  288. $filter3 = explode('|',$value2);
  289. if(array_key_exists($filter3[0],$data) && !empty($data[$filter3[0]]) && $data[$filter3[0]] != '请选择'){
  290. switch ($filter3[1]){
  291. case '>=':
  292. if($data[$filter3[0]] >= $filter3[2]){
  293. $i++;
  294. }
  295. break;
  296. case '=':
  297. if($data[$filter3[0]] == $filter3[2]){
  298. $i++;
  299. }
  300. break;
  301. case '<=':
  302. if($data[$filter3[0]] <= $filter3[2] && $data[$filter3[0]] > 0){
  303. $i++;
  304. }
  305. break;
  306. }
  307. }
  308. }
  309. }
  310. }
  311. if($i == 0){
  312. $is_match[$key1] = false;
  313. continue 2;
  314. }else{
  315. $is_match[$key1] = true;
  316. }
  317. }
  318. if(strpos($value1,'|') !== false){//如果有存在判断大小
  319. $filter2 = explode('|',$value1);
  320. if(array_key_exists($filter2[0],$data) && !empty($data[$filter2[0]]) && $data[$filter2[0]] != '请选择'){
  321. switch ($filter2[1]){
  322. case '>=':
  323. if($data[$filter2[0]] >= $filter2[2]){
  324. $is_match[$key1] = true;
  325. }else{
  326. $is_match[$key1] = false;
  327. continue 2;
  328. }
  329. break;
  330. case '=':
  331. if($data[$filter2[0]] == $filter2[2]){
  332. $is_match[$key1] = true;
  333. }else{
  334. $is_match[$key1] = false;
  335. continue 2;
  336. }
  337. break;
  338. case '<=':
  339. if($data[$filter2[0]] <= $filter2[2] && $data[$filter2[0]] > 0){
  340. $is_match[$key1] = true;
  341. }else{
  342. $is_match[$key1] = false;
  343. continue 2;
  344. }
  345. break;
  346. }
  347. }else{
  348. $is_match[$key1] = false;
  349. continue 2;
  350. }
  351. }
  352. }
  353. }
  354. $match_count = 0;
  355. foreach ($is_match as $v){
  356. if($v){
  357. $match_count++;
  358. }
  359. }
  360. if($match_count == count($filter)){
  361. switch ($value['cengci']){
  362. case '1':
  363. $level = '第一层次';
  364. break;
  365. case '2':
  366. $level = '第二层次';
  367. break;
  368. case '3':
  369. $level = '第三层次';
  370. break;
  371. case '4':
  372. $level = '第四层次';
  373. break;
  374. case '5':
  375. $level = '第五层次';
  376. break;
  377. case '6':
  378. $level = '第六层次';
  379. break;
  380. case '7':
  381. $level = '第七层次';
  382. break;
  383. }
  384. $list[] = [
  385. 'id'=>$value['id'],
  386. 'title'=>$value['title'],
  387. 'content'=>$value['content'],
  388. 'level' => $level
  389. ];
  390. }
  391. }
  392. foreach($list as $k => $v){
  393. $zclist = Policy::find()->where(['type' => Policy::TYPE_SURVEY, 'estate' => $type])->andWhere(['like','cengci',"{$v['level']}"])->all();
  394. $list[$k]['policy'] = $zclist;
  395. }
  396. //去重复
  397. $cengci = [];
  398. foreach ($list as $value) {
  399. if(isset($cengci[$value['level']])){
  400. unset($value['level']);
  401. }else{
  402. $cengci[$value['level']] = $value;
  403. }
  404. }
  405. $cengci = array_values($cengci);
  406. }
  407. return ['data' => $cengci];
  408. }
  409. /**
  410. * @api {get} /v1/category/id:\d+ 分类详情
  411. * @apiVersion 1.0.0
  412. * @apiName view
  413. * @apiGroup Category
  414. *
  415. */
  416. public function actionView($id)
  417. {
  418. $model = Category::find()->where(['id' => $id])->one();
  419. return ['data' => $model];
  420. }
  421. }