1
This commit is contained in:
@@ -302,11 +302,24 @@ class Article extends Base
|
||||
//增加审稿意见信息
|
||||
foreach ($res as $key => $val) {
|
||||
$cache_review = $this->article_reviewer_obj
|
||||
->field("t_article_reviewer.*,t_article_reviewer_question.rated")
|
||||
->field("t_article_reviewer.*,t_article_reviewer_question.rated,t_user.realname")
|
||||
->join("t_article_reviewer_question", "t_article_reviewer_question.art_rev_id = t_article_reviewer.art_rev_id", 'left')
|
||||
->join("t_user","t_user.user_id = t_article_reviewer.reviewer_id","left")
|
||||
->where("t_article_reviewer.article_id", $val['article_id'])
|
||||
->where("t_article_reviewer.state", 'in', [0, 1, 2, 3])
|
||||
->select();
|
||||
//添加复审信息
|
||||
foreach ($cache_review as $k => $v){
|
||||
$repeat = $this->article_reviewer_repeat_obj->where('art_rev_id',$v['art_rev_id'])->select();
|
||||
if($repeat){
|
||||
$last = count($repeat)-1;
|
||||
$cache_review[$k]['can_repeat'] = ($repeat[$last]['state']==1&&$repeat[$last]['recommend']==3)?1:0;
|
||||
$cache_review[$k]['repeat'] = $repeat;
|
||||
}else{//不存在复审实例,可添加
|
||||
$cache_review[$k]['can_repeat'] = 1;
|
||||
$cache_review[$k]['repeat'] = [];
|
||||
}
|
||||
}
|
||||
$res[$key]['review'] = $cache_review;
|
||||
|
||||
//查询作者信息
|
||||
@@ -427,53 +440,42 @@ class Article extends Base
|
||||
*/
|
||||
public function getArticleDetail()
|
||||
{
|
||||
//接受参数
|
||||
$data = $this->request->post();
|
||||
|
||||
//查询文章基础数据
|
||||
$where['t_article.article_id'] = $data['articleId'];
|
||||
$article_res = $this->article_obj->field('t_article.*,t_journal.title journalname,t_user.account')->join(array(['t_journal', 't_journal.journal_id = t_article.journal_id', 'LEFT'], ['t_user', 't_user.user_id = t_article.user_id', 'LEFT']))->where($where)->find();
|
||||
|
||||
//查询文章状态跟踪信息
|
||||
$article_msg = $this->article_msg_obj->where(['article_id' => $data['articleId']])->where('state', 0)->select();
|
||||
|
||||
$suggest = '';
|
||||
//如果是退修状态,显示退休信息
|
||||
// if($article_res['state']==4){
|
||||
// $lastbean = end($article_msg);
|
||||
// $suggest = $lastbean['content'];
|
||||
// }
|
||||
//查询审稿人审稿建议
|
||||
// if($article_res['state']==4){
|
||||
$suggest = $this->article_reviewer_obj->field('t_article_reviewer.*,t_article_reviewer_question.qu9_contents,t_article_reviewer_question.qu10_contents,t_article_reviewer_question.qu11_contents,t_article_reviewer_question.qu12_contents,t_article_reviewer_question.qu13_contents,t_article_reviewer_question.qu14_contents,t_article_reviewer_question.qu15_contents,t_article_reviewer_question.comments comments')
|
||||
->join('t_article_reviewer_question', 't_article_reviewer.art_rev_id=t_article_reviewer_question.art_rev_id', 'left')
|
||||
->where('t_article_reviewer.state', '<', 4)
|
||||
->where('t_article_reviewer.state', '>', 0)
|
||||
->where('t_article_reviewer.article_id', $article_res['article_id'])
|
||||
->select();
|
||||
// }
|
||||
// $suggest = $this->article_reviewer_obj->field('t_article_reviewer.*,t_article_reviewer_question.qu9_contents,t_article_reviewer_question.qu10_contents,t_article_reviewer_question.qu11_contents,t_article_reviewer_question.qu12_contents,t_article_reviewer_question.qu13_contents,t_article_reviewer_question.qu14_contents,t_article_reviewer_question.qu15_contents,t_article_reviewer_question.comments comments')
|
||||
// ->join('t_article_reviewer_question', 't_article_reviewer.art_rev_id=t_article_reviewer_question.art_rev_id', 'left')
|
||||
// ->where('t_article_reviewer.state', '<', 4)
|
||||
// ->where('t_article_reviewer.state', '>', 0)
|
||||
// ->where('t_article_reviewer.article_id', $article_res['article_id'])
|
||||
// ->select();
|
||||
|
||||
//查询major信息
|
||||
// $major_data = [];
|
||||
// if($article_res['major_id']!=0){
|
||||
// $major_data['major'] = $this->reviewer_major_obj->where('major_id',$article_res['major_id'])->find();
|
||||
// }else{
|
||||
// $major_data['major'] = null;
|
||||
// }
|
||||
// if($article_res['cmajor_id']!=0){
|
||||
// $major_data['cmajor'] = $this->reviewer_major_obj->where('major_id',$article_res['cmajor_id'])->find();
|
||||
// }else{
|
||||
// $major_data['cmajor'] = null;
|
||||
// }
|
||||
//新领域查询
|
||||
$suggest = $this->article_reviewer_obj->where("state","in",[1,2,3])->where('article_id',$article_res['article_id'])->select();
|
||||
|
||||
foreach ($suggest as $k => $v){
|
||||
$fr = [];
|
||||
$c = $this->article_reviewer_question_obj->where('art_rev_id',$v['art_rev_id'])->find();
|
||||
$fr[] = $c;
|
||||
$f = $this->article_reviewer_repeat_obj->where('art_rev_id',$v['art_rev_id'])->select();
|
||||
foreach ($f as $val){
|
||||
$fr[] = $val;
|
||||
}
|
||||
$suggest[$k]['question'] = $fr;
|
||||
}
|
||||
|
||||
// foreach ($suggest as $k => $v){
|
||||
// $ca = $this->article_reviewer_repeat_obj->where('art_rev_id',$v['art_rev_id'])->select();
|
||||
// $suggest[$k]['repeats'] = $ca;
|
||||
// }
|
||||
$major = $this->getMajorStr($article_res['major_id']);
|
||||
|
||||
//查询文章作者信息
|
||||
$author_res = $this->article_author_obj->where('article_id', $data['articleId'])->where('state', 0)->select();
|
||||
|
||||
//查询转投信息
|
||||
$transfer_res = $this->article_transfer_obj->where('article_id', $data['articleId'])->select();
|
||||
|
||||
//查询建议转投详情
|
||||
$transfer_info = $this->article_transfer_obj
|
||||
->field('t_article_transfer.*,t_journal.title jourtitle')
|
||||
@@ -481,7 +483,6 @@ class Article extends Base
|
||||
->where('t_article_transfer.article_id', $data['articleId'])
|
||||
->where('t_article_transfer.state', 2)
|
||||
->find();
|
||||
|
||||
//更新文章操作记录状态
|
||||
if ($data['human'] == 'editor') {
|
||||
$up_data['author_act'] = 0;
|
||||
@@ -489,7 +490,6 @@ class Article extends Base
|
||||
$up_data['editor_act'] = 0;
|
||||
}
|
||||
$this->article_obj->where('article_id', $data['articleId'])->update($up_data);
|
||||
|
||||
return json(['article' => $article_res, 'msg' => $article_msg, 'authors' => $author_res, 'suggest' => $suggest, 'transfer' => $transfer_res, 'transinfo' => $transfer_info, 'major' => $major]);
|
||||
}
|
||||
|
||||
@@ -2217,6 +2217,12 @@ class Article extends Base
|
||||
$journal_info = $this->journal_obj->where('journal_id', $article_info['journal_id'])->find();
|
||||
$user_res = $this->user_obj->where('user_id', $article_info['user_id'])->find();
|
||||
|
||||
//验证是否在黑名单
|
||||
$black = $this->user_black_obj->where('user_id',$user_res['user_id'])->where('black_state',0)->find();
|
||||
if($black){
|
||||
return jsonError("Your account is currently blacklisted by TMR Publishing Group. Please contact the official email of the journal you wish to submit to for further clarification.");
|
||||
}
|
||||
|
||||
$author_email = [];
|
||||
|
||||
$authors = $this->article_author_obj->where('article_id', $data['article_id'])->where('state', 0)->select();
|
||||
|
||||
@@ -151,6 +151,21 @@ class Auto extends Base
|
||||
}
|
||||
|
||||
|
||||
public function reviewerRepeat(){
|
||||
$repeats = $this->article_reviewer_repeat_obj->where("ctime","<",(time()-24*5*3600))->where("state",0)->select();
|
||||
foreach ($repeats as $v){
|
||||
$ca_rev_info = $this->article_reviewer_obj->where('art_rev_id',$v['art_rev_id'])->find();
|
||||
if($ca_rev_info['state']==2){
|
||||
$com = 2;
|
||||
}else{
|
||||
$com = 1;
|
||||
}
|
||||
$this->article_reviewer_repeat_obj->where('art_rev_rep_id',$v['art_rev_rep_id'])->update(["recommend"=>$com,"stime"=>time()]);
|
||||
}
|
||||
echo "done";
|
||||
}
|
||||
|
||||
|
||||
// public function cvComit(){
|
||||
// $list = $this->user_reviewer_info_obj
|
||||
// ->field('t_user.user_id,t_user.ctime,t_user_reviewer_info.qualifications')
|
||||
|
||||
@@ -84,6 +84,25 @@ class Publish extends Base
|
||||
return jsonSuccess($re);
|
||||
}
|
||||
|
||||
public function getArticleMains(){
|
||||
$data = $this->request->post();
|
||||
$rule = new Validate([
|
||||
"article_id"=>"require"
|
||||
]);
|
||||
if(!$rule->check($data)){
|
||||
return jsonError($rule->getError());
|
||||
}
|
||||
$url = 'http://journalapi.tmrjournals.com/public/index.php/master/Article/getArticleMainsForSubmit';
|
||||
$pra = [];
|
||||
$pra['article_id'] = $data['article_id'];
|
||||
$res = object_to_array(json_decode(myPost($url, $pra)));
|
||||
|
||||
$mains = $res['data']["mains"];
|
||||
|
||||
$re['mains'] = $mains;
|
||||
return jsonSuccess($re);
|
||||
}
|
||||
|
||||
/**
|
||||
* 提前出刊
|
||||
*/
|
||||
|
||||
@@ -4,6 +4,7 @@ namespace app\api\controller;
|
||||
|
||||
use app\api\controller\Base;
|
||||
use think\Db;
|
||||
use think\Queue;
|
||||
use think\Validate;
|
||||
|
||||
/**
|
||||
@@ -51,7 +52,7 @@ class Reviewer extends Base
|
||||
}
|
||||
|
||||
/**
|
||||
* @title 获取待审审稿实例列表
|
||||
* @title 获取待审审稿实例列表,包含复审待审
|
||||
* @description 获取待审审稿实例列表
|
||||
* @author wangjinlei
|
||||
* @url /api/Reviewer/getReviewerListPending
|
||||
@@ -67,7 +68,8 @@ class Reviewer extends Base
|
||||
//获取审稿人基本信息
|
||||
$reviewer_info = $this->user_obj->where('user_id', $data['user_id'])->find();
|
||||
|
||||
$res = $this->article_reviewer_obj->field('t_article_reviewer.*,t_article.title article_title,t_article.abstrart,t_article.major_id,t_article.cmajor_id,t_article.type,t_journal.title journal_title,t_article.accept_sn accept_sn')
|
||||
$res = $this->article_reviewer_obj
|
||||
->field('t_article_reviewer.*,t_article.title article_title,t_article.abstrart,t_article.major_id,t_article.cmajor_id,t_article.type,t_journal.title journal_title,t_article.accept_sn accept_sn')
|
||||
->join('t_article', 't_article_reviewer.article_id = t_article.article_id', 'LEFT')
|
||||
->join('t_journal', 't_article.journal_id = t_journal.journal_id', 'LEFT')
|
||||
->where('t_article_reviewer.reviewer_id', $reviewer_info['user_id'])
|
||||
@@ -88,7 +90,18 @@ class Reviewer extends Base
|
||||
$res[$k]['cmajor'] = $cmajor['title'];
|
||||
}
|
||||
|
||||
//复审的稿件列表
|
||||
$repeats = $this->article_reviewer_obj
|
||||
->field('t_article_reviewer.*,t_article.title article_title,t_article.abstrart,t_article.major_id,t_article.cmajor_id,t_article.type,t_journal.title journal_title,t_article.accept_sn accept_sn')
|
||||
->join("t_article_reviewer_repeat","t_article_reviewer_repeat.art_rev_id = t_article_reviewer.art_rev_id","left")
|
||||
->join('t_article', 't_article_reviewer.article_id = t_article.article_id', 'LEFT')
|
||||
->join('t_journal', 't_article.journal_id = t_journal.journal_id', 'LEFT')
|
||||
->where("t_article_reviewer.reviewer_id",$reviewer_info['user_id'])
|
||||
->where("t_article_reviewer_repeat.state",0)
|
||||
->select();
|
||||
|
||||
$re['lists'] = $res;
|
||||
$re['repeats'] = $repeats;
|
||||
return jsonSuccess($re);
|
||||
}
|
||||
|
||||
@@ -104,8 +117,16 @@ class Reviewer extends Base
|
||||
return jsonError($rule->getError());
|
||||
}
|
||||
$article_reviewer_info = $this->article_reviewer_obj->where('art_rev_id',$data['art_rev_id'])->find();
|
||||
//审查添加的合法性
|
||||
$repeats = $this->article_reviewer_repeat_obj->where('art_rev_id',$data['art_rev_id'])->select();
|
||||
$last = count($repeats)-1;
|
||||
if($repeats&&($repeats[$last]['state']==0||$repeats[$last]['recommend']!=3)){
|
||||
return jsonError("create error");
|
||||
}
|
||||
|
||||
$reviewer_info = $this->user_obj->where('user_id',$article_reviewer_info['reviewer_id'])->find();
|
||||
$article_info = $this->article_obj->where('article_id',$article_reviewer_info['article_id'])->find();
|
||||
$journal_info = $this->journal_obj->where("journal_id",$article_info['journal_id'])->find();
|
||||
|
||||
//添加实例数据
|
||||
$insert['art_rev_id'] = $data['art_rev_id'];
|
||||
@@ -113,6 +134,21 @@ class Reviewer extends Base
|
||||
$this->article_reviewer_repeat_obj->insert($insert);
|
||||
|
||||
//发送邮件至审稿人,提醒到系统内复审稿件
|
||||
$tt = "Dear Reviewer,<br/><br/>";
|
||||
$tt .= "Thank you for your support and valuable feedback to our journal. According to your comments, the author has made revisions to the article and submitted the revised manuscript to us.<br/><br/>";
|
||||
$tt .= 'To ensure the quality and accuracy of the article, we would like to ask for your re-review of the revised manuscript within 5 days. Please log in to the <a href="https://submission.tmrjournals.com">Submission System</a> and click on "Peer Review" to re-review the revised manuscript.If you fail to complete the re-review, we will consider your initial opinion as the final decision.<br/><br/>';
|
||||
$tt .= "We appreciate your time and effort to the journal and look forward to hearing back from you soon.<br/><br/>";
|
||||
$tt .= 'Sincerely,<br>Editorial Office<br>';
|
||||
$tt .= $journal_info['title'] . '<br>';
|
||||
$tt .= 'Email: ' . $journal_info['email'] . '<br>';
|
||||
$tt .= 'Website: ' . $journal_info['website'];
|
||||
|
||||
$maidata['email'] = $reviewer_info['email'];
|
||||
$maidata['title'] = "Invitation for Re-review of Revised Manuscript";
|
||||
$maidata['content'] = $tt;
|
||||
$maidata['tmail'] = $journal_info['email'];
|
||||
$maidata['tpassword'] = $journal_info['epassword'];
|
||||
Queue::push('app\api\job\mail@fire', $maidata, "tmail");
|
||||
|
||||
return jsonSuccess([]);
|
||||
}
|
||||
@@ -307,6 +343,48 @@ class Reviewer extends Base
|
||||
return json(['code' => 0]);
|
||||
}
|
||||
|
||||
/**获取复审稿件详情
|
||||
* @return \think\response\Json
|
||||
* @throws \think\db\exception\DataNotFoundException
|
||||
* @throws \think\db\exception\ModelNotFoundException
|
||||
* @throws \think\exception\DbException
|
||||
*/
|
||||
public function getReviewerRepeatDetail(){
|
||||
$data = $this->request->post();
|
||||
$rule = new Validate([
|
||||
"art_rev_id"=>'require'
|
||||
]);
|
||||
if(!$rule->check($data)){
|
||||
return jsonError($rule->getError());
|
||||
}
|
||||
$art_rev_info = $this->article_reviewer_obj->where('art_rev_id',$data['art_rev_id'])->find();
|
||||
$article_info = $this->article_obj
|
||||
->field("t_article.*,t_journal.title journal_title,t_journal.website")
|
||||
->join("t_journal","t_journal.journal_id = t_article.journal_id","left")
|
||||
->where('t_article.article_id',$art_rev_info['article_id'])
|
||||
->find();
|
||||
//组装审稿时间线
|
||||
$c_question = $this->article_reviewer_question_obj->where('art_rev_id',$data['art_rev_id'])->find();
|
||||
$question[] = $c_question;
|
||||
$re_question = $this->article_reviewer_repeat_obj->where('art_rev_id',$data['art_rev_id'])->select();
|
||||
foreach ($re_question as $v){
|
||||
$question[] = $v;
|
||||
}
|
||||
$art_rev_info['question'] = $question;
|
||||
$re['art_rev_info'] = $art_rev_info;
|
||||
|
||||
//组装文章文件
|
||||
$response = $this->article_response_to_reviewer_obj->where('article_id',$article_info['article_id'])->select();
|
||||
$files['response'] = $response;
|
||||
|
||||
$files['manuscript'] = $this->article_file_obj->where('article_id',$article_info['article_id'])->where('type_name',"manuscirpt")->order("ctime")->select();
|
||||
$files['figures'] = $this->article_file_obj->where('article_id',$article_info['article_id'])->where('type_name',"picturesAndTables")->order("ctime")->select();
|
||||
$re['files'] = $files;
|
||||
|
||||
$re['article_info'] = $article_info;
|
||||
return jsonSuccess($re);
|
||||
}
|
||||
|
||||
/**
|
||||
* @title 发起审稿
|
||||
* @description 发起审稿
|
||||
@@ -484,6 +562,19 @@ class Reviewer extends Base
|
||||
->find();
|
||||
//文章类型转译
|
||||
$res['atype'] = translateType($res['atype']);
|
||||
|
||||
//复审相关
|
||||
$repeats = $this->article_reviewer_repeat_obj->where('art_rev_id',$data['revid'])->select();
|
||||
if($repeats){
|
||||
$last = count($repeats)-1;
|
||||
$res['can_repeat'] = ($repeats[$last]['state']==1&&$repeats[$last]['recommend']==3)?1:0;
|
||||
$res['repeat'] = $repeats;
|
||||
}else{//不存在复审实例,可添加
|
||||
$res['can_repeat'] = 1;
|
||||
$res['repeat'] = [];
|
||||
}
|
||||
|
||||
|
||||
//更改实例状态(消息提醒)
|
||||
if ($data['human'] == 'editor') {
|
||||
$up_data['reviewer_act'] = 0;
|
||||
@@ -840,6 +931,37 @@ class Reviewer extends Base
|
||||
// sendEmail("1586428462@qq.com", "title", "ttttt", "content", 'tmr@tmrjournals.com', "Wu9999999999", $reviewer_ZS);
|
||||
// }
|
||||
|
||||
public function questionRepeat(){
|
||||
$data = $this->request->post();
|
||||
$rule = new Validate([
|
||||
"art_rev_rep_id"=>"require",
|
||||
"recommend"=>"require"
|
||||
]);
|
||||
if(!$rule->check($data)){
|
||||
return jsonError($rule->getError());
|
||||
}
|
||||
$repeat_info = $this->article_reviewer_repeat_obj->where('art_rev_rep_id',$data['art_rev_rep_id'])->find();
|
||||
$update['recommend'] = $data['recommend'];
|
||||
$update['stime'] = time();
|
||||
if($data['recommend']==3){
|
||||
$update['content'] = isset($data['content'])?trim($data['content']):'';
|
||||
}
|
||||
$update['state'] = 1;
|
||||
$this->article_reviewer_repeat_obj->where('art_rev_rep_id',$data['art_rev_rep_id'])->update($update);
|
||||
|
||||
//更新审稿实例
|
||||
if($data['recommend']!=3){
|
||||
$state = $data['recommend']==1?3:2;
|
||||
$this->article_reviewer_obj->where("art_rev_id",$repeat_info['art_rev_id'])->update(['state'=>$state]);
|
||||
}
|
||||
|
||||
//复审后发送邮件
|
||||
|
||||
|
||||
return jsonSuccess([]);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* 获取问卷详情
|
||||
*/
|
||||
|
||||
@@ -195,7 +195,8 @@ class Ucenter extends Base{
|
||||
|
||||
public function getAsYboard($user_id){
|
||||
$user_info = $this->user_obj->where('user_id',$user_id)->find();
|
||||
$list = $this->user_to_yboard_obj->where('user_id',$user_id)->where('state',0)->group('journal_id')->select();
|
||||
// $list = $this->user_to_yboard_obj->where('user_id',$user_id)->where('state',0)->group('journal_id')->select();
|
||||
$list = $this->user_to_yboard_obj->where('user_id',$user_id)->where('state',0)->order('journal_id')->select();
|
||||
$frag = [];
|
||||
foreach($list as $v){
|
||||
$journal = $this->journal_obj->where('journal_id',$v['journal_id'])->find();
|
||||
|
||||
@@ -862,6 +862,8 @@ class User extends Base
|
||||
$insert['reason'] = trim($data['reason']);
|
||||
$insert['black_ctime'] = time();
|
||||
$this->user_black_obj->insert($insert);
|
||||
//消除审稿人关系
|
||||
$this->user_black_obj->where('user_id',$data['user_id'])->update(['state'=>1]);
|
||||
return jsonSuccess($data);
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user