* Date: 2018-4-3 */ namespace app\admin\controller; use think\Page; use think\Db; use think\Cache; class ZczsPosition extends Base { private $ad_position_system_id = array(); // 系统默认位置ID,不可删除 public function _initialize() { parent::_initialize(); } public function index() { $list = array(); $get = input('get.'); $keywords = input('keywords/s'); $condition = []; // 应用搜索条件 foreach (['keywords', 'type'] as $key) { $get[$key] = addslashes(trim($get[$key])); if (isset($get[$key]) && $get[$key] !== '') { if ($key == 'keywords') { $condition['a.title'] = array('LIKE', "%{$get[$key]}%"); } else { $tmp_key = 'a.'.$key; $condition[$tmp_key] = array('eq', $get[$key]); } } } unset($condition['a.type']); //var_dump($condition); if(!empty($get['type']) && (int)$get['type'] > 0){ if(!empty($get['type2']) && (int)$get['type2'] > 0){ //存在二级 $condition['a.type'] = array('eq', (int)$get['type2']); }else{ //存在一级 $zc_ids = Db::name('zc_type')->where('pid','=',(int)$get['type'])->column('id'); $zc_ids[] = (int)$get['type']; $condition['a.type'] = array('IN', $zc_ids); } }else{ unset($condition['a.type']); } //var_dump($condition); //增加地区条件 if(!empty($get['map']) && $get['map'] == '-1'){ }else{ if(!empty($get['map']) && (int)$get['map'] > 0) { //查找 $zc_ids = Db::name('zc_map')->where('map_id','=',(int)$get['map'])->column('zc_id'); $condition['a.id'] = array('IN', $zc_ids); }else{ //$condition['a.type'] = array('eq', 0); } } // 多语言 //$condition['a.lang'] = array('eq', $this->admin_lang); $adPositionM = Db::name('zczs_position'); $count = $adPositionM->alias('a')->where($condition)->count();// 查询满足要求的总记录数 $Page = new Page($count, config('paginate.list_rows'));// 实例化分页类 传入总记录数和每页显示的记录数 $list = $adPositionM->alias('a')->where($condition)->order('id desc')->limit($Page->firstRow.','.$Page->listRows)->getAllWithIndex('id'); //var_dump($condition);die; // 每组获取三张图片 $pids = get_arr_column($list, 'id'); $ad = Db::name('zczs') ->where(['pid' => ['IN', $pids], 'lang' => $this->admin_lang]) ->order('pid asc, id asc') ->select(); foreach ($list as $k => $v) { /* if (1 == $v['type']) { // 图片封面图片 $v['ad'] = []; foreach ($ad as $m => $n) { if ($v['id'] == $n['pid']) { $n['litpic'] = get_default_pic($n['litpic']); // 支持子目录 $v['ad'][] = $n; unset($ad[$m]); } else { continue; } } // 若没有内容则显示默认图片 if (empty($v['ad'])) { $v['ad_count'] = 0; $v['ad'][]['litpic'] = ROOT_DIR . '/public/static/common/images/not_adv.jpg'; } else { $v['ad_count'] = count($v['ad']); } // 广告类型 $v['type_name'] = '图片'; } else if (2 == $v['type']) { // 多媒体封面图片 $v['ad'][]['litpic'] = ROOT_DIR . '/public/static/admin/images/ad_type_media.png'; // 广告类型 $v['type_name'] = '多媒体'; } else if (3 == $v['type']) { // HTML代码封面图片 $v['ad'][]['litpic'] = ROOT_DIR . '/public/static/admin/images/ad_type_html.png'; // 广告类型 $v['type_name'] = 'HTML代码'; }*/ //处理图片 $v['ad'] = []; foreach ($ad as $m => $n) { if ($v['id'] == $n['pid']) { $n['litpic'] = get_default_pic($n['litpic']); // 支持子目录 $v['ad'][] = $n; unset($ad[$m]); } else { continue; } } // 若没有内容则显示默认图片 if (empty($v['ad'])) { $v['ad_count'] = 0; $v['ad'][]['litpic'] = ROOT_DIR . '/public/static/common/images/not_adv.jpg'; } else { $v['ad_count'] = count($v['ad']); } //查找分类表 $v['type_name'] = Db::name('zc_type')->where(['id' => (int)$v['type']])->value('name'); /* $less = ['初级','中级','高级']; $v['type_name'] = $less[(int)$v['type']];*/ $less_name = ['无','中专','高技','大专','本科','硕士','博士']; $v['xl_name'] = $less_name[(int)$v['bdxl']]; if((int)$v['type'] == 0){ }else{ //获取中间表 /*$map_ids = Db::name('zc_map') ->where('is_del','=',0) ->where('zc_id', $v['id']) ->column('map_id'); //获取地区 $oneList = Db::name('citysite') ->where('id','in',$map_ids) ->select(); foreach ($oneList as $k2 => $v2) { $v['type_name'] .= $v2['name'].','; }*/ } $list[$k] = $v; } $show = $Page->show();// 分页显示输出 $this->assign('page',$show);// 赋值分页输出 $this->assign('list',$list);// 赋值数据集 $this->assign('pager',$Page);// 赋值分页对象 /*多语言模式下,广告位ID显示主体语言的ID和属性title名称*/ $main_adv_list = []; if ($this->admin_lang != $this->main_lang && empty($this->globalConfig['language_split'])) { $attr_values = get_arr_column($list, 'id'); $languageAttrRow = Db::name('language_attr')->field('attr_name,attr_value')->where([ 'attr_value' => ['IN', $attr_values], 'attr_group' => 'ad_position', 'lang' => $this->admin_lang, ])->getAllWithIndex('attr_value'); $ids = []; foreach ($languageAttrRow as $key => $val) { $tid_tmp = str_replace('adp', '', $val['attr_name']); array_push($ids, intval($tid_tmp)); } $main_advRow = Db::name('zczs_position')->field("id,title,CONCAT('adp', id) AS attr_name") ->where([ 'id' => ['IN', $ids], 'lang' => $this->main_lang, ])->getAllWithIndex('attr_name'); foreach ($list as $key => $val) { $key_tmp = !empty($languageAttrRow[$val['id']]['attr_name']) ? $languageAttrRow[$val['id']]['attr_name'] : ''; $main_adv_list[$val['id']] = [ 'id' => !empty($main_advRow[$key_tmp]['id']) ? $main_advRow[$key_tmp]['id'] : '', 'title' => !empty($main_advRow[$key_tmp]['title']) ? $main_advRow[$key_tmp]['title'] : '', ]; } } $this->assign('main_adv_list', $main_adv_list); /*end*/ //查找区域数据 $pro_list = Db::name('citysite')->where(['level'=>1,'is_open'=>1])->select(); //var_dump($pro_list); $this->assign('pro_list', $pro_list); $pos_list = Db::name('zc_type')->where(['pid'=>0,'is_del'=>0,'catid'=>1])->select(); $this->assign('pos_list', $pos_list); //查询二级 if(!empty($get['type']) && (int)$get['type'] > 0){ $pos_list2 = Db::name('zc_type')->where(['pid'=>$get['type'],'is_del'=>0])->select(); $this->assign('pos_list2', $pos_list2); } return $this->fetch(); } /** * 新增 */ public function add() { //防止php超时 function_exists('set_time_limit') && set_time_limit(0); if (is_language() && empty($this->globalConfig['language_split'])) { $this->language_access(); // 多语言功能操作权限 } if (IS_POST) { $post = input('post.'); //var_dump($post); //die; /* * array(11) { ["title"]=> string(12) "建筑职称" ["type"]=> string(1) "1" ["img_id"]=> array(1) { [0]=> string(0) "" } ["img_litpic"]=> array(1) { [0]=> string(67) "https://oss.zc10000.com/uploads/allimg/20240528/1-24052R01005Z4.png" } ["img_title"]=> array(1) { [0]=> string(0) "" } ["img_links"]=> array(1) { [0]=> string(0) "" } ["img_intro"]=> array(1) { [0]=> string(0) "" } ["img_target"]=> array(1) { [0]=> string(1) "0" } ["video_litpic"]=> string(0) "" ["html_intro"]=> string(0) "" ["intro"]=> string(0) "" } */ //var_dump($post);die; $map = array( 'title' => trim($post['title']), 'lang' => $this->admin_lang, ); if(Db::name('zczs_position')->where($map)->count() > 0){ $this->error('该职称名称已存在,请检查', url('ZczsPosition/index')); } /* if((int)$post['type'] === 1) { if(empty($post['map']) || !is_array($post['map'])) { $this->error('请选择至少一个地区', url('ZczsPosition/index')); } }*/ // 添加广告位置表信息 $data = array( 'title' => trim($post['title']), 'type' => $post['type'], //职称地区 全国或者地区 'intro' => $post['intro'], //备注 'admin_id' => session('admin_id'), 'bdxl' => $post['bdxl'], //绑定学历 'lang' => $this->admin_lang, 'add_time' => getTime(), 'update_time' => getTime(), ); $insertID = Db::name('zczs_position')->insertGetId($data); if (!empty($insertID)) { /* //处理多选 if((int)$post['type'] === 1){ //$post['map'] 已验证 是非空数组 //插入中间表 $map_data = []; foreach ($post['map'] as $k => $v) { $map_data[] = [ 'map_id' => $v, 'zc_id' => $insertID, 'add_time' => time(), 'is_del' => 0, 'del_time' => 0 ]; } Db::name('zc_map')->insertAll($map_data); }else{ //属于全国 不需要添加区域 }*/ // 同步广告位置ID到多语言的模板变量里,添加多语言广告位 //$this->syn_add_language_attribute($insertID); // 读取组合广告位的图片及信息 $AdData = []; if (!empty($post['img_litpic'])) { // 图片类型 $i = 1; foreach ($post['img_litpic'] as $key => $value) { if (!empty($value)) { // 去掉http: $value = str_replace("http:", "", $value); // 去掉https: $value = str_replace("https:", "", $value); // 主要参数 $AdData['litpic'] = $value; $AdData['pid'] = $insertID; $AdData['title'] = trim($post['img_title'][$key]); $AdData['links'] = $post['img_links'][$key]; $AdData['intro'] = $post['img_intro'][$key]; $target = !empty($post['img_target'][$key]) ? 1 : 0; $AdData['target'] = $target; // 其他参数 $AdData['media_type'] = 1; $AdData['admin_id'] = session('admin_id'); $AdData['lang'] = $this->admin_lang; $AdData['sort_order'] = $i++; $AdData['add_time'] = getTime(); $AdData['update_time'] = getTime(); // 添加到广告图表 $ad_id = Db::name('zczs')->add($AdData); // 同步多语言 //$this->syn_add_ad_language_attribute($ad_id); } } } //Cache::clear('ad'); adminLog('新增职称:'.$post['title']); $this->success("操作成功", url('ZczsPosition/index')); } else { $this->error("操作失败", url('ZczsPosition/index')); } } // 上传通道 $WeappConfig = Db::name('weapp')->field('code, status')->where('code', 'IN', ['Qiniuyun', 'AliyunOss', 'Cos'])->select(); $WeappOpen = []; foreach ($WeappConfig as $value) { if ('Qiniuyun' == $value['code']) { $WeappOpen['qny_open'] = $value['status']; } else if ('AliyunOss' == $value['code']) { $WeappOpen['oss_open'] = $value['status']; } else if ('Cos' == $value['code']) { $WeappOpen['cos_open'] = $value['status']; } } $this->assign('WeappOpen', $WeappOpen); // 系统最大上传视频的大小 $upload_max_filesize = upload_max_filesize(); $this->assign('upload_max_filesize', $upload_max_filesize); // 视频类型 $media_type = tpCache('global.media_type'); $media_type = !empty($media_type) ? $media_type : config('global.media_ext'); $media_type = str_replace(",", "|", $media_type); $this->assign('media_type', $media_type); //查找区域数据 $pro_list = Db::name('citysite')->where(['level'=>1,'is_open'=>1])->select(); //var_dump($pro_list); $this->assign('pro_list', $pro_list); $pos_list = Db::name('zc_type')->where(['pid'=>0,'is_del'=>0,'catid'=>1])->select(); $this->assign('pos_list', $pos_list); //查询二级 if(!empty($pos_list)){ $pos_list2 = Db::name('zc_type')->where(['pid'=>$pos_list[0]['id'],'is_del'=>0,'catid'=>1])->select(); $this->assign('pos_list2', $pos_list2); } return $this->fetch(); } public function getType($sid='') { if($sid == ''){ $id = request()->post('id',0); }else{ $id = $sid; } //查找区域 $list = Db::name('zc_type') ->where('pid','=',$id) ->where('is_del','=',0) ->select(); $html = ''; foreach ($list as $key => $value) { $html .= ''; } $data = [ 'code' => 0, 'msg' => '获取成功', 'data' => $html, ]; if($sid == ''){ return json($data); }else{ return $list; } } /** * 编辑 */ public function edit() { if (IS_POST) { $post = input('post.'); if (!empty($post['id'])) { $post['id'] = intval($post['id']); if (array_key_exists($post['id'], $this->ad_position_system_id)) { $this->error("不可更改系统预定义位置", url('ZczsPosition/edit',array('id'=>$post['id']))); } /* 判断除自身外是否还有相同广告名称已存在 */ $map = array( 'id' => array('NEQ', $post['id']), 'title' => trim($post['title']), //'lang' => $this->admin_lang, ); if (Db::name('zczs_position')->where($map)->count() > 0) $this->error('该职称名称已存在,请检查'); /* END */ /* if((int)$post['type'] === 1) { if(empty($post['map']) || !is_array($post['map'])) { $this->error('请选择至少一个地区', url('ZczsPosition/index')); } }*/ /* 判断广告是否切换广告类型 */ // $where = [ // 'id' => $post['id'], // 'type' => $post['type'], // 'lang' => $this->admin_lang // ]; // if (Db::name('zczs_position')->where($where)->count() == 0) { // // 已切换广告类型,清除广告中的广告内容 // $where = [ // 'pid' => $post['id'], // 'lang' => $this->admin_lang // ]; // Db::name('zczs')->where($where)->delete(); // } /* END */ /* 修改广告主体信息 */ $data = array( 'id' => $post['id'], 'title' => trim($post['title']), 'type' => $post['type'], //全国或者地区 'intro' => $post['intro'], 'bdxl' => $post['bdxl'], //绑定学历 'update_time' => getTime(), ); $resultID = Db::name('zczs_position')->update($data); /* END */ } if (!empty($resultID)) { /*//处理多选 if((int)$post['type'] === 1){ //$post['map'] 已验证 是非空数组 //先删除旧数据 Db::name('zc_map')->where('zc_id','=',$post['id'])->update([ 'is_del' => 1, 'del_time' => time() ]); //插入中间表 $map_data = []; foreach ($post['map'] as $k => $v) { $map_data[] = [ 'map_id' => $v, 'zc_id' => $post['id'], 'add_time' => time(), 'is_del' => 0, 'del_time' => 0 ]; } Db::name('zc_map')->insertAll($map_data); }else{ //属于全国 删除所有区域 Db::name('zc_map')->where('zc_id','=',$post['id'])->update([ 'is_del' => 1, 'del_time' => time() ]); }*/ $ad_db = Db::name('zczs'); if (!empty($post['img_litpic'])) { // 图片类型 // 读取组合广告位的图片及信息 $i = 1; foreach ($post['img_litpic'] as $key => $value) { if (!empty($value)) { // 去掉http: $value = str_replace("http:", "", $value); // 去掉https: $value = str_replace("https:", "", $value); // 是否新窗口打开 $target = !empty($post['img_target'][$key]) ? 1 : 0; // 广告位ID,为空则表示添加 $ad_id = $post['img_id'][$key]; if (!empty($ad_id)) { // 查询更新条件 $where = [ 'id' => $ad_id, 'lang' => $this->admin_lang, ]; if ($ad_db->where($where)->count() > 0) { // 主要参数 $AdData['litpic'] = $value; $AdData['title'] = $post['img_title'][$key]; $AdData['links'] = $post['img_links'][$key]; $AdData['intro'] = $post['img_intro'][$key]; $AdData['target'] = $target; // 其他参数 $AdData['sort_order'] = $i++; $AdData['update_time'] = getTime(); // 更新,不需要同步多语言 $ad_db->where($where)->update($AdData); } else { // 主要参数 $AdData['litpic'] = $value; $AdData['pid'] = $post['id']; $AdData['title'] = $post['img_title'][$key]; $AdData['links'] = $post['img_links'][$key]; $AdData['intro'] = $post['img_intro'][$key]; $AdData['target'] = $target; // 其他参数 $AdData['media_type'] = 1; $AdData['admin_id'] = session('admin_id'); $AdData['lang'] = $this->admin_lang; $AdData['sort_order'] = $i++; $AdData['add_time'] = getTime(); $AdData['update_time'] = getTime(); $ad_id = $ad_db->add($AdData); // 同步多语言 //$this->syn_add_ad_language_attribute($ad_id); } } else { // 主要参数 $AdData['litpic'] = $value; $AdData['pid'] = $post['id']; $AdData['title'] = $post['img_title'][$key]; $AdData['links'] = $post['img_links'][$key]; $AdData['intro'] = $post['img_intro'][$key]; $AdData['target'] = $target; // 其他参数 $AdData['media_type'] = 1; $AdData['admin_id'] = session('admin_id'); $AdData['lang'] = $this->admin_lang; $AdData['sort_order'] = $i++; $AdData['add_time'] = getTime(); $AdData['update_time'] = getTime(); $ad_id = $ad_db->add($AdData); // 同步多语言 //$this->syn_add_ad_language_attribute($ad_id); } } } } //Cache::clear('ad'); adminLog('编辑职称名称:'.$post['title']); $this->success("操作成功", url('ZczsPosition/index')); } else { $this->error("操作失败"); } } $assign_data = array(); $id = input('id/d'); $field = Db::name('zczs_position')->field('a.*')->alias('a')->where(array('a.id'=>$id))->find(); if (empty($field)) $this->error('职称不存在,请联系管理员!'); switch ($field['type']) { case '1': $field['type_name'] = '图片'; break; case '2': $field['type_name'] = '多媒体'; break; case '3': $field['type_name'] = 'HTML代码'; break; } $assign_data['field'] = $field; // 广告 $ad_data = Db::name('zczs')->where(array('pid'=>$field['id']))->order('sort_order asc')->select(); foreach ($ad_data as $key => $val) { if (1 == $val['media_type']) { $ad_data[$key]['litpic'] = get_default_pic($val['litpic']); // 支持子目录 } } $assign_data['ad_data'] = $ad_data; // 上传通道 $WeappConfig = Db::name('weapp')->field('code, status')->where('code', 'IN', ['Qiniuyun', 'AliyunOss', 'Cos'])->select(); $WeappOpen = []; foreach ($WeappConfig as $value) { if ('Qiniuyun' == $value['code']) { $WeappOpen['qny_open'] = $value['status']; } else if ('AliyunOss' == $value['code']) { $WeappOpen['oss_open'] = $value['status']; } else if ('Cos' == $value['code']) { $WeappOpen['cos_open'] = $value['status']; } } $this->assign('WeappOpen', $WeappOpen); // 系统最大上传视频的大小 $file_size = tpCache('global.file_size'); $postsize = @ini_get('file_uploads') ? ini_get('post_max_size') : -1; $fileupload = @ini_get('file_uploads') ? ini_get('upload_max_filesize') : -1; $min_size = strval($file_size) < strval($postsize) ? $file_size : $postsize; $min_size = strval($min_size) < strval($fileupload) ? $min_size : $fileupload; $upload_max_filesize = intval($min_size) * 1024 * 1024; $assign_data['upload_max_filesize'] = $upload_max_filesize; // 视频类型 $media_type = tpCache('global.media_type'); $media_type = !empty($media_type) ? $media_type : config('global.media_ext'); $media_type = str_replace(",", "|", $media_type); $assign_data['media_type'] = $media_type; //查询关联区域数据 $map_list = Db::name('zc_map')->where(['zc_id'=>$field['id'],'is_del'=>0])->column('map_id'); //var_dump($map_list);die(); $this->assign('$map_list', $map_list); //查找区域数据 $pro_list = Db::name('citysite')->where(['level'=>1,'is_open'=>1])->select(); foreach ($pro_list as $k=>$v){ if(in_array($v['id'],$map_list) === true){ $pro_list[$k]['is_check'] = "checked"; }else{ $pro_list[$k]['is_check'] = ''; } } //var_dump($pro_list); $this->assign('pro_list', $pro_list); $this->assign('curr_id', $field['type']); $row = Db::name('zc_type')->where(['id'=>$field['type'],'is_del'=>0])->find(); $this->assign('pid', $row['pid']); $pos_list = Db::name('zc_type')->where(['pid'=>0,'is_del'=>0,'catid'=>1])->select(); $this->assign('pos_list', $pos_list); //查询二级 if(!empty($pos_list)){ $pos_list2 = Db::name('zc_type')->where(['pid'=>$row['pid'],'is_del'=>0,'catid'=>1])->select(); $this->assign('pos_list2', $pos_list2); } $this->assign($assign_data); return $this->fetch(); } public function addtype(){ $pos_list = Db::name('zc_type')->where(['pid'=>0,'is_del'=>0,'catid'=>1])->select(); $this->assign('pos_list', $pos_list); return $this->fetch(); } public function addtypePost(){ $post = request()->post(); if((int)$post['pid'] > 0){ $level = 1; }else{ $level = 0; } $data = [ 'pid' => $post['pid'], 'level' => $level, 'add_time' => time(), 'is_del' => 0, 'del_time' => 0, 'name' => $post['title'], 'catid' => 1, // ]; Db::name('zc_type')->insert($data); $this->success('新增成功'); } public function edittype(){ //判断当前编辑的是一级还是二级 $param = request()->param(); if(!empty($param['type2']) && (int)$param['type2'] > 0){ //二级 $id = (int)$param['type2']; $pid = (int)$param['type']; $pos_list = Db::name('zc_type')->where(['pid'=>0,'is_del'=>0,'catid'=>1])->select(); $this->assign('pos_list', $pos_list); $this->assign('pid', $pid); }else{ if(!empty($param['type']) && (int)$param['type'] > 0){ //一级 $id = (int)$param['type']; //$pos_list = Db::name('zc_type')->where(['pid'=>0,'is_del'=>0])->select(); $pos_list = []; $this->assign('pos_list', $pos_list); }else{ // $this->error('请选择分类才能进行编辑'); } } $one = Db::name('zc_type')->where(['id'=>$id])->find(); //var_dump($one); $this->assign('one', $one); return $this->fetch(); } public function deltype() { $param = request()->param(); if(!empty($param['type2']) && (int)$param['type2'] > 0){ //二级 $id = (int)$param['type2']; $pid = (int)$param['type']; //查询是否存在证书 $count = Db::name('zczs_position')->where(['type'=>$id,'is_del'=>0])->count(); if($count > 0){ $this->error('该分类下存在数据,不允许删除'); } }else{ if(!empty($param['type']) && (int)$param['type'] > 0){ //一级 $id = (int)$param['type']; //查询是否存在下级 $count = Db::name('zc_type')->where(['pid'=>$id,'is_del'=>0])->count(); if($count > 0){ $this->error('该分类下存在子级,不允许删除'); } //查询是否存在证书 $count = Db::name('zczs_position')->where(['type'=>$id,'is_del'=>0])->count(); if($count > 0){ $this->error('该分类下存在数据,不允许删除'); } }else{ // $this->error('请选择分类才能进行删除'); } } Db::name('zc_type')->where(['id'=>$id])->delete(); $this->success('删除成功'); } public function edittypePost(){ $post = request()->post(); if((int)$post['pid'] > 0){ $level = 1; }else{ $level = 0; } $data = [ 'pid' => $post['pid'], 'level' => $level, 'is_del' => 0, 'del_time' => 0, 'name' => $post['title'], 'catid' => 1, // 'update_time' => time(), ]; Db::name('zc_type')->where('id',(int)$post['id'])->update($data); $this->success('新增成功'); } /** * 删除广告图片 */ public function del_imgupload() { if (is_language() && empty($this->globalConfig['language_split'])) { $this->language_access(); // 多语言功能操作权限 } $id_arr = input('del_id/a'); $id_arr = eyIntval($id_arr); if(IS_POST && !empty($id_arr)){ /*多语言*/ $attr_name_arr = []; if (empty($this->globalConfig['language_split'])) { foreach ($id_arr as $key => $val) { $attr_name_arr[] = 'ad'.$val; } if (is_language()) { $new_id_arr = Db::name('language_attr')->where([ 'attr_name' => ['IN', $attr_name_arr], 'attr_group' => 'ad', ])->column('attr_value'); !empty($new_id_arr) && $id_arr = $new_id_arr; } } else { if (get_admin_lang() == get_main_lang()) { foreach ($id_arr as $key => $val) { $attr_name_arr[] = 'ad'.$val; } } } /*--end*/ $r = Db::name('zczs')->where([ 'id' => ['IN', $id_arr], ]) ->delete(); if ($r !== false) { /*多语言*/ if (!empty($attr_name_arr)) { Db::name('language_attr')->where([ 'attr_name' => ['IN', $attr_name_arr], 'attr_group' => 'ad', ])->delete(); Db::name('language_attribute')->where([ 'attr_name' => ['IN', $attr_name_arr], 'attr_group' => 'ad', ])->delete(); } /*--end*/ Cache::clear('ad'); adminLog('删除广告-id:'.implode(',', $id_arr)); } } } /** * 删除 */ public function del() { if (is_language() && empty($this->globalConfig['language_split'])) { $this->language_access(); // 多语言功能操作权限 } $id_arr = input('del_id/a'); $id_arr = eyIntval($id_arr); if(IS_POST && !empty($id_arr)){ foreach ($id_arr as $key => $val) { if(array_key_exists($val, $this->ad_position_system_id)){ $this->error('系统预定义,不能删除'); } } /*多语言*/ $attr_name_arr = []; foreach ($id_arr as $key => $val) { $attr_name_arr[] = 'adp'.$val; } if (is_language() && empty($this->globalConfig['language_split'])) { $new_id_arr = Db::name('language_attr')->where([ 'attr_name' => ['IN', $attr_name_arr], 'attr_group' => 'ad_position', ])->column('attr_value'); !empty($new_id_arr) && $id_arr = $new_id_arr; } /*--end*/ $r = Db::name('zczs_position')->where('id','IN',$id_arr)->delete(); if ($r !== false) { /*多语言*/ if (!empty($attr_name_arr)) { if (get_admin_lang() == get_main_lang()) { Db::name('language_attribute')->where([ 'attr_name' => ['IN', $attr_name_arr], 'attr_group' => 'ad_position', ])->delete(); } if (empty($this->globalConfig['language_split'])) { Db::name('language_attr')->where([ 'attr_name' => ['IN', $attr_name_arr], 'attr_group' => 'ad_position', ])->delete(); } else { Db::name('language_attr')->where([ 'attr_value' => ['IN', $id_arr], 'attr_group' => 'ad_position', ])->delete(); } } /*--end*/ $ad_ids = Db::name('zczs')->where(['pid'=>['IN', $id_arr]])->column('id'); $attr_name_arr = []; foreach ($ad_ids as $key => $val) { $attr_name_arr[] = "ad{$val}"; } $r1 = Db::name('zczs')->where('pid','IN',$id_arr)->delete(); if ($r1 !== false) { /*多语言*/ if (!empty($attr_name_arr)) { if (get_admin_lang() == get_main_lang()) { Db::name('language_attribute')->where([ 'attr_name' => ['IN', $attr_name_arr], 'attr_group' => 'ad', ])->delete(); } if (empty($this->globalConfig['language_split'])) { Db::name('language_attr')->where([ 'attr_name' => ['IN', $attr_name_arr], 'attr_group' => 'ad', ])->delete(); } else { Db::name('language_attr')->where([ 'attr_value' => ['IN', $ad_ids], 'attr_group' => 'ad', ])->delete(); } } /*--end*/ } Cache::clear('ad'); adminLog('删除广告-id:'.implode(',', $id_arr)); $this->success('删除成功'); } else { $this->error('删除失败'); } }else{ $this->error('参数有误'); } } /** * 打开预览视频 */ public function open_preview_video() { $post = input('post.'); $video_litpic = $post['video_litpic']; if (!is_http_url($video_litpic)) { $video_litpic = request()->domain() . handle_subdir_pic($video_litpic, 'media'); } $this->success('执行成功', $video_litpic); } /** * 检测广告名称是否存在重复 */ public function detection_title_repeat() { if (IS_AJAX_POST) { $post = input('post.'); $where = [ 'id' => ['NEQ', $post['id']], 'title' => trim($post['title']), 'lang' => $this->admin_lang, ]; $count = Db::name('zczs_position')->where($where)->count(); if (empty($count)) { $this->success('检测通过'); } else { $this->error('该广告名称已存在,请检查'); } } } /** * 同步新增广告位置ID到多语言的模板变量里 */ private function syn_add_language_attribute($adp_id) { /*单语言情况下不执行多语言代码*/ if (!is_language() || tpCache('language.language_split')) { return true; } /*--end*/ $attr_group = 'ad_position'; $admin_lang = $this->admin_lang; $main_lang = $this->main_lang; $languageRow = Db::name('language')->field('mark')->order('id asc')->select(); if (!empty($languageRow) && $admin_lang == $main_lang) { // 当前语言是主体语言,即语言列表最早新增的语言 $ad_position_db = Db::name('zczs_position'); $result = $ad_position_db->find($adp_id); $attr_name = 'adp'.$adp_id; $r = Db::name('language_attribute')->save([ 'attr_title' => $result['title'], 'attr_name' => $attr_name, 'attr_group' => $attr_group, 'add_time' => getTime(), 'update_time' => getTime(), ]); if (false !== $r) { $data = []; foreach ($languageRow as $key => $val) { /*同步新广告位置到其他语言广告位置列表*/ if ($val['mark'] != $admin_lang) { $addsaveData = $result; $addsaveData['lang'] = $val['mark']; $addsaveData['title'] = $val['mark'].$addsaveData['title']; unset($addsaveData['id']); $adp_id = $ad_position_db->insertGetId($addsaveData); } /*--end*/ /*所有语言绑定在主语言的ID容器里*/ $data[] = [ 'attr_name' => $attr_name, 'attr_value' => $adp_id, 'lang' => $val['mark'], 'attr_group' => $attr_group, 'add_time' => getTime(), 'update_time' => getTime(), ]; /*--end*/ } if (!empty($data)) { model('LanguageAttr')->saveAll($data); } } } } /** * 同步新增广告ID到多语言的模板变量里 */ private function syn_add_ad_language_attribute($ad_id) { /*单语言情况下不执行多语言代码*/ if (!is_language() || tpCache('language.language_split')) { return true; } /*--end*/ $attr_group = 'ad'; $admin_lang = $this->admin_lang; $main_lang = get_main_lang(); $languageRow = Db::name('language')->field('mark')->order('id asc')->select(); if (!empty($languageRow) && $admin_lang == $main_lang) { // 当前语言是主体语言,即语言列表最早新增的语言 $ad_db = Db::name('zczs'); $result = $ad_db->find($ad_id); $attr_name = 'ad'.$ad_id; $r = Db::name('language_attribute')->save([ 'attr_title' => $result['title'], 'attr_name' => $attr_name, 'attr_group' => $attr_group, 'add_time' => getTime(), 'update_time' => getTime(), ]); if (false !== $r) { $data = []; foreach ($languageRow as $key => $val) { /*同步新广告到其他语言广告列表*/ if ($val['mark'] != $admin_lang) { $addsaveData = $result; $addsaveData['lang'] = $val['mark']; $newPid = Db::name('language_attr')->where([ 'attr_name' => 'adp'.$result['pid'], 'attr_group' => 'ad_position', 'lang' => $val['mark'], ])->getField('attr_value'); $addsaveData['pid'] = $newPid; $addsaveData['title'] = $val['mark'].$addsaveData['title']; unset($addsaveData['id']); $ad_id = $ad_db->insertGetId($addsaveData); } /*--end*/ /*所有语言绑定在主语言的ID容器里*/ $data[] = [ 'attr_name' => $attr_name, 'attr_value' => $ad_id, 'lang' => $val['mark'], 'attr_group' => $attr_group, 'add_time' => getTime(), 'update_time' => getTime(), ]; /*--end*/ } if (!empty($data)) { model('LanguageAttr')->saveAll($data); } } } } }