table('comment')." WHERE id_value = '$goods_id' AND comment_type=0 AND status = 1 AND parent_id = 0 AND (comment_rank = 4 OR comment_rank = 5)";
$haoping_count = $GLOBALS['db']->getOne($sql);
$sql = 'SELECT COUNT(*) AS zhongping FROM '.$GLOBALS['ecs']->table('comment')." WHERE id_value = '$goods_id' AND comment_type=0 AND status = 1 AND parent_id = 0 AND (comment_rank = 2 OR comment_rank = 3)";
$zhongping_count = $GLOBALS['db']->getOne($sql);
$sql = 'SELECT COUNT(*) AS chaping FROM '.$GLOBALS['ecs']->table('comment')." WHERE id_value = '$goods_id' AND comment_type=0 AND status = 1 AND parent_id = 0 AND comment_rank = 1";
$chaping_count = $GLOBALS['db']->getOne($sql);
$sql = 'SELECT COUNT(*) AS comment_count FROM '.$GLOBALS['ecs']->table('comment')." WHERE id_value = '$goods_id' AND comment_type=0 AND status = 1 AND parent_id = 0";
$comment_count = $GLOBALS['db']->getOne($sql);
$arr['haoping_percent'] = $comment_count?round(($haoping_count/$comment_count)*100) : 0;
$arr['zhongping_percent'] = $comment_count?round(($zhongping_count/$comment_count)*100) : 0;
$arr['chaping_percent'] = $comment_count?round(($chaping_count/$comment_count)*100) : 0;
$arr['comment_count'] = $comment_count ? $comment_count : 0;
if($comment_count == 0)
{
$arr['haoping_percent'] = 100;
}
foreach($arr as $key => $val)
{
if($val == 0.0)
{
$arr[$key] = 0;
}
}
return $arr;
}
function get_related_cat($cat_id)
{
$sql = 'SELECT parent_id FROM '.$GLOBALS['ecs']->table('category')." WHERE cat_id = '$cat_id' ";
$parent_id = $GLOBALS['db']->getOne($sql);
$sql = 'SELECT cat_id,cat_name FROM '.$GLOBALS['ecs']->table('category')." WHERE parent_id = '$parent_id' AND cat_id != '$cat_id'";
$res = $GLOBALS['db']->getAll($sql);
$arr = array();
if($res != '')
{
foreach($res as $idx=>$row)
{
$arr[$idx]['cat_name'] = $row['cat_name'];
$arr[$idx]['url'] = build_uri('category', array('cid' => $row['cat_id']), $row['cat_name']);
}
}
return $arr;
}
function get_related_brand($cat_id)
{
$children = get_children($cat_id);
/* 品牌篩選 */
$sql = "SELECT b.brand_id, b.brand_name,b.brand_logo, COUNT(*) AS goods_num ".
"FROM " . $GLOBALS['ecs']->table('brand') . "AS b, ".
$GLOBALS['ecs']->table('goods') . " AS g LEFT JOIN ". $GLOBALS['ecs']->table('goods_cat') . " AS gc ON g.goods_id = gc.goods_id " .
"WHERE g.brand_id = b.brand_id AND ($children OR " . 'gc.cat_id ' . db_create_in(array_unique(array_merge(array($cat_id), array_keys(cat_list($cat_id, 0, false))))) . ") AND b.is_show = 1 " .
" AND g.is_on_sale = 1 AND g.is_alone_sale = 1 AND g.is_delete = 0 ".
"GROUP BY b.brand_id HAVING goods_num > 0 ORDER BY b.sort_order, b.brand_id ASC";
$brands = $GLOBALS['db']->getAll($sql);
foreach ($brands AS $key => $val)
{
$temp_key = $key + 1;
$brands[$temp_key]['brand_name'] = $val['brand_name'];
$brands[$temp_key]['url'] = build_uri('category', array('cid' => $cat_id, 'bid' => $val['brand_id'], 'price_min'=>$price_min, 'price_max'=> $price_max, 'filter_attr'=>$filter_attr_str), $cat['cat_name']);
/* 判斷品牌是否被選中 */
if ($brand == $brands[$key]['brand_id'])
{
$brands[$temp_key]['selected'] = 1;
}
else
{
$brands[$temp_key]['selected'] = 0;
}
$brands[$temp_key]['logo'] = !empty($val['brand_logo']) ? 'data/brandlogo/'.$val['brand_logo'] : '';
}
$brands[0]['brand_name'] = $_LANG['all_attribute'];
$brands[0]['url'] = build_uri('category', array('cid' => $cat_id, 'bid' => 0, 'price_min'=>$price_min, 'price_max'=> $price_max, 'filter_attr'=>$filter_attr_str), $cat['cat_name']);
$brands[0]['selected'] = empty($brand) ? 1 : 0;
unset($brands[0]);
return $brands;
}
/**
* 創建像這樣的查詢: "IN('a','b')";
*
* @access public
* @param mix $item_list 列表數組或字符串
* @param string $field_name 字段名稱
*
* @return void
*/
function db_create_in($item_list, $field_name = '')
{
if (empty($item_list))
{
return $field_name . " IN ('') ";
}
else
{
if (!is_array($item_list))
{
$item_list = explode(',', $item_list);
}
$item_list = array_unique($item_list);
$item_list_tmp = '';
foreach ($item_list AS $item)
{
if ($item !== '')
{
$item_list_tmp .= $item_list_tmp ? ",'$item'" : "'$item'";
}
}
if (empty($item_list_tmp))
{
return $field_name . " IN ('') ";
}
else
{
return $field_name . ' IN (' . $item_list_tmp . ') ';
}
}
}
/**
* 驗證輸入的郵件地址是否合法
*
* @access public
* @param string $email 需要驗證的郵件地址
*
* @return bool
*/
function is_email($user_email)
{
$chars = "/^([a-z0-9+_]|\\-|\\.)+@(([a-z0-9_]|\\-)+\\.)+[a-z]{2,6}\$/i";
if (strpos($user_email, '@') !== false && strpos($user_email, '.') !== false)
{
if (preg_match($chars, $user_email))
{
return true;
}
else
{
return false;
}
}
else
{
return false;
}
}
/**
* 檢查是否為一個合法的時間格式
*
* @access public
* @param string $time
* @return void
*/
function is_time($time)
{
$pattern = '/[\d]{4}-[\d]{1,2}-[\d]{1,2}\s[\d]{1,2}:[\d]{1,2}:[\d]{1,2}/';
return preg_match($pattern, $time);
}
/**
* 獲得查詢時間和次數,並賦值給smarty
*
* @access public
* @return void
*/
function assign_query_info()
{
if ($GLOBALS['db']->queryTime == '')
{
$query_time = 0;
}
else
{
if (PHP_VERSION >= '5.0.0')
{
$query_time = number_format(microtime(true) - $GLOBALS['db']->queryTime, 6);
}
else
{
list($now_usec, $now_sec) = explode(' ', microtime());
list($start_usec, $start_sec) = explode(' ', $GLOBALS['db']->queryTime);
$query_time = number_format(($now_sec - $start_sec) + ($now_usec - $start_usec), 6);
}
}
$GLOBALS['smarty']->assign('query_info', sprintf($GLOBALS['_LANG']['query_info'], $GLOBALS['db']->queryCount, $query_time));
/* 內存佔用情況 */
if ($GLOBALS['_LANG']['memory_info'] && function_exists('memory_get_usage'))
{
$GLOBALS['smarty']->assign('memory_info', sprintf($GLOBALS['_LANG']['memory_info'], memory_get_usage() / 1048576));
}
/* 是否啓用了 gzip */
$gzip_enabled = gzip_enabled() ? $GLOBALS['_LANG']['gzip_enabled'] : $GLOBALS['_LANG']['gzip_disabled'];
$GLOBALS['smarty']->assign('gzip_enabled', $gzip_enabled);
}
/**
* 創建地區的返回信息
*
* @access public
* @param array $arr 地區數組 *
* @return void
*/
function region_result($parent, $sel_name, $type)
{
global $cp;
$arr = get_regions($type, $parent);
foreach ($arr AS $v)
{
$region =& $cp->add_node('region');
$region_id =& $region->add_node('id');
$region_name =& $region->add_node('name');
$region_id->set_data($v['region_id']);
$region_name->set_data($v['region_name']);
}
$select_obj =& $cp->add_node('select');
$select_obj->set_data($sel_name);
}
/**
* 獲得指定國家的所有省份
*
* @access public
* @param int country 國家的編號
* @return array
*/
function get_regions($type = 0, $parent = 0)
{
$sql = 'SELECT region_id, region_name FROM ' . $GLOBALS['ecs']->table('region') .
" WHERE region_type = '$type' AND parent_id = '$parent'";
return $GLOBALS['db']->GetAll($sql);
}
/**
* 獲得配送區域中指定的配送方式的配送費用的計算參數
*
* @access public
* @param int $area_id 配送區域ID
*
* @return array;
*/
function get_shipping_config($area_id)
{
/* 獲得配置信息 */
$sql = 'SELECT configure FROM ' . $GLOBALS['ecs']->table('shipping_area') . " WHERE shipping_area_id = '$area_id'";
$cfg = $GLOBALS['db']->GetOne($sql);
if ($cfg)
{
/* 拆分成配置信息的數組 */
$arr = unserialize($cfg);
}
else
{
$arr = array();
}
return $arr;
}
/**
* 初始化客戶數據整合類
*
* @access public
* @return object
*/
function init_users()
{
$set_modules = false;
static $cls = null;
if ($cls != null)
{
return $cls;
}
include_once(ROOT_PATH . 'includes/modules/integrates/' . $GLOBALS['_CFG']['integrate_code'] . '.php');
$cfg = unserialize($GLOBALS['_CFG']['integrate_config']);
$cls = new $GLOBALS['_CFG']['integrate_code']($cfg);
return $cls;
}
/**
* 獲得指定分類下的子分類的數組
*
* @access public
* @param int $cat_id 分類的ID
* @param int $selected 當前選中分類的ID
* @param boolean $re_type 返回的類型: 值為真時返回下拉列表,否則返回數組
* @param int $level 限定返回的級數。為0時返回所有級數
* @param int $is_show_all 如果為true顯示所有分類,如果為false隱藏不可見分類。
* @return mix
*/
function cat_list($cat_id = 0, $selected = 0, $re_type = true, $level = 0, $is_show_all = true)
{
static $res = NULL;
if ($res === NULL)
{
// $data = read_static_cache('cat_pid_releate');
$data = false;
if ($data === false)
{
$sql = "SELECT c.cat_id, c.cat_name, c.cat_ico, c.measure_unit, c.parent_id, c.is_show, c.show_in_nav, c.grade, c.sort_order, COUNT(s.cat_id) AS has_children ".
'FROM ' . $GLOBALS['ecs']->table('category') . " AS c ".
"LEFT JOIN " . $GLOBALS['ecs']->table('category') . " AS s ON s.parent_id=c.cat_id ".
"GROUP BY c.cat_id ".
'ORDER BY c.parent_id, c.sort_order ASC, c.cat_id ASC';
$res = $GLOBALS['db']->getAll($sql);
$sql = "SELECT cat_id, COUNT(*) AS goods_num " .
" FROM " . $GLOBALS['ecs']->table('goods') .
" WHERE is_delete = 0 AND is_on_sale = 1 " .
" GROUP BY cat_id";
$res2 = $GLOBALS['db']->getAll($sql);
$sql = "SELECT gc.cat_id, COUNT(*) AS goods_num " .
" FROM " . $GLOBALS['ecs']->table('goods_cat') . " AS gc , " . $GLOBALS['ecs']->table('goods') . " AS g " .
" WHERE g.goods_id = gc.goods_id AND g.is_delete = 0 AND g.is_on_sale = 1 " .
" GROUP BY gc.cat_id";
$res3 = $GLOBALS['db']->getAll($sql);
$newres = array();
foreach($res2 as $k=>$v)
{
$newres[$v['cat_id']] = $v['goods_num'];
foreach($res3 as $ks=>$vs)
{
if($v['cat_id'] == $vs['cat_id'])
{
$newres[$v['cat_id']] = $v['goods_num'] + $vs['goods_num'];
}
}
}
foreach($res as $k=>$v)
{
$res[$k]['goods_num'] = !empty($newres[$v['cat_id']]) ? $newres[$v['cat_id']] : 0;
}
//如果數組過大,不採用靜態緩存方式
if (count($res) <= 1000)
{
write_static_cache('cat_pid_releate', $res);
}
}
else
{
$res = $data;
}
}
if (empty($res) == true)
{
return $re_type ? '' : array();
}
$options = cat_options($cat_id, $res); // 獲得指定分類下的子分類的數組
$children_level = 99999; //大於這個分類的將被刪除
if ($is_show_all == false)
{
foreach ($options as $key => $val)
{
if ($val['level'] > $children_level)
{
unset($options[$key]);
}
else
{
if ($val['is_show'] == 0)
{
unset($options[$key]);
if ($children_level > $val['level'])
{
$children_level = $val['level']; //標記一下,這樣子分類也能刪除
}
}
else
{
$children_level = 99999; //恢復初始值
}
}
}
}
/* 截取到指定的縮減級別 */
if ($level > 0)
{
if ($cat_id == 0)
{
$end_level = $level;
}
else
{
$first_item = reset($options); // 獲取第一個元素
$end_level = $first_item['level'] + $level;
}
/* 保留level小於end_level的部分 */
foreach ($options AS $key => $val)
{
if ($val['level'] >= $end_level)
{
unset($options[$key]);
}
}
}
if ($re_type == true)
{
$select = '';
foreach ($options AS $var)
{
$select .= '';
}
return $select;
}
else
{
foreach ($options AS $key => $value)
{
$options[$key]['url'] = build_uri('category', array('cid' => $value['cat_id']), $value['cat_name']);
}
return $options;
}
}
/**
* 過濾和排序所有分類,返回一個帶有縮進級別的數組
*
* @access private
* @param int $cat_id 上級分類ID
* @param array $arr 含有所有分類的數組
* @param int $level 級別
* @return void
*/
function cat_options($spec_cat_id, $arr)
{
static $cat_options = array();
if (isset($cat_options[$spec_cat_id]))
{
return $cat_options[$spec_cat_id];
}
if (!isset($cat_options[0]))
{
$level = $last_cat_id = 0;
$options = $cat_id_array = $level_array = array();
$data = read_static_cache('cat_option_static');
if ($data === false)
{
while (!empty($arr))
{
foreach ($arr AS $key => $value)
{
$cat_id = $value['cat_id'];
if ($level == 0 && $last_cat_id == 0)
{
if ($value['parent_id'] > 0)
{
break;
}
$options[$cat_id] = $value;
$options[$cat_id]['level'] = $level;
$options[$cat_id]['id'] = $cat_id;
$options[$cat_id]['name'] = $value['cat_name'];
unset($arr[$key]);
if ($value['has_children'] == 0)
{
continue;
}
$last_cat_id = $cat_id;
$cat_id_array = array($cat_id);
$level_array[$last_cat_id] = ++$level;
continue;
}
if ($value['parent_id'] == $last_cat_id)
{
$options[$cat_id] = $value;
$options[$cat_id]['level'] = $level;
$options[$cat_id]['id'] = $cat_id;
$options[$cat_id]['name'] = $value['cat_name'];
unset($arr[$key]);
if ($value['has_children'] > 0)
{
if (end($cat_id_array) != $last_cat_id)
{
$cat_id_array[] = $last_cat_id;
}
$last_cat_id = $cat_id;
$cat_id_array[] = $cat_id;
$level_array[$last_cat_id] = ++$level;
}
}
elseif ($value['parent_id'] > $last_cat_id)
{
break;
}
}
$count = count($cat_id_array);
if ($count > 1)
{
$last_cat_id = array_pop($cat_id_array);
}
elseif ($count == 1)
{
if ($last_cat_id != end($cat_id_array))
{
$last_cat_id = end($cat_id_array);
}
else
{
$level = 0;
$last_cat_id = 0;
$cat_id_array = array();
continue;
}
}
if ($last_cat_id && isset($level_array[$last_cat_id]))
{
$level = $level_array[$last_cat_id];
}
else
{
$level = 0;
}
}
//如果數組過大,不採用靜態緩存方式
if (count($options) <= 2000)
{
write_static_cache('cat_option_static', $options);
}
}
else
{
$options = $data;
}
$cat_options[0] = $options;
}
else
{
$options = $cat_options[0];
}
if (!$spec_cat_id)
{
return $options;
}
else
{
if (empty($options[$spec_cat_id]))
{
return array();
}
$spec_cat_id_level = $options[$spec_cat_id]['level'];
foreach ($options AS $key => $value)
{
if ($key != $spec_cat_id)
{
unset($options[$key]);
}
else
{
break;
}
}
$spec_cat_id_array = array();
foreach ($options AS $key => $value)
{
if (($spec_cat_id_level == $value['level'] && $value['cat_id'] != $spec_cat_id) ||
($spec_cat_id_level > $value['level']))
{
break;
}
else
{
$spec_cat_id_array[$key] = $value;
}
}
$cat_options[$spec_cat_id] = $spec_cat_id_array;
return $spec_cat_id_array;
}
}
/**
* 載入配置信息
*
* @access public
* @return array
*/
function load_config()
{
$arr = array();
$data = read_static_cache('shop_config');
if ($data === false)
{
$sql = 'SELECT code, value FROM ' . $GLOBALS['ecs']->table('shop_config') . ' WHERE parent_id > 0';
$res = $GLOBALS['db']->getAll($sql);
foreach ($res AS $row)
{
$arr[$row['code']] = $row['value'];
}
/* 對數值型設置處理 */
$arr['watermark_alpha'] = intval($arr['watermark_alpha']);
$arr['market_price_rate'] = floatval($arr['market_price_rate']);
$arr['integral_scale'] = floatval($arr['integral_scale']);
//$arr['integral_percent'] = floatval($arr['integral_percent']);
$arr['cache_time'] = intval($arr['cache_time']);
$arr['thumb_width'] = intval($arr['thumb_width']);
$arr['thumb_height'] = intval($arr['thumb_height']);
$arr['image_width'] = intval($arr['image_width']);
$arr['image_height'] = intval($arr['image_height']);
$arr['best_number'] = !empty($arr['best_number']) && intval($arr['best_number']) > 0 ? intval($arr['best_number']) : 3;
$arr['new_number'] = !empty($arr['new_number']) && intval($arr['new_number']) > 0 ? intval($arr['new_number']) : 3;
$arr['hot_number'] = !empty($arr['hot_number']) && intval($arr['hot_number']) > 0 ? intval($arr['hot_number']) : 3;
$arr['promote_number'] = !empty($arr['promote_number']) && intval($arr['promote_number']) > 0 ? intval($arr['promote_number']) : 3;
$arr['top_number'] = intval($arr['top_number']) > 0 ? intval($arr['top_number']) : 10;
$arr['history_number'] = intval($arr['history_number']) > 0 ? intval($arr['history_number']) : 5;
$arr['comments_number'] = intval($arr['comments_number']) > 0 ? intval($arr['comments_number']) : 5;
$arr['article_number'] = intval($arr['article_number']) > 0 ? intval($arr['article_number']) : 5;
$arr['page_size'] = intval($arr['page_size']) > 0 ? intval($arr['page_size']) : 10;
$arr['bought_goods'] = intval($arr['bought_goods']);
$arr['goods_name_length'] = intval($arr['goods_name_length']);
$arr['top10_time'] = intval($arr['top10_time']);
$arr['goods_gallery_number'] = intval($arr['goods_gallery_number']) ? intval($arr['goods_gallery_number']) : 5;
$arr['no_picture'] = !empty($arr['no_picture']) ? str_replace('../', './', $arr['no_picture']) : 'images/no_picture.gif'; // 修改默認產品圖片的路徑
$arr['qq'] = !empty($arr['qq']) ? $arr['qq'] : '';
$arr['ww'] = !empty($arr['ww']) ? $arr['ww'] : '';
$arr['default_storage'] = isset($arr['default_storage']) ? intval($arr['default_storage']) : 1;
$arr['min_goods_amount'] = isset($arr['min_goods_amount']) ? floatval($arr['min_goods_amount']) : 0;
$arr['one_step_buy'] = empty($arr['one_step_buy']) ? 0 : 1;
$arr['invoice_type'] = empty($arr['invoice_type']) ? array('type' => array(), 'rate' => array()) : unserialize($arr['invoice_type']);
$arr['show_order_type'] = isset($arr['show_order_type']) ? $arr['show_order_type'] : 0; // 顯示方式默認為列表方式
$arr['help_open'] = isset($arr['help_open']) ? $arr['help_open'] : 1; // 顯示方式默認為列表方式
if (!isset($GLOBALS['_CFG']['ecs_version']))
{
/* 如果沒有版本號則默認為2.0.5 */
$GLOBALS['_CFG']['ecs_version'] = 'v2.0.5';
}
//限定語言項
$lang_array = array('zh_cn', 'zh_tw', 'en_us');
if (empty($arr['lang']) || !in_array($arr['lang'], $lang_array))
{
$arr['lang'] = 'zh_cn'; // 默認語言為簡體中文
}
if (empty($arr['integrate_code']))
{
$arr['integrate_code'] = 'shop'; // 默認的客戶整合插件為 shop
}
write_static_cache('shop_config', $arr);
}
else
{
$arr = $data;
}
return $arr;
}
function load_config_mobile()
{
$arr = array();
$data = false;
if ($data === false)
{
$sql = 'SELECT code, value FROM ' . $GLOBALS['ecs']->table('touch_shop_config') . ' WHERE parent_id > 0';
$res = $GLOBALS['db']->getAll($sql);
foreach ($res AS $row)
{
$arr[$row['code']] = $row['value'];
}
/* 對數值型設置處理 */
$arr['watermark_alpha'] = intval($arr['watermark_alpha']);
$arr['market_price_rate'] = floatval($arr['market_price_rate']);
$arr['integral_scale'] = floatval($arr['integral_scale']);
//$arr['integral_percent'] = floatval($arr['integral_percent']);
$arr['cache_time'] = intval($arr['cache_time']);
$arr['thumb_width'] = intval($arr['thumb_width']);
$arr['thumb_height'] = intval($arr['thumb_height']);
$arr['image_width'] = intval($arr['image_width']);
$arr['image_height'] = intval($arr['image_height']);
$arr['best_number'] = !empty($arr['best_number']) && intval($arr['best_number']) > 0 ? intval($arr['best_number']) : 3;
$arr['new_number'] = !empty($arr['new_number']) && intval($arr['new_number']) > 0 ? intval($arr['new_number']) : 3;
$arr['hot_number'] = !empty($arr['hot_number']) && intval($arr['hot_number']) > 0 ? intval($arr['hot_number']) : 3;
$arr['promote_number'] = !empty($arr['promote_number']) && intval($arr['promote_number']) > 0 ? intval($arr['promote_number']) : 3;
$arr['top_number'] = intval($arr['top_number']) > 0 ? intval($arr['top_number']) : 10;
$arr['history_number'] = intval($arr['history_number']) > 0 ? intval($arr['history_number']) : 5;
$arr['comments_number'] = intval($arr['comments_number']) > 0 ? intval($arr['comments_number']) : 5;
$arr['article_number'] = intval($arr['article_number']) > 0 ? intval($arr['article_number']) : 5;
$arr['page_size'] = intval($arr['page_size']) > 0 ? intval($arr['page_size']) : 10;
$arr['bought_goods'] = intval($arr['bought_goods']);
$arr['goods_name_length'] = intval($arr['goods_name_length']);
$arr['top10_time'] = intval($arr['top10_time']);
$arr['goods_gallery_number'] = intval($arr['goods_gallery_number']) ? intval($arr['goods_gallery_number']) : 5;
$arr['no_picture'] = !empty($arr['no_picture']) ? str_replace('../', './', $arr['no_picture']) : 'data/static/images/no_picture.gif'; // 修改默認產品圖片的路徑
$arr['qq'] = !empty($arr['qq']) ? $arr['qq'] : '';
$arr['ww'] = !empty($arr['ww']) ? $arr['ww'] : '';
$arr['default_storage'] = isset($arr['default_storage']) ? intval($arr['default_storage']) : 1;
$arr['min_goods_amount'] = isset($arr['min_goods_amount']) ? floatval($arr['min_goods_amount']) : 0;
$arr['one_step_buy'] = empty($arr['one_step_buy']) ? 0 : 1;
$arr['invoice_type'] = empty($arr['invoice_type']) ? array('type' => array(), 'rate' => array()) : unserialize($arr['invoice_type']);
$arr['show_order_type'] = isset($arr['show_order_type']) ? $arr['show_order_type'] : 0; // 顯示方式默認為列表方式
$arr['help_open'] = isset($arr['help_open']) ? $arr['help_open'] : 1; // 顯示方式默認為列表方式
if (!isset($GLOBALS['_CFG']['ecs_version']))
{
/* 如果沒有版本號則默認為2.0.5 */
$GLOBALS['_CFG']['ecs_version'] = 'v3.6';
}
//限定語言項
$lang_array = array('zh_cn', 'zh_tw', 'en_us');
if (empty($arr['lang']) || !in_array($arr['lang'], $lang_array))
{
$arr['lang'] = 'zh_cn'; // 默認語言為簡體中文
}
if (empty($arr['integrate_code']))
{
$arr['integrate_code'] = 'shop'; // 默認的客戶整合插件為 shop
}
}
else
{
$arr = $data;
}
return $arr;
}
/**
* 取得品牌列表
* @return array 品牌列表 id => name
*/
function get_brand_list()
{
$sql = 'SELECT brand_id, brand_name FROM ' . $GLOBALS['ecs']->table('brand') . ' ORDER BY sort_order';
$res = $GLOBALS['db']->getAll($sql);
$brand_list = array();
foreach ($res AS $row)
{
$brand_list[$row['brand_id']] = addslashes($row['brand_name']);
}
return $brand_list;
}
/**
* 獲得某個分類下
*
* @access public
* @param int $cat
* @return array
*/
function get_brands($cat = 0, $app = 'brand')
{
global $page_libs;
$template = basename(PHP_SELF);
$template = substr($template, 0, strrpos($template, '.'));
include_once(ROOT_PATH . ADMIN_PATH . '/includes/lib_template.php');
static $static_page_libs = null;
if ($static_page_libs == null)
{
$static_page_libs = $page_libs;
}
$children = ($cat > 0) ? ' AND ' . get_children($cat) : '';
$sql = "SELECT b.brand_id, b.brand_name, b.brand_logo, b.brand_desc, COUNT(*) AS goods_num, IF(b.brand_logo > '', '1', '0') AS tag ".
"FROM " . $GLOBALS['ecs']->table('brand') . "AS b, ".
$GLOBALS['ecs']->table('goods') . " AS g ".
"WHERE g.brand_id = b.brand_id $children AND is_show = 1 " .
" AND g.is_on_sale = 1 AND g.is_alone_sale = 1 AND g.is_delete = 0 ".
"GROUP BY b.brand_id HAVING goods_num > 0 ORDER BY tag DESC, b.sort_order ASC";
if (isset($static_page_libs[$template]['/library/brands.lbi']))
{
$num = get_library_number("brands");
$sql .= " LIMIT $num ";
}
$row = $GLOBALS['db']->getAll($sql);
foreach ($row AS $key => $val)
{
$row[$key]['url'] = build_uri($app, array('cid' => $cat, 'bid' => $val['brand_id']), $val['brand_name']);
$row[$key]['brand_desc'] = htmlspecialchars($val['brand_desc'],ENT_QUOTES);
}
return $row;
}
/**
* 所有的促銷活動信息
*
* @access public
* @return array
*/
function get_promotion_info($goods_id = '')
{
$snatch = array();
$group = array();
$auction = array();
$package = array();
$favourable = array();
$gmtime = gmtime();
$sql = 'SELECT act_id, act_name, act_type, start_time, end_time FROM ' . $GLOBALS['ecs']->table('goods_activity') . " WHERE is_finished=0 AND start_time <= '$gmtime' AND end_time >= '$gmtime'";
if(!empty($goods_id))
{
$sql .= " AND goods_id = '$goods_id'";
}
$res = $GLOBALS['db']->getAll($sql);
foreach ($res as $data)
{
switch ($data['act_type'])
{
case GAT_SNATCH: //奪寶奇兵
$snatch[$data['act_id']]['act_name'] = $data['act_name'];
$snatch[$data['act_id']]['url'] = build_uri('snatch', array('sid' => $data['act_id']));
$snatch[$data['act_id']]['time'] = sprintf($GLOBALS['_LANG']['promotion_time'], local_date('Y-m-d', $data['start_time']), local_date('Y-m-d', $data['end_time']));
$snatch[$data['act_id']]['sort'] = $data['start_time'];
$snatch[$data['act_id']]['type'] = 'snatch';
break;
case GAT_GROUP_BUY: //團購
$group[$data['act_id']]['act_name'] = $data['act_name'];
$group[$data['act_id']]['url'] = build_uri('group_buy', array('gbid' => $data['act_id']));
$group[$data['act_id']]['time'] = sprintf($GLOBALS['_LANG']['promotion_time'], local_date('Y-m-d', $data['start_time']), local_date('Y-m-d', $data['end_time']));
$group[$data['act_id']]['sort'] = $data['start_time'];
$group[$data['act_id']]['type'] = 'group_buy';
break;
case GAT_AUCTION: //拍賣
$auction[$data['act_id']]['act_name'] = $data['act_name'];
$auction[$data['act_id']]['url'] = build_uri('auction', array('auid' => $data['act_id']));
$auction[$data['act_id']]['time'] = sprintf($GLOBALS['_LANG']['promotion_time'], local_date('Y-m-d', $data['start_time']), local_date('Y-m-d', $data['end_time']));
$auction[$data['act_id']]['sort'] = $data['start_time'];
$auction[$data['act_id']]['type'] = 'auction';
break;
case GAT_PACKAGE: //禮包
$package[$data['act_id']]['act_name'] = $data['act_name'];
$package[$data['act_id']]['url'] = 'package.php#' . $data['act_id'];
$package[$data['act_id']]['time'] = sprintf($GLOBALS['_LANG']['promotion_time'], local_date('Y-m-d', $data['start_time']), local_date('Y-m-d', $data['end_time']));
$package[$data['act_id']]['sort'] = $data['start_time'];
$package[$data['act_id']]['type'] = 'package';
break;
}
}
$user_rank = ',' . $_SESSION['user_rank'] . ',';
$favourable = array();
$sql = 'SELECT act_id, act_range, act_range_ext, act_name, start_time, end_time FROM ' . $GLOBALS['ecs']->table('favourable_activity') . " WHERE start_time <= '$gmtime' AND end_time >= '$gmtime'";
if(!empty($goods_id))
{
$sql .= " AND CONCAT(',', user_rank, ',') LIKE '%" . $user_rank . "%'";
}
$res = $GLOBALS['db']->getAll($sql);
if(empty($goods_id))
{
foreach ($res as $rows)
{
$favourable[$rows['act_id']]['act_name'] = $rows['act_name'];
$favourable[$rows['act_id']]['url'] = 'activity.php';
$favourable[$rows['act_id']]['time'] = sprintf($GLOBALS['_LANG']['promotion_time'], local_date('Y-m-d', $rows['start_time']), local_date('Y-m-d', $rows['end_time']));
$favourable[$rows['act_id']]['sort'] = $rows['start_time'];
$favourable[$rows['act_id']]['type'] = 'favourable';
}
}
else
{
$sql = "SELECT cat_id, brand_id FROM " . $GLOBALS['ecs']->table('goods') .
"WHERE goods_id = '$goods_id'";
$row = $GLOBALS['db']->getRow($sql);
$category_id = $row['cat_id'];
$brand_id = $row['brand_id'];
foreach ($res as $rows)
{
if ($rows['act_range'] == FAR_ALL)
{
$favourable[$rows['act_id']]['act_name'] = $rows['act_name'];
$favourable[$rows['act_id']]['url'] = 'activity.php';
$favourable[$rows['act_id']]['time'] = sprintf($GLOBALS['_LANG']['promotion_time'], local_date('Y-m-d', $rows['start_time']), local_date('Y-m-d', $rows['end_time']));
$favourable[$rows['act_id']]['sort'] = $rows['start_time'];
$favourable[$rows['act_id']]['type'] = 'favourable';
}
elseif ($rows['act_range'] == FAR_CATEGORY)
{
/* 找出分類id的子分類id */
$id_list = array();
$raw_id_list = explode(',', $rows['act_range_ext']);
foreach ($raw_id_list as $id)
{
$id_list = array_merge($id_list, array_keys(cat_list($id, 0, false)));
}
$ids = join(',', array_unique($id_list));
if (strpos(',' . $ids . ',', ',' . $category_id . ',') !== false)
{
$favourable[$rows['act_id']]['act_name'] = $rows['act_name'];
$favourable[$rows['act_id']]['url'] = 'activity.php';
$favourable[$rows['act_id']]['time'] = sprintf($GLOBALS['_LANG']['promotion_time'], local_date('Y-m-d', $rows['start_time']), local_date('Y-m-d', $rows['end_time']));
$favourable[$rows['act_id']]['sort'] = $rows['start_time'];
$favourable[$rows['act_id']]['type'] = 'favourable';
}
}
elseif ($rows['act_range'] == FAR_BRAND)
{
if (strpos(',' . $rows['act_range_ext'] . ',', ',' . $brand_id . ',') !== false)
{
$favourable[$rows['act_id']]['act_name'] = $rows['act_name'];
$favourable[$rows['act_id']]['url'] = 'activity.php';
$favourable[$rows['act_id']]['time'] = sprintf($GLOBALS['_LANG']['promotion_time'], local_date('Y-m-d', $rows['start_time']), local_date('Y-m-d', $rows['end_time']));
$favourable[$rows['act_id']]['sort'] = $rows['start_time'];
$favourable[$rows['act_id']]['type'] = 'favourable';
}
}
elseif ($rows['act_range'] == FAR_GOODS)
{
if (strpos(',' . $rows['act_range_ext'] . ',', ',' . $goods_id . ',') !== false)
{
$favourable[$rows['act_id']]['act_name'] = $rows['act_name'];
$favourable[$rows['act_id']]['url'] = 'activity.php';
$favourable[$rows['act_id']]['time'] = sprintf($GLOBALS['_LANG']['promotion_time'], local_date('Y-m-d', $rows['start_time']), local_date('Y-m-d', $rows['end_time']));
$favourable[$rows['act_id']]['sort'] = $rows['start_time'];
$favourable[$rows['act_id']]['type'] = 'favourable';
}
}
}
}
// if(!empty($goods_id))
// {
// return array('snatch'=>$snatch, 'group_buy'=>$group, 'auction'=>$auction, 'favourable'=>$favourable);
// }
$sort_time = array();
$arr = array_merge($snatch, $group, $auction, $package, $favourable);
foreach($arr as $key => $value)
{
$sort_time[] = $value['sort'];
}
array_multisort($sort_time, SORT_NUMERIC, SORT_DESC, $arr);
return $arr;
}
/**
* 獲得指定分類下所有底層分類的ID
*
* @access public
* @param integer $cat 指定的分類ID
* @return string
*/
function get_children($cat = 0)
{
return 'g.cat_id ' . db_create_in(array_unique(array_merge(array($cat), array_keys(cat_list($cat, 0, false)))));
}
/**
* 獲得指定文章分類下所有底層分類的ID
*
* @access public
* @param integer $cat 指定的分類ID
*
* @return void
*/
function get_article_children ($cat = 0)
{
return db_create_in(array_unique(array_merge(array($cat), array_keys(article_cat_list($cat, 0, false)))), 'cat_id');
}
/**
* 獲取郵件模板
*
* @access public
* @param: $tpl_name[string] 模板代碼
*
* @return array
*/
function get_mail_template($tpl_name)
{
$sql = 'SELECT template_subject, is_html, template_content FROM ' . $GLOBALS['ecs']->table('mail_templates') . " WHERE template_code = '$tpl_name'";
return $GLOBALS['db']->GetRow($sql);
}
/**
* 記錄訂單操作記錄
*
* @access public
* @param string $order_sn 訂單編號
* @param integer $order_status 訂單狀態
* @param integer $shipping_status 配送狀態
* @param integer $pay_status 付款狀態
* @param string $note 備註
* @param string $username 用户名,用户自己的操作則為 buyer
* @return void
*/
function order_action($order_sn, $order_status, $shipping_status, $pay_status, $note = '', $username = null, $place = 0)
{
if (is_null($username))
{
$username = $_SESSION['admin_name'];
}
$sql = 'INSERT INTO ' . $GLOBALS['ecs']->table('order_action') .
' (order_id, action_user, order_status, shipping_status, pay_status, action_place, action_note, log_time) ' .
'SELECT ' .
"order_id, '$username', '$order_status', '$shipping_status', '$pay_status', '$place', '$note', '" .gmtime() . "' " .
'FROM ' . $GLOBALS['ecs']->table('order_info') . " WHERE order_sn = '$order_sn'";
$GLOBALS['db']->query($sql);
}
/**
* 格式化產品價格
*
* @access public
* @param float $price 產品價格
* @return string
*/
function price_format($price, $change_price = true)
{
$price = 0 + $price;
if($price==='')
{
$price=0;
}
if ($change_price && defined('ECS_ADMIN') === false)
{
switch ($GLOBALS['_CFG']['price_format'])
{
case 0:
$price = number_format($price, 0, '.', '');
break;
case 1: // 保留不為 0 的尾數
$price = preg_replace('/(.*)(\\.)([0-9]*?)0+$/', '\1\2\3', number_format($price, 0, '.', ''));
if (substr($price, -1) == '.')
{
$price = substr($price, 0, -1);
}
break;
case 2: // 不四捨五入,保留1位
$price = substr(number_format($price, 0, '.', ''), 0, -1);
break;
case 3: // 直接取整
$price = intval($price);
break;
case 4: // 四捨五入,保留 1 位
$price = number_format($price, 0, '.', '');
break;
case 5: // 先四捨五入,不保留小數
$price = round($price);
break;
}
}
else
{
$price = number_format($price, 0, '.', '');
}
return sprintf($GLOBALS['_CFG']['currency_format'], $price);
}
/**
* 返回訂單中的虛擬產品
*
* @access public
* @param int $order_id 訂單id值
* @param bool $shipping 是否已經發貨
*
* @return array()
*/
function get_virtual_goods($order_id, $shipping = false)
{
if ($shipping)
{
$sql = 'SELECT goods_id, goods_name, send_number AS num, extension_code FROM '.
$GLOBALS['ecs']->table('order_goods') .
" WHERE order_id = '$order_id' AND extension_code > ''";
}
else
{
$sql = 'SELECT goods_id, goods_name, (goods_number - send_number) AS num, extension_code FROM '.
$GLOBALS['ecs']->table('order_goods') .
" WHERE order_id = '$order_id' AND is_real = 0 AND (goods_number - send_number) > 0 AND extension_code > '' ";
}
$res = $GLOBALS['db']->getAll($sql);
$virtual_goods = array();
foreach ($res AS $row)
{
$virtual_goods[$row['extension_code']][] = array('goods_id' => $row['goods_id'], 'goods_name' => $row['goods_name'], 'num' => $row['num']);
}
return $virtual_goods;
}
/**
* 虛擬產品發貨
*
* @access public
* @param array $virtual_goods 虛擬產品數組
* @param string $msg 錯誤信息
* @param string $order_sn 訂單號。
* @param string $process 設定當前流程:split,發貨分單流程;other,其他,默認。
*
* @return bool
*/
function virtual_goods_ship(&$virtual_goods, &$msg, $order_sn, $return_result = false, $process = 'other')
{
$virtual_card = array();
foreach ($virtual_goods AS $code => $goods_list)
{
/* 只處理虛擬卡 */
if ($code == 'virtual_card')
{
foreach ($goods_list as $goods)
{
if (virtual_card_shipping($goods, $order_sn, $msg, $process))
{
if ($return_result)
{
$virtual_card[] = array('goods_id'=>$goods['goods_id'], 'goods_name'=>$goods['goods_name'], 'info'=>virtual_card_result($order_sn, $goods));
}
}
else
{
return false;
}
}
$GLOBALS['smarty']->assign('virtual_card', $virtual_card);
}
}
return true;
}
/**
* 虛擬卡發貨
*
* @access public
* @param string $goods 產品詳情數組
* @param string $order_sn 本次操作的訂單
* @param string $msg 返回信息
* @param string $process 設定當前流程:split,發貨分單流程;other,其他,默認。
*
* @return boolen
*/
function virtual_card_shipping ($goods, $order_sn, &$msg, $process = 'other')
{
/* 包含加密解密函數所在文件 */
include_once(ROOT_PATH . 'includes/lib_code.php');
/* 檢查有沒有缺貨 */
$sql = "SELECT COUNT(*) FROM ".$GLOBALS['ecs']->table('virtual_card')." WHERE goods_id = '$goods[goods_id]' AND is_saled = 0 ";
$num = $GLOBALS['db']->GetOne($sql);
if ($num < $goods['num'])
{
$msg .= sprintf($GLOBALS['_LANG']['virtual_card_oos'], $goods['goods_name']);
return false;
}
/* 取出卡片信息 */
$sql = "SELECT card_id, card_sn, card_password, end_date, crc32 FROM ".$GLOBALS['ecs']->table('virtual_card')." WHERE goods_id = '$goods[goods_id]' AND is_saled = 0 LIMIT " . $goods['num'];
$arr = $GLOBALS['db']->getAll($sql);
$card_ids = array();
$cards = array();
foreach ($arr as $virtual_card)
{
$card_info = array();
/* 卡號和密碼解密 */
if ($virtual_card['crc32'] == 0 || $virtual_card['crc32'] == crc32(AUTH_KEY))
{
$card_info['card_sn'] = decrypt($virtual_card['card_sn']);
$card_info['card_password'] = decrypt($virtual_card['card_password']);
}
elseif ($virtual_card['crc32'] == crc32(OLD_AUTH_KEY))
{
$card_info['card_sn'] = decrypt($virtual_card['card_sn'], OLD_AUTH_KEY);
$card_info['card_password'] = decrypt($virtual_card['card_password'], OLD_AUTH_KEY);
}
else
{
$msg .= 'error key';
return false;
}
$card_info['end_date'] = date($GLOBALS['_CFG']['date_format'], $virtual_card['end_date']);
$card_ids[] = $virtual_card['card_id'];
$cards[] = $card_info;
}
/* 標記已經取出的卡片 */
$sql = "UPDATE ".$GLOBALS['ecs']->table('virtual_card')." SET ".
"is_saled = 1 ,".
"order_sn = '$order_sn' ".
"WHERE " . db_create_in($card_ids, 'card_id');
if (!$GLOBALS['db']->query($sql, 'SILENT'))
{
$msg .= $GLOBALS['db']->error();
return false;
}
/* 更新庫存 */
$sql = "UPDATE ".$GLOBALS['ecs']->table('goods'). " SET goods_number = goods_number - '$goods[num]' WHERE goods_id = '$goods[goods_id]'";
$GLOBALS['db']->query($sql);
if (true)
{
/* 獲取訂單信息 */
$sql = "SELECT order_id, order_sn, consignee, email FROM ".$GLOBALS['ecs']->table('order_info'). " WHERE order_sn = '$order_sn'";
$order = $GLOBALS['db']->GetRow($sql);
/* 更新訂單信息 */
if ($process == 'split')
{
$sql = "UPDATE ".$GLOBALS['ecs']->table('order_goods'). "
SET send_number = send_number + '" . $goods['num'] . "'
WHERE order_id = '" . $order['order_id'] . "'
AND goods_id = '" . $goods['goods_id'] . "' ";
}
else
{
$sql = "UPDATE ".$GLOBALS['ecs']->table('order_goods'). "
SET send_number = '" . $goods['num'] . "'
WHERE order_id = '" . $order['order_id'] . "'
AND goods_id = '" . $goods['goods_id'] . "' ";
}
if (!$GLOBALS['db']->query($sql, 'SILENT'))
{
$msg .= $GLOBALS['db']->error();
return false;
}
}
/* 發送郵件 */
$GLOBALS['smarty']->assign('virtual_card', $cards);
$GLOBALS['smarty']->assign('order', $order);
$GLOBALS['smarty']->assign('goods', $goods);
$GLOBALS['smarty']->assign('send_time', date('Y-m-d H:i:s'));
$GLOBALS['smarty']->assign('shop_name', $GLOBALS['_CFG']['shop_name']);
$GLOBALS['smarty']->assign('send_date', date('Y-m-d'));
$GLOBALS['smarty']->assign('sent_date', date('Y-m-d'));
$tpl = get_mail_template('virtual_card');
$content = $GLOBALS['smarty']->fetch('str:' . $tpl['template_content']);
send_mail($order['consignee'], $order['email'], $tpl['template_subject'], $content, $tpl['is_html']);
return true;
}
/**
* 返回虛擬卡信息
*
* @access public
* @param
*
* @return void
*/
function virtual_card_result($order_sn, $goods)
{
/* 包含加密解密函數所在文件 */
include_once(ROOT_PATH . 'includes/lib_code.php');
/* 獲取已經發送的卡片數據 */
$sql = "SELECT card_sn, card_password, end_date, crc32 FROM ".$GLOBALS['ecs']->table('virtual_card')." WHERE goods_id= '$goods[goods_id]' AND order_sn = '$order_sn' ";
$res= $GLOBALS['db']->query($sql);
$cards = array();
while ($row = $GLOBALS['db']->FetchRow($res))
{
/* 卡號和密碼解密 */
if ($row['crc32'] == 0 || $row['crc32'] == crc32(AUTH_KEY))
{
$row['card_sn'] = decrypt($row['card_sn']);
$row['card_password'] = decrypt($row['card_password']);
}
elseif ($row['crc32'] == crc32(OLD_AUTH_KEY))
{
$row['card_sn'] = decrypt($row['card_sn'], OLD_AUTH_KEY);
$row['card_password'] = decrypt($row['card_password'], OLD_AUTH_KEY);
}
else
{
$row['card_sn'] = '***';
$row['card_password'] = '***';
}
$cards[] = array('card_sn'=>$row['card_sn'], 'card_password'=>$row['card_password'], 'end_date'=>date($GLOBALS['_CFG']['date_format'], $row['end_date']));
}
return $cards;
}
/**
* 獲取指定 id snatch 活動的結果
*
* @access public
* @param int $id snatch_id
*
* @return array array(user_name, bie_price, bid_time, num)
* num通常為1,如果為2表示有2個用户取到最小值,但結果只返回最早出價用户。
*/
function get_snatch_result($id)
{
$sql = 'SELECT u.user_id, u.user_name, u.email, lg.bid_price, lg.bid_time, count(*) as num' .
' FROM ' . $GLOBALS['ecs']->table('snatch_log') . ' AS lg '.
' LEFT JOIN ' . $GLOBALS['ecs']->table('users') . ' AS u ON lg.user_id = u.user_id'.
" WHERE lg.snatch_id = '$id'".
' GROUP BY lg.bid_price' .
' ORDER BY num ASC, lg.bid_price ASC, lg.bid_time ASC LIMIT 1';
$rec = $GLOBALS['db']->GetRow($sql);
if ($rec)
{
$rec['bid_time'] = local_date($GLOBALS['_CFG']['time_format'], $rec['bid_time']);
$rec['formated_bid_price'] = price_format($rec['bid_price'], false);
/* 活動信息 */
$sql = 'SELECT ext_info " .
" FROM ' . $GLOBALS['ecs']->table('goods_activity') .
" WHERE act_id= '$id' AND act_type=" . GAT_SNATCH.
" LIMIT 1";
$row = $GLOBALS['db']->getOne($sql);
$info = unserialize($row);
if (!empty($info['max_price']))
{
$rec['buy_price'] = ($rec['bid_price'] > $info['max_price']) ? $info['max_price'] : $rec['bid_price'];
}
else
{
$rec['buy_price'] = $rec['bid_price'];
}
/* 檢查訂單 */
$sql = "SELECT COUNT(*)" .
" FROM " . $GLOBALS['ecs']->table('order_info') .
" WHERE extension_code = 'snatch'" .
" AND extension_id = '$id'" .
" AND order_status " . db_create_in(array(OS_CONFIRMED, OS_UNCONFIRMED));
$rec['order_count'] = $GLOBALS['db']->getOne($sql);
}
return $rec;
}
/**
* 清除指定後綴的模板緩存或編譯文件
*
* @access public
* @param bool $is_cache 是否清除緩存還是清出編譯文件
* @param string $ext 需要刪除的文件名,不包含後綴
*
* @return int 返回清除的文件個數
*/
function clear_tpl_files($is_cache = true, $ext = '')
{
$dirs = array();
if (isset($GLOBALS['shop_id']) && $GLOBALS['shop_id'] > 0)
{
$tmp_dir = DATA_DIR ;
}
else
{
$tmp_dir = 'temp';
}
if ($is_cache)
{
$cache_dir = ROOT_PATH . $tmp_dir . '/caches/';
$dirs[] = ROOT_PATH . $tmp_dir . '/query_caches/';
$dirs[] = ROOT_PATH . $tmp_dir . '/static_caches/';
for($i = 0; $i < 16; $i++)
{
$hash_dir = $cache_dir . dechex($i);
$dirs[] = $hash_dir . '/';
}
}
else
{
$dirs[] = ROOT_PATH . $tmp_dir . '/compiled/';
$dirs[] = ROOT_PATH . $tmp_dir . '/compiled/admin/';
}
$str_len = strlen($ext);
$count = 0;
foreach ($dirs AS $dir)
{
$folder = @opendir($dir);
if ($folder === false)
{
continue;
}
while ($file = readdir($folder))
{
if ($file == '.' || $file == '..' || $file == 'index.htm' || $file == 'index.html')
{
continue;
}
if (is_file($dir . $file))
{
/* 如果有文件名則判斷是否匹配 */
$pos = ($is_cache) ? strrpos($file, '_') : strrpos($file, '.');
if ($str_len > 0 && $pos !== false)
{
$ext_str = substr($file, 0, $pos);
if ($ext_str == $ext)
{
if (@unlink($dir . $file))
{
$count++;
}
}
}
else
{
if (@unlink($dir . $file))
{
$count++;
}
}
}
}
closedir($folder);
}
return $count;
}
/**
* 清除模版編譯文件
*
* @access public
* @param mix $ext 模版文件名, 不包含後綴
* @return void
*/
function clear_compiled_files($ext = '')
{
return clear_tpl_files(false, $ext);
}
/**
* 清除緩存文件
*
* @access public
* @param mix $ext 模版文件名, 不包含後綴
* @return void
*/
function clear_cache_files($ext = '')
{
return clear_tpl_files(true, $ext);
}
/**
* 清除模版編譯和緩存文件
*
* @access public
* @param mix $ext 模版文件名後綴
* @return void
*/
function clear_all_files($ext = '')
{
return clear_tpl_files(false, $ext) + clear_tpl_files(true, $ext);
}
/**
* 頁面上調用的js文件
*
* @access public
* @param string $files
* @return void
*/
function smarty_insert_scripts($args)
{
static $scripts = array();
$arr = explode(',', str_replace(' ','',$args['files']));
$str = '';
foreach ($arr AS $val)
{
if (in_array($val, $scripts) == false)
{
$scripts[] = $val;
if ($val[0] == '.')
{
$str .= '';
}
else
{
$str .= '';
}
}
}
return $str;
}
/**
* 創建分頁的列表
*
* @access public
* @param integer $count
* @return string
*/
function smarty_create_pages($params)
{
extract($params);
$str = '';
$len = 10;
if (empty($page))
{
$page = 1;
}
if (!empty($count))
{
$step = 1;
$str .= "";
for ($i = 2; $i < $count; $i += $step)
{
$step = ($i >= $page + $len - 1 || $i <= $page - $len + 1) ? $len : 1;
$str .= "';
}
return $select;
}
else
{
foreach ($options AS $key => $value)
{
$options[$key]['url'] = build_uri('article_cat', array('acid' => $value['cat_id']), $value['cat_name']);
}
return $options;
}
}
/**
* 過濾和排序所有文章分類,返回一個帶有縮進級別的數組
*
* @access private
* @param int $cat_id 上級分類ID
* @param array $arr 含有所有分類的數組
* @param int $level 級別
* @return void
*/
function article_cat_options($spec_cat_id, $arr)
{
static $cat_options = array();
if (isset($cat_options[$spec_cat_id]))
{
return $cat_options[$spec_cat_id];
}
if (!isset($cat_options[0]))
{
$level = $last_cat_id = 0;
$options = $cat_id_array = $level_array = array();
while (!empty($arr))
{
foreach ($arr AS $key => $value)
{
$cat_id = $value['cat_id'];
if ($level == 0 && $last_cat_id == 0)
{
if ($value['parent_id'] > 0)
{
break;
}
$options[$cat_id] = $value;
$options[$cat_id]['level'] = $level;
$options[$cat_id]['id'] = $cat_id;
$options[$cat_id]['name'] = $value['cat_name'];
unset($arr[$key]);
if ($value['has_children'] == 0)
{
continue;
}
$last_cat_id = $cat_id;
$cat_id_array = array($cat_id);
$level_array[$last_cat_id] = ++$level;
continue;
}
if ($value['parent_id'] == $last_cat_id)
{
$options[$cat_id] = $value;
$options[$cat_id]['level'] = $level;
$options[$cat_id]['id'] = $cat_id;
$options[$cat_id]['name'] = $value['cat_name'];
unset($arr[$key]);
if ($value['has_children'] > 0)
{
if (end($cat_id_array) != $last_cat_id)
{
$cat_id_array[] = $last_cat_id;
}
$last_cat_id = $cat_id;
$cat_id_array[] = $cat_id;
$level_array[$last_cat_id] = ++$level;
}
}
elseif ($value['parent_id'] > $last_cat_id)
{
break;
}
}
$count = count($cat_id_array);
if ($count > 1)
{
$last_cat_id = array_pop($cat_id_array);
}
elseif ($count == 1)
{
if ($last_cat_id != end($cat_id_array))
{
$last_cat_id = end($cat_id_array);
}
else
{
$level = 0;
$last_cat_id = 0;
$cat_id_array = array();
continue;
}
}
if ($last_cat_id && isset($level_array[$last_cat_id]))
{
$level = $level_array[$last_cat_id];
}
else
{
$level = 0;
}
}
$cat_options[0] = $options;
}
else
{
$options = $cat_options[0];
}
if (!$spec_cat_id)
{
return $options;
}
else
{
if (empty($options[$spec_cat_id]))
{
return array();
}
$spec_cat_id_level = $options[$spec_cat_id]['level'];
foreach ($options AS $key => $value)
{
if ($key != $spec_cat_id)
{
unset($options[$key]);
}
else
{
break;
}
}
$spec_cat_id_array = array();
foreach ($options AS $key => $value)
{
if (($spec_cat_id_level == $value['level'] && $value['cat_id'] != $spec_cat_id) ||
($spec_cat_id_level > $value['level']))
{
break;
}
else
{
$spec_cat_id_array[$key] = $value;
}
}
$cat_options[$spec_cat_id] = $spec_cat_id_array;
return $spec_cat_id_array;
}
}
/**
* 調用UCenter的函數
*
* @param string $func
* @param array $params
*
* @return mixed
*/
function uc_call($func, $params=null)
{
restore_error_handler();
if (!function_exists($func))
{
include_once(ROOT_PATH . 'uc_client/client.php');
}
$res = call_user_func_array($func, $params);
set_error_handler('exception_handler');
return $res;
}
/**
* error_handle回調函數
*
* @return
*/
function exception_handler($errno, $errstr, $errfile, $errline)
{
return;
}
/**
* 重新獲得產品圖片與產品相冊的地址
*
* @param int $goods_id 產品ID
* @param string $image 原產品相冊圖片地址
* @param boolean $thumb 是否為縮略圖
* @param string $call 調用方法(產品圖片還是產品相冊)
* @param boolean $del 是否刪除圖片
*
* @return string $url
*/
function get_image_path($goods_id, $image='', $thumb=false, $call='goods', $del=false)
{
$url = empty($image) ? $GLOBALS['_CFG']['no_picture'] : $image;
return $url;
}
/**
* 調用使用UCenter插件時的函數
*
* @param string $func
* @param array $params
*
* @return mixed
*/
function user_uc_call($func, $params = null)
{
if (isset($GLOBALS['_CFG']['integrate_code']) && $GLOBALS['_CFG']['integrate_code'] == 'ucenter')
{
restore_error_handler();
if (!function_exists($func))
{
include_once(ROOT_PATH . 'includes/lib_uc.php');
}
$res = call_user_func_array($func, $params);
set_error_handler('exception_handler');
return $res;
}
else
{
return;
}
}
/**
* 取得產品優惠價格列表
*
* @param string $goods_id 產品編號
* @param string $price_type 價格類別(0為全店優惠比率,1為產品優惠價格,2為分類優惠比率)
*
* @return 優惠價格列表
*/
function get_volume_price_list($goods_id, $price_type = '1')
{
$volume_price = array();
$temp_index = '0';
$sql = "SELECT `volume_number` , `volume_price`".
" FROM " .$GLOBALS['ecs']->table('volume_price'). "".
" WHERE `goods_id` = '" . $goods_id . "' AND `price_type` = '" . $price_type . "'".
" ORDER BY `volume_number`";
$res = $GLOBALS['db']->getAll($sql);
$count = count($res);
foreach ($res as $k => $v)
{
$volume_price[$temp_index] = array();
if(($temp_index+1)==$count)
{
$volume_price[$temp_index]['number_format'] = '≥'.$v['volume_number'];
}
else
{
$last_number = $res[$k+1]['volume_number']-1;
$volume_price[$temp_index]['number_format'] = $v['volume_number'].'-'.$last_number;
}
$volume_price[$temp_index]['number'] = $v['volume_number'];
$volume_price[$temp_index]['price'] = $v['volume_price'];
$volume_price[$temp_index]['shop_price'] = $rank_price-$v['volume_price'];
$volume_price[$temp_index]['format_price'] = price_format($v['volume_price']);
$volume_price[$temp_index]['format_shop_price'] = price_format($volume_price[$temp_index]['shop_price']);
$temp_index ++;
}
return $volume_price;
}
/**
* 取得產品最終使用價格
*
* @param string $goods_id 產品編號
* @param string $goods_num 購買數量
* @param boolean $is_spec_price 是否加入規格價格
* @param mix $spec 規格ID的數組或者逗號分隔的字符串
*
* @return 產品最終購買價格
*/
function get_final_price($goods_id, $goods_num = '1', $is_spec_price = false, $spec = array())
{
$final_price = '0'; //產品最終購買價格
$volume_price = '0'; //產品優惠價格
$promote_price = '0'; //產品促銷價格
$user_price = '0'; //產品客戶價格
/* 判斷產品是否參與預售活動,如果參與則獲取產品 start */
if(!empty($_REQUEST['pre_sale_id']))
{
$pre_sale = pre_sale_info($_REQUEST['pre_sale_id'], $goods_num);
if(!empty($pre_sale)){
$final_price = $pre_sale['cur_price'];
//如果需要加入規格價格
if ($is_spec_price)
{
if (!empty($spec))
{
$spec_price = spec_price($spec);
$final_price += $spec_price;
}
}
return $final_price;
}
}
/* 判斷產品是否參與預售活動,如果參與則獲取產品 end */
//取得產品優惠價格列表
$price_list = get_volume_price_list($goods_id, '1');
if (!empty($price_list))
{
foreach ($price_list as $value)
{
if ($goods_num >= $value['number'])
{
$volume_price = $value['price'];
}
}
}
//取得產品促銷價格列表
/* 取得產品信息 */
$sql = "SELECT g.promote_price, g.promote_start_date, g.promote_end_date,g.sale_price, g.sale_start_date, g.sale_end_date, ".//限時秒殺增加字段
"IFNULL(mp.user_price, g.shop_price * '" . $_SESSION['discount'] . "') AS shop_price ".
" FROM " .$GLOBALS['ecs']->table('goods'). " AS g ".
" LEFT JOIN " . $GLOBALS['ecs']->table('member_price') . " AS mp ".
"ON mp.goods_id = g.goods_id AND mp.user_rank = '" . $_SESSION['user_rank']. "' ".
" WHERE g.goods_id = '" . $goods_id . "'" .
" AND g.is_delete = 0";
$goods = $GLOBALS['db']->getRow($sql);
/* 計算限時秒殺價格 開始*/
$nowtime = gmtime();
if ($goods['is_sale'] = 1 && $nowtime >= $goods['sale_start_date'] && $nowtime <= $goods['sale_end_date'])
{
$sale_price =$goods['sale_price'];
}
/* 計算限時秒殺價格 結束 */
/* 計算產品的促銷價格 */
if ($goods['promote_price'] > 0)
{
$promote_price = bargain_price($goods['promote_price'], $goods['promote_start_date'], $goods['promote_end_date']);
}
else
{
$promote_price = 0;
}
//取得產品客戶價格列表
$user_price = $goods['shop_price'];
//比較產品的促銷價格,客戶價格,優惠價格
if (!empty($sale_price))
{
//如果有秒殺價格,則取秒殺價格
$final_price = $sale_price;
}
elseif (empty($volume_price) && empty($promote_price))
{
//如果優惠價格,促銷價格都為空則取客戶價格
$final_price = $user_price;
}
elseif (!empty($volume_price) && empty($promote_price))
{
//如果優惠價格為空時不參加這個比較。
$final_price = min($volume_price, $user_price);
}
elseif (empty($volume_price) && !empty($promote_price))
{
//如果促銷價格為空時不參加這個比較。
$final_price = min($promote_price, $user_price);
}
elseif (!empty($volume_price) && !empty($promote_price))
{
//取促銷價格,客戶價格,優惠價格最小值
$final_price = min($volume_price, $promote_price, $user_price);
}
else
{
$final_price = $user_price;
}
//如果需要加入規格價格
if ($is_spec_price)
{
if (!empty($spec))
{
$spec_price = spec_price($spec);
$final_price += $spec_price;
}
}
//返回產品最終購買價格
return $final_price;
}
/**
* 將 goods_attr_id 的序列按照 attr_id 重新排序
*
* 注意:非規格屬性的id會被排除
*
* @access public
* @param array $goods_attr_id_array 一維數組
* @param string $sort 序號:asc|desc,默認為:asc
*
* @return string
*/
function sort_goods_attr_id_array($goods_attr_id_array, $sort = 'asc')
{
if (empty($goods_attr_id_array))
{
return $goods_attr_id_array;
}
//重新排序
$sql = "SELECT a.attr_type, v.attr_value, v.goods_attr_id
FROM " .$GLOBALS['ecs']->table('attribute'). " AS a
LEFT JOIN " .$GLOBALS['ecs']->table('goods_attr'). " AS v
ON v.attr_id = a.attr_id
AND a.attr_type = 1
WHERE v.goods_attr_id " . db_create_in($goods_attr_id_array) . "
ORDER BY a.attr_id $sort";
$row = $GLOBALS['db']->GetAll($sql);
$return_arr = array();
foreach ($row as $value)
{
$return_arr['sort'][] = $value['goods_attr_id'];
$return_arr['row'][$value['goods_attr_id']] = $value;
}
return $return_arr;
}
/**
*
* 是否存在規格
*
* @access public
* @param array $goods_attr_id_array 一維數組
*
* @return string
*/
function is_spec($goods_attr_id_array, $sort = 'asc')
{
if (empty($goods_attr_id_array))
{
return $goods_attr_id_array;
}
//重新排序
$sql = "SELECT a.attr_type, v.attr_value, v.goods_attr_id
FROM " .$GLOBALS['ecs']->table('attribute'). " AS a
LEFT JOIN " .$GLOBALS['ecs']->table('goods_attr'). " AS v
ON v.attr_id = a.attr_id
AND a.attr_type = 1
WHERE v.goods_attr_id " . db_create_in($goods_attr_id_array) . "
ORDER BY a.attr_id $sort";
$row = $GLOBALS['db']->GetAll($sql);
$return_arr = array();
foreach ($row as $value)
{
$return_arr['sort'][] = $value['goods_attr_id'];
$return_arr['row'][$value['goods_attr_id']] = $value;
}
if(!empty($return_arr))
{
return true;
}
else
{
return false;
}
}
/**
* 獲取指定id package 的信息
*
* @access public
* @param int $id package_id
*
* @return array array(package_id, package_name, goods_id,start_time, end_time, min_price, integral)
*/
function get_package_info($id)
{
global $ecs, $db,$_CFG;
$id = is_numeric($id)?intval($id):0;
$now = gmtime();
$sql = "SELECT act_id AS id, act_name AS package_name, goods_id , goods_name, start_time, end_time, act_desc, ext_info".
" FROM " . $GLOBALS['ecs']->table('goods_activity') .
" WHERE act_id='$id' AND act_type = " . GAT_PACKAGE;
$package = $db->GetRow($sql);
/* 將時間轉成可閲讀格式 */
if ($package['start_time'] <= $now && $package['end_time'] >= $now)
{
$package['is_on_sale'] = "1";
}
else
{
$package['is_on_sale'] = "0";
}
$package['start_time'] = local_date('Y-m-d H:i', $package['start_time']);
$package['end_time'] = local_date('Y-m-d H:i', $package['end_time']);
$row = unserialize($package['ext_info']);
unset($package['ext_info']);
if ($row)
{
foreach ($row as $key=>$val)
{
$package[$key] = $val;
}
}
$sql = "SELECT pg.package_id, pg.goods_id, pg.goods_number, pg.admin_id, ".
" g.goods_sn, g.goods_name, g.market_price, g.goods_thumb, g.is_real, ".
" IFNULL(mp.user_price, g.shop_price * '$_SESSION[discount]') AS rank_price " .
" FROM " . $GLOBALS['ecs']->table('package_goods') . " AS pg ".
" LEFT JOIN ". $GLOBALS['ecs']->table('goods') . " AS g ".
" ON g.goods_id = pg.goods_id ".
" LEFT JOIN " . $GLOBALS['ecs']->table('member_price') . " AS mp ".
"ON mp.goods_id = g.goods_id AND mp.user_rank = '$_SESSION[user_rank]' ".
" WHERE pg.package_id = " . $id. " ".
" ORDER BY pg.package_id, pg.goods_id";
$goods_res = $GLOBALS['db']->getAll($sql);
$market_price = 0;
$real_goods_count = 0;
$virtual_goods_count = 0;
foreach($goods_res as $key => $val)
{
$goods_res[$key]['goods_thumb'] = get_image_path($val['goods_id'], $val['goods_thumb'], true);
$goods_res[$key]['market_price_format'] = price_format($val['market_price']);
$goods_res[$key]['rank_price_format'] = price_format($val['rank_price']);
$market_price += $val['market_price'] * $val['goods_number'];
/* 統計實體產品和虛擬產品的個數 */
if ($val['is_real'])
{
$real_goods_count++;
}
else
{
$virtual_goods_count++;
}
}
if ($real_goods_count > 0)
{
$package['is_real'] = 1;
}
else
{
$package['is_real'] = 0;
}
$package['goods_list'] = $goods_res;
$package['market_package'] = $market_price;
$package['market_package_format'] = price_format($market_price);
$package['package_price_format'] = price_format($package['package_price']);
return $package;
}
/**
* 獲得指定禮包的產品
*
* @access public
* @param integer $package_id
* @return array
*/
function get_package_goods($package_id)
{
$sql = "SELECT pg.goods_id, g.goods_name, pg.goods_number, p.goods_attr, p.product_number, p.product_id
FROM " . $GLOBALS['ecs']->table('package_goods') . " AS pg
LEFT JOIN " .$GLOBALS['ecs']->table('goods') . " AS g ON pg.goods_id = g.goods_id
LEFT JOIN " . $GLOBALS['ecs']->table('products') . " AS p ON pg.product_id = p.product_id
WHERE pg.package_id = '$package_id'";
if ($package_id == 0)
{
$sql .= " AND pg.admin_id = '$_SESSION[admin_id]'";
}
$resource = $GLOBALS['db']->query($sql);
if (!$resource)
{
return array();
}
$row = array();
/* 生成結果數組 取存在貨品的產品id 組合產品id與貨品id */
$good_product_str = '';
while ($_row = $GLOBALS['db']->fetch_array($resource))
{
if ($_row['product_id'] > 0)
{
/* 取存產品id */
$good_product_str .= ',' . $_row['goods_id'];
/* 組合產品id與貨品id */
$_row['g_p'] = $_row['goods_id'] . '_' . $_row['product_id'];
}
else
{
/* 組合產品id與貨品id */
$_row['g_p'] = $_row['goods_id'];
}
//生成結果數組
$row[] = $_row;
}
$good_product_str = trim($good_product_str, ',');
/* 釋放空間 */
unset($resource, $_row, $sql);
/* 取產品屬性 */
if ($good_product_str != '')
{
$sql = "SELECT goods_attr_id, attr_value FROM " .$GLOBALS['ecs']->table('goods_attr'). " WHERE goods_id IN ($good_product_str)";
$result_goods_attr = $GLOBALS['db']->getAll($sql);
$_goods_attr = array();
foreach ($result_goods_attr as $value)
{
$_goods_attr[$value['goods_attr_id']] = $value['attr_value'];
}
}
/* 過濾貨品 */
$format[0] = '%s[%s]--[%d]';
$format[1] = '%s--[%d]';
foreach ($row as $key => $value)
{
if ($value['goods_attr'] != '')
{
$goods_attr_array = explode('|', $value['goods_attr']);
$goods_attr = array();
foreach ($goods_attr_array as $_attr)
{
$goods_attr[] = $_goods_attr[$_attr];
}
$row[$key]['goods_name'] = sprintf($format[0], $value['goods_name'], implode(',', $goods_attr), $value['goods_number']);
}
else
{
$row[$key]['goods_name'] = sprintf($format[1], $value['goods_name'], $value['goods_number']);
}
}
return $row;
}
/**
* 取產品的貨品列表
*
* @param mixed $goods_id 單個產品id;多個產品id數組;以逗號分隔產品id字符串
* @param string $conditions sql條件
*
* @return array
*/
function get_good_products($goods_id, $conditions = '')
{
if (empty($goods_id))
{
return array();
}
switch (gettype($goods_id))
{
case 'integer':
$_goods_id = "goods_id = '" . intval($goods_id) . "'";
break;
case 'string':
case 'array':
$_goods_id = db_create_in($goods_id, 'goods_id');
break;
}
/* 取貨品 */
$sql = "SELECT * FROM " .$GLOBALS['ecs']->table('products'). " WHERE $_goods_id $conditions";
$result_products = $GLOBALS['db']->getAll($sql);
/* 取產品屬性 */
$sql = "SELECT goods_attr_id, attr_value FROM " .$GLOBALS['ecs']->table('goods_attr'). " WHERE $_goods_id";
$result_goods_attr = $GLOBALS['db']->getAll($sql);
$_goods_attr = array();
foreach ($result_goods_attr as $value)
{
$_goods_attr[$value['goods_attr_id']] = $value['attr_value'];
}
/* 過濾貨品 */
foreach ($result_products as $key => $value)
{
$goods_attr_array = explode('|', $value['goods_attr']);
if (is_array($goods_attr_array))
{
$goods_attr = array();
foreach ($goods_attr_array as $_attr)
{
$goods_attr[] = $_goods_attr[$_attr];
}
$goods_attr_str = implode(',', $goods_attr);
}
$result_products[$key]['goods_attr_str'] = $goods_attr_str;
}
return $result_products;
}
/**
* 取產品的下拉框Select列表
*
* @param int $goods_id 產品id
*
* @return array
*/
function get_good_products_select($goods_id)
{
$return_array = array();
$products = get_good_products($goods_id);
if (empty($products))
{
return $return_array;
}
foreach ($products as $value)
{
$return_array[$value['product_id']] = $value['goods_attr_str'];
}
return $return_array;
}
/**
* 取產品的規格列表
*
* @param int $goods_id 產品id
* @param string $conditions sql條件
*
* @return array
*/
function get_specifications_list($goods_id, $conditions = '')
{
/* 取產品屬性 */
$sql = "SELECT ga.goods_attr_id, ga.attr_id, ga.attr_value, a.attr_name
FROM " .$GLOBALS['ecs']->table('goods_attr'). " AS ga, " .$GLOBALS['ecs']->table('attribute'). " AS a
WHERE ga.attr_id = a.attr_id
AND ga.goods_id = '$goods_id'
$conditions";
$result = $GLOBALS['db']->getAll($sql);
$return_array = array();
foreach ($result as $value)
{
$return_array[$value['goods_attr_id']] = $value;
}
return $return_array;
}
/**
* 調用array_combine函數
*
* @param array $keys
* @param array $values
*
* @return $combined
*/
if (!function_exists('array_combine')) {
function array_combine($keys, $values)
{
if (!is_array($keys)) {
user_error('array_combine() expects parameter 1 to be array, ' .
gettype($keys) . ' given', E_USER_WARNING);
return;
}
if (!is_array($values)) {
user_error('array_combine() expects parameter 2 to be array, ' .
gettype($values) . ' given', E_USER_WARNING);
return;
}
$key_count = count($keys);
$value_count = count($values);
if ($key_count !== $value_count) {
user_error('array_combine() Both parameters should have equal number of elements', E_USER_WARNING);
return false;
}
if ($key_count === 0 || $value_count === 0) {
user_error('array_combine() Both parameters should have number of elements at least 0', E_USER_WARNING);
return false;
}
$keys = array_values($keys);
$values = array_values($values);
$combined = array();
for ($i = 0; $i < $key_count; $i++) {
$combined[$keys[$i]] = $values[$i];
}
return $combined;
}
}
?>