| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402 | <?php/** * Created by PhpStorm. * User: 中闽 < 1464674022@qq.com > * Date: 2019/12/5 * Time: 17:44 */namespace app\admin\controller;use app\admin\controller\base\Permissions;use app\common\model\Article as articleModel;use app\common\model\ArticleCate as articleCateModel;use app\common\model\Catalog as cataLogModel;use app\common\model\Templet as templetModel;use app\common\service\CmsService;use file\PathHelper;use paginate\Bootstrap;use think\Db;class Catalog extends Permissions{    /**     * index2 使用新的树形表格组件     * @return array|mixed     */    public function index()    {        if ($this->request->isAjax()) {            $model = new cataLogModel();            $data = $model->order('pid,sort desc,id asc')->select();            foreach ($data as $k => $v) {                /**@var cataLogModel $v */                $v['type_text'] = $v->type_text;                $v['article_count'] = $v->article_count ?: '';                $v['tpath'] = $v->tpath();                $data[$k] = $v;            }            return array('code' => 0, 'count' => count($data), 'data' => $data, "tip" => "操作成功!");        } else {            return $this->fetch();        }    }    public function publish()    {        $id = $this->request->param('id', 0, 'intval');        $post = $this->request->post();        $model = new cataLogModel();        if ($this->request->isPost()) {            $validate = new \think\Validate([                ['title|栏目名称', 'require'],                ['catalog_templet|栏目模板', 'requireIf:type,0|requireIf:type,1'],                ['article_templet|文章模板', 'requireIf:type,1'],                ['path|栏目路径', 'requireIf:type,0|requireIf:type,1'],                ['article_rule|文章路径', 'requireIf:type,1'],                ['articlelist_rule|列表页路径', 'requireIf:type,1'],            ]);            if (!$validate->check($post)) {                $this->error('提交失败:' . $validate->getError());            }            $post['path'] = trim($post['path']);            $post['path'] = empty($post['path']) ? "" : appendStartDS(trim($post['path']), '/');            $post['catalog_templet'] = trim($post['catalog_templet']);            $post['article_templet'] = trim($post['article_templet']);            $post['article_rule'] = trim($post['article_rule']);            $post['articlelist_rule'] = trim($post['articlelist_rule']);            $post['articlelist_rows'] = empty($post['articlelist_rows']) ? 10 : $post['articlelist_rows'];        } else {            $pid = $this->request->param('pid', 0, 'intval');            $this->assign('pid', $pid);            $this->assign("templets", templetModel::getTemplets());            $this->assign('cates', $model->treelistForCatalog());            $this->assign('types', cataLogModel::TYPES);        }        if ($id > 0) {            //修改            $item = $model->where('id', $id)->find();            if (empty($item)) {                $this->error('id不存在');            }            if ($this->request->isPost()) {                if ($id == $post['pid']) {                    $this->error('上级节点不能选自己');                }                //更新tree_path                $post = $this->updatePath($post, $id);                if (false == $model->allowField(true)->save($post, ['id' => $id])) {                    $this->error('修改失败');                } else {                    $this->success('修改成功', 'index');                }            } else {                $this->assign('item', $item);                return $this->fetch();            }        } else {            //新增            if ($this->request->isPost()) {                $post['status'] = $model::STATUS_OPEN;                if (false == $model->allowField(true)->save($post)) {                    $this->error('添加失败');                } else {                    $cate = $model;                    //更新tree_path                    $post = $this->updatePath($post, $model->id);                    if (false == $cate->save(['tree_path' => $post['tree_path']])) {                        $this->error('更新tree_path失败');                    }                    $this->success('添加成功', 'index');                }            } else {                return $this->fetch();            }        }    }    /**     * 更新tree_path     * @param $post     * @param $id     * @return mixed     */    private function updatePath($post, $id)    {        if ($post['pid']) {            $pdoc = (new cataLogModel())->find($post['pid']);            if (!$pdoc) {                $this->error('该上级节点不存在,请重新选择');            }            $post['tree_path'] = $pdoc->tree_path . '-' . $id;        } else {            $post['tree_path'] = $id;        }        return $post;    }    /**     * 删除     */    public function delete()    {        if ($this->request->isAjax()) {            $id = $this->request->param('id', 0, 'intval');            $exits = cataLogModel::get(['pid' => $id]);            if ($exits) {                $this->error('请先删除子节点');            }            if (false == Db::name('catalog')->where('id', $id)->delete()) {                $this->error('删除失败');            } else {                $this->success('删除成功', 'index');            }        }    }    /**     * 审核     */    public function status()    {        if ($this->request->isPost()) {            $post = $this->request->post();            if (false == Db::name('catalog')->where('id', $post['id'])->update(['status' => $post['status']])) {                $this->error('设置失败');            } else {                $this->success('设置成功', 'index');            }        }    }    /**     * 排序     */    public function sort()    {        if ($this->request->isPost() && $this->request->has('ids')) {            $post = $this->request->post();            $i = 0;            foreach ($post['ids'] as $k => $id) {                $sort = Db::name('catalog')->where('id', $id)->value('sort');                $newsort = $post['sorts'][$k]??$sort;                if ($sort != $newsort) {                    if (false == Db::name('catalog')->where('id', $id)->update(['sort' => $newsort])) {                        $this->error('更新失败');                    } else {                        $i++;                    }                }            }            if (empty($i)) {                $this->error('没有更新排序', 'index');            }            $this->success('成功更新' . $i . '个排序', 'index');        } else {            $this->error('无数据更新', 'index');        }    }    /**     * 更新所有节点tree_path     * admin/catalog/updateTreePath     */    public function updateTreePath()    {        (new cataLogModel())->updateTreePath();        return $this->success();    }    //预览    public function perview()    {        $id = $this->request->param('id', 0, 'intval');        if ($id) {            /** @var cataLogModel $catalog */            $catalog = (new cataLogModel())->where('id', $id)->find();            try {                $cate = $catalog->getFirstArticleCate();            } catch (\Exception $e) {                $cate = null;            }            return (new CmsService())->perviewCatalog($catalog, $cate);        }        $this->error('预览失败:id is null');    }    /**     * @param $where array     * @param $catalog cataLogModel     * @param $tid int     * @param $cate articleCateModel     */    private function exportArticle($where, $catalog, $tid, $cate)    {        $replace = CmsService::getArticleReplace();        $service = new CmsService();        $articleModel = new articleModel();        $catalogPath = $catalog->getRealPath();        $total = $articleModel->where($where)->where($catalog->articlelist_where)->count();        $listRows = $catalog->articlelist_rows??10;//分页        $orderby = $catalog->articlelist_sort??'create_time desc';//排序        if ($total) {            $lastPage = (int)ceil($total / $listRows);            //分页            for ($page = 1; $page <= $lastPage; $page++) {                $articleCatePath = articleCateModel::getRulePath($catalogPath, $catalog->articlelist_rule, $catalog->id, $tid, $page);                $articleList = $articleModel->where($where)->where($catalog->articlelist_where)->page($page, $listRows)->order($orderby)->select();                $prefix = isset($replace['_ROOT_']) ? $replace['_ROOT_'] : '_ROOT_';                $paginate = new Bootstrap($articleList, $listRows, $page, $total, false, ["path" => $prefix . CmsService::getPaginatePath($catalog, $tid)]);                $service->info("       ├─ 列表页:" . $articleCatePath);                $content = $this->fetch($catalog->getCatalogTemplet()->getRealPath(), ['catalog' => $catalog, 'articleCate' => $cate, 'paginate' => $paginate], $replace);                $service->createFile($articleCatePath, $content);                foreach ($articleList as $article) {                    /**@var articleModel $article */                    $articlePath = $article->getRulePath($catalogPath, $catalog->article_rule);                    $content = $this->fetch($catalog->getArticleTemplet()->getRealPath(), ['catalog' => $catalog, 'article' => $article, 'articleCate' => $cate], $replace);                    $service->info("           ├─ 文章:" . $articlePath);                    $service->createFile($articlePath, $content);                }            }        }        $articleCatePath = articleCateModel::getRulePath($catalogPath, $catalog->articlelist_rule, $catalog->id, $tid);        $content = file_exists($articleCatePath) ? $this->fetch($articleCatePath, [], $replace) : CmsService::errorHtml($articleCatePath);        $dir = PathHelper::getDir($articleCatePath);        $service->info("       ├─ 列表默认页:" . $dir . DS . "index.html");        $service->createFile($dir . DS . "index.html", $content);    }    /**     * 生成文章列表&文章页     * @param $catalog cataLogModel     * @param $cate     */    private function exportArticleList($catalog, $cate)    {        $where = [            'article_cate_id' => $cate->id,            'status' => articleModel::STATUS_OPEN,        ];        $this->exportArticle($where, $catalog, $cate->id, $cate);    }    /**     * 生成栏目文章页     * @param $catalog cataLogModel     */    private function exportCatalogArticle($catalog)    {        $where = [            'catalog_id' => $catalog->id,            'status' => articleModel::STATUS_OPEN,        ];        $this->exportArticle($where, $catalog, 0, null);    }    /**     * 生成静态文件     */    public function exportHtml()    {        if (!$this->request->isAjax() && !$this->request->isCli()) {            return;        }        if ($this->request->isCli()) {            $ids = (new cataLogModel())->column('id');        } else {            $post = $this->request->param();            if (!isset($post['ids']) || empty($post['ids'])) {                $this->error('请选择栏目');            }            $ids = $post['ids'];        }        clear_temp_cache();//预览模式和生成模式切换时会缓存        //全局对象        $cataLogModel = new cataLogModel();        $articleModel = new articleModel();        $articleCateModel = new articleCateModel();        $service = new CmsService();        $this->assign([            'cataLogModel' => $cataLogModel,            'articleCateModel' => $articleCateModel,            'articleModel' => $articleModel,        ]);        $catalogs = $cataLogModel->where(['id' => ['in', $ids], 'status' => cataLogModel::STATUS_OPEN])->order('sort asc')->select();        $replace = CmsService::getArticleReplace();        try {            /**@var cataLogModel $catalog */            foreach ($catalogs as $catalog) {                $service->info("栏目:" . $catalog->title);                if ($catalog->type == cataLogModel::TYPE_DIRECTORY) {                    $service->info("  ├─ 类型:目录");                    continue;                }                $catalogPath = $catalog->getRealPath();                if ($catalog->type == cataLogModel::TYPE_CATALOG) {                    $service->info("  ├─ 类型:栏目页:" . $catalogPath);                    $content = $this->fetch($catalog->getCatalogTemplet()->getRealPath(), ['catalog' => $catalog], $replace);                    $service->createFile($catalogPath, $content);                } else {                    $articleCates = $catalog->articleCates;                    if (count($articleCates) > 0) {                        $service->info("  ├─ 类型:文章列表+分类");                        foreach ($articleCates as $cate) {                            $service->info("    ├─ 分类:" . $cate->title);                            $this->exportArticleList($catalog, $cate);                        }                        $service->info("      ├─ 栏目默认页:" . $catalogPath);                        $articleCatePath = articleCateModel::getRulePath($catalogPath, $catalog->articlelist_rule, $catalog->id, $articleCates[0]->id);                        $content = file_exists($articleCatePath) ? $this->fetch($articleCatePath, [], $replace) : CmsService::errorHtml($articleCatePath);                        $service->createFile($catalogPath, $content);                    } else {                        $service->info("  ├─ 类型:文章列表+栏目");                        if ($catalog->article_count > 0) {                            $this->exportCatalogArticle($catalog);                        } else {                            $service->info("      ├─ 栏目默认页:" . $catalogPath);                            $content = $this->fetch($catalog->getCatalogTemplet()->getRealPath(), ['catalog' => $catalog], $replace);                            $service->createFile($catalogPath, $content);                        }                    }                }            }            if (!$this->request->has('delete')) {                $service->copyUploads();            }        } catch (\Exception $e) {            CmsService::errorlog($e);            if ($this->request->isCli()) {                return $service->info('执行失败 ' . $e->getMessage());            } else {                $this->error('执行失败 ' . $e->getMessage());            }        }        if ($this->request->isCli()) {            $service->info('执行成功');        } else {            $this->success('执行成功', 'index');        }    }}
 |