AdminpostController.php 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | ThinkCMF [ WE CAN DO IT MORE SIMPLE ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2013-2014 http://www.thinkcmf.com All rights reserved.
  6. // +----------------------------------------------------------------------
  7. // | Author: Tuolaji <479923197@qq.com>
  8. // +----------------------------------------------------------------------
  9. namespace app\admin\controller;
  10. use cmf\controller\AdminBaseController;
  11. use think\facade\Db;
  12. use think\db\Query;
  13. class AdminpostController extends AdminBaseController{
  14. protected function initialize()
  15. {
  16. parent::initialize();
  17. $adminId = cmf_get_current_admin_id(); //获取后台管理员id,可判断是否登录
  18. if (!empty($adminId)) {
  19. $this->assign('admin_id', $adminId);
  20. }
  21. }
  22. // 后台文章列表
  23. public function index(){
  24. //文章分类
  25. $terms_list=Db::name('terms')
  26. ->order("listorder ASC,id DESC")
  27. ->select();
  28. $this->assign('terms_list', $terms_list);
  29. //文章
  30. $posts=Db::name('posts')
  31. ->where(function (Query $query) {
  32. $data = $this->request->param();
  33. $query->where('post_type', 0);
  34. if (isset($data['id']) && $data['id']!='') {
  35. $query->where('id', $data['id']);
  36. }
  37. if (isset($data['termid']) && $data['termid']!='') {
  38. $query->where('termid', $data['termid']);
  39. }
  40. if (isset($data['keyword']) && !empty($data['keyword'])) {
  41. $keyword = $data['keyword'];
  42. $query->where('post_title|post_keywords', 'like', "%$keyword%");
  43. }
  44. })
  45. ->order("orderno DESC")
  46. ->paginate(20);
  47. $posts->each(function($v,$k){
  48. $userinfo=Db::name("user")
  49. ->field("user_nickname")
  50. ->where("id={$v['post_author']}")
  51. ->find();
  52. if(!$userinfo){
  53. $userinfo=array(
  54. 'user_nickname'=>'已删除',
  55. );
  56. }
  57. $v['userinfo']= $userinfo;
  58. $termsinfo=Db::name("terms")
  59. ->field("name")
  60. ->where("id='$v[termid]'")
  61. ->find();
  62. if(!$termsinfo){
  63. $termsinfo=array(
  64. 'name'=>'已删除'
  65. );
  66. }
  67. $v['termsinfo']= $termsinfo;
  68. return $v;
  69. });
  70. //分页-->筛选条件参数
  71. $data = $this->request->param();
  72. $posts->appends($data);
  73. // 获取分页显示
  74. $page = $posts->render();
  75. $this->assign('posts', $posts);
  76. $this->assign('page', $page);
  77. $configpub=getConfigPub();
  78. $this->assign("site",$configpub['site']);
  79. return $this->fetch();
  80. }
  81. //文章添加
  82. public function add(){
  83. //文章分类
  84. $terms_list=Db::name('terms')
  85. ->order("listorder ASC,id DESC")
  86. ->select();
  87. $this->assign('terms_list', $terms_list);
  88. return $this->fetch();
  89. }
  90. public function add_post(){
  91. $data = input('post.post');
  92. if(empty($data['termid'])){
  93. $this->error("请至少选择一个分类!");
  94. }else if(empty($data['post_title'])){
  95. $this->error('请输入标题!');
  96. }
  97. $data['post_content']=html_entity_decode($data['post_content']);
  98. $data['post_author']=cmf_get_current_admin_id(); //获取后台管理员id
  99. $path='';
  100. if($data['termid']!=0){
  101. $info=Db::name('terms')->where('id',$data['termid'])->value('path');
  102. $path=$info;
  103. }
  104. $data['path']=$path;
  105. $data['post_status']='1';
  106. $data['post_date']=time();
  107. $add=Db::name('posts')->insert($data);
  108. if($add){
  109. $this->success('添加成功!');
  110. }else{
  111. $this->error('添加失败!');
  112. }
  113. }
  114. //文章分类编辑
  115. public function edit(){
  116. $id = input('param.id');
  117. if($id){
  118. //文章分类
  119. $terms_list=Db::name('terms')
  120. ->order("listorder ASC,id DESC")
  121. ->select();
  122. $this->assign('terms_list', $terms_list);
  123. $info=Db::name('posts')->where('id',$id)->find();
  124. $info['post_content']=str_replace('../../','/upload/',$info['post_content']);
  125. $this->assign('info',$info);
  126. }else{
  127. $this->error('数据传入失败!');
  128. }
  129. return $this->fetch();
  130. }
  131. public function edit_post(){
  132. $data = input('post.post');
  133. $data['post_content']=html_entity_decode($data['post_content']);
  134. if(empty($data['termid'])){
  135. $this->error("请至少选择一个分类!");
  136. }else if(empty($data['post_title'])){
  137. $this->error('请输入标题!');
  138. }
  139. $path='';
  140. if($data['termid']!=0){
  141. $info=Db::name('terms')->where('id',$data['termid'])->value('path');
  142. $path=$info;
  143. }
  144. $data['path']=$path;
  145. $save=Db::name('posts')->where('id',$data['id'])->update($data);
  146. if($save!==false){
  147. $this->success('保存成功!');
  148. }else{
  149. $this->error('保存失败!');
  150. }
  151. }
  152. // 文章分类删除
  153. public function del(){
  154. $id = input('param.id');
  155. if($id){
  156. $result=Db::name('posts')->delete($id);
  157. if($result){
  158. $this->success('删除成功');
  159. }else{
  160. $this->error('删除失败');
  161. }
  162. }else{
  163. $this->error('数据传入失败!');
  164. }
  165. }
  166. // 文章批量审核或取消审核
  167. public function check(){
  168. $data = input();
  169. foreach ($data['ids'] as $k => $r) {
  170. $save=array();
  171. $save['post_status'] = $data['check'];
  172. Db::name('posts')->where(['id'=>$r])->update($save);
  173. }
  174. $status = true;
  175. if ($status) {
  176. $this->success("操作成功!");
  177. } else {
  178. $this->error("操作失败!");
  179. }
  180. }
  181. // 文章批量置顶或取消置顶
  182. public function tops(){
  183. $data = input();
  184. foreach ($data['ids'] as $k => $r) {
  185. $save=array();
  186. $save['istop'] = $data['top'];
  187. Db::name('posts')->where(['id'=>$r])->update($save);
  188. }
  189. $status = true;
  190. if ($status) {
  191. $this->success("操作成功!");
  192. } else {
  193. $this->error("操作失败!");
  194. }
  195. }
  196. // 文章批量删除
  197. public function deletes(){
  198. $data = input();
  199. foreach ($data['ids'] as $k => $r) {
  200. Db::name('posts')->where(['id'=>$r])->delete();
  201. }
  202. $status = true;
  203. if ($status) {
  204. $this->success("操作成功!");
  205. } else {
  206. $this->error("操作失败!");
  207. }
  208. }
  209. // 文章排序
  210. public function listordersset() {
  211. $ids=$this->request->param('listordersset');
  212. foreach ($ids as $key => $r) {
  213. $data['orderno'] = $r;
  214. Db::name("posts")
  215. ->where(array('id' => $key))
  216. ->update($data);
  217. }
  218. $status = true;
  219. if ($status) {
  220. $this->success("排序更新成功!");
  221. } else {
  222. $this->error("排序更新失败!");
  223. }
  224. }
  225. }