diff --git a/application/api/controller/Article.php b/application/api/controller/Article.php index af1e8db..d414c75 100644 --- a/application/api/controller/Article.php +++ b/application/api/controller/Article.php @@ -34,6 +34,7 @@ class Article extends Controller { protected $article_dialog_obj = ''; protected $article_proposal_obj = ''; protected $user_black_obj = ''; + protected $user_reviewer_recommend_obj = ''; public function __construct(\think\Request $request = null) { parent::__construct($request); @@ -59,6 +60,7 @@ class Article extends Controller { $this->article_dialog_obj = Db::name('article_dialog'); $this->article_proposal_obj = Db::name('article_proposal'); $this->user_black_obj = Db::name('user_black'); + $this->user_reviewer_recommend_obj = Db::name('user_reviewer_recommend'); } /** @@ -1312,6 +1314,35 @@ class Article extends Controller { public function addArticle() { //接受参数,查询信息 $data = $this->request->post(); + // $data['journal'] = 1; + // $data['username'] = 'wangjinlei'; + // $data['title'] = 'sadfsq11adf'; + // $data['major'] = 2; + // $data['authorList'][0] = [ + // 'firstname'=>'name1', + // 'lastname'=>'name22', + // 'orcid'=>'', + // 'company'=>'dsadsa', + // 'department'=>'name1', + // 'title'=>'Assistant Prof.', + // 'country'=>'Angola', + // 'email'=>'sadf@65.com', + // 'address'=>'address', + // 'isSuper'=>'true', + // 'isReport'=>'true' + // ]; + // $data['abstrart']='dadsasd'; + // $data['type']='A'; + // $data['approval']='false'; + // $data['istransfer']='false'; + // $data['becomeRev']='false'; + // $data['keyWords']='sdfsfdf'; + // $data['fund']=''; + // $data['coverLetter']=''; + // $data['totalpage']=''; + // $data['manuscirpt']='manuscirpt/20220420/7c9ffb7ff502ec6b6b7642fcba77fa63.rar'; + + $user_res = $this->user_obj->where('account', $data['username'])->find(); //确定用户是否属于黑名单 @@ -1332,6 +1363,9 @@ class Article extends Controller { return json(['code'=>1,'msg'=>'Warning: you are re-submitting the article!']); } } + + + Db::startTrans(); //添加文章基础信息 @@ -1384,7 +1418,7 @@ class Article extends Controller { } } - + //增加articlefile表的信息 $res_file1 = self::save_article_file($res, $user_res['user_id'], $user_res['account'], $data['coverLetter'], 'coverLetter'); $res_file2 = true; @@ -1401,18 +1435,6 @@ class Article extends Controller { $tt = 'Dear editor,
'; $tt .= 'Please check the new manuscript in the submission system.'; sendEmail($editor_info['email'], $journal_info['title'], $journal_info['title'], $tt,$journal_info['email'],$journal_info['epassword']); - $sendEditor=[ - 'title'=> $journal_info['title'], // 邮件标题 - 'content'=>'Dear editor,
Please check the new manuscript in the submission system.',//邮件内容 - 'user_id'=>$editor_info['user_id'], //收件人ID - 'email'=>$editor_info['email'],// 收件人邮箱 - 'journal_id'=>$journal_info['journal_id'], // 期刊ID - 'sendEmail'=>$journal_info['email'], // 期刊邮箱 - 'sendPassword'=>$journal_info['epassword'], // 期刊密码 - 'from_name'=>$journal_info['title'] - ]; - // Queue::push('app\api\job\domail@fire',$sendEditor,'domail'); - $user_rev_info = $this->user_reviewer_info_obj->where("reviewer_id",$user_res['user_id'])->find(); //发送邮件给作者,表示感谢 $tt1 = 'Dear Dr. '.($user_res['realname']==''?$user_res['account']:$user_res['realname']).',

'; @@ -1432,20 +1454,8 @@ class Article extends Controller { $tt1 .= 'Email: '.$journal_info['email'].'
'; $tt1 .= 'Website: '.$journal_info['website']; } - $sendUser=[ - 'title'=> $journal_info['title'], // 邮件标题 - 'content'=>$tt1,//邮件内容 - 'user_id'=>$user_res['user_id'], //收件人ID - 'email'=>$user_res['email'],// 收件人邮箱 - 'journal_id'=>$journal_info['journal_id'], // 期刊ID - 'sendEmail'=>$journal_info['email'], // 期刊邮箱 - 'sendPassword'=>$journal_info['epassword'], // 期刊密码 - 'from_name'=>$journal_info['title'] - ]; - // Queue::push('app\api\job\domail@fire',$sendUser,'domail'); sendEmail($user_res['email'],$journal_info['title'], $journal_info['title'], $tt1,$journal_info['email'],$journal_info['epassword']); - //增加用户操作log $log_data['user_id'] = $user_res['user_id']; $log_data['type'] = 0; @@ -1459,14 +1469,13 @@ class Article extends Controller { //通讯作者转为审稿人 $this->addReviewerFromArticle($res, $journal_info['journal_id']); - - //如果存在推荐审稿人,则执行添加审稿人操作 - $res_recommend = true; + //推荐审稿人 + $recommend_res = true; foreach($data['reviewers'] as $v){ - $res_recommend = $this->addRecommentReviewer($v,$journal_info['journal_id'],$user_res['user_id'],$res); + $recommend_res = $this->addRecommentReviewer($v,$journal_info['journal_id'],$user_res['user_id'],$res); } - if ($res && $res_author && $transr && $res_file1 && $res_file2 && $res_file3 && $res_file4 && $res_log && $res_msg && $res_recommend) { + if ($res && $res_author && $transr && $res_file1 && $res_file2 && $res_file3 && $res_file4 && $res_log && $res_msg && $recommend_res) { Db::commit(); return json(['code' => 0]); } else { @@ -1474,7 +1483,7 @@ class Article extends Controller { return json(['code' => 1]); } } - + /** * 添加推荐审稿人 @@ -1494,8 +1503,8 @@ class Article extends Controller { } //判断是否是此期刊审稿人 $rtj = $this->reviewer_to_journal_obj->where('journal_id', $journal_id)->where('reviewer_id', $reviewer_info['user_id'])->where('state', 0)->find(); - // $res2 = true; - // $res3 = true; + $res2 = true; + $res3 = true; if ($rtj == null) { //判断是否具有审稿人身份,并具有审稿人资料 $uri = $this->user_reviewer_info_obj->where('reviewer_id', $reviewer_info['user_id'])->where('state', 0)->find(); diff --git a/application/api/controller/Reviewer.php b/application/api/controller/Reviewer.php index 528a6f4..aa187a3 100644 --- a/application/api/controller/Reviewer.php +++ b/application/api/controller/Reviewer.php @@ -4,6 +4,7 @@ namespace app\api\controller; use think\Controller; use think\Db; +use think\Validate; use TCPDF; use think\Queue; @@ -30,6 +31,8 @@ class Reviewer extends Controller protected $board_to_journal_obj = ''; protected $login_auto_obj = ''; protected $country_obj = ''; + protected $user_reviewer_recommend_obj = ''; + protected $article_msg_obj = ''; //put your code here public function __construct(\think\Request $request = null) @@ -51,6 +54,8 @@ class Reviewer extends Controller $this->board_to_journal_obj = Db::name('board_to_journal'); $this->login_auto_obj = Db::name('login_auto'); $this->country_obj = Db::name('country'); + $this->user_reviewer_recommend_obj = Db::name('user_reviewer_recommend'); + $this->article_msg_obj = Db::name('article_msg'); } /** @@ -387,9 +392,9 @@ class Reviewer extends Controller //发送email提醒 if ($type != 'editor') { - $tt = 'Dear editor,
'; - $tt .= 'Please check the new comments from the reviewer.'; - sendEmail($editor_info['email'], $journal_info['title'], $journal_info['title'], $tt, $journal_info['email'], $journal_info['epassword']); + $tt = 'Dear editor,
'; + $tt .= 'Please check the new comments from the reviewer.'; + sendEmail($editor_info['email'], $journal_info['title'], $journal_info['title'], $tt, $journal_info['email'], $journal_info['epassword']); $sendEditor = [ 'title' => $journal_info['title'], // 邮件标题 'content' => 'Dear editor,
Please check the new comments from the reviewer.', //邮件内容 @@ -712,6 +717,14 @@ class Reviewer extends Controller $this->user_obj->where('user_id', $art_rev_info['reviewer_id'])->setInc('rs_num'); } + //添加文章状态信息 + $insert_data['article_id'] = $article_info['article_id']; + $insert_data['content'] = 'Comments from the reviewer has been received'; + $insert_data['state_from'] = $article_info['state']; + $insert_data['state_to'] = $article_info['state']; + $insert_data['ctime'] = time(); + $this->article_msg_obj->insert($insert_data); + //记录log //生成pdf文件 // $reviewer_pdf = self::pdftest($journal_info['title']); @@ -928,7 +941,7 @@ class Reviewer extends Controller ->text($reviewer_info['realname'] == '' ? $reviewer_info['account'] : $reviewer_info['realname'], $ziti, 60, '#000000', [1900, 1700]) ->text('awarded ' . date('d, F, Y', $article_info['rtime'] == 0 ? $article_info['ctime'] : $article_info['rtime']) . ' to', $ziti, 60, '#000000', [1600, 1500]) ->text('In recognition of the review made for the journal', $ziti, 80, '#000000', [900, 1900]) - ->text($article_info['title'],$ziti,30,'#000000',[230,2100]) + ->text($article_info['title'], $ziti, 30, '#000000', [230, 2100]) ->text('The Editors of', $ziti, 65, '#000000', [230, 2345]) ->text($journal_info['title'], $ziti, 60, '#000000', [830, 2345]) ->text('Auckland, New Zealand, 2012', $ziti, 60, '#000000', [230, 2500]) @@ -990,20 +1003,17 @@ class Reviewer extends Controller $tt .= 'Email:' . $journal_info['email'] . '
'; $tt .= 'Website:' . $journal_info['website']; - $sendReviewer = [ - 'title' => $journal_info['title'], // 邮件标题 - 'content' => $tt, //邮件内容 - 'user_id' => $user_info['user_id'], //收件人ID - 'email' => $user_info['email'], // 收件人邮箱 - 'journal_id' => $journal_info['journal_id'], // 期刊ID - 'sendEmail' => $journal_info['email'], // 期刊邮箱 - 'sendPassword' => $journal_info['epassword'], // 期刊密码 - 'from_name' => $journal_info['title'] - ]; - // Queue::push('app\api\job\domail@fire', $sendReviewer, 'domail'); - sendEmail($user_info['email'], $journal_info['title'], $journal_info['title'], $tt, $journal_info['email'], $journal_info['epassword']); + //添加文章状态信息 + $insert_data['article_id'] = $article_info['article_id']; + $insert_data['content'] = 'The reviewer has been appointed'; + $insert_data['state_from'] = $article_info['state']; + $insert_data['state_to'] = $article_info['state']; + $insert_data['ctime'] = time(); + $this->article_msg_obj->insert($insert_data); + + $re['art_rev_id'] = $res; return jsonSuccess($re); } @@ -1033,6 +1043,17 @@ class Reviewer extends Controller $data = $this->request->post(); $art_rev_info = $this->article_reviewer_obj->where('art_rev_id', $data['art_rev_id'])->find(); if ($art_rev_info['state'] == 5) { + //添加找到审稿人信息的article msg + $article_info = $this->article_obj->where('article_id',$art_rev_info['article_id'])->find(); + $journal_info = $this->journal_obj->where('journal_id',$article_info['journal_id'])->find(); + //添加文章状态信息 + $insert_data['article_id'] = $article_info['article_id']; + $insert_data['content'] = 'The reviewer has been appointed'; + $insert_data['state_from'] = $article_info['state']; + $insert_data['state_to'] = $article_info['state']; + $insert_data['ctime'] = time(); + $this->article_msg_obj->insert($insert_data); + $this->article_reviewer_obj->where('art_rev_id', $data['art_rev_id'])->update(['state' => 0]); return jsonSuccess([]); } else { @@ -1657,6 +1678,31 @@ class Reviewer extends Controller return jsonSuccess($re); } + /** + * 获取作者推荐审稿人 + */ + public function getRecommendReviewer() + { + $data = $this->request->post(); + // 验证规则 + $rule = new Validate([ + 'article_id' => 'require|number' + ]); + if (!$rule->check($data)) { + return jsonError($rule->getError()); + } + + $list = $this->user_reviewer_recommend_obj + ->field("t_user.user_id,t_user.realname,t_reviewer_major.title cmajor,t_user.account,t_user_reviewer_info.company,t_user_reviewer_info.field,t_user.rs_num,t_user.rd_num") + ->join("t_user", "t_user.user_id = t_user_reviewer_recommend.reviewer_id", "left") + ->join("t_user_reviewer_info", "t_user_reviewer_info.reviewer_id = t_user_reviewer_recommend.reviewer_id", "left") + ->join("t_reviewer_major", "t_reviewer_major.major_id = t_user_reviewer_info.cmajor", "left") + ->where('t_user_reviewer_recommend.article_id', $data['article_id']) + ->select(); + $re['reviewers'] = $list; + return jsonSuccess($re); + } + /** * @title 获取所有审稿意见 * @description 获取所有审稿意见 diff --git a/application/api/controller/User.php b/application/api/controller/User.php index 735c958..2df1a4c 100644 --- a/application/api/controller/User.php +++ b/application/api/controller/User.php @@ -705,18 +705,7 @@ class User extends Controller $url = config('base_web_url') . 'retrieveact?actkey=' . $act_insert['act_key']; $title = 'Your request to reset your password [TMR Publishing Group]'; $content = "$realname, we've received your request to reset your password.Please click the link below to change your password. $url"; - //$res = sendEmail($email, $title, 'TMR', $content); - $sendUser = [ - 'title' => $title, // 邮件标题 - 'content' => $content, //邮件内容 - 'user_id' => $user['user_id'], //收件人ID - 'email' => $email, // 收件人邮箱 - 'journal_id' => 0, // 期刊ID - 'sendEmail' => Env::get('email.send_email'), // 期刊邮箱 - 'sendPassword' => Env::get('email.send_email_password'), // 期刊密码 - 'from_name' => 'TMR' - ]; - // $isUserPushed = Queue::push('app\api\job\domail@fire',$sendUser,'domail'); + $res = sendEmail($email, $title, 'TMR', $content,Env::get('email.send_email'),Env::get("email.send_email_password")); // if ($isUserPushed) {//成功 return json(['code' => 0, 'msg' => 'success']); // } else {//失败 diff --git a/public/index.php b/public/index.php index 258d72d..9043046 100644 --- a/public/index.php +++ b/public/index.php @@ -1,4 +1,7 @@