1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538 |
- <?php
- /**
- * lionfish 商城系统
- *
- * ==========================================================================
- * @link http://www.liofis.com/
- * @copyright Copyright (c) 2015 liofis.com.
- * @license http://www.liofis.com/license.html License
- * ==========================================================================
- *
- * @author fish
- *
- */
- namespace Seller\Model;
- class OrderModel{
-
-
- public function do_tuanz_over($order_id, $title = '后台操作,确认送达团长')
- {
- //express_time
-
- M('lionfish_comshop_order')->where( array('order_id' => $order_id) )->save( array('order_status_id' => 4, 'express_tuanz_time' => time()) );
-
- //todo ... send member msg goods is ing
-
- $history_data = array();
- $history_data['order_id'] = $order_id;
- $history_data['order_status_id'] = 4;
- $history_data['notify'] = 0;
- $history_data['comment'] = $title;
- $history_data['date_added'] = time();
-
-
- M('lionfish_comshop_order_history')->add( $history_data );
-
- D('Home/Frontorder')->send_order_operate($order_id);
- }
- /**
- * @param $order_id
- * @param string 同城配送发货
- */
- public function do_send_localtown( $order_id, $title = '后台操作,开始配送货物' )
- {
- //express_time
- M('lionfish_comshop_order')->where( array('order_id' => $order_id) )->save( array('order_status_id' => 4,'express_time' => time(), 'express_tuanz_time' => time()) );
- //todo ... send member msg goods is ing
- $history_data = array();
- $history_data['order_id'] = $order_id;
- $history_data['order_status_id'] = 4;
- $history_data['notify'] = 0;
- $history_data['comment'] = $title;
- $history_data['date_added'] = time();
- M('lionfish_comshop_order_history')->add( $history_data );
- D('Home/LocaltownDelivery')->change_distribution_order_state( $order_id, 0, 1);
- M('lionfish_comshop_orderdistribution_order')->where( array('order_id' => $order_id) )->save( array('delivery_type' => 1) );
- D('Home/Frontorder')->send_order_operate($order_id);
- //给配送员发送公众号消息
- $count = D('Seller/Redisorder')->set_distribution_delivery_message($order_id);
- return $count;
- }
- public function do_send_tuanz($order_id, $title = '后台操作,确认开始配送货物')
- {
-
- //express_time
-
- M('lionfish_comshop_order')->where( array('order_id' => $order_id) )->save( array('order_status_id' => 14, 'express_time' => time()) );
-
- //todo ... send tuanz msg
-
- $history_data = array();
- $history_data['order_id'] = $order_id;
- $history_data['order_status_id'] = 14;
- $history_data['notify'] = 0;
- $history_data['comment'] = $title;
- $history_data['date_added'] = time();
-
- M('lionfish_comshop_order_history')->add($history_data);
-
- }
-
- /**
- * 后台自动送达团长
- * @param unknown $order
- * @param string $title
- */
- public function order_auto_service($order,$title="后台自动确认送达团长"){
- if($order['delivery'] == 'tuanz_send'){//团长配送订单
- $is_communityhead_auto_service = D('Home/Front')->get_config_by_name('is_communityhead_auto_service');
- if($is_communityhead_auto_service == 1){//团长订单自动确认送达团长
- D('Seller/Order')->do_tuanz_over($order['order_id'],'后台自动确认送达团长');
- D('Home/Frontorder')->send_order_operate($order['order_id']);
- }
- }else if($order['delivery'] == 'pickup'){//到点自提订单
- $is_ziti_auto_service = D('Home/Front')->get_config_by_name('is_ziti_auto_service');
- if($is_ziti_auto_service == 1){//到店自提订单自动确认送达团长
- D('Seller/Order')->do_tuanz_over($order['order_id'],'后台自动确认送达团长');
- D('Home/Frontorder')->send_order_operate($order['order_id']);
- }
- }
- }
-
- public function update($data)
- {
-
- $ins_data = array();
- $ins_data['tagname'] = $data['tagname'];
- $ins_data['tagcontent'] = serialize(array_filter($data['tagcontent']));
- $ins_data['state'] = $data['state'];
- $ins_data['sort_order'] = $data['sort_order'];
-
- $id = $data['id'];
- if( !empty($id) && $id > 0 )
- {
- M('lionfish_comshop_goods_tags')->where( array('id' => $id) )->save( $ins_data );
-
- }else{
- M('lionfish_comshop_goods_tags')->add( $ins_data );
- }
- }
-
- public function load_order_list($reorder_status_id = 0,$is_fenxiao =0,$is_pin =0,$integral =0,$is_soli=0)
- {
-
- $time = I('request.time');
-
- $s_time_start = I('request.time_start');
- $s_time_end = I('request.time_end');
-
- if( !isset($time['start']) )
- {
- $time['start'] = $s_time_start;
- $time['end'] = $s_time_end;
- }
-
- $starttime = isset($time['start']) ? strtotime($time['start']) : strtotime(date('Y-m-d'.' 00:00:00'));
- $endtime = isset($time['end']) ? strtotime($time['end']) : strtotime(date('Y-m-d'.' 23:59:59'));
-
- $order_status_id = I('request.order_status_id', 0);
-
- if($reorder_status_id >0)
- {
- $order_status_id = $reorder_status_id;
- }
-
- $searchtime = I('request.searchtime','');
- $searchfield = I('request.searchfield', '');
-
- $searchtype = I('request.type', 'normal');
-
- if( $is_pin == 1 )
- {
- $searchtype = 'pintuan';
- }
-
- if( $integral == 1 )
- {
- $searchtype = 'integral';
- }
- if(empty($searchtype)){
- $searchtype = 'normal';
- }
- $delivery = I('request.delivery', '');
-
-
- $count_where = "";
- $agentid = I('request.agentid', '');
-
-
- $head_id = I('request.headid', '');
- //$is_fenxiao = I('request.is_fenxiao', 0);
-
- $pindex = I('request.page', 1);
- $psize = 20;
-
-
- $paras =array();
-
- $sqlcondition = "";
-
- $condition = " 1 ";
-
- $is_soli_type = I('request.type', '');
- if($is_soli_type == 'soli')
- {
- $is_soli = 1;
- }
-
- if($is_soli > 0)
- {
- $condition .= " and o.soli_id > 0 ";
- }
-
- //begin 预售
- if( isset($_GET['presale_order']) && $_GET['presale_order'] == 1 )
- {
- $condition .= " and opr.order_id=o.order_id ";
- $sqlcondition .= ' inner join ' . C('DB_PREFIX').'lionfish_comshop_order_presale opr ';
- }
- //end 预售
- //begin 礼品卡
- if( isset($_GET['virtualcard_order']) && $_GET['virtualcard_order'] == 1 )
- {
- $condition .= " and vco.order_id=o.order_id ";
- $sqlcondition .= ' inner join ' . C('DB_PREFIX').'lionfish_comshop_order_virtualcard vco ';
- }
- //end 礼品卡
-
- if (defined('ROLE') && ROLE == 'agenter' )
- {
- $supper_info = get_agent_logininfo();
-
- $order_ids_list_tmp = M('lionfish_comshop_order_goods')->field('order_id')->where( array('supply_id' => $supper_info['id'] ) )->select();
-
- if( !empty($order_ids_list_tmp) )
- {
- $order_ids_tmp_arr = array();
- foreach($order_ids_list_tmp as $vv)
- {
- $order_ids_tmp_arr[] = $vv['order_id'];
- }
- $order_ids_tmp_str = implode(',', $order_ids_tmp_arr);
-
- $condition .= " and o.order_id in({$order_ids_tmp_str}) ";
- }
- else{
- $condition .= " and o.order_id in(0) ";
- }
- }
-
- if( $is_fenxiao == 1)
- {
- //分销订单
-
- $condition .= " and o.is_commission = 1 ";
- $count_where .= " and is_commission = 1 ";
-
- $commiss_member_id = I('request.commiss_member_id', '');
-
- if( $commiss_member_id > 0 )
- {
- $order_ids = M('lionfish_comshop_member_commiss_order')->field('order_id')->where( array('member_id' => $commiss_member_id ) )->select();
-
- if(!empty($order_ids))
- {
- $order_ids_arr = array();
- foreach($order_ids as $vv)
- {
- $order_ids_arr[] = $vv['order_id'];
- }
- $order_ids_str = implode(",",$order_ids_arr);
- $condition .= ' AND ( o.order_id in('.$order_ids_str.') ) ';
- $count_where .= ' AND ( order_id in('.$order_ids_str.') ) ';
- }else{
- $condition .= " and o.order_id in(0) ";
- $count_where .= ' AND order_id in(0) ';
- }
- }
-
-
-
- }
-
- if( !empty($searchtype) && in_array($searchtype, array('normal','pintuan','integral')) )
- {
- $condition .= " and o.type ='{$searchtype}' ";
- }
-
- if( !empty($delivery) )
- {
- if($delivery == 'cashon_delivery'){
- $condition .= " and o.payment_code = '{$delivery}' ";
- }else{
- $condition .= " and o.delivery ='{$delivery}' ";
- }
- }
-
-
- if( !empty($head_id) && $head_id >0 )
- {
- $condition .= " and o.head_id ='{$head_id}' ";
-
- $count_where .= " and head_id ='{$head_id}' ";
- }
-
- if($order_status_id > 0)
- {
- //$condition .= " and o.order_status_id={$order_status_id} ";
-
- if($order_status_id ==12 )
- {
- $condition .= " and (o.order_status_id={$order_status_id} or o.order_status_id=10 ) ";
-
- }else if($order_status_id ==11)
- {
- $condition .= " and (o.order_status_id={$order_status_id} or o.order_status_id=6 ) ";
- }
- else{
- $condition .= " and o.order_status_id={$order_status_id} ";
- }
-
- }
-
- //$is_fenxiao = I('request.is_fenxiao','intval',0);
-
- $keyword = I('request.keyword');
- if( !empty($searchfield) && !empty($keyword))
- {
- $keyword = trim($keyword);
-
- $keyword = htmlspecialchars_decode($keyword, ENT_QUOTES);
-
- switch($searchfield)
- {
- case 'ordersn':
- $condition .= ' AND locate("'.$keyword.'",o.order_num_alias)>0';
- break;
- case 'member':
- $condition .= ' AND (locate("'.$keyword.'",m.username)>0 or locate("'.$keyword.'",m.telephone)>0 or "'.$keyword.'"=o.member_id ) and o.member_id >0 ';
- $sqlcondition .= ' left join ' . C('DB_PREFIX') . 'lionfish_comshop_member m on m.member_id = o.member_id ';
- break;
- case 'member_id':
- $keyword = intval($keyword);
- $condition .= ' AND o.member_id = '.$keyword.' ';
- break;
-
- case 'address':
- $condition .= ' AND ( locate("'.$keyword.'",o.shipping_name)>0 )';
- //shipping_address
- break;
- case 'mobile':
- $condition .= ' AND ( locate("'.$keyword.'",o.shipping_tel)>0 )';
- //shipping_address
- break;
- case 'location':
- $condition .= ' AND (locate("'.$keyword.'",o.shipping_address)>0 )';
- break;
- case 'shipping_no':
- $condition .= ' AND (locate("'.$keyword.'",o.shipping_no)>0 )';
- break;
-
- case 'head_address':
- $head_ids = M('lionfish_community_head')->field('id')->where( 'community_name like "%'.$keyword.'%"' )->select();
-
-
- if(!empty($head_ids))
- {
- $head_ids_arr = array();
- foreach($head_ids as $vv)
- {
- $head_ids_arr[] = $vv['id'];
- }
- $head_ids_str = implode(",",$head_ids_arr);
- $condition .= ' AND ( o.head_id in('.$head_ids_str.') )';
- }else{
- $condition .= " and o.order_id in(0) ";
- }
-
- break;
- case 'head_name':
- // SELECT * FROM `ims_lionfish_community_head` WHERE `head_name` LIKE '%黄%'
-
- $head_ids = M('lionfish_community_head')->field('id')->where( 'head_name like "%'.$keyword.'%"' )->select();
-
- if(!empty($head_ids))
- {
- $head_ids_arr = array();
- foreach($head_ids as $vv)
- {
- $head_ids_arr[] = $vv['id'];
- }
- $head_ids_str = implode(",",$head_ids_arr);
- $condition .= ' AND ( o.head_id in('.$head_ids_str.') )';
- }else{
-
- $condition .= " and o.order_id in(0) ";
-
- }
-
- break;
- case 'goodstitle':
- $sqlcondition = ' inner join ( select DISTINCT(og.order_id) from ' . C('DB_PREFIX').'lionfish_comshop_order_goods og where (locate("'.$keyword.'",og.name)>0)) gs on gs.order_id=o.order_id';
- //var_dump($sqlcondition);
- //die();
-
- break;
- case 'supply_name':
-
- $supply_name_sql = 'SELECT id FROM ' . C('DB_PREFIX').
- 'lionfish_comshop_supply where shopname like "%'.$keyword.'%"';
- $supply_ids = M()->query($supply_name_sql);
-
-
- if(!empty($supply_ids))
- {
- $supply_ids_arr = array();
- foreach($supply_ids as $vv)
- {
- $supply_ids_arr[] = $vv['id'];
- }
- $supply_ids_str = implode(",",$supply_ids_arr);
-
- $order_ids_list_tmp = M('lionfish_comshop_order_goods')->field('order_id')->where( "supply_id in ({$supply_ids_str})" )->select();
-
- if( !empty($order_ids_list_tmp) )
- {
- $order_ids_tmp_arr = array();
- foreach($order_ids_list_tmp as $vv)
- {
- $order_ids_tmp_arr[] = $vv['order_id'];
- }
- $order_ids_tmp_str = implode(',', $order_ids_tmp_arr);
-
- $condition .= " and o.order_id in({$order_ids_tmp_str}) ";
- }else{
- $condition .= " and o.order_id in(0) ";
- }
- }else{
- $condition .= " and o.order_id in(0) ";
- }
- break;
- case 'trans_id':
- $condition .= ' AND (locate('.$keyword.',o.transaction_id)>0 )';
- break;
-
- }
- }
-
- if( !empty($searchtime) )
- {
- switch( $searchtime )
- {
- case 'create':
- //下单时间 date_added
- $condition .= " and o.date_added>={$starttime} and o.date_added <= {$endtime}";
- break;
- case 'pay':
- //付款时间
- $condition .= " and o.pay_time>={$starttime} and o.pay_time <= {$endtime}";
- break;
- case 'send':
- //发货时间
- $condition .= " and o.express_time>={$starttime} and o.express_time <= {$endtime}";
- break;
- case 'finish':
- //完成时间
- $condition .= " and o.receive_time>={$starttime} and o.receive_time <= {$endtime}";
- break;
- }
- }
-
-
- //----begin----
-
- if (defined('ROLE') && ROLE == 'agenter' ) {
-
- $supper_info = get_agent_logininfo();
-
-
- $total_where = " and supply_id= ".$supper_info['id'];
-
- $order_ids_list = M()->query("select og.order_id,og.total,og.shipping_fare,og.voucher_credit,og.fullreduction_money from ".
- C('DB_PREFIX')."lionfish_comshop_order_goods as og , ".C('DB_PREFIX')."lionfish_comshop_order as o where og.order_id =o.order_id and og.supply_id = ".$supper_info['id'] );
-
- $order_ids_arr = array();
- $order_ids_arr_dan = array();
-
- $total_money = 0;
- foreach($order_ids_list as $vv)
- {
- if( empty($order_ids_arr) || !isset($order_ids_arr[$vv['order_id']]) )
- {
- $order_ids_arr[$vv['order_id']] = $vv;
- $order_ids_arr_dan[] = $vv['order_id'];
- }
- }
-
- if( !empty($order_ids_arr_dan) )
- {
- $sql = 'SELECT count(o.order_id) as count FROM ' . C('DB_PREFIX'). 'lionfish_comshop_order as o '.$sqlcondition.' where ' . $condition." and o.order_id in (".implode(',', $order_ids_arr_dan).") " ;
-
- $total_arr = M()->query($sql);
-
- $total = $total_arr[0]['count'];
-
-
- $order_ids_list = M()->query("select og.order_id,og.total,og.shipping_fare,og.voucher_credit,og.fullreduction_money from ".C('DB_PREFIX').
- "lionfish_comshop_order_goods as og , ".C('DB_PREFIX')."lionfish_comshop_order as o where {$condition} and og.order_id =o.order_id and og.supply_id = ".$supper_info['id']." ");
-
- if( !empty($order_ids_list) )
- {
- foreach($order_ids_list as $vv)
- {
- $total_money += $vv['total']+$vv['shipping_fare']-$vv['voucher_credit']-$vv['fullreduction_money'];
- }
- }
- }else{
- $total = 0;
- }
-
-
- }else{
- $sql = 'SELECT count(o.order_id) as count FROM ' . C('DB_PREFIX'). 'lionfish_comshop_order as o '.$sqlcondition.' where ' . $condition ;
-
- $total_arr = M()->query( $sql );
-
- $total = $total_arr[0]['count'];
-
-
-
-
- $sql = 'SELECT sum(o.total+o.shipping_fare-o.voucher_credit-o.fullreduction_money) as total_money FROM ' . C('DB_PREFIX') . 'lionfish_comshop_order as o '.$sqlcondition.' where ' . $condition ;
-
- $total_money_arr = M()->query($sql);
-
- $total_money = $total_money_arr[0]['total_money'];
- }
- //---------end----
-
- if($total_money < 0)
- {
- $total_money = 0;
- }
-
-
- $total_money = number_format($total_money,2);
-
- $order_status_arr = $this->get_order_status_name();
-
- $export = I('request.export', 0);
-
-
- if ($export == 1 || $export == 2)
- {
- @set_time_limit(0);
-
- $is_can_look_headinfo = true;
- $supply_can_look_headinfo = D('Home/Front')->get_config_by_name('supply_can_look_headinfo');
-
-
- if (defined('ROLE') && ROLE == 'agenter' )
- {
- if( isset($supply_can_look_headinfo) && $supply_can_look_headinfo == 2 )
- {
- $is_can_look_headinfo = false;
- }
- }
- $note_content = D('Home/Front')->get_config_by_name('order_note_name');
- $order_note_open = D('Home/Front')->get_config_by_name('order_note_open');
- $columns = array(
- array('title' => '订单流水号', 'field' => 'day_paixu', 'width' => 24),
- array('title' => '订单编号', 'field' => 'order_num_alias', 'width' => 36),
- array('title' => '昵称', 'field' => 'name', 'width' => 12),
- //array('title' => '会员姓名', 'field' => 'mrealname', 'width' => 12),
- array('title' => 'openid', 'field' => 'openid', 'width' => 24),
- array('title' => '会员手机号', 'field' => 'telephone', 'width' => 12),
- array('title' => '会员备注', 'field' => 'member_content', 'width' => 24),
- array('title' => '收货姓名(或自提人)', 'field' => 'shipping_name', 'width' => 12),
- array('title' => '联系电话', 'field' => 'shipping_tel', 'width' => 12),
- array('title' => '供应商名称/类型', 'field' => 'supply_name', 'width' => 12),
- //array('title' => '收货地址', 'field' => 'address_province', 'width' => 12),
- //array('title' => '', 'field' => 'address_city', 'width' => 12),
- //array('title' => '', 'field' => 'address_area', 'width' => 12),
- array('title' => '微信支付交易单号', 'field' => 'transaction_id', 'width' => 24),
- array('title' => '完整收货地址', 'field' => 'address_province_city_area', 'width' => 12),
- //array('title' => '', 'field' => 'address_street', 'width' => 12),
- array('title' => '提货详细地址', 'field' => 'address_address', 'width' => 12),
- array('title' => '团长配送送货详细地址', 'field' => 'tuan_send_address', 'width' => 22),
- array('title' => '商品名称', 'field' => 'goods_title', 'width' => 24),
- array('title' => '商品分类', 'field' => 'goods_category', 'width' => 24),
- array('title' => '商品编码', 'field' => 'goods_goodssn', 'width' => 12),
- array('title' => '商品规格', 'field' => 'goods_optiontitle', 'width' => 12),
- array('title' => '商品数量', 'field' => 'quantity', 'width' => 12),
- array('title' => '商品单价', 'field' => 'goods_price1', 'width' => 12),
- //array('title' => '商品单价(折扣后)', 'field' => 'goods_price2', 'width' => 12),
- //array('title' => '商品价格(折扣前)', 'field' => 'goods_rprice1', 'width' => 12),
- array('title' => '商品价格', 'field' => 'goods_rprice2', 'width' => 12),
- array('title' => '支付方式', 'field' => 'paytype', 'width' => 12),
- array('title' => '配送方式', 'field' => 'delivery', 'width' => 12),
- array('title' => '预计送达时间', 'field' => 'expected_delivery_time', 'width' => 24),
- //array('title' => '自提门店', 'field' => 'pickname', 'width' => 24),
- //array('title' => '商品小计', 'field' => 'goodsprice', 'width' => 12),
- array('title' => '运费', 'field' => 'dispatchprice', 'width' => 12),
- array('title' => '积分抵扣', 'field' => 'score_for_money', 'width' => 12),
- //array('title' => '余额抵扣', 'field' => 'deductcredit2', 'width' => 12),
- array('title' => '满额立减', 'field' => 'fullreduction_money', 'width' => 12),
- array('title' => '优惠券优惠', 'field' => 'voucher_credit', 'width' => 12),
- array('title' => '会员佣金', 'field' => 'member_commissmoney', 'width' => 12),
- //array('title' => '订单改价', 'field' => 'changeprice', 'width' => 12),
- //array('title' => '运费改价', 'field' => 'changedispatchprice', 'width' => 12),
- array('title' => '应收款(该笔订单总款)', 'field' => 'price', 'width' => 12),
- array('title' => '状态', 'field' => 'status', 'width' => 12),
- array('title' => '团长佣金', 'field' => 'head_money', 'width' => 12),
- array('title' => '下单时间', 'field' => 'createtime', 'width' => 24),
- array('title' => '付款时间', 'field' => 'paytime', 'width' => 24),
- array('title' => '发货时间', 'field' => 'sendtime', 'width' => 24),
-
- array('title' => '收货时间', 'field' => 'receive_time', 'width' => 24),
-
- array('title' => '退款商品数量', 'field' => 'has_refund_quantity', 'width' => 12),
- array('title' => '退款金额', 'field' => 'has_refund_money', 'width' => 12),
-
- array('title' => '完成时间', 'field' => 'finishtime', 'width' => 24),
- array('title' => '快递公司', 'field' => 'expresscom', 'width' => 24),
- array('title' => '快递单号', 'field' => 'expresssn', 'width' => 24),
-
- array('title' => '小区名称', 'field' => 'community_name', 'width' => 12),
- array('title' => '团长姓名', 'field' => 'head_name', 'width' => 12),
- array('title' => '团长电话', 'field' => 'head_mobile', 'width' => 12),
- array('title' => '团长完整地址', 'field' => 'fullAddress', 'width' => 24),
- array('title' => '省市区', 'field' => 'province', 'width' => 24),
-
- array('title' => '订单备注', 'field' => 'remark', 'width' => 36),
- array('title' => '卖家订单备注', 'field' => 'remarksaler', 'width' => 36),
- array('title' => '商品成本价', 'field' => 'costprice', 'width' => 36),
- //array('title' => '核销员', 'field' => 'salerinfo', 'width' => 24),
- //array('title' => '核销门店', 'field' => 'storeinfo', 'width' => 36),
- //array('title' => '订单自定义信息', 'field' => 'order_diyformdata', 'width' => 36),
- //array('title' => '商品自定义信息', 'field' => 'goods_diyformdata', 'width' => 36)
- array('title' => '省', 'field' => 'address_province', 'width' => 36),
- array('title' => '市', 'field' => 'address_city', 'width' => 36),
- array('title' => '区', 'field' => 'address_country', 'width' => 36),
- array('title' => '商品重量(克)', 'field' => 'goods_weight', 'width' => 36),
- );
-
- if($order_note_open == 1){
- if(empty($note_content)){
- $note_content= '店名';
- }
- $columns[] = array('title' => $note_content, 'field' => 'note_content', 'width' => 24, 'sort' => 0, 'is_check' => 0);
- }
-
- //modify_explode_arr
-
- $modify_explode_arr = I('request.modify_explode_arr', '');
- $columns_keys = array();
-
- foreach($columns as $val)
- {
- $columns_keys[ $val['field'] ] = array('title' => $val['title'],'width' => $val['width'] );
-
- }
-
- if( !empty($modify_explode_arr) )
- {
- /**
- order_num_alias,
- name,telephone,member_content,shipping_name,shipping_tel,
- address_province_city_area,address_address,goods_title,goods_rprice2,quantity,paytype,
- delivery,tuan_send_address,goods_optiontitle,goods_price1,receive_time,expresssn,createtime,
- community_name,head_name,head_mobile
- **/
-
-
- $ziduan_arr = explode(',', $modify_explode_arr);
-
- $length = count($ziduan_arr);
-
- $columns = array();
-
- $save_columns = array();
-
- foreach( $ziduan_arr as $fields )
- {
- if($fields == 'province'){
- $columns[] = array('title' => $columns_keys['address_province']['title'], 'field' => 'address_province', 'width' => $columns_keys['address_province']['width'] );
- $columns[] = array('title' => $columns_keys['address_city']['title'], 'field' => 'address_city', 'width' => $columns_keys['address_city']['width'] );
- $columns[] = array('title' => $columns_keys['address_country']['title'], 'field' => 'address_country', 'width' => $columns_keys['address_country']['width'] );
- }else{
- $columns[] = array('title' => $columns_keys[$fields]['title'], 'field' => $fields, 'width' => $columns_keys[$fields]['width'] );
- }
- $save_columns[$fields] = $length;
- $length--;
- }
- //dump(777);die;
- D('Seller/Config')->update( array('modify_export_fields' => json_encode($save_columns) ) );
- }
-
-
- $exportlist = array();
-
-
-
-
- if (!(empty($total))) {
-
- //begin
- set_time_limit(0);
-
- $fileName = date('YmdHis', time());
- header('Content-Type: application/vnd.ms-execl');
- header('Content-Disposition: attachment;filename="订单数据' . $fileName . '.csv"');
- $begin = microtime(true);
-
- $fp = fopen('php://output', 'a');
-
- $step = 100;
- $nums = 10000;
-
- //设置标题
- //$title = array('ID', '用户名', '用户年龄', '用户描述', '用户手机', '用户QQ', '用户邮箱', '用户地址');
-
- $title = array();
-
- foreach($columns as $key => $item) {
- $title[$item['field']] = iconv('UTF-8', 'GBK', $item['title']);
- }
- fputcsv($fp, $title);
-
- //$page = ceil($total / 500);
-
-
- $sqlcondition .= ' left join ' .C('DB_PREFIX') . 'lionfish_comshop_order_goods ogc on ogc.order_id = o.order_id ';
-
-
- $sql_count = 'SELECT count(o.order_id) as count
- FROM ' . C('DB_PREFIX'). 'lionfish_comshop_order as o '.$sqlcondition.' where ' . $condition ;
-
- $total_arr = M()->query($sql_count);
-
- $total = $total_arr[0]['count'];
-
- $page = ceil($total / 500);
-
-
-
- for($s = 1; $s <= $page; $s++) {
- $offset = ($s-1)* 500;
-
-
-
- if ($_GPC['export'] == 1 ) {
- $sql = 'SELECT o.*,ogc.name as goods_title,ogc.supply_id,ogc.goods_id,ogc.order_goods_id ,ogc.quantity as ogc_quantity,ogc.price,ogc.statements_end_time,
- ogc.total as goods_total ,ogc.score_for_money as g_score_for_money, ogc.fullreduction_money as g_fullreduction_money,ogc.voucher_credit as g_voucher_credit ,ogc.has_refund_money,ogc.has_refund_quantity , ogc.shipping_fare as g_shipping_fare,ogc.model as model ,ogc.cost_price
- FROM ' . C('DB_PREFIX') . 'lionfish_comshop_order as o '.$sqlcondition.' where ' . $condition . ' ORDER BY o.head_id asc,ogc.goods_id desc, o.`order_id` DESC limit '."{$offset},500";
-
- }else{
- $sql = 'SELECT o.*,ogc.name as goods_title,ogc.supply_id,ogc.order_goods_id,ogc.goods_id,ogc.quantity as ogc_quantity,ogc.price,ogc.is_refund_state,ogc.statements_end_time,
- ogc.total as goods_total ,ogc.score_for_money as g_score_for_money, ogc.fullreduction_money as g_fullreduction_money,ogc.voucher_credit as g_voucher_credit ,ogc.has_refund_money,ogc.has_refund_quantity ,ogc.shipping_fare as g_shipping_fare,ogc.model as model ,ogc.cost_price
- FROM ' . C('DB_PREFIX') . 'lionfish_comshop_order as o '.$sqlcondition.' where ' . $condition . ' ORDER BY o.`order_id` DESC limit '."{$offset},500";
- }
-
-
- $list = M()->query( $sql );
- // var_dump($list);
-
-
- $look_member_arr = array();
- $area_arr = array();
-
- if( !empty($list) )
- {
- foreach($list as $val)
- {
- if (defined('ROLE') && ROLE == 'agenter' )
- {
- $supper_info = get_agent_logininfo();
- if($supper_info['id'] != $val['supply_id'])
- {
- continue;
- }
- }
-
-
- if( empty($look_member_arr) || !isset($look_member_arr[$val['member_id']]) )
- {
- $member_info = M('lionfish_comshop_member')->where( array('member_id' => $val['member_id']) )->find();
-
- $look_member_arr[$val['member_id']] = $member_info;
- }
-
-
- $category_name = "";
-
- $cate_list = M('lionfish_comshop_goods_to_category')->where( array('goods_id' => $val['goods_id'] ) )->select();
-
- $cate_arr = array();
-
- if( !empty($cate_list) )
- {
- foreach( $cate_list as $c_val )
- {
- $ct_info = M('lionfish_comshop_goods_category')->field('name')->where( array('id' => $c_val['cate_id'] ) )->find();
- if( !empty($ct_info) )
- {
- $cate_arr[] = $ct_info['name'];
- }
- }
- $category_name = implode('、', $cate_arr);
- }
-
-
- $tmp_exval= array();
- $tmp_exval['order_num_alias'] = $val['order_num_alias']."\t";
- $tmp_exval['day_paixu'] = '#'.$val['day_paixu'];
- $tmp_exval['name'] = $look_member_arr[$val['member_id']]['username'];
-
- $tmp_exval['goods_category'] = $category_name;
-
- //from_type
- if($val['from_type'] == 'wepro')
- {
- $tmp_exval['openid'] = $look_member_arr[$val['member_id']]['we_openid'];
- }else{
- $tmp_exval['openid'] = $look_member_arr[$val['member_id']]['openid'];
- }
- $tmp_exval['telephone'] = $look_member_arr[$val['member_id']]['telephone'];
- $tmp_exval['member_content'] = $look_member_arr[$val['member_id']]['content'];
-
- $tmp_exval['shipping_name'] = $val['shipping_name'];
- $tmp_exval['shipping_tel'] = $val['shipping_tel'];
-
- //area_arr
- if( empty($area_arr) || !isset($area_arr[$val['shipping_province_id']]) )
- {
- $area_arr[$val['shipping_province_id']] = D('Seller/Front')->get_area_info($val['shipping_province_id']);
- }
-
- if( empty($area_arr) || !isset($area_arr[$val['shipping_city_id']]) )
- {
- $area_arr[$val['shipping_city_id']] = D('Seller/Front')->get_area_info($val['shipping_city_id']);
- }
-
- if( empty($area_arr) || !isset($area_arr[$val['shipping_country_id']]) )
- {
- $area_arr[$val['shipping_country_id']] = D('Seller/Front')->get_area_info($val['shipping_country_id']);
- }
-
- $province_info = $area_arr[$val['shipping_province_id']];
- $city_info = $area_arr[$val['shipping_city_id']];
- $area_info = $area_arr[$val['shipping_country_id']];
-
-
- $tmp_exval['address_province_city_area'] = $province_info['name'].$city_info['name'].$area_info['name'].$val['shipping_address'];
-
- $tmp_exval['address_province'] = $province_info['name'];
- $tmp_exval['address_city'] = $city_info['name'];
- $tmp_exval['address_country'] = $area_info['name'];
- $tmp_exval['goods_goodssn'] = $val['model'];
-
-
- $tmp_exval['address_address'] = $val['shipping_address'];
-
- if( $val['delivery'] == 'tuanz_send'){
- // $tmp_exval['address_address'] = $val['tuan_send_address'];
- }
-
- $tmp_exval['tuan_send_address'] = $val['tuan_send_address'];
-
- $tmp_exval['goods_title'] = htmlspecialchars_decode(stripslashes($val['goods_title']));
- if($val['supply_id'] == 0){
- $tmp_exval['supply_name'] = '平台自营(自营)';
- }else{
- $supply_list = M('lionfish_comshop_supply')->where( array('id' => $val['supply_id'] ) )->find();
- $tmp_exval['supply_name'] = $supply_list['shopname'].'(独立供应商)';
- }
- $goods_optiontitle = $this->get_order_option_sku($val['order_id'], $val['order_goods_id']);
- $tmp_exval['goods_optiontitle'] = $goods_optiontitle;
- $tmp_exval['quantity'] = $val['ogc_quantity'];
- $tmp_exval['goods_price1'] = $val['price'];
- $tmp_exval['goods_rprice2'] = $val['goods_total'];
-
- $tmp_exval['has_refund_money'] = $val['has_refund_money'];
- $tmp_exval['has_refund_quantity'] = $val['has_refund_quantity'];
- $goods_weight = $this->get_order_option_weight($val['order_id'], $val['order_goods_id']);
- $tmp_exval['goods_weight'] = $goods_weight;
-
- $paytype = $val['payment_code'];
- switch($paytype)
- {
- case 'admin':
- $paytype='后台支付';
- break;
- case 'yuer':
- $paytype='余额支付';
- break;
- case 'weixin':
- $paytype='微信支付';
- break;
- default:
- $paytype = '未支付';
- }
-
- //has_refund_quantity has_refund_money
- //$val['order_id'], $val['order_goods_id']
-
- $has_refund_quantity = D('Seller/Commonorder')->refund_order_goods_quantity( $val['order_id'], $val['order_goods_id'] );
-
- $tmp_exval['has_refund_quantity'] = $has_refund_quantity;
-
- $has_refund_money = D('Seller/Commonorder')->get_order_goods_refund_money( $val['order_id'], $val['order_goods_id'] );
-
- $tmp_exval['has_refund_money'] = $has_refund_money;
-
-
- if(!empty($val['head_id'])){
-
- $community_info = D('Seller/Front')->get_community_byid($val['head_id']);
- $tmp_exval['community_name'] = $community_info['communityName'];
-
- if( $is_can_look_headinfo )
- {
- $tmp_exval['fullAddress'] = $community_info['fullAddress'];
- $tmp_exval['head_name'] = $community_info['disUserName'];
- $tmp_exval['head_mobile'] = $community_info['head_mobile'];
- }else{
- $tmp_exval['fullAddress'] = '';
- $tmp_exval['head_name'] = '';
- $tmp_exval['head_mobile'] = '';
- }
- }else{
- $tmp_exval['community_name'] = '';
- $tmp_exval['fullAddress'] = '';
- $tmp_exval['head_name'] = '';
- $tmp_exval['head_mobile'] = '';
- }
-
-
-
- $tmp_exval['paytype'] = $paytype;
-
- //express 快递, pickup 自提, tuanz_send 团长配送
- //$tmp_exval['delivery'] = $val['delivery'] == 'express'? '快递':'自提';
- if($val['delivery'] == 'express'){
- $tmp_exval['delivery'] = '快递';
- }elseif($val['delivery'] == 'pickup'){
- $tmp_exval['delivery'] = '自提';
- }elseif($val['delivery'] == 'tuanz_send'){
- $tmp_exval['delivery'] = '团长配送';
- }
-
- $tmp_exval['expected_delivery_time'] =$val['expected_delivery_time'];
-
- if ($_GPC['export'] == 1 ) {
-
- $tmp_exval['dispatchprice'] = $val['g_shipping_fare'];
- $val['total'] = $val['goods_total']+$val['g_shipping_fare']-$val['g_score_for_money']-$val['g_fullreduction_money'] - $val['g_voucher_credit'];
-
- if($val['total'] < 0)
- {
- $val['total'] = 0;
- }
- $tmp_exval['price'] = $val['total'];
- }else{
- //总运费
- $shipping_fare_sum = array();
-
- $shipping_fare_sum = M('lionfish_comshop_order')->where( array('order_id' => $val['order_id']) )->count('shipping_fare');
-
- $total = M('lionfish_comshop_order')->where( array('order_id' => $val['order_id']) )->field('total, shipping_fare, score_for_money,fullreduction_money, voucher_credit')->find();
- //
- $order_goods_id = M('lionfish_comshop_order_goods')->where( array('order_id' => $val['order_id']) )->field('order_goods_id')->order('order_goods_id asc')->find();
-
- $lionfish_comshop_order_goods = M('lionfish_comshop_order_goods')->where( array('goods_id' => $val['goods_id'],'order_id' => $val['order_id']) )->find();
- if($order_goods_id['order_goods_id'] == $val['order_goods_id'] ){
-
- $tmp_exval['dispatchprice'] = $shipping_fare_sum;
- $tmp_exval['price'] = $total['total']+$total['shipping_fare']-$total['score_for_money']-$total['fullreduction_money'] - $total['voucher_credit'];
- }else{
- $tmp_exval['dispatchprice'] = 0;
- $tmp_exval['price'] = 0;
- }
-
-
- }
- $tmp_exval['transaction_id'] = $val['transaction_id']."\t";
- $tmp_exval['note_content'] = $val['note_content'];
- $tmp_exval['score_for_money'] = $val['g_score_for_money'];
- $tmp_exval['fullreduction_money'] = $val['g_fullreduction_money'];
- $tmp_exval['voucher_credit'] = $val['g_voucher_credit'];
-
-
-
- $tmp_exval['changeprice'] = $val['changedtotal'];
- $tmp_exval['changedispatchprice'] = $val['changedshipping_fare'];
-
-
- $val['total'] = $val['goods_total']+$val['g_shipping_fare']-$val['g_score_for_money']-$val['g_fullreduction_money'] - $val['g_voucher_credit'];
-
-
- if($val['total'] < 0)
- {
- $val['total'] = 0;
- }
-
-
- $tmp_exval['price'] = $val['total'];
-
-
- $tmp_exval['head_money'] = 0;
-
-
- $head_commiss_order = M('lionfish_community_head_commiss_order')->where( array('order_id' => $val['order_id'],'order_goods_id' => $val['order_goods_id'],'type' => 'orderbuy') )->select();
-
- if( !empty($head_commiss_order) )
- {
- $head_money = 0;
- foreach($head_commiss_order as $k=>$v){
- $head_money = $head_money + $v['money'];
- }
- $tmp_exval['head_money'] = $head_money;
- //$tmp_exval['head_money'] = $head_commiss_order['money'];
- }
-
- $tmp_exval['member_commissmoney'] = 0;
- //array('title' => '会员佣金', 'field' => 'member_commissmoney', 'width' => 12),
- $member_commissmoney = M('lionfish_comshop_member_commiss_order')->where( array('order_id' => $val['order_id'], 'order_goods_id' => $val['order_goods_id'] ) )->sum('money');
- if( !empty($member_commissmoney) && $member_commissmoney > 0 )
- {
- $tmp_exval['member_commissmoney'] = $member_commissmoney;
- }
-
-
- if($val['has_refund_quantity'] > 0){
- $tmp_exval['status'] = $order_status_arr[7];
- }else{
- $tmp_exval['status'] = $order_status_arr[$val['order_status_id']];
- }
-
- $tmp_exval['createtime'] = date('Y-m-d H:i:s', $val['date_added']);
-
-
- $tmp_exval['paytime'] = empty($val['pay_time']) ? '' : date('Y-m-d H:i:s', $val['pay_time']);
- $tmp_exval['sendtime'] = empty($val['express_time']) ? '': date('Y-m-d H:i:s', $val['express_time']);
- $tmp_exval['finishtime'] = empty($val['finishtime']) ? '' : date('Y-m-d H:i:s', $val['finishtime']);
-
- $tmp_exval['receive_time'] = empty($val['receive_time']) ? '' : date('Y-m-d H:i:s', $val['receive_time']);
-
- $tmp_exval['expresscom'] = $val['dispatchname'];
- $tmp_exval['expresssn'] = $val['shipping_no'];
- $tmp_exval['remark'] = $val['comment'];
- $tmp_exval['remarksaler'] = $val['remarksaler'];
- $tmp_exval['costprice'] = 0;
- $lionfish_comshop_goods = M('lionfish_comshop_goods')->where( array('id' => $val['goods_id']) )->find();
- if(!empty($lionfish_comshop_goods)){
- if ($lionfish_comshop_goods['hasoption'] == 1){
- $lionfish_comshop_order_goods = M('lionfish_comshop_order_goods')->where( array('goods_id' => $val['goods_id'],'order_id' => $val['order_id']) )->find();
- if (!empty($lionfish_comshop_order_goods)){
- $lionfish_comshop_goods_option_item_value = M('lionfish_comshop_goods_option_item_value')->where( array('option_item_ids' => $lionfish_comshop_order_goods['rela_goodsoption_valueid'],'goods_id' => $val['goods_id']) )->find();
- $tmp_exval['costprice'] = isset($lionfish_comshop_goods_option_item_value['costprice'])?$lionfish_comshop_goods_option_item_value['costprice'] : 0;
- }
- }else{
- $tmp_exval['costprice'] = $lionfish_comshop_goods['costprice'];
- }
- }
- $tmp_exval['costprice'] = isset($val['cost_price'])?$val['cost_price'] : 0;
- $exportlist[] = $tmp_exval;
-
- $row_arr = array();
-
- foreach($columns as $key => $item) {
-
- $row_arr[$item['field']] = iconv('UTF-8', 'GBK//IGNORE', $tmp_exval[$item['field']]);
- }
- //var_dump($row_arr);die;
- fputcsv($fp, $row_arr);
- }
-
- ob_flush();
- flush();
-
- unset($list);
- }
-
- }
-
- die();
-
- //D('Seller/Excel')->export($exportlist, array('title' => '订单数据', 'columns' => $columns));
- }
-
- }
-
-
- if (!(empty($total))) {
-
- $sql = 'SELECT o.* FROM ' .C('DB_PREFIX'). 'lionfish_comshop_order as o '.$sqlcondition.' where ' . $condition . ' ORDER BY o.`order_id` DESC LIMIT ' . (($pindex - 1) * $psize) . ',' . $psize;
-
-
- $list = M()->query($sql);
- $need_list = array();
-
-
- foreach ($list as $key => &$value ) {
- $sql_goods = "select og.* from ".C('DB_PREFIX')."lionfish_comshop_order_goods as og
- where og.order_id = {$value[order_id]} ";
-
- $goods = M()->query($sql_goods);
- $value['is_virtualcard'] = 0;
- if( $value['delivery'] == 'express' )
- {
- $virtualcard_result = D('Seller/VirtualCard')->getVirtualCardOrderInfO( $value['order_id'] );
- if( $virtualcard_result['code'] == 0 ) {
- $value['is_virtualcard'] = 1;
- }
- }
-
- $need_goods = array();
-
- $shipping_fare = 0;
- $fullreduction_money = 0;
- $voucher_credit = 0;
- $totals = 0;
- if( $value['delivery'] == 'localtown_delivery' && ($value['order_status_id'] != 3 && $value['order_status_id'] != 5 ) )
- {
- $value['orderdistribution_order'] = M('lionfish_comshop_orderdistribution_order')->where( array('order_id' => $value['order_id'] ) )->find();
- if( !empty($value['orderdistribution_order']) && $value['orderdistribution_order'] > 0 )
- {
- $orderdistribution = M('lionfish_comshop_orderdistribution')->where( array('id' => $value['orderdistribution_order']['orderdistribution_id'] ) )->find();
- $value['orderdistribution_order']['username'] = $orderdistribution['username'];
- }
- $imdada_data = M('lionfish_comshop_orderdistribution_thirth_query')->where( array('order_id' => $value['order_id'], 'third_distribution_type'=>'imdada' ) )->find();
- if($imdada_data['status'] == 1){
- $value['pre_imdada_delivery_fee'] = "¥".$imdada_data['shipping_fee'];
- }else{
- $value['pre_imdada_delivery_fee'] = $imdada_data['message'];
- }
- $mk_data = M('lionfish_comshop_orderdistribution_thirth_query')->where( array('order_id' => $value['order_id'], 'third_distribution_type'=>'mk' ) )->find();
- if($mk_data['status'] == 1){
- $value['pre_mk_delivery_fee'] = "¥".$mk_data['shipping_fee'];
- }else{
- $value['pre_mk_delivery_fee'] = $mk_data['message'];
- }
- $sf_data = M('lionfish_comshop_orderdistribution_thirth_query')->where( array('order_id' => $value['order_id'], 'third_distribution_type'=>'sf' ) )->find();
- if($sf_data['status'] == 1){
- $value['pre_sf_delivery_fee'] = "¥".$sf_data['shipping_fee'];
- }else{
- $value['pre_sf_delivery_fee'] = $sf_data['message'];
- }
- //达达配送是否已发过
- $imdada_count = M('lionfish_comshop_orderdistribution_thirth_log')->where(array('order_id'=>$value['order_id'],'third_distribution_type'=>'imdada'))->count();
- $imdada_has_send = 0;
- if($imdada_count > 0){
- $imdada_has_send = 1;
- }
- $value['imdada_has_send'] = $imdada_has_send;
- //顺丰配送是否已发过
- $sf_count = M('lionfish_comshop_orderdistribution_thirth_log')->where(array('order_id'=>$value['order_id'],'third_distribution_type'=>'sf'))->count();
- $sf_has_send = 0;
- if($sf_count > 0){
- $sf_has_send = 1;
- }
- $value['sf_has_send'] = $sf_has_send;
- }
-
- foreach($goods as $key =>$goods_val)
- {
- $goods_val['name'] = htmlspecialchars_decode(stripslashes($goods_val['name']));
- if( $goods_val['is_statements_state'] == 1 )
- {
- $value['is_statements_state'] = 1;
- }
-
- $goods_val['option_sku'] = $this->get_order_option_sku($value['order_id'], $goods_val['order_goods_id']);
-
- $goods_val['commisson_info'] = array();//load_model_class('commission')->get_order_goods_commission( $value['order_id'], $goods_val['order_goods_id']);
-
- //供应商名称
- $goods_val['shopname'] = M('lionfish_comshop_supply')->field('shopname,type')->where( array('id' => $goods_val['supply_id'] ) )->find();
- //商品类型
- $goods_val['goods_type'] = M('lionfish_comshop_goods')->field('type')->where( array('id' => $goods_val['goods_id'] ) )->find();
-
- if( $goods_val['is_refund_state'] == 1 )
- {
-
- $refund_info = M('lionfish_comshop_order_refund')->where( array('order_id' => $value['order_id'] ,'order_goods_id' => $goods_val['order_goods_id']) )->order('ref_id desc')->find();
-
- $goods_val['refund_info'] = $refund_info;
- }
-
- if (defined('ROLE') && ROLE == 'agenter' )
- {
- $supper_info = get_agent_logininfo();
-
- if($supper_info['id'] != $goods_val['supply_id'])
- {
- continue;
- }
- }
- $shipping_fare += $goods_val['shipping_fare'];
- $fullreduction_money += $goods_val['fullreduction_money'];
- $voucher_credit += $goods_val['voucher_credit'];
- $totals += $goods_val['total'];
- if($value['delivery'] == 'hexiao'){
- $goods_val['hexiao_info'] = M('lionfish_comshop_order_goods_saleshexiao')->where( array('order_id' => $value['order_id'] ,'order_goods_id' => $goods_val['order_goods_id']) )->find();
- }
- $need_goods[$key] = $goods_val;
- }
-
- if (defined('ROLE') && ROLE == 'agenter' )
- {
- $value['shipping_fare'] = $shipping_fare;
- $value['fullreduction_money'] = $fullreduction_money;
- $value['voucher_credit'] = $voucher_credit;
- $value['total'] = $totals;
- }
-
- //member_id ims_ nickname
-
- $nickname_info = M('lionfish_comshop_member')->field('username as nickname,content')->where( array('member_id' => $value['member_id']) )->find();
-
- $nickname = $nickname_info['nickname'];
-
- $value['nickname'] = $nickname;
- $value['member_content'] = $nickname_info['content'];
-
-
- $value['goods'] = $need_goods;
-
- if($value['head_id'] <=0 )
- {
- $value['community_name'] = '';
- $value['head_name'] = '';
- $value['head_mobile'] = '';
-
- $value['province'] = '';
- $value['city'] = '';
- }else{
- $community_info = D('Seller/Front')->get_community_byid($value['head_id']);
-
-
- $value['community_name'] = $community_info['communityName'];
- $value['head_name'] = $community_info['disUserName'];
- $value['head_mobile'] = $community_info['head_mobile'];
-
- if (defined('ROLE') && ROLE == 'agenter' )
- {
- $supply_can_look_headinfo = D('Home/Front')->get_config_by_name('supply_can_look_headinfo');
- if($supply_can_look_headinfo != 1){
- $value['community_name'] = D('Seller/Order')->desensitize($community_info['communityName'],0,-1);
- $value['head_name'] = D('Seller/Order')->desensitize($community_info['disUserName'],1,1);
- $value['head_mobile'] = D('Seller/Order')->desensitize($community_info['head_mobile'],3,4);
- }
- }
-
- $value['province'] = $community_info['province'];
- $value['city'] = $community_info['city'];
- }
-
-
-
-
- }
- $pager = pagination2($total, $pindex, $psize);
- }
-
- //get_order_count($where = '',$uniacid = 0)
-
- if( !empty($searchtype) )
- {
- $count_where .= " and type = '{$searchtype}' ";
- }
-
-
- if (defined('ROLE') && ROLE == 'agenter' )
- {
- $supper_info = get_agent_logininfo();
-
- $order_ids_list = M()->query("select og.order_id,og.total,og.shipping_fare,og.voucher_credit,og.fullreduction_money from ".C('DB_PREFIX').
- "lionfish_comshop_order_goods as og , ".C('DB_PREFIX')."lionfish_comshop_order as o where og.order_id =o.order_id and og.supply_id = ".$supper_info['id']." ");
- $order_ids_arr = array();
-
- $seven_refund_money= 0;
-
- foreach($order_ids_list as $vv)
- {
- if( empty($order_ids_arr) || !isset($order_ids_arr[$vv['order_id']]) )
- {
- $order_ids_arr[$vv['order_id']] = $vv['order_id'];
- }
- }
- if( !empty($order_ids_arr) )
- {
- $count_where .= " and order_id in (".implode(',', $order_ids_arr).")";
- }else{
- $count_where .= " and order_id in (0)";
- }
-
- }
-
-
- $all_count = $this->get_order_count($count_where);
- $count_status_1 = $this->get_order_count(" {$count_where} and order_status_id = 1 ");
- $count_status_3 = $this->get_order_count(" {$count_where} and order_status_id = 3 ");
- $count_status_4 = $this->get_order_count(" {$count_where} and order_status_id = 4 ");
- $count_status_5 = $this->get_order_count(" {$count_where} and order_status_id = 5 ");
- $count_status_7 = $this->get_order_count(" {$count_where} and order_status_id = 7 ");
- $count_status_11 = $this->get_order_count(" {$count_where} and (order_status_id = 11 or order_status_id = 6) ");
- $count_status_14 = $this->get_order_count(" {$count_where} and order_status_id = 14 ");
- $count_status_express = $this->get_order_count(" {$count_where} and order_status_id = 1 and delivery = 'express'");
-
-
- return array('total' => $total, 'total_money' => $total_money,'pager' => $pager, 'all_count' => $all_count,
- 'list' =>$list,
- 'count_status_1' => $count_status_1,'count_status_3' => $count_status_3,'count_status_4' => $count_status_4,
- 'count_status_5' => $count_status_5, 'count_status_7' => $count_status_7, 'count_status_11' => $count_status_11,
- 'count_status_14' => $count_status_14,'count_status_express'=>$count_status_express
- );
- }
-
- //---copy begin
-
- public function load_afterorder_list($is_pintuan = 0)
- {
- $time = I('request.time');
-
- $starttime = isset($time['start']) ? strtotime($time['start']) : strtotime(date('Y-m-d'.' 00:00:00'));
- $endtime = isset($time['end']) ? strtotime($time['end']) : strtotime(date('Y-m-d'.' 23:59:59'));
-
- $order_status_id = I('request.order_status_id', 0);
- $state = I('request.state', -1);
- if($reorder_status_id >0)
- {
- $order_status_id = $reorder_status_id;
- }
-
- $searchtime = I('request.searchtime','');
- $searchfield = I('request.searchfield', '');
-
- $searchtype = I('request.type', '');
-
- if( $is_pintuan == 1 && empty($searchtype) )
- {
- $searchtype = 'pintuan';
- }
-
- $delivery = I('request.delivery', '');
-
-
- $count_where = "";
- $agentid = I('request.agentid', '');
-
- $head_id = I('request.headid', '');
-
-
- $pindex = I('request.page', 1);
- $psize = 20;
-
-
- $paras =array();
-
- $sqlcondition = "";
-
- $condition = " 1 ";
-
- if( defined('ROLE') && ROLE == 'agenter' )
- {
- $supper_info = session('agent_auth');
-
- $supper_info['id'] = $supper_info['uid'];
-
- $order_ids_list_tmp = M('lionfish_comshop_order_goods')->field('order_id')->where( array('supply_id' => $supper_info['id'] ) )->select();
-
- if( !empty($order_ids_list_tmp) )
- {
- $order_ids_tmp_arr = array();
- foreach($order_ids_list_tmp as $vv)
- {
- $order_ids_tmp_arr[] = $vv['order_id'];
- }
- $order_ids_tmp_str = implode(',', $order_ids_tmp_arr);
-
- $condition .= " and o.order_id in({$order_ids_tmp_str}) ";
- }
- else{
- $condition .= " and o.order_id in(0) ";
- }
- }
-
-
- if( !empty($searchtype) )
- {
- $condition .= " and o.type ='{$searchtype}' ";
- }
-
- if( !empty($delivery) )
- {
- $condition .= " and o.delivery ='{$delivery}' ";
- }
-
- if( !empty($head_id) && $head_id >0 )
- {
- $condition .= " and o.head_id ='{$head_id}' ";
-
- $count_where .= " and head_id ='{$head_id}' ";
- }
-
-
- if( $state >= 0 )
- {
- $condition .= " and ore.state ='{$state}' ";
- }
-
-
- if($order_status_id > 0)
- {
- if($order_status_id ==12 )
- {
- $condition .= " and (o.order_status_id={$order_status_id} or o.order_status_id=10 ) ";
- }else if($order_status_id ==11)
- {
- $condition .= " and (o.order_status_id={$order_status_id} or o.order_status_id=6 ) ";
- }
- else{
- $condition .= " and o.order_status_id={$order_status_id} ";
- }
-
-
- }
- if( $is_fenxiao == 1)
- {
- //分销订单
-
- $condition .= " and o.is_commission = 1 ";
- $count_where = " and is_commission = 1 ";
-
- }
-
- $keyword = I('request.keyword');
- if( !empty($searchfield) && !empty($keyword))
- {
- $keyword = trim($keyword);
-
- $keyword = htmlspecialchars_decode($keyword, ENT_QUOTES);
-
- switch($searchfield)
- {
- case 'ordersn':
- $condition .= ' AND locate("'.$keyword.'",o.order_num_alias)>0';
- break;
- case 'member':
- $condition .= ' AND (locate("'.$keyword.'",m.username)>0 or locate("'.$keyword.'",m.telephone)>0 or "'.$keyword.'"=o.member_id )';
- $sqlcondition .= ' left join ' . C('DB_PREFIX') . 'lionfish_comshop_member m on m.member_id = o.member_id ';
- break;
- case 'address':
- $condition .= ' AND ( locate("'.$keyword.'",o.shipping_name)>0 )';
- //shipping_address
- break;
- case 'mobile':
- $condition .= ' AND ( locate("'.$keyword.'",o.shipping_tel)>0 )';
- //shipping_address
- break;
- case 'location':
- $condition .= ' AND (locate("'.$keyword.'",o.shipping_address)>0 )';
- break;
- case 'shipping_no':
- $condition .= ' AND (locate("'.$keyword.'",o.shipping_no)>0 )';
- break;
-
- case 'head_address':
- $head_ids = M('lionfish_community_head')->field('id')->where( 'community_name like "%'.$keyword.'%"' )->select();
-
-
- if(!empty($head_ids))
- {
- $head_ids_arr = array();
- foreach($head_ids as $vv)
- {
- $head_ids_arr[] = $vv['id'];
- }
- $head_ids_str = implode(",",$head_ids_arr);
- $condition .= ' AND ( o.head_id in('.$head_ids_str.') )';
- }else{
- $condition .= " and o.order_id in(0) ";
- }
-
- break;
- case 'head_name':
- // SELECT * FROM `ims_lionfish_community_head` WHERE `head_name` LIKE '%黄%'
-
- $head_ids = M('lionfish_community_head')->field('id')->where( 'head_name like "%'.$keyword.'%"' )->select();
-
- if(!empty($head_ids))
- {
- $head_ids_arr = array();
- foreach($head_ids as $vv)
- {
- $head_ids_arr[] = $vv['id'];
- }
- $head_ids_str = implode(",",$head_ids_arr);
- $condition .= ' AND ( o.head_id in('.$head_ids_str.') )';
- }else{
-
- $condition .= " and o.order_id in(0) ";
-
- }
-
- break;
- case 'goodstitle':
- $sqlcondition = ' inner join ( select DISTINCT(og.order_id) from ' . C('DB_PREFIX').'lionfish_comshop_order_goods og where (locate("'.$keyword.'",og.name)>0)) gs on gs.order_id=o.order_id';
- //var_dump($sqlcondition);
- //die();
-
- break;
- case 'supply_name':
-
- $supply_name_sql = 'SELECT id FROM ' . C('DB_PREFIX').
- 'lionfish_comshop_supply where shopname like "%'.$keyword.'%"';
- $supply_ids = M()->query($supply_name_sql);
-
-
- if(!empty($supply_ids))
- {
- $supply_ids_arr = array();
- foreach($supply_ids as $vv)
- {
- $supply_ids_arr[] = $vv['id'];
- }
- $supply_ids_str = implode(",",$supply_ids_arr);
-
- $order_ids_list_tmp = M('lionfish_comshop_order_goods')->field('order_id')->where( "supply_id in ({$supply_ids_str})" )->select();
-
- if( !empty($order_ids_list_tmp) )
- {
- $order_ids_tmp_arr = array();
- foreach($order_ids_list_tmp as $vv)
- {
- $order_ids_tmp_arr[] = $vv['order_id'];
- }
- $order_ids_tmp_str = implode(',', $order_ids_tmp_arr);
-
- $condition .= " and o.order_id in({$order_ids_tmp_str}) ";
- }else{
- $condition .= " and o.order_id in(0) ";
- }
- }else{
- $condition .= " and o.order_id in(0) ";
- }
- break;
- case 'trans_id':
- $condition .= ' AND (locate('.$keyword.',o.transaction_id)>0 )';
- break;
-
- }
- }
-
- if( !empty($searchtime) )
- {
- switch( $searchtime )
- {
- case 'create':
- //下单时间 date_added
- $condition .= " and o.date_added>={$starttime} and o.date_added <= {$endtime}";
- break;
- case 'pay':
- //付款时间
- $condition .= " and o.pay_time>={$starttime} and o.pay_time <= {$endtime}";
- break;
- case 'send':
- //发货时间
- $condition .= " and o.express_time>={$starttime} and o.express_time <= {$endtime}";
- break;
- case 'finish':
- //完成时间
- $condition .= " and o.finishtime>={$starttime} and o.finishtime <= {$endtime}";
- break;
- }
- }
-
-
- if (defined('ROLE') && ROLE == 'agenter' ) {
-
- $supper_info = get_agent_logininfo();
-
-
- $total_where = " and supply_id= ".$supper_info['id'];
-
- $order_ids_list = M()->query("select og.order_id,og.total,og.shipping_fare,og.voucher_credit,og.fullreduction_money from ".
- C('DB_PREFIX')."lionfish_comshop_order_goods as og , ".C('DB_PREFIX')."lionfish_comshop_order as o where og.order_id =o.order_id and og.supply_id = ".$supper_info['id'] );
-
- $order_ids_arr = array();
- $order_ids_arr_dan = array();
-
- $total_money = 0;
- foreach($order_ids_list as $vv)
- {
- if( empty($order_ids_arr) || !isset($order_ids_arr[$vv['order_id']]) )
- {
- $order_ids_arr[$vv['order_id']] = $vv;
- $order_ids_arr_dan[] = $vv['order_id'];
- }
- }
-
- if( !empty($order_ids_arr_dan) )
- {
- $sql = 'SELECT count(o.order_id) as count FROM '.C('DB_PREFIX')."lionfish_comshop_order_refund as ore, " . C('DB_PREFIX'). 'lionfish_comshop_order as o
- '.$sqlcondition.' where ' . $condition." and ore.order_id = o.order_id and o.order_id in (".implode(',', $order_ids_arr_dan).") " ;
-
- $total_arr = M()->query($sql);
-
- $total = $total_arr[0]['count'];
-
-
- $order_ids_list = M()->query("select og.order_id,og.total,og.shipping_fare,og.voucher_credit,og.fullreduction_money
- from ".C('DB_PREFIX')."lionfish_comshop_order_goods as og , ".C('DB_PREFIX')."lionfish_comshop_order as o ,".C('DB_PREFIX')."lionfish_comshop_order_refund as ore
- where {$condition} and ore.order_id = o.order_id and og.order_id =o.order_id and og.supply_id = ".$supper_info['id']." ");
-
- if( !empty($order_ids_list) )
- {
- foreach($order_ids_list as $vv)
- {
- $total_money += $vv['total']+$vv['shipping_fare']-$vv['voucher_credit']-$vv['fullreduction_money'];
- }
- }
- }else{
- $total = 0;
- }
-
-
- }else{
-
- $sql = 'SELECT count(o.order_id) as count FROM '.C('DB_PREFIX')."lionfish_comshop_order_refund as ore,
- " . C('DB_PREFIX'). 'lionfish_comshop_order as o '.$sqlcondition.' where ore.order_id = o.order_id and ' . $condition ;
-
- $total_arr = M()->query($sql);
-
- $total = $total_arr[0]['count'];
-
-
-
- }
-
-
-
-
- $order_status_arr = $this->get_order_status_name();
-
- $export = I('request.export', 0);
-
-
- if ($export == 1)
- {
- $is_can_look_headinfo = true;
- $supply_can_look_headinfo = D('Home/Front')->get_config_by_name('supply_can_look_headinfo');
-
- if (defined('ROLE') && ROLE == 'agenter' )
- {
- if( isset($supply_can_look_headinfo) && $supply_can_look_headinfo == 2 )
- {
- $is_can_look_headinfo = false;
- }
- }
-
-
- @set_time_limit(0);
- $columns = array(
-
- array('title' => '订单编号', 'field' => 'order_num_alias', 'width' => 36),
- array('title' => '订单流水号', 'field' => 'day_paixu', 'width' => 24),
- array('title' => '昵称', 'field' => 'name', 'width' => 12),
- //array('title' => '会员姓名', 'field' => 'mrealname', 'width' => 12),
- array('title' => 'openid', 'field' => 'openid', 'width' => 24),
- array('title' => '会员手机号', 'field' => 'telephone', 'width' => 12),
- array('title' => '会员备注', 'field' => 'member_content', 'width' => 24),
-
- array('title' => '收货姓名(或自提人)', 'field' => 'shipping_name', 'width' => 12),
- array('title' => '联系电话', 'field' => 'shipping_tel', 'width' => 12),
- array('title' => '收货地址', 'field' => 'address_province', 'width' => 12),
- array('title' => '', 'field' => 'address_city', 'width' => 12),
- array('title' => '', 'field' => 'address_area', 'width' => 12),
- //array('title' => '', 'field' => 'address_street', 'width' => 12),
- array('title' => '提货详细地址', 'field' => 'address_address', 'width' => 12),
- array('title' => '团长配送送货详细地址', 'field' => 'tuan_send_address', 'width' => 22),
- array('title' => '商品名称', 'field' => 'goods_title', 'width' => 24),
- array('title' => '商品编码', 'field' => 'goods_goodssn', 'width' => 12),
- array('title' => '商品规格', 'field' => 'goods_optiontitle', 'width' => 12),
- array('title' => '商品数量', 'field' => 'quantity', 'width' => 12),
- array('title' => '商品单价', 'field' => 'goods_price1', 'width' => 12),
- //array('title' => '商品单价(折扣后)', 'field' => 'goods_price2', 'width' => 12),
- //array('title' => '商品价格(折扣前)', 'field' => 'goods_rprice1', 'width' => 12),
- array('title' => '商品价格', 'field' => 'goods_rprice2', 'width' => 12),
- array('title' => '支付方式', 'field' => 'paytype', 'width' => 12),
- array('title' => '配送方式', 'field' => 'delivery', 'width' => 12),
- array('title' => '预计送达时间', 'field' => 'expected_delivery_time', 'width' => 24),
-
- //array('title' => '自提门店', 'field' => 'pickname', 'width' => 24),
- //array('title' => '商品小计', 'field' => 'goodsprice', 'width' => 12),
- array('title' => '运费', 'field' => 'dispatchprice', 'width' => 12),
- array('title' => '积分抵扣', 'field' => 'score_for_money', 'width' => 12),
- //array('title' => '余额抵扣', 'field' => 'deductcredit2', 'width' => 12),
- array('title' => '满额立减', 'field' => 'fullreduction_money', 'width' => 12),
- array('title' => '优惠券优惠', 'field' => 'voucher_credit', 'width' => 12),
- //array('title' => '订单改价', 'field' => 'changeprice', 'width' => 12),
- //array('title' => '运费改价', 'field' => 'changedispatchprice', 'width' => 12),
- array('title' => '应收款(该笔订单总款)', 'field' => 'price', 'width' => 12),
- array('title' => '状态', 'field' => 'status', 'width' => 12),
- array('title' => '团长佣金', 'field' => 'head_money', 'width' => 12),
- array('title' => '下单时间', 'field' => 'createtime', 'width' => 24),
- array('title' => '付款时间', 'field' => 'paytime', 'width' => 24),
- array('title' => '发货时间', 'field' => 'sendtime', 'width' => 24),
- array('title' => '完成时间', 'field' => 'finishtime', 'width' => 24),
- array('title' => '快递公司', 'field' => 'expresscom', 'width' => 24),
- array('title' => '快递单号', 'field' => 'expresssn', 'width' => 24),
-
- array('title' => '小区名称', 'field' => 'community_name', 'width' => 12),
- array('title' => '团长姓名', 'field' => 'head_name', 'width' => 12),
- array('title' => '团长电话', 'field' => 'head_mobile', 'width' => 12),
- array('title' => '完整地址', 'field' => 'fullAddress', 'width' => 24),
-
-
- array('title' => '订单备注', 'field' => 'remark', 'width' => 36),
- array('title' => '卖家订单备注', 'field' => 'remarksaler', 'width' => 36),
- //array('title' => '核销员', 'field' => 'salerinfo', 'width' => 24),
- //array('title' => '核销门店', 'field' => 'storeinfo', 'width' => 36),
- //array('title' => '订单自定义信息', 'field' => 'order_diyformdata', 'width' => 36),
- //array('title' => '商品自定义信息', 'field' => 'goods_diyformdata', 'width' => 36)
- );
- $exportlist = array();
-
-
- set_time_limit(0);
-
- $fileName = date('YmdHis', time());
- header('Content-Type: application/vnd.ms-execl');
- header('Content-Disposition: attachment;filename="退款订单数据' . $fileName . '.csv"');
- $begin = microtime(true);
-
- $fp = fopen('php://output', 'a');
-
- $step = 100;
- $nums = 10000;
-
- //设置标题
- //$title = array('ID', '用户名', '用户年龄', '用户描述', '用户手机', '用户QQ', '用户邮箱', '用户地址');
-
- $title = array();
-
- foreach($columns as $key => $item) {
- $title[$item['field']] = iconv('UTF-8', 'GBK', $item['title']);
- }
- fputcsv($fp, $title);
-
-
- $sql_count = 'SELECT count(o.order_id) as count FROM '.C('DB_PREFIX')."lionfish_comshop_order_refund as ore, "
- . C('DB_PREFIX'). 'lionfish_comshop_order as o '.$sqlcondition.' where ore.order_id = o.order_id and '
- . $condition . ' ORDER BY ore.`ref_id` DESC ';
-
- $total_arr = M()->query($sql_count);
-
- $total = $total_arr[0]['count'];
-
- $sqlcondition .= ' left join ' .C('DB_PREFIX') . 'lionfish_comshop_order_goods ogc on ogc.order_id = o.order_id ';
-
-
- $page = ceil($total / 500);
-
-
- if (!(empty($total))) {
-
- //searchfield goodstitle goods_goodssn
-
- for($s = 1; $s <= $page; $s++) {
-
- $offset = ($s-1)* 500;
-
- $sql = 'SELECT o.*,ogc.name as goods_title,ogc.supply_id,ogc.order_goods_id ,ogc.quantity as ogc_quantity,ogc.price,ogc.model as model,
- ogc.total as goods_total ,ogc.score_for_money as g_score_for_money,ogc.fullreduction_money as g_fullreduction_money,ogc.voucher_credit as g_voucher_credit ,ogc.shipping_fare as g_shipping_fare FROM '.C('DB_PREFIX').
- "lionfish_comshop_order_refund as ore, " . C('DB_PREFIX'). 'lionfish_comshop_order as o '.$sqlcondition.' where ore.order_id = o.order_id and ' .
- $condition . ' ORDER BY ore.`ref_id` DESC limit ' . "{$offset}, 500";
-
- $list = M()->query($sql);
-
-
-
-
- $look_member_arr = array();
- $area_arr = array();
-
- foreach($list as $val)
- {
- if (defined('ROLE') && ROLE == 'agenter' )
- {
- $supper_info = get_agent_logininfo();
- if($supper_info['id'] != $val['supply_id'])
- {
- continue;
- }
- }
-
-
- if( empty($look_member_arr) || !isset($look_member_arr[$val['member_id']]) )
- {
- $member_info = M('lionfish_comshop_member')->where( array('member_id' => $val['member_id']) )->find();
-
- $look_member_arr[$val['member_id']] = $member_info;
- }
- $tmp_exval= array();
- $tmp_exval['order_num_alias'] = $val['order_num_alias']."\t";
- $tmp_exval['day_paixu'] = $val['day_paixu'];
-
-
- $tmp_exval['name'] = $look_member_arr[$val['member_id']]['username'];
- //from_type
- if($val['from_type'] == 'wepro')
- {
- $tmp_exval['openid'] = $look_member_arr[$val['member_id']]['we_openid'];
- }else{
- $tmp_exval['openid'] = $look_member_arr[$val['member_id']]['openid'];
- }
- $tmp_exval['telephone'] = $look_member_arr[$val['member_id']]['telephone'];
- $tmp_exval['member_content'] = $look_member_arr[$val['member_id']]['content'];
-
- $tmp_exval['shipping_name'] = $val['shipping_name'];
- $tmp_exval['shipping_tel'] = $val['shipping_tel'];
-
- //area_arr
- if( empty($area_arr) || !isset($area_arr[$val['shipping_province_id']]) )
- {
- $area_arr[$val['shipping_province_id']] = D('Seller/Front')->get_area_info($val['shipping_province_id']);
- }
-
- if( empty($area_arr) || !isset($area_arr[$val['shipping_city_id']]) )
- {
- $area_arr[$val['shipping_city_id']] = D('Seller/Front')->get_area_info($val['shipping_city_id']);
- }
-
- if( empty($area_arr) || !isset($area_arr[$val['shipping_country_id']]) )
- {
- $area_arr[$val['shipping_country_id']] = D('Seller/Front')->get_area_info($val['shipping_country_id']);
- }
-
- $province_info = $area_arr[$val['shipping_province_id']];
- $city_info = $area_arr[$val['shipping_city_id']];
- $area_info = $area_arr[$val['shipping_country_id']];
-
- $tmp_exval['address_province'] = $province_info['name'];
- $tmp_exval['address_city'] = $city_info['name'];
- $tmp_exval['address_area'] = $area_info['name'];
- $tmp_exval['goods_goodssn'] = $val['model'];
-
-
- $tmp_exval['address_address'] = $val['shipping_address'];
-
- if( $val['delivery'] == 'tuanz_send'){
- //$tmp_exval['address_address'] = $val['tuan_send_address'];
- }
- $tmp_exval['tuan_send_address'] = $val['tuan_send_address'];
-
- $tmp_exval['goods_title'] = htmlspecialchars_decode(stripslashes($val['goods_title']));
- $goods_optiontitle = $this->get_order_option_sku($val['order_id'], $val['order_goods_id']);
- $tmp_exval['goods_optiontitle'] = $goods_optiontitle;
- $tmp_exval['quantity'] = $val['ogc_quantity'];
- $tmp_exval['goods_price1'] = $val['price'];
- $tmp_exval['goods_rprice2'] = $val['goods_total'];
-
- $paytype = $val['payment_code'];
- switch($paytype)
- {
- case 'admin':
- $paytype='后台支付';
- break;
- case 'yuer':
- $paytype='余额支付';
- break;
- case 'weixin':
- $paytype='微信支付';
- break;
- default:
- $paytype = '未支付';
- }
-
- $community_info = D('Seller/Front')->get_community_byid($val['head_id']);
-
-
- $tmp_exval['community_name'] = $community_info['communityName'];
-
- if($is_can_look_headinfo){
- $tmp_exval['fullAddress'] = $community_info['fullAddress'];
- $tmp_exval['head_name'] = $community_info['disUserName'];
- $tmp_exval['head_mobile'] = $community_info['head_mobile'];
- }else{
- $tmp_exval['fullAddress'] = '';
- $tmp_exval['head_name'] = '';
- $tmp_exval['head_mobile'] = '';
- }
-
-
- $tmp_exval['paytype'] = $paytype;
-
- if($val['delivery'] == 'express'){
- $tmp_exval['delivery'] = '快递';
- }elseif($val['delivery'] == 'pickup'){
- $tmp_exval['delivery'] = '自提';
- }elseif($val['delivery'] == 'tuanz_send'){
- $tmp_exval['delivery'] = '团长配送';
- }
-
- $tmp_exval['expected_delivery_time'] =$val['expected_delivery_time']; //date("Y-m-d H:i:s",time())
- $tmp_exval['dispatchprice'] = $val['g_shipping_fare'];
- $tmp_exval['score_for_money'] = $val['g_score_for_money'];
-
-
- $tmp_exval['fullreduction_money'] = $val['g_fullreduction_money'];
- $tmp_exval['voucher_credit'] = $val['g_voucher_credit'];
-
-
-
- $tmp_exval['changeprice'] = $val['changedtotal'];
- $tmp_exval['changedispatchprice'] = $val['changedshipping_fare'];
-
-
- $val['total'] = $val['goods_total']+$val['g_shipping_fare']-$val['g_score_for_money']-$val['g_fullreduction_money'] - $val['g_voucher_credit'];
-
-
- if($val['total'] < 0)
- {
- $val['total'] = 0;
- }
-
-
- $tmp_exval['price'] = $val['total'];
-
-
- $tmp_exval['head_money'] = 0;
-
-
- $head_commiss_order = M('lionfish_community_head_commiss_order')->where( array('order_id' => $val['order_id'],'order_goods_id' => $val['order_goods_id']) )->find();
-
- if( !empty($head_commiss_order) )
- {
- $tmp_exval['head_money'] = $head_commiss_order['money'];
- }
-
-
-
-
- $tmp_exval['status'] = $order_status_arr[$val['order_status_id']];
-
- $tmp_exval['createtime'] = date('Y-m-d H:i:s', $val['date_added']);
-
-
- $tmp_exval['paytime'] = empty($val['pay_time']) ? '' : date('Y-m-d H:i:s', $val['pay_time']);
- $tmp_exval['sendtime'] = empty($val['express_time']) ? '': date('Y-m-d H:i:s', $val['express_time']);
- $tmp_exval['finishtime'] = empty($val['finishtime']) ? '' : date('Y-m-d H:i:s', $val['finishtime']);
-
-
- $tmp_exval['expresscom'] = $val['dispatchname'];
- $tmp_exval['expresssn'] = $val['shipping_no'];
- $tmp_exval['remark'] = $val['comment'];
- $tmp_exval['remarksaler'] = $val['remarksaler'];
-
- $exportlist[] = $tmp_exval;
-
- $row_arr = array();
-
- foreach($columns as $key => $item) {
-
- $row_arr[$item['field']] = iconv('UTF-8', 'GBK//IGNORE', $tmp_exval[$item['field']]);
- }
-
- fputcsv($fp, $row_arr);
- }
-
- ob_flush();
- flush();
-
- unset($list);
- }
-
- die();
- // dump($exportlist);die;
- //D('Seller/Excel')->export($exportlist, array('title' => '订单数据', 'columns' => $columns));
- }
-
- }
-
- if (!(empty($total))) {
-
- $sql = 'SELECT ore.ref_id, ore.order_goods_id,ore.state as ore_state, o.* FROM '.
- C('DB_PREFIX')."lionfish_comshop_order_refund as ore, " . C('DB_PREFIX') . 'lionfish_comshop_order as o '.
- $sqlcondition.' where ore.order_id = o.order_id and ' . $condition .
- ' ORDER BY ore.`ref_id` DESC LIMIT ' . (($pindex - 1) * $psize) . ',' . $psize;
-
- $list = M()->query($sql);
- $need_list = array();
- foreach ($list as $key => &$value ) {
-
- $sql_goods = "select og.* from ".C('DB_PREFIX')."lionfish_comshop_order_goods as og
- where og.order_id = {$value[order_id]} ";
- if( !empty($value['order_goods_id']) && $value['order_goods_id'] > 0 )
- {
- $sql_goods = "select og.* from ".C('DB_PREFIX')."lionfish_comshop_order_goods as og
- where og.order_goods_id = ".$value['order_goods_id']." and og.order_id = {$value[order_id]} ";
- }
-
- $goods = M()->query($sql_goods);
-
-
- $need_goods = array();
-
- $shipping_fare = 0;
- $fullreduction_money = 0;
- $voucher_credit = 0;
- $totals = 0;
-
-
- //ref_id
-
- $refund_disable = M('lionfish_comshop_order_refund_disable')->where( array('ref_id' => $value['ref_id'] ) )->find();
-
- if( !empty($refund_disable) )
- {
-
- $value['is_forbidden'] = 1;
- }else{
- $value['is_forbidden'] = 0;
- }
-
-
- foreach($goods as $key =>$goods_val)
- {
- $goods_val['name'] = htmlspecialchars_decode(stripslashes($goods_val['name']));
- $goods_val['option_sku'] = $this->get_order_option_sku($value['order_id'], $goods_val['order_goods_id']);
-
- $goods_val['commisson_info'] = array();
-
- if (defined('ROLE') && ROLE == 'agenter' )
- {
- $supper_info = get_agent_logininfo();
-
- if($supper_info['id'] != $goods_val['supply_id'])
- {
- continue;
- }
- }
- $shipping_fare += $goods_val['shipping_fare'];
- $fullreduction_money += $goods_val['fullreduction_money'];
- $voucher_credit += $goods_val['voucher_credit'];
- $totals += $goods_val['total'];
-
- $need_goods[$key] = $goods_val;
- }
-
- //if( $_W['role'] == 'agenter' )
- //{
- $value['shipping_fare'] = $shipping_fare;
- $value['fullreduction_money'] = $fullreduction_money;
- $value['voucher_credit'] = $voucher_credit;
- $value['total'] = $totals;
- // }
- //member_id ims_ nickname
-
- $nickname_row = M('lionfish_comshop_member')->field('username as nickname,content')->where( array('member_id' =>$value['member_id'] ) )->find();
-
- $value['nickname'] = $nickname_row['nickname'];
- $value['member_content'] = $nickname_row['content'];
-
-
- $value['goods'] = $need_goods;
-
- $community_info = D('Seller/Front')->get_community_byid($value['head_id']);
-
-
-
-
- $value['community_name'] = $community_info['communityName'];
- $value['head_name'] = $community_info['disUserName'];
- $value['head_mobile'] = $community_info['head_mobile'];
-
- if (defined('ROLE') && ROLE == 'agenter' )
- {
- $supply_can_look_headinfo = D('Home/Front')->get_config_by_name('supply_can_look_headinfo');
- if($supply_can_look_headinfo != 1){
- $value['community_name'] = D('Seller/Order')->desensitize($community_info['communityName'],0,-1);
- $value['head_name'] = D('Seller/Order')->desensitize($community_info['disUserName'],1,1);
- $value['head_mobile'] = D('Seller/Order')->desensitize($community_info['head_mobile'],3,4);
- }
- }
-
-
- $value['province'] = $community_info['province'];
- $value['city'] = $community_info['city'];
-
-
- }
- $pager = pagination2($total, $pindex, $psize);
- }
-
- //get_order_count($where = '',$uniacid = 0)
-
- if( !empty($searchtype) )
- {
- $count_where = " and type = '{$searchtype}' ";
- }
-
- if (defined('ROLE') && ROLE == 'agenter' )
- {
-
- $supper_info = get_agent_logininfo();
-
- $order_ids_list = M()->query("select og.order_id,og.total,og.shipping_fare,og.voucher_credit,og.fullreduction_money from ".C('DB_PREFIX').
- "lionfish_comshop_order_goods as og , ".C('DB_PREFIX')."lionfish_comshop_order as o where og.order_id =o.order_id and og.supply_id = ".$supper_info['id']." ");
- $order_ids_arr = array();
-
- $seven_refund_money= 0;
-
- foreach($order_ids_list as $vv)
- {
- if( empty($order_ids_arr) || !isset($order_ids_arr[$vv['order_id']]) )
- {
- $order_ids_arr[$vv['order_id']] = $vv['order_id'];
- }
- }
- if( !empty($order_ids_arr) )
- {
- $count_where .= " and order_id in (".implode(',', $order_ids_arr).")";
- }else{
- $count_where .= " and order_id in (0)";
- }
-
- }
-
- $all_count = $this->get_order_count($count_where);
- $count_status_1 = $this->get_order_count(" {$count_where} and order_status_id = 1 ");
- $count_status_3 = $this->get_order_count(" {$count_where} and order_status_id = 3 ");
- $count_status_4 = $this->get_order_count(" {$count_where} and order_status_id = 4 ");
- $count_status_5 = $this->get_order_count(" {$count_where} and order_status_id = 5 ");
- $count_status_7 = $this->get_order_count(" {$count_where} and order_status_id = 7 ");
- $count_status_11 = $this->get_order_count(" {$count_where} and (order_status_id = 11 or order_status_id = 6) ");
- $count_status_14 = $this->get_order_count(" {$count_where} and order_status_id = 14 ");
-
-
- return array('total' => $total, 'total_money' => $total_money,'pager' => $pager, 'all_count' => $all_count,
- 'list' =>$list,
- 'count_status_1' => $count_status_1,'count_status_3' => $count_status_3,'count_status_4' => $count_status_4,
- 'count_status_5' => $count_status_5, 'count_status_7' => $count_status_7, 'count_status_11' => $count_status_11,
- 'count_status_14' => $count_status_14
- );
- }
-
-
- //---copy end
- /**
- * @param $order_id
- * @param int $is_supply 1、供应商手机付款,0、后台付款
- * @return array
- */
- public function admin_pay_order($order_id,$is_supply = 0)
- {
- $order = M('lionfish_comshop_order')->where( array('order_id' => $order_id) )->find();
-
-
- $member_id = $order['member_id'];
- //支付才减库存,才需要判断
- $kucun_method = D('Home/Front')->get_config_by_name('kucun_method');
-
- if( empty($kucun_method) )
- {
- $kucun_method = 0;
- }
-
- $error_msg = '';
-
- if($kucun_method == 1)
- {
- /*** 检测商品库存begin **/
- $order_goods_list = M('lionfish_comshop_order_goods')->where( array('order_id' => $order['order_id'] ) )->select();
-
- //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);
-
-
- //TODO.这里有问题
- $goods_description = D('Home/Front')->get_goods_common_field($goods_id , 'total_limit_count');
-
- if($can_buy_count == -1)
- {
- $error_msg = '每人最多购买'.$goods_description['total_limit_count'].'个哦';
- }else if($can_buy_count >0 && $quantity >$can_buy_count)
- {
- $error_msg = '您还能购买'.$can_buy_count.'份';
- }
-
- $goods_quantity= D('Home/Car')->get_goods_quantity($goods_id);
-
- if($goods_quantity<$quantity){
-
- if ($goods_quantity==0) {
- $error_msg ='已抢光';
- }else{
- $error_msg ='商品数量不足,剩余'.$goods_quantity.'个!!';
- }
- }
-
- //rela_goodsoption_valueid
- if(!empty($val['rela_goodsoption_valueid']))
- {
- $mul_opt_arr = array();
-
- $goods_option_mult_value = M('lionfish_comshop_goods_option_item_value')->where( array('option_item_ids' => $val['rela_goodsoption_valueid'],'goods_id' => $goods_id) )->find();
-
- if( !empty($goods_option_mult_value) )
- {
- if($goods_option_mult_value['stock']<$quantity){
-
- $error_msg = '商品数量不足,剩余'.$goods_option_mult_value['stock'].'个!!';
- }
- }
- }
-
- }
- /*** 检测商品库存end **/
- }
- if( !empty($error_msg) )
- {
- return array('code' => 0,'msg' => $error_msg);
- }else{
- if( $order && $order['order_status_id'] == 3)
- {
- $o = array();
- if($is_supply == 1){
- $o['payment_code'] = 'supply_mobile';
- $o['transaction_id'] = '供应商手机付款';
- }else{
- $o['payment_code'] = 'admin';
- $o['transaction_id'] ='后台付款';
- }
- $o['order_id']=$order['order_id'];
- $o['order_status_id'] = $order['is_pin'] == 1 ? 2:1;
- $o['date_modified']=time();
- $o['pay_time']=time();
- if($order['delivery'] == 'hexiao'){//核销订单 支付完成状态改成 已发货待收货
- $o['order_status_id'] = 4;
- }
-
- //ims_
- M('lionfish_comshop_order')->where( array('order_id' => $order['order_id']) )->save($o);
-
-
-
- $kucun_method = D('Home/Front')->get_config_by_name('kucun_method', $_W['uniacid']);
-
- if( empty($kucun_method) )
- {
- $kucun_method = 0;
- }
-
- if($kucun_method == 1)
- {//支付完减库存,增加销量
-
- $order_goods_list = M('lionfish_comshop_order_goods')->where( array('order_id' => $order['order_id']) )->select();
-
- foreach($order_goods_list as $order_goods)
- {
- D('Home/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['order_id']=$order['order_id'];
- $oh['order_status_id']= $order['is_pin'] == 1 ? 2:1;
- if($is_supply == 1){
- $oh['comment']='供应商手机端付款';
- }else{
- $oh['comment']='后台付款';
- }
- $oh['date_added']=time();
- $oh['notify']=1;
-
- M('lionfish_comshop_order_history')->add($oh);
-
- D('Home/Weixinnotify')->orderBuy($order['order_id'],true);
-
- //发送购买通知
- //TODO 先屏蔽,等待调试这个消息
- //$weixin_nofity = D('Home/Weixinnotify');
- //$weixin_nofity->orderBuy($order['order_id']);
- if($order['type'] == 'pintuan'){
- $pin_order = M('lionfish_comshop_pin_order')->where( array('order_id' => $order['order_id']) )->find();
- $pin_id = $pin_order['pin_id'];
- $pin_model = D('Home/Pin');
- $is_pin_success = $pin_model->checkPinSuccess($pin_id);
- if($is_pin_success) {
- //todo send pintuan success notify
- $pin_model->updatePintuanSuccess($pin_id);
- }
- }
- return array('code' => 1);
- }
- }
-
-
- }
-
- public function admin_pay_order2($order_id)
- {
-
-
- $order = M('lionfish_comshop_order')->where( array('order_id' => $order_id) )->find();
-
-
- if( $order && $order['order_status_id'] == 3)
- {
- $o = array();
- $o['payment_code'] = 'admin';
- $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_
- M('lionfish_comshop_order')->where( array('order_id' => $order['order_id']) )->save($o);
-
-
- //暂时屏蔽
- //$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 = M('lionfish_comshop_order_goods')->where( array('order_id' => $order['order_id']) )->select();
-
- foreach($order_goods_list as $order_goods)
- {
- D('Home/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['order_id']=$order['order_id'];
- $oh['order_status_id']= $order['is_pin'] == 1 ? 2:1;
- $oh['comment']='后台付款';
- $oh['date_added']=time();
- $oh['notify']=1;
-
- M('lionfish_comshop_order_history')->add($oh);
-
-
- //发送购买通知
- //TODO 先屏蔽,等待调试这个消息
- //$weixin_nofity = D('Home/Weixinnotify');
- //$weixin_nofity->orderBuy($order['order_id']);
-
-
- }
- }
- //检查订单是否能确认收货(存在售后未完成无法确认收货)
- public function check_order_receive($order_id){
- $result = array();
- $status = 1;//1、可以确认收货,0、不能确认收货
- $sql_goods = "select og.* from ".C('DB_PREFIX')."lionfish_comshop_order_goods as og
- where og.order_id = {$order_id} ";
- $goods = M()->query($sql_goods);
- foreach($goods as $key =>$goods_val)
- {
- if( $goods_val['is_refund_state'] == 1 )
- {
- $refund_info = M('lionfish_comshop_order_refund')->field('state')->where( array('order_id' => $order_id ,'order_goods_id' => $goods_val['order_goods_id']) )->find();
- if(!empty($refund_info)){
- if($refund_info['state'] == 0 || $refund_info['state'] == 2){
- $status = 0;
- break;
- }
- }
- }
- }
- $result['status'] = $status;
- return $result;
- }
- //检查订单是否能确认收货(同城配送订单) 该订单未有配送员接单或还未指定配送员,无法确认收货
- public function check_localtown_order_receive($order_id){
- $result = array();
- $status = 1;//1、可以确认收货,0、不能确认收货
- $order_distribution = M('lionfish_comshop_orderdistribution_order')->where( array('order_id' => $order_id) )->find();
- if(empty($order_distribution['orderdistribution_id']) && ($order_distribution['state'] == 1 || $order_distribution['state'] == 0)){
- $status = 0;
- }
- if(empty($order_distribution['third_distribution_type']) && ($order_distribution['state'] == 1 || $order_distribution['state'] == 0)){
- $status = 0;
- }
- $result['status'] = $status;
- return $result;
- }
-
-
- public function receive_order($order_id)
- {
-
- M('lionfish_comshop_order')->where( array('order_id' => $order_id) )->save( array('order_status_id' => 6, 'receive_time' => time()) );
-
- D('Home/Frontorder')->receive_order($order_id);
-
- }
-
- /**
- 获取订单规格值
- **/
- public function get_order_option_sku($order_id, $order_goods_id)
- {
- $option_list = M('lionfish_comshop_order_option')->field('name,value')->where( array('order_goods_id' => $order_goods_id,'order_id' => $order_id) )->select();
-
- $sku_str = "";
-
- if( !empty($option_list) )
- {
- $tmp_arr = array();
- foreach($option_list as $val)
- {
- $tmp_arr[] = $val['name'].",".$val['value'];
- }
- $sku_str = implode(' ', $tmp_arr);
- }
- return $sku_str;
- }
- /**
- 获取订单商品重量
- **/
- public function get_order_option_weight($order_id, $order_goods_id)
- {
- $weight_str = "";
- $order_goods_info = M('lionfish_comshop_order_goods')->field('goods_id,rela_goodsoption_valueid')->where( array('order_goods_id' => $order_goods_id,'order_id' => $order_id) )->find();
- if(!empty($order_goods_info) && !empty($order_goods_info['rela_goodsoption_valueid'])){
- $godos_option_info = M('lionfish_comshop_goods_option_item_value')->field('goods_id,weight')->where( array('goods_id' => $order_goods_info['goods_id'],'option_item_ids' => $order_goods_info['rela_goodsoption_valueid']) )->find();
- if(!empty($godos_option_info) && !empty($godos_option_info['weight'])){
- $weight_str = $godos_option_info['weight'];
- }
- }else{
- $goods_info = M('lionfish_comshop_goods')->field('id,weight')->where( array('id' => $order_goods_info['goods_id']) )->find();
- if(!empty($goods_info) && !empty($goods_info['weight'])){
- $weight_str = $goods_info['weight'];
- }
- }
- return $weight_str;
- }
-
- public function get_order_status_name()
- {
-
- $data = S('order_status_name');
-
- if (empty($data)) {
-
- $all_list = M('lionfish_comshop_order_status')->select();
- if (empty($all_list)) {
- $data = array();
- }else{
- $data = array();
- foreach($all_list as $val)
- {
- $data[$val['order_status_id']] = $val['name'];
- }
- }
- S('order_status_name', $data);
- }
- return $data;
- }
-
- /**
- 获取商品数量
- **/
- public function get_order_count($where = '')
- {
- //begin 预售
- if( isset($_GET['presale_order']) && $_GET['presale_order'] == 1 )
- {
- $sql = "select count(1) as count from ".C('DB_PREFIX')."lionfish_comshop_order inner join ".C('DB_PREFIX').'lionfish_comshop_order_presale opr on '.C("DB_PREFIX").'lionfish_comshop_order.order_id =opr.order_id ';
- $sql .= " where 1 {$where} ";
- $count_arr = M()->query( $sql );
- $total = $count_arr[0]['count'];
- }else if( isset($_GET['virtualcard_order']) && $_GET['virtualcard_order'] == 1 )
- {
- //礼品卡订单
- $sql = "select count(1) as count from ".C('DB_PREFIX')."lionfish_comshop_order inner join ".C('DB_PREFIX').'lionfish_comshop_order_virtualcard vco on '.C("DB_PREFIX").'lionfish_comshop_order.order_id =vco.order_id ';
- $sql .= " where 1 {$where} ";
- $count_arr = M()->query( $sql );
- $total = $count_arr[0]['count'];
- }
- else{
- $total = M('lionfish_comshop_order')->where("1 ".$where)->count();
- }
- //end 预售
-
- return $total;
- }
-
- public function get_wait_shen_order_comment()
- {
- $total = M('lionfish_comshop_order_comment')->where( array('state' => 0, 'type' =>0) )->count();
-
- return $total;
- }
- /**
- 获取商品数量
- **/
- public function get_order_sum($field=' sum(total) as total ' , $where = '',$uniacid = 0)
- {
-
- $info = M('lionfish_comshop_order')->field($field)->where("1 ".$where )->find();
-
- return $info;
- }
-
- /**
-
- **/
- public function get_order_goods_group_paihang($where = '',$uniacid = 0)
- {
-
- //total
- //SELECT name , sum(`quantity`) as total_quantity , goods_id FROM `ims_lionfish_comshop_order_goods` GROUP by goods_id order by total_quantity desc
- $sql ="SELECT name , sum(`quantity`) as total_quantity, sum(`total`) as m_total , goods_id FROM ".
- C('DB_PREFIX') ."lionfish_comshop_order_goods where 1 {$where} GROUP by goods_id
- order by total_quantity desc limit 10 ";
- $list = M()->query($sql);
-
-
- return $list;
- }
-
- public function goods_express()
- {
- $_GPC = I('request.');
- $order_id = $_GPC['order_id'];// I('get.order_id',0);
-
- $order_info = M('lionfish_comshop_order')->where( array('order_id' => $order_id ) )->find();
-
- $now_time = time();
- if($now_time - $order_info['shipping_cha_time'] >= 43200 || true)
- {
- //即时查询接口
-
- $seller_express = M('lionfish_comshop_express')->where( array('id' => $order_info['shipping_method'] ) )->find();
-
-
- if(!empty($seller_express['simplecode']))
- {
- //887406591556327434 YTO
- //TODO...
- $ebuss_info = D('Home/Front')->get_config_by_name('kdniao_id');
- $exappkey = D('Home/Front')->get_config_by_name('kdniao_api_key');
-
- $req_url = "http://api.kdniao.com/Ebusiness/EbusinessOrderHandle.aspx";
- //shipping_tel
- if($seller_express['simplecode'] == 'SF'){
-
- $shipping_tel = substr($order_info['shipping_tel'],-4);
- $requestData= "{'OrderCode':'".$order_id."','ShipperCode':'".$seller_express['simplecode']."','CustomerName':'".$shipping_tel."','LogisticCode':'". $order_info['shipping_no']."'}";
- }else{
-
- $requestData= "{'OrderCode':'".$order_id."','ShipperCode':'".$seller_express['simplecode']."','LogisticCode':'". $order_info['shipping_no']."'}";
-
- }
- $customerName = $order_info['shipping_tel'];
- $customerName = substr($customerName,7);
- $datas = array(
- 'EBusinessID' => $ebuss_info,
- 'RequestType' => '1002',
- 'RequestData' => urlencode($requestData) ,
- 'DataType' => '2',
- 'CustomerName'=>$customerName
- );
-
- $kdniao_freestatus = D('Home/Front')->get_config_by_name('kdniao_freestatus');
-
- if( isset($kdniao_freestatus) && $kdniao_freestatus ==1 )
- {
- $datas['RequestType'] = '8001';
- //$datas['RequestType'] = '8002';
- }
- if($kdniao_freestatus == 0 ){
- //申通、中通、圆通
- if($seller_express['simplecode'] !='STO' && $seller_express['simplecode'] !='ZTO' && $seller_express['simplecode'] !='YTO' ){
-
- $order_express = array('code' => 2, 'Reason' => "物流接口(快递鸟)-'免费模式'只支持查询申通、中通、圆通物流轨迹");
- return $order_express;
- }
- }
-
- $datas['DataSign'] = $this->encrypt($requestData, $exappkey);
- $result_old=$this->sendPost($req_url, $datas);
-
- $result = json_decode($result_old);
-
- //array(8) { ["LogisticCode"]=> string(14) "75395511326146" ["ShipperCode"]=> string(3) "ZTO" ["Traces"]=> array(0) { } ["State"]=> string(1) "0" ["OrderCode"]=> string(4) "5884" ["EBusinessID"]=> string(7) "1636513" ["Reason"]=> string(50) "业务错误[不支持当前快递公司的查询]" ["Success"]=> bool(false) }
- $result2 = json_decode($result_old,true);
- if($result2["Success"] == false){
- $order_express = array('code' => 2, 'Reason' => $result2["Reason"]);
- return $order_express;
- }
- //根据公司业务处理返回的信息......
- //Traces
- if(!empty($result->Traces))
- {
- $order_info['shipping_traces'] = serialize($result->Traces);
- $up_data = array('shipping_cha_time' => time(), 'shipping_traces' => $order_info['shipping_traces']);
- M('lionfish_comshop_order')->where( array('order_id' => $order_id ) )->save( $up_data );
- }else{
-
- $order_express = array('code' => 2, 'Reason' => $result2["Reason"]);
- return $order_express;
- }
- }
- }
- //ims_
-
- $order_goods = M('lionfish_comshop_order_goods')->where( array('order_id' => $order_id ) )->find();
-
- $goods_info = array();
- $goods_info = D('Home/Pingoods')->get_goods_images($order_goods['goods_id']);
-
-
- $goods_info['image'] = tomedia($goods_info['image']);
-
- $seller_express = M('lionfish_comshop_express')->where( array('id' => $order_info['shipping_method'] ) )->find();
-
- $order_info['shipping_traces'] = unserialize($order_info['shipping_traces']) ;
- $order_express = array('code' => 0, 'seller_express' => $seller_express, 'goods_info' => $goods_info, 'order_info' => $order_info);
- return $order_express;
- }
-
- function encrypt($data, $appkey) {
- return urlencode(base64_encode(md5($data.$appkey)));
- }
-
- function sendPost($url, $datas) {
- $temps = array();
- foreach ($datas as $key => $value) {
- $temps[] = sprintf('%s=%s', $key, $value);
- }
- $post_data = implode('&', $temps);
- $url_info = parse_url($url);
- if(empty($url_info['port']))
- {
- $url_info['port']=80;
- }
- $httpheader = "POST " . $url_info['path'] . " HTTP/1.0\r\n";
- $httpheader.= "Host:" . $url_info['host'] . "\r\n";
- $httpheader.= "Content-Type:application/x-www-form-urlencoded\r\n";
- $httpheader.= "Content-Length:" . strlen($post_data) . "\r\n";
- $httpheader.= "Connection:close\r\n\r\n";
- $httpheader.= $post_data;
- $fd = fsockopen($url_info['host'], $url_info['port']);
- fwrite($fd, $httpheader);
- $gets = "";
- $headerFlag = true;
- while (!feof($fd)) {
- if (($header = @fgets($fd)) && ($header == "\r\n" || $header == "\n")) {
- break;
- }
- }
- while (!feof($fd)) {
- $gets.= fread($fd, 128);
- }
- fclose($fd);
-
- return $gets;
- }
-
- /**
- * 好评有礼送积分
- * @param array $comment_info 评价信息
- */
- public function sendCommentGift($comment_id){
- $comment_info = M('lionfish_comshop_order_comment')->where(array('comment_id'=>$comment_id))->find();
- $open_comment_gift = D('Home/Front')->get_config_by_name('open_comment_gift');
- //开启好评有礼
- if($open_comment_gift == 1){
- //评价奖励积分数
- $comment_gift_score = D('Home/Front')->get_config_by_name('comment_gift_score');
- $type = "goodscomment";
- $result = D('Seller/Order')->check_comment_gift_score($comment_info['member_id']);
- if($result['is_comment_gift']){
- $this->charge_member_score( $comment_info['member_id'] , $comment_gift_score,'in', $type, $comment_info['order_id']);
- }
- /*if($send_all_score < $comment_gift_max_score){//已赠送积分小于好评奖励积分上限
- $this->charge_member_score( $comment_info['member_id'] , $comment_gift_score,'in', $type, $comment_info['order_id']);
- }*/
- }
- }
- /**
- * 验证评价有礼积分是否达到上限
- * 返回boolean true 还没达到上限,false 已经达到上限
- */
- public function check_comment_gift_score($member_id){
- $result = array();
- //好评奖励积分上限周期
- $comment_gift_time = D('Home/Front')->get_config_by_name('comment_gift_time');
- //好评奖励积分上限
- $comment_gift_max_score = D('Home/Front')->get_config_by_name('comment_gift_max_score');
- $type = "goodscomment";
- $where = " 1 and member_id=".$member_id;
- $where = $where. " and in_out='in' and type='".$type."' ";
- if($comment_gift_time == 1){//每天
- $begin_time = strtotime(date('Y-m-d 00:00:00'));
- $end_time = strtotime(date('Y-m-d 23:59:59'));
- $where = $where. " and addtime >= ".$begin_time." and addtime <= ".$end_time;
- }else if($comment_gift_time == 2){//每周
- $today = date('Y-m-d');
- $first = 1;
- $w = date('w',strtotime($today));
- $begin_time = strtotime(date('Y-m-d',strtotime("$today -" . ($w ? $w - $first : 6) . ' days')));
- $begin = date('Y-m-d',strtotime("$today -" . ($w ? $w - $first : 6) . ' days'));
- $end_time = strtotime(date('Y-m-d',strtotime("$begin +6 days")));
- $where = $where. " and addtime >= ".$begin_time." and addtime <= ".$end_time;
- }else if($comment_gift_time == 3){//每月
- $begin_time = strtotime(date('Y-m-01', strtotime(date("Y-m-d"))));
- $begin = date('Y-m-01', strtotime(date("Y-m-d")));
- $end_time = strtotime(date('Y-m-d', strtotime("$begin +1 month -1 day")));
- $where = $where. " and addtime >= ".$begin_time." and addtime <= ".$end_time;
- }
-
- $send_all_score = M('lionfish_comshop_member_integral_flow')->where($where)->sum('score');
- /*$result['where'] = $where;
- $result['all_score'] = $send_all_score;*/
- if(empty($send_all_score)){
- $send_all_score = 0;
- }
- /*$result['send_all_score'] = $send_all_score;
- $result['comment_gift_max_score'] = $comment_gift_max_score;*/
- if($comment_gift_max_score > 0){
- if($send_all_score < $comment_gift_max_score){//已赠送积分小于好评奖励积分上限
- $result['is_comment_gift'] = true;
- }else{
- $result['is_comment_gift'] = false;
- }
- }else{
- $result['is_comment_gift'] = true;
- }
- return $result;
- }
-
- public function charge_member_score($member_id, $score,$in_out, $type, $order_id=0){
- $log_data = array();
- $log_data['member_id'] = $member_id;
- $log_data['in_out'] = $in_out;
- $log_data['score'] = $score;
- $log_data['type'] = $type;
- $log_data['order_id'] = $order_id;
- $log_data['addtime'] = time();
-
- $member_score_info = M('lionfish_comshop_member')->field('score')->where( array('member_id' => $member_id) )->find();
- $member_score = $member_score_info['score'];
- if(empty($member_score)){
- $member_score = 0;
- }
- if($in_out == 'in'){
- $log_data['after_operate_score'] = $member_score+$score;
- if($type == 'goodscomment'){
- //增加积分
- $log_data['state'] = 1;
- $log_data['remark'] = "评价有礼,增加积分";
- M('lionfish_comshop_member')->where( array('member_id' => $member_id) )->setInc('score',$score);
- }else if($type == 'invitegift'){
- //邀请者赠送积分
- $log_data['state'] = 1;
- $log_data['remark'] = "邀请者邀请成功,增加积分".$score;
- M('lionfish_comshop_member')->where( array('member_id' => $member_id) )->setInc('score',$score);
- }else if($type == 'invitegift_new'){
- //被邀请者赠送积分
- $log_data['state'] = 1;
- $log_data['remark'] = "被邀请者邀请成功,增加积分".$score;
- M('lionfish_comshop_member')->where( array('member_id' => $member_id) )->setInc('score',$score);
- }else if($type == 'pintuan_rebate'){
- //拼团返利
- $log_data['state'] = 1;
- $log_data['remark'] = "拼团返利,赠送积分".$score;
- M('lionfish_comshop_member')->where( array('member_id' => $member_id) )->setInc('score',$score);
- }
- }
- M('lionfish_comshop_member_integral_flow')->add($log_data);
- }
- public function send_delivery_msg($order_info,$we_openid){
- //同城配送是否开启
- $isopen_localtown_delivery = D('Home/Front')->get_config_by_name('isopen_localtown_delivery' );
- if(!empty($isopen_localtown_delivery)){
- $weixin_template_order =array();
- $weixin_appid = D('Home/Front')->get_config_by_name('weixin_appid');
- $weixin_template_order_riders_receive = D('Home/Front')->get_config_by_name('weixin_template_order_riders_receive');
- $shop_domain = D('Home/Front')->get_config_by_name('shop_domain');
- $url = $shop_domain;
- if( !empty($weixin_appid) && !empty($weixin_template_order_riders_receive) )
- {
- $template_id = $weixin_template_order_riders_receive;
- $head_pathinfo = "lionfish_comshop/moudleB/rider/grap";
- $weixin_template_order = array(
- 'appid' => $weixin_appid,
- 'template_id' => $weixin_template_order_riders_receive,
- 'pagepath' => $head_pathinfo,
- 'data' => array(
- //详细内容
- 'first' => array('value' => '您好,有新的同城配送订单,请您尽快接单!','color' => '#030303'),
- //买家名称
- 'keyword1' => array('value' => $order_info['shipping_name'],'color' => '#030303'),
- //买家电话
- 'keyword2' => array('value' => $order_info['shipping_tel'],'color' => '#030303'),
- //配送地址
- 'keyword3' => array('value' => $order_info['shipping_address'],'color' => '#030303'),
- //商品内容
- 'keyword4' => array('value' => $order_info['goods_name'],'color' => '#030303'),
- //下单时间
- 'keyword5' => array('value' => $order_info['create_time'],'color' => '#030303'),
- 'remark' => array('value' => '请骑手们尽快接单','color' => '#030303'),
- )
- );
- $res = D('Seller/User')->send_wxtemplate_msg(array() , $url ,$head_pathinfo,$we_openid,$template_id,"", 0,$weixin_template_order);
- //print_r($res);
- }
- }
- }
- /**
- * 获取同城配送订单信息
- * @param $order_id
- */
- public function get_order_delivery_detail($order_id){
- $order_delivery = array();
- $order_info = M('lionfish_comshop_order')->where( array('order_id' => $order_id) )->find();
- //买家名称
- $order_delivery['shipping_name'] = $order_info['shipping_name'];
- //买家电话
- $order_delivery['shipping_tel'] = $order_info['shipping_tel'];
- //配送地址
- $province_info = D('Seller/Area')->get_area_info($order_info['shipping_province_id']);
- $city_info = D('Seller/Area')->get_area_info($order_info['shipping_city_id']);
- $country_info = D('Seller/Area')->get_area_info($order_info['shipping_country_id']);
- $shipping_address = $province_info.$city_info.$country_info.$order_info['shipping_address'];
- $order_delivery['shipping_address'] = $shipping_address;
- //商品内容
- $goods_name = "";
- $order_goods = M('lionfish_comshop_order_goods')->where( array('order_id' => $order_id ) )->select();
- foreach($order_goods as $k=>$v)
- {
- if(empty($goods_name)){
- $goods_name = $v['name'];
- }else{
- $goods_name = $goods_name.';'.$v['name'];
- }
- }
- $order_delivery['goods_name'] = $goods_name;
- //下单时间
- $order_delivery['create_time'] = date('Y-m-d H:i:s',$order_info['date_added']);
- return $order_delivery;
- }
- /**
- * 同城配送第三方公司配送
- * @param $order_id 订单号
- * @param $data_type 第三方公司
- * @param $express_info 第三方公司返回数据
- */
- public function do_send_localtown_thirth_delivery( $order_id, $data_type, $express_info)
- {
- $title = ",开始配送货物";
- $delivery_company = "";
- if($data_type == 'imdada'){
- $delivery_company = "第三方达达";
- }else if($data_type == 'sf'){
- $delivery_company = "第三方顺丰同城";
- }else if($data_type == 'make'){
- $delivery_company = "码科配送";
- }else if($data_type == 'ele'){
- $delivery_company = "蜂鸟即配";
- }
- $title = $delivery_company.$title;
- //express_time
- M('lionfish_comshop_order')->where( array('order_id' => $order_id) )->save( array('order_status_id' => 4,'express_time' => time(), 'express_tuanz_time' => time(), 'third_distribution_type'=>$data_type) );
- //todo ... send member msg goods is ing
- $history_data = array();
- $history_data['order_id'] = $order_id;
- $history_data['order_status_id'] = 4;
- $history_data['notify'] = 0;
- $history_data['comment'] = $title;
- $history_data['date_added'] = time();
- M('lionfish_comshop_order_history')->add( $history_data );
- $other_data = array();
- $other_data['delivery_company'] = $delivery_company;
- $other_data['data_type'] = $data_type;
- if($data_type == 'imdada'){
- $other_data['delivery_fee'] = $express_info['delivery_fee'];
- }else if($data_type == 'sf'){
- $other_data['delivery_fee'] = $express_info['delivery_fee'];
- $other_data['delivery_order_id'] = $express_info['delivery_order_id'];
- $other_data['delivery_bill_id'] = $express_info['delivery_bill_id'];
- }else if( $data_type == 'make' ){
- $other_data['delivery_fee'] = $express_info['delivery_fee'];
- $other_data['delivery_order_id'] = $express_info['delivery_order_id'];
- }else if( $data_type == 'ele' ){
- $other_data['delivery_fee'] = $express_info['delivery_fee'];
- $other_data['delivery_order_id'] = $express_info['delivery_order_id'];
- }
- D('Home/LocaltownDelivery')->change_thirth_distribution_order_state( $order_id, 1, $other_data);
- D('Home/LocaltownDelivery')->save_orderdistribution_thirth_log( $order_id, $data_type , 1 ,'已创建订单' );
- D('Home/Frontorder')->send_order_operate($order_id);
- }
- /**
- * @param $order_id
- * @param $order_status_id 0、状态未改变,4、已发货,待收货,6、已签收
- * @param $other_data
- */
- public function do_localtown_thirth_delivery_return( $order_sn, $order_status_id, $other_data)
- {
- $order_info = M('lionfish_comshop_order')->field('order_id,order_num_alias,total,member_id,order_status_id')->where( array('order_num_alias' => $order_sn) )->find();
- if(!empty($order_info)){
- $order_id = $order_info['order_id'];
- $delivery_company = "";
- if($other_data['data_type'] == 'imdada'){
- $delivery_company = "第三方达达";
- }else if($other_data['data_type'] == 'sf'){
- $delivery_company = "第三方顺丰同城";
- }else if( $other_data['data_type'] == 'make' )
- {
- $delivery_company = "第三方码科配送";
- }else if( $other_data['data_type'] == 'ele' )
- {
- $delivery_company = "第三方蜂鸟即配";
- }
- if($order_status_id > 0){
- if($order_status_id == 6 && $order_info['order_status_id'] == 4){
- M('lionfish_comshop_order')->where( array('order_id' => $order_id) )->save( array('order_status_id' => 6, 'receive_time' => time()) );
- D('Home/Frontorder')->receive_order($order_id, 1, $delivery_company);
- //M('lionfish_comshop_order_history')->where( array('order_id' => $order_id,'order_status_id' => 6) )->save( array( 'comment' => $delivery_company.',确认收货') );
- }
- }
- $other_data['delivery_company'] = $delivery_company;
- if($other_data['data_type'] == 'imdada'){//达达平台配送
- if($other_data['order_status'] == 2){//待取货
- D('Home/LocaltownDelivery')->change_thirth_distribution_order_state( $order_id, 2, $other_data);
- D('Home/LocaltownDelivery')->save_orderdistribution_thirth_log( $order_id, $other_data['data_type'] , $other_data['order_status'] ,$other_data['dm_name'].'已抢单,待取货' );
- }else if($other_data['order_status'] == 3){//配送中
- D('Home/LocaltownDelivery')->change_thirth_distribution_order_state( $order_id, 3, $other_data);
- D('Home/LocaltownDelivery')->save_orderdistribution_thirth_log( $order_id, $other_data['data_type'] , $other_data['order_status'] ,$other_data['dm_name'].'配送中' );
- }else if($other_data['order_status'] == 4){//已完成
- D('Home/LocaltownDelivery')->change_thirth_distribution_order_state( $order_id, 4, $other_data);
- D('Home/LocaltownDelivery')->save_orderdistribution_thirth_log( $order_id, $other_data['data_type'] , $other_data['order_status'] ,$other_data['dm_name'].'配送完成' );
- }else if($other_data['order_status'] == 5){//已取消
- D('Home/LocaltownDelivery')->change_thirth_distribution_order_state( $order_id, 5, $other_data);
- $cancel_reason = "";
- if($other_data['cancel_from'] == 11){//达达骑手取消订单
- $cancel_reason = "骑士取消订单:".$other_data['cancel_reason'];
- }else{
- $cancel_reason = "订单取消原因:".$other_data['cancel_reason'];
- }
- D('Home/LocaltownDelivery')->save_orderdistribution_thirth_log( $order_id, $other_data['data_type'] , $other_data['order_status'] , $cancel_reason );
- $this->cancel_third_delviery_order_notice($order_info,$other_data);
- }else if($other_data['order_status'] == 9){//妥投异常之物品返回中
- D('Home/LocaltownDelivery')->change_thirth_distribution_order_state( $order_id, 5, $other_data);
- D('Home/LocaltownDelivery')->save_orderdistribution_thirth_log( $order_id, $other_data['data_type'] , $other_data['order_status'] ,$other_data['cancel_reason'] );
- $this->cancel_third_delviery_order_notice($order_info,$other_data);
- }else if($other_data['order_status'] == 10){//妥投异常之物品返回完成
- D('Home/LocaltownDelivery')->change_thirth_distribution_order_state( $order_id, 5, $other_data);
- D('Home/LocaltownDelivery')->save_orderdistribution_thirth_log( $order_id, $other_data['data_type'] , $other_data['order_status'] ,$other_data['cancel_reason'] );
- $this->cancel_third_delviery_order_notice($order_info,$other_data);
- }else if($other_data['order_status'] == 100){//创建达达运单失败
- D('Home/LocaltownDelivery')->change_thirth_distribution_order_state( $order_id, 5, $other_data);
- D('Home/LocaltownDelivery')->save_orderdistribution_thirth_log( $order_id, $other_data['data_type'] , $other_data['order_status'] ,$other_data['cancel_reason'] );
- }
- }else if( $other_data['data_type'] == 'make' ){
- //2 3/ 4
- if($other_data['order_status'] == 2){//待取货
- D('Home/LocaltownDelivery')->change_thirth_distribution_order_state( $order_id, 2, $other_data);
- D('Home/LocaltownDelivery')->save_orderdistribution_thirth_log( $order_id, $other_data['data_type'] , $other_data['order_status'] ,$other_data['dm_name'].'已抢单,待取货' );
- }else if($other_data['order_status'] == 3){//配送中
- D('Home/LocaltownDelivery')->change_thirth_distribution_order_state( $order_id, 3, $other_data);
- D('Home/LocaltownDelivery')->save_orderdistribution_thirth_log( $order_id, $other_data['data_type'] , $other_data['order_status'] ,$other_data['dm_name'].'配送中' );
- }else if($other_data['order_status'] == 4){//已完成
- D('Home/LocaltownDelivery')->change_thirth_distribution_order_state( $order_id, 4, $other_data);
- D('Home/LocaltownDelivery')->save_orderdistribution_thirth_log( $order_id, $other_data['data_type'] , $other_data['order_status'] ,$other_data['dm_name'].'配送完成' );
- }
- }else if($other_data['data_type'] == 'sf'){//顺丰同城配送
- if($other_data['order_status'] == 2){//已取消
- D('Home/LocaltownDelivery')->change_thirth_distribution_order_state( $order_id, 5, $other_data);
- $cancel_reason = "订单取消,操作人:".$other_data['operator_name'].",取消原因:".$other_data['status_desc'];
- D('Home/LocaltownDelivery')->save_orderdistribution_thirth_log( $order_id, $other_data['data_type'] , 5 ,$cancel_reason );
- $other_data['cancel_reason'] = $other_data['status_desc'];
- $this->cancel_third_delviery_order_notice($order_info,$other_data);
- }else if($other_data['order_status'] == 10 || $other_data['order_status'] == 12 || $other_data['order_status'] == 15){
- //10-配送员确认;12:配送员到店;15:配送员配送中
- $operator_action = $other_data['status_desc'];
- $operator_txt = "";
- if(!empty($other_data['operator_name'])){
- $operator_txt = "(".$other_data['operator_name'].','.$other_data['operator_phone'].")";
- }
- if($other_data['order_status'] == 10){
- D('Home/LocaltownDelivery')->change_thirth_distribution_order_state( $order_id, 2, $other_data);
- D('Home/LocaltownDelivery')->save_orderdistribution_thirth_log( $order_id, $other_data['data_type'] , 2 ,$operator_action.$operator_txt);
- }else if($other_data['order_status'] == 12){
- D('Home/LocaltownDelivery')->change_thirth_distribution_order_state( $order_id, 2, $other_data);
- D('Home/LocaltownDelivery')->save_orderdistribution_thirth_log( $order_id, $other_data['data_type'] , 2 ,$operator_action.$operator_txt);
- }else if($other_data['order_status'] == 15){
- D('Home/LocaltownDelivery')->change_thirth_distribution_order_state( $order_id, 3, $other_data);
- D('Home/LocaltownDelivery')->save_orderdistribution_thirth_log( $order_id, $other_data['data_type'] , 3 ,$operator_action.$operator_txt);
- }
- }else if($other_data['order_status'] == 0){
- //0-订单异常
- D('Home/LocaltownDelivery')->change_thirth_distribution_order_state( $order_id, 5, $other_data);
- D('Home/LocaltownDelivery')->save_orderdistribution_thirth_log( $order_id, $other_data['data_type'] , 11 ,'订单异常,异常详情:'.$other_data['ex_content'] );
- }else if($other_data['order_status'] == 17){//已完成
- D('Home/LocaltownDelivery')->change_thirth_distribution_order_state( $order_id, 4, $other_data);
- D('Home/LocaltownDelivery')->save_orderdistribution_thirth_log( $order_id, $other_data['data_type'] , 4 , '配送员点击完成' );
- }
- }else if( $other_data['data_type'] == 'ele' ){//蜂鸟即配
- if($other_data['order_status'] == 2){//待取货
- D('Home/LocaltownDelivery')->change_thirth_distribution_order_state( $order_id, 2, $other_data);
- D('Home/LocaltownDelivery')->save_orderdistribution_thirth_log( $order_id, $other_data['data_type'] , $other_data['order_status'] , $other_data['desc'] );
- }else if($other_data['order_status'] == 3){//配送中
- D('Home/LocaltownDelivery')->change_thirth_distribution_order_state( $order_id, 3, $other_data);
- D('Home/LocaltownDelivery')->save_orderdistribution_thirth_log( $order_id, $other_data['data_type'] , $other_data['order_status'] , $other_data['desc'] );
- }else if($other_data['order_status'] == 4){//已完成
- D('Home/LocaltownDelivery')->change_thirth_distribution_order_state( $order_id, 4, $other_data);
- D('Home/LocaltownDelivery')->save_orderdistribution_thirth_log( $order_id, $other_data['data_type'] , $other_data['order_status'] , $other_data['desc'] );
- }else if($other_data['order_status'] == 100){//异常订单
- D('Home/LocaltownDelivery')->change_thirth_distribution_order_state( $order_id, 5, $other_data);
- D('Home/LocaltownDelivery')->save_orderdistribution_thirth_log( $order_id, $other_data['data_type'] , $other_data['order_status'] ,$other_data['desc'] );
- }
- }
- }
- }
- /**
- * 商家取消第三方配送订单
- * @param $order_id
- * @param $data_type
- * @param $other_data
- */
- public function do_cancel_thirth_delivery_order($order_id,$data_type,$other_data){
- /*$delivery_company = "";
- if($other_data['data_type'] == 'imdada'){
- $delivery_company = "第三方达达";
- }else if($other_data['data_type'] == 'sf'){
- $delivery_company = "第三方顺丰同城";
- }*/
- M('lionfish_comshop_orderdistribution_order')->where( array('order_id' => $order_id ) )->save(
- array('state' => 5,'cancel_reason'=>$other_data['cancel_reason'],'deduct_fee'=>$other_data['deduct_fee'])
- );
- //违约金
- if(!empty($other_data['now_deduct_fee']) && $other_data['now_deduct_fee'] > 0){
- $log_mgs = "";
- if($data_type == 'imdada'){
- $log_mgs = "第三方达达取消订单,产生违约费:¥".$other_data['now_deduct_fee'];
- }else if($data_type == 'sf'){
- $log_mgs = "第三方顺丰取消订单,产生违约费:¥".$other_data['now_deduct_fee'];
- }else if($data_type == 'make'){
- $log_mgs = "码科配送取消订单,产生违约费:¥".$other_data['now_deduct_fee'];
- }else if($data_type == 'ele'){
- $log_mgs = "蜂鸟即配取消订单,产生违约费:¥".$other_data['now_deduct_fee'];
- }
- $oh = array();
- $oh['order_id'] = $order_id;
- $oh['order_status_id'] = 4;
- $oh['comment'] = $log_mgs;
- $oh['date_added'] = time();
- $oh['notify'] = 1;
- M('lionfish_comshop_order_history')->add($oh);
- //扣除违约金
- D('Seller/Supply')->update_supply_commission($order_id,$other_data['now_deduct_fee']);
- }
- if($data_type == 'sf'){
- $delivery_company = "第三方顺丰同城";
- $remark = $delivery_company.'订单已取消,取消原因:'.$other_data['cancel_reason'];
- D('Home/LocaltownDelivery')->write_distribution_log( $order_id, 0 , 5 ,$remark );
- M('lionfish_comshop_orderdistribution_order')->where( array('order_id' => $order_id ) )->save(
- array('delivery_type'=>0)
- );
- D('Home/LocaltownDelivery')->save_orderdistribution_thirth_log( $order_id, $data_type , 5 ,'订单已取消,取消原因:'.$other_data['cancel_reason'] );
- }if($data_type == 'make'){
- $delivery_company = "码科配送";
- $remark = $delivery_company.'订单已取消,取消原因:'.$other_data['cancel_reason'];
- D('Home/LocaltownDelivery')->write_distribution_log( $order_id, 0 , 5 ,$remark );
- D('Home/LocaltownDelivery')->save_orderdistribution_thirth_log( $order_id, $data_type , 5 ,'订单已取消,取消原因:'.$other_data['cancel_reason'] );
- }if($data_type == 'ele'){
- $delivery_company = "蜂鸟即配";
- $remark = $delivery_company.'订单已取消,取消原因:'.$other_data['cancel_reason'];
- D('Home/LocaltownDelivery')->write_distribution_log( $order_id, 0 , 5 ,$remark );
- D('Home/LocaltownDelivery')->save_orderdistribution_thirth_log( $order_id, $data_type , 5 ,'订单已取消,取消原因:'.$other_data['cancel_reason'] );
- }
- }
- /**
- * 第三方配送取消订单通知
- */
- public function cancel_third_delviery_order_notice($order_info,$other_data){
- $delivery_company = "";
- if($other_data['data_type'] == 'imdada'){
- $delivery_company = "达达";
- }else if($other_data['data_type'] == 'sf'){
- $delivery_company = "顺丰同城";
- }else if($other_data['data_type'] == 'ele'){
- $delivery_company = "蜂鸟即配";
- }if($other_data['data_type'] == 'make') {
- $delivery_company = "码科配送";
- }
- $order_member_name = M('lionfish_comshop_member')->where( array('member_id' => $order_info['member_id'] ) )->find();
- //6、发送取消通知订单给平台
- $weixin_template_cancle_order = D('Home/Front')->get_config_by_name('weixin_template_cancle_order');
- $platform_send_info_member_id = D('Home/Front')->get_config_by_name('platform_send_info_member');
- if( !empty($weixin_template_cancle_order) && !empty($platform_send_info_member_id) )
- {
- $weixin_template_order =array();
- $weixin_appid = D('Home/Front')->get_config_by_name('weixin_appid' );
- if( !empty($weixin_appid) && !empty($weixin_template_cancle_order) )
- {
- $head_pathinfo = "lionfish_comshop/pages/index/index";
- $pl_member_id = explode(",", $platform_send_info_member_id);
- foreach($pl_member_id as $m_id){
- $weopenid = M('lionfish_comshop_member')->where( array('member_id' => $m_id ) )->find();
- $weixin_template_order = array(
- 'appid' => $weixin_appid,
- 'template_id' => $weixin_template_cancle_order,
- 'pagepath' => $head_pathinfo,
- 'data' => array(
- 'first' => array('value' => '您好,您收到了一个'.$delivery_company.'配送取消订单,请尽快处理','color' => '#030303'),
- 'keyword1' => array('value' => $order_info['order_num_alias'],'color' => '#030303'),
- 'keyword2' => array('value' => '取消订单','color' => '#030303'),
- 'keyword3' => array('value' => sprintf("%01.2f", $order_info['total']),'color' => '#030303'),
- 'keyword4' => array('value' => date('Y-m-d H:i:s'),'color' => '#030303'),
- 'keyword5' => array('value' => $order_member_name['username'],'color' => '#030303'),
- 'remark' => array('value' => '此订单已于'.date('Y-m-d H:i:s').'被'.$delivery_company.'配送取消,取消原因:'.$other_data['cancel_reason'].',请尽快处理','color' => '#030303'),
- )
- );
- D('Seller/User')->just_send_wxtemplate($weopenid['we_openid'], 0, $weixin_template_order );
- }
- }
- }
- }
-
- /**
- * 核销订单
- * @param $order_id 订单号
- * @return array
- */
- public function hexiao_all_orders($order_id){
- //订单信息
- $field = "order_id,order_num_alias,member_id,ziti_name,ziti_mobile,shipping_name,shipping_tel";
- $order_info = M('lionfish_comshop_order')->where(array('order_id'=>$order_id))->field($field)->find();
- //订单要核销商品(未核销完,剩余核销数量大于0)
- $order_goods_saleshexiao_list = M('lionfish_comshop_order_goods_saleshexiao')->where(array('order_id'=>$order_info['order_id'],'is_hexiao_over'=>0))->select();
- if(count($order_goods_saleshexiao_list) > 0){
- foreach($order_goods_saleshexiao_list as $k=>$v){
- //核销商品
- $this->hexiao_order_goods($v,0);
- }
- $this->hexiao_finished($order_id,'后台整单点击“确认使用”,订单完成');
- }
- }
-
- /**
- * 核销完成
- * @param $order_id
- */
- public function hexiao_finished($order_id,$hx_msg){
- $is_finished = true;
- $hexiao_list = M('lionfish_comshop_order_goods_saleshexiao')->where(array('order_id'=>$order_id))->select();
- foreach($hexiao_list as $k=>$v){
- if($v['hexiao_type'] == 0 && $v['is_hexiao_over'] == 0){//按订单核销
- $is_finished = false;
- }
- if($v['hexiao_type'] == 1 && $v['is_hexiao_over'] == 0){//按次核销
- if($v['hexiao_count'] > 0 && $v['remain_hexiao_count'] > 0){
- $is_finished = false;
- }
- if($v['hexiao_count'] == 0){
- $is_finished = false;
- }
- }
- }
- if($is_finished){
- $order_history = array();
- $order_history['order_id'] = $order_id;
- $order_history['order_status_id'] = 11;
- $order_history['notify'] = 0;
- $order_history['comment'] = $hx_msg;
- $order_history['date_added']=time();
- M('lionfish_comshop_order_history')->add($order_history);
- //ims_
- $time = time();
- M('lionfish_comshop_order')->where( array('order_id' => $order_id) )->save( array('order_status_id' => 11,'receive_time' => $time,'finishtime' => $time) );
- $open_aftersale = D('Home/Front')->get_config_by_name('open_aftersale');
- $open_aftersale_time = D('Home/Front')->get_config_by_name('open_aftersale_time');
- $statements_end_time = $time;
- if( !empty($open_aftersale) && !empty($open_aftersale_time) && $open_aftersale_time > 0 )
- {
- $statements_end_time = $statements_end_time + 86400 * $open_aftersale_time;
- }
- $up_order_data = array();
- $up_order_data['statements_end_time'] = $statements_end_time;
- M('lionfish_comshop_order_goods')->where( array('order_id' => $order_id) )->save( $up_order_data );
- }
- }
-
- /**
- * 核销商品
- * @param $order_goods_saleshexiao 订单商品核销信息表
- * @param $hx_time 0、按订单核销,大于0、按次数核销
- * @return 1、核销商品成功,0、核销商品失败,-1 核销次数大于剩余次数
- */
- public function hexiao_order_goods($order_goods_saleshexiao,$hx_time){
- //订单核销信息表id
- $hx_id = $order_goods_saleshexiao['id'];
- //剩余核销数量
- $remain_hexiao_count = $order_goods_saleshexiao['remain_hexiao_count'];
- if($order_goods_saleshexiao['hexiao_count'] > 0){
- $hexiao_count = 0;
- if($hx_time > 0){
- if($hx_time > $remain_hexiao_count){
- return -1;
- }else{
- $hexiao_count = $hx_time;
- }
- }else{
- $hexiao_count = $remain_hexiao_count;
- }
- $hexiao_data = array();
- if($hexiao_count == $remain_hexiao_count){
- $hexiao_data['remain_hexiao_count'] = 0;
- $hexiao_data['is_hexiao_over'] = 1;
- }else{
- $hexiao_data['remain_hexiao_count'] = $remain_hexiao_count - $hexiao_count;
- }
- $hx_result = M('lionfish_comshop_order_goods_saleshexiao')->where(array('id'=>$hx_id))->save($hexiao_data);
- }else{
- if($hx_time == 0){
- $hexiao_data = array();
- $hexiao_data['is_hexiao_over'] = 1;
- $hexiao_count = 1;
- $hx_result = M('lionfish_comshop_order_goods_saleshexiao')->where(array('id'=>$hx_id))->save($hexiao_data);
- }else{
- $hx_result = 1;
- $hexiao_count = $hx_time;
- }
- }
- if($hx_result !== false){
- //添加订单核销记录表
- $hexiao_record = array();
- $hexiao_record['order_id'] = $order_goods_saleshexiao['order_id'];
- $hexiao_record['order_goods_id'] = $order_goods_saleshexiao['order_goods_id'];
- $hexiao_record['goods_id'] = $order_goods_saleshexiao['goods_id'];
- $hexiao_record['hexiao_count'] = $hexiao_count;
- $hexiao_record['smember_name'] = "后台操作";
- $hexiao_record['is_admin'] = 1;
- $hexiao_record['addtime'] = time();
- M('lionfish_comshop_order_goods_saleshexiao_record')->add($hexiao_record);
- return 1;
- }else{
- return 0;
- }
- }
- /**
- * 获取订单商品核销记录
- */
- public function get_goods_hexiao_record(){
- $data = array();
- $order_id = I('request.id','');
- $order_goods_id = I('request.order_goods_id','');
- $hx_count = 0;
- $list = M('lionfish_comshop_order_goods_saleshexiao_record')->where(array('order_id'=>$order_id,'order_goods_id'=>$order_goods_id))->order('addtime desc')->select();
- foreach($list as $k=>$v){
- $hx_count = $hx_count + $v['hexiao_count'];
- }
- $data['hx_count'] = $hx_count;
- $data['hx_list'] = $list;
- return $data;
- }
- /**
- * 商品指定核销信息
- * @param unknown $goods_id
- */
- public function get_goods_assign_salesroom($goods_id){
- $data = array();
- //核销员
- $item_smember = array();
- //核销门店
- $item_salesroom = M()->query("SELECT gs.*,sr.room_name,sr.room_logo FROM " . C('DB_PREFIX') .
- "lionfish_comshop_goods_relative_salesroom as gs left join " . C('DB_PREFIX') ."lionfish_comshop_salesroom as sr on gs.salesroom_id=sr.id WHERE gs.goods_id=".$goods_id." order by gs.id asc" );
- foreach($item_salesroom as $k=>$v){
- $item_salesroom_smember = M()->query("SELECT grs.smember_id,sm.username FROM " . C('DB_PREFIX') .
- "lionfish_comshop_goods_relative_smember as grs left join " . C('DB_PREFIX') ."lionfish_comshop_salesroom_member as sm on grs.smember_id=sm.id ".
- " left join " . C('DB_PREFIX') ."lionfish_comshop_member as m on sm.member_id=m.member_id ".
- " WHERE grs.gr_id=".$v['id']." order by sm.id asc" );
- foreach($item_salesroom_smember as $mk=>$mv){
- $item_smember[$mv['smember_id']] = $mv['username'];
- }
- }
- $data['salesroom_list'] = $item_salesroom;
- $data['smember_list'] = $item_smember;
- return $data;
- }
-
- //脱敏代码
- public function desensitize($string, $start = 0, $length = 0, $re = '*'){
- if(empty($string) || empty($length) || empty($re)) return $string;
- $end = $start + $length;
- $strlen = mb_strlen($string);
- $str_arr = array();
- for($i=0; $i<$strlen; $i++) {
- if($i>=$start && $i<$end)
- $str_arr[] = $re;
- else
- $str_arr[] = mb_substr($string, $i, 1);
- }
- return implode('',$str_arr);
- }
-
- public function num_to_rmb($num){
- $c1 = "零壹贰叁肆伍陆柒捌玖";
- $c2 = "分角元拾佰仟万拾佰仟亿";
- //精确到分后面就不要了,所以只留两个小数位
- $num = round($num, 2);
- //将数字转化为整数
- $num = $num * 100;
- if (strlen($num) > 10) {
- return "金额太大,请检查";
- }
- $i = 0;
- $c = "";
- while (1) {
- if ($i == 0) {
- //获取最后一位数字
- $n = substr($num, strlen($num)-1, 1);
- } else {
- $n = $num % 10;
- }
- //每次将最后一位数字转化为中文
- $p1 = substr($c1, 3 * $n, 3);
- $p2 = substr($c2, 3 * $i, 3);
- if ($n != '0' || ($n == '0' && ($p2 == '亿' || $p2 == '万' || $p2 == '元'))) {
- $c = $p1 . $p2 . $c;
- } else {
- $c = $p1 . $c;
- }
- $i = $i + 1;
- //去掉数字最后一位了
- $num = $num / 10;
- $num = (int)$num;
- //结束循环
- if ($num == 0) {
- break;
- }
- }
- $j = 0;
- $slen = strlen($c);
- while ($j < $slen) {
- //utf8一个汉字相当3个字符
- $m = substr($c, $j, 6);
- //处理数字中很多0的情况,每次循环去掉一个汉字“零”
- if ($m == '零元' || $m == '零万' || $m == '零亿' || $m == '零零') {
- $left = substr($c, 0, $j);
- $right = substr($c, $j + 3);
- $c = $left . $right;
- $j = $j-3;
- $slen = $slen-3;
- }
- $j = $j + 3;
- }
- //这个是为了去掉类似23.0中最后一个“零”字
- if (substr($c, strlen($c)-3, 3) == '零') {
- $c = substr($c, 0, strlen($c)-3);
- }
- //将处理的汉字加上“整”
- if (empty($c)) {
- return "零元整";
- }else{
- return $c . "整";
- }
- }
-
- }
- ?>
|