12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000 |
- <?php
- /**
- * 小梦科技资源nanodreamtech.com
- *
- * ==========================================================================
- * @link https://www.nanodreamtech.com/
- * @copyright Copyright (c) 2015 liofis.com.
- * @license https://www.nanodreamtech.com/license.html License
- * ==========================================================================
- *
- * @author fish
- *
- */
- namespace Home\Controller;
- class CartController extends CommonController {
-
- public function add()
- {
- global $_W;
- global $_GPC;
-
- $data = array();
- $data['goods_id'] = $_GPC['goods_id'];
- $data['community_id'] = $_GPC['community_id'];
- $data['quantity'] = $_GPC['quantity'];
- $data['sku_str'] = $_GPC['sku_str'];
- if($_GPC['sku_str'] == 'undefined')
- {
- $_GPC['sku_str'] = '';
- $data['sku_str'] = '';
- }
-
-
-
-
- $data['buy_type'] = $_GPC['buy_type'];
- $data['pin_id'] = $_GPC['pin_id'];
- $data['is_just_addcar'] = $_GPC['is_just_addcar'];
-
- if( !isset($data['buy_type']) || empty($data['buy_type']) )
- {
- $data['buy_type'] = 'dan';
- }
- $token = $_GPC['token'];
-
-
-
- $token_param = array();
- $token_param[':uniacid'] = $_W['uniacid'];
- $token_param[':token'] = $token;
-
- $weprogram_token = pdo_fetch("select member_id from ".tablename('lionfish_comshop_weprogram_token')." where uniacid=:uniacid and token=:token limit 1", $token_param);
-
- $member_id = $weprogram_token['member_id'];
-
-
- $is_just_addcar = empty($data['is_just_addcar']) ? 0: 1;
-
- $goods_id = $data['goods_id'];
- if( empty($member_id))
- {
- $result = array('code' =>4);
- echo json_encode($result);
- die();
- }
-
- if (isset($data['goods_id'])) {
- $goods_id = $data['goods_id'];
- } else {
- $goods_id = 0;
- }
-
- $goods_param = array();
- $goods_sql = "select * from ".tablename('lionfish_comshop_goods')." where uniacid=:uniacid and id=:id limit 1";
-
- $product = pdo_fetch($goods_sql, array(':uniacid' => $_W['uniacid'], ':id' => $goods_id));
-
- if( $product['grounding'] != 1)
- {
- $json['code'] =6;
- $json['msg']='商品已下架!';
- echo json_encode($json);
- die();
- }
-
-
- //判断是否积分兑换
- if( $product['type'] == 'integral')
- {
- //判断积分是否足够 member_id 暂时关闭以下代码
- /**
- $integral_model = D('Seller/Integral');
- $check_result = $integral_model->check_user_score_can_pay($member_id, $data['sku_str'], $goods_id);
-
- if( $check_result['code'] == 1 )
- {
- $json['code'] =6;
- $json['msg']='剩余'.$check_result['cur_score'].'积分,积分不足!';
- echo json_encode($json);
- die();
- }
- **/
- }
-
- //6
- if($is_just_addcar == 1)
- {
- if($product['pick_just'] > 0)
- {
- $json['code'] =6;
- $json['msg']='自提商品,请立即购买';
- echo json_encode($json);
- die();
- }
- }
-
- //商品存在
- if($product){
-
- $cart= load_model_class('car');
-
- if (isset($data['quantity'])) {
- $quantity = $data['quantity'];
- } else {
- $quantity = 1;
- }
-
- $option = array();
-
- if( !empty($data['sku_str'])){
- $option = explode('_', $data['sku_str']);
- }
-
- $cart_goods_quantity = $cart->get_wecart_goods($goods_id,$data['sku_str'],$data['community_id'] ,$token);
-
- $json=array('code' =>0);
- //$goods_model = D('Home/Goods');
- $goods_quantity=$cart->get_goods_quantity($goods_id);
-
-
- //检测商品限购 6
-
- $can_buy_count = D('Home/Front')->check_goods_user_canbuy_count($member_id, $goods_id);
-
- $goods_description = D('Home/Front')->get_goods_common_field($goods_id , 'total_limit_count');
-
- if($can_buy_count == -1)
- {
- $json['code'] =6;
- //$json['msg']='已经不能再买了';
-
- $json['msg']='每人最多购买'.$goods_description['total_limit_count'].'个哦';
-
- echo json_encode($json);
- die();
- }else if($can_buy_count >0 && $quantity >$can_buy_count)
- {
- $json['code'] =6;
- $json['msg']='您还能购买'.$can_buy_count.'份';
- echo json_encode($json);
- die();
- }
-
- //已加入购物车的总数
-
- if($goods_quantity<$quantity+$cart_goods_quantity){
- $json['code'] =3;
- if ($goods_quantity==0) {
- $json['msg']='已抢光';
- }else{
- $json['msg']='商品数量不足,剩余'.$goods_quantity.'个!!';
- }
- echo json_encode($json);
- die();
- }
- //rela_goodsoption_valueid
-
- if(!empty($option))
- {
- $mul_opt_arr = array();
-
- //ims_
-
- $mult_sql = "select * from ".tablename('lionfish_comshop_goods_option_item_value')."
- where uniacid=:uniacid and option_item_ids = :sku_str and goods_id =:goods_id limit 1 ";
-
- $goods_option_mult_value = pdo_fetch($mult_sql, array(':uniacid' => $_W['uniacid'],':sku_str' =>$data['sku_str'],':goods_id' => $goods_id ));
-
- if( !empty($goods_option_mult_value) )
- {
- if($goods_option_mult_value['stock']<$quantity+$cart_goods_quantity){
- $json['code'] =3;
- $json['msg']='商品数量不足,剩余'.$goods_option_mult_value['stock'].'个!!';
- echo json_encode($json);
- die();
- }
- }
- }
- //buy_type
-
- // $this->clear_all_cart(); $data['community_id']
- $format_data_array = array('quantity' => $quantity,'community_id' => $data['community_id'] ,'goods_id' => $goods_id,'sku_str'=>$data['sku_str'],'buy_type' =>$data['buy_type']);
- //区分活动商品还是普通商品。做两个购物车,活动商品是需要直接购买的,单独购买商品加入正常的购物车TODO....
- //is_just_addcar 0 1
- if($data['buy_type'] == 'dan' && $is_just_addcar == 0)
- {
-
- //$cart->removedancar($token);
- //清空一下购物车
- //singledel
- $format_data_array['is_just_addcar'] = 0;
- $format_data_array['singledel'] = 1;
-
- $cart->addwecar($token,$goods_id,$format_data_array,$data['sku_str'],$data['community_id']);
- $total=$cart->count_goodscar($token ,$data['community_id']);
- }
- else if($data['buy_type'] == 'dan' && $is_just_addcar == 1)
- {
- //singledel
- $format_data_array['is_just_addcar'] = 1;
- $format_data_array['singledel'] = 1;
- $cart->addwecar($token,$goods_id,$format_data_array,$data['sku_str'],$data['community_id']);
- $total=$cart->count_goodscar($token, $data['community_id']);
- }
- else {
- //buy_type:pin 活动购物车。
- $pin_id = isset($data['pin_id']) ? $data['pin_id'] : 0;
-
- //lottery
- if( $product['type'] == 'lottery' && $product['type'] == 'lottery' )
- {
- /**
- //等待把抽奖的活动打开
- $now_time = time();
- $lottery_goods_info = M('lottery_goods')->where( array('goods_id' => $goods_id) )->find();
-
- if($lottery_goods_info['end_time'] < $now_time)
- {
- $json['code'] =6;
- $json['msg']='抽奖活动已结束';
- echo json_encode($json);
- die();
- }
- **/
- }
-
- //检测商品是否老带新,新人才能参团
- if($pin_id > 0 )
- {
- //等待把老带新的活动打开
- /**
- if($product['type'] == 'newman')
- {
- $new_mamn_buy = $goods_model->check_goods_new_manbug($member_id);
- if($new_mamn_buy>0)
- {
- $json['code'] =5;
- $json['msg']='该商品只能新人参团';
- echo json_encode($json);
- die();
- }
- }
- **/
- }
-
- $format_data_array['pin_id'] = $pin_id;
- $cart->add_activitycar($token, $goods_id,$format_data_array,$data['sku_str']);
- $total=$cart->count_activitycar($token);
- }
-
-
- $car_total_sql = "select * from ".tablename('lionfish_comshop_car')." where token=:token and community_id=:community_id and uniacid=:uniacid and carkey ='cart_total' ";
- $carts = pdo_fetch($car_total_sql, array(':token' => $token,':community_id' => $data['community_id'],':uniacid' => $_W['uniacid']));
-
- if( !empty($carts) )
- {
- $car_data = array();
- $car_data['format_data'] = serialize(array('quantity' => $total));
- $car_data['modifytime'] = 1;
-
- pdo_update('lionfish_comshop_car', $car_data, array('token' => $token,'community_id' => $data['community_id'],'carkey' => 'cart_total'));
-
- } else{
-
- $car_data = array();
- $car_data['token'] = $token;
- $car_data['uniacid'] = $_W['uniacid'];
- $car_data['community_id'] = $data['community_id'];
- $car_data['carkey'] = 'cart_total';
- $car_data['format_data'] = serialize(array('quantity' => $total));
- pdo_insert('lionfish_comshop_car', $car_data);
- }
- //session('cart_total',$total);
- $json ['code'] = 1;
- if( $data['buy_type'] != 'dan' )
- {
- $json ['code'] = 2;
- }
- $json['success']='成功加入购物车!!';
- $json['total']=$total;
- echo json_encode($json);
- die();
- }
-
- }
-
- //显示购物车中商品列表
- function show_cart_goods(){
-
- global $_W;
- global $_GPC;
-
- $token = $_GPC['token'];
- $community_id = $_GPC['community_id'];
-
-
- $token_param = array();
- $token_param[':uniacid'] = $_W['uniacid'];
- $token_param[':token'] = $token;
- $weprogram_token = pdo_fetch("select member_id from ".tablename('lionfish_comshop_weprogram_token')." where uniacid=:uniacid and token=:token limit 1", $token_param);
-
- $member_id = $weprogram_token['member_id'];
-
- $buy_type = isset($_GPC['buy_type']) ? $_GPC['buy_type']: 'dan';
-
- if( empty($member_id) )
- {
- //需要登录
- echo json_encode( array('code' =>5) );
- die();
- }
-
- $cart = load_model_class('car');
-
- $goods = $cart->get_all_goodswecar($buy_type, $token, 0, $community_id);
-
- $seller_goodss = array();
- foreach($goods as $key => $val)
- {
- //$goods_store_field = M('goods')->field('store_id')->where( array('goods_id' => $val['goods_id']) )->find();
- //$seller_goodss[ $goods_store_field['store_id'] ]['goods'][$key] = $val;
- $seller_goodss[ 1 ]['goods'][$key] = $val;
- }
-
- $ck_goodstype_count = 0;
-
- foreach($seller_goodss as $store_id => $val)
- {
- //total
- $seller_voucher_list = array();
- $seller_total_fee = 0;
- $total_trans_free = 0;
-
- $tmp_goods = array();
-
- $is_store_ck = false;
-
- foreach($val['goods'] as $kk =>$d_goods)
- {
- $seller_total_fee += $d_goods['total'];
-
- $total_trans_free += $d_goods[$kk]['trans_free'];
- $val['goods'][$kk] = $d_goods;
-
- $tp_val = array();
- $tp_val['id'] = $d_goods['goods_id'];
- $tp_val['key'] = $d_goods['key'];
- if($d_goods['singledel'] == 1)
- {
- $tp_val['isselect'] = true;
- $is_store_ck = true;
- $ck_goodstype_count++;
- } else {
- $tp_val['isselect'] = false;
- }
-
- $tp_val['imgurl'] = $d_goods['image'];
- $tp_val['edit'] = 'inline';
- $tp_val['title'] = $d_goods['name'];
- $tp_val['finish'] = 'none';
- $tp_val['description'] = 'description';
-
- $option_arr = array();
- $option_str = "";
- foreach($d_goods['option'] as $option_val)
- {
- $option_arr[] = $option_val['name'].':'.$option_val['value'];
- }
- if(!empty($option_arr))
- {
- $option_str = implode(',', $option_arr);
- }
-
- $tp_val['goodstype'] = $option_str;
- $tp_val['goodstypeedit'] = $option_str;
- $tp_val['goodsnum'] = $d_goods['quantity'];
- $tp_val['max_quantity'] = $d_goods['max_quantity'];
- $tp_val['cartype'] = 'inline';
- $tp_val['currntprice'] = $d_goods['price'];
- $tp_val['price'] = $d_goods['shop_price'];
-
- $tmp_goods[] = $tp_val;
-
- }
-
- //$store_info = M('seller')->field('s_id,s_true_name,s_logo')->where( array('s_id' => $store_id) )->find();
- //$store_info['s_logo'] = C('SITE_URL').'Uploads/image/'.$store_info['s_logo'];
-
- $store_info = array('s_true_name' => '','s_id' => 1);
- $s_logo = D('Home/Front')->get_config_by_name('shoplogo');
-
- if( !empty($s_logo) )
- {
- $s_logo = tomedia($s_logo);
- }
-
- $val['store_info'] = $store_info;
-
- $store_data = array();
- $store_data['id'] = $store_info['s_id'];
- if($is_store_ck)
- {
- $store_data['isselect'] = true;
- } else {
- $store_data['isselect'] = false;
- }
-
- $store_data['shopname'] = $store_info['s_true_name'];
- $store_data['caredit'] = 'inline';
- $store_data['finish'] = 'none';
- $store_data['count'] = '0.00';
- $store_data['goodstype'] = 2;
- $store_data['goodstypeselect'] = 0;
- $store_data['shopcarts'] = $tmp_goods;
-
-
- $seller_goodss[$store_id] = $store_data;
- $i++;
- }
-
- $need_data = array();
- $need_data['code'] = 0;
- $need_data['carts'] = $seller_goodss;
-
- echo json_encode( $need_data );
- die();
-
- }
-
- public function checkout_flushall()
- {
- global $_W;
- global $_GPC;
-
- $token = $_GPC['token'];
-
- $community_id = $_GPC['community_id'];
-
- $token_param = array();
- $token_param[':uniacid'] = $_W['uniacid'];
- $token_param[':token'] = $token;
- $weprogram_token = pdo_fetch("select member_id from ".tablename('lionfish_comshop_weprogram_token')." where uniacid=:uniacid and token=:token limit 1", $token_param);
-
- $member_id = $weprogram_token['member_id'];
-
- $data = array();
- $data['car_key'] = $_GPC['car_key'];
- $data['all_keys_arr'] = $_GPC['all_keys_arr'];
-
- //car_key:cart.6:MTc0:,cart.13:MjcwXzI3Mw==:
- //all_keys_arr:cart.6:MTc0:_1,cart.13:MjcwXzI3Mw==:_1
- $car_key = explode(',', $data['car_key']);
- $all_keys_arr = explode(',', $data['all_keys_arr']) ;
-
- $save_keys = array();
- if(!empty($all_keys_arr)){
- foreach($all_keys_arr as $val)
- {
- $tmp_val = explode('_', $val);
- $save_keys[ $tmp_val[0] ] = $tmp_val[1];
- }
- }
-
-
- $all_cart = pdo_fetchall("select * from ".tablename('lionfish_comshop_car')." where uniacid=:uniacid and community_id=:community_id and token=:token and carkey like 'cart.%' ",
- array(':uniacid' => $_W['uniacid'],':community_id' => $community_id, ':token' => $token));
-
- if(!empty($all_cart))
- {
- foreach($all_cart as $val)
- {
- $tmp_format_data = unserialize($val['format_data']);
- $tmp_format_data['singledel'] = 0;
- $tmp_format_data['quantity'] = $save_keys[$val['carkey']];
- pdo_update('lionfish_comshop_car', array('format_data' => serialize($tmp_format_data) ), array('id' => $val['id'] ,'community_id' => $community_id));
- }
- }
-
- if(!empty($car_key)){
- foreach( $car_key as $key )
- {
- $car_info = pdo_fetch("select * from ".tablename('lionfish_comshop_car')." where uniacid=:uniacid and community_id=:community_id and carkey=:carkey and token=:token ",
- array(':token' => $token,':carkey' => $key,':uniacid' => $_W['uniacid'], ':community_id' => $community_id));
-
- if( !empty($car_info) )
- {
- $tmp_format_data = unserialize($car_info['format_data']);
- $tmp_format_data['singledel'] = 1;
- $quantity = $tmp_format_data['quantity'];
- $goods_id = $tmp_format_data['goods_id'];
- $sku_str = $tmp_format_data['sku_str'];
-
- $check_json = $this->_check_can_buy($member_id, $goods_id,$quantity);
-
- if($check_json['code'] != 0)
- {
- $tmp_format_data['quantity'] = $check_json['count'];
-
- pdo_update('lionfish_comshop_car', array('format_data' => serialize($tmp_format_data) ),
- array('id' => $car_info['id'], 'community_id' => $community_id));
-
- echo json_encode( array('code' => 6,'msg' => $check_json['msg']) );
- die();
- }
- $check_json = $this->_check_goods_quantity($goods_id,$quantity,$sku_str);
-
- if($check_json['code'] != 0)
- {
- echo json_encode( array('code' => 6,'msg' => $check_json['msg']) );
- die();
- }
- pdo_update('lionfish_comshop_car', array('format_data' => serialize($tmp_format_data) ),
- array('id' => $car_info['id'], 'community_id' => $community_id));
-
- }
- }
- }
- echo json_encode( array('code' => 0) );
- die();
- }
-
- public function del_car_goods()
- {
- global $_W;
- global $_GPC;
-
- $token = $_GPC['token'];
- $community_id = $_GPC['community_id'];
-
- $carkey = $_GPC['carkey'];
-
-
- $sql_del = "delete from ".tablename('lionfish_comshop_car')." where uniacid={$_W[uniacid]} and community_id={$community_id} and token='{$token}' and carkey='{$carkey}' ";
-
- $all_cart = pdo_query($sql_del);
-
- echo json_encode( array('code' => 0) );
- die();
-
- }
-
- public function _check_goods_quantity($goods_id,$quantity,$sku_str)
- {
- global $_W;
- global $_GPC;
-
-
- $goods_info = pdo_fetch("select goodsname as name from ".tablename('lionfish_comshop_goods')." where id=:id and uniacid=:uniacid ",array(':uniacid'=>$_W['uniacid'],':id' => $goods_id));
-
- $goods_quantity= load_model_class('car')->get_goods_quantity($goods_id);
- $json = array('code' => 0);
-
- if($goods_quantity<$quantity){
- $json['code'] =3;
- $json['msg']= mb_substr($goods_info['name'],0,4,'utf-8').'...,商品数量不足,剩余'.$goods_quantity.'个!!';
-
- }else if(!empty($sku_str))
- {
- $mul_opt_arr = array();
-
- $goods_option_mult_value = pdo_fetch("select stock as quantity from ".tablename('lionfish_comshop_goods_option_item_value')." where uniacid=:uniacid and goods_id=:goods_id and option_item_ids=:option_item_ids ", array(':goods_id'=>$goods_id,':option_item_ids' => $sku_str,':uniacid' => $_W['uniacid']));
-
- if( !empty($goods_option_mult_value) )
- {
- if($goods_option_mult_value['quantity']<$quantity+$cart_goods_quantity){
- $json['code'] =3;
- $json['msg']=mb_substr($goods_info['name'],0,4,'utf-8').'...,商品数量不足,剩余'.$goods_option_mult_value['quantity'].'个!!';
- }
- }
- }
- return $json;
- }
-
- private function _check_can_buy($member_id, $goods_id,$quantity)
- {
- global $_W;
- global $_GPC;
-
- $can_buy_count = D('Home/Front')->check_goods_user_canbuy_count($member_id, $goods_id);
-
- $goods_info = pdo_fetch("select goodsname as name from ".tablename('lionfish_comshop_goods')." where id=:id and uniacid=:uniacid ",array(':uniacid'=>$_W['uniacid'],':id' => $goods_id));
-
- $goods_description = D('Home/Front')->get_goods_common_field($goods_id , 'per_number');
-
-
-
- $json = array();
- if($can_buy_count == -1)
- {
- $json['code'] =6;
- $json['msg']=mb_substr($goods_info['name'],0,4,'utf-8').'...,每人最多购买'.$goods_description['per_number'].'个哦';
-
- }else if($can_buy_count >0 && $quantity >$can_buy_count)
- {
- $json['code'] =6;
- $json['msg']=mb_substr($goods_info['name'],0,4,'utf-8').'...,您还能购买'.$can_buy_count.'份';
- $json['count']=$can_buy_count;
-
- }else{
- $json['code'] = 0;
- }
- return $json;
- }
-
- public function checkout()
- {
- global $_W;
- global $_GPC;
-
-
- $buy_type = isset($_GPC['buy_type']) ? $_GPC['buy_type'] : 'dan';
-
- if($buy_type == 'undefined')
- {
- $buy_type = 'dan';
- }
-
- $community_id = $_GPC['community_id'];
- $token = $_GPC['token'];
-
- $voucher_id = isset($_GPC['voucher_id']) ? $_GPC['voucher_id'] : 0;
-
- $use_quan_str = isset($_GPC['use_quan_str']) ? $_GPC['use_quan_str'] : '';
- $use_quan_arr = array();
-
- if($use_quan_str != '')
- {
- $use_quan_arr_tmp = explode('@',$use_quan_str );
- foreach($use_quan_arr_tmp as $val)
- {
- $tmp_arr = explode('_', $val);
- $use_quan_arr[$tmp_arr[0]] = $tmp_arr[1];
- }
- }
-
-
- $token_param = array();
- $token_param[':uniacid'] = $_W['uniacid'];
- $token_param[':token'] = $token;
-
- $weprogram_token = pdo_fetch("select member_id from ".tablename('lionfish_comshop_weprogram_token')." where uniacid=:uniacid and token=:token limit 1", $token_param);
-
- $member_id = $weprogram_token['member_id'];
-
-
- if( empty($member_id) )
- {
- //需要登录
- echo json_encode( array('code' =>5) );
- die();
- }
-
- $cart = load_model_class('car');
-
-
-
- if ((!$cart->has_goodswecar($buy_type,$token,$community_id) ) ) {
- //购物车中没有商品
- echo json_encode( array('code' =>4) );
- die();
- }
-
-
- $member_param = array();
- $member_param[':uniacid'] = $_W['uniacid'];
- $member_param[':member_id'] = $member_id;
-
- $member_info = pdo_fetch("select * from ".tablename('lionfish_comshop_member')." where uniacid=:uniacid and member_id=:member_id",$member_param);
-
-
-
- $goods=$cart->get_all_goodswecar($buy_type, $token,1,$community_id);
-
- $add_where = array(':member_id'=>$member_id,':uniacid' => $_W['uniacid'] );
-
- $add_sql = "select * from ".tablename('lionfish_comshop_address')." where member_id=:member_id and uniacid=:uniacid order by is_default desc,address_id desc ";
-
- $address = pdo_fetch($add_sql, $add_where);
-
-
- if($address){
- //get_area_info($id)
- $province_info = D('Home/Front')->get_area_info($address['province_id']);// M('area')->field('area_name')->where( array('area_id' => $address['province_id']) )->find();
- $city_info = D('Home/Front')->get_area_info($address['city_id']);//M('area')->field('area_name')->where( array('area_id' => $address['city_id']) )->find();
- $country_info = D('Home/Front')->get_area_info($address['country_id']);//M('area')->field('area_name')->where( array('area_id' => $address['country_id']) )->find();
-
- $address['province_name'] = $province_info['name'];
- $address['city_name'] = $city_info['name'];
- $address['country_name'] = $country_info['name'];
- }
-
- $seller_goodss = array();
- $show_voucher = 0;
-
-
- foreach($goods as $key => $val)
- {
- //$goods_store_field = M('goods')->field('store_id')->where( array('goods_id' => $val['goods_id']) )->find();
- $seller_goodss[ 1 ]['goods'][$key] = $val;
- }
-
- $quan_model = load_model_class('voucher');
- $pin_model = load_model_class('pin');//D('Home/Pin');
-
-
- $voucher_price = 0;
- $is_pin_over = 0;
- //计算优惠券
- foreach($seller_goodss as $store_id => $val)
- {
-
- $seller_voucher_list = array();
- $seller_total_fee = 0;
- $total_trans_free = 0;
- $is_no_quan = false;
- foreach($val['goods'] as $kk =>$d_goods)
- {
- $seller_total_fee += $d_goods['total'];
-
- if($buy_type == 'pin' && $d_goods['pin_id'] > 0)
- {
- $is_pin_over = $pin_model->getNowPinState($d_goods['pin_id']);
- }
-
- $tp_goods_info = pdo_fetch("select type from ".tablename("lionfish_comshop_goods")." where id=:id and uniacid=:uniacid ",array(':id' => $d_goods['goods_id'], ':uniacid'=>$_W['uniacid']));
-
-
- $is_no_quan = true;
-
- if($tp_goods_info['type'] == 'integral')
- {
- //$is_no_quan = true;
- }
-
-
- $d_goods[$kk]['trans_free'] = 0;
- /**
- if($d_goods['shipping']==1)
- {
- //统一运费
- $d_goods[$kk]['trans_free'] = $d_goods['goods_freight'];
- }else {
- //运费模板
- if(!empty($address))
- {
- $trans_free = load_model_class('transport')->calc_transport($d_goods['transport_id'], $d_goods['quantity'],$d_goods['quantity']*$d_goods['weight'], $address['city_id'] );
- }else{
- $trans_free = 0;
- }
- $d_goods[$kk]['trans_free'] = $trans_free;
- }
- **/
-
- $total_trans_free += $d_goods[$kk]['trans_free'];
- $val['goods'][$kk] = $d_goods;
-
- }
-
- $chose_vouche = array();
- $show_voucher = 0;
-
- if(!$is_no_quan)
- {
-
- $vouche_list = $quan_model->get_user_canpay_voucher($member_id,$store_id,$seller_total_fee);
-
-
- if(!empty($vouche_list) && empty($use_quan_arr) ) {
- $show_voucher = 1;
- reset($vouche_list);
- $chose_vouche = current($vouche_list);
- $voucher_price += $chose_vouche['credit'];
-
- $seller_total_fee = round( $seller_total_fee - $chose_vouche['credit'], 2);
- }else if( !empty($vouche_list) && !empty($use_quan_arr) )
- {
-
- foreach($vouche_list as $tmp_voucher)
- {
- if($tmp_voucher['id'] == $use_quan_arr[$store_id])
- {
- $show_voucher = 1;
- $chose_vouche = $tmp_voucher;
- $seller_total_fee = round( $seller_total_fee - $chose_vouche['credit'], 2);
- $voucher_price += $chose_vouche['credit'];
- break;
- }
- }
- }
-
- }
-
- $val['chose_vouche'] = $chose_vouche;
- $val['show_voucher'] = $show_voucher;
-
- $val['voucher_list'] = $vouche_list;
- $val['total'] = $seller_total_fee;
-
- if($val['total'] < 0)
- {
- $val['total'] = 0;
- }
-
- $val['trans_free'] = $total_trans_free;
-
-
-
- $s_logo = D('Home/Front')->get_config_by_name('shoplogo');
- if( !empty($s_logo) )
- {
- $s_logo = tomedia( $s_logo );
- }
-
- $store_info = array('s_id' => 1,'s_true_name' => '','s_logo' => $s_logo );
-
- $val['store_info'] = $store_info;
-
- $seller_goodss[$store_id] = $val;
- }
-
- $trans_free_toal = 0;//运费
-
-
- $total_free = 0;
- $is_ziti = 2;
-
- $pick_up_time = "";
- $pick_up_type = -1;
- $pick_up_weekday = '';
- $today_time = time();
-
- $arr = array('天','一','二','三','四','五','六');
-
- $pick_up_arr = array();
- foreach($goods as $key => $good)
- {
- //暂时关闭
-
-
- //ims_lionfish_comshop_goods
- //ims_ lionfish_comshop_good_common
-
- $goods_info = pdo_fetch("select pick_up_type,pick_up_modify from ".tablename('lionfish_comshop_good_common').
- " where uniacid=:uniacid and goods_id=:goods_id ",
- array(':uniacid' => $_W['uniacid'], ':goods_id' => $good['goods_id']));
- if($pick_up_type == -1 || $goods_info['pick_up_type'] > $pick_up_type)
- {
- $pick_up_type = $goods_info['pick_up_type'];
-
- if($pick_up_type == 0)
- {
- $pick_up_time = date('m-d', $today_time);
- $pick_up_weekday = '周'.$arr[date('w',$today_time)];
- }else if( $pick_up_type == 1 ){
- $pick_up_time = date('m-d', $today_time+86400);
- $pick_up_weekday = '周'.$arr[date('w',$today_time+86400)];
- }else if( $pick_up_type == 2 )
- {
- $pick_up_time = date('m-d', $today_time+86400*2);
- $pick_up_weekday = '周'.$arr[date('w',$today_time+86400*2)];
- }else if($pick_up_type == 3)
- {
- $pick_up_time = $goods_info['pick_up_modify'];
- }
- }
-
- /**
- if($goods_info['pick_just'] >= 1)
- {
- $pick_up = $goods_info['pick_up'];
- $is_ziti = $goods_info['pick_just'];
- }
- **/
-
-
- $trans_free_toal += $good['goods_freight'];
- $goods[$key]['trans_free'] = $good['goods_freight'];
-
- /**
- if($good['shipping']==1)
- {
- //统一运费
- $trans_free_toal += $good['goods_freight'];
- $goods[$key]['trans_free'] = $good['goods_freight'];
- }else {
- //运费模板
- if(!empty($address))
- {
- $trans_free = load_model_class('transport')->calc_transport($good['transport_id'], $good['quantity'], $good['quantity']*$good['weight'], $address['city_id'] );
- }else{
- $trans_free = 0;
- }
-
- $goods[$key]['trans_free'] = $trans_free;
- $trans_free_toal +=$trans_free;
-
- }
- **/
-
- $total_free += $good['total'];
- }
-
- //暂时关闭自提代码
- /**
- if(!empty($pick_up))
- {
- $pick_up = unserialize($pick_up);
- $pick_up_ids = implode(',',$pick_up);
- $pick_up_arr = M('pick_up')->where( array('id'=>array('in',$pick_up_ids)) )->select();
- }
- **/
-
-
- $pick_up_name = '';
- $pick_up_mobile = '';
-
-
-
- if($is_ziti >= 1)
- {
- //寻找上一个订单的自提电话 自提姓名
-
- $last_order_info = pdo_fetch("select * from ".tablename('lionfish_comshop_order').
- " where uniacid=:uniacid and member_id=:member_id and delivery =:delivery order by order_id desc ",
- array(':uniacid' => $_W['uniacid'], ':member_id' => $member_id, ':delivery' => 'pickup' ));
-
- if(!empty($last_order_info))
- {
- $pick_up_name = $last_order_info['shipping_name'];
- $pick_up_mobile = $last_order_info['telephone'];
- }
- }
- /**
- **/
-
- $need_data = array();
- $need_data['code'] = 1;
-
- $need_data['pick_up_time'] = $pick_up_time;
- $need_data['pick_up_type'] = $pick_up_type;
- $need_data['pick_up_weekday'] = $pick_up_weekday;
-
- $need_data['is_pin_over'] = $is_pin_over;
- $need_data['is_integer'] = 0;//$is_no_quan ? 1: 0;
- $need_data['pick_up_arr'] = $pick_up_arr;
- $need_data['is_ziti'] = 2;
-
- $need_data['ziti_name'] = $pick_up_name;
- $need_data['ziti_mobile'] = $pick_up_mobile;
- $need_data['seller_goodss'] = $seller_goodss;
- $need_data['show_voucher'] = $show_voucher;
-
- $need_data['buy_type'] = $buy_type;
- $need_data['address'] = $address;
- $need_data['trans_free_toal'] = $trans_free_toal;
-
- $dispatching = isset($_GPC['dispatching']) ? $_GPC['dispatching']:'pickup';
- //is_ziti == 2
- if($dispatching == 'express')
- {
- $need_data['total_free'] = $total_free + $trans_free_toal - $voucher_price;
- }else{
- $need_data['total_free'] = $total_free - $voucher_price;
- }
- if($is_ziti == 2)
- {
- $need_data['total_free'] = $total_free - $voucher_price;
- }
-
-
-
- if($need_data['total_free'] < 0)
- {
- $need_data['total_free'] = 0;
- }
-
- //判断是否可以余额支付
-
- //暂时关闭 会员余额功能
- /**
- $is_yue_open_info = M('config')->where( array('name' => 'is_yue_open') )->find();
- $is_yue_open = $is_yue_open_info['value'];
- **/
-
- $is_yue_open = 0;
-
- $need_data['is_yue_open'] = $is_yue_open;
-
- $need_data['can_yupay'] = 0;
-
- //暂时关闭 会员余额功能
- /**
- if($is_yue_open == 1 && $need_data['total_free'] >=0 && $member_info['account_money'] >= $need_data['total_free'])
- {
- $need_data['can_yupay'] = 1;
- }
- **/
-
- $need_data['yu_money'] = $member_info['account_money'];
- $need_data['goods'] = $goods;
-
- echo json_encode($need_data);
- die();
- }
- public function sub_order()
- {
- global $_W;
- global $_GPC;
-
- $token = $_GPC['token'];
-
- $token_param = array();
- $token_param[':uniacid'] = $_W['uniacid'];
- $token_param[':token'] = $token;
-
- $weprogram_token = pdo_fetch("select member_id from ".tablename('lionfish_comshop_weprogram_token')." where uniacid=:uniacid and token=:token limit 1", $token_param);
-
- $member_id = $weprogram_token['member_id'];
-
- $data_s = array();
- $data_s['pay_method'] = $_GPC['wxpay'];
- $data_s['buy_type'] = $_GPC['buy_type'];
- $data_s['pick_up_id'] = $_GPC['pick_up_id'];
- $data_s['dispatching'] = $_GPC['dispatching'];
- $data_s['ziti_name'] = $_GPC['ziti_name'];
- $data_s['quan_arr'] = $_GPC['quan_arr'];
- $data_s['comment'] = $_GPC['comment'];
- $data_s['ziti_mobile'] = $_GPC['ziti_mobile'];
- $data_s['ck_yupay'] = $_GPC['ck_yupay'];
-
-
-
- $json=array();
- $pay_method = $data_s['pay_method'];//支付类型
- $order_msg_str = $data_s['order_msg_str'];//商品订单留言
- $comment = $data_s['comment'];//商品订单留言
-
- $pick_up_id = $data_s['pick_up_id'];
- $dispatching = $data_s['dispatching'];
- $ziti_name = $data_s['ziti_name'];
- $ziti_mobile = $data_s['ziti_mobile'];
- $ck_yupay = $data_s['ck_yupay'];
- /**
-
- pick_up_id: that.data.pick_up_id,
- dispatching: that.data.dispatching, //express pickup
- ziti_name: t_ziti_name,
- ziti_mobile: t_ziti_mobile
- **/
- $order_msg_arr = explode('@,@', $order_msg_str);
-
- $quan_arr = $data_s['quan_arr'];//商品订单留言
- $order_quan_arr = array();
-
-
- if( !empty($quan_arr) )
- {
- if( !is_array($quan_arr) )
- {
- $quan_arr = array($quan_arr);
- }
-
- foreach($quan_arr as $q_val)
- {
- $tmp_q = array();
- $tmp_q = explode('_',$q_val);
-
- $voucher_info = pdo_fetch("select * from ".tablename('lionfish_comshop_coupon_list')." where uniacid=:uniacid and consume='N' and id=:id and user_id=:user_id and end_time >:end_time ",
- array(':end_time' => time(),':user_id' => $member_id, ':id' => $tmp_q[1],':uniacid' => $_W['uniacid']));
-
- if( !empty($voucher_info) )
- {
- //$order_quan_arr[$tmp_q[0]] = $tmp_q[1];
- $order_quan_arr[1] = $tmp_q[1];
- }
- }
- }
-
-
- $msg_arr = array();
- foreach($order_msg_arr as $val)
- {
- $tmp_val = explode('@_@', $val);
- $msg_arr[ $tmp_val[0] ] = $tmp_val[1];
- }
-
- $cart= load_model_class('car');
- // 验证商品数量
- //buy_type:buy_type
- $buy_type = $data_s['buy_type'];//I('post.buy_type');
- $is_pin = 0;
- if($buy_type == 'pin')
- {
- $is_pin = 1;
- }
-
-
- $goodss = $cart->get_all_goodswecar($buy_type,$token,1,$data_s['pick_up_id']);
- //付款人
-
-
- $member_param = array();
- $member_param[':uniacid'] = $_W['uniacid'];
- $member_param[':member_id'] = $member_id;
-
- $payment = pdo_fetch("select * from ".tablename('lionfish_comshop_member')." where uniacid=:uniacid and member_id=:member_id",$member_param);
-
-
- //收货人
- $addr_param = array();
- $addr_param[':uniacid'] = $_W['uniacid'];
- $addr_param[':member_id'] = $member_id;
-
- //$addr_sql = "select * from ".tablename('lionfish_comshop_address')." where uniacid=:uniacid and member_id=:member_id order by is_default desc,address_id desc limit 1";
- //$address = pdo_fetch($addr_sql, $addr_param);
-
- $seller_goodss = array();
-
- foreach($goodss as $key => $val)
- {
- //单商户先屏蔽
- //$goods_store_field = M('goods')->field('store_id')->where( array('goods_id' => $val['goods_id']) )->find();
- $seller_goodss[ 1 ][$key] = $val;
-
- $cart->removecar($val['key'],$token);
- }
-
- $pay_total = 0;
- //M('order_all')
-
-
- $order_all_data = array();
- $order_all_data['uniacid'] = $_W['uniacid'];
- $order_all_data['member_id'] = $member_id;
- $order_all_data['order_num_alias'] = build_order_no($member_id);
- $order_all_data['transaction_id'] = '';
- $order_all_data['order_status_id'] = 3;
- $order_all_data['is_pin'] = $is_pin;
- $order_all_data['paytime'] = 0;
-
- $order_all_data['addtime'] = time();
-
- pdo_insert('lionfish_comshop_order_all',$order_all_data);
- $order_all_id = pdo_insertid();
-
- //暂时屏蔽积分商城模块
- //$integral_model = D('Seller/Integral');
- $order_ids_arr = array();
- $del_integral = 0;
-
- $community_info = pdo_fetch("select * from ".tablename('lionfish_community_head')." where uniacid=:uniacid and id=:id ",
- array(':uniacid' => $_W['uniacid'], ':id' => $data_s['pick_up_id']));
- //$data_s['pick_up_id']
-
- //community_info
-
- $community_detail_info = D('Home/Front')->get_community_byid($data_s['pick_up_id']);
-
- foreach($seller_goodss as $kk => $vv)
- {
-
- $data = array();
- $data['member_id']=$member_id;
- $data['name']= $payment['username'];
-
- $data['telephone']= $data_s['ziti_mobile'];
- $data['shipping_name']= $data_s['ziti_name'];
- $data['shipping_tel']= $data_s['ziti_mobile'];
-
- $data['shipping_address'] = $community_detail_info['fullAddress'];
- $data['shipping_province_id']=$community_info['province_id'];
- $data['shipping_city_id']=$community_info['city_id'];
- $data['shipping_stree_id']=$community_info['country_id'];
- $data['shipping_country_id']=$community_info['area_id'];
-
- $data['shipping_method'] = 0;
- $data['delivery']=$dispatching;
- $data['pick_up_id']=$pick_up_id;
-
- $data['ziti_name']=$community_info['head_name'];
- $data['ziti_mobile']=$community_info['head_mobile'];
- //$data['ziti_address']=$community_detail_info['fullAddress'];
-
- //$pick_up_id = $data_s['pick_up_id'];
- //$dispatching = $data_s['dispatching'];
- //$ziti_name = $data_s['ziti_name'];
- //$ziti_mobile = $data_s['ziti_mobile'];
-
- $data['payment_method']=$pay_method;
-
- $data['address_id']= $address['address_id'];
- $data['voucher_id'] = isset($order_quan_arr[$kk]) ? $order_quan_arr[$kk]:0;
-
-
- $data['user_agent']=$_SERVER['HTTP_USER_AGENT'];
- $data['date_added']=time();
-
- //$hashids = new \Lib\Hashids(C('PWD_KEY'), C('URL_ID'));
- $subject='';
- $fare = 0;
-
- $trans_free_toal = 0;//运费
- $order_total = 0;
- $is_lottery = 0;
- $is_integral = 0;
- $is_spike = 0;
-
- foreach($goodss as $key => $good)
- {
- /**
- if($good['shipping']==1)
- {
- //统一运费
- $trans_free_toal += $good['goods_freight'];
- $trans_free = $good['goods_freight'];
- }else {
- //运费模板
- $trans_free = load_model_class('transport')->calc_transport($good['transport_id'], $good['quantity'], $good['quantity']*$good['weight'], $address['city_id'] );
-
- //$trans_free = D('Home/Transport')->calc_transport($good['transport_id'], $good['quantity']*$good['weight'], $address['city_id'] );
- $trans_free_toal +=$trans_free;
- }
- **/
- $trans_free = 0;
- $trans_free_toal +=$trans_free;
- //sku_str
-
-
- $order_total += $good['total'];
-
- $tp_goods_info = pdo_fetch("select type from ".tablename('lionfish_comshop_goods')." where id=:id and uniacid=:uniacid ", array(':id' => $good['goods_id'], ':uniacid' =>$_W['uniacid'] ));
-
- $tp_goods_info['store_id'] = 1;
-
- if($tp_goods_info['type'] == 'lottery')
- {
- $is_lottery = 1;
- }
- if($tp_goods_info['type'] == 'spike')
- {
- $is_spike = 1;
- $is_pin = 0;
- }
- //暂时屏蔽积分商城模块
- /**
- if($tp_goods_info['type'] == 'integral')
- {
- $is_integral = 1;
- $is_pin = 0;
- $check_result = $integral_model->check_user_score_can_pay($member_id, $good['sku_str'], $good['goods_id'] );
- if($check_result['code'] == 1)
- {
- die();
- }
- }
- **/
-
- $goods_data[] = array(
- 'goods_id' => $good['goods_id'],
- 'store_id' => $tp_goods_info['store_id'],
- 'name' => $good['name'],
- 'model' => $good['model'],
- 'is_pin' => $is_pin,
- 'pin_id' => $good['pin_id'],
- 'header_disc' => $good['header_disc'],
- 'member_disc' => $good['member_disc'],
- 'level_name' => $good['level_name'],
- 'option' => $good['sku_str'],
- 'quantity' => $good['quantity'],
- 'shipping_fare' => $trans_free,
- 'price' => $good['price'],
- 'total' => $good['total'],
- 'comment' => htmlspecialchars($comment)
- );
- }
-
- //$is_pin; is_lottery
- //'pintuan', 'normal', 'lottery'
- $data['type'] = 'normal';
- if($is_pin == 1)
- {
- $data['type'] = 'pintuan';
- if($is_lottery == 1)
- {
- $data['type'] = 'lottery';
- }
- }
- if($is_integral == 1)
- {
- $data['type'] = 'integral';
- $is_pin = 0;
- }
- if($is_spike == 1)
- {
- $data['type'] = 'spike';
- $is_pin = 0;
- }
-
- $data['shipping_fare'] = floatval($trans_free_toal);
-
-
- $data['store_id']= $kk;
-
-
- $data['goodss'] = $goods_data;
- $data['order_num_alias']=build_order_no($member_id);
-
- $data['totals'][0]=array(
- 'code'=>'sub_total',
- 'title'=>'商品价格',
- 'text'=>'¥'.$order_total,
- 'value'=>$order_total
- );
- $data['totals'][1]=array(
- 'code'=>'shipping',
- 'title'=>'运费',
- 'text'=>'¥'.$trans_free_toal,
- 'value'=>$trans_free_toal
- );
-
- $data['totals'][2]=array(
- 'code'=>'total',
- 'title'=>'总价',
- 'text'=>'¥'.($order_total+$trans_free_toal),
- 'value'=>($order_total+$trans_free_toal)
- );
-
- $data['from_type'] = 'wepro';
-
- if($data['voucher_id'] > 0) {
-
- //暂时屏蔽优惠券,等待开启
- $voucher_info = pdo_fetch("select * from ".tablename('lionfish_comshop_coupon_list')." where uniacid=:uniacid and id=:id ",
- array(':uniacid' => $_W['uniacid'],':id' => $data['voucher_id']));
-
- $data['voucher_credit'] = $voucher_info['credit'];
-
- pdo_update('lionfish_comshop_coupon_list', array('ordersn' => $data['order_num_alias'],'consume' => 'Y','usetime' => time()), array('id' => $data['voucher_id'] ));
-
- } else {
- $data['voucher_credit'] = 0;
- }
-
- $data['comment'] = htmlspecialchars($comment);
-
- //判断自提 dispatching:"pickup"
- //dispatching, //express pickup
-
- if($dispatching == 'express')
- {
- $data['total']=($order_total+$fare - $data['voucher_credit']);
- }else{
- $data['total'] = ($order_total - $data['voucher_credit']);
- }
- //积分商城
- //暂时屏蔽积分商城模块
- /**
- if($data['type'] == 'integral')
- {
- $del_integral += $order_total;//扣除积分
- $data['total'] = 0;
- $order_total = 0;
- }
- **/
-
-
- $oid= load_model_class('frontorder')->addOrder($data);// D('Order')->addOrder($data);
-
-
- //暂时屏蔽自提模块
- /**
- if($data['delivery'] == 'pickup')
- {
- $verify_bool = true;
- $verifycode = 0;
- while($verify_bool)
- {
- $code = (ceil(time()/100)+rand(10000000,40000000)).rand(1000,9999);
- $verifycode = $code ? $code : rand(100000,999999);
- $verifycode = str_replace('1989','9819',$verifycode);
- $verifycode = str_replace('1259','9521',$verifycode);
- $verifycode = str_replace('12590','95210',$verifycode);
- $verifycode = str_replace('10086','68001',$verifycode);
-
- $pick_order = M('pick_order')->where( array('pick_sn' => $verifycode) )->find();
- if(empty($pick_order))
- {
- $verify_bool = false;
- }
- }
- $pick_data = array();
- $pick_data['pick_sn'] = $verifycode;
- $pick_data['pick_id'] = $pick_up_id;
- $pick_data['order_id'] = $oid;
- $pick_data['state'] = 0;
-
- $pick_data['ziti_name'] = $ziti_name;
- $pick_data['ziti_mobile'] = $ziti_mobile;
-
-
- $pick_data['addtime'] = time();
- M('pick_order')->add($pick_data);
- }
- **/
-
- $order_ids_arr[] = $oid;
- //$pay_total = $pay_total + $order_total+$trans_free_toal - $data['voucher_credit'];
-
- if($dispatching == 'express')
- {
- $pay_total = $pay_total + $order_total+$trans_free_toal - $data['voucher_credit'];
- }else{
- $pay_total = $pay_total + $order_total - $data['voucher_credit'];
- }
-
-
-
- $order_relate_data = array();
-
- $order_relate_data['uniacid'] = $_W['uniacid'];
- $order_relate_data['order_all_id'] = $order_all_id;
- $order_relate_data['order_id'] = $oid;
- $order_relate_data['addtime'] = time();
-
- pdo_insert('lionfish_comshop_order_relate',$order_relate_data);
-
-
- }
-
- $order_all_data = array();
- $order_all_data['total_money'] = $pay_total;
-
- pdo_update('lionfish_comshop_order_all', $order_all_data, array('id' => $order_all_id,'uniacid' => $_W['uniacid']));
-
-
- if($order_all_id){
-
- $order = pdo_fetch("select * from ".tablename('lionfish_comshop_order')." where order_id=:order_id and uniacid=:uniacid ",array(':order_id'=>$oid,':uniacid' => $_W['uniacid']) );
-
- $member_info = pdo_fetch('select we_openid,account_money from '.tablename('lionfish_comshop_member')." where member_id=:member_id and unionid=:uniacid " ,array(':uniacid' => $_W['uniacid'],':member_id'=>$member_id));
-
-
- if( $pay_total<=0 || ($ck_yupay == 1 && $member_info['account_money'] >= $pay_total) )
- {
- /****
- //暂时关闭
-
-
- //检测是否需要扣除积分
- if($del_integral> 0 && $is_integral == 1)
- {
- $integral_model->charge_member_score( $member_id, $del_integral,'out', 'orderbuy', $oid);
- }
-
- if($ck_yupay == 1 && $pay_total >0)
- {
- //开始余额支付
- $member_charge_flow_data = array();
- $member_charge_flow_data['member_id'] = $member_id;
- $member_charge_flow_data['trans_id'] = $oid;
- $member_charge_flow_data['money'] = $pay_total;
- $member_charge_flow_data['state'] = 3;
- $member_charge_flow_data['charge_time'] = time();
- $member_charge_flow_data['add_time'] = time();
- M('member_charge_flow')->add($member_charge_flow_data);
- //开始处理扣钱
- M('member')->where( array('member_id' => $member_id) )->setInc('account_money',-$pay_total);
- }
- ***/
- //lionfish_comshop_order_all
-
- //开始处理订单状态
- //$order_all = M('order_all')->where( array('id' => $order_all_id) )->find();
- $order_all = pdo_fetch("select * from ".tablename('lionfish_comshop_order_all')." where id=:id and uniacid=:uniacid ",array(':id'=>$order_all_id, ":uniacid"=>$_W['uniacid']));
-
- if($order&&($order['order_status_id']!=1))
- {
- //支付完成
- $o = array();
- $o['order_status_id'] = $order['is_pin'] == 1 ? 2:1;
- $o['paytime']=time();
- $o['transaction_id'] = $transaction_id;
-
- pdo_update('lionfish_comshop_order_all', $o, array( 'id' => $out_trade_no,'uniacid' =>$_W['uniacid'] ));
-
- // ims_
-
- $order_relate_list_sql = "select * from ".tablename('lionfish_comshop_order_relate')." where order_all_id=:id and uniacid=:uniacid ";
- $order_relate_list = pdo_fetchall($order_relate_list_sql, array(':uniacid' =>$_W['uniacid'], ':id' => $order_all['id'] ));
-
- foreach($order_relate_list as $order_relate)
- {
-
- $order = pdo_fetch("select * from ".tablename('lionfish_comshop_order')." where uniacid=:uniacid and order_id=:order_id " ,array(':uniacid' => $_W['uniacid'], ':order_id' => $order_relate['order_id'] ));
-
- if( $order && $order['order_status_id'] == 3)
- {
- $o = array();
- $o['payment_code'] = 'yuer';
- $o['order_id']=$order['order_id'];
- $o['order_status_id'] = $order['is_pin'] == 1 ? 2:1;
- $o['date_modified']=time();
- $o['pay_time']=time();
- $o['transaction_id'] = $is_integral ==1? '积分兑换':'余额支付';
-
- //ims_
- pdo_update('lionfish_comshop_order', $o, array('order_id' => $order['order_id'],'uniacid' => $_W['uniacid']));
-
-
- //暂时屏蔽
- //$kucun_method = C('kucun_method');
- //$kucun_method = empty($kucun_method) ? 0 : intval($kucun_method);
- $kucun_method = 0;
-
- //$goods_model = D('Home/Goods');
-
- if($kucun_method == 1)
- {//支付完减库存,增加销量
-
- $order_goods_list = pdo_fetchall("select * from ".tablename('lionfish_comshop_order_goods')." where order_id=:order_id and uniacid=:uniacid ", array(':order_id' => $order['order_id'], ':uniacid' => $_W['uniacid']) );
-
- foreach($order_goods_list as $order_goods)
- {
- load_model_class('pingoods')->del_goods_mult_option_quantity($order['order_id'],$order_goods['rela_goodsoption_valueid'],$order_goods['goods_id'],$order_goods['quantity'],1);
-
- }
- }
-
- $oh = array();
- $oh['uniacid'] = $_W['uniacid'];
- $oh['order_id']=$order['order_id'];
- $oh['order_status_id']= $order['is_pin'] == 1 ? 2:1;
- $oh['comment']='买家已付款';
- $oh['date_added']=time();
- $oh['notify']=1;
-
- pdo_insert('lionfish_comshop_order_history', $oh);
-
-
- //发送购买通知
- //TODO 先屏蔽,等待调试这个消息
- //$weixin_nofity = D('Home/Weixinnotify');
- //$weixin_nofity->orderBuy($order['order_id']);
-
-
- if($order['is_pin'] == 1)
- {
-
- $pin_order = pdo_fetch('select * from '.tablename('lionfish_comshop_pin_order')." where order_id=:order_id and uniacid=:uniacid ", array(':order_id' => $order['order_id'], ':uniacid' => $_W['uniacid']) );
-
-
- load_model_class('pin')->insertNotifyOrder($order['order_id']);
-
-
- $is_pin_success = load_model_class('pin')->checkPinSuccess($pin_order['pin_id']);
-
- if($is_pin_success) {
- //todo send pintuan success notify
- load_model_class('pin')->updatePintuanSuccess($pin_order['pin_id']);
- }
- }
-
- }
-
- }
- //返回支付成功给app
- $data = array();
- $data['code'] = 0;
- $data['has_yupay'] = 1;
- $data['is_integral'] = $is_integral;
- $data['is_spike'] = $is_spike;
-
- }
-
- }else{
-
- $fee = $pay_total;
- $appid = D('Home/Front')->get_config_by_name('wepro_appid');
- $body = '商品购买';
- $mch_id = D('Home/Front')->get_config_by_name('wepro_partnerid');
- $nonce_str = nonce_str();
- $notify_url = $_W['siteroot'].'addons/lionfish_comshop/notify.php';
-
-
- $openid = $payment['we_openid'];
- $out_trade_no = $order_all_id.'-'.time();
- $spbill_create_ip = $_SERVER['REMOTE_ADDR'];
- $total_fee = $fee*100;
- $trade_type = 'JSAPI';
- $pay_key = D('Home/Front')->get_config_by_name('wepro_key');
- $post['appid'] = $appid;
- $post['body'] = $body;
- $post['mch_id'] = $mch_id;
- $post['nonce_str'] = $nonce_str;
- $post['notify_url'] = $notify_url;
-
- $post['openid'] = $openid;
- $post['out_trade_no'] = $out_trade_no;
- $post['spbill_create_ip'] = $spbill_create_ip;
- $post['total_fee'] = $total_fee;
- $post['trade_type'] = $trade_type;
- $sign = sign($post,$pay_key);
-
-
- $post_xml = '<xml>
- <appid>'.$appid.'</appid>
- <body>'.$body.'</body>
- <mch_id>'.$mch_id.'</mch_id>
- <nonce_str>'.$nonce_str.'</nonce_str>
- <notify_url>'.$notify_url.'</notify_url>
- <openid>'.$openid.'</openid>
- <out_trade_no>'.$out_trade_no.'</out_trade_no>
- <spbill_create_ip>'.$spbill_create_ip.'</spbill_create_ip>
- <total_fee>'.$total_fee.'</total_fee>
- <trade_type>'.$trade_type.'</trade_type>
- <sign>'.$sign.'</sign>
- </xml> ';
- $url = 'https://api.mch.weixin.qq.com/pay/unifiedorder';
- $xml = http_request($url,$post_xml);
- $array = xml($xml);
-
- if($array['RETURN_CODE'] == 'SUCCESS' && $array['RESULT_CODE'] == 'SUCCESS'){
- $time = time();
- $tmp='';
- $tmp['appId'] = $appid;
- $tmp['nonceStr'] = $nonce_str;
- $tmp['package'] = 'prepay_id='.$array['PREPAY_ID'];
- $tmp['signType'] = 'MD5';
- $tmp['timeStamp'] = "$time";
-
- $prepay_id = (string)$array['PREPAY_ID'];
- //ims_
- $order_sql = "update ".tablename('lionfish_comshop_order')." set perpay_id='{$prepay_id}' where uniacid={$_W[uniacid]} and order_id in (".implode(',', $order_ids_arr).") ";
-
- pdo_query($order_sql);
-
- //M('order')->where( array('order_id' => array('in',$order_ids_arr) ) )->save( array('perpay_id' => (string)$array['PREPAY_ID']) );
- $data = array();
- $data['code'] = 0;
- $data['appid'] = $appid;
- $data['timeStamp'] = "$time";
- $data['nonceStr'] = $nonce_str;
- $data['signType'] = 'MD5';
- $data['package'] = 'prepay_id='.$array['PREPAY_ID'];
- $data['paySign'] = sign($tmp,$pay_key);
- $data['out_trade_no'] = $out_trade_no;
-
- if($is_pin == 1)
- {
- $data['redirect_url'] = '../groups/group?id='.$oid.'&is_show=1';
- } else {
- $data['redirect_url'] = '../orders/order_show_all?order_all_id=' + $order_all_id;
- }
-
- }else{
- $data = array();
- $data['code'] = 1;
- $data['text'] = "错误";
- $data['RETURN_CODE'] = $array['RETURN_CODE'];
- $data['RETURN_MSG'] = $array['RETURN_MSG'];
- }
- $data['has_yupay'] = 0;
- }
-
- if($is_pin == 1)
- {
- $data['order_id'] = $oid;
- $data['order_all_id'] = $order_all_id;
- }else{
- $data['order_id'] = $oid;
- $data['order_all_id'] = $order_all_id;
- }
- $data['is_spike'] = $is_spike;
- echo json_encode($data);
- die();
- }else{
- echo json_encode( array('code' =>1,'order_all_id' =>$order_all_id) );
- die();
- }
-
- }
-
-
- public function wxpay()
- {
- global $_W;
- global $_GPC;
-
- $token = $_GPC['token'];
- $order_id = $_GPC['order_id'];
-
-
- $token_param = array();
- $token_param[':uniacid'] = $_W['uniacid'];
- $token_param[':token'] = $token;
-
- $weprogram_token = pdo_fetch("select member_id from ".tablename('lionfish_comshop_weprogram_token')." where uniacid=:uniacid and token=:token limit 1", $token_param);
-
- $member_id = $weprogram_token['member_id'];
-
-
- if( empty($member_id) )
- {
- echo json_encode( array('code' =>1,'msg' =>'未登录') );
- die();
- }
-
- //
- $member_info = pdo_fetch("select we_openid from ".tablename('lionfish_comshop_member')." where uniacid=:uniacid and member_id=:member_id ", array(':member_id' => $member_id, ':uniacid' => $_W['uniacid']));
-
-
- $order = pdo_fetch("select * from ".tablename('lionfish_comshop_order')." where uniacid=:uniacid and order_id=:order_id ",array(':uniacid' => $_W['uniacid'] , ':order_id' => $order_id));
-
-
- //支付才减库存,才需要判断
- $kucun_method = D('Home/Front')->get_config_by_name('kucun_method', $uniacid);
-
- if( empty($kucun_method) )
- {
- $kucun_method = 0;
- }
-
- if($kucun_method == 1)
- {
- /*** 检测商品库存begin **/
-
- $sql = "select name,quantity,rela_goodsoption_valueid,goods_id from ".tablename('lionfish_comshop_order_goods')."
- where order_id=:order_id and uniacid=:uniacid ";
-
- $order_goods_list = pdo_fetchall($sql, array(':order_id' => $order_id, ':uniacid' => $_W['uniacid']));
-
- //goods_id
- foreach($order_goods_list as $val)
- {
- $quantity = $val['quantity'];
-
- $goods_id = $val['goods_id'];
-
- $can_buy_count = D('Home/Front')->check_goods_user_canbuy_count($member_id, $goods_id);
-
- $goods_description = D('Home/Front')->get_goods_common_field($goods_id , 'total_limit_count');
-
- if($can_buy_count == -1)
- {
- $json['code'] = 2;
-
- $json['msg']='每人最多购买'.$goods_description['total_limit_count'].'个哦';
-
- echo json_encode($json);
- die();
- }else if($can_buy_count >0 && $quantity >$can_buy_count)
- {
- $json['code'] = 2;
- $json['msg']='您还能购买'.$can_buy_count.'份';
- echo json_encode($json);
- die();
- }
- //rela_goodsoption_valueid
- if(!empty($val['rela_goodsoption_valueid']))
- {
- $mul_opt_arr = array();
-
- //ims_
-
- $mult_sql = "select * from ".tablename('lionfish_comshop_goods_option_item_value')."
- where uniacid=:uniacid and option_item_ids = :sku_str and goods_id =:goods_id limit 1 ";
-
- $goods_option_mult_value = pdo_fetch($mult_sql, array(':uniacid' => $_W['uniacid'],':sku_str' =>$val['rela_goodsoption_valueid'],':goods_id' => $goods_id ));
-
- if( !empty($goods_option_mult_value) )
- {
- if($goods_option_mult_value['stock']<$quantity){
- $json['code'] =2;
- $json['msg']='商品数量不足,剩余'.$goods_option_mult_value['stock'].'个!!';
- echo json_encode($json);
- die();
- }
- }
- }
-
- }
- /*** 检测商品库存end **/
- }
-
-
- $pin_order = pdo_fetch("select * from ".tablename('lionfish_comshop_pin_order')." where uniacid=:uniacid and order_id=:order_id ", array(':order_id' => $order_id, ':uniacid' => $_W['uniacid']));
-
- if( !empty($pin_order) )
- {
- $pin_model = load_model_class('pin');
- $is_pin_over = $pin_model->getNowPinState($pin_order['pin_id']);
- if($is_pin_over != 0)
- {
- pdo_query("delete from ".tablename('lionfish_comshop_pin_order')." where order_id = {$order_id} ");
-
- pdo_query("delete from ".tablename('lionfish_comshop_pin')." where pin_id = ".$pin_order['pin_id']." and order_id = ".$order_id);
-
- $order_goods_info = pdo_fetch("select goods_id from ".tablename('lionfish_comshop_order_goods')." where uniacid=:uniacid and order_id=:order_id ", array(':order_id' => $order_id,':uniacid' => $_W['uniacid']));
-
- //新开团
-
- $pin_id = $pin_model->openNewTuan($order_id,$order_goods_info['goods_id'],$member_id);
- //插入拼团订单
- $pin_model->insertTuanOrder($pin_id,$order_id);
-
- }
- }
-
-
- //单独支付一个店铺的订单
- pdo_query("delete from ".tablename('lionfish_comshop_order_relate')." where order_id=".$order_id." and uniacid=".$_W['uniacid']);
-
- $order_all_data = array();
- $order_all_data['member_id'] = $member_id;
- $order_all_data['uniacid'] = $_W['uniacid'];
- $order_all_data['order_num_alias'] = build_order_no($member_id);
- $order_all_data['transaction_id'] = '';
- $order_all_data['order_status_id'] = 3;
- $order_all_data['is_pin'] = $order['is_pin'];
- $order_all_data['paytime'] = 0;
- $order_all_data['total_money'] = $order['total'];
- $order_all_data['addtime'] = time();
-
- pdo_insert('lionfish_comshop_order_all', $order_all_data);
- $order_all_id = pdo_insertid();
-
- $order_relate_data = array();
- $order_relate_data['uniacid'] = $_W['uniacid'];
- $order_relate_data['order_all_id'] = $order_all_id;
- $order_relate_data['order_id'] = $order_id;
- $order_relate_data['addtime'] = time();
-
- pdo_insert('lionfish_comshop_order_relate',$order_relate_data);//ims_
-
- if( $order['delivery'] == 'pickup' )
- {
- $fee = $order['total'];
- }else {
- $fee = $order['total'];
- }
-
-
-
- $appid = D('Home/Front')->get_config_by_name('wepro_appid');
- $body = '商品购买';
- $mch_id = D('Home/Front')->get_config_by_name('wepro_partnerid');
- $nonce_str = nonce_str();
- $notify_url = $_W['siteroot'].'addons/lionfish_comshop/notify.php';
- $openid = $member_info['we_openid'];
- $out_trade_no = $order_all_id.'-'.time();
- $spbill_create_ip = $_SERVER['REMOTE_ADDR'];
- $total_fee = $fee*100;
- $trade_type = 'JSAPI';
- $pay_key = D('Home/Front')->get_config_by_name('wepro_key');
-
-
- $post['appid'] = $appid;
- $post['body'] = $body;
- $post['mch_id'] = $mch_id;
- $post['nonce_str'] = $nonce_str;
- $post['notify_url'] = $notify_url;
- $post['openid'] = $openid;
- $post['out_trade_no'] = $out_trade_no;
- $post['spbill_create_ip'] = $spbill_create_ip;
- $post['total_fee'] = $total_fee;
- $post['trade_type'] = $trade_type;
- $sign = sign($post,$pay_key);
-
-
- $post_xml = '<xml>
- <appid>'.$appid.'</appid>
- <body>'.$body.'</body>
- <mch_id>'.$mch_id.'</mch_id>
- <nonce_str>'.$nonce_str.'</nonce_str>
- <notify_url>'.$notify_url.'</notify_url>
- <openid>'.$openid.'</openid>
- <out_trade_no>'.$out_trade_no.'</out_trade_no>
- <spbill_create_ip>'.$spbill_create_ip.'</spbill_create_ip>
- <total_fee>'.$total_fee.'</total_fee>
- <trade_type>'.$trade_type.'</trade_type>
- <sign>'.$sign.'</sign>
- </xml> ';
- $url = 'https://api.mch.weixin.qq.com/pay/unifiedorder';
- $xml = http_request($url,$post_xml);
- $array = xml($xml);
- if($array['RETURN_CODE'] == 'SUCCESS' && $array['RESULT_CODE'] == 'SUCCESS'){
- $time = time();
- $tmp='';
- $tmp['appId'] = $appid;
- $tmp['nonceStr'] = $nonce_str;
- $tmp['package'] = 'prepay_id='.$array['PREPAY_ID'];
- $tmp['signType'] = 'MD5';
- $tmp['timeStamp'] = "$time";
-
- $prepay_id = (string)$array['PREPAY_ID'];
-
- $order_sql = "update ".tablename('lionfish_comshop_order')." set perpay_id='{$prepay_id}' where uniacid={$_W[uniacid]} and order_id =".$order_id;
-
- pdo_query($order_sql);
-
-
- $data['code'] = 0;
- $data['timeStamp'] = "$time";
- $data['nonceStr'] = $nonce_str;
- $data['signType'] = 'MD5';
- $data['package'] = 'prepay_id='.$array['PREPAY_ID'];
- $data['paySign'] = sign($tmp, $pay_key);
- $data['out_trade_no'] = $out_trade_no;
- $data['is_pin'] = $order['is_pin'];
-
- if($order['is_pin'] == 1)
- {
- $data['redirect_url'] = '../groups/group?id='.$order_id.'&is_show=1';
- } else {
- $data['redirect_url'] = '../orders/order?id=' + $order_id;
- }
-
- }else{
- $data['code'] = 1;
- $data['text'] = "错误";
- $data['RETURN_CODE'] = $array['RETURN_CODE'];
- $data['RETURN_MSG'] = $array['RETURN_MSG'];
- }
-
-
- echo json_encode($data);
- die();
- }
- /**
- * 获取购物车总数
- */
- public function count() {
-
- $data = I('param.');
-
- var_dump($data,999);die();
- global $_W;
- global $_GPC;
-
- $data = array();
- $token = $_GPC['token'];
- $community_id = $_GPC['community_id'];
- $cart= load_model_class('car');
- $total=$cart->count_goodscar($token, $community_id);
- $data['code'] = 0;
- $data['data'] = $total;
- echo json_encode($data);
- die();
- }
-
- }
|