547 lines
22 KiB
PHP
547 lines
22 KiB
PHP
<?php
|
|
|
|
namespace app\admin\controller;
|
|
use think\facade\View;
|
|
use think\facade\Lang;
|
|
use think\facade\Db;
|
|
/**
|
|
* ============================================================================
|
|
* 联课教育商城系统
|
|
* ============================================================================
|
|
* 版权所有 2022 刻羽互动科技有限公司,并保留所有权利。
|
|
* 网站地址: http://www.o1h.cn
|
|
* ----------------------------------------------------------------------------
|
|
* 这不是一个自由软件!您只能在不用于商业目的的前提下对程序代码进行修改和使用 .
|
|
* 不允许对程序代码以任何形式任何目的的再发布。
|
|
* ============================================================================
|
|
* 控制器
|
|
*/
|
|
class Order extends AdminControl
|
|
{
|
|
|
|
const EXPORT_SIZE = 1000;
|
|
|
|
public function initialize()
|
|
{
|
|
parent::initialize();
|
|
Lang::load(base_path() . 'admin/lang/' . config('lang.default_lang') . '/order.lang.php');
|
|
}
|
|
|
|
public function enroll()
|
|
{
|
|
$order_id = input('param.order_id');
|
|
$ordergoods = Db::name('ordergoods')->where(['order_id' => $order_id])->find();
|
|
//查询课程信息
|
|
$goods = Db::name('goods')->where(['goods_id' => $ordergoods['goods_id']])->find();
|
|
|
|
$college = $goods['ke_college'];
|
|
$goods_serial = $goods['goods_serial'];
|
|
$goods_name = $goods['goods_name'];
|
|
$time = $goods['ke_start_time'] .'-'. $goods['ke_end_time'];
|
|
$ke_period= $goods['ke_period'];
|
|
$ke_type = $goods['ke_type'];
|
|
|
|
//查询学生
|
|
$order = Db::name('order')->where(['order_id' => $order_id])->find();
|
|
$user = Db::name('member')->where(['member_id' => $order['buyer_id']])->find();
|
|
$name = $user['member_name'];
|
|
|
|
|
|
$message = "
|
|
Dear $name Student,<br>
|
|
|
|
Welcome back to $name! Thank you for seeking enrollment through us. <br>
|
|
|
|
This message is your official confirmation that you have successfully completed enrollment in the following:<br>
|
|
|
|
Host Institution: $college<br>
|
|
Course Code: $goods_serial<br>
|
|
Course Title: $goods_name<br>
|
|
Session Dates: $time<br>
|
|
Program Duration: $ke_period weeks<br>
|
|
Mode of Instruction: $ke_type<br>
|
|
|
|
We look forward to helping you achieve your professional and personal goals. For further assistance, please email us at studentservice@lightglobal.org.<br>
|
|
|
|
We wish you the very best in your studies!<br>
|
|
Kind regards,<br>
|
|
$name
|
|
|
|
";
|
|
|
|
//发送邮件
|
|
$email = new \sendmsg\Email();
|
|
$rst = $email->send_sys_email($user['member_email'], 'LightCourse Email', $message);
|
|
|
|
$order_model = model('order');
|
|
$order_model->editOrderEnroll($order_id);
|
|
header("Location:/index.php/admin/order/index");
|
|
}
|
|
|
|
public function index()
|
|
{
|
|
$order_model = model('order');
|
|
$condition = array();
|
|
|
|
$order_sn = input('param.order_sn');
|
|
if ($order_sn) {
|
|
$condition[] = array('order_sn','=',$order_sn);
|
|
}
|
|
$order_state = input('param.order_state');
|
|
if (in_array($order_state, array('0', '10', '20', '30', '40'))) {
|
|
$condition[] = array('order_state','=',$order_state);
|
|
}
|
|
$payment_code = input('param.payment_code');
|
|
if ($payment_code) {
|
|
$condition[] = array('payment_code','=',$payment_code);
|
|
}
|
|
$buyer_name = input('param.buyer_name');
|
|
if ($buyer_name) {
|
|
$condition[] = array('buyer_name','=',$buyer_name);
|
|
}
|
|
$query_start_time = input('param.query_start_time');
|
|
$query_end_time = input('param.query_end_time');
|
|
$if_start_time = preg_match('/^20\d{2}-\d{2}-\d{2}$/', $query_start_time);
|
|
$if_end_time = preg_match('/^20\d{2}-\d{2}-\d{2}$/', $query_end_time);
|
|
$start_unixtime = $if_start_time ? strtotime($query_start_time) : null;
|
|
$end_unixtime = $if_end_time ? strtotime($query_end_time) : null;
|
|
if ($start_unixtime) {
|
|
$condition[] = array('add_time','>=',$start_unixtime);
|
|
}
|
|
if ($end_unixtime) {
|
|
$condition[] = array('add_time','<=',$end_unixtime);
|
|
}
|
|
$order_list = $order_model->getOrderList($condition, 10);
|
|
View::assign('show_page', $order_model->page_info->render());
|
|
|
|
foreach ($order_list as $order_id => $order_info) {
|
|
//显示取消订单
|
|
$order_list[$order_id]['if_cancel'] = $order_model->getOrderOperateState('system_cancel', $order_info);
|
|
//显示调整运费
|
|
$order_list[$order_id]['if_modify_price'] = $order_model->getOrderOperateState('modify_price', $order_info);
|
|
//显示收到货款
|
|
$order_list[$order_id]['if_system_receive_pay'] = $order_model->getOrderOperateState('system_receive_pay', $order_info);
|
|
//显示调整价格
|
|
$order_list[$order_id]['if_spay_price'] = $order_model->getOrderOperateState('spay_price', $order_info);
|
|
//显示发货状态
|
|
$order_list[$order_id]['if_send'] = $order_model->getOrderOperateState('send', $order_info);
|
|
}
|
|
//显示支付接口列表(搜索)
|
|
$payment_list = model('payment')->getPaymentOpenList();
|
|
View::assign('payment_list', $payment_list);
|
|
View::assign('order_list', $order_list);
|
|
|
|
View::assign('filtered', $condition ? 1 : 0); //是否有查询条件
|
|
$this->setAdminCurItem('add');
|
|
return View::fetch('index');
|
|
}
|
|
|
|
/**
|
|
* 查看订单
|
|
*/
|
|
public function order_print()
|
|
{
|
|
$order_id = ds_delete_param(input('param.order_id'));
|
|
if (empty($order_id)) {
|
|
$this->error(lang('param_error'));
|
|
}
|
|
$order_model = model('order');
|
|
$condition[] = array('order_id','in',$order_id);
|
|
$order_list = $order_model->getOrderList($condition, '', '*', 'order_id desc', 0, array('order_common', 'order_goods'));
|
|
if (empty($order_list)) {
|
|
$this->error(lang('member_printorder_ordererror'));
|
|
}
|
|
|
|
|
|
//订单商品
|
|
foreach($order_list as $key =>$order_info){
|
|
$goods_all_num = 0;
|
|
$goods_total_price = 0;
|
|
if (isset($order_info['extend_order_goods']) && !empty($order_info['extend_order_goods'])) {
|
|
foreach ($order_info['extend_order_goods'] as $k => $v) {
|
|
$v['goods_name'] = str_cut($v['goods_name'], 100);
|
|
$goods_all_num += $v['goods_num'];
|
|
$v['goods_all_price'] = ds_price_format($v['goods_num'] * $v['goods_price']);
|
|
$goods_total_price += $v['goods_all_price'];
|
|
$order_list[$key]['extend_order_goods'][$k]=$v;
|
|
}
|
|
//优惠金额
|
|
$order_list[$key]['promotion_amount'] = $goods_total_price - $order_info['goods_amount'];
|
|
$order_list[$key]['goods_all_num'] = $goods_all_num;
|
|
$order_list[$key]['goods_total_price'] = ds_price_format($goods_total_price);
|
|
$order_list[$key]['total_page'] = ceil(count($order_info['extend_order_goods']) / 15);
|
|
}
|
|
|
|
}
|
|
View::assign('order_list', $order_list);
|
|
View::assign('seal_printexplain',config('ds_config.seal_printexplain'));
|
|
View::assign('seal_img',config('ds_config.seal_img')?ds_get_pic(DIR_ADMIN,config('ds_config.seal_img')):'');
|
|
$this->setAdminCurItem();
|
|
return View::fetch('order_print');
|
|
}
|
|
|
|
/**
|
|
* 平台订单状态操作
|
|
*
|
|
*/
|
|
public function change_state()
|
|
{
|
|
$order_id = intval(input('param.order_id'));
|
|
if ($order_id <= 0) {
|
|
$this->error(lang('miss_order_number'));
|
|
}
|
|
$order_model = model('order');
|
|
|
|
//获取订单详细
|
|
$condition = array();
|
|
$condition[] = array('order_id','=',$order_id);
|
|
$order_info = $order_model->getOrderInfo($condition);
|
|
|
|
$state_type = input('param.type_state');
|
|
if ($state_type == 'cancel') {
|
|
$result = $this->_order_cancel($order_info);
|
|
if ($result['code']){
|
|
ds_json_encode(10000, $result['msg']);
|
|
}
|
|
} elseif ($state_type == 'spay_price') {
|
|
//修改商品价格
|
|
$result = $this->_order_spay_price($order_info, input('post.'));
|
|
} elseif ($state_type == 'modify_price') {
|
|
//修改商品运费
|
|
$result = $this->_order_ship_price($order_info, input('post.'));
|
|
} elseif ($state_type == 'receive_pay') {
|
|
$result = $this->_order_receive_pay($order_info, input('post.'));
|
|
}
|
|
if (!$result['code']) {
|
|
$this->error($result['msg']);
|
|
} else {
|
|
dsLayerOpenSuccess($result['msg']);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* 系统取消订单
|
|
*/
|
|
private function _order_cancel($order_info)
|
|
{
|
|
$order_model = model('order');
|
|
$logic_order = model('order', 'logic');
|
|
$if_allow = $order_model->getOrderOperateState('system_cancel', $order_info);
|
|
if (!$if_allow) {
|
|
return ds_callback(false, '无权操作');
|
|
}
|
|
try{
|
|
Db::startTrans();
|
|
$logic_order->changeOrderStateCancel($order_info, 'system', $this->admin_info['admin_name']);
|
|
} catch (\Exception $e) {
|
|
Db::rollback();
|
|
return ds_callback(false, $e->getMessage());
|
|
}
|
|
Db::commit();
|
|
$this->log(lang('order_log_cancel') . ',' . lang('order_number') . ':' . $order_info['order_sn'], 1);
|
|
return ds_callback(true, lang('ds_common_op_succ'));
|
|
}
|
|
|
|
/**
|
|
* 修改发货地址
|
|
*/
|
|
private function _edit_order_daddress($daddress_id, $order_id)
|
|
{
|
|
$order_model = model('order');
|
|
$data = array();
|
|
$data['daddress_id'] = intval($daddress_id);
|
|
$condition = array();
|
|
$condition[] = array('order_id','=',$order_id);
|
|
return $order_model->editOrdercommon($data, $condition);
|
|
}
|
|
|
|
/**
|
|
* 修改商品价格
|
|
* @param unknown $order_info
|
|
*/
|
|
private function _order_spay_price($order_info, $post)
|
|
{
|
|
$order_model = model('order');
|
|
$logic_order = model('order', 'logic');
|
|
if (!request()->isPost()) {
|
|
View::assign('order_info', $order_info);
|
|
View::assign('order_id', $order_info['order_id']);
|
|
echo View::fetch('edit_spay_price');
|
|
exit();
|
|
} else {
|
|
$if_allow = $order_model->getOrderOperateState('spay_price', $order_info);
|
|
if (!$if_allow) {
|
|
return ds_callback(false, '无权操作');
|
|
}
|
|
return $logic_order->changeOrderSpayPrice($order_info, 'admin', session('member_name'), $post['goods_amount']);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 修改运费
|
|
* @param unknown $order_info
|
|
*/
|
|
private function _order_ship_price($order_info, $post)
|
|
{
|
|
$order_model = model('order');
|
|
$logic_order = model('order', 'logic');
|
|
if (!request()->isPost()) {
|
|
View::assign('order_info', $order_info);
|
|
View::assign('order_id', $order_info['order_id']);
|
|
echo View::fetch('edit_price');
|
|
exit();
|
|
} else {
|
|
$if_allow = $order_model->getOrderOperateState('modify_price', $order_info);
|
|
if (!$if_allow) {
|
|
return ds_callback(false, '无权操作');
|
|
}
|
|
return $logic_order->changeOrderShipPrice($order_info, 'admin', session('member_name'), $post['shipping_fee']);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* 系统收到货款
|
|
* @throws Exception
|
|
*/
|
|
private function _order_receive_pay($order_info, $post)
|
|
{
|
|
$order_model = model('order');
|
|
$logic_order = model('order', 'logic');
|
|
$if_allow = $order_model->getOrderOperateState('system_receive_pay', $order_info);
|
|
if (!$if_allow) {
|
|
return ds_callback(false, '无权操作');
|
|
}
|
|
|
|
if (!request()->isPost()) {
|
|
View::assign('order_info', $order_info);
|
|
//显示支付接口列表
|
|
$payment_list = model('payment')->getPaymentOpenList();
|
|
//去掉预存款和货到付款
|
|
foreach ($payment_list as $key => $value) {
|
|
if ($value['payment_code'] == 'predeposit' || $value['payment_code'] == 'offline') {
|
|
unset($payment_list[$key]);
|
|
}
|
|
}
|
|
View::assign('payment_list', $payment_list);
|
|
$this->setAdminCurItem('receive_pay');
|
|
echo View::fetch('receive_pay');
|
|
exit;
|
|
} else {
|
|
$order_list = $order_model->getOrderList(array('pay_sn' => $order_info['pay_sn'], 'order_state' => ORDER_STATE_NEW));
|
|
try{
|
|
Db::startTrans();
|
|
$logic_order->changeOrderReceivePay($order_list, 'system', $this->admin_info['admin_name'], $post);
|
|
} catch (\Exception $e) {
|
|
Db::rollback();
|
|
return ds_callback(false, $e->getMessage());
|
|
}
|
|
Db::commit();
|
|
$this->log('将订单改为已收款状态,' . lang('order_number') . ':' . $order_info['order_sn'], 1);
|
|
return ds_callback(true, lang('ds_common_op_succ'));
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 查看订单
|
|
*
|
|
*/
|
|
public function show_order()
|
|
{
|
|
$order_id = intval(input('param.order_id'));
|
|
if ($order_id <= 0) {
|
|
$this->error(lang('miss_order_number'));
|
|
}
|
|
$order_model = model('order');
|
|
$order_info = $order_model->getOrderInfo(array('order_id' => $order_id), array('order_goods', 'order_common'));
|
|
|
|
//订单变更日志
|
|
$log_list = $order_model->getOrderlogList(array('order_id' => $order_info['order_id']));
|
|
View::assign('order_log', $log_list);
|
|
|
|
//退款退货信息
|
|
$refundreturn_model = model('refundreturn');
|
|
$condition = array();
|
|
$condition[] = array('order_id','=',$order_info['order_id']);
|
|
$condition[] = array('admin_time','>', 0);
|
|
$return_list = $refundreturn_model->getReturnList($condition);
|
|
View::assign('return_list', $return_list);
|
|
|
|
//退款信息
|
|
$refund_list = $refundreturn_model->getRefundList($condition);
|
|
View::assign('refund_list', $refund_list);
|
|
|
|
//卖家发货信息
|
|
if (!empty($order_info['extend_order_common']['daddress_id'])) {
|
|
$daddress_info = model('daddress')->getAddressInfo(array('daddress_id' => $order_info['extend_order_common']['daddress_id']));
|
|
View::assign('daddress_info', $daddress_info);
|
|
}
|
|
View::assign('order_info', $order_info);
|
|
return View::fetch('show_order');
|
|
}
|
|
|
|
/**
|
|
* 导出
|
|
*
|
|
*/
|
|
public function export_step1()
|
|
{
|
|
|
|
$order_model = model('order');
|
|
$condition = array();
|
|
$order_sn = input('param.order_sn');
|
|
if ($order_sn) {
|
|
$condition[] = array('order_sn','=',$order_sn);
|
|
}
|
|
$order_state = input('param.order_state');
|
|
if (in_array($order_state, array('0', '10', '20', '30', '40'))) {
|
|
$condition[] = array('order_state','=',$order_state);
|
|
}
|
|
$payment_code = input('param.payment_code');
|
|
if ($payment_code) {
|
|
$condition[] = array('payment_code','=',$payment_code);
|
|
}
|
|
$buyer_name = input('param.buyer_name');
|
|
if ($buyer_name) {
|
|
$condition[] = array('buyer_name','=',$buyer_name);
|
|
}
|
|
$query_start_time = input('param.query_start_time');
|
|
$query_end_time = input('param.query_end_time');
|
|
$if_start_time = preg_match('/^20\d{2}-\d{2}-\d{2}$/', $query_start_time);
|
|
$if_end_time = preg_match('/^20\d{2}-\d{2}-\d{2}$/', $query_end_time);
|
|
$start_unixtime = $if_start_time ? strtotime($query_start_time) : null;
|
|
$end_unixtime = $if_end_time ? strtotime($query_end_time) : null;
|
|
if ($start_unixtime || $end_unixtime) {
|
|
$condition[] = array('add_time','between', array($start_unixtime, $end_unixtime));
|
|
}
|
|
|
|
if (!is_numeric(input('param.page'))) {
|
|
$count = $order_model->getOrderCount($condition);
|
|
$export_list = array();
|
|
if ($count > self::EXPORT_SIZE) { //显示下载链接
|
|
$page = ceil($count / self::EXPORT_SIZE);
|
|
for ($i = 1; $i <= $page; $i++) {
|
|
$limit1 = ($i - 1) * self::EXPORT_SIZE + 1;
|
|
$limit2 = $i * self::EXPORT_SIZE > $count ? $count : $i * self::EXPORT_SIZE;
|
|
$export_list[$i] = $limit1 . ' ~ ' . $limit2;
|
|
}
|
|
View::assign('export_list', $export_list);
|
|
return View::fetch('/public/excel');
|
|
} else { //如果数量小,直接下载
|
|
$data = $order_model->getOrderList($condition, 0, '*', 'order_id desc', self::EXPORT_SIZE);
|
|
$this->createExcel($data);
|
|
}
|
|
} else { //下载
|
|
$limit1 = (input('param.page') - 1) * self::EXPORT_SIZE;
|
|
$limit2 = self::EXPORT_SIZE;
|
|
$data = $order_model->getOrderList($condition, $limit2, '*', 'order_id desc');
|
|
$this->createExcel($data);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 发货
|
|
*/
|
|
public function send()
|
|
{
|
|
$order_id = input('param.order_id');
|
|
if ($order_id <= 0) {
|
|
$this->error(lang('param_error'));
|
|
}
|
|
|
|
$order_model = model('order');
|
|
$condition = array();
|
|
$condition[] = array('order_id','=',$order_id);
|
|
$order_info = $order_model->getOrderInfo($condition, array('order_common', 'order_goods'));
|
|
$if_allow_send = intval($order_info['lock_state']) || !in_array($order_info['order_state'], array(ORDER_STATE_PAY, ORDER_STATE_SEND));
|
|
if ($if_allow_send) {
|
|
$this->error(lang('param_error'));
|
|
}
|
|
|
|
if (!request()->isPost()) {
|
|
View::assign('order_info', $order_info);
|
|
//取发货地址
|
|
$daddress_model = model('daddress');
|
|
$daddress_info = array();
|
|
if ($order_info['extend_order_common']['daddress_id'] > 0) {
|
|
$daddress_info = $daddress_model->getAddressInfo(array('daddress_id' => $order_info['extend_order_common']['daddress_id']));
|
|
}
|
|
if (empty($daddress_info)) {
|
|
//取默认地址
|
|
$daddress_info = $daddress_model->getAddressList(array(), '*', 'daddress_isdefault desc', 1);
|
|
if (!empty($daddress_info)) {
|
|
$daddress_info = $daddress_info[0];
|
|
//写入发货地址编号
|
|
$this->_edit_order_daddress($daddress_info['daddress_id'], $order_id);
|
|
} else {
|
|
//写入发货地址编号
|
|
$this->_edit_order_daddress(0, $order_id);
|
|
}
|
|
}
|
|
View::assign('daddress_info', $daddress_info);
|
|
|
|
//如果是自提订单
|
|
$express_list = rkcache('express', true);
|
|
|
|
|
|
View::assign('express_list', $express_list);
|
|
|
|
return View::fetch('send');
|
|
} else {
|
|
$logic_order = model('order', 'logic');
|
|
$post = input('post.');
|
|
$post['reciver_info'] = $this->_get_reciver_info();
|
|
$result = $logic_order->changeOrderSend($order_info, 'admin', session('admin_name'), $post);
|
|
if (!$result['code']) {
|
|
$this->error($result['msg']);
|
|
} else {
|
|
$this->success($result['msg'], url('order/index'));
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 生成excel
|
|
*
|
|
* @param array $data
|
|
*/
|
|
private function createExcel($data = array())
|
|
{
|
|
Lang::load(base_path() . 'admin/lang/' . config('lang.default_lang') . '/export.lang.php');
|
|
$excel_obj = new \excel\Excel();
|
|
$excel_data = array();
|
|
//设置样式
|
|
$excel_obj->setStyle(array('id' => 's_title', 'Font' => array('FontName' => '宋体', 'Size' => '12', 'Bold' => '1')));
|
|
//header
|
|
$excel_data[0][] = array('styleid' => 's_title', 'data' => lang('order_number'));
|
|
$excel_data[0][] = array('styleid' => 's_title', 'data' => lang('buyer_name'));
|
|
$excel_data[0][] = array('styleid' => 's_title', 'data' => lang('order_time'));
|
|
$excel_data[0][] = array('styleid' => 's_title', 'data' => lang('order_price_from'));
|
|
$excel_data[0][] = array('styleid' => 's_title', 'data' => lang('order_total_transport'));
|
|
$excel_data[0][] = array('styleid' => 's_title', 'data' => lang('exp_od_paytype'));
|
|
$excel_data[0][] = array('styleid' => 's_title', 'data' => lang('order_state'));
|
|
$excel_data[0][] = array('styleid' => 's_title', 'data' => lang('exp_od_buyerid'));
|
|
$excel_data[0][] = array('styleid' => 's_title', 'data' => lang('exp_od_bemail'));
|
|
//data
|
|
foreach ((array)$data as $k => $v) {
|
|
$tmp = array();
|
|
$tmp[] = array('data' => 'DS' . $v['order_sn']);
|
|
$tmp[] = array('data' => $v['buyer_name']);
|
|
$tmp[] = array('data' => date('Y-m-d H:i:s', $v['add_time']));
|
|
$tmp[] = array('format' => 'Number', 'data' => ds_price_format($v['order_amount']));
|
|
$tmp[] = array('format' => 'Number', 'data' => ds_price_format($v['shipping_fee']));
|
|
$tmp[] = array('data' => get_order_payment_name($v['payment_code']));
|
|
$tmp[] = array('data' => get_order_state($v));
|
|
$tmp[] = array('data' => $v['buyer_id']);
|
|
$tmp[] = array('data' => $v['buyer_email']);
|
|
$excel_data[] = $tmp;
|
|
}
|
|
$excel_data = $excel_obj->charset($excel_data, CHARSET);
|
|
$excel_obj->addArray($excel_data);
|
|
$excel_obj->addWorksheet($excel_obj->charset(lang('ds_orders'), CHARSET));
|
|
$excel_obj->generateXML($excel_obj->charset(lang('ds_orders'), CHARSET) . input('param.page') . '-' . date('Y-m-d-H', TIMESTAMP));
|
|
}
|
|
|
|
}
|