Column.php 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | 海豚PHP框架 [ DolphinPHP ]
  4. // +----------------------------------------------------------------------
  5. // | 版权所有 2016~2017 河源市卓锐科技有限公司 [ http://www.zrthink.com ]
  6. // +----------------------------------------------------------------------
  7. // | 官方网站: http://dolphinphp.com
  8. // +----------------------------------------------------------------------
  9. // | 开源协议 ( http://www.apache.org/licenses/LICENSE-2.0 )
  10. // +----------------------------------------------------------------------
  11. namespace app\cms\home;
  12. use app\cms\model\Column as ColumnModel;
  13. use think\Db;
  14. use util\Tree;
  15. /**
  16. * 前台栏目文档列表控制器
  17. * @package app\cms\admin
  18. */
  19. class Column extends Common
  20. {
  21. /**
  22. * 栏目文章列表
  23. * @param null $id 栏目id
  24. * @author 蔡伟明 <314013107@qq.com>
  25. * @return mixed
  26. */
  27. public function index($id = null)
  28. {
  29. if ($id === null) $this->error('缺少参数');
  30. $map = [
  31. 'status' => 1,
  32. 'id' => $id
  33. ];
  34. $column = Db::name('cms_column')->where($map)->find();
  35. if (!$column) $this->error('该栏目不存在');
  36. $model = Db::name('cms_model')->where('id', $column['model'])->find();
  37. if ($model['type'] == 2) {
  38. $cid_all = ColumnModel::getChildsId($id);
  39. $cid_all[] = (int)$id;
  40. $map = [
  41. $model['table'].'.trash' => 0,
  42. $model['table'].'.status' => 1,
  43. $model['table'].'.cid' => ['in', $cid_all]
  44. ];
  45. $data_list = Db::view($model['table'], true)
  46. ->view('admin_user', 'username', $model['table'].'.uid=admin_user.id', 'left')
  47. ->where($map)
  48. ->order('create_time desc')
  49. ->paginate(config('list_rows'));
  50. $this->assign('model', $column['model']);
  51. } else {
  52. $cid_all = ColumnModel::getChildsId($id);
  53. $cid_all[] = (int)$id;
  54. $map = [
  55. 'cms_document.trash' => 0,
  56. 'cms_document.status' => 1,
  57. 'cms_document.cid' => ['in', $cid_all]
  58. ];
  59. $data_list = Db::view('cms_document', true)
  60. ->view('admin_user', 'username', 'cms_document.uid=admin_user.id', 'left')
  61. ->view($model['table'], '*', 'cms_document.id='. $model['table'] . '.aid', 'left')
  62. ->where($map)
  63. ->order('create_time desc')
  64. ->paginate(config('list_rows'));
  65. $this->assign('model', '');
  66. }
  67. $this->assign('lists', $data_list);
  68. $this->assign('pages', $data_list->render());
  69. $this->assign('breadcrumb', $this->getBreadcrumb($id));
  70. $this->assign('column_info', $column);
  71. $template = $column['list_template'] == '' ? 'list' : substr($column['list_template'], 0, strpos($column['list_template'], '.'));
  72. return $this->fetch($template);
  73. }
  74. /**
  75. * 获取栏目面包屑导航
  76. * @param int $id
  77. * @author 蔡伟明 <314013107@qq.com>
  78. */
  79. public function getBreadcrumb($id)
  80. {
  81. $columns = ColumnModel::where('status', 1)->column('id,pid,name,url,target,type');
  82. foreach ($columns as &$column) {
  83. if ($column['type'] == 0) {
  84. $column['url'] = url('cms/column/index', ['id' => $column['id']]);
  85. }
  86. }
  87. return Tree::config(['title' => 'name'])->getParents($columns, $id);
  88. }
  89. }