登录后,购买下载资源更方便!
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
针对ecshop订单中的物品,需要支持拣货的状态,比如未拣货、拣货中、拣货完成,以及显示拣货人姓名。
+ b5 ~! B, S* ~; [7 f# {/ X
0 i7 T; W1 k# `! G3 G8 P( W1.SQL操作:' e. X5 s* _* U: a
9 z# D) b& T% ^$ I& c( K4 K
2.在文件languages\zh_cn\admin\order.php中增加:; h: |, |7 a9 \: R0 D+ o B
/ U! g( Z4 i: I4 w4 C5 k- e. m/* 拣货 */. c" y) t8 h1 [, l% Z3 Q
$_LANG['order_picking_status'] = '拣货状态';6 z$ R% y! P4 w7 R
$_LANG['order_picking_status_none'] = '未拣货';( c5 r( Q# x" m; g$ q) A" v
$_LANG['order_picking_status_processing'] = '拣货中';. u) D5 j/ e# C
$_LANG['order_picking_status_finish'] = '拣货完成';6 z! \# x6 O7 @% D3 E" ~
$_LANG['invalid_order_picking_status'] = '拣货状态无效。0:未拣货;1:拣货中;2:拣货完成';( ?; S$ T6 S( G7 E
6 }5 {9 p3 V% Q" |: U$ A2 F/ a& ?8 c2 r
3.文件admin\templates\order_list.htm中在一下两行之间:- S3 C) b) d- _- h4 `
第一个地方7 Q. R) z# D% b' Y ]
<th>{$lang.all_status}</th>
; M. ]3 ?5 M) x N# y8 S<th>{$lang.handler}</th>- Q3 ~- A4 b8 ], T8 v
中间加上
7 W7 w/ a- K" v. t' B/ ]: Q<th>{$lang.order_picking_status}</th>) G- k3 o$ @( f0 v
) M/ ^% B# `) H
第二个地方5 r" H _% B$ f2 l f1 p9 i7 l
在<td align="center" valign="top" nowrap="nowrap">{$lang.os[$order.order_status]},{$lang.ps[$order.pay_status]},{$lang.ss[$order.shipping_status]}</td>- D5 F5 U; N% a# ^0 K
后面加上
8 `! h$ X7 O% }: {' L" g" f<td align="right" valign="top"nowrap="nowrap"><span>{$order.user_name}【{if $order.order_picking_status == 1}{$lang.order_picking_status_processing}{elseif $order.order_picking_status ==2} {$lang.order_picking_status_finish} {else}{$lang.order_picking_status_none}{/if}】</span></td>
, J% i. w0 k, |( \8 r
, r4 ~ {( E7 H8 x( l
. T& O; G+ Y& J' y6 [" e6 G9 `( K& ]' U! W: |0 p' i
4.admin\js\listtable.js中,listTable.edit的响应函数修改如下:
8 S7 I- H/ f9 B/ t6 G! l0 Q. M0 s4 q, I
7 a3 p& y8 d- {1 d$ a3 F
/** * 创建一个可编辑区 */ listTable.edit = function(obj, act, id) { var tag =obj.firstChild.tagName; if (typeof(tag) !="undefined" && tag.toLowerCase() == "input") { return; } /* 保存原始的内容 */ var org = obj.innerHTML; var val = Browser.isIE ?obj.innerText : obj.textContent; /* 创建一个输入框 */ var txt =document.createElement("INPUT"); txt.value = (val == 'N/A') ?'' : val; txt.style.width =(obj.offsetWidth + 12) + "px" ; /* 隐藏对象中的内容,并将输入框加入到对象中 */ obj.innerHTML =""; obj.appendChild(txt); txt.focus(); txt.select(); /* 编辑区输入事件处理函数 */ txt.onkeypress = function(e) { var evt =Utils.fixEvent(e); var obj =Utils.srcElement(e); if (evt.keyCode == 13)//www.zuimoban.com { obj.blur(); return false; } if (evt.keyCode == 27) { obj.parentNode.innerHTML= org; } } /* 编辑区失去焦点的处理函数 */ txt.onblur = function(e) { if(Utils.trim(txt.value).length > 0) { res =Ajax.call(listTable.url, "act="+act+"&val=" +encodeURIComponent(Utils.trim(txt.value)) + "&id=" +id, null,"POST", "JSON", false); if (res.message) { alert(res.message); } if(res.id &&(res.act == 'goods_auto' || res.act == 'article_auto')) { document.getElementById('del'+res.id).innerHTML = "<ahref=\""+ thisfile +"?goods_id="+ res.id+"&act=del\" onclick=\"returnconfirm('"+deleteck+"');\">"+deleteid+"</a>"; } obj.innerHTML = (res.error== 0) ? res.content : org; } else { obj.innerHTML = org; } if (act =='edit_is_validated') { var content = obj.innerHTML.trim(); if (content == '1' || content.indexOf("yes") >= 0) { obj.innerHTML = '<imgsrc="images/yes.gif">'; } else { obj.innerHTML ='<img src="images/no.gif">'; } } else if (act =='edit_order_picking_status') { if (org == obj.innerHTML) { return true; } if (obj.innerHTML == '1') { obj.innerHTML ="【拣货中】"; } else if (obj.innerHTML == '2') { obj.innerHTML ="【拣货完成】"; } else { obj.innerHTML ="【未拣货】"; } } else { } }
# ?( }" t4 z3 a9 ^9 g. _}
: O, ~4 @, n1 q7 t- ^5.admin\order.php文件中增加下面的函数:
0 X# [, o, u5 |2 j" G0 `* F, Z$ B# s2 n
/*------------------------------------------------------ */7 P, ?- y: f0 O! [
//-- 订单拣货状态查询
+ _0 C9 Y4 Z4 a2 R/*------------------------------------------------------ */
; q" e" e4 Q6 K5 E" C8 G
. R; d* w: @* Q, l( S2 dif ($_REQUEST['act'] == 'edit_order_picking_status')
2 \: V8 M! h+ E7 |. m/ u{6 m _! i( P, w+ O$ F3 v
/* 检查权限 */0 N) J5 g: k h; \5 x
check_authz_json('users_manage');; I9 I. I2 L6 }6 n7 R# U1 E
: D, }% E3 T+ l( O) ?
$id =empty($_REQUEST['id']) ? 0 : intval($_REQUEST['id']);$ B7 o* @% A; n% H1 J, R0 v
$order_picking_status =empty($_REQUEST['val']) ? '' : json_str_iconv(trim($_REQUEST['val']));( N% ^1 r& {1 g6 r0 X
! T3 v* M% W% Z% s( u0 F! ^0 a $sql = "DELETE fromorder_picking_status WHERE order_id = '". $id ."' LIMIT 1";) U& o! _1 \5 m8 J. y
$db->query($sql);! L+ Z$ E" y. O( O
6 _) N' Q6 v' h8 b
$sql = "INSERT INTOorder_picking_status (order_id, user_name, order_picking_status) VALUES('". $id ."', '". $_SESSION['admin_name'] ."', '".$order_picking_status ."')";$ O7 f+ E( t( N8 ]
$db->query($sql);" p4 c! [$ p2 k1 Y% o6 h( o I% G
/ v5 c1 |0 Z* `1 Q
if ($order_picking_status> 2 || $order_picking_status < 0): @6 K) R! p z0 E
{
4 Q q. I1 V/ i$ s make_json_error($GLOBALS['_LANG']['invalid_order_picking_status']);3 h- y, B) w4 U/ ~3 l
}
, T2 n6 a6 r% P' H. o else# i' L$ o( L7 _2 s% u
{
0 _: L3 C( Q+ L" ~& M4 x8 ~4 ^ make_json_result($order_picking_status);9 p3 c# L0 `- b
}
* V8 C& z& r1 ?, A}
0 z) h6 U9 M- B* T; t/ D( S% H; @! ?! W6 b
6、admin\order.php文件中增加下面的函数将以下代码4 g# p. w! r1 B2 E y2 A* V$ |# |
/* 查询 */: ~; u0 e- D. ]2 Y+ v* v
$sql = "SELECT o.*," ./ N, C3 b5 _# K
"o.pay_status, o.consignee, o.firstname, o.lastname, o.address, o.email, o.tel, o.extension_code, o.extension_id, " .
- q S) l9 ]: y5 f8 R "(" . order_amount_field('o.') . ") AS total_fee, " .4 }, O0 }3 P1 m0 g+ d: T
"IFNULL(u.user_name, '" .$GLOBALS['_LANG']['anonymous']. "') AS buyer ".& f9 J$ n S; ? E2 h4 b% s: h0 o
" FROM " . $GLOBALS['ecs']->table('order_info') . " AS o " .
* a/ r4 A0 S" t( C/ z7 ~ " LEFT JOIN " .$GLOBALS['ecs']->table('users'). " AS u ON u.user_id=o.user_id ". $where .
! G8 ~# ~ d, Q8 H1 a; a " ORDER BY $filter[sort_by] $filter[sort_order] ".
+ t5 y6 {& e& n' A) L8 D% u " LIMIT " . ($filter['page'] - 1) * $filter['page_size'] . ",$filter[page_size]"; : [! S# {/ X& Q5 ?) {8 E2 ]9 g5 B
修改为:
! ~- A/ \9 |, @) {3 P7 ]# z7 q1 ^ //* 查询 */
& a8 E+ z- u' j) P& \3 _) N1 ?) i% G1 Z $sql = "SELECT o.*," .
7 f- `- E# T( r2 L) x! f6 H: w5 M& ? "o.pay_status, o.consignee, o.firstname, o.lastname, o.address, o.email, o.tel, o.extension_code, o.extension_id, " .% q; T( |# R2 y+ q# R# G6 d
"(" . order_amount_field('o.') . ") AS total_fee, " .% H3 u' g b; u* k7 _! v
"IFNULL(u.user_name, '" .$GLOBALS['_LANG']['anonymous']. "') AS buyer , p.user_name, p.order_picking_status, r.order_reply_status ".
3 x5 S3 v7 i3 `; o& u " FROM " . $GLOBALS['ecs']->table('order_info') . " AS o " .5 ], R( C0 K" T, D0 u7 r( w5 x
" LEFT JOIN " .$GLOBALS['ecs']->table('users'). " AS u ON u.user_id=o.user_id ".
( }: n0 P6 c3 D9 Y' [ " LEFT JOIN order_reply_status AS r ON r.order_id = o.order_id ". $ k: F9 l6 Z# i( p0 K' P# V5 }9 ~6 J8 c
" LEFT JOIN order_picking_status AS p ON p.order_id = o.order_id ". $where .
7 y. Q% ^2 C5 O3 { " ORDER BY $filter[sort_by] $filter[sort_order] ".
2 p* i6 L* K3 w " LIMIT " . ($filter['page'] - 1) * $filter['page_size'] . ",$filter[page_size]";) G d1 B% f- ^& F4 O
4 X* \' C7 P9 u2 i% K9 M
2 M0 S5 R F( _1 T& S. }& x) s
$ R/ o3 f/ h, [: I$ D4 K |