homepagePHP/app/Admin/Controller/KeywordsController.class.php

215 lines
7.4 KiB
PHP
Executable File

<?php
namespace Admin\Controller;
use Gy_Library\GyListController;
use Gy_Library\DBCont;
use Qscmf\Builder\FormBuilder;
use Qscmf\Builder\ListBuilder;
/*
* 关键词
*/
class KeywordsController extends GyListController
{
public function index()
{
$map = [];
$get_data = I('get.');
if (isset($get_data['key']) && $get_data['word']) {
$map[$get_data['key']] = array('like', '%' . $get_data['word'] . '%');
}
$model = D('Keywords');
$count = $model->getListForCount($map);
$per_page = C('ADMIN_PER_PAGE_NUM', null, false);
if ($per_page === false) {
$page = new \Gy_Library\GyPage($count);
} else {
$page = new \Gy_Library\GyPage($count, $per_page);
}
$order = 'sort asc,id desc';
if (!empty($get_data['click_time']) && $get_data['click_time']==='asc') {
$order = 'total_time asc';
}elseif (!empty($get_data['click_time']) && $get_data['click_time']==='desc'){
$order = 'total_time desc';
}
$data_list = $model->getListForPage($map, $page->nowPage, $page->listRows, $order);
// 使用Builder快速建立列表页面。
$builder = new ListBuilder();
$builder = $builder->setMetaTitle('关键词管理');// 设置页面标题
$builder->addTopButton('addnew');
// $builder->addTopButton('save', array('title' => '保存排序'));
$builder
->addSearchItem('click_time', 'select', '点击量排序', array('asc' => '点击量正序','desc'=>'点击量倒序'))
->setNIDByNode(MODULE_NAME, CONTROLLER_NAME, 'index')
->addSearchItem('title', 'select_text', '单行输入', array('name' => '名称'))
->addTableColumn('name', '名称')
->addTableColumn('total_time', '点击量','','',false)
->addTableColumn('status', '状态', 'status', '', false)
->addTableColumn('right_button', '操作', 'btn')
->setTableDataList($data_list)// 数据列表
->setTableDataPage($page->show())// 数据列表分页
->addRightButton('edit')// 添加编辑按钮
->addRightButton('delete')// 添加删除按钮
->addRightButton('forbid')// 添加禁用按钮
->addRightButton('self', ['title' => '查看相关文章', 'href' => U('News/index', ['key' => 'keyword','word'=>'__name__']), 'class' => 'label label-success'])
->display();
}
public function add()
{
if (IS_POST) {
parent::autoCheckToken();
$data = I('post.');
$data['name'] = trim($data['name']);
$model = D('Keywords');
$r = $model->createAdd($data);
if ($r === false) {
$this->error($model->getError());
} else {
sysLogs('新增关键词id:' . $r);
$this->success(l('add') . l('success'), U(CONTROLLER_NAME . '/index'));
}
} else {
// 使用FormBuilder快速建立表单页面。
$builder = new FormBuilder();
$data_list = array(
"status" => 1,
"sort" => 0,
);
if ($data_list) {
$builder->setFormData($data_list);
}
$builder->setMetaTitle('添加关键词')//设置页面标题
->setNIDByNode(MODULE_NAME, CONTROLLER_NAME, 'index')
->setPostUrl(U('add'))//设置表单提交地址
->addFormItem('name', 'text', '名称')
->addFormItem('sort', 'hidden', '排序')
->addFormItem('status', 'select', '状态', '', DBCont::getStatusList())
->display();
}
}
public function save(){
if(IS_POST){
$data = I('post.');
foreach($data['id'] as $k=>$v){
$save_data['sort'] = $data['sort'][$k];
D('Keywords')->where('id=' . $v)->save($save_data);
}
$this->success('保存成功', U('index'));
}
}
public function edit($id)
{
if (IS_POST) {
parent::autoCheckToken();
$m_id = I('post.id');
$data = I('post.');
$data['name'] = trim($data['name']);
$model = D('Keywords');
if (!$m_id) {
E('缺少内容ID');
}
$ent = $model->getOne($m_id);
if (!$ent) {
E('不存在内容');
}
$ent['name'] = $data['name'];
$ent['sort'] = $data['sort'];
$ent['status'] = $data['status'];
if ($model->createSave($ent) === false) {
$this->error($model->getError());
} else {
$this->success('修改成功', U('index'));
}
} else {
$info = D('Keywords')->getOne($id);
$builder = new FormBuilder();
$builder->setMetaTitle('编辑关键词')
->setPostUrl(U('edit'))
// ->setExtraHtml($this->fetch('Keywords/detail'))
->setNIDByNode(MODULE_NAME, CONTROLLER_NAME, 'index')
->addFormItem('id', 'hidden', 'ID')
->addFormItem('name', 'text', '名称')
->addFormItem('sort', 'hidden', '排序','',$info['sort'])
->addFormItem('status', 'select', '状态', '', DBCont::getStatusList())
->setFormData($info)
->display();
}
}
public function forbid()
{
$ids = I('ids');
if (!$ids) {
$this->error('请选择要禁用的数据');
}
$r = parent::_forbid($ids);
if ($r !== false) {
// sysLogs('新闻分类id: ' . $ids . ' 禁用');
$this->success('禁用成功', U(CONTROLLER_NAME . '/index'));
} else {
$this->error($this->_getError());
}
}
public function resume()
{
$ids = I('ids');
if (!$ids) {
$this->error('请选择要启用的数据');
}
$r = parent::_resume($ids);
if ($r !== false) {
$this->success('启用成功', U(CONTROLLER_NAME . '/index'));
} else {
$this->error($this->_getError());
}
}
public function delete()
{
$ids = I('ids');
if (!$ids) {
$this->error('请选择要删除的数据');
}
$r = parent::_del($ids);
if ($r === false) {
$this->error($this->_getError());
} else {
$this->success('删除成功', U(MODULE_NAME . '/' . CONTROLLER_NAME . '/index'));
}
}
public function getKeyword(){
$result = D('Keywords')->field('id, name')->where(['status'=>DBCont::YES_BOOL_STATUS])->order('sort asc, id asc')->select();
$this->ajaxReturn($result);
}
public function addKeyword($labelName){
C('TOKEN_ON', false);
$data['name'] = $labelName;
$model = D('Keywords');
$r = $model->createAdd($data);
if($r === false){
$this->error($model->getError());
}else{
$new_keyword = $model->where(['id' => $r])->field('id,name')->select();
$this->ajaxReturn($new_keyword);
}
}
public function delKeyword($id){
$r = D('Keywords')->del($id);
$this->ajaxReturn($r);
}
}