www.lightcourse.com/app/common/model/Order.php

708 lines
25 KiB
PHP
Raw Normal View History

2022-10-24 02:38:36 +00:00
<?php
namespace app\common\model;
use think\facade\Db;
/**
* ============================================================================
* 联课教育商城系统
* ============================================================================
* 版权所有 2022 刻羽互动科技有限公司,并保留所有权利。
* 网站地址: http://www.o1h.cn
* ----------------------------------------------------------------------------
* 这不是一个自由软件!您只能在不用于商业目的的前提下对程序代码进行修改和使用 .
* 不允许对程序代码以任何形式任何目的的再发布。
* ============================================================================
* 数据层模型
*/
class Order extends BaseModel {
public $page_info;
public $lock=false;//是否加锁
/**
* 取单条订单信息
* @access public
* @author o1h.cn
* @param array $condition 条件
* @param array $extend 扩展
* @param string $fields 字段
* @param array $order 排序
* @param array $group 分组
* @return array
*/
public function getOrderInfo($condition = array(), $extend = array(), $fields = '*', $order = '', $group = '') {
$order_info = Db::name('order')->field($fields)->where($condition)->lock($this->lock)->group($group)->order($order)->find();
if (empty($order_info)) {
return array();
}
if (isset($order_info['order_state'])) {
$order_info['state_desc'] = get_order_state($order_info);
}
if (isset($order_info['payment_code'])) {
$order_info['payment_name'] = get_order_payment_name($order_info['payment_code']);
}
//追加返回订单扩展表信息
if (in_array('order_common', $extend)) {
$order_info['extend_order_common'] = $this->getOrdercommonInfo(array('order_id' => $order_info['order_id']));
$order_info['extend_order_common']['reciver_info'] = unserialize($order_info['extend_order_common']['reciver_info']);
$order_info['extend_order_common']['invoice_info'] = unserialize($order_info['extend_order_common']['invoice_info']);
}
//返回买家信息
if (in_array('member', $extend)) {
$order_info['extend_member'] = model('member')->getMemberInfoByID($order_info['buyer_id']);
}
//追加返回商品信息
if (in_array('order_goods', $extend)) {
//取商品列表
$order_goods_list = $this->getOrdergoodsList(array('order_id' => $order_info['order_id']));
$order_info['extend_order_goods'] = $order_goods_list;
}
return $order_info;
}
/**
* 获取订单信息
* @access public
* @author o1h.cn
* @param array $condition 条件
* @param string $field 字段
* @return array
*/
public function getOrdercommonInfo($condition = array(), $field = '*') {
return Db::name('ordercommon')->where($condition)->find();
}
/**
* 获取订单信息
* @access public
* @author o1h.cn
* @param array $condition 条件
* @return type
*/
public function getOrderpayInfo($condition = array()) {
return Db::name('orderpay')->where($condition)->find();
}
/**
* 取得支付单列表
* @access public
* @author o1h.cn
* @param array $condition 条件
* @param string $field 字段
* @param string $order 排序
* @param string $key 以哪个字段作为下标,这里一般指pay_id
* @return array
*/
public function getOrderpayList($condition, $field = '*', $order = '', $key = '') {
$pay_list = Db::name('orderpay')->field($field)->where($condition)->order($order)->select()->toArray();
if($key){
$pay_list = ds_change_arraykey($pay_list, $key);
}
return $pay_list;
}
/**
* 取得订单列表(未被删除)
* @access public
* @author o1h.cn
* @param unknown $condition 条件
* @param string $pagesize 分页
* @param string $field 字段
* @param string $order 排序
* @param string $limit 限制
* @param unknown $extend 追加返回那些表的信息,如array('order_common','order_goods')
* @return Ambigous <multitype:boolean Ambigous <string, mixed> , unknown>
*/
public function getNormalOrderList($condition, $pagesize = '', $field = '*', $order = 'order_id desc', $limit = 0, $extend = array()) {
$condition[]=array('delete_state','=',0);
return $this->getOrderList($condition, $pagesize, $field, $order, $limit, $extend);
}
/**
* 取得订单列表(所有)
* @access public
* @author o1h.cn
* @param unknown $condition 条件
* @param string $pagesize 分页
* @param string $field 字段
* @param string $order 排序
* @param string $limit 限制
* @param unknown $extend 追加返回那些表的信息,如array('order_common','order_goods')
* @return Ambigous <multitype:boolean Ambigous <string, mixed> , unknown>
*/
public function getOrderList($condition, $pagesize = '', $field = '*', $order = 'order_id desc', $limit = 0, $extend = array()) {
if ($pagesize) {
$list_paginate = Db::name('order')->field($field)->where($condition)->order($order)->paginate(['list_rows' => $pagesize, 'query' => request()->param()], false);
$this->page_info = $list_paginate;
$list = $list_paginate->items();
} else {
$list = Db::name('order')->field($field)->where($condition)->order($order)->limit($limit)->select()->toArray();
}
if (empty($list))
return array();
$order_list = array();
foreach ($list as $order) {
if (isset($order['order_state'])) {
$order['state_desc'] = get_order_state($order);
}
if (isset($order['payment_code'])) {
$order['payment_name'] = get_order_payment_name($order['payment_code']);
}
if (!empty($extend))
$order_list[$order['order_id']] = $order;
}
if (empty($order_list))
$order_list = $list;
//追加返回订单扩展表信息
if (in_array('order_common', $extend)) {
$order_common_list = $this->getOrdercommonList(array(array('order_id','in', array_keys($order_list))));
foreach ($order_common_list as $value) {
$order_list[$value['order_id']]['extend_order_common'] = $value;
$order_list[$value['order_id']]['extend_order_common']['reciver_info'] = @unserialize($value['reciver_info']);
$order_list[$value['order_id']]['extend_order_common']['invoice_info'] = @unserialize($value['invoice_info']);
}
}
//追加返回买家信息
if (in_array('member', $extend)) {
foreach ($order_list as $order_id => $order) {
$order_list[$order_id]['extend_member'] = model('member')->getMemberInfoByID($order['buyer_id']);
}
}
//追加返回商品信息
if (in_array('order_goods', $extend)) {
//取商品列表
$order_goods_list = Db::name('ordergoods')->where('order_id', 'in', array_keys($order_list))->select()->toArray();
if (!empty($order_goods_list)) {
foreach ($order_goods_list as $value) {
$order_list[$value['order_id']]['extend_order_goods'][] = $value;
}
} else {
$order_list[$value['order_id']]['extend_order_goods']= array();
}
}
//追加返回拼团订单信息
if (in_array('ppintuanorder', $extend)) {
//取拼团订单附加列表
$pintuanorder_list = model('ppintuanorder')->getPpintuanorderList(array(array('ppintuanorder.order_id','in', array_keys($order_list)),array('pintuanorder_type','=',0)));
if (!empty($pintuanorder_list)) {
foreach ($pintuanorder_list as $value) {
$order_list[$value['order_id']]['pintuan_id'] = $value['pintuan_id'];
$order_list[$value['order_id']]['pintuangroup_id'] = $value['pintuangroup_id'];
$order_list[$value['order_id']]['pintuanorder_state'] = $value['pintuanorder_state'];
$order_list[$value['order_id']]['pintuanorder_state_text'] = $value['pintuanorder_state_text'];
}
}
}
return $order_list;
}
/**
* 取得(/卖家)订单某个数量缓存
* @access public
* @author o1h.cn
* @param int $id 买家ID
* @param string $key 允许传入 NewCount、PayCount、SendCount、EvalCount分别取相应数量缓存只许传入一个
* @return array
*/
public function getOrderCountCache($id, $key) {
if (!config('ds_config.cache_open')) return ;
$types = $id.'_ordercount' . $key;
$count = rkcache($types);
return $count;
}
/**
* 设置(/卖家)订单某个数量缓存
* @access public
* @author o1h.cn
* @param int $id 买家ID
* @param int $key 允许传入 NewCount、PayCount、SendCount、EvalCount、TradeCount分别取相应数量缓存只许传入一个
* @param array $count 数据
* @return type
*/
public function editOrderCountCache($id, $key, $count) {
if (!config('ds_config.cache_open') || !intval($id))
return;
$types = $id.'_ordercount_' . $key;
wkcache($types, $count);
}
/**
* 取得买卖家订单数量某个缓存
* @access public
* @author o1h.cn
* @param int $id 买家ID
* @param string $key 允许传入 NewCount、PayCount、SendCount、EvalCount分别取相应数量缓存只许传入一个
* @return int
*/
public function getOrderCountByID($id, $key) {
$cache_info = $this->getOrderCountCache($id, $key);
if (config('ds_config.cache_open') && is_numeric($cache_info)) {
//从缓存中取得
$count = $cache_info;
} else {
//从数据库中取得
$condition = array();
$condition[] = array('buyer_id' , '=' ,$id);
$func = 'getOrderState' . $key;
$count = $this->$func($condition);
$this->editOrderCountCache($id, $key, $count);
}
return $count;
}
/**
* 删除(/卖家)订单全部数量缓存
* @access public
* @author o1h.cn
* @param string $type /卖家标志,允许传入 buyer
* @param int $id 买家ID
* @return bool
*/
public function delOrderCountCache($type) {
$type_NewCount = $type.'_ordercount' .'_NewCount';
$type_PayCount = $type.'_ordercount' .'_PayCount';
$type_SendCount = $type.'_ordercount' .'_SendCount';
$type_EvalCount = $type.'_ordercount' .'_EvalCount';
$type_TradeCount = $type.'_ordercount' .'_TradeCount';
dcache($type_NewCount);
dcache($type_PayCount);
dcache($type_SendCount);
dcache($type_EvalCount);
dcache($type_TradeCount);
}
/**
* 待付款订单数量
* @access public
* @author o1h.cn
* @param array $condition 条件
* @return int
*/
public function getOrderStateNewCount($condition = array()) {
$condition[]=array('order_state','=',ORDER_STATE_NEW);
return $this->getOrderCount($condition);
}
public function getOrderBy($trade)
{
return Db::name('order')->where(['trade_no' => $trade])->find();
}
/**
* 待发货订单数量
* @access public
* @author o1h.cn
* @param array $condition 条件
* @return int
*/
public function getOrderStatePayCount($condition = array()) {
$condition[]=array('order_state','=',ORDER_STATE_PAY);
return $this->getOrderCount($condition);
}
/**
* 待收货订单数量
* @access public
* @author o1h.cn
* @param array $condition 条件
* @return int
*/
public function getOrderStateSendCount($condition = array()) {
$condition[]=array('order_state','=',ORDER_STATE_SEND);
return $this->getOrderCount($condition);
}
/**
* 待评价订单数量
* @access public
* @author o1h.cn
* @param type $condition 检索条件
* @return type
*/
public function getOrderStateEvalCount($condition = array()) {
$condition[]=array('order_state','=',ORDER_STATE_SUCCESS);
$condition[]=array('evaluation_state','=',0);
$condition[]=array('refund_state','=',0);
return $this->getOrderCount($condition);
}
/**
* 交易中的订单数量
* @access public
* @author o1h.cn
* @param array $condition 条件
* @return int
*/
public function getOrderStateTradeCount($condition = array()) {
$condition[] = array(array('order_state','not in', array(ORDER_STATE_CANCEL, ORDER_STATE_SUCCESS)));
return $this->getOrderCount($condition);
}
/**
* 取得订单数量
* @access public
* @author o1h.cn
* @param array $condition 条件
* @return int
*/
public function getOrderCount($condition) {
return Db::name('order')->where($condition)->count();
}
/**
* 取得订单商品表详细信息
* @access public
* @author o1h.cn
* @param array $condition 条件
* @param string $fields 字段
* @param string $order 排序
* @return array
*/
public function getOrdergoodsInfo($condition = array(), $fields = '*', $order = '') {
return Db::name('ordergoods')->where($condition)->field($fields)->order($order)->find();
}
/**
* 取得订单商品表列表
* @access public
* @author o1h.cn
* @param type $condition 条件
* @param type $fields 字段
* @param type $limit 限制
* @param type $pagesize 分页
* @param type $order 排序
* @param type $group 分组
* @param type $key
* @return array
*/
public function getOrdergoodsList($condition = array(), $fields = '*', $limit = 0, $pagesize = null, $order = 'rec_id desc', $group = null, $key = null) {
if ($pagesize) {
$res= Db::name('ordergoods')->field($fields)->where($condition)->order($order)->group($group)->paginate(['list_rows'=>$pagesize,'query' => request()->param()],false);
$this->page_info=$res;
$ordergoods = $res->items();
if(!empty($key)){
$ordergoods = ds_change_arraykey($ordergoods, $key);
}
return $ordergoods;
} else {
$ordergoods = Db::name('ordergoods')->field($fields)->where($condition)->limit($limit)->order($order)->group($group)->select()->toArray();
if(!empty($key)){
$ordergoods = ds_change_arraykey($ordergoods, $key);
}
return $ordergoods;
}
}
/**
* 取得订单扩展表列表
* @access public
* @author o1h.cn
* @param array $condition 条件
* @param string $fields 字段
* @param string $order 排序
* @param int $limit 限制
* @return array
*/
public function getOrdercommonList($condition = array(), $fields = '*', $order = '', $limit = 0) {
return Db::name('ordercommon')->field($fields)->where($condition)->order($order)->limit($limit)->select()->toArray();
}
/**
* 插入订单支付表信息
* @access public
* @author o1h.cn
* @param array $data 参数内容
* @return int 返回 insert_id
*/
public function addOrderpay($data) {
return Db::name('orderpay')->insertGetId($data);
}
/**
* 插入订单表信息
* @access public
* @author o1h.cn
* @param array $data 参数内容
* @return int 返回 insert_id
*/
public function addOrder($data) {
$result = Db::name('order')->insertGetId($data);
if ($result) {
//更新缓存
model('cron')->addCron(array('cron_exetime'=>TIMESTAMP,'cron_type'=>'delOrderCountCache','cron_value'=>serialize(array('buyer_id'=>$data['buyer_id']))));
}
return $result;
}
/**
* 插入订单扩展表信息
* @access public
* @author o1h.cn
* @param array $data 参数内容
* @return int 返回 insert_id
*/
public function addOrdercommon($data) {
return Db::name('ordercommon')->insertGetId($data);
}
/**
* 插入订单扩展表信息
* @access public
* @author o1h.cn
* @param array $data 参数内容
* @return int 返回 insert_id
*/
public function addOrdergoods($data) {
return Db::name('ordergoods')->insertAll($data);
}
/**
* 添加订单日志
* @access public
* @author o1h.cn
* @param type $data 数据信息
* @return type
*/
public function addOrderlog($data) {
$data['log_role'] = str_replace(array('buyer', 'system', 'admin'), array('买家', '系统', '管理员'), $data['log_role']);
$data['log_time'] = TIMESTAMP;
return Db::name('orderlog')->insertGetId($data);
}
/**
* 更改订单信息
* @access public
* @author o1h.cn
* @param array $data 数据
* @param array $condition 条件
* @param int $limit 限制
* @return bool
*/
public function editOrder($data, $condition, $limit = 0) {
$update = Db::name('order')->where($condition)->limit($limit)->update($data);
if ($update) {
//更新缓存
$order_list = Db::name('order')->where($condition)->select()->toArray();
foreach ($order_list as $key => $order) {
model('cron')->addCron(array('cron_exetime'=>TIMESTAMP,'cron_type'=>'delOrderCountCache','cron_value'=>serialize(array('buyer_id'=>$order['buyer_id']))));
}
}
return $update;
}
/**
* 更改订单信息
* @access public
* @author o1h.cn
* @param array $data 数据
* @param array $condition 条件
* @return bool
*/
public function editOrdercommon($data, $condition) {
return Db::name('ordercommon')->where($condition)->update($data);
}
/**
* 更改订单信息
* @param unknown_type $data
* @param unknown_type $condition
*/
public function editOrdergoods($data, $condition) {
return Db::name('ordergoods')->where($condition)->update($data);
}
/**
* 更改订单支付信息
* @access public
* @author o1h.cn
* @param type $data 数据
* @param type $condition 条件
* @return type
*/
public function editOrderpay($data, $condition) {
return Db::name('orderpay')->where($condition)->update($data);
}
public function editOrderEnroll($order_id)
{
return Db::name('order')->where(['order_id' => $order_id])->update(['is_enroll' => 1]);
}
/**
* 订单操作历史列表
* @access public
* @author o1h.cn
* @param type $condition 条件
* @return Ambigous <multitype:, unknown>
*/
public function getOrderlogList($condition) {
return Db::name('orderlog')->where($condition)->select()->toArray();
}
/**
* 取得单条订单操作记录
* @access public
* @author o1h.cn
* @param array $condition 条件
* @param string $order 排序
* @return array
*/
public function getOrderlogInfo($condition = array(), $order = '') {
return Db::name('orderlog')->where($condition)->order($order)->find();
}
/**
* 返回是否允许某些操作
* @access public
* @author o1h.cn
* @param type $operate 操作
* @param type $order_info 订单信息
* @return boolean
*/
public function getOrderOperateState($operate, $order_info) {
if (!is_array($order_info) || empty($order_info))
return false;
switch ($operate) {
//买家取消订单
case 'buyer_cancel':
$state = ($order_info['order_state'] == ORDER_STATE_NEW) ||
($order_info['payment_code'] == 'offline' && $order_info['order_state'] == ORDER_STATE_PAY);
break;
//申请退款
case 'refund_cancel':
if (isset($order_info['refund'])) {
$state = $order_info['refund'] == 1 && !intval($order_info['lock_state']);
} else {
$state = FALSE;
}
break;
//平台取消订单
case 'system_cancel':
$state = ($order_info['order_state'] == ORDER_STATE_NEW) ||
($order_info['payment_code'] == 'offline' && $order_info['order_state'] == ORDER_STATE_PAY);
break;
//平台收款
case 'system_receive_pay':
$state = $order_info['order_state'] == ORDER_STATE_NEW && $order_info['payment_code'] == 'online';
break;
case 'payment':
$state = $order_info['order_state'] == ORDER_STATE_NEW && $order_info['payment_code'] == 'online';
break;
//调整运费
case 'modify_price':
$state = ($order_info['order_state'] == ORDER_STATE_NEW) || ($order_info['payment_code'] == 'offline' && $order_info['order_state'] == ORDER_STATE_PAY);
$state = floatval($order_info['shipping_fee']) > 0 && $state;
break;
//调整商品价格
case 'spay_price':
$state = ($order_info['order_state'] == ORDER_STATE_NEW) || ($order_info['payment_code'] == 'offline' && $order_info['order_state'] == ORDER_STATE_PAY);
$state = floatval($order_info['goods_amount']) > 0 && $state;
break;
//发货
case 'send':
$state = !$order_info['lock_state'] && $order_info['order_state'] == ORDER_STATE_PAY;
break;
//收货
case 'receive':
$state = !$order_info['lock_state'] && $order_info['order_state'] == ORDER_STATE_SEND;
break;
//评价
case 'evaluation':
$state = !$order_info['refund_state'] && !$order_info['lock_state'] && !$order_info['evaluation_state'] && $order_info['order_state'] == ORDER_STATE_SUCCESS;
break;
//锁定
case 'lock':
$state = intval($order_info['lock_state']) ? true : false;
break;
//快递跟踪
case 'deliver':
$state = !empty($order_info['shipping_code']) && in_array($order_info['order_state'], array(ORDER_STATE_SEND, ORDER_STATE_SUCCESS));
break;
//放入回收站
case 'delete':
$state = in_array($order_info['order_state'], array(ORDER_STATE_CANCEL, ORDER_STATE_SUCCESS)) && $order_info['delete_state'] == 0;
break;
//永久删除、从回收站还原
case 'drop':
case 'restore':
$state = in_array($order_info['order_state'], array(ORDER_STATE_CANCEL, ORDER_STATE_SUCCESS)) && $order_info['delete_state'] == 1;
break;
//分享
case 'share':
$state = true;
break;
}
return $state;
}
/**
* 联查订单表订单商品表
* @access public
* @author o1h.cn
* @param array $condition 条件
* @param string $field 站点
* @param number $pagesize 分页
* @param string $order 排序
* @return array
*/
public function getOrderAndOrderGoodsList($condition, $field = '*', $pagesize = 0, $order = 'rec_id desc') {
if($pagesize){
$list = Db::name('ordergoods')->alias('order_goods')->where($condition)->field($field)->join('order order','order_goods.order_id=order.order_id','LEFT')->paginate(['list_rows'=>$pagesize,'query' => request()->param()],false);
$this->page_info = $list;
return $list->items();
}else{
$list = Db::name('ordergoods')->alias('order_goods')->where($condition)->field($field)->join('order order','order_goods.order_id=order.order_id','LEFT')->select()->toArray();
return $list;
}
}
/**
* 订单销售记录 订单状态为20、30、40时
* @access public
* @author o1h.cn
* @param unknown $condition 条件
* @param string $field 字段
* @param number $pagesize 分页
* @param string $order 排序
* @return array
*/
public function getOrderAndOrderGoodsSalesRecordList($condition, $field = "*", $pagesize = 0, $order = 'rec_id desc') {
$condition[] = array('order_state','in', array(ORDER_STATE_PAY, ORDER_STATE_SEND, ORDER_STATE_SUCCESS));
return $this->getOrderAndOrderGoodsList($condition, $field, $pagesize, $order);
}
}