You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
178 lines
7.4 KiB
178 lines
7.4 KiB
<?php
|
|
|
|
/**
|
|
* ECSHOP 文章内容
|
|
* ============================================================================
|
|
* 版权所有 2005-2016 上海商创网络科技有限公司,并保留所有权利。
|
|
* 网站地址: http://www.ecmoban.com;
|
|
* ----------------------------------------------------------------------------
|
|
* 这不是一个自由软件!您只能在不用于商业目的的前提下对程序代码进行修改和
|
|
* 使用;不允许对程序代码以任何形式任何目的的再发布。
|
|
* ============================================================================
|
|
* $Author: liuhui $
|
|
* $Id: article.php 17069 2010-03-26 05:28:01Z liuhui $
|
|
*/
|
|
|
|
define('IN_ECS', true);
|
|
|
|
require(dirname(__FILE__) . '/includes/init.php');
|
|
|
|
if ((DEBUG_MODE & 2) != 2)
|
|
{
|
|
$smarty->caching = true;
|
|
}
|
|
|
|
/*------------------------------------------------------ */
|
|
//-- INPUT
|
|
/*------------------------------------------------------ */
|
|
|
|
$_REQUEST['id'] = isset($_REQUEST['id']) ? intval($_REQUEST['id']) : 18;
|
|
$region_id = $_REQUEST['id'];
|
|
|
|
|
|
/*------------------------------------------------------ */
|
|
//-- PROCESSOR
|
|
/*------------------------------------------------------ */
|
|
|
|
$cache_id = sprintf('%X', crc32($_REQUEST['id'] . '-' . $_CFG['lang']));
|
|
|
|
if (!$smarty->is_cached('help.dwt', $cache_id))
|
|
{
|
|
|
|
//自提点部分
|
|
$sql = "SELECT a.region_id ,a.shipping_area_id,b.region_name,c.name,c.user_name,c.id,c.address,c.mobile,c.img_url,c.anchor,c.line FROM ".$GLOBALS['ecs']->table('area_region')." AS a
|
|
LEFT JOIN ".$GLOBALS['ecs']->table('region')." AS b ON a.region_id=b.region_id LEFT JOIN ".
|
|
$GLOBALS['ecs']->table('shipping_point')." AS c ON c.shipping_area_id=a.shipping_area_id ".
|
|
"WHERE c.name != '' AND a.region_id IN (SELECT region_id FROM ".$ecs->table('region')." WHERE parent_id='$region_id')";
|
|
$self_point = $db->getAll($sql);
|
|
|
|
//获取城市
|
|
$sql = "SELECT region_name FROM ". $ecs->table('region') ." WHERE region_id=".$region_id;
|
|
$region_name = $db->getOne($sql);
|
|
|
|
if (empty($self_point))
|
|
{
|
|
ecs_header("Location: ./\n");
|
|
exit;
|
|
}
|
|
|
|
$smarty->assign('self_point', $self_point);
|
|
$smarty->assign('region_name', $region_name);
|
|
$smarty->assign('sys_categories', article_categories_tree(0,2)); //系统保留文章分类树by wang
|
|
$smarty->assign('custom_categories', article_categories_tree(0,1)); //自定义文章分类树by wang
|
|
$categories_pro = get_category_tree_leve_one();
|
|
$smarty->assign('categories_pro', $categories_pro); // 分类树加强版
|
|
$smarty->assign('article_categories', article_categories_tree($article_id)); //文章分类树
|
|
$smarty->assign('helps', get_shop_help()); // 网店帮助
|
|
$smarty->assign('new_article', get_new_article(5)); // 网店帮助
|
|
$smarty->assign('id', $article_id);
|
|
$smarty->assign('username', $_SESSION['user_name']);
|
|
$smarty->assign('email', $_SESSION['email']);
|
|
$smarty->assign('type', '1');
|
|
|
|
/* 验证码相关设置 */
|
|
if ((intval($_CFG['captcha']) & CAPTCHA_COMMENT) && gd_version() > 0)
|
|
{
|
|
$smarty->assign('enabled_captcha', 1);
|
|
$smarty->assign('rand', mt_rand());
|
|
}
|
|
|
|
$smarty->assign('article', $article);
|
|
$smarty->assign('keywords', htmlspecialchars($article['keywords']));
|
|
$smarty->assign('description', htmlspecialchars($article['description']));
|
|
|
|
$position = assign_ur_here($article['cat_id'], $article['title']);
|
|
$smarty->assign('page_title', $position['title']); // 页面标题
|
|
$smarty->assign('ur_here', $region_name."市自提点"); // 当前位置
|
|
$smarty->assign('comment_type', 1);
|
|
|
|
assign_dynamic('help');
|
|
assign_template('c', $catlist);
|
|
}
|
|
|
|
$smarty->display('help.dwt', $cache_id);
|
|
|
|
|
|
|
|
/*------------------------------------------------------ */
|
|
//-- PRIVATE FUNCTION
|
|
/*------------------------------------------------------ */
|
|
|
|
/**
|
|
* 获得指定的文章的详细信息
|
|
*
|
|
* @access private
|
|
* @param integer $article_id
|
|
* @return array
|
|
*/
|
|
function get_article_info($article_id)
|
|
{
|
|
/* 获得文章的信息 */
|
|
$sql = "SELECT a.*, IFNULL(AVG(r.comment_rank), 0) AS comment_rank ".
|
|
"FROM " .$GLOBALS['ecs']->table('article'). " AS a ".
|
|
"LEFT JOIN " .$GLOBALS['ecs']->table('comment'). " AS r ON r.id_value = a.article_id AND comment_type = 1 ".
|
|
"WHERE a.is_open = 1 AND a.article_id = '$article_id' GROUP BY a.article_id";
|
|
$row = $GLOBALS['db']->getRow($sql);
|
|
|
|
if ($row !== false)
|
|
{
|
|
$row['comment_rank'] = ceil($row['comment_rank']); // 用户评论级别取整
|
|
$row['add_time'] = local_date($GLOBALS['_CFG']['date_format'], $row['add_time']); // 修正添加时间显示
|
|
|
|
/* 作者信息如果为空,则用网站名称替换 */
|
|
if (empty($row['author']) || $row['author'] == '_SHOPHELP')
|
|
{
|
|
$row['author'] = $GLOBALS['_CFG']['shop_name'];
|
|
}
|
|
}
|
|
|
|
return $row;
|
|
}
|
|
|
|
/**
|
|
* 获得文章关联的商品
|
|
*
|
|
* @access public
|
|
* @param integer $id
|
|
* @return array
|
|
*/
|
|
function article_related_goods($id)
|
|
{
|
|
$sql = 'SELECT g.goods_id, g.goods_name, g.goods_thumb, g.goods_img, g.shop_price AS org_price, ' .
|
|
"IFNULL(mp.user_price, g.shop_price * '$_SESSION[discount]') AS shop_price, ".
|
|
'g.market_price, g.promote_price, g.promote_start_date, g.promote_end_date ' .
|
|
'FROM ' . $GLOBALS['ecs']->table('goods_article') . ' ga ' .
|
|
'LEFT JOIN ' . $GLOBALS['ecs']->table('goods') . ' AS g ON g.goods_id = ga.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 ga.article_id = '$id' AND g.is_on_sale = 1 AND g.is_alone_sale = 1 AND g.is_delete = 0";
|
|
$res = $GLOBALS['db']->query($sql);
|
|
|
|
$arr = array();
|
|
while ($row = $GLOBALS['db']->fetchRow($res))
|
|
{
|
|
$arr[$row['goods_id']]['goods_id'] = $row['goods_id'];
|
|
$arr[$row['goods_id']]['goods_name'] = $row['goods_name'];
|
|
$arr[$row['goods_id']]['short_name'] = $GLOBALS['_CFG']['goods_name_length'] > 0 ?
|
|
sub_str($row['goods_name'], $GLOBALS['_CFG']['goods_name_length']) : $row['goods_name'];
|
|
$arr[$row['goods_id']]['goods_thumb'] = get_image_path($row['goods_id'], $row['goods_thumb'], true);
|
|
$arr[$row['goods_id']]['goods_img'] = get_image_path($row['goods_id'], $row['goods_img']);
|
|
$arr[$row['goods_id']]['market_price'] = price_format($row['market_price']);
|
|
$arr[$row['goods_id']]['shop_price'] = price_format($row['shop_price']);
|
|
$arr[$row['goods_id']]['url'] = build_uri('goods', array('gid' => $row['goods_id']), $row['goods_name']);
|
|
|
|
if ($row['promote_price'] > 0)
|
|
{
|
|
$arr[$row['goods_id']]['promote_price'] = bargain_price($row['promote_price'], $row['promote_start_date'], $row['promote_end_date']);
|
|
$arr[$row['goods_id']]['formated_promote_price'] = price_format($arr[$row['goods_id']]['promote_price']);
|
|
}
|
|
else
|
|
{
|
|
$arr[$row['goods_id']]['promote_price'] = 0;
|
|
}
|
|
}
|
|
|
|
return $arr;
|
|
}
|
|
|
|
?>
|