123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289 |
- <?php
- namespace app\common\model;
- use think\facade\Db;
- /**
- * ============================================================================
- *
- * ============================================================================
- * 版权所有 2014-2028 浙江惠利玛产业互联网有限公司,并保留所有权利。
- * 网站地址: https://www.valimart.net/
- * ----------------------------------------------------------------------------
- *
- * ============================================================================
- * 数据层模型
- */
- class Vrrefund extends BaseModel {
- public $page_info;
-
- /**
- * 增加退款
- * @access public
- * @author csdeshang
- * @param type $refund_array 退款数组数据
- * @param type $order 排序
- * @return boolean
- */
- public function addVrrefund($refund_array, $order = array()) {
- if (!empty($order) && is_array($order)) {
- $refund_array['order_id'] = $order['order_id'];
- $refund_array['order_sn'] = $order['order_sn'];
- $refund_array['store_id'] = $order['store_id'];
- $refund_array['store_name'] = $order['store_name'];
- $refund_array['buyer_id'] = $order['buyer_id'];
- $refund_array['buyer_name'] = $order['buyer_name'];
- $refund_array['goods_id'] = $order['goods_id'];
- $refund_array['goods_name'] = $order['goods_name'];
- $refund_array['goods_image'] = $order['goods_image'];
- $refund_array['commis_rate'] = $order['commis_rate'];
- }
- $refund_array['refund_sn'] = $this->getVrrefundSn($refund_array['store_id']);
- try {
- Db::startTrans();
- $refund_id = Db::name('vrrefund')->insertGetId($refund_array);
- $code_array = explode(',', $refund_array['redeemcode_sn']);
- $vrorder_model = model('vrorder');
- $vrorder_model->editVrorderCode(array('refund_lock' => 1), array(array('vr_code','in', $code_array))); //退款锁定
- Db::commit();
- return $refund_id;
- } catch (Exception $e) {
- Db::rollback();
- return false;
- }
- }
- /**
- * 平台退款处理
- * @access public
- * @author csdeshang
- * @param type $refund 退款
- * @return boolean
- */
- public function editVrorderRefund($refund) {
- $refund_id = $refund['refund_id'];
- $refund_lock = '0'; //退款锁定状态:0为正常,1为锁定,2为同意
- $vrorder_model = model('vrorder');
-
- $order_id = $refund['order_id']; //订单编号
-
- try {
- Db::startTrans();
- $order = $vrorder_model->getVrorderInfo(array('order_id' => $order_id));
- $state = $this->editVrrefund(array('refund_id' => $refund_id), $refund); ////更新退款
- if ($state && $refund['admin_state'] == '2') {//审核状态:1为待审核,2为同意,3为不同意
- $refundreturn_model=model('refundreturn');
- $refundreturn_model->refundAmount($order, $order['order_amount']);
- if($order['order_promotion_type']==2){//如果是拼团
- $ppintuangroup_info=Db::name('ppintuangroup')->where('pintuangroup_id', $order['promotions_id'])->lock(true)->find();
- if ($ppintuangroup_info && $ppintuangroup_info['pintuangroup_state'] == 1) {
- if ($ppintuangroup_info['pintuangroup_joined'] > 0) {
- Db::name('ppintuangroup')->where('pintuangroup_id', $order['promotions_id'])->dec('pintuangroup_joined')->update();
- if ($ppintuangroup_info['pintuangroup_joined'] == 1) {
- //拼团统计开团数量
- $condition = array();
- $condition[] = array('pintuan_id', '=', $ppintuangroup_info['pintuan_id']);
- $condition[] = array('pintuan_count', '>', 0);
- Db::name('ppintuan')->where($condition)->dec('pintuan_count')->update();
- }
- }
- }
-
- }
-
- $refund_lock = '2';
- if ($state) {
- $order_array = array();
- $order_amount = $order['order_amount']; //订单金额
- $refund_amount = $order['refund_amount'] + $refund['refund_amount']; //退款金额
- $order_array['refund_state'] = ($order_amount - $refund_amount) > 0 ? 1 : 2;
- $order_array['refund_amount'] = ds_price_format($refund_amount);
- $state = $vrorder_model->editVrorder($order_array, array('order_id' => $order_id)); //更新订单退款
-
- //修改分销佣金
- $condition=array();
- $condition[]=array('orderinviter_order_id','=',$order_id);
- $condition[]=array('orderinviter_valid','=',0);
- $condition[]=array('orderinviter_order_type','=',1);
- $orderinviter_list=Db::name('orderinviter')->where($condition)->select()->toArray();
- foreach($orderinviter_list as $orderinviter_info){
- $orderinviter_goods_amount=round($order_amount-$refund_amount,2);
- $orderinviter_money=round($orderinviter_info['orderinviter_ratio']/100*$orderinviter_goods_amount,2);
- Db::name('orderinviter')->where(array(array('orderinviter_id','=',$orderinviter_info['orderinviter_id'])))->update(['orderinviter_goods_amount' => $orderinviter_goods_amount,'orderinviter_money'=>$orderinviter_money]);
- }
-
- }
- }
- if ($state) {
- $code_array = explode(',', $refund['redeemcode_sn']);
- $state = $vrorder_model->editVrorderCode(array('refund_lock' => $refund_lock), array(array('vr_code','in', $code_array))); //更新退款的兑换码
- if ($state && $refund['admin_state'] == '2') {
- model('vrorder','logic')->changeOrderStateSuccess($order_id); //更新订单状态
- }
- }
- Db::commit();
- return $state;
- } catch (Exception $e) {
- Db::rollback();
- return false;
- }
- }
- /**
- * 修改退款
- * @access public
- * @author csdeshang
- * @param type $condition 条件
- * @param type $data 数据
- * @return boolean
- */
- public function editVrrefund($condition, $data) {
- if (empty($condition)) {
- return false;
- }
- if (is_array($data)) {
- $result = Db::name('vrrefund')->where($condition)->update($data);
- return $result;
- } else {
- return false;
- }
- }
- /**
- * 退款编号
- * @access public
- * @author csdeshang
- * @param type $store_id 店铺ID
- * @return string
- */
- public function getVrrefundSn($store_id) {
- $result = mt_rand(100, 999) . substr(500 + $store_id, -3) . date('ymdHis');
- return $result;
- }
- /**
- * 退款记录
- * @access public
- * @author csdeshang
- * @param type $condition 条件
- * @param type $pagesize 分页
- * @param type $limit 限制
- * @param type $fields 字段
- * @return type
- */
- public function getVrrefundList($condition = array(), $pagesize = '', $field = '*', $order = 'refund_id desc', $limit = 0) {
- if($pagesize){
- $result = Db::name('vrrefund')->field($field)->where($condition)->order($order)->paginate(['list_rows'=>$pagesize,'query' => request()->param()],false);
- $this->page_info = $result;
- $result = $result->items();
- }else{
- $result = Db::name('vrrefund')->field($field)->where($condition)->order($order)->limit($limit)->select()->toArray();
- }
-
-
- return $result;
- }
- /**
- * 取得退款记录的数量
- * @access public
- * @author csdeshang
- * @param type $condition 条件
- * @return type
- */
- public function getVrrefundCount($condition) {
- $result = Db::name('vrrefund')->where($condition)->count();
- return $result;
- }
- /**
- * 详细页右侧订单信息
- * @access public
- * @author csdeshang
- * @param type $order_condition 条件
- * @return type
- */
- public function getRightVrorderList($order_condition,$order_id) {
- $vrorder_model = model('vrorder');
- $order_info = $vrorder_model->getVrorderInfo($order_condition);
- $order_list = array();
- $order_list[$order_id] = $order_info;
- $order_list = $vrorder_model->getCodeRefundList($order_list); //没有使用的兑换码列表
- $order_info = $order_list[$order_id];
- $store_model = model('store');
- $store = $store_model->getStoreInfo(array('store_id' => $order_info['store_id']));
- //显示退款
- $order_info['if_refund'] = $vrorder_model->getVrorderOperateState('refund', $order_info);
- $code_list=array();
- if ($order_info['if_refund']) {
- $code_list = $order_info['code_list'];
- }
- return array('order_info'=>$order_info,'store'=>$store,'code_list'=>$code_list);
- }
- /**
- * 获得退款的店铺列表
- * @access public
- * @author csdeshang
- * @param type $list 列表
- * @return type
- */
- public function getVrrefundStoreList($list) {
- $store_ids = array();
- if (!empty($list) && is_array($list)) {
- foreach ($list as $key => $value) {
- $store_ids[] = $value['store_id']; //店铺编号
- }
- }
- $field = 'store_id,store_name,member_id,member_name,seller_name,store_company_name,store_qq,store_ww,store_phone';
- return model('store')->getStoreMemberIDList($store_ids, $field);
- }
-
- /**
- * 获取一条退款记录
- * @access public
- * @author csdeshang
- * @param type $condition 条件
- * @return type
- */
- public function getOneVrrefund($condition){
- $refund = Db::name('vrrefund')->where($condition)->find();
- return $refund;
- }
- /**
- * 向模板页面输出退款状态
- * @access public
- * @author csdeshang
- * @param type $type 类型
- * @return string
- */
- public function getRefundStateArray($type = 'all') {
- $admin_array = array(
- '1' => '待审核',
- '2' => '同意',
- '3' => '不同意'
- ); //退款状态:1为待审核,2为同意,3为不同意
- $state_data = array(
- 'admin' => $admin_array
- );
- if ($type == 'all')
- return $state_data; //返回所有
- return $state_data[$type];
- }
- }
|