From d8c86a5d5fca760e614570548c920c74e11fe872 Mon Sep 17 00:00:00 2001 From: liaofei <136327134@qq.com> Date: Sat, 4 Jan 2020 10:55:40 +0800 Subject: [PATCH] =?UTF-8?q?=E8=B0=83=E6=95=B4=E5=86=85=E5=AE=B9?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../app/admin/controller/article/Article.php | 133 +++++++++--------- .../app/admin/view/article/article/index.php | 2 +- crmeb/app/common.php | 28 ++++ 3 files changed, 93 insertions(+), 70 deletions(-) diff --git a/crmeb/app/admin/controller/article/Article.php b/crmeb/app/admin/controller/article/Article.php index 155f0faf..56743be2 100644 --- a/crmeb/app/admin/controller/article/Article.php +++ b/crmeb/app/admin/controller/article/Article.php @@ -28,22 +28,12 @@ class Article extends AuthController public function index() { $where = Util::getMore([ - ['title',''], - ['cid',''] - ],$this->request); - $pid = $this->request->param('pid'); - $this->assign('where',$where); + ['title', ''], + ['cid', $this->request->param('pid', '')] + ], $this->request); + $this->assign('where', $where); $where['merchant'] = 0;//区分是管理员添加的图文显示 0 还是 商户添加的图文显示 1 - $cateList = ArticleCategoryModel::getArticleCategoryList(); - $tree = []; - //获取分类列表 - if(count($cateList)){ - $tree = Phptree::makeTreeForHtml($cateList); - if($pid){ - $pids = Util::getChildrenPid($tree,$pid); - $where['cid'] = ltrim($pid.$pids); - } - } + $tree = sort_list_tier(ArticleCategoryModel::getArticleCategoryList()); $this->assign(compact('tree')); $this->assign(ArticleModel::getAll($where)); return $this->fetch(); @@ -56,7 +46,8 @@ class Article extends AuthController * @throws \think\db\exception\ModelNotFoundException * @throws \think\exception\DbException */ - public function create(){ + public function create() + { $id = $this->request->param('id'); $cid = $this->request->param('cid'); $news = []; @@ -71,26 +62,26 @@ class Article extends AuthController $news['synopsis'] = ''; $news['url'] = ''; $news['cid'] = []; - $select = 0; - if($id){ - $news = ArticleModel::where('n.id',$id)->alias('n')->field('n.*,c.content')->join('ArticleContent c','c.nid=n.id','left')->find(); - if(!$news) return $this->failed('数据不存在!'); - $news['cid'] = explode(',',$news['cid']); + $select = 0; + if ($id) { + $news = ArticleModel::where('n.id', $id)->alias('n')->field('n.*,c.content')->join('ArticleContent c', 'c.nid=n.id', 'left')->find(); + if (!$news) return $this->failed('数据不存在!'); + $news['cid'] = explode(',', $news['cid']); } - if($cid && in_array($cid, ArticleCategoryModel::getArticleCategoryInfo(0,'id'))){ + if ($cid && in_array($cid, ArticleCategoryModel::getArticleCategoryInfo(0, 'id'))) { $all = ArticleCategoryModel::getArticleCategoryInfo($cid); $select = 1; } - if(!$select){ + if (!$select) { $list = ArticleCategoryModel::getTierList(); - foreach ($list as $menu){ - $all[$menu['id']] = $menu['html'].$menu['title']; + foreach ($list as $menu) { + $all[$menu['id']] = $menu['html'] . $menu['title']; } } - $this->assign('all',$all); - $this->assign('news',$news); - $this->assign('cid',$cid); - $this->assign('select',$select); + $this->assign('all', $all); + $this->assign('news', $news); + $this->assign('cid', $cid); + $this->assign('select', $select); return $this->fetch(); } @@ -98,20 +89,22 @@ class Article extends AuthController * 上传图文图片 * @return \think\response\Json */ - public function upload_image(){ - $res = Upload::instance()->setUploadPath('wechat/image/'.date('Ymd'))->image($_POST['file']); - if(!is_array($res)) return Json::fail($res); - SystemAttachment::attachmentAdd($res['name'],$res['size'],$res['type'],$res['dir'],$res['thumb_path'],5,$res['image_type'],$res['time']); - return Json::successful('上传成功!',['url'=>$res['dir']]); + public function upload_image() + { + $res = Upload::instance()->setUploadPath('wechat/image/' . date('Ymd'))->image($_POST['file']); + if (!is_array($res)) return Json::fail($res); + SystemAttachment::attachmentAdd($res['name'], $res['size'], $res['type'], $res['dir'], $res['thumb_path'], 5, $res['image_type'], $res['time']); + return Json::successful('上传成功!', ['url' => $res['dir']]); } /** * 添加和修改图文 */ - public function add_new(){ + public function add_new() + { $data = Util::postMore([ - ['id',0], - ['cid',[]], + ['id', 0], + ['cid', []], 'title', 'author', 'image_input', @@ -119,47 +112,47 @@ class Article extends AuthController 'synopsis', 'share_title', 'share_synopsis', - ['visit',0], - ['sort',0], + ['visit', 0], + ['sort', 0], 'url', - ['is_banner',0], - ['is_hot',0], - ['status',1],]); - $data['cid'] = implode(',',$data['cid']); + ['is_banner', 0], + ['is_hot', 0], + ['status', 1],]); + $data['cid'] = implode(',', $data['cid']); $content = $data['content']; unset($data['content']); - if($data['id']){ + if ($data['id']) { $id = $data['id']; unset($data['id']); $res = false; ArticleModel::beginTrans(); - $res1 = ArticleModel::edit($data,$id,'id'); - $res2 = ArticleModel::setContent($id,$content); - if($res1 && $res2){ + $res1 = ArticleModel::edit($data, $id, 'id'); + $res2 = ArticleModel::setContent($id, $content); + if ($res1 && $res2) { $res = true; } ArticleModel::checkTrans($res); - if($res) - return Json::successful('修改图文成功!',$id); + if ($res) + return Json::successful('修改图文成功!', $id); else - return Json::fail('修改图文失败,您并没有修改什么!',$id); - }else{ + return Json::fail('修改图文失败,您并没有修改什么!', $id); + } else { $data['add_time'] = time(); $data['admin_id'] = $this->adminId; $res = false; ArticleModel::beginTrans(); $res1 = ArticleModel::create($data); $res2 = false; - if($res1) - $res2 = ArticleModel::setContent($res1->id,$content); - if($res1 && $res2){ + if ($res1) + $res2 = ArticleModel::setContent($res1->id, $content); + if ($res1 && $res2) { $res = true; } ArticleModel::checkTrans($res); - if($res) - return Json::successful('添加图文成功!',$res1->id); + if ($res) + return Json::successful('添加图文成功!', $res1->id); else - return Json::successful('添加图文失败!',$res1->id); + return Json::successful('添加图文失败!', $res1->id); } } @@ -171,17 +164,18 @@ class Article extends AuthController public function delete($id) { $res = ArticleModel::del($id); - if(!$res) + if (!$res) return Json::fail('删除失败,请稍候再试!'); else return Json::successful('删除成功!'); } - public function merchantIndex(){ + public function merchantIndex() + { $where = Util::getMore([ - ['title',''] - ],$this->request); - $this->assign('where',$where); + ['title', ''] + ], $this->request); + $this->assign('where', $where); $where['cid'] = input('cid'); $where['merchant'] = 1;//区分是管理员添加的图文显示 0 还是 商户添加的图文显示 1 $this->assign(ArticleModel::getAll($where)); @@ -194,7 +188,7 @@ class Article extends AuthController */ public function relation($id = 0) { - $this->assign('id',$id); + $this->assign('id', $id); return $this->fetch(); } @@ -204,23 +198,24 @@ class Article extends AuthController */ public function edit_article($id = 0) { - if(!$id) return Json::fail('缺少参数'); + if (!$id) return Json::fail('缺少参数'); list($product_id) = Util::postMore([ - ['product_id',0] - ],$this->request,true); - if(ArticleModel::edit(['product_id'=>$product_id],['id'=>$id])) + ['product_id', 0] + ], $this->request, true); + if (ArticleModel::edit(['product_id' => $product_id], ['id' => $id])) return Json::successful('保存成功'); else return Json::fail('保存失败'); } + /** * 取消绑定的产品id * @param int $id */ public function unrelation($id = 0) { - if(!$id) return Json::fail('缺少参数'); - if(ArticleModel::edit(['product_id'=>0],$id)) + if (!$id) return Json::fail('缺少参数'); + if (ArticleModel::edit(['product_id' => 0], $id)) return Json::successful('取消关联成功!'); else return Json::fail('取消失败'); diff --git a/crmeb/app/admin/view/article/article/index.php b/crmeb/app/admin/view/article/article/index.php index 7d489ca8..b9fe3c54 100644 --- a/crmeb/app/admin/view/article/article/index.php +++ b/crmeb/app/admin/view/article/article/index.php @@ -13,7 +13,7 @@
diff --git a/crmeb/app/common.php b/crmeb/app/common.php index d81fc761..55b513d2 100644 --- a/crmeb/app/common.php +++ b/crmeb/app/common.php @@ -193,4 +193,32 @@ if (!function_exists('set_file_url')) { $image = str_replace('\\', '/', $image); return $siteUrl . $image; } +} + +if (!function_exists('sort_list_tier')) { + /** + * 分级排序 + * @param $data + * @param int $pid + * @param string $field + * @param string $pk + * @param string $html + * @param int $level + * @param bool $clear + * @return array + */ + function sort_list_tier($data, $pid = 0, $field = 'pid', $pk = 'id', $html = '|-----', $level = 1, $clear = true) + { + static $list = []; + if ($clear) $list = []; + foreach ($data as $k => $res) { + if ($res[$field] == $pid) { + $res['html'] = str_repeat($html, $level); + $list[] = $res; + unset($data[$k]); + sort_list_tier($data, $res[$pk], $field, $pk, $html, $level + 1, false); + } + } + return $list; + } } \ No newline at end of file