field($field)->where(array('nav_type'=>'header', 'is_show'=>1, 'pid'=>0))->order('sort')->select()); if(!empty($header)) { foreach($header as $k=>$v) { $header[$k]['item'] = self::NavDataDealWith($m->field($field)->where(array('nav_type'=>'header', 'is_show'=>1, 'pid'=>$v['id']))->order('sort')->select()); } } cache(config('shopxo.cache_common_home_nav_header_key'), $header); } // 底部导航 if(empty($footer)) { $footer = self::NavDataDealWith($m->field($field)->where(array('nav_type'=>'footer', 'is_show'=>1))->order('sort')->select()); cache(config('shopxo.cache_common_home_nav_footer_key'), $footer); } return [ 'header' => $header, 'footer' => $footer, ]; } /** * [NavDataDealWith 导航数据处理] * @author Devil * @blog http://gong.gg/ * @version 0.0.1 * @datetime 2017-02-05T21:36:46+0800 * @param [array] $data [需要处理的数据] * @return [array] [处理好的数据] */ public static function NavDataDealWith($data) { if(!empty($data) && is_array($data)) { foreach($data as $k=>$v) { // url处理 switch($v['data_type']) { // 文章分类 case 'article': $v['url'] = MyUrl('index/article/index', ['id'=>$v['value']]); break; // 自定义页面 case 'customview': $v['url'] = MyUrl('index/customview/index', ['id'=>$v['value']]); break; // 商品分类 case 'goods_category': $v['url'] = MyUrl('index/search/index', ['category_id'=>$v['value']]); break; } $data[$k] = $v; } } return $data; } /** * 获取导航列表 * @author Devil * @blog http://gong.gg/ * @version 1.0.0 * @date 2018-12-18 * @desc description * @param [array] $params [输入参数] */ public static function NavList($params = []) { if(empty($params['nav_type'])) { return []; } $field = 'id,pid,name,url,value,data_type,sort,is_show,is_new_window_open'; $data = self::NavDataDealWith(Db::name('Navigation')->field($field)->where(['nav_type'=>$params['nav_type'], 'pid'=>0])->order('sort')->select()); if(!empty($data)) { foreach($data as &$v) { $v['item'] = self::NavDataDealWith(Db::name('Navigation')->field($field)->where(['nav_type'=>$params['nav_type'], 'pid'=>$v['id']])->order('sort')->select()); } } return $data; } /** * 获取一级导航列表 * @author Devil * @blog http://gong.gg/ * @version 1.0.0 * @date 2018-12-18 * @desc description * @param [array] $params [输入参数] */ public static function LevelOneNav($params = []) { if(empty($params['nav_type'])) { return []; } return Db::name('Navigation')->field('id,name')->where(['is_show'=>1, 'pid'=>0, 'nav_type'=>$params['nav_type']])->select(); } /** * 导航保存 * @author Devil * @blog http://gong.gg/ * @version 0.0.1 * @datetime 2016-12-07T21:58:19+0800 * @param [array] $params [输入参数] */ public static function NavSave($params = []) { if(empty($params['data_type'])) { return DataReturn('操作类型有误', -1); } // 请求类型 $p = [ [ 'checked_type' => 'length', 'key_name' => 'sort', 'checked_data' => '4', 'error_msg' => '顺序 0~255 之间的数值', ], [ 'checked_type' => 'in', 'key_name' => 'is_show', 'checked_data' => [0,1], 'error_msg' => '是否显示范围值有误', ], [ 'checked_type' => 'in', 'key_name' => 'is_new_window_open', 'checked_data' => [0,1], 'error_msg' => '是否新窗口打开范围值有误', ] ]; switch($params['data_type']) { // 自定义导航 case 'custom': $p = [ [ 'checked_type' => 'in', 'key_name' => 'nav_type', 'checked_data' => ['header', 'footer'], 'error_msg' => '数据类型有误', ], [ 'checked_type' => 'length', 'key_name' => 'name', 'checked_data' => '2,16', 'error_msg' => '导航名称格式 2~16 个字符', ], [ 'checked_type' => 'fun', 'key_name' => 'url', 'checked_data' => 'CheckUrl', 'error_msg' => 'url格式有误', ], ]; break; // 文章分类导航 case 'article': $p = [ [ 'checked_type' => 'length', 'key_name' => 'name', 'checked_data' => '2,16', 'is_checked' => 1, 'error_msg' => '导航名称格式 2~16 个字符', ], [ 'checked_type' => 'empty', 'key_name' => 'value', 'error_msg' => '文章选择有误', ], ]; break; // 自定义页面导航 case 'customview': $p = [ [ 'checked_type' => 'length', 'key_name' => 'name', 'checked_data' => '2,16', 'is_checked' => 1, 'error_msg' => '导航名称格式 2~16 个字符', ], [ 'checked_type' => 'empty', 'key_name' => 'value', 'error_msg' => '自定义页面选择有误', ], ]; break; // 商品分类导航 case 'goods_category': $p = [ [ 'checked_type' => 'length', 'key_name' => 'name', 'is_checked' => 1, 'error_msg' => '导航名称格式 2~16 个字符', ], [ 'checked_type' => 'empty', 'key_name' => 'value', 'error_msg' => '商品分类选择有误', ], ]; break; // 没找到 default : return DataReturn('操作类型有误', -1); } // 参数 $ret = ParamsChecked($params, $p); if($ret !== true) { return DataReturn($ret, -1); } // 保存数据 return self::NacDataSave($params); } /** * 导航数据保存 * @author Devil * @blog http://gong.gg/ * @version 0.0.1 * @datetime 2017-02-05T20:12:30+0800 * @param [array] $params [输入参数] */ public static function NacDataSave($params = []) { // 非自定义导航数据处理 if(empty($params['name'])) { switch($params['data_type']) { // 文章分类导航 case 'article': $temp_name = Db::name('Article')->where(['id'=>$params['value']])->value('title'); break; // 自定义页面导航 case 'customview': $temp_name = Db::name('CustomView')->where(['id'=>$params['value']])->value('title'); break; // 商品分类导航 case 'goods_category': $temp_name = Db::name('GoodsCategory')->where(['id'=>$params['value']])->value('name'); break; } // 只截取16个字符 $params['name'] = mb_substr($temp_name, 0, 16, config('shopxo.default_charset')); } // 清除缓存 cache(config('cache_common_home_nav_'.$params['nav_type'].'_key'), null); // 数据 $data = [ 'pid' => isset($params['pid']) ? intval($params['pid']) : 0, 'value' => isset($params['value']) ? intval($params['value']) : 0, 'name' => $params['name'], 'url' => isset($params['url']) ? $params['url'] : '', 'nav_type' => $params['nav_type'], 'data_type' => $params['data_type'], 'sort' => intval($params['sort']), 'is_show' => intval($params['is_show']), 'is_new_window_open' => intval($params['is_new_window_open']), ]; // id为空则表示是新增 if(empty($params['id'])) { $data['add_time'] = time(); if(Db::name('Navigation')->insertGetId($data) > 0) { // 清除缓存 cache(config('cache_common_home_nav_'.$params['nav_type'].'_key'), null); return DataReturn('新增成功', 0); } else { return DataReturn('新增失败', -100); } } else { $data['upd_time'] = time(); if(Db::name('Navigation')->where(['id'=>intval($params['id'])])->update($data)) { // 清除缓存 cache(config('cache_common_home_nav_'.$params['nav_type'].'_key'), null); return DataReturn('编辑成功', 0); } else { return DataReturn('编辑失败或数据未改变', -100); } } } /** * 导航删除 * @author Devil * @blog http://gong.gg/ * @version 1.0.0 * @date 2018-12-18 * @desc description * @param [array] $params [输入参数] */ public static function NavDelete($params = []) { // 请求参数 $p = [ [ 'checked_type' => 'empty', 'key_name' => 'id', 'error_msg' => '操作id有误', ], ]; $ret = ParamsChecked($params, $p); if($ret !== true) { return DataReturn($ret, -1); } // 启动事务 Db::startTrans(); // 删除操作 if(Db::name('Navigation')->where(['id'=>$params['id']])->delete() !== false && Db::name('Navigation')->where(['pid'=>$params['id']])->delete() !== false) { // 提交事务 Db::commit(); // 清除缓存 cache(config('shopxo.cache_common_home_nav_header_key'), null); cache(config('shopxo.cache_common_home_nav_footer_key'), null); return DataReturn('删除成功'); } // 回滚事务 Db::rollback(); return DataReturn('删除失败或资源不存在', -100); } /** * 状态更新 * @author Devil * @blog http://gong.gg/ * @version 0.0.1 * @datetime 2016-12-06T21:31:53+0800 * @param [array] $params [输入参数] */ public static function NavStatusUpdate($params = []) { // 请求参数 $p = [ [ 'checked_type' => 'empty', 'key_name' => 'id', 'error_msg' => '操作id有误', ], [ 'checked_type' => 'in', 'key_name' => 'state', 'checked_data' => [0,1], 'error_msg' => '状态有误', ], ]; $ret = ParamsChecked($params, $p); if($ret !== true) { return DataReturn($ret, -1); } // 数据更新 if(Db::name('Navigation')->where(['id'=>intval($params['id'])])->update(['is_show'=>intval($params['state'])])) { // 清除缓存 cache(config('shopxo.cache_common_home_nav_header_key'), null); cache(config('shopxo.cache_common_home_nav_footer_key'), null); return DataReturn('编辑成功'); } return DataReturn('编辑失败或数据未改变', -100); } } ?>