存档

‘ecshop’ 分类的存档

为ECSHOP后台添加通过email搜索用户的功能

2010年8月15日 果果 35 条评论

RT:准备以下两个文件admin/users.php以及admin/templates/users_list.htm
1,修改admin/users.php:
查找“过滤条件”,672行左右,在$filter['keywords']后一行添加

$filter['email'] = empty($_REQUEST['email']) ? '' : trim($_REQUEST['email']);

查找

if ($filter['keywords'])
        {
            $ex_where .= " AND user_name LIKE '%" . mysql_like_quote($filter['keywords']) ."%'";
        }

修改为:

if ($filter['keywords'] && $filter['email'])
        {
            $ex_where .= " AND user_name LIKE '%" . mysql_like_quote($filter['keywords']) ."%' AND email LIKE '%" . mysql_like_quote($filter['email']) ."%'";
        }
  elseif($filter['keywords'])
  {
   $ex_where .= " AND user_name LIKE '%" . mysql_like_quote($filter['keywords']) ."%'";
  }
  elseif($filter['email'])
  {
      $ex_where .= " AND email LIKE '%" . mysql_like_quote($filter['email']) ."%'";
  }

2,修改admin/templates/users_list.htm
查找 {$lang.label_user_name},11行左右,在下面添加

&nbsp;邮箱地址 &nbsp;<input type="text" name="email" /> <input type="submit" value="{$lang.button_search}" />

查找listTable.filter['rank'],97行左右,在后面添加:

listTable.filter['email'] = document.forms['searchForm'].elements['email'].value;

至此就可以在用户列表里面通过邮箱查找用户了。

分类: ecshop 标签:

为ECSHOP后台添加通过快递单号搜索订单的功能

2010年8月15日 果果 78 条评论

RT,需要修改admin/order.php,admin/templates/order_list.htm两个文件

1,修改admin/order.php添加代码:

搜索“过滤信息”,在后面添加

$filter['invoice_no'] = empty($_REQUEST['invoice_no']) ? '' : trim($_REQUEST['invoice_no']);

找到

if ($filter['address'])
        {
            $where .= " AND o.address LIKE '%" . mysql_like_quote($filter['address']) . "%'";
        }

在后面添加:

if ($filter['invoice_no'])
        {
            $where .= " AND o.invoice_no LIKE '%" . mysql_like_quote($filter['invoice_no']) . "%'";
        }

2,修改后台模板文件:第八行{$lang.order_sn}下添加

发货单号<input name="invoice_no" type="text" id="invoice_no" size="15">

在搜索订单部分,listTable.filter['consignee']下添加一行

listTable.filter['invoice_no'] = Utils.trim(document.forms['searchForm'].elements['invoice_no'].value);

修改完成后就可以在订单列表也看到快递单搜索框了,注意备份源文件

分类: ecshop 标签:

ECSHOP添加指定支付方式享受折扣功能

2010年8月12日 果果 49 条评论

需要修改的文件:includes/lib_order.php, themes/../order_total.lib

修改order_total.lib代码,将if $total.pay_fee > 0修改为如下内容

<!-- {if $total.pay_fee neq 0} 支付费用 -->
      + {$lang.pay_fee}: <font>{$total.pay_fee_formated}</font>
      <!-- {/if} -->

修改lib_order.php,找到“/* 支付费用是一个比例 */”,修改下面计算方法为

   

 {

        /* 支付费用是一个比例 */

        $val     = floatval($rate) / 100;

        $pay_fee = $order_amount * $val;

    }

在订单页面,将负号显示在货币前面,修改lib_order.php,找到pay_fee_formated,修改如下

if($total['pay_fee']<0){
  $total['pay_fee_formated'] = "-".price_format((-1 * $total['pay_fee']), false);
 }else{
  $total['pay_fee_formated'] = price_format($total['pay_fee'], false);
 }

就可以在后台设置支付费用时,输入-10%,即可选用该支付方式时打九折

分类: ecshop 标签: ,

修改ECSHOP后台订单列表默认订单状态为请选择

2010年8月11日 果果 302 条评论

修改admin/templates/order_list.htm,大约10行左右,最后添加selected=-1

{html_options options=$status_list selected=-1}
分类: ecshop 标签:

用Google Analytics分析ECShop的电子商务数据

2010年7月20日 果果 61 条评论

此方法的缺陷是,只要下订单GA就认为算一次交易,是否付款跟踪不到

1,注册:http://www.google.com/analytics

2,创建账号、站点.

3,设置站点时要将“电子商务”(Ecommerce)选成”yes”.

4,在ECSHOP themes/library/page_footer.lbi 的末尾,加上google analytics的统计代码

(要将UA-xxxxxx-1改成自己的)

