Files
journal/application/master/controller/Journal.php
wangjinlei c0fba968de 1
2022-09-30 18:03:31 +08:00

2492 lines
180 KiB
PHP
Raw Blame History

This file contains invisible Unicode characters
This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
<?php
namespace app\master\controller;
use think\Controller;
use think\Db;
use think\Queue;
use think\Validate;
/**
* @title 期刊接口
* @description 期刊相关操作
* @group 期刊相关
*/
class Journal extends Controller
{
//put your code here
protected $admin_obj = '';
protected $journal_obj = '';
protected $article_obj = '';
protected $journal_topic_obj = '';
protected $journal_stage_obj = '';
protected $journal_line_obj = '';
protected $journal_notices_obj = '';
protected $journal_abs_obj = '';
protected $article_author_obj = '';
protected $article_to_topic_obj = '';
protected $article_to_line_obj = '';
protected $journal_cfp_obj = '';
protected $journal_paper_obj = '';
protected $journal_paper_art_obj = '';
protected $subscribe_journal_obj = '';
protected $subscribe_topic_obj = '';
protected $board_obj = '';
protected $board_group_obj = '';
protected $base_topic_obj = '';
protected $subscribe_base_topic_obj = '';
protected $journal_for_author = '';
public function __construct(\think\Request $request = null)
{
parent::__construct($request);
$this->admin_obj = Db::name('admin');
$this->journal_obj = Db::name('journal');
$this->article_obj = Db::name('article');
$this->journal_topic_obj = Db::name('journal_topic');
$this->journal_stage_obj = Db::name('journal_stage');
$this->journal_line_obj = Db::name('journal_line');
$this->journal_notices_obj = Db::name('journal_notices');
$this->journal_abs_obj = Db::name('journal_abstracting');
$this->article_author_obj = Db::name('article_author');
$this->article_to_topic_obj = Db::name('article_to_topic');
$this->article_to_line_obj = Db::name('article_to_line');
$this->journal_cfp_obj = Db::name('journal_cfp');
$this->journal_paper_obj = Db::name('journal_paper');
$this->journal_paper_art_obj = Db::name('journal_paper_art');
$this->subscribe_journal_obj = Db::name('subscribe_journal');
$this->subscribe_topic_obj = Db::name('subscribe_topic');
$this->board_obj = Db::name('board');
$this->board_group_obj = Db::name('board_group');
$this->base_topic_obj = Db::name('base_topic');
$this->subscribe_base_topic_obj = Db::name('subscribe_base_topic');
$this->journal_for_author = Db::name('journal_for_author');
}
/**
* @title 获取期刊列表
* @description 获取期刊列表
* @author wangjinlei
* @url /master/Journal/getJournalList
* @method POST
*
* @param name:editor_id type:int require:1 desc:编辑id
*
* @return journalList:期刊列表@
* @journalList title:标题 issn:issn editorinchief:editorinchief acceptance:acceptance finaldecision:finaldecision apc:apc
*/
public function getJournalList()
{
$data = $this->request->post();
$where['j_journal.state'] = 0;
if ($data['editor_id'] != 1) {
$where['j_journal.editor_id'] = $data['editor_id'];
}
$res = $this->journal_obj
->field('j_journal.*,j_admin.realname realname')
->join('j_admin', 'j_admin.admin_id = j_journal.editor_id', 'LEFT')
->where($where)
->order('j_journal.sort desc')
->select();
return json(['code' => 0, 'msg' => 'success', 'data' => ['journalList' => $res]]);
}
/**
* 获取全部期刊
*/
public function getJournals()
{
$jouranls = $this->journal_obj->where('state', 0)->select();
$re['journals'] = $jouranls;
return jsonSuccess($re);
}
/**
* 获取分期通过期刊
*/
public function getStagesByJournal()
{
$data = $this->request->post();
$rule = new Validate([
'journal_id' => 'require|number'
]);
if (!$rule->check($data)) {
return jsonError($rule->getError());
}
$list = $this->journal_stage_obj->where('journal_id', $data['journal_id'])->where('state', 0)->select();
foreach ($list as $k => $vv) {
$list[$k]['title'] = $vv['stage_year'] . ' Vol.' . $vv['stage_vol'] . ' issue.' . $vv['stage_no'] . $vv['stage_pagename'] . $vv['stage_page'];
}
$re['stages'] = $list;
return jsonSuccess($re);
}
/**
* 获取期刊和分期信息
*/
public function getJournalsAndStage()
{
$data = $this->request->post();
$journal_list = $this->journal_obj->where('state', 0)->select();
$frag = [];
foreach ($journal_list as $v) {
// $v['journal_stage_id'] = $v['journal_id'];
$cache_list = $this->journal_stage_obj->where('journal_id', $v['journal_id'])->where('state', 0)->select();
foreach ($cache_list as $k => $vv) {
$cache_list[$k]['title'] = $vv['stage_year'] . ' Vol.' . $vv['stage_vol'] . ' issue.' . $vv['stage_no'] . $vv['stage_pagename'] . $vv['stage_page'];
}
if (count($cache_list) > 0) {
$v['children'] = $cache_list;
} else {
$v['children'] = [];
}
$frag[] = $v;
}
return json(['code' => 0, 'msg' => 'success', 'data' => ['joutaglist' => $frag]]);
}
/**
* @title 获取所有期刊
* @description 获取所有期刊
* @author wangjinlei
* @url /master/Journal/getJournalAll
* @method POST
*
* @param name:journal_id type:int require:1 desc:当前期刊id
*
* @return journalList:期刊列表#
*/
public function getJournalAll()
{
$data = $this->request->post();
$res = $this->journal_obj->where('journal_id', '<>', $data['journal_id'])->where('state', 0)->select();
$re['journalList'] = $res;
return jsonSuccess($re);
}
/**
* @title 添加期刊
* @description 添加期刊
* @author wangjinlei
* @url /master/Journal/addJournal
* @method POST
*
* @param name:title type:string require:1 desc:标题
* @param name:issn type:string require:1
* @param name:editorinchief type:string require:1
* @param name:acceptance type:string require:1 desc:受理度
* @param name:finaldecision type:string require:1 desc:最终受理
* @param name:sort type:int require:1 detault:0 desc:权重值
* @param name:abstract type:string require:1 desc:简介
* @param name:sx type:string require:1 desc:缩写(demo:tmr)
* @param name:jabbr type:int require:0 desc:期刊简称
* @param name:apc type:string require:1
* @param name:art_num type:int require:1 desc:单刊文章数量
* @param name:cycle type:int require:1 desc:1月刊2双月刊3季刊6半年刊
* @param name:icon type:string require:1
* @param name:licon type:string require:1 desc:简易缩略图
* @param name:editor_id type:int require:1 desc:编辑id
* @param name:system_color type:string require:1
* @param name:submission_url type:string require:1
* @param name:board_url type:string require:1 desc:编委会地址
* @param name:topic_show_type type:int require:1 desc:0无图片1有图片
*/
public function addJournal()
{
$data = $this->request->post();
$insert_data['title'] = $data['title'];
$insert_data['issn'] = $data['issn'];
$insert_data['editorinchief'] = $data['editorinchief'];
$insert_data['acceptance'] = $data['acceptance'];
$insert_data['finaldecision'] = $data['finaldecision'];
$insert_data['sort'] = $data['sort'];
$insert_data['abstract'] = $data['abstract'];
$insert_data['sx'] = $data['sx'];
$insert_data['jabbr'] = $data['jabbr'];
$insert_data['apc'] = $data['apc'];
$insert_data['art_num'] = $data['art_num'];
$insert_data['cycle'] = $data['cycle'];
$insert_data['icon'] = $data['icon'];
$insert_data['licon'] = $data['licon'];
$insert_data['editor_id'] = $data['editor_id'];
$insert_data['system_color'] = $data['system_color'];
$insert_data['submission_url'] = $data['submission_url'];
$insert_data['board_url'] = $data['board_url'];
$insert_data['topic_show_type'] = $data['topic_show_type'];
$res = $this->journal_obj->insert($insert_data);
if ($res) {
return json(['code' => 0, 'msg' => 'success']);
} else {
return json(['code' => 1, 'msg' => 'system error']);
}
}
/**
* @title 删除期刊
* @description 删除期刊
* @author wangjinlei
* @url /master/Journal/delJournal
* @method POST
*
* @param name:journal_id require:1 desc:主键
*/
public function delJournal()
{
$data = $this->request->post();
$res = $this->journal_obj->where('journal_id', $data['journal_id'])->update(['state' => 1]);
if ($res) {
return json(['code' => 0, 'msg' => 'success']);
} else {
return json(['code' => 1, 'msg' => 'system error']);
}
}
/**
* @title 修改期刊详情
* @description 修改期刊详情
* @author wangjinlei
* @url /master/Journal/editJournalDetail
* @method POST
*
* @param name:journal_id require:1 desc:主键
* @param name:title type:string require:1 desc:标题
* @param name:issn type:string require:1
* @param name:editorinchief type:string require:1
* @param name:acceptance type:string require:1 desc:受理度
* @param name:finaldecision type:string require:1 desc:最终受理
* @param name:art_num type:int require:1 desc:单刊文章数量
* @param name:cycle type:int require:1 desc:1月刊2双月刊3季刊6半年刊
* @param name:sort type:int require:1 detault:0 desc:权重值
* @param name:abstract type:string require:1 desc:简介
* @param name:sx type:string require:1 desc:缩写(demo:tmr)
* @param name:jabbr type:string require:0 desc:期刊简称
* @param name:apc type:string require:1
* @param name:publish_stage_id type:int require:1 desc:推广分期id
* @param name:icon type:string require:1
* @param name:licon type:string require:1 desc:简易缩略图
* @param name:editor_id type:int require:1 desc:编辑id
* @param name:system_color type:string require:1
* @param name:submission_url type:string require:1
* @param name:board_url type:string require:1 desc:编委会地址
* @param name:topic_show_type type:int require:1 desc:0无图片1有图片
*/
public function editJournalDetail()
{
$data = $this->request->post();
$insert_data['title'] = $data['title'];
$insert_data['issn'] = $data['issn'];
$insert_data['editorinchief'] = $data['editorinchief'];
$insert_data['acceptance'] = $data['acceptance'];
$insert_data['finaldecision'] = $data['finaldecision'];
$insert_data['art_num'] = $data['art_num'];
$insert_data['cycle'] = $data['cycle'];
$insert_data['sort'] = $data['sort'];
$insert_data['abstract'] = $data['abstract'];
$insert_data['sx'] = $data['sx'];
$insert_data['jabbr'] = $data['jabbr'];
$insert_data['publish_stage_id'] = $data['publish_stage_id'];
$insert_data['apc'] = $data['apc'];
$insert_data['icon'] = $data['icon'];
$insert_data['licon'] = $data['licon'];
$insert_data['editor_id'] = $data['editor_id'];
$insert_data['system_color'] = $data['system_color'];
$insert_data['submission_url'] = $data['submission_url'];
$insert_data['board_url'] = $data['board_url'];
$insert_data['topic_show_type'] = $data['topic_show_type'];
$res = $this->journal_obj->where('journal_id', $data['journal_id'])->update($insert_data);
// if($res){
return json(['code' => 0, 'msg' => 'success']);
// }else{
// return json(['code'=>1,'msg'=>'Please confirm you have changed the journal information.']);
// }
}
/**
* @title 获取编辑列表
* @description 获取编辑列表
* @author wangjinlei
* @url /master/Journal/getEditorList
* @method POST
*
* @return editorList:编辑列表@
* @editorList account:账号 realname:真实姓名 role:角色代号0admin1editor
*/
public function getEditorList()
{
$editor_list = $this->admin_obj->where('role', 1)->select();
return json(['code' => 0, 'msg' => 'success', 'data' => ['editorList' => $editor_list]]);
}
/**
* @title 图片上传
* @description 图片上传
* @author wangjinlei
* @url /master/Journal/up_file
* @method POST
*
* @param name:name type:string require:1 default:journalicon desc:文件域名称
*
* @return upurl:图片地址
*/
public function up_file()
{
$file = request()->file('journalicon');
if ($file) {
$info = $file->move(ROOT_PATH . 'public' . DS . 'journalicon');
if ($info) {
return json(['code' => 0, 'msg' => 'success', 'upurl' => str_replace("\\", "/", $info->getSaveName())]);
} else {
return json(['code' => 1, 'msg' => $file->getError()]);
}
}
}
/**
* @title 获取编委列表
* @description 获取编委列表
* @author wangjinlei
* @url /master/Journal/getBoardList
* @method POST
*
* @param name:journal_id type:int require:1 desc:期刊id
*
* @return boards:编委列表array#
* @return journal:期刊信息#
*/
public function getBoardList()
{
$data = $this->request->post();
$journal_info = $this->journal_obj->where('journal_id', $data['journal_id'])->find();
$list = $this->board_obj
->field('j_board.*,j_board_group.group_name')
->join('j_board_group', 'j_board.board_group_id = j_board_group.board_group_id', 'LEFT')
->where('j_board.journal_id', $data['journal_id'])
->where('j_board.state', 0)
->order('j_board.type')
->select();
$re['boards'] = $list;
$re['journal'] = $journal_info;
return jsonSuccess($re);
}
/**
* @title 获取编委成员分类列表
* @description 获取编委成员分类列表
* @author wangjinlei
* @url /master/Journal/getBoardGroups
* @method POST
*
* @param name:journal_id type:int require:1 desc:期刊id
*
* @return groups:编委分类列表array#
*/
public function getBoardGroups()
{
$data = $this->request->post();
$list = $this->board_group_obj->where('journal_id', $data['journal_id'])->where('state', 0)->select();
$re['groups'] = $list;
return jsonSuccess($re);
}
/**
* @title 添加编委成员分组
* @description 添加编委成员分组
* @author wangjinlei
* @url /master/Journal/addBoardGroup
* @method POST
*
* @param name:journal_id type:int require:1 desc:期刊id
* @param name:group_name type:string require:1 desc:分组名字
*/
public function addBoardGroup()
{
$data = $this->request->post();
$insert['journal_id'] = $data['journal_id'];
$insert['group_name'] = $data['group_name'];
$this->board_group_obj->insert($insert);
return jsonSuccess([]);
}
/**
* @title 删除编委成员分组
* @description 删除编委成员分组
* @author wangjinlei
* @url /master/Journal/delBoardGroup
* @method POST
*
* @param name:board_group_id type:int require:1 desc:编委分组id
*/
public function delBoardGroup()
{
$data = $this->request->post();
$this->board_group_obj->where('board_group_id', $data['board_group_id'])->update(['state' => 1]);
return jsonSuccess([]);
}
/**
* @title 编辑编委成员分组信息
* @description 编辑编委成员分组信息
* @author wangjinlei
* @url /master/Journal/editBoardGroup
* @method POST
*
* @param name:board_group_id type:int require:1 desc:编委分组id
* @param name:group_name type:string require:1 desc:分组名字
*/
public function editBoardGroup()
{
$data = $this->request->post();
$this->board_group_obj->where('board_group_id', $data['board_group_id'])->update(['group_name' => $data['group_name']]);
return jsonSuccess([]);
}
/**
* @title 添加编委
* @description 添加编委
* @author wangjinlei
* @url /master/Journal/addBoard
* @method POST
*
* @param name:journal_id type:int require:1 desc:期刊id
* @param name:type type:int require:1 desc:编委类型0主编1副主编2编委成员
* @param name:name type:string require:1 desc:编委姓名
* @param name:website type:string require:1 desc:个人主页地址
* @param name:dr type:string require:1 desc:学位
* @param name:title type:string require:1 desc:职称
* @param name:field type:string require:1 desc:领域描述
* @param name:board_icon type:string require:1 desc:编委头像地址
* @param name:address type:string require:1 desc:单位
* @param name:country type:string require:1 desc:国家
* @param name:board_group_id type:int require:1 desc:编委分组id
*/
public function addBoard()
{
$data = $this->request->post();
$insert['journal_id'] = $data['journal_id'];
$insert['type'] = $data['type'];
$insert['name'] = trim($data['name']);
$insert['website'] = trim($data['website']);
$insert['dr'] = $data['dr'];
$insert['field'] = trim($data['field']);
$insert['title'] = $data['title'];
$insert['address'] = trim($data['address']);
$insert['country'] = trim($data['country']);
$insert['board_icon'] = trim($data['board_icon']);
$insert['board_group_id'] = $data['board_group_id'];
$this->board_obj->insert($insert);
return jsonSuccess([]);
}
/**
* @title 删除编委
* @description 删除编委
* @author wangjinlei
* @url /master/Journal/delBoard
* @method POST
*
* @param name:board_id type:int require:1 desc:编委id
*/
public function delBoard()
{
$data = $this->request->post();
$this->board_obj->where('board_id', $data['board_id'])->update(['state' => 1]);
return jsonSuccess([]);
}
/**
* @title 编辑编委信息
* @description 编辑编委信息
* @author wangjinlei
* @url /master/Journal/editBoard
* @method POST
*
* @param name:board_id type:int require:1 desc:编委id
* @param name:type type:int require:1 desc:编委类型0主编1副主编2编委成员
* @param name:name type:string require:1 desc:编委姓名
* @param name:website type:string require:1 desc:个人主页地址
* @param name:dr type:string require:1 desc:学位
* @param name:title type:string require:1 desc:职称
* @param name:field type:string require:1 desc:领域描述
* @param name:address type:string require:1 desc:单位
* @param name:board_icon type:string require:1 desc:编委头像
* @param name:country type:string require:1 desc:国家
* @param name:board_group_id type:int require:1 desc:编委分组id
*/
public function editBoard()
{
$data = $this->request->post();
$insert['type'] = $data['type'];
$insert['name'] = trim($data['name']);
$insert['website'] = trim($data['website']);
$insert['dr'] = $data['dr'];
$insert['title'] = trim($data['title']);
$insert['field'] = trim($data['field']);
$insert['address'] = trim($data['address']);
$insert['board_icon'] = trim($data['board_icon']);
$insert['country'] = $data['country'];
$insert['board_group_id'] = $data['board_group_id'];
$this->board_obj->where('board_id', $data['board_id'])->update($insert);
return jsonSuccess([]);
}
/**
* @title 增加话题
* @description 增加话题
* @author wangjinlei
* @url /master/Journal/addTopic
* @method POST
*
* @param name:journal_id type:int require:1 desc:期刊id
* @param name:parent_id type:int require:1 default:0 desc:父id
* @param name:title type:string require:1 desc:标题
* @param name:icon type:string require:1 desc:缩略图
* @param name:intro type:string require:1 desc:介绍
* @param name:come type:string require:1 desc:图片证书
* @param name:position type:string require:1 desc:摆放位置
* @param name:is_final type:int require:1 desc:是否终结点0no1yes
* @param name:sort type:int require:1 default:0 desc:权重
*/
public function addTopic()
{
$data = $this->request->post();
$level = 0;
if ($data['parent_id'] == 0) {
$level = 1;
} else {
$parent_info = $this->journal_topic_obj->where('journal_topic_id', $data['parent_id'])->find();
$level = intval($parent_info['level']) + 1;
}
$insert['journal_id'] = $data['journal_id'];
$insert['parent_id'] = $data['parent_id'];
$insert['title'] = $data['title'];
$insert['icon'] = $data['icon'];
$insert['intro'] = $data['intro'];
$insert['come'] = isset($data['come']) ? $data['come'] : '';
if ($data['parent_id'] == 0) {
$insert['position'] = $data['position'];
}
$insert['is_final'] = $data['is_final'];
$insert['sort'] = $data['sort'];
$insert['level'] = $level;
$res = $this->journal_topic_obj->insert($insert);
if ($res) {
return json(['code' => 0, 'msg' => 'success']);
} else {
return json(['code' => 1, 'msg' => 'system error']);
}
}
/**
* @title 更改话题信息
* @description 更改话题信息
* @author wangjinlei
* @url /master/Journal/editTopic
* @method POST
*
* @param name:journal_topic_id type:int require:1 desc:主键
* @param name:title type:string require:1 desc:标题
* @param name:icon type:string require:1 desc:缩略图
* @param name:intro type:string require:1 desc:介绍
* @param name:come type:string require:1 desc:图片证书
* @param name:position type:string require:1 desc:摆放位置
* @param name:is_final type:int require:1 desc:是否终结点0no1yes
* @param name:sort type:int require:1 default:0 desc:权重
*/
public function editTopic()
{
$data = $this->request->post();
$update['journal_topic_id'] = $data['journal_topic_id'];
$update['title'] = $data['title'];
$update['icon'] = $data['icon'];
$update['intro'] = $data['intro'];
$update['come'] = $data['come'];
$update['position'] = isset($data['position']) ? $data['position'] : '';
$update['is_final'] = $data['is_final'];
$update['sort'] = $data['sort'];
$res = $this->journal_topic_obj->update($update);
return json(['code' => 0, 'msg' => 'success']);
}
/**
* @title 删除话题
* @description 删除话题
* @author wangjinlei
* @url /master/Journal/delTopic
* @method POST
*
* @param name:journal_topic_id type:int require:1 desc:主键
*/
public function delTopic()
{
$data = $this->request->post();
//排除有子节点的项
$rep = $this->journal_topic_obj->where('parent_id', $data['journal_topic_id'])->where('state', 0)->find();
if ($rep) {
return json(['code' => 1, 'msg' => '删除的话题不能有子节点!']);
}
$res = $this->journal_topic_obj->where('journal_topic_id', $data['journal_topic_id'])->update(['state' => 1]);
//删除此话题下的话题文章对应关系
$this->article_to_topic_obj->where('topic_id', $data['journal_topic_id'])->update(['state' => 1]);
if ($res) {
return json(['code' => 0, 'msg' => 'success']);
} else {
return json(['code' => 1, 'msg' => 'system error']);
}
}
/**
* @title 获取话题父级列表
* @description 获取话题父级列表
* @author wangjinlei
* @url /master/Journal/getParent
* @method POST
*
* @param name:journal_id type:int require:1 desc:
*
* @return parentList:array#
*/
public function getParent()
{
$data = $this->request->post();
// $data['journal_id'] = 9;
$res = $this->journal_topic_obj
->where('journal_id', $data['journal_id'])
->where('state', 0)
->where('is_final', 0)
->order('sort desc')
->select();
//处理数组
$frag = [];
foreach ($res as $v) {
if ($v['parent_id'] == 0) {
$frag[] = $v;
}
}
$ff = [];
foreach ($frag as $kk => $vv) {
$ff[] = $this->getpChieldarr($vv, $res);
// $frag[$kk] = $this->getChieldarr($vv,$res);
}
$fff = [];
foreach ($ff as $vvv) {
foreach ($vvv as $vvvv) {
$fff[] = $vvvv;
}
}
return json(['code' => 0, 'msg' => 'success', 'data' => ['parentList' => $fff]]);
}
private function getpChieldarr($vv, $res)
{
if ($vv['is_final'] == 1) {
return $vv;
}
$frag = [];
$frag[] = $vv;
foreach ($res as $v) {
if ($v['parent_id'] == $vv['journal_topic_id']) {
$frag[] = $this->getChieldarr($v, $res);
}
}
return $frag;
}
/**
* @title 获取话题列表
* @description 获取话题列表
* @author wangjinlei
* @url /master/Journal/getTopicList
* @method POST
*
* @param name:journal_id type:int require:1 desc:期刊id
*
* @return journal:array#
* @return topicList:话题数组@
* @topicList array:数据
*/
public function getTopicList()
{
$data = $this->request->post();
$res = $this->journal_topic_obj
->where('journal_id', $data['journal_id'])
->where('state', 0)
->select();
$journal_info = $this->journal_obj->where('journal_id', $data['journal_id'])->find();
//处理数组
$frag = [];
foreach ($res as $v) {
if ($v['parent_id'] == 0) {
$frag[] = $v;
}
}
foreach ($frag as $kk => $vv) {
$frag[$kk] = $this->getChieldarr($vv, $res);
}
return json(['code' => 0, 'msg' => 'success', 'data' => ['journal' => $journal_info, 'topicList' => $frag]]);
}
private function getChieldarr($vv, $res)
{
if ($vv['is_final'] == 1) {
return $vv;
}
foreach ($res as $v) {
if ($v['parent_id'] == $vv['journal_topic_id']) {
$vv['children'][] = $this->getChieldarr($v, $res);
}
}
return $vv;
}
/**
* @title 添加话题的文章
* @description 添加话题的文章
* @author wangjinlei
* @url /master/Journal/addTopicArticle
* @method POST
*
* @param name:article_id type:int require:1 desc:文章id
* @param name:topic_id type:int require:1 desc:话题id
*/
public function addTopicArticle()
{
$data = $this->request->post();
$insert['article_id'] = $data['article_id'];
$insert['topic_id'] = $data['topic_id'];
$res = $this->article_to_topic_obj->insert($insert);
$this->msg_subscript_topic($data['topic_id'], $data['article_id']);
$this->msg_subscribe_base_topic($data['topic_id'], $data['article_id']);
if ($res) {
return json(['code' => 0, 'msg' => 'success']);
} else {
return json(['code' => 1, 'msg' => 'system error']);
}
}
/**
* 推送邮件给编委
*/
private function pushEmailToBoardByJournal()
{
$data = $this->request->post();
$rule = new Validate([
'journal_id' => 'require'
]);
if (!$rule->check($data)) {
return jsonError($rule->getError());
}
$journal_info = $this->journal_obj->where('journal_id', $data['journal_id'])->find();
$boards = $this->board_obj->where('journal_id', $data['journal_id'])->where('type', 2)->where('state', 0)->select();
$tt = "Life Research journal is currently applying for Web of Science Core Collection (SCI), and we have received modification comments from Web of Science Editorial Team. Life Research is expected to be indexed in SCI in two years. <br><br>";
$tt .= "According to the opinions, the editorial board of Life Research journal needs to be reorganized. <strong>Please send the URL of your latest publication record (ORCID or ResearchGate) to this email address (liferes@tmrjournals.com)</strong>. We will choose new editorial board members based on the latest publication record. If you cannot respond within two weeks, you will be temporarily removed from the editorial board list until you send us the publication record.<br><br>";
$tt .= "Thank you very much for your support.<br><br>";
$tt .= "Life Research Editorial Team";
// $name = 'haoRan Zhang';
// // $maidata['email'] = 'liferes@tmrjournals.com';
// $maidata['email'] = '751475802@qq.com';
// $maidata['title'] = 'Please send the URL of your latest publication record (Life Research)';
// $maidata['content'] = "Dear ".$name.",<br><br>".$tt;
// // $maidata['tmail'] = $journal_info['email'];
// // $maidata['tpassword'] = $journal_info['epassword'];
// $maidata['tmail'] = 'liferes@tmrjournals.com';
// $maidata['tpassword'] = 'Wu999999lifere';
// Queue::push('app\api\job\mail@fire', $maidata, "mail");
// $r = sendEmail($maidata['email'],$maidata['title'],$maidata['title'],$maidata['content'],$maidata['tmail'],$maidata['tpassword']);
foreach ($boards as $v) {
if ($v['email'] == '') {
continue;
}
$maidata['email'] = $v['email'];
$maidata['title'] = 'Please send the URL of your latest publication record (Life Research)';
$maidata['content'] = "Dear " . $v['name'] . ",<br><br>" . $tt;
$maidata['tmail'] = $journal_info['email'];
$maidata['tpassword'] = $journal_info['epassword'];
Queue::push('app\api\job\mail@fire', $maidata, "mail");
// Queue::push('app\api\job\mail@propa', $maidata, "mail");
}
return jsonSuccess([]);
}
/**
* 发送推广邮件到订阅者
*/
public function pushEmailToDY()
{
$frag = $this->subscribe_journal_obj->where('journal_id', 1)->where('state', 0)->limit(0, 1000)->select();
$articles = $this->article_obj
->field('j_article.*,j_journal_stage.stage_year,j_journal_stage.stage_vol,j_journal_stage.stage_no')
->join('j_journal_stage', 'j_journal_stage.journal_stage_id = j_article.journal_stage_id', 'left')
->where('j_article.journal_id', 1)
->where('j_article.journal_stage_id', '<', 375)
->limit(20)
->order('pdf_num desc')->select();
$tt = 'Greetings!<br>';
$tt .= 'Thank you for your attention to TMR Publishing Group and your active participation.<br><br>';
$tt .= "According to Clarivate's latest policy (https://clarivate.com/news/clarivate-announces-changes-to-the-2023-journal-citation-reports/), Traditional Medicine Research (ISSN 2413-3973) will get the first Impact Factor in 2023. You are welcome to pay attention to the journal and submit manuscripts. <br><br>";
$tt .= "Attached are some popular papers published in Traditional Medicine Research.<br><br>";
$tt .= "You are always welcome to read and share the articles and encourage you to submit your manuscripts to us through the following channels: www.tmrjournals.com/tmr<br><br>";
foreach ($articles as $v) {
$tt .= "<a href='https://www.tmrjournals.com/article.html?J_num=1&a_id=" . $v['article_id'] . "'>" . $v['title'] . "</a><br>";
$tt .= "Traditional Medicine Research. " . $v['stage_year'] . " " . $v['stage_vol'] . "(" . $v['stage_no'] . ")<br>";
$tt .= "<a href='https://www.tmrjournals.com/public/articlePDF/" . $v['file_pdf'] . "'>Download pdf</a><br><br><br>";
}
$frag1 = [];
$frag1[] = [
'subscribe_journal_id' => 7,
'email' => '751475802@qq.com'
];
$frag1[] = [
'subscribe_journal_id' => 7,
'email' => 'tmr@tmrjournals.com'
];
foreach ($frag as $v) {
$cache_tt = $tt . '<a href="http://journalapi.tmrjournals.com/public/index.php/api/Journal/UnsubscribeJournal/snum/' . $v['subscribe_journal_id'] . '">Unsubscribe</a>';
$maidata['email'] = $v['email'];
$maidata['title'] = "Traditional Medicine Research will get the first Impact Factor (WOS) in 2023";
$maidata['content'] = $cache_tt;
// $maidata['tmail'] = 'publicrelations@tmrjournals.com';
// $maidata['tpassword'] = 'pRWU999999';
// $maidata['tmail'] = 'ghr@tmrjournals.com';
// $maidata['tpassword'] = 'Gh999666';
// echo aliemail($maidata['email'], $maidata['title'], $maidata['content']);
Queue::push('app\api\job\mail@propa', $maidata, "mail");
// sendEmail($maidata['email'],$maidata['title'],$maidata['title'],$maidata['content'],$maidata['tmail'],$maidata['tpassword']);
}
return jsonSuccess([]);
}
/**
* 发送邮件至审稿人
*/
public function pushEmailToReviewer()
{
$data = $this->request->post();
$topic_tem = Db::name('topic_tem');
$tems = $topic_tem->where('topic_id', $data['topic'])->where('state', 0)->select();
$frag = [];
foreach ($tems as $k => $v) {
$url = "http://api.tmrjournals.com/public/index.php/api/Reviewer/getRevEmailByTopic";
$pag = [];
$pag['topic'] = $v['p_title'];
$cache_res = object_to_array(json_decode(myPost($url, $pag)));
if ($cache_res['code'] == 0) {
$emails = $cache_res['data']['reviewers'];
foreach ($emails as $val) {
$frag[] = $val;
}
}
}
$article_ids = $this->article_to_topic_obj->where('topic_id', $data['topic'])->where('state', 0)->column('article_id');
$articles = $this->article_obj
->field('j_article.*,j_journal_stage.stage_year,j_journal_stage.stage_vol,j_journal_stage.stage_no')
->join('j_journal_stage', 'j_journal_stage.journal_stage_id = j_article.journal_stage_id', 'left')
->where('j_journal_stage.stage_year', '>=', '2020')
->where('j_article.article_id', 'in', $article_ids)
->where('j_article.journal_id', 1)
->where('j_article.state', 0)
->select();
$tt = 'Greetings!<br>';
$tt .= 'Thank you for your contribution to TMR Publishing Group and your active participation in the peer review process.<br>';
$tt .= "According to Clarivate's latest policy (https://clarivate.com/news/clarivate-announces-changes-to-the-2023-journal-citation-reports/), Traditional Medicine Research (ISSN 2413-3973) will get the first Impact Factor in 2023. You are welcome to pay attention to the journal and submit manuscripts.<br>Attached are some papers published in Traditional Medicine Research, which are related to your research field. You are always welcome to read and to share the articles and encourage you to submit your manuscripts to us through the following channels: www.tmrjournals.com/tmr <br><br>";
foreach ($articles as $v) {
$tt .= "<a href='https://www.tmrjournals.com/article.html?J_num=1&a_id=" . $v['article_id'] . "'>" . $v['title'] . "</a><br>";
$tt .= "Traditional Medicine Research. " . $v['stage_year'] . " " . $v['stage_vol'] . "(" . $v['stage_no'] . ")<br>";
$tt .= "<a href='https://www.tmrjournals.com/public/articlePDF/" . $v['file_pdf'] . "'>Download pdf</a><br><br><br>";
}
$frag1 = [];
$frag1[] = [
'user_id' => 54,
'email' => '751475802@qq.com'
];
$frag1[] = [
'user_id' => 28,
'email' => 'tmr@tmrjournals.com'
];
foreach ($frag as $v) {
$cache_tt = $tt . '<a href="http://api.tmrjournals.com/public/index.php/api/User/unAdvertForUser/uid/' . $v['user_id'] . '">Unsubscribe</a>';
$maidata['email'] = $v['email'];
$maidata['title'] = "Traditional Medicine Research will get the first Impact Factor (WOS) in 2023";
$maidata['content'] = $cache_tt;
// $maidata['tmail'] = 'publicrelations@tmrjournals.com';
// $maidata['tpassword'] = 'pRWU999999';
// $maidata['tmail'] = 'ghr@tmrjournals.com';
// $maidata['tpassword'] = 'Gh999666';
// echo aliemail($maidata['email'], $maidata['title'], $maidata['content']);
Queue::push('app\api\job\mail@propa', $maidata, "mail");
// sendEmail($maidata['email'],$maidata['title'],$maidata['title'],$maidata['content'],$maidata['tmail'],$maidata['tpassword']);
}
return jsonSuccess(['num' => count($frag)]);
}
// public function toReviewerEmail()//$email, $topic_id)
// {
// $data = $this->request->post();
// $article_ids = $this->article_to_topic_obj->where('topic_id', $data['topic_id'])->where('state', 0)->column('article_id');
// $articles = $this->article_obj
// ->field('j_article.*,j_journal_stage.stage_year,j_journal_stage.stage_vol,j_journal_stage.stage_no')
// ->join('j_journal_stage', 'j_journal_stage.journal_stage_id = j_article.journal_stage_id', 'left')
// ->where('j_journal_stage.stage_year', '>=', '2020')
// ->where('j_article.article_id', 'in', $article_ids)
// ->where('j_article.journal_id',1)
// ->where('j_article.state', 0)
// ->select();
// $tt = 'Greetings!<br>';
// $tt .= 'Thank you for your contribution to TMR Publishing Group and your active participation in the peer review process.<br>';
// $tt .= "According to Clarivate's latest policy (https://clarivate.com/news/clarivate-announces-changes-to-the-2023-journal-citation-reports/), Traditional Medicine Research (ISSN 2413-3973) will get the first Impact Factor in 2023. You are welcome to pay attention to the journal and submit manuscripts.Attached are some papers published in Traditional Medicine Research, which are related to your research field. You are always welcome to read and to share the articles and encourage you to submit your manuscripts to us through the following channels: www.tmrjournals.com/tmr <br><br>";
// foreach($articles as $v){
// $tt .= "<a href='https://www.tmrjournals.com/article.html?J_num=1&a_id=".$v['article_id']."'>".$v['title']."</a><br>";
// $tt .= "Traditional Medicine Research. ".$v['stage_year']." ".$v['stage_vol']."(".$v['stage_no'].")<br>";
// $tt .= "<a href='https://www.tmrjournals.com/public/articlePDF/".$v['file_pdf']."'>Download pdf</a><br><br><br>";
// }
// $maidata['email'] = $data['email'];
// $maidata['title'] = "Traditional Medicine Research will get the first Impact Factor (WOS) in 2023";
// $maidata['content'] = $tt;
// $maidata['tmail'] = 'publicrelations@tmrjournals.com';
// $maidata['tpassword'] = 'pRWU999999';
// echo sendEmail($maidata['email'],$maidata['title'],$maidata['title'],$maidata['content'],$maidata['tmail'],$maidata['tpassword']);
// // Queue::push('app\api\job\mail@fire', $maidata, "mail");
// }
public function mmm()
{
$this->msg_subscribe_base_topic(14, 5);
}
private function msg_subscribe_base_topic($topic_id, $article_id)
{
$article_info = $this->article_obj->where('article_id', $article_id)->find();
$topic_info = $this->journal_topic_obj->where('journal_topic_id', $topic_id)->find();
$base_topic_info = $this->base_topic_obj->where('title', $topic_info['title'])->find();
$journal_info = $this->journal_obj->where('journal_id', $article_info['journal_id'])->find();
if ($base_topic_info == null) {
return;
}
$list = $this->subscribe_base_topic_obj->where('base_topic_id', $base_topic_info['base_topic_id'])->where('state', 0)->select();
$title = 'These new articles included in TMRDE database are available online.';
$tt = 'Dear Researcher,<br>';
$tt .= 'It is our great honor to present you the articles included in TMRDE.The following new articles have just been included.<br>';
$tt .= '<a href="https://www.tmrjournals.com/article.html?J_num=' . $article_info['journal_id'] . '&a_id=' . $article_id . '">' . $article_info['title'] . '</a><br>';
foreach ($list as $v) {
$tt1 = '';
$tt1 .= $tt;
$tt1 .= '<a href="http://journalapi.tmrjournals.com/public/index.php/api/Journal/UnsubscribeBaseTopic/snum/' . $v['subscribe_base_topic_id'] . '">Unsubscribe</a><br><br>';
$tt1 .= 'Email:' . $journal_info['email'] . '<br>';
$tt1 .= 'Website:' . $journal_info['website'] . '<br><br>';
$tt1 .= 'TMR Publishing Group Ltd.<br>';
$tt1 .= '11 Cockle Bay Rd, Cockle Bay, Auckland, New Zealand<br>';
$tt1 .= 'Tel: +64 02108293806.';
$maidata['email'] = $v['email'];
$maidata['title'] = $title;
$maidata['content'] = $tt1;
$maidata['tmail'] = 'publicrelations@tmrjournals.com';
$maidata['tpassword'] = 'pRWU999999';
Queue::push('app\api\job\mail@fire', $maidata, "mail");
}
}
private function msg_subscript_topic($topic_id, $article_id)
{
$article_info = $this->article_obj->where('article_id', $article_id)->find();
$stage_info = $this->journal_stage_obj->where('journal_stage_id', $article_info['journal_stage_id'])->find();
$topic_info = $this->journal_topic_obj->where('journal_topic_id', $topic_id)->find();
$journal_info = $this->journal_obj->where('journal_id', $article_info['journal_id'])->find();
$list = [];
if ($topic_info['level'] == 2) {
$list = $this->subscribe_topic_obj->where('topic_id', $topic_id)->where('state', 0)->select();
} else {
$list = $this->subscribe_topic_obj->where('topic_id', $topic_info['parent_id'])->where('state', 0)->select();
}
// $list = $this->subscribe_topic_obj->where('topic_id',$topic_info['parent_id'])->where('state',0)->select();
//组成文章信息
$tt1 = '<div style="background-color: #ededed;margin: 0;">
<div class="con_content" style="font-family: Arial;
width: 600px;
margin: 0 auto;
background-color: #fff;
padding: 30px 40px;
color: #1B3051;
font-size: 14px;
line-height: 20px;">
<div>
<img style="width: 80px;" src="" alt="">
</div><br><br>';
$tt1 .= $journal_info['title'] . '<br><br>';
$tt1 .= 'The following new articles have just been published in Topic "' . $topic_info['title'] . '" of ' . $journal_info['title'] . '<br><br>';
$tt1 .= $article_info['type'] . '<br>';
$tt1 .= '<a href="https://www.tmrjournals.com/article.html?J_num=' . $journal_info['journal_id'] . '&a_id=' . $article_info['article_id'] . '">' . $article_info['title'] . '</a><br>';
$tt1 .= $this->getAuthor($article_info) . '<br>';
$tt1 .= $journal_info['title'] . ' ' . $stage_info['stage_year'] . ' ' . $stage_info['stage_vol'] . "(" . $stage_info['stage_no'] . "). https://doi.org/" . $article_info['doi'] . '<br>';
$tt1 .= '<a href="https://www.tmrjournals.com/public/articlePDF/' . $article_info['file_pdf'] . '">Download pdf</a><br><br><br>';
$tt2 = 'Email: ' . $journal_info['email'] . '<br>';
$tt2 .= 'Website: https://www.tmrjournals.com/' . $journal_info['usx'] . '<br>';
$tt2 .= 'TMR Publishing Group Ltd.<br>';
$tt2 .= '11 Cockle Bay Rd, Cockle Bay, Auckland, New Zealand<br>';
$tt2 .= 'Tel: +64 02108293806.';
$tt2 .= '</div>
</div>';
foreach ($list as $v) {
$cache = $tt1 . '<a href="http://journalapi.tmrjournals.com/public/index.php/api/Journal/UnsubscribeTopic/snum/' . $v['subscribe_topic_id'] . '">Unsubscribe</a><br><br>' . $tt2;
$maidata['email'] = $v['email'];
$maidata['title'] = $journal_info['title'];
$maidata['content'] = $cache;
$maidata['tmail'] = 'publicrelations@tmrjournals.com';
$maidata['tpassword'] = 'pRWU999999';
Queue::push('app\api\job\mail@fire', $maidata, "mail");
}
}
/**
* @title 获取当前话题的文章
* @description 获取当前话题的文章
* @author wangjinlei
* @url /master/Journal/getTopicArticles
* @method POST
*
* @param name:topic_id type:int require:1 desc:话题id
*
* @return dataList:array#
* @return topic:array#
*/
public function getTopicArticles()
{
$data = $this->request->post();
$list = $this->article_to_topic_obj
->field('j_article_to_topic.*,j_article.*')
->join('j_article', 'j_article.article_id = j_article_to_topic.article_id', 'LEFT')
->where('j_article_to_topic.topic_id', $data['topic_id'])
->where('j_article_to_topic.state', 0)
->select();
$info = $this->journal_topic_obj->where('journal_topic_id', $data['topic_id'])->find();
return json(['code' => 0, 'msg' => 'success', 'data' => ['topic' => $info, 'dataList' => $list]]);
}
/**
* @title 获取当前期刊的文章
* @description 获取当前期刊的文章
* @author wangjinlei
* @url /master/Journal/getArticleByJournal
* @method POST
*
* @param name:journal_id type:int require:1 desc:期刊id
* @param name:topic_id type:int require:1 desc:话题id
* @param name:title type:string require:1 desc:标题
* @param name:pageIndex type:int require:1 desc:当前页码数
* @param name:pageSize type:int require:1 desc:单页数据条数
*
* @return dataList:array#
*/
public function getArticleByJournal()
{
$data = $this->request->post();
//排除stage
$ids = $this->article_to_topic_obj->where('topic_id', $data['topic_id'])->where('state', 0)->column('article_id');
$limit_start = ($data['pageIndex'] - 1) * $data['pageSize'];
$list = $this->article_obj->where('journal_id', $data['journal_id'])->where('state', 0)->where('article_id', 'not in', $ids)->where('title', 'like', '%' . $data['title'] . '%')->limit($limit_start, $data['pageSize'])->select();
$count = $this->article_obj->where('journal_id', $data['journal_id'])->where('state', 0)->where('article_id', 'not in', $ids)->where('title', 'like', '%' . $data['title'] . '%')->count();
return json(['code' => 0, 'msg' => 'success', 'data' => ['count' => $count, 'dataList' => $list]]);
}
/**
* @title 删除文章话题关系
* @description 删除文章话题关系
* @author wangjinlei
* @url /master/Journal/delArticleToTopic
* @method POST
*
* @param name:article_to_topic_id type:int require:1 desc:id
*
*/
public function delArticleToTopic()
{
$data = $this->request->post();
$res = $this->article_to_topic_obj->where('article_to_topic_id', $data['article_to_topic_id'])->update(['state' => 1]);
if ($res) {
return json(['code' => 0, 'msg' => 'success']);
} else {
return json(['code' => 1, 'msg' => 'system error']);
}
}
/**
* @title 添加期刊外链
* @description 添加期刊外链
* @author wangjinlei
* @url /master/Journal/addJournalAbs
* @method POST
*
* @param name:journal_id type:int require:1 desc:期刊id
* @param name:title type:int require:1 desc:标题
* @param name:url type:string require:1 desc:地址
* @param name:sort type:int require:1 default:0 desc:权重
* @param name:is_show type:int require:1 default:1 desc:是否显示1yes0no
*/
public function addJournalAbs()
{
$data = $this->request->post();
$add_data['journal_id'] = $data['journal_id'];
$add_data['title'] = $data['title'];
$add_data['url'] = $data['url'];
$add_data['sort'] = $data['sort'];
$add_data['is_show'] = $data['is_show'];
$res = $this->journal_abs_obj->insert($add_data);
if ($res) {
return json(['code' => 0, 'msg' => 'success']);
} else {
return json(['code' => 1, 'msg' => 'system error!']);
}
}
/**
* @title 删除期刊外链
* @description 删除期刊外链
* @author wangjinlei
* @url /master/Journal/delJournalAbs
* @method POST
*
* @param name:journal_abstracting_id type:int require:1 desc:期刊外链id
*/
public function delJournalAbs()
{
$data = $this->request->post();
$this->journal_abs_obj->where('journal_abstracting_id', $data['journal_abstracting_id'])->update(['state' => 1]);
return json(['code' => 0, 'msg' => 'success']);
}
/**
* @title 编辑期刊外链
* @description 编辑期刊外链
* @author wangjinlei
* @url /master/Journal/editJournalAbs
* @method POST
*
* @param name:journal_abstracting_id type:int require:1 desc:期刊外链id
* @param name:journal_id type:int require:1 desc:期刊id
* @param name:title type:int require:1 desc:标题
* @param name:url type:string require:1 desc:地址
* @param name:sort type:int require:1 default:0 desc:权重
* @param name:is_show type:int require:1 default:1 desc:是否显示1yes0no
*/
public function editJournalAbs()
{
$data = $this->request->post();
$this->journal_abs_obj->update($data);
return json(['code' => 0, 'msg' => 'success']);
}
/**
* @title 获取期刊外链
* @description 获取期刊外链
* @author wangjinlei
* @url /master/Journal/getJournalAbs
* @method POST
*
* @param name:journal_id type:int require:1 desc:期刊id
*/
public function getJournalAbs()
{
$data = $this->request->post();
$journal_info = $this->journal_obj->where('journal_id', $data['journal_id'])->find();
$list = $this->journal_abs_obj->where('journal_id', $data['journal_id'])->where('state', 0)->order('sort desc')->select();
return json(['code' => 0, 'msg' => 'success', 'data' => ['journal' => $journal_info, 'absList' => $list]]);
}
/**
* @title topic图片上传
* @description topic图片上传
* @author wangjinlei
* @url /master/Journal/up_topic_file
* @method POST
*
* @param name:name type:string require:1 default:journaltopic desc:文件域名称
*
* @return upurl:图片地址
*/
public function up_topic_file()
{
$file = request()->file('journaltopic');
if ($file) {
$info = $file->move(ROOT_PATH . 'public' . DS . 'journaltopic');
if ($info) {
return json(['code' => 0, 'msg' => 'success', 'upurl' => str_replace("\\", "/", $info->getSaveName())]);
} else {
return json(['code' => 1, 'msg' => $file->getError()]);
}
}
}
/**
* @title 编委头像上传
* @description 编委头像上传
* @author wangjinlei
* @url /master/Journal/up_board_file
* @method POST
*
* @param name:name type:string require:1 default:boardIcon desc:文件域名称
*
* @return upurl:图片地址
*/
public function up_board_file()
{
$file = request()->file('boardIcon');
if ($file) {
$info = $file->move(ROOT_PATH . 'public' . DS . 'boardIcon');
if ($info) {
return json(['code' => 0, 'msg' => 'success', 'upurl' => str_replace("\\", "/", $info->getSaveName())]);
} else {
return json(['code' => 1, 'msg' => $file->getError()]);
}
}
}
/**
* 获取期刊forAuthor
*/
public function getForAuthorList()
{
$data = $this->request->post();
// 验证规则
$rule = new Validate([
'journal_id' => 'require'
]);
if (!$rule->check($data)) {
return jsonError($rule->getError());
}
$journals[] = 0;
if ($data['journal_id'] != 0) {
$journals[] = $data['journal_id'];
}
$list = $this->journal_for_author->where('journal_id', 'in', $journals)->where('pid', 0)->where('jfa_state', 0)->order("sort desc")->select();
foreach ($list as $k => $v) {
$cache_list = $this->journal_for_author->where('journal_id', 'in', $journals)->where('pid', $v['jfa_id'])->where('jfa_state', 0)->order("sort desc")->select();
foreach ($cache_list as $key => $val) {
$cache_list[$key]['p_title'] = $v['jfa_title'];
}
$list[$k]['children'] = $cache_list;
}
$re['forAuthors'] = $list;
return jsonSuccess($re);
}
/**
* 添加forauthor
*/
public function addForAuthor()
{
$data = $this->request->post();
// 验证规则
$rule = new Validate([
'journal_id' => 'require',
'pid' => 'require',
'jfa_title' => 'require'
]);
if (!$rule->check($data)) {
return jsonError($rule->getError());
}
$insert['journal_id'] = $data['journal_id'];
$insert['pid'] = $data['pid'];
$insert['jfa_title'] = $data['jfa_title'];
$insert['content'] = $data['content'];
$insert['sort'] = isset($data['sort']) ? $data['sort'] : 0;
$insert['jfa_ctime'] = time();
$this->journal_for_author->insert($insert);
return jsonSuccess([]);
}
/**
* 编辑forauthor
*/
public function editForAuthor()
{
$data = $this->request->post();
// 验证规则
$rule = new Validate([
'jfa_id' => 'require',
'jfa_title' => 'require',
'sort' => 'require'
]);
if (!$rule->check($data)) {
return jsonError($rule->getError());
}
$update['jfa_title'] = $data['jfa_title'];
$update['content'] = $data['content'];
$update['sort'] = $data['sort'];
$this->journal_for_author->where('jfa_id', $data['jfa_id'])->update($update);
return jsonSuccess([]);
}
/**
* 删除forAuthor
*/
public function delForAuthor()
{
$data = $this->request->post();
// 验证规则
$rule = new Validate([
'jfa_id' => 'require'
]);
if (!$rule->check($data)) {
return jsonError($rule->getError());
}
$this->journal_for_author->where('jfa_id', $data['jfa_id'])->update(['jfa_state' => 1]);
return jsonSuccess([]);
}
/**
* @title line图片上传
* @description line图片上传
* @author wangjinlei
* @url /master/Journal/up_line_file
* @method POST
*
* @param name:name type:string require:1 default:journalline desc:文件域名称
*
* @return upurl:图片地址
*/
public function up_line_file()
{
$file = request()->file('journalline');
if ($file) {
$info = $file->move(ROOT_PATH . 'public' . DS . 'journalline');
if ($info) {
return json(['code' => 0, 'msg' => 'success', 'upurl' => str_replace("\\", "/", $info->getSaveName())]);
} else {
return json(['code' => 1, 'msg' => $file->getError()]);
}
}
}
/**
* @title footer图片上传
* @description footer图片上传
* @author wangjinlei
* @url /master/Journal/up_footer_file
* @method POST
*
* @param name:name type:string require:1 default:journalfooter desc:文件域名称
*
* @return upurl:图片地址
*/
public function up_footer_file()
{
$file = request()->file('journalfooter');
if ($file) {
$info = $file->move(ROOT_PATH . 'public' . DS . 'journalfooter');
if ($info) {
return json(['code' => 0, 'msg' => 'success', 'upurl' => str_replace("\\", "/", $info->getSaveName())]);
} else {
return json(['code' => 1, 'msg' => $file->getError()]);
}
}
}
/**
* @title 添加期刊分期
* @description 添加期刊分期
* @author wangjinlei
* @url /master/Journal/addStage
* @method POST
*
* @param name:journal_id type:int require:1 desc:期刊id
* @param name:stage_year type:string require:1 desc:分期年份
* @param name:stage_vol type:int require:1 desc:分期卷数
* @param name:stage_no type:int require:1 desc:分期号码
* @param name:stage_pagename type:string require:1 desc:page名称
* @param name:is_publish type:int require:1 default:1 desc:是否出刊
* @param name:stage_page type:string require:1 desc:分期页码
* @param name:issue_date type:string require:1 desc:发布时间
* @param name:stage_icon type:string require:0 desc:期刊封面url
*/
public function addStage()
{
$data = $this->request->post();
$insert_data['journal_id'] = $data['journal_id'];
$insert_data['stage_year'] = $data['stage_year'];
$insert_data['stage_vol'] = $data['stage_vol'];
$insert_data['stage_no'] = $data['stage_no'];
$insert_data['stage_pagename'] = $data['stage_pagename'];
$insert_data['stage_page'] = $data['stage_page'];
$insert_data['issue_date'] = $data['issue_date'];
if (isset($data['stage_icon']) && !empty($data['stage_icon'])) {
$insert_data['stage_icon'] = $data['stage_icon'];
}
$res = $this->journal_stage_obj->insert($insert_data);
if ($res) {
return json(['code' => 0, 'msg' => 'success']);
} else {
return json(['code' => 1, 'msg' => 'system error']);
}
}
/**
* 添加分期应对投稿系统
*/
public function addStageForTG(){
$data = $this->request->post();
$journal_info = $this->journal_obj->where('issn',$data['issn'])->find();
$insert_data['journal_id'] = $journal_info['journal_id'];
$insert_data['stage_year'] = $data['stage_year'];
$insert_data['stage_vol'] = $data['stage_vol'];
$insert_data['stage_no'] = $data['stage_no'];
$insert_data['stage_pagename'] = $data['stage_pagename'];
$insert_data['stage_page'] = $data['stage_page'];
$insert_data['issue_date'] = $data['issue_date'];
if (isset($data['stage_icon']) && !empty($data['stage_icon'])) {
$insert_data['stage_icon'] = $data['stage_icon'];
}
$res = $this->journal_stage_obj->insert($insert_data);
if ($res) {
return json(['code' => 0, 'msg' => 'success']);
} else {
return json(['code' => 1, 'msg' => 'system error']);
}
}
/**
* @title 获取期刊分期
* @description 获取期刊分期
* @author wangjinlei
* @url /master/Journal/getStageList
* @method POST
*
* @param name:journal_id type:int require:1 desc:期刊id
*
* @return journal:array#
* @return stage_list:array#
*/
public function getStageList()
{
$data = $this->request->post();
$journal_info = $this->journal_obj->where('journal_id', $data['journal_id'])->find();
$stage_list = $this->journal_stage_obj->where('journal_id', $data['journal_id'])->where('state', 0)->order('journal_stage_id desc')->select();
return json(['code' => 0, 'msg' => 'success', 'data' => ['journal' => $journal_info, 'stage_list' => $stage_list]]);
}
/**
* 获取stages通过issn号
*/
public function getStageByISSN()
{
$data = $this->request->post();
$rule = new Validate([
'issn' => 'require'
]);
if (!$rule->check($data)) {
return jsonError($rule->getError());
}
$journal_info = $this->journal_obj->where('issn',$data['issn'])->find();
$stages = $this->journal_stage_obj->where('journal_id',$journal_info['journal_id'])->where('state',0)->order('journal_stage_id desc')->select();
$re['stages'] = $stages;
return jsonSuccess($re);
}
/**
* 获取分期详情
*/
public function getStageDetail(){
$data = $this->request->post();
$rule = new Validate([
'journal_stage_id'=>'require|number'
]);
if(!$rule->check($data)){
return jsonError($rule->getError());
}
$stage = $this->journal_stage_obj->where('journal_stage_id',$data['journal_stage_id'])->find();
$re['stage'] = $stage;
return jsonSuccess($re);
}
/**
* @title 删除期刊分期
* @description 删除期刊分期
* @author wangjinlei
* @url /master/Journal/delStage
* @method POST
*
* @param name:journal_stage_id type:int require:1 desc:期刊分期id
*/
public function delStage()
{
$data = $this->request->post();
$res = $this->journal_stage_obj->where('journal_stage_id', $data['journal_stage_id'])->update(['state' => 1]);
if ($res) {
return json(['code' => 0, 'msg' => 'success']);
} else {
return json(['code' => 1, 'msg' => 'system error']);
}
}
/**
* @title 更改期刊分期
* @description 更改期刊分期
* @author wangjinlei
* @url /master/Journal/editStage
* @method POST
*
* @param name:journal_stage_id type:int require:1 desc:期刊分期id
* @param name:stage_year type:string require:1 desc:分期年份
* @param name:stage_vol type:int require:1 desc:分期卷数
* @param name:stage_no type:int require:1 desc:分期号码
* @param name:is_publish type:int require:1 default:1 desc:是否出刊
* @param name:stage_pagename type:string require:1 desc:分期页码name
* @param name:stage_page type:string require:1 desc:分期页码
* @param name:issue_date type:string require:1 desc:发布时间
* @param name:stage_icon type:string require:0 desc:封面url
*/
public function editStage()
{
$data = $this->request->post();
$old = $this->journal_stage_obj->where('journal_stage_id', $data['journal_stage_id'])->find();
$res = $this->journal_stage_obj->update($data);
//是否提醒订阅者
if ($old['is_publish'] == 0 && $data['is_publish'] == 1) {
$this->msg_subscript_journal($data['journal_stage_id'], $old['journal_id']);
// 提醒作者 发送邮件
$this->sendAuthor($data['journal_stage_id'], $old['journal_id']);
}
if ($res) {
return json(['code' => 0, 'msg' => 'success']);
} else {
return json(['code' => 1, 'msg' => 'system error']);
}
}
private function msg_subscript_journal($journal_stage_id, $journal_id)
{
$articles = $this->article_obj->where('journal_stage_id', $journal_stage_id)->where('state', 0)->select();
$stage_info = $this->journal_stage_obj->where('journal_stage_id', $journal_stage_id)->find();
$journal_info = $this->journal_obj->where('journal_id', $journal_id)->find();
$list = $this->subscribe_journal_obj->where('journal_id', $journal_id)->where('state', 0)->select();
//组成文章信息
$tt1 = '<div style="background-color: #ededed;margin: 0;">
<div class="con_content" style="font-family: Arial;
width: 600px;
margin: 0 auto;
background-color: #fff;
padding: 30px 40px;
color: #1B3051;
font-size: 14px;
line-height: 20px;">
<div>
<img style="width: 80px;" src="" alt="">
</div><br><br>';
$tt1 .= $journal_info['title'] . '<br><br>';
$tt1 .= 'Dear Researcher,<br>';
$tt1 .= 'It is our great honor to present you the articles published in ' . $journal_info['title'] . '.<br>';
$tt1 .= 'The following new articles have just been published.<br><br>';
foreach ($articles as $val) {
$tt1 .= $val['type'] . '<br>';
$tt1 .= '<a href="https://www.tmrjournals.com/article.html?J_num=' . $journal_info['journal_id'] . '&a_id=' . $val['article_id'] . '">' . $val['title'] . '</a><br>';
$tt1 .= $this->getAuthor($val) . '<br>';
$tt1 .= $journal_info['title'] . ' ' . $stage_info['stage_year'] . ' ' . $stage_info['stage_vol'] . "(" . $stage_info['stage_no'] . "). DOI:" . $val['doi'] . '<br>';
$tt1 .= '<a href="https://www.tmrjournals.com/public/articlePDF/' . $val['file_pdf'] . '">Download pdf</a><br><br><br>';
}
$tt2 = 'Email: ' . $journal_info['email'] . '<br>';
$tt2 .= 'Website: https://www.tmrjournals.com/' . $journal_info['usx'] . '<br><br>';
$tt2 .= 'TMR Publishing Group Ltd.<br>';
$tt2 .= 'Auckland, New Zealand<br>';
$tt2 .= 'Tel: +64 02108293806.';
$tt2 .= '</div>
</div>';
foreach ($list as $v) {
$cache = $tt1 . '<a href="http://journalapi.tmrjournals.com/public/index.php/api/Journal/UnsubscribeJournal/snum/' . $v['subscribe_journal_id'] . '">Unsubscribe</a><br><br>' . $tt2;
$maidata['email'] = $v['email'];
$maidata['title'] = $journal_info['title'];
$maidata['content'] = $cache;
$maidata['tmail'] = 'publicrelations@tmrjournals.com';
$maidata['tpassword'] = 'pRWU999999';
// sendEmail($maidata['email'],$maidata['title'],$maidata['title'],$maidata['content'],$maidata['tmail'],$maidata['tpassword']);
Queue::push('app\api\job\mail@fire', $maidata, "mail");
echo $v['email'];
}
}
private function getAuthor($article)
{
$where['article_id'] = $article['article_id'];
$where['state'] = 0;
$list = $this->article_author_obj->where($where)->select();
$frag = '';
foreach ($list as $k => $v) {
$frag = $frag == '' ? '' . $v['author_name'] : $frag . ', ' . $v['author_name'];
}
return $frag;
}
// 出刊给作者发送邮件
private function sendAuthor($journal_stage_id, $journal_id)
{
$stage_info = $this->journal_stage_obj->where('journal_stage_id', $journal_stage_id)->find();
$journal_info = $this->journal_obj->where('journal_id', $journal_id)->find();
// 根据journal_stage_id 去article 中 找article_id
$articles = $this->article_obj->where('journal_stage_id', $journal_stage_id)->where('state', 0)->select();
foreach ($articles as $v) {
// 根据article_id 去article_author 中author
$datas = $this->article_author_obj->where(['article_id' => $v['article_id'], 'email' => array('neq', '')])->select();
foreach ($datas as $data) {
// 邮件内容
$content = '<div style="background-color: #ededed;margin: 0;">
<div class="con_content" style="font-family: Arial;
width: 600px;
margin: 0 auto;
background-color: #fff;
padding: 30px 40px;
color: #1B3051;
font-size: 14px;
line-height: 20px;">
<div>
<img style="width: 80px;" src="" alt="">
</div>
<br><br>';
$content .= 'Dear Author,<br><br>Congratulations<br><br>';
$content .= 'Thank you for choosing to publish with ' . $journal_info['title'] . '.<br>';
$content .= 'Your article has been published on Vol. ' . $stage_info['stage_vol'] . ' Issue ' . $stage_info['stage_no'] . '.<br><br>';
$content .= $v['type'] . '<br>';
$content .= '<a href="https://www.tmrjournals.com/article.html?J_num=' . $journal_info['journal_id'] . '&a_id=' . $v['article_id'] . '">' . $v['title'] . '</a><br>';
$content .= $this->getAuthor($v) . '<br>';
$content .= $journal_info['title'] . ' ' . $stage_info['stage_year'] . ' ' . $stage_info['stage_vol'] . "(" . $stage_info['stage_no'] . "). DOI:" . $v['doi'] . '<br>';
$content .= '<a href="https://www.tmrjournals.com/public/articlePDF/' . $v['file_pdf'] . '">Download pdf</a><br><br><br>';
$content .= 'If you want to be sure your research gets the attention it deserves, the following channels may be useful.<br><br>';
$content .= 'https://www.researchgate.net<br> https://www.academia.edu <br> https://twitter.com <br> https://www.linkedin.com <br> https://www.facebook.com <br><br>We look forward to receiving manuscripts from you in future.';
$content .= '</div></div>';
$maidata = [
'email' => $data['email'],
'title' => 'Congratulations on your published article',
'content' => $content,
'tmail' => 'publicrelations@tmrjournals.com',
'tpassword' => 'pRWU999999'
];
Queue::push('app\api\job\mail@fire', $maidata, "mail");
}
}
}
/**
* @title 增加期刊消息
* @description 增加期刊消息
* @author wangjinlei
* @url /master/Journal/addNotices
* @method POST
*
* @param name:journal_id type:int require:1 desc:期刊id
* @param name:title type:string require:1 desc:消息标题
* @param name:content type:string require:1 desc:内容
* @param name:ctime type:string require:1 desc:时间
*
*/
public function addNotices()
{
$data = $this->request->post();
$insert['journal_id'] = $data['journal_id'];
$insert['title'] = $data['title'];
$insert['content'] = $data['content'];
$insert['ctime'] = $data['ctime'] == '' ? time() : strtotime($data['ctime']);
$res = $this->journal_notices_obj->insert($insert);
if ($res) {
return json(['code' => 0, 'msg' => 'success']);
} else {
return json(['code' => 1, 'msg' => 'system error']);
}
}
/**
* @title 删除期刊消息
* @description 删除期刊消息
* @author wangjinlei
* @url /master/Journal/delNotices
* @method POST
*
* @param name:journal_notices_id type:int require:1 desc:期刊id
*/
public function delNotices()
{
$data = $this->request->post();
$this->journal_notices_obj->where('journal_notices_id', $data['journal_notices_id'])->update(['state' => 1]);
return json(['code' => 0, 'msg' => 'success']);
}
/**
* @title 更改期刊消息
* @description 更改期刊消息
* @author wangjinlei
* @url /master/Journal/changeNotices
* @method POST
*
* @param name:journal_notices_id type:int require:1 desc:期刊消息id
* @param name:title type:string require:1 desc:消息标题
* @param name:content type:string require:1 desc:内容
* @param name:ctime type:string require:1 desc:时间
*/
public function changeNotices()
{
$data = $this->request->post();
$update['title'] = $data['title'];
$update['content'] = $data['content'];
$update['ctime'] = strtotime($data['ctime']);
$this->journal_notices_obj->where('journal_notices_id', $data['journal_notices_id'])->update($update);
return json(['code' => 0, 'msg' => 'success']);
}
/**
* @title 获取期刊消息
* @description 获取期刊消息
* @author wangjinlei
* @url /master/Journal/getNotices
* @method POST
*
* @param name:journal_id type:int require:1 desc:期刊id
*
* @return notices:消息list
* @return journal_info:期刊消息
*/
public function getNotices()
{
$data = $this->request->post();
$journal_info = $this->journal_obj->where('journal_id', $data['journal_id'])->find();
$list = $this->journal_notices_obj->where('journal_id', $data['journal_id'])->where('state', 0)->select();
return jsonSuccess(['journal_info' => $journal_info, 'notices' => $list]);
}
/**
* @title 增加期刊收刊文章
* @description 增加期刊收刊文章
* @author wangjinlei
* @url /master/Journal/addJournalCfp
* @method POST
*
* @param name:journal_id type:int require:1 desc:期刊id
* @param name:title type:string require:1 desc:标题
* @param name:icon type:string require:1 desc:图标
* @param name:sort type:int require:1 desc:权重
* @param name:showtime type:string require:1 desc:显示时间
* @param name:content type:string require:1 desc:内容
*
* @return notices:消息list
* @return journal_info:期刊消息
*/
public function addJournalCfp()
{
$data = $this->request->post();
$insert['journal_id'] = $data['journal_id'];
$insert['title'] = trim($data['title']);
$insert['icon'] = $data['icon'];
$insert['sort'] = isset($data['sort']) ? $data['sort'] : 0;
$insert['showtime'] = $data['showtime'];
$insert['content'] = $data['content'];
$insert['ctime'] = time();
$this->journal_cfp_obj->insert($insert);
return jsonSuccess([]);
}
/**
* @title 删除期刊收刊文章
* @description 删除期刊收刊文章
* @author wangjinlei
* @url /master/Journal/delJournalCfp
* @method POST
*
* @param name:journal_cfp_id type:int require:1 desc:期刊收刊id
*
*/
public function delJournalCfp()
{
$data = $this->request->post();
$this->journal_cfp_obj->where('journal_cfp_id', $data['journal_cfp_id'])->update(['state' => 1]);
return jsonSuccess([]);
}
/**
* @title 编辑期刊收刊信息
* @description 编辑期刊收刊信息
* @author wangjinlei
* @url /master/Journal/editJournalCfp
* @method POST
*
* @param name:journal_cfp_id type:int require:1 desc:期刊收刊id
* @param name:title type:string require:1 desc:标题
* @param name:icon type:string require:1 desc:图标
* @param name:sort type:int require:1 desc:权重
* @param name:showtime type:string require:1 desc:显示时间
* @param name:content type:string require:1 desc:内容
*/
public function editJournalCfp()
{
$data = $this->request->post();
$update['title'] = $data['title'];
$update['icon'] = $data['icon'];
$update['sort'] = $data['sort'];
$update['showtime'] = $data['showtime'];
$update['content'] = $data['content'];
$this->journal_cfp_obj->where('journal_cfp_id', $data['journal_cfp_id'])->update($update);
return jsonSuccess([]);
}
/**
* @title 获取期刊收刊列表
* @description 获取期刊收刊列表
* @author wangjinlei
* @url /master/Journal/getJournalCfps
* @method POST
*
* @param name:journal_id type:int require:1 desc:期刊id
*
* @return journal:期刊信息#
* @return cfps:收刊列表#
*/
public function getJournalCfps()
{
$data = $this->request->post();
$journal_info = $this->journal_obj->where('journal_id', $data['journal_id'])->find();
$list = $this->journal_cfp_obj->where('journal_id', $data['journal_id'])->where('state', 0)->order('sort desc ,journal_cfp_id asc')->select();
$re['cfps'] = $list;
$re['journal'] = $journal_info;
return jsonSuccess($re);
}
/**
* @title cfp图片上传
* @description cfp图片上传
* @author wangjinlei
* @url /master/Journal/up_cfp_file
* @method POST
*
* @param name:name type:string require:1 default:journalCfp desc:文件域名称
*
* @return upurl:图片地址
*/
public function up_cfp_file()
{
$file = request()->file('journalCfp');
if ($file) {
$info = $file->move(ROOT_PATH . 'public' . DS . 'journalCfp');
if ($info) {
return json(['code' => 0, 'msg' => 'success', 'upurl' => str_replace("\\", "/", $info->getSaveName())]);
} else {
return json(['code' => 1, 'msg' => $file->getError()]);
}
}
}
/**
* @title 添加期刊paper
* @description 添加期刊paper
* @author wangjinlei
* @url /master/Journal/addJournalPaper
* @method POST
*
* @param name:journal_id type:int require:1 desc:期刊id
* @param name:title type:string require:1 desc:标题
*
*/
public function addJournalPaper()
{
$data = $this->request->post();
$insert['journal_id'] = $data['journal_id'];
$insert['title'] = $data['title'];
$this->journal_paper_obj->insert($insert);
return jsonSuccess([]);
}
/**
* @title 删除期刊paper
* @description 删除期刊paper
* @author wangjinlei
* @url /master/Journal/delJournalPaper
* @method POST
*
* @param name:journal_paper_id type:int require:1 desc:期刊paperid
*
*/
public function delJournalPaper()
{
$data = $this->request->post();
$this->journal_paper_obj->where('journal_paper_id', $data['journal_paper_id'])->update(['state' => 1]);
return jsonSuccess([]);
}
/**
* @title 编辑期刊paper
* @description 编辑期刊paper
* @author wangjinlei
* @url /master/Journal/editJournalPaper
* @method POST
*
* @param name:journal_paper_id type:int require:1 desc:期刊paperid
* @param name:title type:string require:1 desc:标题
*
*/
public function editJournalPaper()
{
$data = $this->request->post();
$this->journal_paper_obj->where('journal_paper_id', $data['journal_paper_id'])->update(['title' => $data['title']]);
return jsonSuccess([]);
}
/**
* @title 获取期刊缩略图
* @description 获取期刊缩略图
* @author wangjinlei
* @url /master/Journal/getJournalIcon
* @method POST
*
* @param name:issn type:int require:1 desc:issn号
*
* @return icon:图片地址#
*/
public function getJournalIcon()
{
$data = $this->request->post();
$journal_info = $this->journal_obj->where('issn', $data['issn'])->find();
$re['icon'] = $journal_info['licon'];
return jsonSuccess($re);
}
/**
* @title 通用话题--获取通用话题列表
* @description 通用话题--获取通用话题列表
* @author wangjinlei
* @url /master/Journal/getBaseTopicList
* @method POST
*
* @return topics:通用话题#
*/
public function getBaseTopicList()
{
$father = $this->base_topic_obj->where('parent_id', 0)->where('state', 0)->order('sort desc')->select();
foreach ($father as $k => $v) {
$cache = $this->base_topic_obj->where('parent_id', $v['base_topic_id'])->where('state', 0)->order('sort desc')->select();
$father[$k]['children'] = $cache;
}
$re['topics'] = $father;
return jsonSuccess($re);
}
/**
* @title 通用话题--增加通用话题
* @description 通用话题--增加通用话题
* @author wangjinlei
* @url /master/Journal/addBaseTopic
* @method POST
*
* @param name:title type:string require:1 desc:话题名称标题
* @param name:parent_id type:int require:1 desc:父级话题id
* @param name:sort type:int require:1 desc:权重值
* @param name:icon type:string require:1 desc:图标
*
*/
public function addBaseTopic()
{
$data = $this->request->post();
$check = $this->base_topic_obj->where('title', $data['title'])->where('state', 0)->find();
if ($check != null) {
return jsonError('此话题已存在,话题名不能重复!!');
}
$insert['title'] = trim($data['title']);
$insert['parent_id'] = $data['parent_id'];
$insert['sort'] = $data['sort'];
$insert['icon'] = $data['icon'];
$this->base_topic_obj->insert($insert);
return jsonSuccess([]);
}
/**
* @title 通用话题--编辑通用话题
* @description 通用话题--编辑通用话题
* @author wangjinlei
* @url /master/Journal/editBaseTopic
* @method POST
*
* @param name:base_topic_id type:int require:1 desc:通用话题id
* @param name:title type:string require:1 desc:话题名称标题
* @param name:sort type:int require:1 desc:权重值
*/
public function editBaseTopic()
{
$data = $this->request->post();
$update['title'] = trim($data['title']);
$update['sort'] = $data['sort'];
if (isset($data['icon'])) {
$update['icon'] = $data['icon'];
}
$this->base_topic_obj->where('base_topic_id', $data['base_topic_id'])->update($update);
return jsonSuccess([]);
}
/**
* @title 通用话题--删除通用话题
* @description 通用话题--删除通用话题
* @author wangjinlei
* @url /master/Journal/delBaseTopic
* @method POST
*
* @param name:base_topic_id type:int require:1 desc:通用话题id
*/
public function delBaseTopic()
{
$data = $this->request->post();
$this->base_topic_obj->where('base_topic_id', $data['base_topic_id'])->update(['state' => 1]);
return jsonSuccess([]);
}
/**
* @title 通用话题--图片上传
* @description 通用话题--图片上传
* @author wangjinlei
* @url /master/Journal/baseTopic_up_file
* @method POST
*
* @param name:name type:string require:1 default:baseTopic desc:文件域名称
*
* @return upurl:图片地址
*/
public function baseTopic_up_file()
{
$file = request()->file('baseTopic');
if ($file) {
$info = $file->move(ROOT_PATH . 'public' . DS . 'baseTopic');
if ($info) {
return json(['code' => 0, 'msg' => 'success', 'upurl' => str_replace("\\", "/", $info->getSaveName())]);
} else {
return json(['code' => 1, 'msg' => $file->getError()]);
}
}
}
/**
* @title 增加期刊paper文章
* @description 增加期刊paper文章
* @author wangjinlei
* @url /master/Journal/addJournalPaperArt
* @method POST
*
* @param name:journal_paper_id type:int require:1 desc:期刊paperid
* @param name:journal_id type:int require:1 desc:期刊id
* @param name:title type:string require:1 desc:标题
* @param name:sort type:int require:1 desc:权重
* @param name:content type:string require:1 desc:内容
*
*/
public function addJournalPaperArt()
{
$data = $this->request->post();
$insert['journal_paper_id'] = $data['journal_paper_id'];
$insert['journal_id'] = $data['journal_id'];
$insert['title'] = $data['title'];
$insert['content'] = $data['content'];
$insert['sort'] = $data['sort'];
$insert['ctime'] = time();
$this->journal_paper_art_obj->insert($insert);
return jsonSuccess([]);
}
/**
* @title 删除期刊paper文章
* @description 删除期刊paper文章
* @author wangjinlei
* @url /master/Journal/delJournalPaperArt
* @method POST
*
* @param name:journal_paper_art_id type:int require:1 desc:期刊paperid
*
*/
public function delJournalPaperArt()
{
$data = $this->request->post();
$this->journal_paper_art_obj->where('journal_paper_art_id', $data['journal_paper_art_id'])->update(['state' => 1]);
return jsonSuccess([]);
}
/**
* @title 编辑期刊paper文章
* @description 编辑期刊paper文章
* @author wangjinlei
* @url /master/Journal/editJournalPaperArt
* @method POST
*
* @param name:journal_paper_art_id type:int require:1 desc:期刊paper文章id
* @param name:title type:string require:1 desc:标题
* @param name:content type:string require:1 desc:内容
* @param name:sort type:int require:1 desc:权重
*
*/
public function editJournalPaperArt()
{
$data = $this->request->post();
$update['title'] = $data['title'];
$update['content'] = $data['content'];
$update['sort'] = $data['sort'];
$this->journal_paper_art_obj->where('journal_paper_art_id', $data['journal_paper_art_id'])->update($update);
return jsonSuccess([]);
}
/**
* @title 增加期刊line
* @description 增加期刊line
* @author wangjinlei
* @url /master/Journal/addJournalLine
* @method POST
*
* @param name:journal_id type:int require:1 desc:期刊id
* @param name:title type:string require:1 desc:标题
* @param name:time type:string require:1 desc:时间
* @param name:img type:string require:1 desc:图片
* @param name:intro type:string require:1 desc:简介
* @param name:dist type:int require:1 desc:距离
*/
public function addJournalLine()
{
$data = $this->request->post();
$insert['journal_id'] = $data['journal_id'];
$insert['title'] = $data['title'];
$insert['time'] = $data['time'];
$insert['img'] = $data['img'];
$insert['intro'] = $data['intro'];
$insert['dist'] = $data['dist'];
$this->journal_line_obj->insert($insert);
return jsonSuccess([]);
}
/**
* @title 删除期刊line
* @description 删除期刊line
* @author wangjinlei
* @url /master/Journal/delJournalLine
* @method POST
*
* @param name:journal_line_id type:int require:1 desc:期刊时间轴id
*/
public function delJournalLine()
{
$data = $this->request->post();
$this->journal_line_obj->where('journal_line_id', $data['journal_line_id'])->update(['state' => 1]);
return jsonSuccess([]);
}
/**
* @title 编辑期刊line
* @description 编辑期刊line
* @author wangjinlei
* @url /master/Journal/editJournalLine
* @method POST
*
* @param name:journal_line_id type:int require:1 desc:期刊时间轴id
* @param name:title type:string require:1 desc:标题
* @param name:time type:string require:1 desc:时间
* @param name:img type:string require:1 desc:图片地址
* @param name:intro type:string require:1 desc:简介
* @param name:dist type:int require:1 desc:距离
*/
public function editJournalLine()
{
$data = $this->request->post();
$update['title'] = $data['title'];
$update['time'] = $data['time'];
$update['img'] = $data['img'];
$update['intro'] = $data['intro'];
$update['dist'] = $data['dist'];
$this->journal_line_obj->where('journal_line_id', $data['journal_line_id'])->update($update);
return jsonSuccess([]);
}
/**
* @title 获取期刊lines
* @description 获取期刊lines
* @author wangjinlei
* @url /master/Journal/getJournalLines
* @method POST
*
* @param name:journal_id type:int require:1 desc:期刊id
*
* @return journal:期刊信息#
* @return lines:array#
*/
public function getJournalLines()
{
$data = $this->request->post();
$journal_info = $this->journal_obj->where('journal_id', $data['journal_id'])->find();
$list = $this->journal_line_obj->where('journal_id', $data['journal_id'])->where('state', 0)->order('journal_line_id')->select();
$re['journal'] = $journal_info;
$re['lines'] = $list;
return jsonSuccess($re);
}
/**
* @title 增加期刊关联期刊
* @description 增加期刊关联期刊
* @author wangjinlei
* @url /master/Journal/addJournalralet
* @method POST
*
* @param name:journal_id type:int require:1 desc:期刊id
* @param name:relat_id type:int require:1 desc:关联期刊id
*/
public function addJournalralet()
{
$data = $this->request->post();
$journal_info = $this->journal_obj->where('journal_id', $data['journal_id'])->find();
$rearr = $journal_info['relate'] == '' ? [] : explode(',', $journal_info['relate']);
if (count($rearr) > 5) {
return jsonError('No more than four');
}
$rearr[] = $data['relat_id'];
$this->journal_obj->where('journal_id', $data['journal_id'])->update(['relate' => implode(',', $rearr)]);
return jsonSuccess([]);
}
/**
* @title 删除期刊关联期刊
* @description 删除期刊关联期刊
* @author wangjinlei
* @url /master/Journal/delJournalralet
* @method POST
*
* @param name:journal_id type:int require:1 desc:期刊id
* @param name:relat_id type:int require:1 desc:关联期刊id
*/
public function delJournalralet()
{
$data = $this->request->post();
$journal_info = $this->journal_obj->where('journal_id', $data['journal_id'])->find();
$rearr = $journal_info['relate'] == '' ? [] : explode(',', $journal_info['relate']);
foreach ($rearr as $k => $v) {
if ($v == $data['relat_id']) {
unset($rearr[$k]);
}
}
$this->journal_obj->where('journal_id', $data['journal_id'])->update(['relate' => implode(',', $rearr)]);
return jsonSuccess([]);
}
/**
* @title 获取期刊关联期刊
* @description 获取期刊关联期刊
* @author wangjinlei
* @url /master/Journal/getJournalralet
* @method POST
*
* @param name:journal_id type:int require:1 desc:期刊id
*
* @return journal:当前期刊#
* @return journals:期刊array#
*/
public function getJournalralet()
{
$data = $this->request->post();
$journal_info = $this->journal_obj->where('journal_id', $data['journal_id'])->find();
$rearr = $journal_info['relate'] == '' ? [] : explode(',', $journal_info['relate']);
$list = $this->journal_obj->where('journal_id', 'in', $rearr)->where('state', 0)->select();
$re['journal'] = $journal_info;
$re['journals'] = $list;
return jsonSuccess($re);
}
/**
* @title 增加期刊line文章
* @description 增加期刊line文章
* @author wangjinlei
* @url /master/Journal/addJournalLineArt
* @method POST
*
* @param name:journal_line_id type:int require:1 desc:期刊id
* @param name:article_id type:int require:1 desc:文章id
*
*/
public function addJournalLineArt()
{
$data = $this->request->post();
$insert['journal_line_id'] = $data['journal_line_id'];
$insert['article_id'] = $data['article_id'];
$this->article_to_line_obj->insert($insert);
return jsonSuccess([]);
}
/**
* @title 删除期刊line文章
* @description 删除期刊line文章
* @author wangjinlei
* @url /master/Journal/delJournalLineArt
* @method POST
*
* @param name:article_to_line_id type:int require:1 desc:期刊id
*
*/
public function delJournalLineArt()
{
$data = $this->request->post();
$this->article_to_line_obj->where('article_to_line_id', $data['article_to_line_id'])->update(['state' => 1]);
return jsonSuccess([]);
}
/**
* @title 获取期刊line文章
* @description 获取期刊line文章
* @author wangjinlei
* @url /master/Journal/getJournalLineArt
* @method POST
*
* @param name:journal_line_id type:int require:1 desc:期刊lineid
*
* @return journalLine:期刊line#
* @return journal:期刊信息#
* @return articles: 文章列表array#
*
*/
public function getJournalLineArt()
{
$data = $this->request->post();
$journal_line_info = $this->journal_line_obj->where('journal_line_id', $data['journal_line_id'])->find();
$journal_info = $this->journal_obj->where('journal_id', $journal_line_info['journal_id'])->find();
$list = $this->article_to_line_obj->field('j_article_to_line.*,j_article.*')
->join('j_article', 'j_article.article_id = j_article_to_line.article_id', 'LEFT')
->where('j_article_to_line.journal_line_id', $data['journal_line_id'])
->where('j_article_to_line.state', 0)
->select();
$re['journalLine'] = $journal_line_info;
$re['journal'] = $journal_info;
$re['articles'] = $list;
return jsonSuccess($re);
}
/**
* @title 获取文章排除line
* @description 获取文章排除line
* @author wangjinlei
* @url /master/Journal/getArticleByLine
* @method POST
*
* @param name:journal_id type:int require:1 desc:期刊id
* @param name:journal_line_id type:int require:1 desc:时间线id
* @param name:title type:string require:1 desc:标题
* @param name:pageIndex type:int require:1 desc:当前页码数
* @param name:pageSize type:int require:1 desc:单页数据条数
*
* $return count:总数
* @return dataList:array#
*/
public function getArticleByLine()
{
$data = $this->request->post();
//排除line
$ids = $this->article_to_line_obj->where('journal_line_id', $data['journal_line_id'])->where('state', 0)->column('article_id');
$limit_start = ($data['pageIndex'] - 1) * $data['pageSize'];
$list = $this->article_obj->where('journal_id', $data['journal_id'])->where('state', 0)->where('article_id', 'not in', $ids)->where('title', 'like', '%' . $data['title'] . '%')->limit($limit_start, $data['pageSize'])->select();
$count = $this->article_obj->where('journal_id', $data['journal_id'])->where('state', 0)->where('article_id', 'not in', $ids)->where('title', 'like', '%' . $data['title'] . '%')->count();
$re['count'] = $count;
$re['dataList'] = $list;
return jsonSuccess($re);
}
/**
* @title 获取期刊paper
* @description 获取期刊paper
* @author wangjinlei
* @url /master/Journal/getJournalPapers
* @method POST
*
* @param name:journal_id type:int require:1 desc:期刊paperid
*
* @return paperLists:paperlist#
*
*/
public function getJournalPapers()
{
$data = $this->request->post();
$journal_info = $this->journal_obj->where('journal_id', $data['journal_id'])->find();
$journalPapers = $this->journal_paper_obj->where('journal_id', $data['journal_id'])->where('state', 0)->select();
$re['journalInfo'] = $journal_info;
$re['paperLists'] = $journalPapers;
return jsonSuccess($re);
}
/**
* @title 获取期刊paper文章列表
* @description 获取期刊paper文章列表
* @author wangjinlei
* @url /master/Journal/getJournalPaperArt
* @method POST
*
* @param name:journal_paper_id type:int require:1 desc:期刊paperid
*
* @return paperinfo:array#
* @return articleLists:paperlist#
*
*/
public function getJournalPaperArt()
{
$data = $this->request->post();
$paper_info = $this->journal_paper_obj->where('journal_paper_id', $data['journal_paper_id'])->find();
$list = $this->journal_paper_art_obj->where('journal_paper_id', $data['journal_paper_id'])->where('state', 0)->order('sort')->select();
$re['paperinfo'] = $paper_info;
$re['articleLists'] = $list;
return jsonSuccess($re);
}
/**
* @title 期刊分期--封面图片上传
* @description 期刊分期--封面图片上传
* @author wangjinlei
* @url /master/Journal/up_stage_icon
* @method POST
*
* @param name:stage_icon type:string require:1 desc:封面图片
*
* @return url:图片地址
*/
public function upStageIcon()
{
$file = request()->file('stage_icon');
if ($file) {
$info = $file->move(ROOT_PATH . 'public' . DS . 'journalstage');
if ($info) {
return json(['code' => 0, 'msg' => 'success', 'url' => str_replace("\\", "/", 'journalstage/' . $info->getSaveName())]);
} else {
return json(['code' => 1, 'msg' => $file->getError()]);
}
}
}
}