load->library('session'); $this->load->_model('Model_fullorder','fullorder'); $this->load->_model('Model_fullordertt','fullordertt'); $this->load->_model('Model_fullorderexcel','fullorderexcel'); $this->load->_model('Model_shop','shop'); $this->load->_model('Model_typeclass','typeclass'); $this->load->_model('Model_express','express'); $this->load->_model('Model_country','country'); $this->load->_model('Model_productdescribe','productdescribe'); $this->load->_model('Model_customs','customs'); $this->load->_model('Model_detailed','detailed'); $this->load->_model('Model_productdescription','productdescription'); $this->load->_model('Model_logistics','logistics'); $this->load->_model('Model_hl','hl'); $this->load->_model('Model_excel','excel'); $this->load->_model('Model_warehouse','warehouse'); $this->load->_model('Model_customer','customer'); $this->load->_model('Model_user','user'); $this->load->_model('Model_dhl','dhl'); $this->load->_model('Model_ali','ali'); $this->load->_model('Model_notice','notice'); $this->load->_model('Model_api','api'); $this->load->_model('Model_usps','usps'); $this->load->_model('Model_fullorder_smt','fullorder_smt'); $this->load->_model('Model_whlabel','whlabel'); $this->load->_model('Model_reset','fullreset'); $this->load->_model('Model_specialstock','specialstock'); $this->load->_model('Model_systemwigsout','systemwigsout'); $this->load->_model('Model_colourorderts','colourorderts'); $this->load->_model('Model_paypal','paypal'); $this->load->_model('Model_ck','ck'); $this->load->_model('Model_weight','weight'); $this->load->_model('Model_pay','pay'); $this->load->_model('Model_setting','setting'); $this->load->_model('Model_whlabel_fc','whlabel_fc'); $this->load->_model('Model_transfer','transfer'); $this->load->_model('Model_systemtransfer','systemtransfer'); $this->load->_model('Model_power','power'); $this->load->_model('Model_awlgx','awlgx'); $this->load->_model('Model_fullorderhb','fullorderhb'); $this->load->_model('Model_notice','notice'); $this->load->_model('Model_producttitle','producttitle'); $this->load->_model('Model_emaildata','emaildata'); $this->load->_model('Model_afspaypal','afspaypal'); $this->load->_model('Model_returngoods','returngoods'); $this->load->_model('Model_message','message'); $this->load->_model("Model_logic_order","logic_order"); $this->load->_model("Model_logic_ding","logic_ding"); $this->load->_model("Model_fullordererrors","fullordererrors"); } //定义方法的调用规则 获取URI第二段值 public function _remap($arg,$arg_array) { if($arg == 'add')//添加 { $this->_add(); } else if($arg == 'edit')//修改 { $this->_edit($arg_array); } else if($arg == 'readonly')//修改 { $this->_readonly($arg_array); } else if($arg == 'readlist') { $this->_readlist(); } else if($arg == 'readlistdown') { $this->_readlistdown(); } else if($arg == 'del')//修改 { $this->_del(); } else if($arg == 'price')//价格明细 { $this->_price(); } else if($arg == 'customs') { $this->_customs(); } else if($arg == 'express') { $this->_express(); } else if($arg == 'hl') { $this->_hl(); } else if($arg == 'repeat') { $this->_repeat(); } else if($arg == 'operation') { $this->_operation(); } else if($arg == 'merge') { $this->_merge(); } else if($arg == 'fmexcel') { $this->_fmexcel(); } else if($arg == 'fdexcel') { $this->_fdexcel(); } else if($arg == 'fdfexcel') { $this->_fdfexcel(); } else if($arg == 'evaluate') { $this->_evaluate(); } else if($arg == 'state') { $this->_state(); } else if($arg == 'wl') { $this->_wl(); } else if($arg == 'wlbz') { $this->_wlbz($arg_array); } else if($arg == 'review') { $this->_review(); } else if($arg == 'black') { $this->_black(); } else if($arg == 'ryf') { $this->_ryf(); } else if($arg == 'expresstype') { $this->_expresstype(); } else if($arg == 'fsstate') { $this->_fsstate(); } else if($arg == 'power') { $this->_power(); } else if($arg == 'error') { $this->_error(); } else if($arg == 'yzaddress') { $this->_yzaddress(); } else if($arg == 'return') { $this->_return(); } else if($arg == 'clearreturn') { $this->_clearreturn(); } else if($arg == 'ali') { $this->_ali(); } else if($arg == 'dqpm') { $this->_dqpm(); } else if($arg == 'ddpmdata') { $this->_ddpmdata($arg_array); } else if($arg == 'dqpmprovince') { $this->_dqpmprovince($arg_array); } else if($arg == 'ddpmexcel') { $this->_ddpmexcel($arg_array); } else if($arg == 'statedc') { $this->_statedc(); } else if($arg == 'statedcwl') { $this->_statedcwl(); } else if($arg == 'waybillemail') { $this->_waybillemail(); } else if($arg == 'khdd') { $this->_khdd(); } else if($arg == 'klarnadata') { $this->_klarnadata(); } else if($arg == 'epod') { $this->_epod(); } else if($arg == 'zw') { $this->_zw($arg_array); } else if($arg == 'thxz') { $this->_thxz($arg_array); } else if($arg == 'dcdxyz') { $this->_dcdxyz(); } else if($arg == 'ddcf') { $this->_ddcf(); } else if($arg == 'cf') { $this->_cf(); } else { $this->_index(); } } //管理 public function _index() { $dt = 0;$fgshop = "shop = 0";$sid = 'id = 0'; if(isset($_SESSION['api'])) { $user = $this->user->get_api($_SESSION['api']); $usp = $user; $fgshop = "";$sid = ""; $usersp = explode('|',trim($user['shop'],'|')); foreach ($usersp as $value) { $fgshop .= " shop = ".$value." or"; $sid .= " id = ".$value." or"; } if($user['vip'] == 1) { $vip = 1; } else { $vip = 0; } } else { $vip = 0; header('Location: /');exit; } $post = $this->input->post(NULL, TRUE); if(isset($post['page'])) { $page = $this->input->post('page',true); $perpage = $this->input->post('perpage',true); $warehouse = $this->input->post('warehouse',true); $timetk = $this->input->post('timetk',true); $timetj = $this->input->post('timetj',true); $shop = $this->input->post('shop',true); $source = $this->input->post('source',true); $state = $this->input->post('state',true); $review = $this->input->post('review',true); $type = $this->input->post('type',true); $express = $this->input->post('express',true); $orderinfo = $this->input->post('orderinfo',true); $user = $this->input->post('user',true); $client = $this->input->post('name',true); $waybill = $this->input->post('waybill',true); $waybillid = $this->input->post('waybillid',true); $number = $this->input->post('number',true); $email = $this->input->post('email',true); $phone = $this->input->post('phone',true); $dlz = $this->input->post('dlz',true); $print = $this->input->post('print',true); $library = $this->input->post('library',true); $js = $this->input->post('js',true); $exstate = $this->input->post('exstate',true); $xztime = $this->input->post('xztime',true); $libraryconfirm = $this->input->post('libraryconfirm',true); $timetk = strtotime($timetk); $timetj = strtotime($timetj); $plorder = $this->input->post('pl',true); $paypal = $this->input->post('paypal',true); $pay = $this->input->post('pay',true); $klarna = $this->input->post('klarna',true); $orderremarks = $this->input->post('orderremarks',true); $zf = $this->input->post('zf',true); $where = "1=1 and (".rtrim($fgshop,'or').")"; if($warehouse) { $where .= " and type = '$warehouse'"; } if($timetk && $timetj) { $where .= " and ".$xztime." > '$timetk' and ".$xztime." < '$timetj'"; } if($shop) { $where .= " and shop = '$shop'"; } if($source) { if($source == '2d') { $where .= " and source >= '2'"; } else { $where .= " and source = '$source'"; } } if($state) { $where .= " and state = '$state'"; } if($review) { $where .= " and review = '$review'"; } if($type) { $where .= " and type = '$type'"; } if($express) { $where .= " and express = '$express'"; } if($orderinfo) { $where .= " and orderinfo = '$orderinfo' and orderinfo != '0'"; } if($user) { $where .= " and user = '$user'"; } if($client) { $where .= " and client like '%$client%'"; } if($waybill) { $where .= " and waybill like '%$waybill%'"; } if($waybillid){ $where .= " and waybillid like '%".$waybillid."%'"; } if($number) { $where .= " and number like '$number%'"; } if($email) { $where .= " and ((email = '$email') or (send_email = '$email')) "; } if($phone) { $where .= " and phone like '%$phone%'"; } if($library) { $where .= " and library = '$library'"; } if($print) { $where .= " and print = '$print'"; } if($dlz != '') { $where .= " and dlz = '$dlz'"; } if($js) { $where .= " and js = '$js'"; } if($exstate) { $where .= " and exstate = '$exstate'"; } if($libraryconfirm) { $where .= " and libraryconfirm = '$libraryconfirm'"; } if($klarna != '') { if($klarna == 2) { $where .= " and klarna >= '$klarna'"; } else { $where .= " and klarna = '$klarna'"; } } if($paypal) { $where .= " and paypal = '$paypal'"; } if($pay) { $where .= " and pay = '$pay'"; } if($zf) { if($zf == 1) { $where .= " and paypal not like '%-%-%-%'"; } else { $where .= " and paypal like '%-%-%-%'"; } } if($orderremarks){ $where .= " and orderremarks like '%$orderremarks%'"; } if($plorder) { $plorderinfo = '';$plnumber = '';$pln = 0; $plorder = explode(',',trim($plorder,',')); foreach ($plorder as $value) { if(is_numeric($value)) { $plorderinfo .= " orderinfo = ".$value." or"; } else if($value != '') { $plorderinfo .= " number = '".$value."' or"; } } if($pln > 0) { $where .= " and (".rtrim($plorderinfo,'or').") and (".rtrim($plnumber,'or').")"; } else { $where .= " and (".rtrim($plorderinfo,'or').")"; } } //数据排序 $order_str = "dtime desc"; if(empty($page)) { $start = 0; $perpage = 1; } else { $start = ($page - 1)*$perpage; } //取得信息列表id,shop,type,source,user,orderinfo,number,name,state,buytime,clientremarks,review,print,library,libraryconfirm,express,waybill,orderremarks,black $info_list = $this->fullorder->find_all($where,'id,shop,type,orderinfo,number,sname,email,state,buytime,review,libraryconfirm,express,waybill,orderremarks,library,black,clientremarks,waybillid',$order_str,$start,$perpage); //格式化数据 foreach ($info_list as $key=>$value) { $rginfo = $this->returngoods->get_orderinfo($value['orderinfo']); if(!empty($rginfo)){ $info_list[$key]['number'] = $value['number']."
".'

'; } $ud = $this->fullorder->read($value['id']); $ud['address'] = str_replace("'","’",$ud['address']); $ud['name'] = str_replace("'","’",$ud['name']); $customer = $this->customer->get_email($ud['email'],$value['shop']); $customernum = $this->fullorder->find_count("email = '".$ud['email']."' and shop = '".$value['shop']."' and extra_status = 0"); preg_match_all('/[0-9]/u',$ud['phone'],$result); $numphone = join('',$result[0]); $hmdaddress1 = str_replace(array(' parkway',' drive',' street',' road',' avenue',' boulevard',' alley',' court',' place',' lane',' manor',' terrace',' trail',' view',' cove'),array(' pkwy',' dr',' st',' rd',' av',' blvd',' aly',' ct',' pl',' ln',' mnr',' ter',' trl',' vw',' cv'),strtolower($ud['address'])); $hmdaddress2 = str_replace(array(' pkwy',' dr',' st',' rd',' av',' blvd',' aly',' ct',' pl',' ln',' mnr',' ter',' trl',' vw',' cv'),array(' parkway',' drive',' street',' road',' avenue',' boulevard',' alley',' court',' place',' lane',' manor',' terrace',' trail',' view',' cove'),strtolower($ud['address'])); $hmdaddress3 = str_replace(array(' avenue',' ave',' av'),array(' ave',' avenue',' ave'),strtolower($ud['address'])); if($numphone == '0') { $customerb = $this->customer->find_all("type = 2 and (email = '".$ud['email']."' or address = '".$ud['address']."' or address = '".$hmdaddress1."' or address = '".$hmdaddress2."' or address = '".$hmdaddress3."' or phone = '".$numphone."')",'*','id desc'); } else { $customerb = $this->customer->find_all("type = 2 and (email = '".$ud['email']."' or address = '".$ud['address']."' or address = '".$hmdaddress1."' or address = '".$hmdaddress2."' or address = '".$hmdaddress3."' or numphone = '".$numphone."')",'*','id desc'); } $customerc = $this->customer->find_all("type = 1 and shop = '".$ud['shop']."' and address = '".$ud['address']."' and numphone = '".$numphone."'",'*','id desc'); $customerd = $this->customer->find_all("type = 2 and shop = '".$ud['shop']."' and email = '".$ud['email']."'",'*','id desc'); //$a = array_column($customer, 'email'); //三维找其中健的数组 //$a = array_flip($a); //键和值调换 $djcount = ''; $lkh = $value['sname']; $djlkh = 0;$djhmd = 0; if($customer) { if($customer['count'] != '' && $customernum < 2) { $count = ''; $djcount = $count; } if(($customer['type'] == 1 && $customernum > 1))// || $customerc['type'] == 1 && $customerc['num'] > 1 { $count = $customer['count']?'':''; $lkh = "

".$value['sname']."

".$count."老客户(".$customer['num'].")

"; $djlkh = 1; $djcount = $count; } else if(isset($customerc[0]['num'])) { if($customerc[0]['num'] > 1) { $count = $customer['count']?'':''; $lkh = "

".$value['sname']."

".$count."老客户(".$customer['num'].")

"; $djlkh = 1; $djcount = $count; } } } if($customerb) { $hmsp = $this->shop->read($customerb[0]['shop']); $count = $customerb[0]['count']?'':''; $lkh = "

".$value['sname']."

".$count."黑名单

来自".$hmsp['shopname']."

"; $djhmd = 1; if($customerd) { if($customerd[0]['num'] > 1) { $count = $customerd[0]['count']?'':''; $lkh = "

".$value['sname']."

".$count."老客户

"; $djlkh = 1; $djcount = $count; $djlkh = 1; } } } if($djlkh == '1' && $djhmd == '1') { $lkh = "

".$value['sname']."

".$djcount."老客户 - ".$count."黑名单

来自".$hmsp['shopname']."

"; } if($djlkh != '1' && $djhmd != '1' && $djcount) { $info_list[$key]['sname'] = $lkh."

".$djcount."

"; } else { $info_list[$key]['sname'] = $lkh; } // $rginfo_list = $this->returngoods->find_all("email = '".$value['email']."'"); // if(!empty($rginfo_list)) // { // $tmp_str = ''; // foreach ($rginfo_list as $k => $v) { // $tmp_str .= $v['remark'].'
'; // } // $info_list[$key]['sname'] = $info_list[$key]['sname']."
售后单(".count($rginfo_list).")".'

'; // } $shop = $this->shop->read($value['shop']); $info_list[$key]['shop'] = $shop['shopname']; //$info_list[$key]['user'] = $shop['shopuser']; $warehouse = $this->warehouse->read($value['type']); $warehousetitle = $warehouse['title']; if($value['type'] != 13){$warehousetitle = "".$warehouse['title']."";} $info_list[$key]['type'] = $warehousetitle; if(empty($ud['send_email'])){ $info_list[$key]['email'] = ''.$value['email'].'
'.$ud['phone']; }else{ $info_list[$key]['email'] = ''.$value['email'].'
'.''.$ud['send_email'].'
'.$ud['phone']; } $typeclass = $this->typeclass->read($value['state']); $info_list[$key]['state'] = "".$typeclass['spare'].""; /** $wl = ''; if($value['exstate'] == '99') { $wl = '未获取到物流信息'; } else if($value['exstate'] == '1') { $wl = '已揽收'.$ud['excontent'].''; } else if($value['exstate'] == '2') { $wl = '在途中'.$ud['excontent'].''; } else if($value['exstate'] == '3') { $wl = '派送中'.$ud['excontent'].''; } else if($value['exstate'] == '4') { $wl = '已签收'.$ud['excontent'].''; } else if($value['exstate'] == '5') { $wl = '派送异常'.$ud['excontent'].''; } $info_list[$key]['exstate'] = $wl.'
'; **/ if($ud['source'] == 1) //线下单用订单时间,其他用付款时间 { $info_list[$key]['buytime'] = '

'.date('Y-m-d',$ud['dtime']).'

'.date('H:i:s',$ud['dtime']).'

'; } else { $info_list[$key]['buytime'] = '

'.date('Y-m-d',$value['buytime']+$dt).'

'.date('H:i:s',$value['buytime']+$dt).'

'; } if($value['review'] == 1) { $info_list[$key]['review'] = "未送审"; } else if($value['review'] == 2) { $info_list[$key]['review'] = "待审核"; } else if($value['review'] == 3) { $info_list[$key]['review'] = "不通过"; } else if($value['review'] == 4) { $info_list[$key]['review'] = "取消重审"; } else if($value['review'] == 5) { $info_list[$key]['review'] = "审核通过"; } else if($value['review'] == 6) { $info_list[$key]['review'] = "自动通过"; } if($ud['dlz'] == 1) { $dlz = "

独立站已更新

"; } else if($ud['dlz'] == 3) { $dlz = "

不需要更新

"; } else if($ud['dlz'] == 2) { $dlz = "

独立站更新失败

"; } else { $dlz = ""; } if($value['waybill'] != "") { $info_list[$key]['waybill'] = "

".$value['waybill']."

".$dlz; //如果是云尚快线那么需要展示一个可以查全程的运单号 if( !empty($value['waybillid'])){ $info_list[$key]['waybill'] = "

".$value['waybill']."

".$dlz."

".$value['waybillid']."

"; } } if($value['express'] != 0) { $express = $this->express->read($value['express']); $expressservicename = $express['servicename']; if($value['express'] != 1 && $value['express'] != 63) { $expressservicename = "".$express['servicename'].""; } else if($value['express'] == 63) { $expressservicename = "".$express['servicename'].""; } $info_list[$key]['express'] = $expressservicename; } else { $info_list[$key]['express'] = "无"; } $x = ""; if($value['libraryconfirm'] == 2 && $value['review'] > 4 && $ud['library'] == 1) { $x = "

禁止发货

"; } else if(($value['review'] > 4) && $ud['print'] != 1 && $value['libraryconfirm'] == 1) { $x = "

允许发货

"; } if(($value['review'] > 4) && $ud['print'] == 2) { $x = "

禁止打印

"; } else if($value['review'] >4 && $ud['print'] == 1) { $x = "

允许打印

"; } if($value['waybill'] == "" && $value['review'] > 4) { $x .= "

填写运单号

"; } else if($value['waybill'] != "" && $value['review'] > 4) { $x .= "

修改运单号

"; } if(($value['review'] == 1 || $value['review'] == 3) && $ud['express'] > 0 && $ud['dtsbjz'] != 0 && $ud['ts'] != 0 && $ud['zsbjz'] != 0 && $ud['zjs'] != 0 && $ud['ts'] != 0 && ($ud['merge'] == 0 || $ud['merge'] != 0 && $ud['merge'] == $ud['id'])) { $x .= "

提交审核

"; } $x .= "

客户信息

"; $info_list[$key]['black'] = $x; $tly = ""; if($value['clientremarks'] != "") { $tly = "

有客户留言

"; } if($value['review'] > 4 && $usp['vip'] != 1 && ($ud['merge'] == 0 || $ud['merge'] == $ud['id'])) { $info_list[$key]['orderinfo'] = "

".$value['orderinfo']."

".$tly."
"; } else if($ud['merge'] == 0 || $ud['merge'] == $ud['id']) { $info_list[$key]['orderinfo'] = "

".$value['orderinfo']."

".$tly."
"; } else if($ud['merge'] != 0 && $ud['merge'] != $ud['id']) { $info_list[$key]['orderinfo'] = "

".$value['orderinfo']."

".$tly."
"."

合并订单

"; } else { $info_list[$key]['orderinfo'] = "

".$value['orderinfo']."

".$tly."
"; } if($value['library'] == 1 && $ud['printtype'] == 3) { $info_list[$key]['library'] = "不需要"; } else if($value['library'] == 1 && $ud['printtype'] != 3) { $info_list[$key]['library'] = "未出库"; } else if($value['library'] == 2) { $info_list[$key]['library'] = '

'.date('Y-m-d',$ud['librarytime']).'

'.date('H:i:s',$ud['librarytime']).'出库

'; } else if($value['library'] == 3) { $info_list[$key]['library'] = '

'.date('Y-m-d',$ud['retreattime']).'

'.date('H:i:s',$ud['retreattime']).'退库

'; } unset($info_list[$key]['waybillid']); } $total = $this->fullorder->find_count($where); $pagenum = ceil($total/$perpage); $over = $total-($start+$perpage); $rows = array('total'=>$total,'over'=>$over,'pagenum'=>$pagenum,'rows'=>($info_list)); echo json_encode($rows);exit; } $wlshop = $this->shop->find_all('1=1 and '.rtrim($sid,'or')); $this->data['wlshop'] = $wlshop; $this->data['express'] = $this->express->find_all(); $user = $this->user->get_api($_SESSION['api']); $powerid = $this->power->read($user['power']); $powertext = explode('|',trim($powerid['excelid'],'|')); $pid = ''; foreach ($powertext as $v) { $pid .= " id = ".$v." or"; } $fullorderexcel = $this->fullorderexcel->find_all("type = '100001' and (".rtrim($pid,'or').")",'*','idorder desc');//导出模板 $this->data['fullorderexcel'] = $fullorderexcel; $error = $this->fullorder->find_count("failed !='' and mergeid = 0 and print != 3 and (".rtrim($fgshop,'or').") and dtime > '".(time()-90*24*3600)."'"); $this->data['error'] = $error; $cs_num = $this->fullordererrors->find_count( " plat = 'fullorder' and error_type = 1 and (".rtrim($fgshop,'or'). " ) and error_time > '".(time()-90*24*3600)."'"); $this->data['cs_num'] = $cs_num; $this->data['power'] = $vip; $this->_Template('fullorder',$this->data); } //筛选重复订单 public function _repeat() { $user = $this->user->get_api($_SESSION['api']); if($user) { $fgshop = "";$sid = ""; $user = explode('|',trim($user['shop'],'|')); foreach ($user as $value) { $fgshop .= " shop = ".$value." or"; $sid .= " id = ".$value." or"; } } $post = $this->input->post(NULL, TRUE); if(isset($post['page'])) { $page = $this->input->post('page',true); $perpage = $this->input->post('perpage',true); $shop = $this->input->post('shop',true); $email = $this->input->post('email',true); $timetk = $this->input->post('timetk',true); $timetj = $this->input->post('timetj',true); $timetk = strtotime($timetk); $timetj = strtotime($timetj); $where = "print != 999 and state = 207 and review = 1 and number NOT like '%-%-%-%' and (".rtrim($fgshop,'or').")"; if($shop) { $where .= " and shop = '$shop'"; } if($email) { $where .= " and email = '$email'"; } if($timetk && $timetj) { $where .= " and dtime > '$timetk' and dtime < '$timetj'"; } //数据排序 $order_str = "id desc"; if(empty($page)) { $start = 0; $perpage = 1; } else { $start = ($page - 1)*$perpage; } //取得信息列表 $info_list = $this->fullorder->find_all($where,'id,shop,orderinfo,number,name,email,address,state,dtime,shipremarks,type,merge'); $info = array(); $len = count($info_list); //格式化数据 foreach ($info_list as $key=>$value) { $ud = $this->fullorder->read($value['id']); $shop = $this->shop->read($value['shop']); $warehouse = $this->warehouse->read($value['type']); $info_list[$key]['shop'] = '

'.$shop['shopname'].'

'.'

'.$warehouse['title'].'

'; $info_list[$key]['email'] = '

'.$value['email'].'

'.'

'.$ud['phone'].'

'; $typeclass = $this->typeclass->read($value['state']); $info_list[$key]['state'] = $typeclass['spare']; $info_list[$key]['type'] = $ud['orderremarks']; $info_list[$key]['dtime'] = '

'.date('Y-m-d',$value['dtime']).'

'.date('H:i:s',$value['dtime']).'

'; if($value['merge'] == 0) { $info_list[$key]['merge'] = "

可合并

"; } else { if($value['merge'] == $value['id']) { if($ud['print'] < '3' && $ud['library'] == '1') { $info_list[$key]['merge'] = "

拆分订单

"; } else { $info_list[$key]['merge'] = "已合并"; } } else { $info_list[$key]['merge'] = "被合并"; } } } /** 操作合并 if($value['merge'] == 0) { $info_list[$key]['merge'] = "

合并订单