<script type="text/javascript">
var gaJsHost = (("https:" == document.location.protocol) ? "https://ssl." : "http://www.");
document.write(unescape("%3Cscript src='" + gaJsHost + "google-analytics.com/ga.js' type='text/javascript'%3E%3C/script%3E"));
</script>
<script type="text/javascript">
try {
var pageTracker = _gat._getTracker("UA-xxxxxx-1");
pageTracker._trackPageview();
<!-- {if $step eq "done"} 订单提交成功-->
pageTracker._addTrans(
    "<!--{$order.order_sn}-->",                                     // Order ID
    "<!--{$order.parent_id}-->",                            // Affiliation
    "<!--{$order.goods_amount}-->",                                    // Total
    "0",                                     // Tax
    "<!--{$order.shipping_fee}-->",                                        // Shipping
    "<!--{$order.city}|{$order.district}-->",                                 // City
    "<!--{$order.province}-->",                               // State
    "<!--{$order.country}-->"                                       // Country
  );

<!--{foreach from=$goods_list item=goods}-->
  pageTracker._addItem(
    "<!--{$order.order_sn}-->",                                     // Order ID
    "<!--{$goods.goods_sn}-->",                                     // SKU
    "<!--{$goods.goods_name}-->",                                  // Product Name
    "<!--{$goods.goods_id}-->",                             // Category
    "<!--{$goods.goods_price}-->",                                    // Price
    "<!--{$goods.goods_number}-->"                                         // Quantity
  );
<!--{/foreach}-->
  pageTracker._trackTrans();
<!-- {/if} -->
} catch(err) {}</script>

完毕。

ecshop在首页调用指定分类的文章

2010年7月16日 果果 107 条评论

具体样式请自行调整

举例如首页调用方法:
1、先打开index.php文件找到以下代码:
$smarty->assign(’new_articles’, index_get_new_articles()); // 最新文章

在它下面增加以下:
//调用方法

$smarty->assign(’class_articles_4′, index_get_class_articles(4,6)); // 分类调用文章
//调用多个就修改传进去的参数,以及模板接收的变量,其中上面的4就是文章分类ID,其中6是调用数量
$smarty->assign(’class_articles_5′, index_get_class_articles(5,6)); // 分类调用文章
$smarty->assign(’class_articles_6′, index_get_class_articles(6,6)); // 分类调用文章
$smarty->assign(’class_articles_7′, index_get_class_articles(7,6)); // 分类调用文章
$smarty->assign(’class_articles_8′, index_get_class_articles(8,6)); // 分类调用文章

//在最后?>这个之前增加以下函数

/**
* 获得指定栏目最新的文章列表。
*
* @access private
* @return array
*/
function index_get_class_articles($cat_aid, $cat_num)
{
$sql = “SELECT article_id, title,open_type,cat_id,file_url FROM ” .$GLOBALS['ecs']->table(’article’). ” WHERE cat_id = “.$cat_aid.” and is_open = 1 LIMIT ” . $cat_num;
$res = $GLOBALS['db']->getAll($sql);
$arr = array();
foreach ($res AS $idx => $row)
{
$arr[$idx]['id'] = $row['article_id'];
$arr[$idx]['title'] = $row['title'];
$arr[$idx]['short_title'] = $GLOBALS['_CFG']['article_title_length'] > 0 ?
sub_str($row['title'], $GLOBALS['_CFG']['article_title_length']) : $row['title'];
$arr[$idx]['cat_name'] = $row['cat_name'];
$arr[$idx]['add_time'] = local_date($GLOBALS['_CFG']['date_format'], $row['add_time']);
$arr[$idx]['url'] = $row['open_type'] != 1 ?
build_uri(’article’, array(’aid’ => $row['article_id']), $row['title']) : trim($row['file_url']);
$arr[$idx]['cat_url'] = build_uri(’article_cat’, array(’acid’ => $row['cat_id']));
}
return $arr;
}

2、第二步是在index.dwt模板想调用的地方增加以下代码,(注:以下调上面设置里的分类ID为8的文章列表):

<!–{foreach from=$class_articles_8 item=article}–>
<li><a href=”{$article.url}” title=”{$article.title|escape:html}”><!–{$article.short_title|truncate:15:true}–></a></li>
<!–{/foreach}–>

ECSHOP注册会员自动发送验证邮件

2010年5月26日 果果 298 条评论

ECshop的验证邮件默认只能用户登录用户中心点击发送才能收到,这里让他改为用户注册时自动发送。适当编写邮件内容也可以让他同时具有注册通知邮件的效果。

在user.php
里面的 大概235行
            if (!empty($passwd_answer) && !empty($sel_question))
            {
                $sql = ‘UPDATE ‘ . $ecs->table(’users’) . ” SET `passwd_question`=’$sel_question’, `passwd_answer`=’$passwd_answer’  WHERE `user_id`=’” . $_SESSION['user_id'] . “‘”;
                $db->query($sql);
            }

            $ucdata = empty($user->ucdata)? “” : $user->ucdata;

下添加
           /* 发送邮件 */
          $cfg = $_CFG['smtp_user'];
          if(!empty($cfg) )
          {
              $sql=”select user_id from “.$GLOBALS['ecs']->table(’users’) .”where user_name = ‘$username’”;
              $user_id=$db->getOne($sql);
              send_regiter_hash ($user_id);
           }

如何修改ECSHOP邮编电话只能输入数字的限制

2010年5月24日 果果 49 条评论

做外贸的经常遇到客户邮编有字母的情况,但ecshop默认是判定只能输入数字

修改js/shopping_flow.js

改为只判断是否为空就可以了
if (frm.elements['zipcode'] && Utils.isEmpty(frm.elements['zipcode'].value))
  {
    err = true;
    msg.push(”Please Enter zip/post code!”);
  }

同样,美国的用户习惯在电话里加(),比如(021)-985-5875
也可以用上面的方法解决。

if (frm.elements['tel'] && Utils.isEmpty(frm.elements['tel'].value))
  {
    err = true;
    msg.push(tele_not_null);
  }

分类: ecshop 标签: ,