table("brand"), $db, 'brand_id', 'brand_name'); /*------------------------------------------------------ */ //-- 品牌列表 /*------------------------------------------------------ */ if ($_REQUEST['act'] == 'list') { $smarty->assign('ur_here', $_LANG['06_goods_brand_list']); $smarty->assign('action_link', array('text' => $_LANG['07_brand_add'], 'href' => 'brand.php?act=add')); $smarty->assign('full_page', 1); $brand_list = get_brandlist(); $smarty->assign('brand_list', $brand_list['brand']); $smarty->assign('filter', $brand_list['filter']); $smarty->assign('record_count', $brand_list['record_count']); $smarty->assign('page_count', $brand_list['page_count']); assign_query_info(); $smarty->display('brand_list.htm'); } /*------------------------------------------------------ */ //-- 添加品牌 /*------------------------------------------------------ */ elseif ($_REQUEST['act'] == 'add') { /* 权限判断 */ admin_priv('brand_manage'); $smarty->assign('ur_here', $_LANG['07_brand_add']); $smarty->assign('action_link', array('text' => $_LANG['06_goods_brand_list'], 'href' => 'brand.php?act=list')); $smarty->assign('form_action', 'insert'); assign_query_info(); $smarty->assign('brand', array('sort_order'=>50, 'is_show'=>1)); $smarty->display('brand_info.htm'); } elseif ($_REQUEST['act'] == 'insert') { /*检查品牌名是否重复*/ admin_priv('brand_manage'); $is_show = isset($_REQUEST['is_show']) ? intval($_REQUEST['is_show']) : 0; $is_only = $exc->is_only('brand_name', $_POST['brand_name']); if (!$is_only) { sys_msg(sprintf($_LANG['brandname_exist'], stripslashes($_POST['brand_name'])), 1); } /*对描述处理*/ if (!empty($_POST['brand_desc'])) { $_POST['brand_desc'] = $_POST['brand_desc']; } /*处理图片*/ $img_name = basename($image->upload_image($_FILES['brand_logo'],'brandlogo')); get_oss_add_file(array(DATA_DIR . '/brandlogo/' . $img_name)); /*处理URL*/ $site_url = sanitize_url( $_POST['site_url'] ); /*插入数据*/ $sql = "INSERT INTO ".$ecs->table('brand')."(brand_name, brand_letter, site_url, brand_desc, brand_logo, is_show, sort_order) ". "VALUES ('$_POST[brand_name]', '$_POST[brand_letter]', '$site_url', '$_POST[brand_desc]', '$img_name', '$is_show', '$_POST[sort_order]')"; $db->query($sql); if($brand_id=$db->insert_id()) { $is_recommend=!empty($_POST['is_recommend'])?intval($_POST['is_recommend']):0; $extend_sql="INSERT INTO ".$ecs->table('brand_extend')." (brand_id,is_recommend) values ('$brand_id','$is_recommend')"; $db->query($extend_sql); } admin_log($_POST['brand_name'],'add','brand'); /* 清除缓存 */ clear_cache_files(); $link[0]['text'] = $_LANG['continue_add']; $link[0]['href'] = 'brand.php?act=add'; $link[1]['text'] = $_LANG['back_list']; $link[1]['href'] = 'brand.php?act=list'; sys_msg($_LANG['brandadd_succed'], 0, $link); } /*------------------------------------------------------ */ //-- 编辑品牌 /*------------------------------------------------------ */ elseif ($_REQUEST['act'] == 'edit') { /* 权限判断 */ admin_priv('brand_manage'); $sql = "SELECT b.brand_id, b.brand_name, b.brand_letter, b.site_url, b.brand_logo, b.brand_desc, b.brand_logo, b.is_show, b.sort_order,be.is_recommend ". "FROM " .$ecs->table('brand'). " as b left join ".$ecs->table('brand_extend')." as be on b.brand_id=be.brand_id WHERE b.brand_id='$_REQUEST[id]'"; $brand = $db->GetRow($sql); $smarty->assign('ur_here', $_LANG['brand_edit']); $smarty->assign('action_link', array('text' => $_LANG['06_goods_brand_list'], 'href' => 'brand.php?act=list&' . list_link_postfix())); $smarty->assign('brand', $brand); $smarty->assign('form_action', 'updata'); assign_query_info(); $smarty->display('brand_info.htm'); } elseif ($_REQUEST['act'] == 'updata') { admin_priv('brand_manage'); if ($_POST['brand_name'] != $_POST['old_brandname']) { /*检查品牌名是否相同*/ $is_only = $exc->is_only('brand_name', $_POST['brand_name'], $_POST['id']); if (!$is_only) { sys_msg(sprintf($_LANG['brandname_exist'], stripslashes($_POST['brand_name'])), 1); } } /*对描述处理*/ if (!empty($_POST['brand_desc'])) { $_POST['brand_desc'] = $_POST['brand_desc']; } $is_show = isset($_REQUEST['is_show']) ? intval($_REQUEST['is_show']) : 0; /*处理URL*/ $site_url = sanitize_url( $_POST['site_url'] ); /* 处理图片 */ $img_name = basename($image->upload_image($_FILES['brand_logo'],'brandlogo')); $param = "brand_name = '$_POST[brand_name]', brand_letter = '$_POST[brand_letter]', site_url='$site_url', brand_desc='$_POST[brand_desc]', is_show='$is_show', sort_order='$_POST[sort_order]' "; if (!empty($img_name)) { //有图片上传 $param .= " ,brand_logo = '$img_name' "; } get_oss_add_file(array(DATA_DIR . '/brandlogo/' . $img_name)); if ($exc->edit($param, $_POST['id'])) { $brand_id=!empty($_POST['id'])?intval($_POST['id']):0; if($brand_id>0) { $is_recommend=!empty($_POST['is_recommend'])?intval($_POST['is_recommend']):0; if($db->query("select count(id) from ".$ecs->table('brand_extend')." where brand_id='$brand_id'")) { $extend_sql="update ".$ecs->table('brand_extend')." set is_recommend='$is_recommend' where brand_id='$brand_id'"; } else { $extend_sql="INSERT INTO ".$ecs->table('brand_extend')." (brand_id,is_recommend) values ('$brand_id','$is_recommend')"; } $db->query($extend_sql); } /* 清除缓存 */ clear_cache_files(); admin_log($_POST['brand_name'], 'edit', 'brand'); $link[0]['text'] = $_LANG['back_list']; $link[0]['href'] = 'brand.php?act=list&' . list_link_postfix(); $note = vsprintf($_LANG['brandedit_succed'], $_POST['brand_name']); sys_msg($note, 0, $link); } else { die($db->error()); } } /*------------------------------------------------------ */ //-- 编辑品牌中文名称 /*------------------------------------------------------ */ elseif ($_REQUEST['act'] == 'edit_brand_name') { check_authz_json('brand_manage'); $id = intval($_POST['id']); $name = json_str_iconv(trim($_POST['val'])); /* 检查名称是否重复 */ if ($exc->num("brand_name",$name, $id) != 0) { make_json_error(sprintf($_LANG['brandname_exist'], $name)); } else { if ($exc->edit("brand_name = '$name'", $id)) { admin_log($name,'edit','brand'); make_json_result(stripslashes($name)); } else { make_json_result(sprintf($_LANG['brandedit_fail'], $name)); } } } /*------------------------------------------------------ */ //-- 编辑品牌英文名称 /*------------------------------------------------------ */ elseif ($_REQUEST['act'] == 'edit_brand_letter') { check_authz_json('brand_manage'); $id = intval($_POST['id']); $name = json_str_iconv(trim($_POST['val'])); /* 检查名称是否重复 */ if ($exc->num("brand_letter",$name, $id) != 0) { make_json_error(sprintf($_LANG['brandname_exist'], $name)); } else { if ($exc->edit("brand_letter = '$name'", $id)) { admin_log($name,'edit','brand'); make_json_result(stripslashes($name)); } else { make_json_result(sprintf($_LANG['brandedit_fail'], $name)); } } } elseif($_REQUEST['act'] == 'add_brand') { $brand = empty($_REQUEST['brand']) ? '' : json_str_iconv(trim($_REQUEST['brand'])); if(brand_exists($brand)) { make_json_error($_LANG['brand_name_exist']); } else { $sql = "INSERT INTO " . $ecs->table('brand') . "(brand_name)" . "VALUES ( '$brand')"; $db->query($sql); $brand_id = $db->insert_id(); $arr = array("id"=>$brand_id, "brand"=>$brand); make_json_result($arr); } } /*------------------------------------------------------ */ //-- 编辑排序序号 /*------------------------------------------------------ */ elseif ($_REQUEST['act'] == 'edit_sort_order') { check_authz_json('brand_manage'); $id = intval($_POST['id']); $order = intval($_POST['val']); $name = $exc->get_name($id); if ($exc->edit("sort_order = '$order'", $id)) { admin_log(addslashes($name),'edit','brand'); make_json_result($order); } else { make_json_error(sprintf($_LANG['brandedit_fail'], $name)); } } /*------------------------------------------------------ */ //-- 切换是否显示 /*------------------------------------------------------ */ elseif ($_REQUEST['act'] == 'toggle_show') { check_authz_json('brand_manage'); $id = intval($_POST['id']); $val = intval($_POST['val']); $exc->edit("is_show='$val'", $id); make_json_result($val); } /*------------------------------------------------------ */ //-- 切换是否显示 /*------------------------------------------------------ */ elseif ($_REQUEST['act'] == 'toggle_recommend') { check_authz_json('brand_manage'); $brand_id = intval($_POST['id']); $is_recommend = intval($_POST['val']); if($db->getOne("select count(id) from ".$ecs->table('brand_extend')." where brand_id='$brand_id'")) { $extend_sql="update ".$ecs->table('brand_extend')." set is_recommend='$is_recommend' where brand_id='$brand_id'"; } else { $extend_sql="INSERT INTO ".$ecs->table('brand_extend')." (brand_id,is_recommend) values ('$brand_id','$is_recommend')"; } $db->query($extend_sql); make_json_result($is_recommend); } /*------------------------------------------------------ */ //-- 删除品牌 /*------------------------------------------------------ */ elseif ($_REQUEST['act'] == 'remove') { check_authz_json('brand_manage'); $id = intval($_GET['id']); get_del_batch('', $id, array('brand_logo'), 'brand_id', 'brand', 0, DATA_DIR . '/brandlogo/'); //删除图片 $exc->drop($id); /* 更新商品的品牌编号 */ $sql = "UPDATE " .$ecs->table('goods'). " SET brand_id=0 WHERE brand_id='$id'"; $db->query($sql); $url = 'brand.php?act=query&' . str_replace('act=remove', '', $_SERVER['QUERY_STRING']); ecs_header("Location: $url\n"); exit; } /*------------------------------------------------------ */ //-- 删除品牌图片 /*------------------------------------------------------ */ elseif ($_REQUEST['act'] == 'drop_logo') { /* 权限判断 */ admin_priv('brand_manage'); $brand_id = isset($_GET['id']) ? intval($_GET['id']) : 0; get_del_batch('', $brand_id, array('brand_logo'), 'brand_id', 'brand', 0, DATA_DIR . '/brandlogo/'); //删除图片 $sql = "UPDATE " .$ecs->table('brand'). " SET brand_logo = '' WHERE brand_id = '$brand_id'"; $db->query($sql); $link= array(array('text' => $_LANG['brand_edit_lnk'], 'href' => 'brand.php?act=edit&id=' . $brand_id), array('text' => $_LANG['brand_list_lnk'], 'href' => 'brand.php?act=list')); sys_msg($_LANG['drop_brand_logo_success'], 0, $link); } /*------------------------------------------------------ */ //-- 排序、分页、查询 /*------------------------------------------------------ */ elseif ($_REQUEST['act'] == 'query') { $brand_list = get_brandlist(); $smarty->assign('brand_list', $brand_list['brand']); $smarty->assign('filter', $brand_list['filter']); $smarty->assign('record_count', $brand_list['record_count']); $smarty->assign('page_count', $brand_list['page_count']); make_json_result($smarty->fetch('brand_list.htm'), '', array('filter' => $brand_list['filter'], 'page_count' => $brand_list['page_count'])); } /** * 获取品牌列表 * * @access public * @return array */ function get_brandlist() { $result = get_filter(); if ($result === false) { /* 分页大小 */ $filter = array(); $filter['sort_by'] = empty($_REQUEST['sort_by']) ? 'brand_id' : trim($_REQUEST['sort_by']); $filter['sort_order'] = empty($_REQUEST['sort_order']) ? 'DESC' : trim($_REQUEST['sort_order']); /* 记录总数以及页数 */ if (isset($_POST['brand_name'])) { $sql = "SELECT COUNT(*) FROM ".$GLOBALS['ecs']->table('brand') .' WHERE brand_name = \''.$_POST['brand_name'].'\''; } else { $sql = "SELECT COUNT(*) FROM ".$GLOBALS['ecs']->table('brand'); } $filter['record_count'] = $GLOBALS['db']->getOne($sql); $filter = page_and_size($filter); $leftjoin=" left join ".$GLOBALS['ecs']->table('brand_extend')." as be on b.brand_id=be.brand_id "; /* 查询记录 */ if (isset($_POST['brand_name'])) { if(strtoupper(EC_CHARSET) == 'GBK') { $keyword = iconv("UTF-8", "gb2312", $_POST['brand_name']); } else { $keyword = $_POST['brand_name']; } $sql = "SELECT b.*,be.is_recommend FROM ".$GLOBALS['ecs']->table('brand')." as b ".$leftjoin." WHERE brand_name like '%{$keyword}%' ORDER BY $filter[sort_by] $filter[sort_order]"; } else { $sql = "SELECT b.*,be.is_recommend FROM ".$GLOBALS['ecs']->table('brand')." as b ".$leftjoin." where 1 ORDER BY $filter[sort_by] $filter[sort_order]"; } set_filter($filter, $sql); } else { $sql = $result['sql']; $filter = $result['filter']; } $res = $GLOBALS['db']->selectLimit($sql, $filter['page_size'], $filter['start']); $arr = array(); while ($rows = $GLOBALS['db']->fetchRow($res)) { $brand_logo = empty($rows['brand_logo']) ? '' : '.$GLOBALS['; $site_url = empty($rows['site_url']) ? 'N/A' : ''.$rows['site_url'].''; $rows['brand_logo'] = $brand_logo; $rows['site_url'] = $site_url; $arr[] = $rows; } return array('brand' => $arr, 'filter' => $filter, 'page_count' => $filter['page_count'], 'record_count' => $filter['record_count']); } ?>