"; } else { if($value['merge'] == $value['id']) { $info_list[$key]['merge'] = "已合并"; } else { $info_list[$key]['merge'] = "被合并"; } } **/ $asd = array(); for($i=0;$i<$len;$i++) { for($j=$i+1;$j<$len;$j++) { if (strtolower($info_list[$i]['address']) == strtolower($info_list[$j]['address']) && stripos($info_list[$i]['number'],$info_list[$j]['number']) === false && stripos($info_list[$j]['number'],$info_list[$i]['number']) === false) //$info_list[$i]['email'] == $info_list[$j]['email'] { if(!array_key_exists($j,$info)) { $info[$j] = $info_list[$j]; } if(!array_key_exists($i,$info)) { $info[$i] = $info_list[$i]; } } } } rsort($info); $total = count($info); $pagenum = ceil($total/$perpage); $over = $total-($start+$perpage); $rows = array('total'=>$total,'over'=>$over,'pagenum'=>$pagenum,'rows'=>(array_slice($info,$start,$perpage))); echo json_encode($rows);exit; } $wlshop = $this->shop->find_all('1=1 and '.rtrim($sid,'or')); $this->data['wlshop'] = $wlshop; $this->_Template('fullorder_repeat',$this->data); } //修改 public function _edit($arg_array) { if(isset($_SESSION['api'])) { $user = $this->user->get_api($_SESSION['api']); if($user['vip'] == 1) { $vip = 1; } else { $vip = 0; } $this->data['userid'] = $user['id']; } else { $this->data['userid'] = 0; $vip = 0; } $post = $this->input->post(NULL, TRUE); if(isset($post['id'])) { // $dtsbjz = $this->input->post('dtsbjz',true); // $ts = $this->input->post('ts',true); // $dtsbjz = sprintf("%.2f",$dtsbjz); // $total_sbjz = $dtsbjz*$ts; // $tmp_zsbjz = $this->input->post('zsbjz',true); // $tmp_zsbjz = sprintf("%.2f",$tmp_zsbjz); // if($tmp_zsbjz*1 != $total_sbjz){ // echo json_encode(array('msg'=>'单条申报价为2为小数!','success'=>false));exit; // } $id = $this->input->post('id',true); $data = $this->fullorder->read($id); $post['type'] = $this->input->post('warehouse',true); $post['country'] = $this->input->post('country',true); $currency = $this->country->read($post['country']); $post['al'] = $currency['lb']; $post['freight'] = $this->input->post('freight',true); $post['expressmoney'] = $this->input->post('expressmoney',true); $post['shouldmoney'] = $this->input->post('shouldmoney',true); $orderremarks = $this->input->post('orderremarks'); $orderremarks = str_replace(array('%26','%2B'),array('&','+'),$orderremarks); $post['orderremarks'] = $orderremarks; $shipremarks = $this->input->post('shipremarks'); $shipremarks = str_replace(array('%26','%2B'),array('&','+'),$shipremarks); $post['shipremarks'] = preg_replace('/( | | |\s)/',' ',$shipremarks); $email = $this->input->post('email',true); $post['email'] = preg_replace('/( | | |\s)/','',$email); //$post['paypal'] = $this->input->post('paypal',true); $name = $this->input->post('name',true); $post['name'] = str_replace("'","’",$name); $post['phone'] = $this->input->post('phone',true); $post['phone'] = preg_replace('/\D/s','',$post['phone']); $post['phone'] = preg_replace('/( | | |\s)/','',$post['phone']); $post['country'] = $this->input->post('country',true); $post['province'] = $this->input->post('province',true);//省、州 $post['province'] = preg_replace("/^[\s\v".chr(227).chr(128)."]+/","", $post['province']); //替换开头空字符 $post['province'] = preg_replace("/[\s\v".chr(227).chr(128)."]+$/","", $post['province']); //替换结尾空字符 $post['city'] = $this->input->post('city',true);//城市 $post['city'] = preg_replace("/^[\s\v".chr(227).chr(128)."]+/","", $post['city']); //替换开头空字符 $post['city'] = preg_replace("/[\s\v".chr(227).chr(128)."]+$/","", $post['city']); //替换结尾空字符 $post['zipcode'] = $this->input->post('zipcode',true);//邮编 $post['zipcode'] = preg_replace("/^[\s\v".chr(227).chr(128)."]+/","", $post['zipcode']); //替换开头空字符 $post['zipcode'] = preg_replace("/[\s\v".chr(227).chr(128)."]+$/","", $post['zipcode']); //替换结尾空字符 $post['street'] = $this->input->post('street',true); $address = $this->input->post('address',true); $address = preg_replace('/( | | |\s)/',' ',$address); $post['address'] = str_replace("'","’",$address); $address2 = $this->input->post('address2',true); $address2 = preg_replace('/( | | |\s)/',' ',$address2); if($address2 == ' ') { $address2 = ''; } $post['address2'] = str_replace("'","’",$address2); $post['express'] = $this->input->post('express',true); $post['printtype'] = $this->input->post('printtype',true); $fpdata = $this->input->post('fpdata'); $fpdata = str_replace(array('%26','%2B'),array('&','+'),$fpdata); $post['fpdata'] = $fpdata; $post['waybill'] = $this->input->post('waybill',true); $post['msg'] = $this->input->post('msg',true); $post['zsbjz'] = $this->input->post('zsbjz',true); $post['refundy'] = $this->input->post('refundy',true); $post['refundj'] = $this->input->post('refundj',true); $rtime = $this->input->post('rtime',true); $post['rtime'] = strtotime($rtime); $post['rpaypal'] = $this->input->post('rpaypal',true); $post['rtext'] = $this->input->post('rtext',true); $post['sbpm'] = $this->input->post('sbpm',true); $post['edittime'] = time(); $editstate = $this->input->post('state',true); if(!$editstate) { $editstate = $data['state']; } $whlabel = $this->input->post('whlabel',true); $fpcount = $this->input->post('fpcount',true); $post['ioss'] = $this->input->post('ioss',true); $post['waybill'] = preg_replace('/( | | | |\s)/','',$post['waybill']); $pay = $this->pay->get_typeclass($data['pay']); $yga = $post['shouldmoney']; $ygc = $data['estimaterate']; $post['budget'] = 0; if($post['email'] == $post['send_email']){ $post['send_email'] = ''; } $ifbudget = eval("return $yga*1.$ygc;"); if($ifbudget > 0) { $post['budget'] = eval("return $yga*1.$ygc;"); } $whlabeldata = explode('|',trim($whlabel,'|'));$way = 0; foreach ($whlabeldata as $va) { if(stripos($va,'z') !== false) { $way += 1; } } //如果备注中出现网红的两个字 ,那么在fpdata种的品名中必须有 WH这两个字 且美仓不用 if($post['type'] !=5 ){ if(stripos($post['shipremarks'],'网红') !== false){ if(stripos($post['fpdata'],'-2090-') === false){ echo json_encode(array('msg'=>'网红单请在商品名称中勾选WH!','success'=>false));exit; } } } if((($post['express'] == 2 || $post['express'] == 63 || $post['express'] == 64) && $post['type'] != 5) ) { echo json_encode(array('msg'=>'此快递方式必须从美仓发货!','success'=>false));exit; } if( ($post['express'] != 2 && $post['express'] != 63 && $post['express'] != 64 && $post['type'] == 5)){ echo json_encode(array('msg'=>'此快递方式不能美仓发货!','success'=>false));exit; } //仅独立站 地址美国对电话 10或者11位进行判断 if($post['country'] == 192){ if((strlen($post['phone'])!= 10) && (strlen($post['phone'])!= 11)){ echo json_encode(array('msg'=>'美国电话号码应为10/11位!','success'=>false));exit; } } //减少代码复用吧 $lo_ret = $this->logic_order->checkEditExpress($post); if($lo_ret['code'] != 1){ echo json_encode(array('msg'=>$lo_ret['msg'],'success'=>false));exit; } //检测PayPal有但是为空的情况 if(isset($post['paypal'])){ if(empty($post['paypal'])){ echo json_encode(array('msg'=>'交易号不可为空!','success'=>false));exit; } }else{ $tmp_info = $this->fullorder->read($post['id']); if(empty($tmp_info)){ echo json_encode(array('msg'=>'订单信息异常','success'=>false));exit; } if(empty($tmp_info['paypal'])){ echo json_encode(array('msg'=>'交易号不可为空!','success'=>false));exit; } } // if($post['express'] == 42 && $post['sbpm'] != 'Human Hair Wigs' && $post['sbpm'] != 'Human Hair Goods')//$post['express'] == 3 || // { // echo json_encode(array('msg'=>'此快递方式必须选择Human Hair Wigs/Human Hair Goods!','success'=>false));exit; // } if($post['express'] == 24 && $post['sbpm'] != 'Hair Sample' && $post['sbpm'] != 'Human Hair Wigs' && $post['sbpm'] != 'Human Hair Goods')//$post['express'] == 3 || { echo json_encode(array('msg'=>'此快递方式必须选择Hair Sample/Human Hair Wigs/Human Hair Goods!','success'=>false));exit; } if($post['country'] != 192 && $post['express'] == 1 && $post['sbpm'] != 'Synthetic Hair Wigs' && $post['sbpm'] != 'Synthetic Hair Goods')//$post['express'] == 3 || { echo json_encode(array('msg'=>'非美国选择官方DHL必须选择Synthetic Hair Wigs/Synthetic Hair Goods','success'=>false));exit; } if($way == count($whlabeldata) && $post['type'] != 12) { echo json_encode(array('msg'=>'必须选择特殊仓!','success'=>false));exit; } if($way == '0' && $post['type'] == 12) { echo json_encode(array('msg'=>'特殊仓必须包含特殊仓货物!','success'=>false));exit; } $post['review'] = 1; if($post['zsbjz'] < '0.01') { echo json_encode(array('msg'=>'总申报价错误!','success'=>false));exit; } if($data['library'] == 1) { if($data['print'] != 3) { $post['print'] = 1; $post['libraryconfirm'] = 1; $post['librarynot'] = "订单未打印,未审核或未通过"; } else { $post['libraryconfirm'] = 1; $post['librarynot'] = "订单被修改或重新提交"; } } if($data['yhs'] == 1) { echo json_encode(array('msg'=>'仓库货物验证中,请稍后再试!','success'=>false));exit; } if($post['express'] == 2 && (stripos($post['name'],'&') !== false || stripos($post['name'],"'") !== false)) { echo json_encode(array('msg'=>'USPS收件人或公司名不可用特殊符号!','success'=>false));exit; } if(strlen($post['client']) > 34 || strlen($post['name']) > 34)//收件人姓名或公司名不允许超过35位 { echo json_encode(array('msg'=>'收件人姓名或公司名不可超过34个字符!','success'=>false));exit; } if($post['express'] == '3' && $post['address2'] != '')//UPS不允许提交地址2 { echo json_encode(array('msg'=>'UPS不允许提交地址2','success'=>false));exit; } if(($post['express'] == '5' || $post['express'] == '24' || $post['express'] == '42' || $post['express'] == '31') && $post['country'] != 192) { echo json_encode(array('msg'=>'非美国无法选择Fedex、DHL官方-美国!','success'=>false));exit; } if($post['express'] == '3' && $post['country'] != 192 && $post['country'] != 35) { echo json_encode(array('msg'=>'非美国和加拿大无法选择UPS!','success'=>false));exit; } if($post['country'] == 35 && $post['zsbjz'] > 20) { echo json_encode(array('msg'=>'加拿大最高申报不可超过20','success'=>false));exit; } if(($post['express'] == '28' || $post['express'] == '7') && $post['country'] != 191) { echo json_encode(array('msg'=>'非英国无法选择CNE和GES!','success'=>false));exit; } $express = $this->express->read($post['express']); if($express['ioss'] == 1 && $post['ioss'] == '') { echo json_encode(array('msg'=>'此快递方式必须选择IOSS!','success'=>false));exit; } if(strlen($post['address']) > $express['addresssize'] || strlen($post['address2']) > $express['addresssize']) { echo json_encode(array('msg'=>'此快递地址不可超出'.$express['addresssize'].'个字符','success'=>false));exit; } if(strlen($post['address']) < 5) { echo json_encode(array('msg'=>'地址不可留空!','success'=>false));exit; } if(($express['sbjz'] > 0) && ($post['zsbjz'] > $express['sbjz'])) { echo json_encode(array('msg'=>'总申报价值不可超出'.$express['sbjz'],'success'=>false));exit; } if($post['shouldmoney'] > $express['shouldmoney'] && $express['shouldmoney'] != 0) { echo json_encode(array('msg'=>'订单金额不可超出'.$express['shouldmoney'],'success'=>false));exit; } if($post['express'] == '2' && $post['zzl'] > '16' && isset($post['js']) && $post['js'] == '0') { echo json_encode(array('msg'=>'重量大于16不可按Ground Advantage提交!','success'=>false));exit; } // if($post['express'] == '2' && isset($post['js']) && $post['js'] == '0'&& $post['qm'] == '1') // { // echo json_encode(array('msg'=>'Ground Advantage不可使用签名服务!','success'=>false));exit; // } if(isset($post['bx'])) { if($post['express'] == '99' && $post['bx'] > 0) { echo json_encode(array('msg'=>'此物流不允许购买保险','success'=>false));exit; } } if(($post['express'] == '3' || $post['express'] == '42' || $post['express'] == '24') && $post['shouldmoney'] < 1) { //echo json_encode(array('msg'=>'零金额订单不可发 UPS/DHL官方-美国/Fedex(杭州)','success'=>false));exit; } if($post['express'] == '42' && $post['zsbjz'] < 1) { echo json_encode(array('msg'=>'零申报金额不可发 DHL官方-美国','success'=>false));exit; } if($post['express'] == '6' && $post['province'] == '') { echo json_encode(array('msg'=>'选择DPEX必须填写州信息','success'=>false));exit; } if(($post['express'] == '24' || $post['express'] == '3') && $post['shouldmoney'] == 0) { echo json_encode(array('msg'=>'0金额订单不可发UPS/Fedex(杭州)!!!','success'=>false));exit; } if($post['country'] == '35' && $post['zsbjz'] > 20) { echo json_encode(array('msg'=>'加拿大不可申报超过20美金!!!','success'=>false));exit; } if($post['printtype'] == 1)//如果是运单 { $post['productdescription'] = $this->input->post('productdescription',true); $post['customs'] = $this->input->post('customs',true); } if($post['express'] == 2 && strlen($post['zipcode']) != 5)//如果usps 邮编不是5位 { echo json_encode(array('msg'=>'USPS-USA的邮编需按5位数格式提交!','success'=>false));exit; } if(strlen($post['phone']) > 11 && $post['express'] == 63) { echo json_encode(array('msg'=>'美国联邦,电话号码不允许超过11位!','success'=>false));exit; } /** if($post['paypal'] != '') { $pp = $this->fullorder->get_paypal($post['paypal']); if(isset($pp['number']) && $pp['number'] != $data['number']) { echo json_encode(array('msg'=>'此交易号的订单已存在!-'.$pp['number'],'success'=>false));exit; } } **/ /** if($editstate == 216 && $data['state'] != 216) { echo json_encode(array('msg'=>'不可修改为完成状态','success'=>false));exit; } **/ $post['review'] = $data['review']; $post['state'] = $editstate; if($editstate == 216) { foreach ($post as $k=>$v) { if($k == 'shipremarks' || $k == 'whlabel' || $k == 'fpdata' || $k == 'fpcount' || $k == 'refundy' || $k == 'refundj' || $k == 'rtime' || $k == 'rpaypal' || $k == 'rtext' || $k == 'freight' || $k == 'expressmoney' || $k == 'edittime' || $k == 'librarynot' || $k == 'state' || $k == 'jweight' || $k == 'productdescription') { continue; } else { //当时不知道为会把 当前不可修改订单信息 给注释掉 但是 如果注释掉 这个判断就没意义了 还引起了报错 我这里就注释掉了 // if($v != $data[$k]) // { // //echo json_encode(array('msg'=>'当前不可修改订单信息','cs'=>$k,'success'=>false));exit; // } } } } /** if($editstate == 216 && $post['waybill'] != '' && $data['waybill'] != '')//if($editstate == 216 && preg_match('/\d/is',$post['waybill']) != true) { echo json_encode(array('msg'=>'当前信息不可修改订单状态','success'=>false));exit; } else { $post['review'] = $data['review']; $post['state'] = $editstate; } **/ $thisdata = $this->fullorder->read($id); $warehouse = $this->warehouse->read($thisdata['type']); $warehousenew = $this->warehouse->read($post['type']); if($warehousenew['bdcountry'] != 0 && $post['country'] != $warehousenew['bdcountry']) { echo json_encode(array('msg'=>'当前国家无法选择'.$warehousenew['title'].'!','success'=>false));exit; } if(($warehouse['zd'] == '1' || stripos($thisdata['whlabel'],'z|') !== false) && $thisdata['library'] == '2' && $post['type'] != $thisdata['type'])//如果已出库并且开启库存模式仓库或者有特殊库存,禁止调整仓库 { echo json_encode(array('msg'=>'此单已占用库存并出库,无法更改仓库!','success'=>false));exit; } $expt = $this->express->read($post['express']); if($expt['pt'] != '' && stripos($post['fpdata'],$expt['pt']) !== false) { echo json_encode(array('msg'=>$expt['ptts'],'success'=>false));exit; } if($expt['province'] != '' && stripos($expt['province'],$post['province'].'、') !== false) { echo json_encode(array('msg'=>'此省/州不可使用 '.$expt['servicename'],'success'=>false));exit; } /** if($warehouse['zd'] == '1' && $warehouse['ys'] != '1' && $thisdata['library'] == '2' && $post['fpdata'] != $thisdata['fpdata']) { echo json_encode(array('msg'=>'已扣减库存,无法更改产品!','success'=>false));exit; } **/ //开始注释 xyxg /** $ft = array(); $ftdata = explode('|',rtrim($fpcount,'|')); foreach ($ftdata as $va) { $ftitle = ''; $va = explode('-',trim($va,'-')); foreach ($va as $v) { $v = $this->typeclass->read($v); $ftitle .= $v['title'].' '; } $ft[] = rtrim($ftitle,' '); } if($data['library'] == 1) { $tqkcyz = $this->_kcyz($post['type'],$whlabel,$id,$data['shop'],$data['number']); if(isset($tqkcyz[0])) { echo json_encode(array('t'=>2,'msg'=>"红色商品名库存匹配错误或库存不够扣减",'error'=>$tqkcyz,'success'=>false));exit; } if(stripos($whlabel,'z|') !== false || stripos($thisdata['whlabel'],'z|') !== false) { $tskcyz = $this->specialstock->get_kc($thisdata['state'],$post['state'],$whlabel,$thisdata['whlabel'],$thisdata['number']); if($tskcyz['t'] > '0') { echo $tskcyz['m'];exit; } } $kcyz = $this->whlabel->get_kc($thisdata['state'],$post['state'],$warehousenew['zd'],$warehousenew['ys'],$post['type'],$whlabel,$fpcount,$ft,$thisdata['number'],$thisdata['shop'],$thisdata['type'],$thisdata['whlabel']);//旧状态、新状态、仓库占单设置、仓库预设设置、新仓库、新产品简化数字、旧产品数字、旧产品名称、订单号、订单店铺、旧订单仓库、旧产品简化数字 if($kcyz['t'] > '0') { echo $kcyz['m'];exit; } } //结束注释 **/ /** 重新写产品名称 $dtctitle = array(); $dictionaries = $this->typeclass->find_all(); foreach ($dictionaries as $v) { $dtctitle[$v['id']] = array($v['title'],$v['bqsku']); } if(stripos($fpdata,'-128-') !== false || stripos($fpdata,'-127-') !== false) { $dfp = explode(';',trim($fpdata,';')); $fdata = ''; foreach ($dfp as $k=>$v) { $ptitleb = ''; $fp = explode('|',trim($v,'|')); $fp0 = explode(',',$fp[0]); $fp1 = explode('-',trim($fp0[1],'-')); foreach ($fp1 as $vv) { $ptitleb .= isset($dtctitle[$vv])?$dtctitle[$vv][0].' ':''; } $ptitleb .= $dtctitle[$fp0[0]][1].'inch '; $fp[1] = $ptitleb; $fdata .= implode("|",$fp).";"; } $fpdata = $fdata; } **/ $warehouse = $this->warehouse->read($post['type']); //未出库或者(已退库并且订单的状态不是等待买家收货和代发货状态) if($data['library'] == 1 || ($data['library'] != 2 && ($post['state'] != '207' || $post['state'] == '209'))) { // echo "
";
				// var_dump($post['state']);
				// var_dump($warehouse);
				// var_dump($thisdata['shop']);
				// var_dump($thisdata['number']);
				// var_dump($whlabel);
				// var_dump($fpdata);
				// die;
			    $kcyz = $this->ck->get_kc($post['state'],$warehouse,$thisdata['shop'],$thisdata['number'],$whlabel,$fpdata);
			    if($kcyz['t'] > '0')
			    {
				    echo $kcyz['m'];exit;
			    }
			    else if($kcyz['fpdata'] != '')
			    {
				    $post['whlabel'] = $kcyz['whlabel'];
				    $post['fpdata'] = $kcyz['fpdata'];
			    }
			}
			//$fl = $this->ck->get_fl($warehouse['hz'],$whlabel,$fpdata);
			//$post['sfxh'] = $fl['sfxh'];
			//$post['ckfl'] = $fl['ckfl'];
			
			//查询净重开始
			$post['jweight'] = $this->weight->get_weightcx($post['fpdata']);
			unset($post[0]);
			
			//查询净重结束
			    if($this->fullorder->save($post,$id))
        	    {
					if($data['printtime'] == '0')
					{
						$xghz = ',将自动禁止打印';
					}
					else if($data['printtime'] > '0' && $data['librarytime'] == '0')
					{
						$q = '';
						if($data['libraryconfirm'] == 1)
						{
							$q = ',改前状态为:禁止出库';
						}
						$xghz = ',将自动禁止发货'.$q;
					}
					else
					{
						$xghz = '';
					}
         		    echo json_encode(array('msg'=>'修改成功'.$xghz,'id'=>$id,'success'=>true));exit;
       	 	    }
       		    else
        	    {
           		    echo json_encode(array('msg'=>'修改失败,请重试','success'=>false));exit;
        	    }
			
		}
		$this->data['vip'] = $vip;
		$arg_array = $arg_array[0];$fpdata = array();
		$fullorder = $this->fullorder->read($arg_array);
		$returngoods = $this->returngoods->get_orderinfo($fullorder['orderinfo']);
		$this->data['returngoods'] = 0;
		if(!empty($returngoods)){
			if($returngoods['status'] != 120){
				$this->data['returngoods'] = 1;
			}
		}

		$fullorder['parameter'] = str_replace(",","---",$fullorder['parameter']);
		$country = $this->country->find_all('1=1','id,name','name asc');//所有国家信息
		$express = $this->express->find_all('1=1');//所有快递配置信息
		$this->data['fullorder'] = $fullorder;
		if($fullorder['express'] == 2)
		{
			$zzhl = 'oz';
		}
		else
		{
			$zzhl = 'kg';
		}
		$this->data['zzhl'] = $zzhl;
		$this->data['country'] = $country;
		$this->data['express'] = $express;
		$this->data['dtime'] = date('Y-m-d H:i:s',$fullorder['dtime']);
		$warehouse = $this->warehouse->read($fullorder['type']);
		if(stripos($fullorder['fpdata'],';') !== false)
		{
		    $fpdata = explode(';',rtrim($fullorder['fpdata'],';'));
		    foreach ($fpdata as $k=>$v) 
		    {
			    $xxv = explode('|',$v);
				if(isset($xxv[9]) && stripos($xxv[9],$warehouse['hz']) !== false && $warehouse['hz'] != '' && $warehouse['zd'] == 1)
				{
					$xxv['zd'] = "

已占单

"; $bdck = $warehouse['bdck']; if(stripos($xxv[9],'~') !== false) { $dxxv = explode('~',trim($xxv[9],'~')); foreach ($dxxv as $val) { $wzid = $this->$bdck->read(trim($val,$warehouse['hz'])); if($wzid['details'] != '') { $xxv['zd'] .= '

位置:'.$wzid['details'].' - '.$wzid['cpid'].'

'; } } } else { $wzid = $this->$bdck->read(trim($xxv[9],$warehouse['hz'])); if($wzid['details'] != '') { $xxv['zd'] .= '

位置:'.$wzid['details'].' - '.$wzid['cpid'].'

'; } } } $fpdata[$k] = $xxv; } } $fpdata = $this->logic_order->checkOrderProduct($fpdata); $this->data['fpdata'] = $fpdata; $thfpdataxs = array(); if($fullorder['thfpdata'] != '') { $thfpdata = explode(';',trim($fullorder['thfpdata'],';')); foreach ($thfpdata as $k=>$v) { $thxs = explode('~',trim($v,'~')); $thxs[0] = explode('|',trim($thxs[0],'|')); $thxs[1] = explode('|',trim($thxs[1],'|')); $thfpdataxs[] = array("

".$thxs[0][1]."

".$thxs[1][1]."

","

".$thxs[0][2]."

".$thxs[1][2]."

","

",$thxs[1][0]); } } $this->data['thfpdata'] = $thfpdataxs; $shop = $this->shop->read($fullorder['shop']); $this->data['et'] = $shop['estimaterate'];//此店铺配置预计到帐金额比例 $is = 0; if($shop['type'] == 269 || $shop['type'] == 2768)//判断是否独立站,269是独立站 { $is = 1; } $this->data['is'] = $is; if(isset($_SESSION['api'])) { $user = $this->user->get_api($_SESSION['api']); if($user['vip'] == 1) { $vip = 1; } else { $vip = 0; } } else { $vip = 0; } $this->data['power'] = $vip; /** 历史运单号展示并下载PDF 打印时间需要2019-3-21 0点之后有记录 **/ $downwaybill = '';$dwls = array(); $oldwaybill = explode('-',ltrim($fullorder['oldwaybill'],'-')); if(isset($oldwaybill[0][1])) { $oldwaybill = array_reverse($oldwaybill); //调整顺序 foreach ($oldwaybill as $v) { $dw = explode('/',$v); if(isset($dw[1])) { if(stripos($downwaybill,$dw[1]) === false) { $dwls[$dw[1]] = 1; $downwaybill .= ''.$dw[1].'、'; } } } } if($fullorder['printtype'] == 1) { if($fullorder['waybill'] != '' && !isset($dwls[$fullorder['waybill']])) { $downwaybill = ''.$fullorder['waybill'].'、'.$downwaybill; } } $this->data['downwaybill'] = rtrim($downwaybill,'、'); /** 历史打印时间 **/ $printtime = ''; if($fullorder['oldprinttime']) { $pte = explode('-',rtrim($fullorder['oldprinttime'],'-')); foreach ($pte as $v) { if(!empty($v)){ $printtime .= date('Y-m-d H:i:s',$v).'、'; } } } $this->data['printtime'] = rtrim($printtime,'、'); $product = ''; $fullorder['product'] = str_replace("'","",$fullorder['product']); if($fullorder['link'] != '' && $fullorder['source'] != '1') { $pt = explode(',',$fullorder['product']); $lk = explode(',',$fullorder['link']); for($i=0;$icolourorderts->get_texturl($pt[$i],$lk[$i]); } else { $octs = ''; } $a = $octs?''.$pt[$i].'':$pt[$i]; //$a = (stripos($pt[$i],'Lace Front Wig Body Wave Human Hair Wigs Pre Plucked Brazilian Virgin Hair') !== false || stripos($pt[$i],'Deep Wave Wig 100 Human Hair Swiss Lace Curly Hair Lace Front Wig') !== false || stripos($pt[$i],'Alipearl Lace Front Wig Silky Straight 100% Virgin Human Hair') !== false || stripos($pt[$i],'Long Wigs Water Wave Lace Front Wigs Natural Wave Wigs For Sale') !== false || stripos($pt[$i],'Deep Wave Long Hair Wigs Lace Front Wigs Cheap Human Hair Wigs') !== false || stripos($pt[$i],'Long Wigs Loose Deep Wave Lace Front Wigs For Black Women') !== false || stripos($pt[$i],'Long Black Wigs Body Wave Lace Front Wigs With Baby Hair') !== false || stripos($pt[$i],'Long Curly Wigs Lace Front Wigs Human Hair Lace Front Wigs') !== false || stripos($pt[$i],'Blonde Skunk Stripe Hair Natural Body Wave Hairstyle Lace Wigs for Women') !== false)?''.$pt[$i].'':$pt[$i]; if(isset($lk[$i])) { $product .= ($product != '')?' , '.$a.'':''.$a.''; } else { $product .= ($product != '')?' , '.$a:$a; } } } else { $octs = $this->colourorderts->get_text($fullorder['product']); $a = $octs?''.$fullorder['product'].'':$fullorder['product']; //$a = (stripos($fullorder['product'],'Lace Front Wig Body Wave Human Hair Wigs Pre Plucked Brazilian Virgin Hair') !== false || stripos($fullorder['product'],'Deep Wave Wig 100 Human Hair Swiss Lace Curly Hair Lace Front Wig') !== false || stripos($fullorder['product'],'Alipearl Lace Front Wig Silky Straight 100% Virgin Human Hair') !== false || stripos($fullorder['product'],'Long Wigs Water Wave Lace Front Wigs Natural Wave Wigs For Sale') !== false || stripos($fullorder['product'],'Deep Wave Long Hair Wigs Lace Front Wigs Cheap Human Hair Wigs') !== false || stripos($fullorder['product'],'Long Wigs Loose Deep Wave Lace Front Wigs For Black Women') !== false || stripos($fullorder['product'],'Long Black Wigs Body Wave Lace Front Wigs With Baby Hair') !== false || stripos($fullorder['product'],'Long Curly Wigs Lace Front Wigs Human Hair Lace Front Wigs') !== false || stripos($fullorder['product'],'Blonde Skunk Stripe Hair Natural Body Wave Hairstyle Lace Wigs for Women') !== false)?''.$fullorder['product'].'':$fullorder['product']; $product = $a; } $this->data['product'] = $product; $out = $this->systemtransfer->find_all("number = '".$fullorder['number']."'"); $outread = ''; if($out) { foreach ($out as $val) { $list = ''; $rk = explode('|',trim($val['rk'],'|')); $rktime = explode('|',trim($val['rktime'],'|')); $zw = array(); $t = $this->transfer->find_all("1=1"); foreach ($t as $v) { $zw[$v['id']] = $v['title']; } if($val['rk'] != '' && count($rk) > 0) { for($i=0;$i:'.$list.'
'; //$outread .= ''.$val['pm'].':'.$list.'
'; } } else { $systemwigsout = $this->systemwigsout->find_all("number = '".$fullorder['number']."'"); $outread = array(); if($systemwigsout) { foreach ($systemwigsout as $v) { if($v['czwarehouse'] == 37) { $outread[] = '华荣厂'; } else if($v['czwarehouse'] == 0) { $outread[] = '龙盈厂'; } $cz = explode('|',trim($v['cz'],'|')); $cztime = explode('|',trim($v['cztime'],'|')); $zw = $this->transfer->get_list(); if($v['cz'] != '' && count($cz) > 0) { for($i=0;$i'AL','alaska'=>'AK','arizona'=>'AZ','arkansas'=>'AR','california'=>'CA','colorado'=>'CO','connecticut'=>'CT','delaware'=>'DE','florida'=>'FL','georgia'=>'GA','hawaii'=>'HI','idaho'=>'ID','illinois'=>'IL','indiana'=>'IN','iowa'=>'IA','kansas'=>'KS','kentucky'=>'KY','louisiana'=>'LA','maine'=>'ME','maryland'=>'MD','massachusetts'=>'MA','michigan'=>'MI','minnesota'=>'MN','mississippi'=>'MS','missouri'=>'MO','montana'=>'MT','nebraska'=>'NE','nevada'=>'NV','new hampshire'=>'NH','new jersey'=>'NJ','new mexico'=>'NM','new york'=>'NY','north carolina'=>'NC','north dakota'=>'ND','ohio'=>'OH','oklahoma'=>'OK','oregon'=>'OR','pennsylvania'=>'PA','rhode island'=>'RI','south carolina'=>'SC','south dakota'=>'SD','tennessee'=>'TN','texas'=>'TX','utah'=>'UT','vermont'=>'VT','virginia'=>'VA','washington'=>'WA','west virginia'=>'WV','wisconsin'=>'WI','wyoming'=>'WY','district of columbia'=>'DC','virgin islands'=>'VI','guam'=>'GU','puerto rico'=>'PR'); $ToState = array_flip($ToState); $klarnadata3 = str_replace(' ','',$klarnadata[3]); $city = str_replace(' ','',$fullorder['city']); $klarnadataaddress = explode($city,$klarnadata3); if(isset($klarnadataaddress[1])) { $klarnadata3 = $city.$klarnadataaddress[1]; $klarnadatacolor = explode(',',$klarnadata3); unset($klarnadatacolor[4]); unset($klarnadatacolor[6]); if(isset($ToState[$klarnadatacolor[1]])) { $klarnadatacolor[1] = ucwords($ToState[$klarnadatacolor[1]]); } $klarnadata['color'] = $klarnadataaddress[0].implode(",",$klarnadatacolor); } else { $klarnadata['color'] = $klarnadata3; } } } else { $klarnadata = ''; } $p = explode('-',$fullorder['paypal']); $this->data['klarnacolor'] = $klarnacolor; $this->data['klarnadata'] = $klarnadata; $this->data['systemwigsout'] = $outread; $quantity = explode(';',trim($fullorder['quantity'],';')); $qc = 0; foreach ($quantity as $v) { if($v > 1) { $qc += 1; } } $this->data['qc'] = $qc; //新增row_total和sub_total $product_ids = $row_total = $sub_total = ""; if(!empty($fullorder['extra_price'])){ $extra_price = json_decode($fullorder['extra_price'],true); foreach($extra_price as $k=>$v){ $row_total .= sprintf("%.2f",($v['qty']* $v['price'])).";"; $sub_total .= sprintf("%.2f",$v['sub_total']).";"; if(!empty($v['product_id'])){ $product_ids .= $v['product_id'].";"; } } } $this->data['row_total'] = trim($row_total,";"); $this->data['sub_total'] = trim($sub_total,";"); $this->data['product_ids'] = trim($product_ids,";"); $this->_Template('fullorder_edit',$this->data); } //不可修改 public function _readonly($arg_array) { $post = $this->input->post(NULL, TRUE); if(isset($post['id'])) { $id = $this->input->post('id',true); $ud = $this->fullorder->read($id); $post['type'] = $this->input->post('warehouse',true); $post['orderremarks'] = $this->input->post('orderremarks',true); $post['state'] = $this->input->post('state',true); $post['msg'] = $this->input->post('msg',true); $post['refundy'] = $this->input->post('refundy',true); $post['refundj'] = $this->input->post('refundj',true); $fpdata = $this->input->post('fpdata'); $fpdata = str_replace(array('%26','%2B'),array('&','+'),$fpdata); $post['fpdata'] = $fpdata; $rtime = $this->input->post('rtime',true); $post['rtime'] = strtotime($rtime); $post['rpaypal'] = $this->input->post('rpaypal',true); $post['rtext'] = $this->input->post('rtext',true); $post['express'] = $this->input->post('express',true); $whlabel = $this->input->post('whlabel',true); //$post['ioss'] = $this->input->post('ioss',true); $post['edittime'] = time(); $editstate = $post['state']; if(!$editstate) { $editstate = $ud['state']; $post['state'] = $editstate; } /** if($post['state'] == 216 && $ud['state'] != 216) { echo json_encode(array('msg'=>'不可修改为完成状态','success'=>false));exit; } **/ $whlabeldata = explode('|',trim($whlabel,'|'));$way = 0; foreach ($whlabeldata as $va) { if(stripos($va,'z') !== false) { $way += 1; } } if((($post['express'] == 2 || $post['express'] == 63 || $post['express'] == 64) && $post['type'] != 5) || ($post['express'] != 2 && $post['express'] != 63 && $post['express'] != 64 && $post['type'] == 5)) { echo json_encode(array('msg'=>'此快递方式必须选择美仓!','success'=>false));exit; } if($way == count($whlabeldata) && $post['type'] != 12) { echo json_encode(array('msg'=>'必须选择特殊仓!','success'=>false));exit; } if($way == '0' && $post['type'] == 12) { echo json_encode(array('msg'=>'特殊仓必须包含特殊仓货物!','success'=>false));exit; } $fpcount = $this->input->post('fpcount',true); if(!$fpcount) { echo json_encode(array('msg'=>'需要先清理浏览器缓存,刷新当前页面后再试!','success'=>false));exit; } if($ud['library'] == 1) { if($ud['print'] != 3) { $post['print'] = 1; $post['libraryconfirm'] = 1; $post['librarynot'] = "订单未打印,未审核或未通过"; } else { $post['libraryconfirm'] = 1; $post['librarynot'] = "订单被重新提交"; } } if(($post['express'] == '5' || $post['express'] == '24' || $post['express'] == '42' || $post['express'] == '31') && $ud['country'] != 192) { echo json_encode(array('msg'=>'非美国无法选择Fedex、DHL官方-美国!','success'=>false));exit; } if($post['express'] == '3' && $ud['country'] != 192 && $ud['country'] != 35) { echo json_encode(array('msg'=>'非美国和加拿大无法选择UPS!','success'=>false));exit; } if(($post['express'] == '28' || $post['express'] == '7') && $ud['country'] != 191) { echo json_encode(array('msg'=>'非英国无法选择CNE和GES!','success'=>false));exit; } $express = $this->express->read($post['express']); /** if($express['ioss'] == 1 && $post['ioss'] == '') { echo json_encode(array('msg'=>'此快递方式必须选择IOSS!','success'=>false));exit; } **/ $thisdata = $this->fullorder->read($id); $warehouse = $this->warehouse->read($thisdata['type']); $warehousenew = $this->warehouse->read($post['type']); if(($warehouse['zd'] == '1' || stripos($thisdata['whlabel'],'z|') !== false) && $thisdata['library'] == '2' && $post['type'] != $thisdata['type'])//如果已出库并且开启库存模式仓库或者有特殊库存,禁止调整仓库 { echo json_encode(array('msg'=>'此单已占用库存并出库,无法更改仓库!','success'=>false));exit; } if($ud['yhs'] == 1) { echo json_encode(array('msg'=>'仓库货物验证中,请稍后再试!','success'=>false));exit; } $expt = $this->express->read($post['express']); if($expt['pt'] != '' && stripos($post['fpdata'],$expt['pt']) !== false) { echo json_encode(array('msg'=>$expt['ptts'],'success'=>false));exit; } if($expt['province'] != '' && stripos($expt['province'],$ud['province'].'、') !== false) { echo json_encode(array('msg'=>'此省/州不可使用 '.$expt['servicename'],'success'=>false));exit; } if($post['type'] != 5 && in_array($post['express'],[2,63,64])) { echo json_encode(array('msg'=>"此快递方式必须从美仓发货!",'success'=>false));exit; } if($post['type'] == 5 && !in_array($post['express'],[2,63,64])) { echo json_encode(array('msg'=>"此快递方式不能美仓发货!",'success'=>false));exit; } /** if($warehouse['zd'] == '1' && $warehouse['ys'] != '1' && $thisdata['library'] == '2' && $post['fpdata'] != $thisdata['fpdata']) { echo json_encode(array('msg'=>'已扣减库存,无法更改产品!','success'=>false));exit; } **/ /** if($warehousenew['zd'] == '1' && $editstate != $thisdata['state'] && $thisdata['library'] == '1')//如果提交的仓库开启库存模式并且更改订单状态并且未出库,那么拒绝 { echo json_encode(array('msg'=>'如需更改订单状态,请先把仓库选择为非开启库存模式仓库或等待订单出库!','success'=>false));exit; } if($warehousenew['zd'] == '1' && $editstate != '207' && $thisdata['library'] == '1')//如果提交的仓库开启库存模式并且更改订单状态并且未出库,那么拒绝 { echo json_encode(array('msg'=>'非待发货状态,不允许修改为开启库存模式仓库','success'=>false));exit; } **/ //开始注释 xyxg /** $ft = array(); $ftdata = explode('|',rtrim($fpcount,'|')); foreach ($ftdata as $va) { $ftitle = ''; $va = explode('-',trim($va,'-')); foreach ($va as $v) { $v = $this->typeclass->read($v); $ftitle .= $v['title'].' '; } $ft[] = rtrim($ftitle,' '); } $user = $this->user->get_api($_SESSION['api']); if($ud['library'] == 1) { $tqkcyz = $this->_kcyz($post['type'],$whlabel,$id,$ud['shop'],$ud['number']); if(isset($tqkcyz[0])) { echo json_encode(array('t'=>2,'msg'=>"红色商品名库存匹配错误或库存不够扣减",'error'=>$tqkcyz,'success'=>false));exit; } if(stripos($whlabel,'z|') !== false || stripos($thisdata['whlabel'],'z|') !== false) { $tskcyz = $this->specialstock->get_kc($thisdata['state'],$post['state'],$whlabel,$thisdata['whlabel'],$thisdata['number']); if($tskcyz['t'] > '0') { echo $tskcyz['m'];exit; } } $kcyz = $this->whlabel->get_kc($thisdata['state'],$post['state'],$warehousenew['zd'],$warehousenew['ys'],$post['type'],$whlabel,$fpcount,$ft,$thisdata['number'],$thisdata['shop'],$thisdata['type'],$thisdata['whlabel']);//旧状态、新状态、仓库占单设置、仓库预设设置、新仓库、新产品简化数字、旧产品数字、旧产品名称、订单号、订单店铺、旧订单仓库、旧产品简化数字 if($kcyz['t'] > '0') { echo $kcyz['m'];exit; } } //结束注释 **/ if($ud['state'] == 216 && $post['fpdata'] != $ud['fpdata']) { echo json_encode(array('msg'=>'商品信息需要找梦体修改','success'=>false));exit; } $warehouse = $this->warehouse->read($post['type']); if($ud['library'] == 1 || ($ud['library'] != 2 && ($post['state'] != '207' || $post['state'] == '209'))) { $kcyz = $this->ck->get_kc($post['state'],$warehouse,$thisdata['shop'],$thisdata['number'],$whlabel,$fpdata); if($kcyz['t'] > '0') { echo $kcyz['m'];exit; } else if($kcyz['fpdata'] != '') { $post['whlabel'] = $kcyz['whlabel']; $post['fpdata'] = $kcyz['fpdata']; } } $fl = $this->ck->get_fl($warehouse['hz'],$whlabel,$fpdata); $post['sfxh'] = $fl['sfxh']; $post['ckfl'] = $fl['ckfl']; //查询净重开始 $post['jweight'] = $this->weight->get_weightcx($post['fpdata']); //查询净重结束 if($this->fullorder->save($post,$id)) { if($ud['printtime'] == '0') { $xghz = ',将自动禁止打印'; } else if($ud['printtime'] > '0' && $ud['librarytime'] == '0') { $q = ''; if($ud['libraryconfirm'] == 1) { $q = ',改前状态为:禁止出库'; } $xghz = ',将自动禁止发货'.$q; } else { $xghz = ''; } echo json_encode(array('msg'=>'修改成功'.$xghz,'id'=>$id,'cs'=>$ud['state'].' - '.$post['fpdata'].' - '.$ud['fpdata'],'success'=>true));exit; } else { echo json_encode(array('msg'=>'修改失败,请重试','success'=>false));exit; } } $arg_array = $arg_array[0];$fpdata = array(); $fullorder = $this->fullorder->read($arg_array); $returngoods = $this->returngoods->get_orderinfo($fullorder['orderinfo']); $this->data['returngoods'] = $returngoods?1:0; $fullorder['shipremarks'] = str_replace(array('<','>'),array('<','>'),$fullorder['shipremarks']); $fullorder['parameter'] = str_replace(",","---",$fullorder['parameter']); $this->data['fullorder'] = $fullorder; if($fullorder['express'] == 2) { $zzhl = 'oz'; } else { $zzhl = 'kg'; } $this->data['zzhl'] = $zzhl; $this->data['countrys'] = $this->country->find_all(); $this->data['express'] = $this->express->find_all(); $warehouse = $this->warehouse->read($fullorder['type']); if(stripos($fullorder['fpdata'],';') !== false) { $fpdata = explode(';',rtrim($fullorder['fpdata'],';')); foreach ($fpdata as $k=>$v) { $xxv = explode('|',$v); if(isset($xxv[9]) && stripos($xxv[9],$warehouse['hz']) !== false && $warehouse['hz'] != '' && $warehouse['zd'] == 1) { $xxv['zd'] = "

已占单

"; $bdck = $warehouse['bdck']; if(stripos($xxv[9],'~') !== false) { $dxxv = explode('~',trim($xxv[9],'~')); foreach ($dxxv as $val) { $wzid = $this->$bdck->read(trim($val,$warehouse['hz'])); if($wzid['details'] != '') { $xxv['zd'] .= '

位置:'.$wzid['details'].' - '.$wzid['cpid'].'

'; } } } else { $wzid = $this->$bdck->read(trim($xxv[9],$warehouse['hz'])); if($wzid['details'] != '') { $xxv['zd'] .= '

位置:'.$wzid['details'].' - '.$wzid['cpid'].'

'; } } } $fpdata[$k] = $xxv; } } $this->data['fpdata'] = $fpdata; $this->data['fpdata'] = $fpdata; $thfpdataxs = array(); if($fullorder['thfpdata'] != '') { $thfpdata = explode(';',trim($fullorder['thfpdata'],';')); foreach ($thfpdata as $k=>$v) { $thxs = explode('~',trim($v,'~')); $thxs[0] = explode('|',trim($thxs[0],'|')); $thxs[1] = explode('|',trim($thxs[1],'|')); $thfpdataxs[] = array("

".$thxs[0][1]."

".$thxs[1][1]."

","

".$thxs[0][2]."

".$thxs[1][2]."

","

",$thxs[1][0]); } } $this->data['thfpdata'] = $thfpdataxs; $shop = $this->shop->read($fullorder['shop']); $this->data['et'] = $shop['estimaterate'];//此店铺配置预计到帐金额比例 $is = 0; if($shop['type'] == 269 || $shop['type']==2768 )//判断是否独立站,269是独立站 { $is = 1; } $this->data['is'] = $is; //单项开始 $warehouse = $this->warehouse->read($fullorder['warehouse']);//发货仓库 $state = $this->typeclass->read($fullorder['state']);//订单状态 $country = $this->country->read($fullorder['country']);//国家 if($fullorder['capital'] == 1) { $capital = '暂未支付'; } else if($fullorder['capital'] == 2) { $capital = '部分支付'; } else if($fullorder['capital'] == 3) { $capital = '全部支付'; } if($fullorder['printtype'] == 1) { $printtype = '运单'; } else if($fullorder['printtype'] == 2) { $printtype = '发货单'; } else if($fullorder['printtype'] == 3) { $printtype = '不打印单据'; } else { $printtype = '未选择'; } $this->data['warehouse'] = $warehouse['title']; $this->data['state'] = $state['title']; $this->data['capital'] = $capital; $this->data['country'] = $country['name']; $this->data['printtype'] = $printtype; //单项结束 /** 历史运单号展示并下载PDF 打印时间需要2019-3-21 0点之后有记录 **/ $downwaybill = '';$dwls = array(); $oldwaybill = explode('-',ltrim($fullorder['oldwaybill'],'-')); if(isset($oldwaybill[0][1])) { $oldwaybill = array_reverse($oldwaybill); //调整顺序 foreach ($oldwaybill as $v) { $dw = explode('/',$v); if(isset($dw[1])) { if(stripos($downwaybill,$dw[1]) === false) { $dwls[$dw[1]] = 1; $downwaybill .= ''.$dw[1].'、'; } } } } if($fullorder['printtype'] == 1) { if($fullorder['waybill'] != '' && !isset($dwls[$fullorder['waybill']])) { $downwaybill = ''.$fullorder['waybill'].'、'.$downwaybill; } } $this->data['downwaybill'] = rtrim($downwaybill,'、'); /** 历史打印时间 **/ $printtime = ''; if($fullorder['oldprinttime']) { $pte = explode('-',rtrim($fullorder['oldprinttime'],'-')); foreach ($pte as $v) { $printtime .= date('Y-m-d H:i:s',$v).'、'; } } $this->data['printtime'] = rtrim($printtime,'、'); $product = ''; $fullorder['product'] = str_replace("'","",$fullorder['product']); if($fullorder['link'] != '' && $fullorder['source'] != '1') { $pt = explode(',',$fullorder['product']); $lk = explode(',',$fullorder['link']); for($i=0;$icolourorderts->get_texturl($pt[$i],$lk[$i]); } else { $octs = ''; } $a = $octs?''.$pt[$i].'':$pt[$i]; //$a = (stripos($pt[$i],'Lace Front Wig Body Wave Human Hair Wigs Pre Plucked Brazilian Virgin Hair') !== false || stripos($pt[$i],'Deep Wave Wig 100 Human Hair Swiss Lace Curly Hair Lace Front Wig') !== false || stripos($pt[$i],'Alipearl Lace Front Wig Silky Straight 100% Virgin Human Hair') !== false || stripos($pt[$i],'Long Wigs Water Wave Lace Front Wigs Natural Wave Wigs For Sale') !== false || stripos($pt[$i],'Deep Wave Long Hair Wigs Lace Front Wigs Cheap Human Hair Wigs') !== false || stripos($pt[$i],'Long Wigs Loose Deep Wave Lace Front Wigs For Black Women') !== false || stripos($pt[$i],'Long Black Wigs Body Wave Lace Front Wigs With Baby Hair') !== false || stripos($pt[$i],'Long Curly Wigs Lace Front Wigs Human Hair Lace Front Wigs') !== false || stripos($pt[$i],'Blonde Skunk Stripe Hair Natural Body Wave Hairstyle Lace Wigs for Women') !== false)?''.$pt[$i].'':$pt[$i]; if(isset($lk[$i])) { $product .= ($product != '')?' , '.$a.'':''.$a.''; } else { $product .= ($product != '')?' , '.$a:$a; } } } else { $octs = $this->colourorderts->get_text($fullorder['product']); $a = $octs?''.$fullorder['product'].'':$fullorder['product']; //$a = (stripos($fullorder['product'],'Lace Front Wig Body Wave Human Hair Wigs Pre Plucked Brazilian Virgin Hair') !== false || stripos($fullorder['product'],'Deep Wave Wig 100 Human Hair Swiss Lace Curly Hair Lace Front Wig') !== false || stripos($fullorder['product'],'Alipearl Lace Front Wig Silky Straight 100% Virgin Human Hair') !== false || stripos($fullorder['product'],'Long Wigs Water Wave Lace Front Wigs Natural Wave Wigs For Sale') !== false || stripos($fullorder['product'],'Deep Wave Long Hair Wigs Lace Front Wigs Cheap Human Hair Wigs') !== false || stripos($fullorder['product'],'Long Wigs Loose Deep Wave Lace Front Wigs For Black Women') !== false || stripos($fullorder['product'],'Long Black Wigs Body Wave Lace Front Wigs With Baby Hair') !== false || stripos($fullorder['product'],'Long Curly Wigs Lace Front Wigs Human Hair Lace Front Wigs') !== false || stripos($fullorder['product'],'Blonde Skunk Stripe Hair Natural Body Wave Hairstyle Lace Wigs for Women') !== false)?''.$fullorder['product'].'':$fullorder['product']; $product = $a; } $this->data['product'] = $product; $out = $this->systemtransfer->find_all("number = '".$fullorder['number']."'"); $outread = ''; if($out) { foreach ($out as $val) { $list = ''; $rk = explode('|',trim($val['rk'],'|')); $rktime = explode('|',trim($val['rktime'],'|')); $zw = array(); $t = $this->transfer->find_all("1=1"); foreach ($t as $v) { $zw[$v['id']] = $v['title']; } if($val['rk'] != '' && count($rk) > 0) { for($i=0;$i:'.$list.'
'; } } else { $systemwigsout = $this->systemwigsout->find_all("number = '".$fullorder['number']."'"); $outread = array(); if($systemwigsout) { foreach ($systemwigsout as $v) { if($v['czwarehouse'] == 37) { $outread[] = '华荣厂'; } else if($v['czwarehouse'] == 0) { $outread[] = '龙盈厂'; } $cz = explode('|',trim($v['cz'],'|')); $cztime = explode('|',trim($v['cztime'],'|')); $zw = $this->transfer->get_list(); if($v['cz'] != '' && count($cz) > 0) { for($i=0;$i'AL','alaska'=>'AK','arizona'=>'AZ','arkansas'=>'AR','california'=>'CA','colorado'=>'CO','connecticut'=>'CT','delaware'=>'DE','florida'=>'FL','georgia'=>'GA','hawaii'=>'HI','idaho'=>'ID','illinois'=>'IL','indiana'=>'IN','iowa'=>'IA','kansas'=>'KS','kentucky'=>'KY','louisiana'=>'LA','maine'=>'ME','maryland'=>'MD','massachusetts'=>'MA','michigan'=>'MI','minnesota'=>'MN','mississippi'=>'MS','missouri'=>'MO','montana'=>'MT','nebraska'=>'NE','nevada'=>'NV','new hampshire'=>'NH','new jersey'=>'NJ','new mexico'=>'NM','new york'=>'NY','north carolina'=>'NC','north dakota'=>'ND','ohio'=>'OH','oklahoma'=>'OK','oregon'=>'OR','pennsylvania'=>'PA','rhode island'=>'RI','south carolina'=>'SC','south dakota'=>'SD','tennessee'=>'TN','texas'=>'TX','utah'=>'UT','vermont'=>'VT','virginia'=>'VA','washington'=>'WA','west virginia'=>'WV','wisconsin'=>'WI','wyoming'=>'WY','district of columbia'=>'DC','virgin islands'=>'VI','guam'=>'GU','puerto rico'=>'PR'); $ToState = array_flip($ToState); $klarnadata3 = str_replace(' ','',$klarnadata[3]); $city = str_replace(' ','',$fullorder['city']); $klarnadataaddress = explode($city,$klarnadata3); if(isset($klarnadataaddress[1])) { $klarnadata3 = $city.$klarnadataaddress[1]; $klarnadatacolor = explode(',',$klarnadata3); unset($klarnadatacolor[4]); unset($klarnadatacolor[6]); if(isset($ToState[$klarnadatacolor[1]])) { $klarnadatacolor[1] = ucwords($ToState[$klarnadatacolor[1]]); } $klarnadata['color'] = $klarnadataaddress[0].implode(",",$klarnadatacolor); } else { $klarnadata['color'] = $klarnadata3; } } } else { $klarnadata = ''; } $p = explode('-',$fullorder['paypal']); $this->data['klarnacolor'] = $klarnacolor; $this->data['klarnadata'] = $klarnadata; $this->data['systemwigsout'] = $outread; $quantity = explode(';',trim($fullorder['quantity'],';')); $qc = 0; foreach ($quantity as $v) { if($v > 1) { $qc += 1; } } $this->data['qc'] = $qc; //新增row_total和sub_total $product_ids = $row_total = $sub_total = ""; if(!empty($fullorder['extra_price'])){ $extra_price = json_decode($fullorder['extra_price'],true); foreach($extra_price as $k=>$v){ $row_total .= sprintf("%.2f",($v['qty']* $v['price'])).";"; $sub_total .= sprintf("%.2f",$v['sub_total']).";"; if(!empty($v['product_id'])){ $product_ids .= $v['product_id'].";"; } } } $this->data['row_total'] = trim($row_total,";"); $this->data['sub_total'] = trim($sub_total,";"); $this->data['product_ids'] = trim($product_ids,";"); $this->_Template('fullorder_readonly',$this->data); } //浏览列表 public function _readlist() { if(isset($_SESSION['api'])) { $user = $this->user->get_api($_SESSION['api']); $usp = $user; $fgshop = "";$sid = ""; $usersp = explode('|',trim($user['shop'],'|')); foreach ($usersp as $value) { $fgshop .= " shop = ".$value." or"; $sid .= " id = ".$value." or"; } } $post = $this->input->post(NULL, TRUE); if(isset($post['page'])) { $page = $this->input->post('page',true); $perpage = $this->input->post('perpage',true); $shop = $this->input->post('shop',true); $warehouse = $this->input->post('warehouse',true); $express = $this->input->post('express',true); $state = $this->input->post('state',true); $print = $this->input->post('print',true); $libraryconfirm = $this->input->post('libraryconfirm',true); $orderinfo = $this->input->post('orderinfo',true); $client = $this->input->post('name',true); $email = $this->input->post('email',true); $number = $this->input->post('number',true); $waybill = $this->input->post('waybill',true); $authorid = $this->input->post('authorid',true); $sourcecontentid = $this->input->post('sourcecontentid',true); $timetk = $this->input->post('timetk',true); $timetj = $this->input->post('timetj',true); $timetk = strtotime($timetk); $timetj = strtotime($timetj); $where = "1=1 and mergeid = 0 and (".rtrim($fgshop,'or').")"; if($shop) { $where .= " and shop = '$shop'"; } if($warehouse) { $where .= " and type = '$warehouse'"; } if($express) { $where .= " and express = '$express'"; } if($state) { $where .= " and state = '$state'"; } if($print) { $where .= " and print = '$print'"; } if($libraryconfirm) { $where .= " and libraryconfirm = '$libraryconfirm'"; } if($orderinfo) { $where .= " and orderinfo = '$orderinfo'"; } if($client) { $where .= " and client like '%$client%'"; } if($email) { $where .= " and email = '$email'"; } if($number) { $where .= " and number = '$number'"; } if($waybill) { $where .= " and waybill = '$waybill'"; } if($authorid) { $where .= " and authorid = '$authorid'"; } if($sourcecontentid) { $where .= " and sourcecontentid = '$sourcecontentid'"; } if($timetk && $timetj) { $timetj = $timetj+24*3600; $where .= " and dtime > '$timetk' and dtime < '$timetj'"; } //数据排序 $order_str = "dtime desc"; if(empty($page)) { $start = 0; $perpage = 1; } else { $start = ($page - 1)*$perpage; } //取得信息列表 $info_list = $this->fullorder->find_all($where,'id,shop,type,orderinfo,number,sname,state,buytime,review,libraryconfirm,express,waybill,exstate,orderremarks,library,clientremarks,waybillid',$order_str,$start,$perpage); //格式化数据 $dt = 0; foreach ($info_list as $key=>$value) { $ud = $this->fullorder->read($value['id']); $ud['address'] = str_replace("'","’",$ud['address']); $ud['name'] = str_replace("'","’",$ud['name']); $customer = $this->customer->get_email($ud['email'],$value['shop']); $customernum = $this->fullorder->find_count("email = '".$ud['email']."' and shop = '".$value['shop']."'"); preg_match_all('/[0-9]/u',$ud['phone'],$result); $numphone = join('',$result[0]); $customerb = $this->customer->find_all("type = 2 and (email = '".$ud['email']."' or address = '".$ud['address']."' or numphone = '".$numphone."')",'*','id desc'); $customerc = $this->customer->find_all("type = 1 and shop = '".$ud['shop']."' and address = '".$ud['address']."' and numphone = '".$numphone."'",'*','id desc'); //$a = array_column($customer, 'email'); //三维找其中健的数组 //$a = array_flip($a); //键和值调换 $lkh = $value['sname']; $djlkh = 0;$djhmd = 0; if($customer) { if(($customer['type'] == 1 && $customernum > 1))// || $customerc['type'] == 1 && $customerc['num'] > 1 { $count = $customer['count']?'':''; $lkh = "

".$value['sname']."

".$count."老客户

"; $djlkh = 1; $djcount = $count; } else if(isset($customerc[0]['num'])) { if($customerc[0]['num'] > 1) { $count = $customer['count']?'':''; $lkh = "

".$value['sname']."

".$count."老客户

"; $djlkh = 1; $djcount = $count; } } } if($customerb) { $hmsp = $this->shop->read($customerb[0]['shop']); $count = $customerb[0]['count']?'':''; $lkh = "

".$value['sname']."

".$count."黑名单

来自".$hmsp['shopname']."

"; $djhmd = 1; } if($djlkh == '1' && $djhmd == '1') { $lkh = "

".$value['sname']."

".$djcount."老客户 - ".$count."黑名单

来自".$hmsp['shopname']."

"; } $info_list[$key]['sname'] = $lkh; $shop = $this->shop->read($value['shop']); $info_list[$key]['shop'] = $shop['shopname']; //$info_list[$key]['user'] = $shop['shopuser']; $warehouse = $this->warehouse->read($value['type']); $warehousetitle = $warehouse['title']; if($value['type'] != 1){$warehousetitle = "".$warehouse['title']."";} $info_list[$key]['type'] = $warehousetitle; $typeclass = $this->typeclass->read($value['state']); $info_list[$key]['state'] = $typeclass['spare']; $wl = ''; if($value['exstate'] == '99') { $wl = '未获取到物流信息'; } else if($value['exstate'] == '1') { $wl = '已揽收'.$ud['excontent'].''; } else if($value['exstate'] == '2') { $wl = '在途中'.$ud['excontent'].''; } else if($value['exstate'] == '3') { $wl = '派送中'.$ud['excontent'].''; } else if($value['exstate'] == '4') { $wl = '已签收'.$ud['excontent'].''; } else if($value['exstate'] == '5') { $wl = '派送异常'.$ud['excontent'].''; } $info_list[$key]['exstate'] = $wl.'
'; if($ud['source'] == 1) //线下单用订单时间,其他用付款时间 { $info_list[$key]['buytime'] = '

'.date('Y-m-d',$ud['dtime']).'

'.date('H:i:s',$ud['dtime']).'

'; } else { $info_list[$key]['buytime'] = '

'.date('Y-m-d',$value['buytime']+$dt).'

'.date('H:i:s',$value['buytime']+$dt).'

'; } if($value['review'] == 1) { $info_list[$key]['review'] = "未送审"; } else if($value['review'] == 2) { $info_list[$key]['review'] = "待审核"; } else if($value['review'] == 3) { $info_list[$key]['review'] = "不通过"; } else if($value['review'] == 4) { $info_list[$key]['review'] = "取消重审"; } else if($value['review'] == 5) { $info_list[$key]['review'] = "审核通过"; } else if($value['review'] == 6) { $info_list[$key]['review'] = "自动通过"; } if($ud['dlz'] == 1) { $dlz = "

独立站已更新

"; } else if($ud['dlz'] == 3) { $dlz = "

不需要更新

"; } else if($ud['dlz'] == 2) { $dlz = "

独立站更新失败

"; } else { $dlz = ""; } if($value['waybill'] != "") { $info_list[$key]['waybill'] = "

".$value['waybill']."

".$dlz; if( !empty($value['waybillid'])){ $info_list[$key]['waybill'] = "

".$value['waybill']."

".$dlz."

".$value['waybillid']."

"; } } if($value['express'] != 0) { $express = $this->express->read($value['express']); $expressservicename = $express['servicename']; if($value['express'] != 1){$expressservicename = "".$express['servicename']."";} $info_list[$key]['express'] = $expressservicename; } else { $info_list[$key]['express'] = "无"; } $tly = ""; if($value['clientremarks'] != "") { $tly = "

有客户留言

"; } if($value['library'] == 1 && $ud['printtype'] == 3) { $info_list[$key]['library'] = "不需要"; } else if($value['library'] == 1 && $ud['printtype'] != 3) { $info_list[$key]['library'] = "未出库"; } else if($value['library'] == 2) { $info_list[$key]['library'] = '

'.date('Y-m-d',$ud['librarytime']).'

'.date('H:i:s',$ud['librarytime']).'出库

'; } else if($value['library'] == 3) { $info_list[$key]['library'] = '

'.date('Y-m-d',$ud['retreattime']).'

'.date('H:i:s',$ud['retreattime']).'退库

'; } if($ud['authorid'] != '' && $ud['authorid'] != 0) { $info_list[$key]['orderremarks'] = '

'.$value['orderremarks'].'

author_id:

'.$ud['authorid'].'

source_content_id:

'.$ud['sourcecontentid'].'

'; } unset($info_list[$key]['waybillid']); } $total = $this->fullorder->find_count($where); $pagenum = ceil($total/$perpage); $over = $total-($start+$perpage); $rows = array('total'=>$total,'over'=>$over,'pagenum'=>$pagenum,'rows'=>($info_list)); echo json_encode($rows);exit; } $wlshop = $this->shop->find_all('1=1 and '.rtrim($sid,'or')); $this->data['wlshop'] = $wlshop; $this->_Template('fullorder_readlist',$this->data); } public function _readlistdown() { if(isset($_SESSION['api'])) { $user = $this->user->get_api($_SESSION['api']); $usp = $user; $fgshop = "";$sid = ""; $usersp = explode('|',trim($user['shop'],'|')); foreach ($usersp as $value) { $fgshop .= " shop = ".$value." or"; $sid .= " id = ".$value." or"; } } $post = $this->input->get(NULL, TRUE); if(isset($post['excel'])) { $shop = $this->input->get('shop',true); $warehouse = $this->input->get('warehouse',true); $express = $this->input->get('express',true); $state = $this->input->get('state',true); $print = $this->input->get('print',true); $libraryconfirm = $this->input->get('libraryconfirm',true); $orderinfo = $this->input->get('orderinfo',true); $client = $this->input->get('name',true); $email = $this->input->get('email',true); $number = $this->input->get('number',true); $waybill = $this->input->get('waybill',true); $authorid = $this->input->get('authorid',true); $sourcecontentid = $this->input->get('sourcecontentid',true); $timetk = $this->input->get('timetk',true); $timetj = $this->input->get('timetj',true); $timetk = strtotime($timetk); $timetj = strtotime($timetj); $where = "1=1 and mergeid = 0 and (".rtrim($fgshop,'or').")"; if($shop) { $where .= " and shop = '$shop'"; } if($warehouse) { $where .= " and type = '$warehouse'"; } if($express) { $where .= " and express = '$express'"; } if($state) { $where .= " and state = '$state'"; } if($print) { $where .= " and print = '$print'"; } if($libraryconfirm) { $where .= " and libraryconfirm = '$libraryconfirm'"; } if($orderinfo) { $where .= " and orderinfo = '$orderinfo'"; } if($client) { $where .= " and client like '%$client%'"; } if($email) { $where .= " and email = '$email'"; } if($number) { $where .= " and number = '$number'"; } if($waybill) { $where .= " and waybill = '$waybill'"; } if($authorid) { $where .= " and authorid = '$authorid'"; } if($sourcecontentid) { $where .= " and sourcecontentid = '$sourcecontentid'"; } if($timetk && $timetj) { $timetj = $timetj+24*3600; $where .= " and dtime > '$timetk' and dtime < '$timetj'"; } //数据排序 $order_str = "dtime desc"; //取得信息列表 $info_list = $this->fullorder->find_all($where,'shop,number,orderinfo,buytime,name,express,waybill,email,shipremarks,shouldmoney,orderremarks,librarytime,authorid,sourcecontentid',$order_str); //格式化数据 $dt = 0; foreach ($info_list as $key=>$value) { $shop = $this->shop->read($value['shop']); $info_list[$key]['shop'] = $shop['shopname']; $info_list[$key]['buytime'] = date('Y-m-d H:i:s',$value['buytime']); if($value['librarytime'] > 0) { $info_list[$key]['librarytime'] = date('Y-m-d H:i:s',$value['librarytime']); } if($value['express'] != 0) { $express = $this->express->read($value['express']); $info_list[$key]['express'] = $express['servicename']; } else { $info_list[$key]['express'] = "无"; } } $title = "订单列表 ".date("Y-m-d"); $titlename = "

".$title."

店铺 编号 订单号 订单日期 客户姓名 快递方式 运单号 邮箱 仓库品名 订单金额 订单备注 出库时间 author_id source_content_id
"; $filename = $title.".xls"; $tail = "\n"; $this->excel->get_fz2($info_list,$titlename,$filename,$tail); } } //删除 public function _del() { $post = $this->input->post(NULL, TRUE); if(isset($post['s'])) { $id_arr = $this->input->post('s'); $id_arr = explode(',',$id_arr); if(!$id_arr) { echo json_encode(array('msg'=>'参数错误!','success'=>false));exit; } //循环删除记录 foreach ($id_arr as $v) { $this->fullorder->remove($v); } echo json_encode(array('del'=>$id_arr,'msg'=>'删除记录成功!','success'=>true)); } } //查找商品价格 public function _price() { $post = $this->input->post(NULL, TRUE); if(isset($post['data'])) { $data = $this->input->post('data'); $data = explode('-',$data); $number = '';$num = count($data); //循环删除记录 for($i=0;$i<$num-1;$i++) { if($data[$i] != 0) { $number=$number.$data[$i]; if($i == 2) { $number=$number.$data[$num-1]; } } } $list = $this->productdescribe->get_number($number); if($list) { echo json_encode(array('msg'=>($list),'n'=>$data[$num-1],'number'=>$number,'success'=>true)); } else { $list = array('purchase'=>0,'cost'=>0,'salesprice'=>0); //echo json_encode(array('msg'=>'此信息没有配置价格!','n'=>$data[$num-1],'success'=>false));exit; echo json_encode(array('msg'=>($list),'n'=>$data[$num-1],'number'=>$number,'success'=>true));exit; } } } public function _customs() { $post = $this->input->post(NULL, TRUE); if(isset($post['e'])) { $e = $this->input->post('e');//快递信息 $c = $this->input->post('c');//国家信息 $data = $this->customs->find_all('express = "'.$e.'" and country = "'.$c.'"'); $list = $this->productdescription->find_all('express = "'.$e.'" and country = "'.$c.'"'); $rows = array(); foreach ($data as $key=>$value) { $detailed = explode('|',trim($value['detailed'],'|')); //此处未对比重量选择价值,暂直接选择第一条海关价值 $detailed = $this->detailed->read($detailed[0]); $money = $detailed['customsval'];//找到海关价值 } foreach ($list as $key=>$value) { $description = $this->typeclass->read($value['description']); $list[$key]['title'] = $description['title'];//产品描述名称 } if(!$data && !$list) { echo json_encode(array('msg'=>'无此快递配置信息!','success'=>false));exit; } else { //$list-title -description 取值 echo json_encode(array('money'=>sprintf("%.2f",$money),'msg'=>$list,'success'=>true)); } } } public function _express() { $post = $this->input->post(NULL, TRUE); if(isset($post['e'])) { $e = $this->input->post('e');//快递信息 $c = $this->input->post('c');//国家信息 $data = $this->logistics->find_all('express = "'.$e.'" and country = "'.$c.'"'); if(!$data) { echo json_encode(array('success'=>false));exit; } else { echo json_encode(array('money'=>sprintf("%.2f",$data[0]['firstmoney']),'success'=>true)); } } } public function _hl() { $post = $this->input->post(NULL, TRUE); if(isset($post['cy'])) { $hl = 0; $cy = $this->input->post('cy');//币种ID $cy = $this->typeclass->read($cy); $gethl = $this->hl->get_hl(); foreach ($gethl as $v) { $code = str_replace(" ","",$v['code']); if($code == $cy['title']) { $hl = $v['refePrice']/100; } } echo json_encode(array('msg'=>$hl,'success'=>true)); } } public function _operation() { $post = $this->input->post(NULL, TRUE); if(isset($post['type'])) { $type = $this->input->post('type'); $id = $this->input->post('id'); $msg = $this->input->post('msg'); $d = $this->fullorder->read($id); $time = time(); if($type == 1)//禁止发货 { if($d['library'] != 1) { echo json_encode(array('msg'=>'操作失败,订单非未出库状态!','success'=>false));exit; } if($msg == "") { echo json_encode(array('msg'=>'必须填写禁止原因!','success'=>false));exit; } if($d['print'] < 3) { $a = "订单未打印,"; } else { $a = ""; } if($this->fullorder->save(array('libraryconfirm'=>1,'librarynot'=>$a.$msg),$id)) { echo json_encode(array('msg'=>'操作成功','l'=>1,'d'=>$id,'success'=>true));exit; } else { echo json_encode(array('msg'=>'操作失败,请重试','success'=>false));exit; } } if($type == 6)//允许发货 { if($d['library'] > 1) { echo json_encode(array('msg'=>'订单已出库,操作失败','success'=>false));exit; } if($d['print'] < 3) { $a = "订单未打印,"; } else { $a = ""; } if($this->fullorder->save(array('libraryconfirm'=>2,'librarynot'=>$a.$msg),$id)) { echo json_encode(array('msg'=>'操作成功','l'=>1,'d'=>$id,'success'=>true));exit; } else { echo json_encode(array('msg'=>'操作失败,请重试','success'=>false));exit; } } if($type == 7)//禁止打印 { if($d['printtime'] != 0) { echo json_encode(array('msg'=>'订单已打印,操作失败','success'=>false));exit; } if($d['library'] > 1) { echo json_encode(array('msg'=>'订单已出库,操作失败','success'=>false));exit; } if($d['print'] < 3) { $a = "订单未打印,"; } else { $a = ""; } if($this->fullorder->save(array('print'=>1),$id)) { echo json_encode(array('msg'=>'操作成功','l'=>2,'d'=>$id,'success'=>true));exit; } else { echo json_encode(array('msg'=>'操作失败,请重试','success'=>false));exit; } } if($type == 8)//允许打印 { /** if($d['printtime'] != 0) { echo json_encode(array('msg'=>'订单已打印,操作失败','success'=>false));exit; } **/ if($d['library'] > 1) { echo json_encode(array('msg'=>'订单已出库,操作失败','success'=>false));exit; } if($d['print'] < 3) { $a = "订单未打印,"; } else { $a = ""; } if($d['printtime'] == '0') { $bcprint = 2; } else { $bcprint = 3; } if($this->fullorder->save(array('print'=>$bcprint,'failed'=>''),$id)) { echo json_encode(array('msg'=>'操作成功','l'=>2,'d'=>$id,'success'=>true));exit; } else { echo json_encode(array('msg'=>'操作失败,请重试','success'=>false));exit; } } if($type == 9)//关闭 { if($this->fullorder->save(array('failed'=>''),$id)) { echo json_encode(array('msg'=>'操作成功','l'=>2,'d'=>$id,'success'=>true));exit; } else { echo json_encode(array('msg'=>'操作失败,请重试','success'=>false));exit; } } if($type == 2)//填写运单、修改运单 { if($d['express'] == 0) { echo json_encode(array('msg'=>'操作失败,未选择物流方式!','success'=>false));exit; } if($d['library'] == 3 || ($d['print'] == 3 && $d['libraryconfirm'] == 1)) { echo json_encode(array('msg'=>'操作失败,不允许填写运单号!','success'=>false));exit; } if($msg == '') { echo json_encode(array('msg'=>'运单号不能为空!','success'=>false));exit; } $ckemail = ''; $d['waybill'] = $msg; $xg = $this->fullorder->read($id); $shop = $this->shop->read($xg['shop']); $ex = $this->express->read($xg['express']); $fs = $this->notice->find_all("shop = '".$d['shop']."' and message = '1' and state = '1' and type = '4' and ktime < '$time' and jtime > '$time'"); if(isset($fs[0])) { $fs = $fs[0]; $fs['email'] = $this->emaildata->read($fs['email']); if(($xg['dlzemail'] == 1 && $msg != $xg['waybill']) || $xg['dlzemail'] == 0) { $warehouse = $this->warehouse->read($xg['type']); $ck = $this->notice->get_god($d,$shop,$ex,$fs); if($ck == 1) { $ckemail = '邮件发送成功,'; $this->fullorder->save(array('dlzemail'=>1,'dlzemailtime'=>time()),$id); } } } if( $msg ) { if($xg['source'] != 1) { $ms = $this->message->find_all("express like '%,".$xg['express'].",%'"); if(!isset($ms[0])) { $ms = $this->message->read(2); } else { $ms = $ms[0]; } if($xg['shop'] == 5){ $ddh = $xg['orderinfo']; }else{ $ddh = substr($xg['orderinfo'],1); } $shopifyid = $xg['shopify']; //独立站地址更新订单状态、物流信息 $shopname = $shop['brandname']; //店铺名 $buyername = $xg['bname']; //Bill Name $email_call = $shop['shopid']; //发货人邮箱; $phone = $shop['shopphone']; //发货人电话 $track_type = $ex['title']; //快递名称 $service = $ex['title']; //快递追踪名称 $track_link = $ex['url']; //快递查询网址 $logistics_number = $msg; //运单号 $t= array('%buyername%','%email_call%','%track_type%','%service%','%track_link%','%logistics_number%','%shop%','%phone%','%jtime%'); $h= array($buyername,$email_call,$track_type,$service,$track_link,$logistics_number,$shopname,$phone,$ex['yjtime']); $remark = str_replace($t,$h,$ms['content']); $gx = $this->api->get_gx($ddh,$msg,$xg,$shop,$ex,$remark,$shopifyid); } else if($xg['source'] == 1) { $gx['res'] = 3; $gx['state'] = 216; $gx['cw'] = 'a'; } } else { $gx['res'] = $xg['dlz']; $gx['state'] = $xg['state']; $gx['cw'] = 'b'; } $xg['iscode'] = $ex['title']; $xg['url'] = $shop['shopname']; $xg['waybill'] = $msg; @$chuanshu = $this->api->get_paypal($xg); $this->afspaypal->insert(array('number'=>$xg['number'],'cs'=>$chuanshu)); $msg = preg_replace('/( | | | |\s)/','',$msg); if($this->fullorder->save(array('waybill'=>$msg,'state'=>$gx['state'],'dlz'=>$gx['res']),$id)) { if($gx['res'] == 2) { echo json_encode(array('msg'=>$ckemail.'传输独立站失败!','cs'=>$gx['state'].' - '.$gx['res'].' - '.$gx['cw'],'success'=>false));exit; } echo json_encode(array('msg'=>'操作成功','success'=>true));exit; } else { echo json_encode(array('msg'=>'操作失败,请重试','success'=>false));exit; } } } } public function _merge() { $post = $this->input->post(NULL, TRUE); if(isset($post['s'])) { $id_arr = $this->input->post('s'); $id_arr = explode(',',trim( $id_arr,',')); $id_arr = array_reverse($id_arr); if(!$id_arr) { echo json_encode(array('msg'=>'参数错误!','success'=>false));exit; } if(count($id_arr) < 2) { echo json_encode(array('msg'=>'缺少可合并单!','success'=>false));exit; } $tmp_list = $this->db->from('fullorder')->where_in('id',$id_arr)->select('id,orderinfo,number,type,express')->get()->result_array(); $count_warehouse_list = []; $count_express_list = []; $flag = 0; $flag_str = ''; foreach ($tmp_list as $k => $v) { $count_warehouse_list[$v['type']] = $v['type']; if(empty($v['express'])){ $flag = 1; $flag_str.= $v['number'].'仓库未选,请先选快递;'; } $count_express_list[$v['express']] = $v['express']; } if($flag == 1){ echo json_encode(array('msg'=>$flag_str,'success'=>false));exit; } if(count($count_warehouse_list) > 1){ echo json_encode(array('msg'=>'合并单的仓库不一致,无法合并!','success'=>false));exit; } if(count($count_express_list) > 1){ echo json_encode(array('msg'=>'合并单的快递不一致,无法合并!','success'=>false));exit; } $post = array(); $u = $this->fullorder->read($id_arr[0]); unset($id_arr[0]); $this->db->trans_begin(); $hd = $this->fullorderhb->get_orderinfo($u['orderinfo']); if(!$hd) { $this->fullorderhb->insert($u); } //相加 $post['shouldmoney'] = $u['shouldmoney'];//购买应收金额 $post['budget'] = $u['budget'];//预估到帐金额 $post['expressmoney']= $u['expressmoney'];//物流金额 //$post['refundy'] = $u['refundy'];//补/退原额 //$post['refundj'] = $u['refundj'];//补/退净额 $post['cost'] = $u['cost'];//成本金额 //$post['zzl'] = $u['zzl'];//总重量 //$post['zsbjz'] = $u['zsbjz'];//总申报价值 $post['ts'] = $u['ts'];//条数 $post['cost'] = $u['cost'];//成本金额 //追加 $post['rpaypal'] = $u['rpaypal'];//补/退交易号 $post['rtext'] = $u['rtext'];//补/退原因 $post['pay'] = $u['pay'];//付款方式 $post['paypal'] = $u['paypal'];//交易号 $post['clientremarks'] = $u['clientremarks'];//客户留言 $post['product'] = $u['product'];//商品名称 //$post['issku'] = $u['issku'];//sku //$post['orderremarks'] = $u['orderremarks'];//订单备注 $post['shipremarks'] = $u['shipremarks'];//仓库品名 //产品追加 $post['fpdata'] = $u['fpdata'];//产品内容 $post['whlabel'] = $u['whlabel'];//产品对应库存码 $merge = $u['id']; $d = array($u['id']);$order = ''; $zsl = 0;$zccsl = 0; foreach ($id_arr as $v) { $v = $this->fullorder->read($v); if($u['type'] != $v['type']) { echo json_encode(array('msg'=>'仓库不一致,无法合并!','success'=>false));exit; } if($v['shop'] = $u['shop']) { $hd = $this->fullorderhb->get_orderinfo($v['orderinfo']); if(!$hd) { $this->fullorderhb->insert($v); } //$post['shouldmoney'] += $v['shouldmoney'];//购买应收金额 // $post['budget'] += $v['budget'];//预估到帐金额 // $post['expressmoney'] += $v['expressmoney'];//物流金额 //$post['refundy'] += $v['refundy'];//补/退原额 //$post['refundj'] += $v['refundj'];//补/退净额 $post['cost'] += $v['cost'];//成本金额 //$post['zzl'] += $v['zzl'];//总重量 //$post['zsbjz'] += $v['zsbjz'];//总申报价值 $post['ts'] += $v['ts'];//条数 //$post['rpaypal'] .= $v['rpaypal'];//补/退交易号 //$post['rtext'] .= $v['rtext'];//补/退原因 //$post['pay'] .= (stripos($post['pay'],$v['pay']) !== false)?'':';'.$v['pay'];//付款方式 //$post['paypal'] .= $v['paypal'];//交易号 $post['clientremarks'] .= $v['clientremarks'];//客户留言 $post['product'] .= $v['product'];//商品名称 //$post['issku'] .= $v['issku'];//sku //$post['orderremarks'] .= $v['orderremarks'];//订单备注 $post['shipremarks'] .= $v['shipremarks'];//仓库品名 $post['fpdata'] .= $v['fpdata'];//产品内容 $post['whlabel'] .= ltrim($v['whlabel'],'|');//产品对应库存码 $d[] = $v['id']; $order .= $v['orderinfo'].'('.$v['number'].')、'; $wl = $this->whlabel->find_all("zd = '".$v['number']."'");//查找是否有占用库存情况 $i = 0; if($wl)//如果有那么清除所有占用 { foreach ($wl as $val) { if($val['sku'] == 'Preset' && $val['state'] == '9') { $this->whlabel->remove($val['id']);//删除预设 $i++; } else { $this->whlabel->save(array('zd'=>''),$val['id']);//专属 $i++; } } } $zsl += count($wl); $zccsl += $i; $this->fullorder->save(array('merge'=>$u['id'],'mergeid'=>1,'orderremarks'=>' 《合并信息》:'.'已合并到'.$u['orderinfo'].'('.$u['number'].')中; '.$v['orderremarks'],'print'=>1,'libraryconfirm'=>1,'whlabel'=>'','fpdata'=>'','shipremarks'=>''),$v['id']); } } //计算出单条价值 /** if($post['zsbjz'] < 1 || $post['ts'] < 1) { //$post['dtsbjz'] = 0; } else { //$post['dtsbjz'] = $post['zsbjz']/$post['ts'];//单条申报价 } **/ $post['orderremarks'] = ' 《合并信息》:由'.rtrim($order,'、').'合并而来; '.$u['orderremarks'];; $post['merge'] = $u['id']; //$post['mergeid'] = 1; //合并重复项 $hbcfw = explode('|',trim($post['whlabel'],'|')); $hbcff = explode(';',trim($post['fpdata'],';')); $c = 0; $hbw = array(); $hbf = array(); for($i=0;$i 0) { $post['fpdata'] = implode(";",$hbf).';'; $post['whlabel'] = '|'.implode("|",$hbw).'|'; } //合并重复项结束 $this->fullorder->save($post,$u['id']); if ($this->db->trans_status() === FALSE) { $this->db->trans_commit(); echo json_encode(array('msg'=>'操作失败,请重试','success'=>false));exit; } else { $this->db->trans_commit(); echo json_encode(array('msg'=>'操作成功','d'=>($d),'b'=>$u['id'],'success'=>true)); } } /** $post = $this->input->post(NULL, TRUE); if(isset($post['type'])) { $type = $this->input->post('type'); $id = $this->input->post('id'); $u = $this->fullorder->read($id); $rows = $this->fullorder->find_all('name = "'.$u['name'].'" or email = "'.$u['email'].'" or address = "'.$u['address'].'"','*','id desc'); if(count($rows)>1) { $this->db->trans_begin(); $fpdata=$rows[0]['fpdata'];//购买产品 $shouldmoney=$rows[0]['shouldmoney'];//购买应收金额 $budget=$rows[0]['budget'];//预估到帐金额 $cost=$rows[0]['cost'];//成本金额 $merge=$rows[0]['id']; $d = array($rows[0]['id']); for($i=1;$ifullorder->save(array('merge'=>$rows[0]['id'],'mergeid'=>1),$rows[$i]['id']); } $this->fullorder->save(array('fpdata'=>$fpdata,'shouldmoney'=>$shouldmoney,'budget'=>$budget,'cost'=>$cost,'merge'=>$merge),$rows[0]['id']); if ($this->db->trans_status() === FALSE) { $this->db->trans_commit(); echo json_encode(array('msg'=>'操作失败,请重试','success'=>false));exit; } else { $this->db->trans_commit(); echo json_encode(array('msg'=>'操作成功','d'=>($d),'b'=>$rows[0]['id'],'success'=>true)); } } } **/ } //评价管理 public function _evaluate() { $user = $this->user->get_api($_SESSION['api']); if($user) { $fgshop = "";$sid = ""; $user = explode('|',trim($user['shop'],'|')); foreach ($user as $value) { $fgshop .= " shop = ".$value." or"; $sid .= " id = ".$value." or"; } } $post = $this->input->post(NULL, TRUE); if(isset($post['page'])) { $page = $this->input->post('page',true); $perpage = $this->input->post('perpage',true); $shop = $this->input->post('shop',true); $where = "1=1 and evaluate = 0 and (".rtrim($fgshop,'or').")"; if($shop) { $where .= " and shop = '$shop'"; } //数据排序 $order_str = "id desc"; if(empty($page)) { $start = 0; $perpage = 1; } else { $start = ($page - 1)*$perpage; } //取得信息列表 $info_list = $this->fullorder->find_all($where,'id,shop,orderinfo,number,operation',$order_str,$start,$perpage); //格式化数据 foreach ($info_list as $key=>$value) { $shop = $this->shop->read($value['shop']); $info_list[$key]['shop'] = $shop['shopname']; $info_list[$key]['operation'] = "评价"; } $total = $this->fullorder->find_count($where); $pagenum = ceil($total/$perpage); $over = $total-($start+$perpage); $rows = array('total'=>$total,'over'=>$over,'pagenum'=>$pagenum,'rows'=>($info_list)); echo json_encode($rows);exit; } $this->_Template('fullorder_evaluate',$this->data); } //订单消息 public function _state() { $user = $this->user->get_api($_SESSION['api']); if($user) { $fgshop = "";$sid = ""; $user = explode('|',trim($user['shop'],'|')); foreach ($user as $value) { $fgshop .= " shop = ".$value." or"; $sid .= " id = ".$value." or"; } } $post = $this->input->post(NULL, TRUE); if(isset($post['page'])) { $page = $this->input->post('page',true); $perpage = $this->input->post('perpage',true); $timetk = $this->input->post('timetk',true); $timetj = $this->input->post('timetj',true); $shop = $this->input->post('shop',true); $expressstate = $this->input->post('expressstate',true); $fs = $this->input->post('fs',true); $state = $this->input->post('state',true); $express = $this->input->post('express',true); $review = $this->input->post('review',true); $orderinfo = $this->input->post('orderinfo',true); $number = $this->input->post('number',true); $waybill = $this->input->post('waybill',true); $xztime = $this->input->post('xztime',true); $timetk = strtotime($timetk); $timetj = strtotime($timetj); $where = "1=1 and mergeid = 0 and (".rtrim($fgshop,'or').")"; if($timetk && $timetj) { $where .= " and ".$xztime." > '$timetk' and ".$xztime." < '$timetj'"; } if($xztime == 'librarytime') { $order_str = "librarytime desc"; } else if($xztime == 'dtime') { $order_str = "dtime desc"; } if($shop) { $where .= " and shop = '$shop'"; } if($expressstate) { $where .= " and expressstate = '$expressstate'"; } if($review) { $where .= " and review = '$review'"; } if($fs) { if($fs == '2') { $where .= " and exstateerror != ''"; } else { $where .= " and exstateerror = ''"; } } if($state) { $where .= " and state = '$state'"; } if($express) { $where .= " and express = '$express'"; } if($orderinfo) { $where .= " and orderinfo = '$orderinfo'"; } if($number) { $where .= " and number = '$number'"; } if($waybill) { $where .= " and waybill = '$waybill'"; } if(empty($page)) { $start = 0; $perpage = 1; } else { $start = ($page - 1)*$perpage; } //取得信息列表 $info_list = $this->fullorder->find_all($where,'id,shop,orderinfo,number,country,library,librarytime,express,waybill,content,orderremarks,exstateerror',$order_str,$start,$perpage); //格式化数据 foreach ($info_list as $key=>$value) { $shop = $this->shop->read($value['shop']); $info_list[$key]['shop'] = $shop['shopname']; $country = $this->country->read($value['country']); $info_list[$key]['country'] = $country['name']; //$state = $this->typeclass->read($value['state']); //$info_list[$key]['state'] = $state['title']; if($value['library'] == 1) { $info_list[$key]['library'] = "未出库"; } else if($value['library'] == 2) { $info_list[$key]['library'] = "已出库"; } else if($value['library'] == 3) { $info_list[$key]['library'] = "已退库"; } if($value['librarytime'] == '0') { $info_list[$key]['librarytime'] = '无'; } else { $info_list[$key]['librarytime'] = date('Y-m-d',$value['librarytime']).'
'.date('H:i:s',$value['librarytime']); } $express = $this->express->read($value['express']); $info_list[$key]['express'] = $express['servicename']; } $total = $this->fullorder->find_count($where); $pagenum = ceil($total/$perpage); $over = $total-($start+$perpage); $rows = array('total'=>$total,'over'=>$over,'pagenum'=>$pagenum,'rows'=>($info_list)); echo json_encode($rows);exit; } $notice = $this->notice->find_all("type = '1' and (".rtrim($fgshop,'or').")"); $this->data['notice'] = $notice; $wlshop = $this->shop->find_all('1=1 and '.rtrim($sid,'or')); $this->data['wlshop'] = $wlshop; $this->data['express'] = $this->express->find_all(); $this->_Template('fullorder_state',$this->data); } //物流信息 public function _wl() { $user = $this->user->get_api($_SESSION['api']); if($user) { $fgshop = "";$sid = ""; $user = explode('|',trim($user['shop'],'|')); foreach ($user as $value) { $fgshop .= " shop = ".$value." or"; $sid .= " id = ".$value." or"; } } $post = $this->input->post(NULL, TRUE); if(isset($post['page'])) { $page = $this->input->post('page',true); $perpage = $this->input->post('perpage',true); $timetk = $this->input->post('timetk',true); $timetj = $this->input->post('timetj',true); $shop = $this->input->post('shop',true); $expressstate = $this->input->post('expressstate',true); $fs = $this->input->post('fs',true); $state = $this->input->post('state',true); $express = $this->input->post('express',true); $orderinfo = $this->input->post('orderinfo',true); $number = $this->input->post('number',true); $waybill = $this->input->post('waybill',true); $wlyc = $this->input->post('wlyc',true); $wltype = $this->input->post('wltype',true); $source = $this->input->post('source',true); $xztime = $this->input->post('xztime',true); $wlbz = $this->input->post('wlbz',true); $timetk = strtotime($timetk); $timetj = strtotime($timetj); $where = "1=1 and mergeid = 0 and (".rtrim($fgshop,'or').")"; if($timetk && $timetj) { $where .= " and ".$xztime." > '$timetk' and ".$xztime." < '$timetj'"; } if($xztime == 'librarytime') { $order_str = "librarytime desc"; } else if($xztime == 'dtime') { $order_str = "dtime desc"; } else if ($xztime == 'wlfstime') { $order_str = "wlfstime desc"; } if($shop) { $where .= " and shop = '$shop'"; } if($fs) { if($fs == '1') { $where .= " and wlcontent != ''"; } if($fs == '2') { $where .= " and wlerror != ''"; } if($fs == '3') { $where .= " and wlcontent = '' and shouldmoney > 100"; } else if($fs == '4') { $where .= " and wltype = '1'"; } } if($state) { $where .= " and state = '$state'"; } if($express) { $where .= " and express = '$express'"; } if($orderinfo) { $where .= " and orderinfo = '$orderinfo'"; } if($number) { $where .= " and number = '$number'"; } if($waybill) { $where .= " and waybill = '$waybill'"; } if($wlbz) { $where .= " and wlbz like '%$wlbz%'"; } if($wlyc!='') { $where .= " and wlyc = '$wlyc'"; } if($wltype!='') { $where .= " and wltype = '$wltype'"; } if($source) { if($source == 1) { $where .= " and source = '$source'"; } else { $where .= " and source != '1'"; } } if($expressstate != '') { if($expressstate == 99) { $cxid = ''; $sjcc = $this->awlgx->find_all("time < '".(time()-3*24*3600)."' and exstate != 6",'number'); foreach ($sjcc as $v) { $cxid .= "number = '".$v['number']."' or "; } $where .= ' and ('.rtrim($cxid,'or ').')'; } else { $where .= " and expressstate = '$expressstate'"; } } if(empty($page)) { $start = 0; $perpage = 1; } else { $start = ($page - 1)*$perpage; } //取得信息列表 $info_list = $this->fullorder->find_all($where,'id,orderinfo,number,country,library,librarytime,expressstate,express,waybill,wlbz,orderremarks,wlcontent,wlerror,excontent,wltype',$order_str,$start,$perpage); //格式化数据 foreach ($info_list as $key=>$value) { $f = $this->fullorder->read($value['id']); $info_list[$key]['number'] = "

".$value['number']."

"."

".$f['email']."

"; $country = $this->country->read($value['country']); $info_list[$key]['country'] = "

".$country['name']."

".$f['phone']."

"; //$state = $this->typeclass->read($value['state']); //$info_list[$key]['state'] = $state['title']; if($value['library'] == 1) { $info_list[$key]['library'] = "未出库"; } else if($value['library'] == 2) { $info_list[$key]['library'] = "已出库"; } else if($value['library'] == 3) { $info_list[$key]['library'] = "已退库"; } if($value['librarytime'] == '0') { $info_list[$key]['librarytime'] = '无'; } else { $info_list[$key]['librarytime'] = date('Y-m-d',$value['librarytime']).'
'.date('H:i:s',$value['librarytime']).'
'.$f['shouldmoney']; } if($value['expressstate'] == 0) { $info_list[$key]['expressstate'] = "无信息"; } else if($value['expressstate'] == 2) { $info_list[$key]['expressstate'] = "已取件"; } else if($value['expressstate'] == 3) { $info_list[$key]['expressstate'] = "在途中"; } /** else if($value['expressstate'] == 4) { $info_list[$key]['expressstate'] = "到达目的地国".$value['expressstate']; } **/ else if($value['expressstate'] == 4 || $value['expressstate'] == 5) { $info_list[$key]['expressstate'] = "即将派送"; } else if($value['expressstate'] == 6) { $info_list[$key]['expressstate'] = "已签收"; } else if($value['expressstate'] == 1) { $info_list[$key]['expressstate'] = "派送异常"; } $express = $this->express->read($value['express']); $info_list[$key]['express'] = $express['servicename']; if($value['wltype'] == '0') { $info_list[$key]['wltype'] = "

禁止发送

"; } else { $info_list[$key]['wltype'] = "

允许发送

"; } if($f['wlyc'] == '0') { $info_list[$key]['wltype'] .= "

加入异常处理中

"; } else if($f['wlyc'] == '1') { $info_list[$key]['wltype'] .= "

移入异常已处理

"; $info_list[$key]['wltype'] .= "

移出异常处理中

"; } else if($f['wlyc'] == '2') { $info_list[$key]['wltype'] .= "

异常已处理

"; } if(stripos($value['excontent'],'
') !== false) { $excontent = explode('
',$value['excontent']); $info_list[$key]['excontent'] = ' '.$excontent[0]; } } $total = $this->fullorder->find_count($where); $pagenum = ceil($total/$perpage); $over = $total-($start+$perpage); $rows = array('total'=>$total,'over'=>$over,'pagenum'=>$pagenum,'rows'=>($info_list),'cs'=>$where); echo json_encode($rows);exit; } if(isset($post['q'])) { $id = $this->input->post('id',true); $f = $this->fullorder->read($id); $wl = ($f['wltype']=='0')?1:0; $wltitle = ($f['wltype']=='0')?'已禁发送':'已允发送'; if($this->fullorder->save(array('wltype'=>$wl),$id)) { echo json_encode(array('msg'=>'ckn','id'=>$id,'wltitle'=>$wltitle,'success'=>true));exit; } else { echo json_encode(array('msg'=>'失败,请重试','id'=>$id,'wltitle'=>$wltitle,'success'=>false));exit; } } if(isset($post['t'])) { $id = $this->input->post('id',true); $f = $this->fullorder->read($id); $t = $this->input->post('t',true); $yc = ($f['wlyc']=='0')?1:2; $yctitle = ($f['wlyc']=='0')?'移入成功':'异常已处理'; if($this->fullorder->save(array('wlyc'=>$yc),$id)) { echo json_encode(array('msg'=>'yc','id'=>$id,'wltitle'=>$yctitle,'success'=>true));exit; } else { echo json_encode(array('msg'=>'失败,请重试','id'=>$id,'wltitle'=>$yctitle,'success'=>false));exit; } } if(isset($post['c'])) { $id = $this->input->post('id',true); $f = $this->fullorder->read($id); $t = $this->input->post('t',true); $yc = 0; $yctitle = '移出成功'; if($this->fullorder->save(array('wlyc'=>$yc),$id)) { echo json_encode(array('msg'=>'yc','id'=>$id,'wltitle'=>$yctitle,'success'=>true));exit; } else { echo json_encode(array('msg'=>'失败,请重试','id'=>$id,'wltitle'=>$yctitle,'success'=>false));exit; } } $notice = $this->notice->find_all("type = '2' and (".rtrim($fgshop,'or').")"); $this->data['notice'] = $notice; $wlshop = $this->shop->find_all('1=1 and '.rtrim($sid,'or')); $this->data['wlshop'] = $wlshop; $this->data['express'] = $this->express->find_all(); $this->_Template('fullorder_wl',$this->data); } //审核订单 public function _review() { $user = $this->user->get_api($_SESSION['api']); if($user) { $fgshop = "";$sid = ""; $user = explode('|',trim($user['shop'],'|')); foreach ($user as $value) { $sid .= " id = ".$value." or"; $fgshop .= " shop = ".$value." or"; } $fgshop = " and (".rtrim($fgshop,'or').")"; } $post = $this->input->post(NULL, TRUE); if(isset($post['page'])) { $page = $this->input->post('page',true); $perpage = $this->input->post('perpage',true); $source = $this->input->post('source',true); $warehouse = $this->input->post('warehouse',true); $express = $this->input->post('express',true); $orderremarks = $this->input->post('orderremarks',true); $shop = $this->input->post('shop',true); $review = $this->input->post('review',true); $orderinfo = $this->input->post('orderinfo',true); $shipremarks = $this->input->post('shipremarks',true); $number = $this->input->post('number',true); $timetk = $this->input->post('timetk',true); $timetj = $this->input->post('timetj',true); $timetk = strtotime($timetk); $timetj = strtotime($timetj); $where = "mergeid = 0 and state = '207'".$fgshop; if($timetk && $timetj) { $where .= " and dtime > '$timetk' and dtime < '$timetj'"; } if($source) { if($source == '2d') { $where .= " and source >= '2'"; } else { $where .= " and source = '$source'"; } } if($review) { $where .= " and review = '$review'"; } else { $where .= " and ((review = '2' and source = '1') or (review = '1' and source >= '2'))"; } if($shop) { $where .= " and shop = '$shop'"; } if($warehouse) { $where .= " and type = '$warehouse'"; } if($express) { $where .= " and express = '$express'"; } if($orderremarks) { $where .= " and orderremarks like '%$orderremarks%'"; } if($orderinfo) { $where .= " and orderinfo = '$orderinfo'"; } if($number) { $where .= " and number = '$number'"; } if($shipremarks) { $where .= " and shipremarks like '%$shipremarks%'"; } //数据排序 $order_str = "id desc"; if(empty($page)) { $start = 0; $perpage = 1; } else { $start = ($page - 1)*$perpage; } //取得信息列表 $info_list = $this->fullorder->find_all($where,'id,shop,type,orderinfo,number,client,express,buytime,shouldmoney,review,orderremarks'); //格式化数据 foreach ($info_list as $key=>$value) { $lr = $this->fullorder->read($value['id']); $shop = $this->shop->read($value['shop']); $info_list[$key]['shop'] = $shop['shopname']; $warehouse = $this->warehouse->read($value['type']); $info_list[$key]['type'] = $warehouse['title']; $express = $this->express->read($value['express']); $info_list[$key]['express'] = $express['servicename']; $info_list[$key]['buytime'] = '

'.date('Y-m-d',$value['buytime']).'

'.date('H:i:s',$value['buytime']).'

'; if($value['review'] == 1) { $info_list[$key]['review'] = "未送审"; } else if($value['review'] == 2) { $info_list[$key]['review'] = "待审核"; } else if($value['review'] == 3) { $info_list[$key]['review'] = "不通过"; } else if($value['review'] == 4) { $info_list[$key]['review'] = "取消重审"; } else if($value['review'] == 5) { $info_list[$key]['review'] = "审核通过"; } else if($value['review'] == 6) { $info_list[$key]['review'] = "自动通过"; } /** $info_list[$key]['library'] = ""; if($value['review'] == 1) { $info_list[$key]['library'] = "

审核通过

"; } if($value['review'] == 2) { $info_list[$key]['library'] = "

审核通过

不通过

"; } else if($value['review'] == 3) { $info_list[$key]['library'] = "

审核通过

"; } else if($value['review'] == 5) { $info_list[$key]['library'] = "

不通过

"; } $info_list[$key]['shouldmoney'] = $value['shouldmoney'].' '.$lr['currencytitle']; $lr['hl'] = $lr['hl']==0?6.71:$lr['hl']; $cost = $lr['cost']/$lr['hl']; $currencytitle = $lr['budget']-$lr['refundj']-$cost-$lr['expressmoney']; $info_list[$key]['currencytitle'] = sprintf("%.2f",$currencytitle).' '.$lr['currencytitle']; **/ } $total = $this->fullorder->find_count($where); $pagenum = ceil($total/$perpage); $over = $total-($start+$perpage); $rows = array('total'=>$total,'over'=>$over,'pagenum'=>$pagenum,'rows'=>($info_list)); echo json_encode($rows);exit; } $wlshop = $this->shop->find_all('1=1 and '.rtrim($sid,'or')); $this->data['shop'] = $wlshop; $this->_Template('fullorder_review',$this->data); } public function _wlbz($arg_array) { $post = $this->input->post(NULL, TRUE); if(isset($post['id'])) { $id = $this->input->post('id',true); $post['wlbz'] = $this->input->post('wlbz',true); if($post['wlbz'] == '') { echo json_encode(array('msg'=>'备注不能为空','success'=>false));exit; } if($this->fullorder->save($post,$id)) { echo json_encode(array('msg'=>'修改成功','id'=>$id,'success'=>true));exit; } else { echo json_encode(array('msg'=>'修改失败,请重试','success'=>false));exit; } } $arg_array = $arg_array[0]; $fullorder = $this->fullorder->read($arg_array); $this->data['fullorder'] = $fullorder; $this->_Template('fullorder_wlbz',$this->data); } //导出资金统计excel public function _fmexcel() { $user = $this->user->get_api($_SESSION['api']); if($user) { $fgshop = "";$sid = ""; $user = explode('|',trim($user['shop'],'|')); foreach ($user as $value) { $fgshop .= " shop = ".$value." or"; $sid .= " id = ".$value." or"; } } if(isset($_GET['excel'])) { $timetk = $this->input->get('timetk',true); $timetj = $this->input->get('timetj',true); $shop = $this->input->get('shop',true); $source = $this->input->get('source',true); $state = $this->input->get('state',true); $type = $this->input->get('type',true); $orderinfo = $this->input->get('orderinfo',true); $user = $this->input->get('user',true); $name = $this->input->get('name',true); $timetk = strtotime($timetk); $timetj = strtotime($timetj); $where = "1=1 and mergeid = 0 and (".rtrim($fgshop,'or').")"; if($timetk && $timetj) { $where .= " and buytime > '$timetk' and buytime < '$timetj'"; } if($shop) { $where .= " and shop = '$shop'"; } if($source) { $where .= " and source = '$source'"; } if($state) { if($state == 1) { $where .= " and state = '$state'"; } } if($type) { $where .= " and type = '$type'"; } if($orderinfo) { $where .= " and orderinfo = '$orderinfo'"; } if($user) { $where .= " and user = '$user'"; } if($name) { $where .= " and name = '$name'"; } //取得信息列表 $info_list = $this->fullorder->find_all($where,'id,shop,user,number,orderinfo,client,country,dtime,ftime,express,waybill,shouldmoney,refund,currency,budget,fpdata,hl,currencytitle'); //格式化数据 $i = 1;$shouldmoney = 0;$refund = 0;$budget = 0;$currency = 0;$hl=1; foreach ($info_list as $key=>$value) { $info_list[$key]['id'] = $i; if($value['currencytitle'] != "CNY") { $hl=$value['hl']; } $shouldmoney=$shouldmoney+($value['shouldmoney']*$hl); $budget=$budget+($value['budget']*$hl); $currency=$currency+(($value['shouldmoney']-$value['budget'])*$hl); $refund=$refund+($value['refund']*$hl); $shop = $this->shop->read($value['shop']); $info_list[$key]['shop'] = $shop['shopname']; $info_list[$key]['user'] = $shop['shopuser']; $info_list[$key]['dtime'] = date('Y-m-d H:i:s',$value['dtime']); $info_list[$key]['ftime'] = date('Y-m-d H:i:s',$value['ftime']); $country = $this->country->read($value['country']); $info_list[$key]['country'] = $country['name']; $express = $this->express->read($value['express']); $info_list[$key]['express'] = $express['servicename']; $info_list[$key]['shouldmoney'] = $value['shouldmoney'].' '.$value['currencytitle']; $info_list[$key]['refund'] = $value['refund'].' '.$value['currencytitle']; $info_list[$key]['budget'] = $value['budget'].' '.$value['currencytitle']; $info_list[$key]['currency'] = sprintf("%.2f",$value['shouldmoney']-$value['budget']).' '.$value['currencytitle']; $fpdata = array(); if(stripos($value['fpdata'],';') !== false) { $fpdata = explode(';',rtrim($value['fpdata'],';')); foreach ($fpdata as $ke=>$va) { $v = explode('|',rtrim($va,'|')); $fpdata[$ke] = array($v[4],$v[5],$v[6],$v[5]*$v[6]);//内容,条数,数量,总条数 } } $info_list[$key]['fpdata'] = $fpdata; $i++; } $data = array($shouldmoney.' CNY',$refund.' CNY',$currency.' CNY',$budget.' CNY'); $title = "订单资金信息"; $titlename = "

".$title."

NO. 店铺 负责人 编号 订单号 客户姓名 国家 订单日期 发货日期 快递公司 运单号 订单金额 退款金额 手续费 预估金额
订单产品信息
产品 条数 数量
总条数
"; $filename = $title.".xls"; $tail = "合计:".$data[0]."".$data[1]."".$data[2]."".$data[3]."\n"; $this->excel->get_fz($info_list,$titlename,$filename,$tail); } } //导出订单excel public function _fdexcel() { if(isset($_GET['excel'])) { $page = $this->input->post('page',true); $perpage = $this->input->post('perpage',true); $timetk = $this->input->post('timetk',true); $timetj = $this->input->post('timetj',true); $shop = $this->input->post('shop',true); $source = $this->input->post('source',true); $state = $this->input->post('state',true); $review = $this->input->post('review',true); $express = $this->input->post('express',true); $orderinfo = $this->input->post('orderinfo',true); $user = $this->input->post('user',true); $name = $this->input->post('name',true); $waybill = $this->input->post('waybill',true); $timetk = strtotime($timetk); $timetj = strtotime($timetj); $where = "1=1 and mergeid = 0"; if($timetk && $timetj) { $where .= " and buytime > '$timetk' and buytime < '$timetj'"; } if($shop) { $where .= " and shop = '$shop'"; } if($source) { $where .= " and source = '$source'"; } if($state) { $where .= " and state = '$state'"; } if($review) { $where .= " and review = '$review'"; } if($express) { $where .= " and express = '$express'"; } if($orderinfo) { $where .= " and orderinfo = '$orderinfo'"; } if($user) { $where .= " and user = '$user'"; } if($name) { $where .= " and name = '$name'"; } if($waybill) { $where .= " and waybill = '$waybill'"; } //取得信息列表 $info_list = $this->fullorder->find_all($where,'id,shop,number,orderinfo,source,client,name,address,city,zipcode,province,country,phone,dtime,ftime,state,shouldmoney,express,waybill,orderremarks,clientremarks,fpdata,hl,currencytitle'); //格式化数据 $i = 1;$shouldmoney = 0;$hl=1; foreach ($info_list as $key=>$value) { $info_list[$key]['id'] = $i; if($value['source'] == 1) { $info_list[$key]['source'] = "线下订单"; } else if($value['source'] == 2) { $info_list[$key]['source'] = "PC订单"; } else if($value['source'] == 3) { $info_list[$key]['source'] = "手机订单"; } if($value['currencytitle'] != "CNY") { $hl=$value['hl']; } $shouldmoney=$shouldmoney+($value['shouldmoney']*$hl); $shop = $this->shop->read($value['shop']); $info_list[$key]['shop'] = $shop['shopname']; $info_list[$key]['dtime'] = date('Y-m-d H:i:s',$value['dtime']); $info_list[$key]['ftime'] = date('Y-m-d H:i:s',$value['ftime']); $state = $this->typeclass->read($value['state']); $info_list[$key]['state'] = $state['title']; $country = $this->country->read($value['country']); $info_list[$key]['country'] = $country['name']; $express = $this->express->read($value['express']); $info_list[$key]['express'] = $express['servicename']; $info_list[$key]['shouldmoney'] = $value['shouldmoney'].' '.$value['currencytitle']; $fpdata = array(); if(stripos($value['fpdata'],';') !== false) { $fpdata = explode(';',rtrim($value['fpdata'],';')); foreach ($fpdata as $ke=>$va) { $v = explode('|',rtrim($va,'|')); $fpdata[$ke] = array($v[4],$v[5],$v[6],$v[5]*$v[6]);//内容,条数,数量,总条数 } } $info_list[$key]['fpdata'] = $fpdata; $i++; } $data = array($shouldmoney.' CNY'); $title = "订单信息表"; $titlename = "

".$title."

NO. 店铺 编号 订单号 订单类型 客户姓名 收件人名称 收货人地址 城市 邮编 国家 收件电话 订单日期 发货日期 订单状态 订单金额 快递公司 运单号 订单备注 客户备注
订单产品信息
产品 条数 数量
总条数
"; $filename = $title.".xls"; $tail = "合计:".$data[0]."\n"; $this->excel->get_fz($info_list,$titlename,$filename,$tail); } } public function _black() { $post = $this->input->post(NULL, TRUE); if(isset($post['bd'])) { $bd = $this->input->post('bd',true); $rows = $this->fullorder->read($bd); $post['shop'] = $rows['shop']; $post['source'] = 1; $post['name'] = $rows['client']; $post['email'] = $rows['email']; $post['phone'] = $rows['phone']; $post['country'] = $rows['country']; $post['money'] = $rows['shouldmoney']; $post['num'] = 1; $post['time'] = $rows['dtime']; $post['province'] = $rows['province']; $post['city'] = $rows['city']; $post['street'] = $rows['street']; $post['address'] = $rows['address']; $post['address2'] = $rows['address2']; $post['zipcode'] = $rows['zipcode']; $post['type'] = 2; if($this->customer->insert($post)) { $this->fullorder->save(array('black'=>1),$bd); echo json_encode(array('msg'=>'操作成功','success'=>true));exit; } else { echo json_encode(array('msg'=>'操作失败,请重试','success'=>false));exit; } } } public function _ryf() { $post = $this->input->post(NULL, TRUE); if(isset($post['bd'])) { $bd = $this->input->post('bd',true); $d = $this->fullorder->read($bd); if($d['state'] == 207 || $d['state'] == 207)//订单状态为等待发货或等待部分发货才可更改为允许发货 { if($d['print'] < 3)//打印状态为未打印 { $print = 1;//未打印 $libraryconfirm = 1;//不允许出库 $a = "订单未打印,"; } else//已打印订单 { $libraryconfirm = 2;//允许出库 $a = ""; } if($this->fullorder->save(array('librarynot'=>$a,'libraryconfirm'=>$libraryconfirm,'print'=>$print),$bd)) { echo json_encode(array('msg'=>'操作成功','success'=>true));exit; } else { echo json_encode(array('msg'=>'操作失败,请重试','success'=>false));exit; } } if($this->fullorder->save(array('librarynot'=>$a,'libraryconfirm'=>$libraryconfirm,'print'=>$print),$bd)) { echo json_encode(array('msg'=>'操作失败!订单未非发货状态','success'=>false));exit; } else { echo json_encode(array('msg'=>'操作失败,请重试','success'=>false));exit; } } } public function _fsstate() { $post = $this->input->post(NULL, TRUE); if(isset($post['s'])) { $id_arr = $this->input->post('s'); $id_arr = explode(',',$id_arr); if(!$id_arr) { echo json_encode(array('msg'=>'参数错误!','success'=>false));exit; } foreach ($id_arr as $v) { $data = $this->fullorder->read($v); $warehouse = $this->warehouse->read($data['type']); $fs = $this->notice->get_ordertatus($data['state']); if($fs) { $ck = $this->_email($fs['content'],$data,$warehouse['company']); if($ck == 1) { $this->fullorder->save(array('fscontent'=>date('Y-m-d H:i:s',time()).'已发送:'.$fs['title'].' - '),$v); } } } echo json_encode(array('msg'=>'发送完成!','success'=>true));exit; } } public function _power() { $user = $this->user->get_api($_SESSION['api']); $post = $this->input->post(NULL, TRUE); if(isset($post['id'])) { $id = $this->input->post('id',true); $fullorder = $this->fullorder->read($id); $express = $this->express->read($fullorder['express']); $warehouse = $this->warehouse->read($fullorder['type']); if(($warehouse['zd'] == '1' || stripos($fullorder['whlabel'],'z|') !== false) && $fullorder['library'] == '2') { echo json_encode(array('msg'=>'需要先退库释放库存后才可重置!','success'=>false));exit; } /** if($fullorder['print'] == '3' && isset($express['iscode']) && ($express['iscode'] == 'ARAMEX' || $express['iscode'] == 'TOLL' || $express['iscode'] == 'FEDEX')) { $lj = $this->ali->get_lj($fullorder['number'],2,'订单修改'); if($lj != '1' && $lj != '订单不存在') { echo json_encode(array('msg'=>$lj,'success'=>false));exit; } } **/ $warehouse = $this->warehouse->read($fullorder['warehouse']); $typeclass = $this->typeclass->read($fullorder['state']); $express = $this->express->read($fullorder['express']); $printtype = array(1=>'运单',2=>'发货单',3=>'不打印单据'); $teset['number']=$fullorder['number']; $teset['orderinfo']=$fullorder['orderinfo']; $teset['shop']=$fullorder['shop']; $teset['user']=$user['userid']; $teset['ip']=$this->input->ip_address(); $teset['time']=time(); $teset['warehouse']=(isset($warehouse['title']))?$warehouse['title']:'未选择'; $teset['state']=(isset($typeclass['title']))?$typeclass['spare']:'未选择'; $teset['express']=(isset($express['title']))?$express['servicename']:'未选择'; $teset['printtype']=(isset($printtype[$fullorder['printtype']]))?$printtype[$fullorder['printtype']]:'未选择'; $teset['reviewtime']=($fullorder['reviewtime'] > '0')?date('Y-m-d H:i:s',$fullorder['reviewtime']):'无'; $teset['printtime']=($fullorder['printtime'] > '0')?date('Y-m-d H:i:s',$fullorder['printtime']):'无'; $teset['librarytime']=($fullorder['librarytime'] > '0')?date('Y-m-d H:i:s',$fullorder['librarytime']):'无'; $teset['shipremarks']=$fullorder['shipremarks']; $teset['fpdata']=$fullorder['fpdata']; $teset['oldwaybill']=$fullorder['oldwaybill']; $teset['oldprinttime']=$fullorder['oldprinttime']; if($fullorder['printtype'] == 1) { if($fullorder['waybill'] != '' && stripos($fullorder['oldwaybill'],$fullorder['waybill']) === false) { $teset['oldwaybill'] .= '-'.date('Ymd',$fullorder['printtime']).'/'.$fullorder['waybill']; $teset['oldprinttime'] .= '-'.$fullorder['printtime']; } } $review = ($fullorder['source']==1)?2:1;//线下单审核状态直接为待审核 if(!$this->fullreset->insert($teset)) { echo json_encode(array('msg'=>'重置失败,请重试','success'=>true));exit; } if($this->fullorder->save(array('library'=>1,'librarytime'=>0,'libraryconfirm'=>2,'print'=>1,'printtime'=>0,'printnumber'=>0,'retreattime'=>0,'librarynot'=>'订单未打印,未审核或未通过','review'=>$review,'reviewtime'=>0,'state'=>207,'waybill'=>'','waybill2'=>'','waybillid'=>'','oldwaybill'=>$teset['oldwaybill'],'oldprinttime'=>$teset['oldprinttime'],'dlzemail'=>0,'yhs'=>0,'failed'=>''),$id)) { echo json_encode(array('msg'=>'重置成功!如需再次提交,请先保存、再提交','success'=>true));exit; } else { echo json_encode(array('msg'=>'重置失败,请重试','success'=>false));exit; } } } public function _expresstype() { $post = $this->input->post(NULL, TRUE); if(isset($post['id'])) { $id = $this->input->post('id',true); $data = $this->express->read($id); echo json_encode(array('msg'=>$data['type'],'success'=>true));exit; } } public function _email($content,$data,$shopname) { $express = $this->express->read($data['express']); $t= array('$userName','$orderid','$trackingNumber','$expressCompany','$contactPerson','$mobileNo','$zip','$recipientAddress');//需要被替换的内容 $h= array($data['client'],$data['orderinfo'],$data['waybill'],$express['servicename'],$data['name'],$data['phone'],$data['zipcode'],$data['address']);//替换的内容 $content = str_replace($t,$h,$content); $this->load->library('email'); $config['protocol'] = 'smtp'; $config['smtp_host'] = 'smtpdm-ap-southeast-1.aliyun.com'; $config['smtp_port'] = 465; $config['smtp_user'] = 'service@email.supernovahair.com'; $config['smtp_pass'] = 'LONGyihair374'; $config['smtp_crypto'] = 'ssl'; $config['crlf'] = "\r\n"; $config['newline'] = "\r\n"; $this->email->initialize($config); $this->email->from('service@email.supernovahair.com',$shopname); $this->email->to($data['email']);//收件 $this->email->subject('The product you purchased has a new progress');//标题 $this->email->message($content);//内容 if ( ! $this->email->send()) { return 2; } else { return 1; } } public function _error() { if(isset($_SESSION['api'])) { $user = $this->user->get_api($_SESSION['api']); $usp = $user; $fgshop = "";$sid = ""; $user = explode('|',trim($user['shop'],'|')); foreach ($user as $value) { $fgshop .= " shop = ".$value." or"; $sid .= " id = ".$value." or"; } } $post = $this->input->post(NULL, TRUE); if(isset($post['page'])) { $page = $this->input->post('page',true); $perpage = $this->input->post('perpage',true); $orderinfo = $this->input->post('orderinfo',true); $waybill = $this->input->post('waybill',true); $number = $this->input->post('number',true); $timetk = $this->input->post('timetk',true); $timetj = $this->input->post('timetj',true); $timetk = strtotime($timetk); $timetj = strtotime($timetj); $where = "failed !='' and mergeid = 0 and print != 3 and (".rtrim($fgshop,'or').")"; if($orderinfo) { $where .= " and orderinfo = '$orderinfo'"; } if($waybill) { $where .= " and waybill = '$waybill'"; } if($number) { $where .= " and number = '$number'"; } if($timetk && $timetj) { $timetj = $timetj+24*3600; $where .= " and dtime > '$timetk' and dtime < '$timetj'"; } //数据排序 $order_str = "dtime desc"; if(empty($page)) { $start = 0; $perpage = 1; } else { $start = ($page - 1)*$perpage; } $info_list = $this->fullorder->find_all($where,'id,shop,type,orderinfo,number,express,failed,operation',$order_str,$start,$perpage); //格式化数据 foreach ($info_list as $key=>$value) { $ud = $this->fullorder->read($value['id']); $shop = $this->shop->read($value['shop']); $info_list[$key]['shop'] = $shop['shopname']; $info_list[$key]['orderinfo'] = "".$value['orderinfo']."

"; $warehouse = $this->warehouse->read($value['type']); $warehousetitle = $warehouse['title']; if($value['type'] != 1){$warehousetitle = "".$warehouse['title']."";} $info_list[$key]['type'] = $warehousetitle; if($value['express'] != 0) { $express = $this->express->read($value['express']); $expressservicename = $express['servicename']; if($value['express'] != 1){$expressservicename = "".$express['servicename']."";} $info_list[$key]['express'] = $expressservicename; } else { $info_list[$key]['express'] = "无"; } $x = ""; if($ud['review'] >4 && $ud['print'] == 1) { $x = "

允许打印

"; } else { $x = "

关闭

"; } $info_list[$key]['operation'] = $x; } $total = $this->fullorder->find_count($where); $pagenum = ceil($total/$perpage); $over = $total-($start+$perpage); $rows = array('total'=>$total,'over'=>$over,'pagenum'=>$pagenum,'rows'=>($info_list)); echo json_encode($rows);exit; } $wlshop = $this->shop->find_all('1=1 and '.rtrim($sid,'or')); $this->data['wlshop'] = $wlshop; $this->data['express'] = $this->express->find_all(); $user = $this->user->get_api($_SESSION['api']); $powerid = $this->power->read($user['power']); $powertext = explode('|',trim($powerid['excelid'],'|')); $pid = ''; foreach ($powertext as $v) { $pid .= " id = ".$v." or"; } $fullorderexcel = $this->fullorderexcel->find_all("type = '100001' and (".rtrim($pid,'or').")",'*','idorder desc');//导出模板 $this->data['fullorderexcel'] = $fullorderexcel; $this->_Template('fullorder_error',$this->data); } //验证地址 public function _yzaddress() { $post = $this->input->post(NULL, TRUE); if(isset($post['address'])) { $address = $this->input->post('address',true); $address2 = $this->input->post('address2',true); $city = $this->input->post('city',true); $province = $this->input->post('province',true); $zipcode = $this->input->post('zipcode',true); $barcode = $this->usps->get_address(array('address'=>$address,'address2'=>$address2,'city'=>$city,'province'=>$province,'zipcode'=>$zipcode)); //$this->logic_ding->sendToDing("usps地址验证返回数据".$barcode); echo $barcode; } } //清除退货信息 public function _clearreturn() { $post = $this->input->post(NULL, TRUE); if(isset($post['orderinfo'])) { $orderinfo = $this->input->post('orderinfo',true); $data = $this->fullorder->get_orderinfo($orderinfo); $fu = 'fullorder'; if(!$data) { $data = $this->fullorder_smt->get_orderinfo($orderinfo); $fu = 'fullorder_smt'; } $this->$fu->save(array('library'=>'2','retreattime'=>'0','returndata'=>''),$data['id']); echo json_encode(array('msg'=>'清除成功!','success'=>true));exit; } } //订单退货 public function _return() { $post = $this->input->post(NULL, TRUE); if(isset($post['orderinfo'])) { $orderinfo = $this->input->post('orderinfo',true); $data = $this->fullorder->get_orderinfo($orderinfo); $fu = 'fullorder'; if(!$data) { $data = $this->fullorder_smt->get_orderinfo($orderinfo); $fu = 'fullorder_smt'; } $bctime = date('Ymd',time()); if($data['library'] != 2){ echo json_encode(array('msg'=>'此单不是出库状态,不允许退货','success'=>false));exit; } if($data['returndata'] != "") { echo json_encode(array('msg'=>'请求失败,已有Return Label信息!','success'=>false));exit; } $barcode = $this->usps->get_return($data); // if(isset($barcode['errors']['ExternalReturnLabelError']['InternalErrorDescription'])) // { // echo json_encode(array('msg'=>$barcode['errors']['ExternalReturnLabelError']['InternalErrorDescription'],'success'=>false));exit; // } // else if(isset($barcode['TrackingNumber'])) // { // $pdf = $this->_pdf($barcode['ReturnLabel'],'t-'.$barcode['TrackingNumber'],$bctime); // $read = 'PostalRouting:'.$barcode['PostalRouting'].' - TrackingNumber:'.$barcode['TrackingNumber'].''; // $this->$fu->save(array('returndata'=>$read),$data['id']); // echo json_encode(array('msg'=>'生成Return Label成功!','data'=>$read,'success'=>true));exit; // } // else // { // echo json_encode(array('msg'=>'请求失败,请稍后重试!','cs'=>$barcode,'success'=>false));exit; // } if(isset($barcode['errors']['ExternalReturnLabelError']['InternalErrorDescription'])) { echo json_encode(array('msg'=>$barcode['errors']['ExternalReturnLabelError']['InternalErrorDescription'],'success'=>false));exit; } else if(isset($barcode['trackingNumber'])) { $pdf = $this->_pdf($barcode['returnLabelImage'],'t-'.$barcode['trackingNumber'],$bctime); $read = 'PostalRouting:'.$barcode['routingInformation'].' - TrackingNumber:'.$barcode['trackingNumber'].''; $this->$fu->save(array('returndata'=>$read),$data['id']); echo json_encode(array('msg'=>'生成Return Label成功!','data'=>$read,'success'=>true));exit; } else { echo json_encode(array('msg'=>'请求失败,请稍后重试!'.json_encode($barcode),'cs'=>$barcode,'success'=>false));exit; } } /** $post = $this->input->post(NULL, TRUE); if(isset($post['orderinfo'])) { $orderinfo = $this->input->post('orderinfo',true); $data = $this->fullorder->get_orderinfo($orderinfo); $fu = 'fullorder'; if(!$data) { $data = $this->fullorder_smt->get_orderinfo($orderinfo); $fu = 'fullorder_smt'; } $bctime = date('Ymd',time()); if($data['returndata'] != "") { echo json_encode(array('msg'=>'请求失败,已有Return Label信息!','success'=>false));exit; } $barcode = $this->usps->get_return($data); if(isset($barcode['error']['message'])) { echo json_encode(array('msg'=>$barcode['error']['message'],'success'=>false));exit; } else if(isset($barcode['trackingNumber'])) { $pdf = $this->_pdf($barcode['returnLabelImage'],'t-'.$barcode['trackingNumber'],$bctime); $read = 'trackingNumber:'.$barcode['trackingNumber'].''; $this->$fu->save(array('returndata'=>$read),$data['id']); echo json_encode(array('msg'=>'生成Return Label成功!','data'=>$read,'success'=>true));exit; } else { echo json_encode(array('msg'=>'请求失败,请稍后重试!','cs'=>$barcode,'success'=>false));exit; } }**/ } public function _pdf($pdf,$title,$bctime) { $pdf_path = './data/pdf/'.$bctime.'/'; $file_base64 = $pdf; $file_base64 = preg_replace('/data:.*;base64,/i', '', $file_base64); $file_base64 = base64_decode($file_base64); if(!is_dir($pdf_path))mkdir($pdf_path,0777); //上传目录不存在则创建 file_put_contents($pdf_path.$title.'.pdf',$file_base64); return $bctime; } public function _find($find) { preg_match_all('/\d+/',$find,$n); $a = ''; foreach($n[0] as $v) { $a .= $v; } return $a; } public function _dqpm() { if(isset($_SESSION['api'])) { $user = $this->user->get_api($_SESSION['api']); $usp = $user; $fgshop = "";$sid = ""; $usersp = explode('|',trim($user['shop'],'|')); foreach ($usersp as $value) { $fgshop .= " shop = ".$value." or"; $sid .= " id = ".$value." or"; } } $post = $this->input->post(NULL, TRUE); if(isset($post['page'])) { $timetk = $this->input->post('timetk',true); $timetj = $this->input->post('timetj',true); $timetk = strtotime($timetk); $timetj = strtotime($timetj); $where = "mergeid = 0 and (".rtrim($fgshop,'or').")"; if($timetk && $timetj) { $where .= " and dtime > '$timetk' and dtime < '$timetj'"; } //数据排序 $order_str = "dtime desc"; if(empty($page)) { $start = 0; $perpage = 1; } else { $start = ($page - 1)*$perpage; } $continentdata = ''; $continent = array();//陆地板块 $num = $this->fullorder->find_count($where);//订单总数量 $country = $this->country->find_all('1=1','id,continent,ename,zname'); foreach ($country as $k=>$v) { $tc = $this->typeclass->read($v['continent']); $continent[$v['continent']] = array(0=>$tc['title'],1=>0,2=>''); } foreach ($country as $k=>$v) { $n = $this->fullorder->find_count($where.' and country = "'.$v['id'].'"'); $country[$k]['continent'] = $continent[$v['continent']][0];//此国家数量 $country[$k]['zname'] = ''.$v['zname'].'';//此国家数量 $country[$k]['num'] = $n;//此国家数量 $country[$k]['zb'] = (sprintf("%.4f",$n/$num)*100).'%';//此国家占比 $continent[$v['continent']]['1'] += $n;//此洲数量增加; } array_multisort(array_column($continent, '1'), SORT_DESC, $continent); array_multisort(array_column($country, 'num'), SORT_DESC, $country); foreach ($continent as $k=>$v) { $continentdata .= $v['0'].' 总量:'.$v['1'].' 占比:'.(sprintf("%.4f",$v['1']/$num)*100).'%   -   '; } echo json_encode(array('ewnr'=>$continentdata,'rows'=>$country,'total'=>count($country),'over'=>0,'pagenum'=>1,'success'=>true));exit; } $this->_Template('fullorder_dqpm',$this->data); } public function _dqpmprovince($arg_array) { if(isset($_SESSION['api'])) { $user = $this->user->get_api($_SESSION['api']); $usp = $user; $fgshop = "";$sid = ""; $usersp = explode('|',trim($user['shop'],'|')); foreach ($usersp as $value) { $fgshop .= " shop = ".$value." or"; $sid .= " id = ".$value." or"; } } $post = $this->input->post(NULL, TRUE); if(isset($post['page'])) { $country = $this->input->post('country',true); $timetk = $this->input->post('timetk',true); $timetj = $this->input->post('timetj',true); $where = "mergeid = 0 and dtime > '$timetk' and dtime < '$timetj' and country = '$country' and (".rtrim($fgshop,'or').")"; $province = array(); $city_list = $this->fullorder->find_all($where,'id,province'); $ToState = array('AL'=>'alabama','AK'=>'alaska','AZ'=>'arizona','AR'=>'arkansas','CA'=>'california','CO'=>'colorado','CT'=>'connecticut','DE'=>'delaware','FL'=>'florida','GA'=>'georgia','HI'=>'hawaii','ID'=>'idaho','IL'=>'illinois','IN'=>'indiana','IA'=>'iowa','KS'=>'kansas','KY'=>'kentucky','LA'=>'louisiana','ME'=>'maine','MD'=>'maryland','MA'=>'massachusetts','MI'=>'michigan','MN'=>'minnesota','MS'=>'mississippi','MO'=>'missouri','MT'=>'montana','NE'=>'nebraska','NV'=>'nevada','NH'=>'new hampshire','NJ'=>'new jersey','NM'=>'new mexico','NY'=>'new york','NC'=>'north carolina','ND'=>'north dakota','OH'=>'ohio','OK'=>'oklahoma','OR'=>'oregon','PA'=>'pennsylvania','RI'=>'rhode island','SC'=>'south carolina','SD'=>'south dakota','TN'=>'tennessee','TX'=>'texas','UT'=>'utah','VT'=>'vermont','VA'=>'virginia','WA'=>'washington','WV'=>'west virginia','WI'=>'wisconsin','WY'=>'wyoming','DC'=>'district of columbia','VI'=>'virgin islands'); foreach ($city_list as $k=>$v) { $v['province'] = strtoupper(trim($v['province'],' ')); if(isset($ToState[$v['province']])) { $v['province'] = $ToState[$v['province']]; } if(!isset($province[$v['province']])) { $province[$v['province']] = array('id'=>$v['id'],'province'=>''.$v['province'].'','num'=>0,'zb'=>''); } $province[$v['province']]['num'] += 1; } array_multisort(array_column($province, 'num'), SORT_DESC, $province); $province = array_values($province); foreach ($province as $k=>$v) { $province[$k]['zb'] = (sprintf("%.4f",$v['num']/count($city_list))*100).'%'; } echo json_encode(array('rows'=>($province),'total'=>count($province),'over'=>0,'pagenum'=>1,'success'=>true));exit; } $this->data['arg_array'] = $arg_array; $this->_Template('fullorder_dqpmprovince',$this->data); } public function _ddpmdata($arg_array) { $arg_array[3] = str_replace('%20',' ',$arg_array[3]); if(isset($_SESSION['api'])) { $user = $this->user->get_api($_SESSION['api']); $usp = $user; $fgshop = "";$sid = ""; $usersp = explode('|',trim($user['shop'],'|')); foreach ($usersp as $value) { $fgshop .= " shop = ".$value." or"; $sid .= " id = ".$value." or"; } } $post = $this->input->post(NULL, TRUE); if(isset($post['page'])) { $page = $this->input->post('page',true); $perpage = $this->input->post('perpage',true); $province = $this->input->post('province',true); $timetk = $this->input->post('timetk',true);; $timetj = $this->input->post('timetj',true);; $country = $this->input->post('country',true);; $where = "mergeid = 0 and dtime > '$timetk' and dtime < '$timetj' and country = '$country' and (".rtrim($fgshop,'or').")"; if($province) { $where .= " and province = '$province'"; } $order_str = "dtime desc"; if(empty($page)) { $start = 0; $perpage = 1; } else { $start = ($page - 1)*$perpage; } $info_list = $this->fullorder->find_all($where,'id,orderinfo,number,shipremarks,shouldmoney',$order_str,$start,$perpage); $total = $this->fullorder->find_count($where); $pagenum = ceil($total/$perpage); $over = $total-($start+$perpage); $rows = array('total'=>$total,'over'=>$over,'pagenum'=>$pagenum,'rows'=>($info_list)); echo json_encode($rows);exit; } $province = array(); $city_list = $this->fullorder->find_all("mergeid = 0 and dtime > '$arg_array[1]' and dtime < '$arg_array[2]' and country = '$arg_array[0]' and (".rtrim($fgshop,'or').")",'province'); $ToState = array('AL'=>'alabama','AK'=>'alaska','AZ'=>'arizona','AR'=>'arkansas','CA'=>'california','CO'=>'colorado','CT'=>'connecticut','DE'=>'delaware','FL'=>'florida','GA'=>'georgia','HI'=>'hawaii','ID'=>'idaho','IL'=>'illinois','IN'=>'indiana','IA'=>'iowa','KS'=>'kansas','KY'=>'kentucky','LA'=>'louisiana','ME'=>'maine','MD'=>'maryland','MA'=>'massachusetts','MI'=>'michigan','MN'=>'minnesota','MS'=>'mississippi','MO'=>'missouri','MT'=>'montana','NE'=>'nebraska','NV'=>'nevada','NH'=>'new hampshire','NJ'=>'new jersey','NM'=>'new mexico','NY'=>'new york','NC'=>'north carolina','ND'=>'north dakota','OH'=>'ohio','OK'=>'oklahoma','OR'=>'oregon','PA'=>'pennsylvania','RI'=>'rhode island','SC'=>'south carolina','SD'=>'south dakota','TN'=>'tennessee','TX'=>'texas','UT'=>'utah','VT'=>'vermont','VA'=>'virginia','WA'=>'washington','WV'=>'west virginia','WI'=>'wisconsin','WY'=>'wyoming','DC'=>'district of columbia','VI'=>'virgin islands'); foreach ($city_list as $k=>$v) { $v['province'] = strtoupper(trim($v['province'],' ')); if(isset($ToState[$v['province']])) { $v['province'] = $ToState[$v['province']]; } $province[$v['province']] = array('province'=>$v['province']); } $this->data['province'] = $province; $this->data['arg_array'] = $arg_array; $this->_Template('fullorder_ddpmdata',$this->data); } public function _ddpmexcel($arg_array) { if(isset($_SESSION['api'])) { $user = $this->user->get_api($_SESSION['api']); $usp = $user; $fgshop = "";$sid = ""; $usersp = explode('|',trim($user['shop'],'|')); foreach ($usersp as $value) { $fgshop .= " shop = ".$value." or"; $sid .= " id = ".$value." or"; } } $province = $this->input->get('province',true); $timetk = $arg_array[1]; $timetj = $arg_array[2]; $country = $arg_array[0]; $where = "mergeid = 0 and dtime > '$timetk' and dtime < '$timetj' and country = '$country' and (".rtrim($fgshop,'or').")"; if($province) { $where .= " and province = '$province'"; } $order_str = "dtime desc"; $info_list = $this->fullorder->find_all($where,'orderinfo,number,shipremarks,shouldmoney',$order_str); $country = $this->country->read($arg_array[0]); $title = $country['zname'].date('Y-m-d',$timetk).'-'.date('Y-m-d',$timetj); $titlename = "

".$title."

订单号 订单编号 仓库品名 订单金额
"; $filename = $title.".xls"; $tail = "\n"; $this->excel->get_fz2($info_list,$titlename,$filename,$tail); } public function _statedc() { $user = $this->user->get_api($_SESSION['api']); if($user) { $fgshop = "";$sid = ""; $user = explode('|',trim($user['shop'],'|')); foreach ($user as $value) { $fgshop .= " shop = ".$value." or"; $sid .= " id = ".$value." or"; } } $post = $this->input->get(NULL, TRUE); if(isset($post['timetk'])) { $page = $this->input->get('page',true); $perpage = $this->input->get('perpage',true); $timetk = $this->input->get('timetk',true); $timetj = $this->input->get('timetj',true); $shop = $this->input->get('shop',true); $source = $this->input->get('source',true); $state = $this->input->get('state',true); $review = $this->input->get('review',true); $express = $this->input->get('express',true); $fs = $this->input->get('fs',true); $orderinfo = $this->input->get('orderinfo',true); $number = $this->input->get('number',true); $user = $this->input->get('user',true); $name = $this->input->get('name',true); $waybill = $this->input->get('waybill',true); $expressstate = $this->input->get('expressstate',true); $wltype = $this->input->get('wltype',true); $wlyc = $this->input->get('wlyc',true); $xztime = $this->input->get('xztime',true); $timetk = strtotime($timetk); $timetj = strtotime($timetj); $where = "1=1 and mergeid = 0 and (".rtrim($fgshop,'or').")"; if($timetk && $timetj) { $where .= " and ".$xztime." > '$timetk' and ".$xztime." < '$timetj'"; } if($xztime == 'librarytime') { $order_str = "librarytime desc"; } else if($xztime == 'dtime') { $order_str = "dtime desc"; } if($shop) { $where .= " and shop = '$shop'"; } if($source) { if($source == 11) { $where .= " and source != '1'"; } else { $where .= " and source = '$source'"; } } if($fs) { if($fs == '2') { $where .= " and exstateerror != ''"; } else { $where .= " and exstateerror = ''"; } } if($state) { $where .= " and state = '$state'"; } if($review) { $where .= " and review = '$review'"; } if($expressstate != "") { $where .= " and expressstate = '$expressstate'"; } if($wltype != "") { $where .= " and wltype = '$wltype'"; } if($wlyc != "") { $where .= " and wlyc = '$wlyc'"; } if($express) { $where .= " and express = '$express'"; } if($orderinfo) { $where .= " and orderinfo = '$orderinfo'"; } if($number) { $where .= " and number = '$number'"; } if($user) { $where .= " and user = '$user'"; } if($name) { $where .= " and name = '$name'"; } if($waybill) { $where .= " and waybill = '$waybill'"; } if(empty($page)) { $start = 0; $perpage = 1; } else { $start = ($page - 1)*$perpage; } //取得信息列表 $info_list = $this->fullorder->find_all($where,'shop,number,country,library,librarytime,expressstate,express,waybill,content,exstateerror,excontent',$order_str); //格式化数据 foreach ($info_list as $key=>$value) { $shop = $this->shop->read($value['shop']); $info_list[$key]['shop'] = $shop['shopname']; $country = $this->country->read($value['country']); $info_list[$key]['country'] = $country['name']; //$state = $this->typeclass->read($value['state']); //$info_list[$key]['state'] = $state['title']; if($value['library'] == 1) { $info_list[$key]['library'] = "未出库"; } else if($value['library'] == 2) { $info_list[$key]['library'] = "已出库"; } else if($value['library'] == 3) { $info_list[$key]['library'] = "已退库"; } if($value['librarytime'] == '0') { $info_list[$key]['librarytime'] = '无'; } else { $info_list[$key]['librarytime'] = date('Y-m-d H:i:s',$value['librarytime']); } if($value['expressstate'] == 0) { $info_list[$key]['expressstate'] = "无信息"; } else if($value['expressstate'] == 2) { $info_list[$key]['expressstate'] = "已取件"; } else if($value['expressstate'] == 3) { $info_list[$key]['expressstate'] = "在途中"; } /** else if($value['expressstate'] == 4) { $info_list[$key]['expressstate'] = "到达目的地国"; } **/ else if($value['expressstate'] == 4 || $value['expressstate'] == 5) { $info_list[$key]['expressstate'] = "即将派送"; } else if($value['expressstate'] == 6) { $info_list[$key]['expressstate'] = "已签收"; } else if($value['expressstate'] == 1) { $info_list[$key]['expressstate'] = "派送异常"; } $express = $this->express->read($value['express']); $info_list[$key]['express'] = $express['servicename']; } } $title = date('Y-m-d',$timetk).'-'.date('Y-m-d',$timetj); $titlename = "
店铺名称 编号 收件人国家 出库状态 发货时间 物流状态 快递公司 运单号 消息状态 错误提示 物流信息
"; $filename = $title.".xls"; $tail = "\n"; $this->excel->get_fz2($info_list,$titlename,$filename,$tail); } public function _statedcwl() { $user = $this->user->get_api($_SESSION['api']); if($user) { $fgshop = "";$sid = ""; $user = explode('|',trim($user['shop'],'|')); foreach ($user as $value) { $fgshop .= " shop = ".$value." or"; $sid .= " id = ".$value." or"; } } $post = $this->input->get(NULL, TRUE); if(isset($post['timetk'])) { $dowid = $this->input->get('a'); $wid = ""; if($dowid != "") { $id_arr = explode(',',rtrim($dowid,',')); $wid .= " id = 0 or"; foreach ($id_arr as $v) { $wid .= " id = '$v' or"; } $wid = " and".rtrim($wid,'or'); } $page = $this->input->get('page',true); $perpage = $this->input->get('perpage',true); $timetk = $this->input->get('timetk',true); $timetj = $this->input->get('timetj',true); $shop = $this->input->get('shop',true); $expressstate = $this->input->get('expressstate',true); $fs = $this->input->get('fs',true); $state = $this->input->get('state',true); $express = $this->input->get('express',true); $orderinfo = $this->input->get('orderinfo',true); $number = $this->input->get('number',true); $waybill = $this->input->get('waybill',true); $wlyc = $this->input->get('wlyc',true); $wltype = $this->input->get('wltype',true); $source = $this->input->get('source',true); $xztime = $this->input->get('xztime',true); $timetk = strtotime($timetk); $timetj = strtotime($timetj); $where = "1=1 and mergeid = 0 and (".rtrim($fgshop,'or').")"; if($timetk && $timetj) { $where .= " and ".$xztime." > '$timetk' and ".$xztime." < '$timetj'"; } if($xztime == 'librarytime') { $order_str = "librarytime desc"; } else if($xztime == 'dtime') { $order_str = "dtime desc"; }else if($xztime == 'wlfstime'){ $order_str = "wlfstime desc"; } if($shop) { $where .= " and shop = '$shop'"; } if($expressstate) { $where .= " and expressstate = '$expressstate'"; } if($fs) { if($fs == '1') { $where .= " and wlcontent != ''"; } if($fs == '2') { $where .= " and wlerror != ''"; } if($fs == '3') { $where .= " and wlcontent = '' and shouldmoney > 100"; } else if($fs == '4') { $where .= " and wltype = '1'"; } } if($state) { $where .= " and state = '$state'"; } if($express) { $where .= " and express = '$express'"; } if($orderinfo) { $where .= " and orderinfo = '$orderinfo'"; } if($number) { $where .= " and number = '$number'"; } if($waybill) { $where .= " and waybill = '$waybill'"; } if($wlyc!='') { $where .= " and wlyc = '$wlyc'"; } if($wltype!='') { $where .= " and wltype = '$wltype'"; } if($source) { if($source == 1) { $where .= " and source = '$source'"; } else { $where .= " and source != '1'"; } } $info_list = $this->fullorder->find_all($where.$wid,'orderinfo,number,country,library,librarytime,expressstate,express,waybill,wlbz,orderremarks,shipremarks,wlfstime,email,phone,wlcontent,wlerror,excontent',$order_str); //格式化数据 foreach ($info_list as $key=>$value) { $country = $this->country->read($value['country']); $info_list[$key]['country'] = $country['name']; //$state = $this->typeclass->read($value['state']); //$info_list[$key]['state'] = $state['title']; if($value['library'] == 1) { $info_list[$key]['library'] = "未出库"; } else if($value['library'] == 2) { $info_list[$key]['library'] = "已出库"; } else if($value['library'] == 3) { $info_list[$key]['library'] = "已退库"; } if($value['librarytime'] == '0') { $info_list[$key]['librarytime'] = '无'; } else { $info_list[$key]['librarytime'] = date('Y-m-d H:i:s',$value['librarytime']); } if($value['expressstate'] == 0) { $info_list[$key]['expressstate'] = "无信息"; } else if($value['expressstate'] == 2) { $info_list[$key]['expressstate'] = "已取件"; } else if($value['expressstate'] == 3) { $info_list[$key]['expressstate'] = "在途中"; } /** else if($value['expressstate'] == 4) { $info_list[$key]['expressstate'] = "到达目的地国"; } **/ else if($value['expressstate'] == 4 || $value['expressstate'] == 5) { $info_list[$key]['expressstate'] = "即将派送"; } else if($value['expressstate'] == 6) { $info_list[$key]['expressstate'] = "已签收"; } else if($value['expressstate'] == 1) { $info_list[$key]['expressstate'] = "派送异常"; } $info_list[$key]['wlfstime'] = date('Y-m-d H:i:s',$value['wlfstime']); $express = $this->express->read($value['express']); $info_list[$key]['express'] = $express['servicename']; $info_list[$key]['excontent'] = str_replace('
','',$value['excontent']); } } $title = date('Y-m-d',$timetk).'-'.date('Y-m-d',$timetj); $titlename = "
订单号 编号 收件人国家 出库状态 出库时间 物流状态 快递公司 运单号 物流备注 订单备注 仓库品名 发送时间 邮箱 电话 邮件发送 错误提示 物流信息
"; $filename = $title.".xls"; $tail = "\n"; $this->excel->get_fz2($info_list,$titlename,$filename,$tail); } public function _waybillemail() { $user = $this->user->get_api($_SESSION['api']); if($user) { $fgshop = "";$sid = ""; $user = explode('|',trim($user['shop'],'|')); foreach ($user as $value) { $fgshop .= " shop = ".$value." or"; $sid .= " id = ".$value." or"; } } $post = $this->input->post(NULL, TRUE); if(isset($post['page'])) { $page = $this->input->post('page',true); $perpage = $this->input->post('perpage',true); $timetk = $this->input->post('timetk',true); $timetj = $this->input->post('timetj',true); $shop = $this->input->post('shop',true); $source = $this->input->post('source',true); $expressstate = $this->input->post('expressstate',true); $fs = $this->input->post('fs',true); $state = $this->input->post('state',true); $express = $this->input->post('express',true); $orderinfo = $this->input->post('orderinfo',true); $number = $this->input->post('number',true); $waybill = $this->input->post('waybill',true); $dlzemail = $this->input->post('dlzemail',true); $xztime = $this->input->post('xztime',true); $timetk = strtotime($timetk); $timetj = strtotime($timetj); $where = "1=1 and mergeid = 0 and (".rtrim($fgshop,'or').")"; if($timetk && $timetj) { $where .= " and ".$xztime." > '$timetk' and ".$xztime." < '$timetj'"; } $order_str = $xztime." desc"; if($source) { if($source == '2d') { $where .= " and source >= '2' and shop != 19"; } else { $where .= " and source = '$source'"; } } if($shop) { $where .= " and shop = '$shop'"; } if($expressstate) { $where .= " and expressstate = '$expressstate'"; } if($state) { $where .= " and state = '$state'"; } if($express) { $where .= " and express = '$express'"; } if($orderinfo) { $where .= " and orderinfo = '$orderinfo'"; } if($number) { $where .= " and number = '$number'"; } if($waybill) { $where .= " and waybill = '$waybill'"; } if($dlzemail != '') { $where .= " and dlzemail = '$dlzemail'"; } if(empty($page)) { $start = 0; $perpage = 1; } else { $start = ($page - 1)*$perpage; } //取得信息列表 $info_list = $this->fullorder->find_all($where,'id,shop,orderinfo,number,country,library,librarytime,express,waybill,dlzemail,dlzemailtime',$order_str,$start,$perpage); //格式化数据 foreach ($info_list as $key=>$value) { $shop = $this->shop->read($value['shop']); $info_list[$key]['shop'] = $shop['shopname']; $country = $this->country->read($value['country']); $info_list[$key]['country'] = $country['name']; //$state = $this->typeclass->read($value['state']); //$info_list[$key]['state'] = $state['title']; if($value['library'] == 1) { $info_list[$key]['library'] = "未出库"; } else if($value['library'] == 2) { $info_list[$key]['library'] = "已出库"; } else if($value['library'] == 3) { $info_list[$key]['library'] = "已退库"; } if($value['librarytime'] == '0') { $info_list[$key]['librarytime'] = '无'; } else { $info_list[$key]['librarytime'] = date('Y-m-d',$value['librarytime']).'
'.date('H:i:s',$value['librarytime']); } $express = $this->express->read($value['express']); $info_list[$key]['express'] = $express['servicename']; if($value['dlzemail'] == '1') { $info_list[$key]['dlzemail'] = '发送成功'; } else if ($value['dlzemail'] == '2') { $info_list[$key]['dlzemail'] = '发送失败'; } else { $info_list[$key]['dlzemail'] = ''; } $info_list[$key]['dlzemailtime'] = ($value['dlzemailtime']>0)?date('Y-m-d H:i:s',$value['dlzemailtime']):''; } $total = $this->fullorder->find_count($where); $pagenum = ceil($total/$perpage); $over = $total-($start+$perpage); $rows = array('total'=>$total,'over'=>$over,'pagenum'=>$pagenum,'rows'=>($info_list)); echo json_encode($rows);exit; } $notice = $this->notice->find_all("type = '2' and (".rtrim($fgshop,'or').")"); $this->data['notice'] = $notice; $wlshop = $this->shop->find_all('1=1 and '.rtrim($sid,'or')); $this->data['wlshop'] = $wlshop; $this->data['express'] = $this->express->find_all(); $this->_Template('fullorder_waybillemail',$this->data); } public function _khdd() { $dt = 0;$fgshop = "shop = 0";$sid = 'id = 0'; if(isset($_SESSION['api'])) { $user = $this->user->get_api($_SESSION['api']); $usp = $user; $fgshop = "";$sid = ""; $usersp = explode('|',trim($user['shop'],'|')); foreach ($usersp as $value) { $fgshop .= " shop = ".$value." or"; $sid .= " id = ".$value." or"; } if($user['vip'] == 1) { $vip = 1; } else { $vip = 0; } } $post = $this->input->post(NULL, TRUE); if(isset($_GET['excel'])) { $page = $this->input->get('page',true); $perpage = $this->input->get('perpage',true); $warehouse = $this->input->get('warehouse',true); $timetk = $this->input->get('timetk',true); $timetj = $this->input->get('timetj',true); $shop = $this->input->get('shop',true); $source = $this->input->get('source',true); $state = $this->input->get('state',true); $review = $this->input->get('review',true); $type = $this->input->get('type',true); $express = $this->input->get('express',true); $orderinfo = $this->input->get('orderinfo',true); $user = $this->input->get('user',true); $client = $this->input->get('name',true); $waybill = $this->input->get('waybill',true); $number = $this->input->get('number',true); $email = $this->input->get('email',true); $phone = $this->input->get('phone',true); $dlz = $this->input->get('dlz',true); $print = $this->input->get('print',true); $library = $this->input->get('library',true); $js = $this->input->get('js',true); $exstate = $this->input->get('exstate',true); $xztime = $this->input->get('xztime',true); $libraryconfirm = $this->input->get('libraryconfirm',true); $timetk = strtotime($timetk); $timetj = strtotime($timetj); $plorder = $this->input->get('pl',true); $paypal = $this->input->get('paypal',true); $zf = $this->input->get('zf',true); $pay = $this->input->get('pay',true); $excel = $this->input->get('excel',true); $where = "1=1 and mergeid = 0 and (".rtrim($fgshop,'or').")"; if($warehouse) { $where .= " and type = '$warehouse'"; } if($timetk && $timetj) { $where .= " and ".$xztime." > '$timetk' and ".$xztime." < '$timetj'"; } if($shop) { $where .= " and shop = '$shop'"; } if($source) { if($source == '2d') { $where .= " and source >= '2'"; } else { $where .= " and source = '$source'"; } } if($state) { $where .= " and state = '$state'"; } if($review) { $where .= " and review = '$review'"; } if($type) { $where .= " and type = '$type'"; } if($express) { $where .= " and express = '$express'"; } if($orderinfo) { $where .= " and orderinfo = '$orderinfo'"; } if($user) { $where .= " and user = '$user'"; } if($client) { $where .= " and client like '%$client%'"; } if($waybill) { $where .= " and waybill = '$waybill'"; } if($number) { $where .= " and number = '$number'"; } if($email) { $where .= " and email = '$email'"; } if($phone) { $where .= " and phone like '%$phone%'"; } if($library) { $where .= " and library = '$library'"; } if($print) { $where .= " and print = '$print'"; } if($dlz != '') { $where .= " and dlz = '$dlz'"; } if($js) { $where .= " and js = '$js'"; } if($exstate) { $where .= " and exstate = '$exstate'"; } if($libraryconfirm) { $where .= " and libraryconfirm = '$libraryconfirm'"; } if($paypal) { $where .= " and paypal = '$paypal'"; } if($pay) { $where .= " and pay = '$pay'"; } if($zf) { if($zf == 1) { $where .= " and paypal not like '%-%-%-%'"; } else { $where .= " and paypal like '%-%-%-%'"; } } if($plorder) { $plorderinfo = '';$plnumber = '';$pln = 0; $plorder = explode(',',trim($plorder,',')); foreach ($plorder as $value) { if(is_numeric($value)) { $plorderinfo .= " orderinfo = ".$value." or"; } else if($value != '') { $plorderinfo .= " number = '".$value."' or"; } } if($pln > 0) { $where .= " and (".rtrim($plorderinfo,'or').") and (".rtrim($plnumber,'or').")"; } else { $where .= " and (".rtrim($plorderinfo,'or').")"; } } //数据排序 $order_str = "dtime desc"; if(empty($page)) { $start = 0; $perpage = 1; } else { $start = ($page - 1)*$perpage; } if($excel == '1') { $shop = array(); $shopdata = $this->shop->find_all("type = '269'"); foreach ($shopdata as $v) { $shop[$v['id']] = array('t'=>$v['brandname'],'z'=>0,'l'=>0,'x'=>0);//店铺名称,总客户,老客户,新客户 } $oldnumber = 0;$newnumber = 0; $info_list = $this->db->query('select distinct shop,email from crowd_fullorder where '.$where)->result_array(); foreach ($info_list as $key=>$v) { $shop[$v['shop']]['z'] += 1; $num = $this->fullorder->find_count("email = '".$v['email']."' and shop = '".$v['shop']."' and ".$xztime." < '$timetj'"); if($num > 1) { $shop[$v['shop']]['l'] += 1; } else { $shop[$v['shop']]['x'] += 1; } if(isset($v['email']) && $usp['excelpass'] == '1') { $emailpass = $this->setting->get_excelpass($v['email']); $info_list[$key]['email'] = $emailpass; } } $title = date('Y-m-d',$timetk).'-'.date('Y-m-d',$timetj); $titlename = "
店铺 客户数 老客户数 新客户数
"; $filename = $title.".xls"; $tail = "\n"; $this->excel->get_fz2($shop,$titlename,$filename,$tail); } else if($excel == '2' || $excel == '3') { $kh = array(); $info_list = $this->db->query('select distinct shop,email from crowd_fullorder where email != "" and '.$where)->result_array(); foreach ($info_list as $key=>$v) { $k = $this->fullorder->find_all("shop = '".$v['shop']."' and email = '".$v['email']."' and ".$xztime." < '$timetj'",'name,email,dtime,shouldmoney','dtime desc'); if($excel == 2 && count($k) > 1) { $kh[] = array($k[0]['name'],$k[0]['email'],date("Y-m-d H:i:s",$k[0]['dtime']),count($k),array_sum(array_column($k,'shouldmoney'))); } if($excel == 3 && count($k) < 2) { $kh[] = array($k[0]['name'],$k[0]['email'],date("Y-m-d H:i:s",$k[0]['dtime']),count($k),array_sum(array_column($k,'shouldmoney'))); } if(isset($v['email']) && $usp['excelpass'] == '1') { $emailpass = $this->setting->get_excelpass($v['email']); $info_list[$key]['email'] = $emailpass; } } $title = $country['zname'].date('Y-m-d',$timetk).'-'.date('Y-m-d',$timetj); $titlename = "
名称 邮箱 最后购买时间 购买次数 购买总额
"; $filename = $title.".xls"; $tail = "\n"; $this->excel->get_fz2($kh,$titlename,$filename,$tail); } else if($excel == '4' || $excel == '5') { $kh = array(); $info_list = $this->db->query('select distinct shop,email from crowd_fullorder where email != "" and '.$where)->result_array(); foreach ($info_list as $key=>$value) { $k = $this->fullorder->find_all("shop = '".$value['shop']."' and email = '".$value['email']."' and ".$xztime." < '$timetj'",'orderinfo,state,product,name,email,dtime,shouldmoney','dtime desc'); if($excel == 4 && count($k) > 1) { foreach ($k as $v) { $typeclass = $this->typeclass->read($v['state']); $kh[] = array($v['orderinfo'],$typeclass['spare'],$v['product'],$v['name'],$v['email'],date("Y-m-d H:i:s",$v['dtime']),$v['shouldmoney']); } } if($excel == 5 && count($k) < 2) { if(!isset($k[0]['state'])) { $typeclass = $k[0]['state'].'-数据字典无此信息'; } else { $typeclass = $this->typeclass->read($k[0]['state']); } $kh[] = array($k[0]['orderinfo'],$typeclass['spare'],$k[0]['product'],$k[0]['name'],$k[0]['email'],date("Y-m-d H:i:s",$k[0]['dtime']),$k[0]['shouldmoney']); } if(isset($value['email']) && $usp['excelpass'] == '1') { $emailpass = $this->setting->get_excelpass($value['email']); $info_list[$key]['email'] = $emailpass; } } $title = $country['zname'].date('Y-m-d',$timetk).'-'.date('Y-m-d',$timetj); $titlename = "
订单号 订单状态 产品名 客户名 客户邮箱 下单时间 订单金额
"; $filename = $title.".xls"; $tail = "\n"; $this->excel->get_fz2($kh,$titlename,$filename,$tail); } } } public function _klarnadata() { $post = $this->input->post(NULL, TRUE); if(isset($post['number'])) { $number = $this->input->post('number',true); $data = $this->fullorder->get_number($number); $shop = $this->shop->read($data['shop']); $f = ''; if($data['pay'] == '23') { $url = 'https://api-na.klarna.com/ordermanagement/v1/orders/'.$data['paypal']; $header[] = "Content-Type:application/json"; $header[] = "Authorization: Basic ".base64_encode($shop['klarnaname'].":".$shop['klarnapass']); $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); curl_setopt($ch, CURLOPT_HTTPHEADER, $header); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false); $res = curl_exec($ch); curl_close($ch); $res = json_decode($res,true); if(isset($res['fraud_status']) && $shop['klarnaname'] != '') { $f = (($res['fraud_status'] == 'ACCEPTED')?1:2).'|'.$res['purchase_currency'].($res['order_amount']/100).' , '.(($res['fraud_status'] != 'ACCEPTED')?''.$res['fraud_status'].'':$res['fraud_status']).' , description:'.$res['initial_payment_method']['description'].' , number of installments:'.$res['initial_payment_method']['number_of_installments'].'|'.$res['billing_address']['street_address'].(($res['billing_address']['street_address2']!='')?' '.$res['billing_address']['street_address2']:'').','.$res['billing_address']['city'].','.$res['billing_address']['region'].','.$res['billing_address']['postal_code'].','.$res['billing_address']['country'].','.$res['billing_address']['given_name'].' '.$res['billing_address']['family_name'].','.$res['billing_address']['phone'].','.$res['billing_address']['email'].'|'.$res['shipping_address']['street_address'].(($res['shipping_address']['street_address2']!='')?' '.$res['shipping_address']['street_address2']:'').','.$res['shipping_address']['city'].','.$res['shipping_address']['region'].','.$res['shipping_address']['postal_code'].','.$res['shipping_address']['country'].','.$res['shipping_address']['given_name'].' '.$res['shipping_address']['family_name'].','.$res['shipping_address']['phone'].','.$res['shipping_address']['email']; } } else if(($data['pay'] == '22' || $data['pay'] == '7') && $shop['paypalname'] != '') { $f = $this->paypal->data($data['paypal'],$shop); } else if(($data['pay'] == '26') && $shop['afterpayname'] != '') { $url = 'https://global-api.afterpay.com/v2/payments?ids='.$data['paypal']; $header[] = "Accept:application/json"; $header[] = "User-Agent: Readme.io API Simulator'"; $header[] = "Authorization: Basic ".base64_encode($shop['afterpayname'].":".$shop['afterpaypass']); $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); curl_setopt($ch, CURLOPT_HTTPHEADER, $header); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false); $res = curl_exec($ch); curl_close($ch); $res = json_decode($res,true); if(isset($res['results'][0]['orderDetails']['consumer']['email'])) { $f = $res['results'][0]['orderDetails']['consumer']['email'].'|'.$res['results'][0]['orderDetails']['billing']['line1'].','.$res['results'][0]['orderDetails']['billing']['line2'].','.$res['results'][0]['orderDetails']['billing']['area1'].','.$res['results'][0]['orderDetails']['billing']['region'].','.$res['results'][0]['orderDetails']['billing']['postcode'].','.$res['results'][0]['orderDetails']['billing']['countryCode'].','.$res['results'][0]['orderDetails']['billing']['name'].','.$res['results'][0]['orderDetails']['billing']['phoneNumber'].'|'.$res['results'][0]['orderDetails']['shipping']['line1'].','.$res['results'][0]['orderDetails']['shipping']['line2'].','.$res['results'][0]['orderDetails']['shipping']['area1'].','.$res['results'][0]['orderDetails']['shipping']['region'].','.$res['results'][0]['orderDetails']['shipping']['postcode'].','.$res['results'][0]['orderDetails']['shipping']['countryCode'].','.$res['results'][0]['orderDetails']['shipping']['name'].','.$res['results'][0]['orderDetails']['shipping']['phoneNumber']; $f = str_replace(',,',',',$f); } } else if(($data['pay'] == '27') && $shop['clearpayname'] != '') { $url = 'https://global-api.afterpay.com/v2/payments?ids='.$data['paypal']; $header[] = "Accept:application/json"; $header[] = "User-Agent: Readme.io API Simulator'"; $header[] = "Authorization: Basic ".base64_encode($shop['clearpayname'].":".$shop['clearpaypass']); $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); curl_setopt($ch, CURLOPT_HTTPHEADER, $header); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false); $res = curl_exec($ch); curl_close($ch); $res = json_decode($res,true); if(isset($res['results'][0]['orderDetails']['consumer']['email'])) { $f = $res['results'][0]['orderDetails']['consumer']['email'].'|'.$res['results'][0]['orderDetails']['billing']['line1'].','.$res['results'][0]['orderDetails']['billing']['line2'].','.$res['results'][0]['orderDetails']['billing']['area1'].','.$res['results'][0]['orderDetails']['billing']['region'].','.$res['results'][0]['orderDetails']['billing']['postcode'].','.$res['results'][0]['orderDetails']['billing']['countryCode'].','.$res['results'][0]['orderDetails']['billing']['name'].','.$res['results'][0]['orderDetails']['billing']['phoneNumber'].'|'.$res['results'][0]['orderDetails']['shipping']['line1'].','.$res['results'][0]['orderDetails']['shipping']['line2'].','.$res['results'][0]['orderDetails']['shipping']['area1'].','.$res['results'][0]['orderDetails']['shipping']['region'].','.$res['results'][0]['orderDetails']['shipping']['postcode'].','.$res['results'][0]['orderDetails']['shipping']['countryCode'].','.$res['results'][0]['orderDetails']['shipping']['name'].','.$res['results'][0]['orderDetails']['shipping']['phoneNumber']; $f = str_replace(',,',',',$f); } } else if($data['pay'] == '1211') { $url = 'https://api.stripe.com/v1/payment_intents/'.$data['paypal']; $header[] = "Authorization:Bearer ".$shop['stripe']; $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); curl_setopt($ch, CURLOPT_HTTPHEADER, $header); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false); $res = curl_exec($ch); curl_close($ch); $res = json_decode($res,true); $f = ''; if(isset($res['shipping']['name'])) { $line = ($res['shipping']['address']['line2'] != '')?$res['shipping']['address']['line1'].' '.$res['shipping']['address']['line2']:$res['shipping']['address']['line1']; $f = 'stripe|'.json_encode(array('name'=>$res['shipping']['name'],'email'=>$res['receipt_email'],'address'=>$line.','.$res['shipping']['address']['city'].','.$res['shipping']['address']['state'].','.$res['shipping']['address']['postal_code'].','.$res['shipping']['address']['country'].','.$res['shipping']['phone'],'shouldmoney'=>$res['amount']/100)); } } else { echo json_encode(array('msg'=>'此店铺没有对接信息','success'=>false));exit; } if($f != '') { if($this->fullorder->save(array('klarnadata'=>$f),$data['id'])) { echo json_encode(array('msg'=>'获取成功,请关闭此页重新打开','success'=>true));exit; } else { echo json_encode(array('msg'=>'写入失败,请重试','success'=>false));exit; } } else { echo json_encode(array('msg'=>'获取失败,请稍后重试','cl'=>base64_encode($shop['afterpayname'].":".$shop['afterpaypass']),'a'=>$data['paypal'],'success'=>false));exit; } } } public function _kcyz($warehouse,$whlabel,$id,$shop,$number) { if(!$whlabel || $whlabel == '|') { return array('t'=>1,'m'=>json_encode(array('t'=>1,'msg'=>'请先添加产品信息!','success'=>false)));exit; } $w = $this->warehouse->read($warehouse); if($w['zd'] != 1) { return 1; } $pp = explode('|',trim($whlabel,'|')); $x = 0;$save = array(); foreach ($pp as $va) { $num = explode('-',$va); if($number) { $whlabel = $this->whlabel->find_all("state = 0 and number = '$num[0]' and warehouse = '$warehouse' and (zd = '$number' or zd = '') and (shop IS NULL or shop = '')");//通用 $shopwhlabel = $this->whlabel->find_all("state = 0 and number = '$num[0]' and warehouse = '$warehouse' and (zd = '$number' or zd = '') and shop like '%,".$shop.",%'");//专属 } else { $whlabel = $this->whlabel->find_all("state = 0 and number = '$num[0]' and warehouse = '$warehouse' and zd = '' and (shop IS NULL or shop = '')");//通用 $shopwhlabel = $this->whlabel->find_all("state = 0 and number = '$num[0]' and warehouse = '$warehouse' and zd = '' and shop like '%,".$shop.",%'");//专属 } $x++; if(count($whlabel)+count($shopwhlabel) < $num[1]) { $save[] = $x-1;continue;//提前先加X不然出错,所以要减1 } } return $save; } public function _epod() { $post = $this->input->post(NULL, TRUE); if(isset($post['number'])) { $number = $this->input->post('number',true); $data = $this->fullorder->get_number($number); if(is_file('./data/epod/'.date('Y',time()).'/epod-'.$data['waybill'].'.pdf')) { echo json_encode(array('msg'=>'http://'.$_SERVER['HTTP_HOST'].'/data/epod/'.date('Y',time()).'/epod-'.$data['waybill'].'.pdf','success'=>true));exit; } else { $epod = $this->dhl->get_epod($data); if($epod['c'] == 1) { echo json_encode(array('msg'=>'http://'.$_SERVER['HTTP_HOST'].$epod['d'],'success'=>true));exit; } else { echo json_encode(array('msg'=>$epod['d'],'success'=>false));exit; } } } } public function _zw($arg_array) { $arg_array = $arg_array[0];$fpdata = array(); $fullorder = $this->fullorder->read($arg_array); $fullorder['shipremarks'] = str_replace(array('<','>'),array('<','>'),$fullorder['shipremarks']); $fullorder['parameter'] = str_replace(",","---",$fullorder['parameter']); $this->data['fullorder'] = $fullorder; $this->data['countrys'] = $this->country->find_all(); $this->data['express'] = $this->express->find_all(); $warehouse = $this->warehouse->read($fullorder['type']); if(stripos($fullorder['fpdata'],';') !== false) { $fpdata = explode(';',rtrim($fullorder['fpdata'],';')); foreach ($fpdata as $k=>$v) { $xxv = explode('|',$v); if(isset($xxv[9]) && stripos($xxv[9],$warehouse['hz']) !== false && $warehouse['hz'] != '' && $warehouse['zd'] == 1) { $xxv['zd'] = "

已占单

"; $bdck = $warehouse['bdck']; if(stripos($xxv[9],'~') !== false) { $dxxv = explode('~',trim($xxv[9],'~')); foreach ($dxxv as $val) { $wzid = $this->$bdck->read(trim($val,$warehouse['hz'])); if($wzid['details'] != '') { $xxv['zd'] .= '

位置:'.$wzid['details'].' - '.$wzid['cpid'].'

'; } } } else { $wzid = $this->$bdck->read(trim($xxv[9],$warehouse['hz'])); if($wzid['details'] != '') { $xxv['zd'] .= '

位置:'.$wzid['details'].' - '.$wzid['cpid'].'

'; } } } $fpdata[$k] = $xxv; } } $this->data['fpdata'] = $fpdata; $this->data['fpdata'] = $fpdata; $thfpdataxs = array(); if($fullorder['thfpdata'] != '') { $thfpdata = explode(';',trim($fullorder['thfpdata'],';')); foreach ($thfpdata as $k=>$v) { $thxs = explode('~',trim($v,'~')); $thxs[0] = explode('|',trim($thxs[0],'|')); $thxs[1] = explode('|',trim($thxs[1],'|')); $thfpdataxs[] = array("

".$thxs[0][1]."

".$thxs[1][1]."

","

".$thxs[0][2]."

".$thxs[1][2]."

","

",$thxs[1][0]); } } $this->data['thfpdata'] = $thfpdataxs; $shop = $this->shop->read($fullorder['shop']); $this->data['et'] = $shop['estimaterate'];//此店铺配置预计到帐金额比例 $is = 0; if($shop['type'] == 269 || $shop['type'] == 2678)//判断是否独立站,269是独立站 { $is = 1; } $this->data['is'] = $is; //单项开始 $warehouse = $this->warehouse->read($fullorder['warehouse']);//发货仓库 $state = $this->typeclass->read($fullorder['state']);//订单状态 $country = $this->country->read($fullorder['country']);//国家 if($fullorder['capital'] == 1) { $capital = '暂未支付'; } else if($fullorder['capital'] == 2) { $capital = '部分支付'; } else if($fullorder['capital'] == 3) { $capital = '全部支付'; } if($fullorder['printtype'] == 1) { $printtype = '运单'; } else if($fullorder['printtype'] == 2) { $printtype = '发货单'; } else if($fullorder['printtype'] == 3) { $printtype = '不打印单据'; } else { $printtype = '未选择'; } $this->data['warehouse'] = $warehouse['title']; $this->data['state'] = $state['title']; $this->data['capital'] = $capital; $this->data['country'] = $country['name']; $this->data['printtype'] = $printtype; //单项结束 /** 历史运单号展示并下载PDF 打印时间需要2019-3-21 0点之后有记录 **/ $downwaybill = '';$dwls = array(); $oldwaybill = explode('-',ltrim($fullorder['oldwaybill'],'-')); if(isset($oldwaybill[0][1])) { $oldwaybill = array_reverse($oldwaybill); //调整顺序 foreach ($oldwaybill as $v) { $dw = explode('/',$v); if(isset($dw[1])) { if(stripos($downwaybill,$dw[1]) === false) { $dwls[$dw[1]] = 1; $downwaybill .= ''.$dw[1].'、'; } } } } if($fullorder['printtype'] == 1) { if($fullorder['waybill'] != '' && !isset($dwls[$fullorder['waybill']])) { $downwaybill = ''.$fullorder['waybill'].'、'.$downwaybill; } } $this->data['downwaybill'] = rtrim($downwaybill,'、'); /** 历史打印时间 **/ $printtime = ''; if($fullorder['oldprinttime']) { $pte = explode('-',rtrim($fullorder['oldprinttime'],'-')); foreach ($pte as $v) { $printtime .= date('Y-m-d H:i:s',$v).'、'; } } $this->data['printtime'] = rtrim($printtime,'、'); $product = ''; $fullorder['product'] = str_replace("'","",$fullorder['product']); if($fullorder['link'] != '' && $fullorder['source'] != '1') { $pt = explode(',',$fullorder['product']); $lk = explode(',',$fullorder['link']); for($i=0;$icolourorderts->get_texturl($pt[$i],$lk[$i]); } else { $octs = ''; } $a = $octs?''.$pt[$i].'':$pt[$i]; //$a = (stripos($pt[$i],'Lace Front Wig Body Wave Human Hair Wigs Pre Plucked Brazilian Virgin Hair') !== false || stripos($pt[$i],'Deep Wave Wig 100 Human Hair Swiss Lace Curly Hair Lace Front Wig') !== false || stripos($pt[$i],'Alipearl Lace Front Wig Silky Straight 100% Virgin Human Hair') !== false || stripos($pt[$i],'Long Wigs Water Wave Lace Front Wigs Natural Wave Wigs For Sale') !== false || stripos($pt[$i],'Deep Wave Long Hair Wigs Lace Front Wigs Cheap Human Hair Wigs') !== false || stripos($pt[$i],'Long Wigs Loose Deep Wave Lace Front Wigs For Black Women') !== false || stripos($pt[$i],'Long Black Wigs Body Wave Lace Front Wigs With Baby Hair') !== false || stripos($pt[$i],'Long Curly Wigs Lace Front Wigs Human Hair Lace Front Wigs') !== false || stripos($pt[$i],'Blonde Skunk Stripe Hair Natural Body Wave Hairstyle Lace Wigs for Women') !== false)?''.$pt[$i].'':$pt[$i]; if(isset($lk[$i])) { $product .= ($product != '')?' , '.$a.'':''.$a.''; } else { $product .= ($product != '')?' , '.$a:$a; } } } else { $octs = $this->colourorderts->get_text($fullorder['product']); $a = $octs?''.$fullorder['product'].'':$fullorder['product']; //$a = (stripos($fullorder['product'],'Lace Front Wig Body Wave Human Hair Wigs Pre Plucked Brazilian Virgin Hair') !== false || stripos($fullorder['product'],'Deep Wave Wig 100 Human Hair Swiss Lace Curly Hair Lace Front Wig') !== false || stripos($fullorder['product'],'Alipearl Lace Front Wig Silky Straight 100% Virgin Human Hair') !== false || stripos($fullorder['product'],'Long Wigs Water Wave Lace Front Wigs Natural Wave Wigs For Sale') !== false || stripos($fullorder['product'],'Deep Wave Long Hair Wigs Lace Front Wigs Cheap Human Hair Wigs') !== false || stripos($fullorder['product'],'Long Wigs Loose Deep Wave Lace Front Wigs For Black Women') !== false || stripos($fullorder['product'],'Long Black Wigs Body Wave Lace Front Wigs With Baby Hair') !== false || stripos($fullorder['product'],'Long Curly Wigs Lace Front Wigs Human Hair Lace Front Wigs') !== false || stripos($fullorder['product'],'Blonde Skunk Stripe Hair Natural Body Wave Hairstyle Lace Wigs for Women') !== false)?''.$fullorder['product'].'':$fullorder['product']; $product = $a; } $this->data['product'] = $product; $out = $this->systemtransfer->find_all("number = '".$fullorder['number']."'"); $outread = ''; if($out) { foreach ($out as $val) { $list = ''; $rk = explode('|',trim($val['rk'],'|')); $rktime = explode('|',trim($val['rktime'],'|')); $zw = array(); $t = $this->transfer->find_all("1=1"); foreach ($t as $v) { $zw[$v['id']] = $v['title']; } if($val['rk'] != '' && count($rk) > 0) { for($i=0;$i:'.$list.'
'; } } else { $systemwigsout = $this->systemwigsout->find_all("number = '".$fullorder['number']."'"); $outread = array(); if($systemwigsout) { foreach ($systemwigsout as $v) { if($v['czwarehouse'] == 37) { $outread[] = '华荣厂'; } else if($v['czwarehouse'] == 0) { $outread[] = '龙盈厂'; } $cz = explode('|',trim($v['cz'],'|')); $cztime = explode('|',trim($v['cztime'],'|')); $zw = $this->transfer->get_list(); if($v['cz'] != '' && count($cz) > 0) { for($i=0;$i'AL','alaska'=>'AK','arizona'=>'AZ','arkansas'=>'AR','california'=>'CA','colorado'=>'CO','connecticut'=>'CT','delaware'=>'DE','florida'=>'FL','georgia'=>'GA','hawaii'=>'HI','idaho'=>'ID','illinois'=>'IL','indiana'=>'IN','iowa'=>'IA','kansas'=>'KS','kentucky'=>'KY','louisiana'=>'LA','maine'=>'ME','maryland'=>'MD','massachusetts'=>'MA','michigan'=>'MI','minnesota'=>'MN','mississippi'=>'MS','missouri'=>'MO','montana'=>'MT','nebraska'=>'NE','nevada'=>'NV','new hampshire'=>'NH','new jersey'=>'NJ','new mexico'=>'NM','new york'=>'NY','north carolina'=>'NC','north dakota'=>'ND','ohio'=>'OH','oklahoma'=>'OK','oregon'=>'OR','pennsylvania'=>'PA','rhode island'=>'RI','south carolina'=>'SC','south dakota'=>'SD','tennessee'=>'TN','texas'=>'TX','utah'=>'UT','vermont'=>'VT','virginia'=>'VA','washington'=>'WA','west virginia'=>'WV','wisconsin'=>'WI','wyoming'=>'WY','district of columbia'=>'DC','virgin islands'=>'VI','guam'=>'GU','puerto rico'=>'PR'); $ToState = array_flip($ToState); $klarnadata3 = str_replace(' ','',$klarnadata[3]); $city = str_replace(' ','',$fullorder['city']); $klarnadataaddress = explode($city,$klarnadata3); if(isset($klarnadataaddress[1])) { $klarnadata3 = $city.$klarnadataaddress[1]; $klarnadatacolor = explode(',',$klarnadata3); unset($klarnadatacolor[4]); unset($klarnadatacolor[6]); if(isset($ToState[$klarnadatacolor[1]])) { $klarnadatacolor[1] = ucwords($ToState[$klarnadatacolor[1]]); } $klarnadata['color'] = $klarnadataaddress[0].implode(",",$klarnadatacolor); } else { $klarnadata['color'] = $klarnadata3; } } } else { $klarnadata = ''; } $p = explode('-',$fullorder['paypal']); $this->data['klarnacolor'] = $klarnacolor; $this->data['klarnadata'] = $klarnadata; $this->data['systemwigsout'] = $outread; $this->_Template('fullorder_zw',$this->data); } public function _dcdxyz() { $post = $this->input->get(NULL, TRUE); if(isset($post['timetk'])) { $timetk = $this->input->get('timetk',true); $timetj = $this->input->get('timetj',true); $timetk = strtotime($timetk); $timetj = strtotime($timetj); $where = "oldwaybill != ''"; if($timetk && $timetj) { $where .= " and dtime > '$timetk' and dtime < '$timetj'"; } //数据排序 $order_str = "dtime desc"; //取得信息列表 $info_list = $this->fullorder->find_all($where,'orderinfo,number,oldwaybill',$order_str); $data = array(); foreach ($info_list as $key=>$value) { $ob = ''; $oldwaybill = explode('-',trim($value['oldwaybill'],'-')); if(count($oldwaybill) < 2) { continue; } $oldwaybill = array_reverse($oldwaybill); //调整顺序 foreach ($oldwaybill as $v) { $dw = explode('/',$v); if(isset($dw[1])) { $dwls[$dw[1]] = 1; $ob .= $dw[1].'、'; } } $info_list[$key]['oldwaybill'] = trim($ob,'、'); $data[] = $info_list[$key]; } $title = "多运单信息 ".date("Y-m-d"); $titlename = "

".$title."

订单号 编号 运单号
"; $filename = $title.".xls"; $tail = "\n"; $this->excel->get_fz2($data,$titlename,$filename,$tail); } } public function _thxz() { $post = $this->input->get(NULL, TRUE); if(isset($post['timetk'])) { $timetk = $this->input->get('timetk',true); $timetj = $this->input->get('timetj',true); $timetk = strtotime($timetk); $timetj = strtotime($timetj); $where = "returndata != ''"; if($timetk && $timetj) { $where .= " and dtime > '$timetk' and dtime < '$timetj'"; } //数据排序 $order_str = "dtime desc"; //取得信息列表 $info_list = $this->fullorder->find_all($where,'orderinfo,number,returndata',$order_str); foreach ($info_list as $key=>$value) { $ydh = explode('">',$value['returndata']); $ydh = explode('',$ydh[1]); $info_list[$key]['returndata'] = $ydh[0]; $time = explode('pdf/',$value['returndata']); $time = explode('/',$time[1]); $info_list[$key]['time'] = $time[0]; } $title = "退货订单信息 ".date("Y-m-d"); $titlename = "

".$title."

订单号 编号 退货运单号 退货时间
"; $filename = $title.".xls"; $tail = "\n"; $this->excel->get_fz2($info_list,$titlename,$filename,$tail); } } public function _ddcf() { $post = $this->input->post(NULL, TRUE); if(isset($post['number'])) { $number = $this->input->post('number',true); $data = $this->fullorder->get_number($number); if(!$data) { echo json_encode(array('msg'=>'没有找到此订单','success'=>false));exit; } if($data['review'] != 1 && $data['review'] != 2) { echo json_encode(array('msg'=>'必须是 待审核 状态才能拆分','success'=>false));exit; } if($data['merge'] != 0) { echo json_encode(array('msg'=>'已合并的订单无法使用此拆分功能','success'=>false));exit; } $cfnum = explode('-',trim($number,'-')); // if((count($cfnum) > 3 && stripos($number,'-PF-') === false)) // { // echo json_encode(array('msg'=>'只能在原单操作拆分','success'=>false));exit; // } if(count($cfnum) > 4 && stripos($number,'-PF-') !== false) { echo json_encode(array('msg'=>'只能在原单操作拆分','success'=>false));exit; } $num = $this->fullorder->find_count("number like '".$number."%'"); $data['number'] = $data['number'].'-'.$num; $data['orderinfo'] = $data['shop'].date('ymdHis',time()).rand(0,1);; $data['shouldmoney'] = 0; $data['budget'] = 0; $data['shipremarks'] = ''; $data['source'] = 1; //$data['review'] = 2; $data['extra_status'] = 1;//拆分的订单 unset($data['id']); unset($data['jweight']); unset($data['fpcount']); unset($data['returndata']); unset($data['waybill']); unset($data['oldwaybill']); unset($data['printtime']); if($this->fullorder->insert($data)) { echo json_encode(array('msg'=>'拆分成功!新订单编号:'.$data['number'],'success'=>true));exit; } else { echo json_encode(array('msg'=>'拆分失败,请重试','success'=>false));exit; } } } public function _cf() //合并订单拆分 { $post = $this->input->post(NULL, TRUE); if(isset($post['id'])) { $id = $this->input->post('id',true); $b = $this->fullorder->read($id); $order = array(); if($b['merge'] == $b['id']) { $data = $this->fullorder->find_all("merge = '".$b['merge']."'"); foreach ($data as $v) { $a = $this->fullorderhb->get_orderinfo($v['orderinfo']); if($a) { $this->fullorder->save($a,$v['id']); } $order[] = $v['id']; } echo json_encode(array('msg'=>'拆分成功!','d'=>$order,'success'=>true));exit; } else { echo json_encode(array('msg'=>'拆分条件错误!','success'=>false));exit; } } } }