123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177 |
- <?php
- namespace app\common\model;
- use think\facade\Db;
- /**
-
- *
-
- *
- * ----------------------------------------------------------------------------
- *
-
- * 数据层模型
- */
- class Trade extends BaseModel
- {
- /**
- * 订单处理天数
- * @access public
- * @author csdeshang
- * @param type $day_type 天数类型
- * @return int
- */
- public function getMaxDay($day_type = 'all')
- {
- $max_data = array(
- 'order_refund' => 7, //收货完成后可以申请退款退货
- 'refund_confirm' => 7, //卖家不处理退款退货申请时按同意处理
- 'return_confirm' => 7, //卖家不处理收货时按弃货处理
- 'return_delay' => 5 //退货的商品发货多少天以后才可以选择没收到
- );
- if ($day_type == 'all')
- return $max_data; //返回所有
- if (intval($max_data[$day_type]) < 1)
- $max_data[$day_type] = 1; //最小的值设置为1
- return $max_data[$day_type];
- }
- /**
- * 订单状态
- * @access public
- * @author csdeshang
- * @param type $type 类型
- * @return type
- */
- public function getOrderState($type = 'all')
- {
- $state_data = array(
- 'order_cancel' => ORDER_STATE_CANCEL, //0:已取消
- 'order_default' => ORDER_STATE_NEW, //10:未付款
- 'order_paid' => ORDER_STATE_PAY, //20:已付款
- 'order_shipped' => ORDER_STATE_SEND, //30:已发货
- 'order_completed' => ORDER_STATE_SUCCESS //40:已收货
- );
- if ($type == 'all')
- return $state_data; //返回所有
- return $state_data[$type];
- }
- /**
- * 更新退款申请
- * @access public
- * @author csdeshang
- * @param int $member_id 会员编号
- * @param int $store_id 店铺编号
- * @return type
- */
- public function editRefundConfirm($member_id = 0, $store_id = 0)
- {
- $refund_confirm = $this->getMaxDay('refund_confirm'); //卖家不处理退款申请时按同意并弃货处理
- $day = TIMESTAMP - $refund_confirm * 60 * 60 * 24;
- $condition = " seller_state=1 and add_time<" . $day; //状态:1为待审核,2为同意,3为不同意
- $condition_sql = "";
- if ($member_id > 0) {
- $condition_sql = " buyer_id = '" . $member_id . "' and ";
- }
- if ($store_id > 0) {
- $condition_sql = " store_id = '" . $store_id . "' and ";
- }
- $condition_sql = $condition_sql . $condition;
- $refund_array = array();
- $refund_array['refund_state'] = '2'; //状态:1为处理中,2为待管理员处理,3为已完成
- $refund_array['seller_state'] = '2'; //卖家处理状态:1为待审核,2为同意,3为不同意
- $refund_array['return_type'] = '1'; //退货类型:1为不用退货,2为需要退货
- $refund_array['seller_time'] = TIMESTAMP;
- $refund_array['seller_message'] = '超过' . $refund_confirm . '天未处理退款退货申请,按同意处理。';
- $refund = Db::name('refundreturn')->field('refund_id,refund_sn,store_id,order_sn,refund_amount,order_lock,refund_type')->where($condition_sql)->select()->toArray();
- Db::name('refundreturn')->where($condition_sql)->update($refund_array);
- // 发送商家提醒
- foreach ((array) $refund as $val) {
- // 参数数组
- $message = array();
- $message['type'] = $val['order_lock'] == 2 ? '售前' : '售后';
- $message['refund_sn'] = $val['refund_sn'];
- $ten_message = array($message['type'], $message['refund_sn']);
- $weixin_param = array(
- 'url' => config('ds_config.h5_store_site_url') . '/pages/seller/refund/RefundView?refund_id=' . $val['refund_id'] . '&refund_type=' . $val['refund_type'],
- 'data' => array(
- "keyword1" => array(
- "value" => $val['order_sn'],
- "color" => "#333"
- ),
- "keyword2" => array(
- "value" => $val['refund_amount'],
- "color" => "#333"
- )
- )
- );
- if (intval($val['refund_type']) == 1) {
- // 退款
- $this->sendStoremsg('refund_auto_process', $val['store_id'], $message, $weixin_param, $message, $ten_message);
- } else {
- // 退货
- $this->sendStoremsg('return_auto_process', $val['store_id'], $message, $weixin_param, $message, $ten_message);
- }
- }
- $return_confirm = $this->getMaxDay('return_confirm'); //卖家不处理收货时按弃货处理
- $day = TIMESTAMP - $return_confirm * 60 * 60 * 24;
- $condition = " seller_state=2 and goods_state=2 and return_type=2 and delay_time<" . $day; //物流状态:1为待发货,2为待收货,3为未收到,4为已收货
- $condition_sql = "";
- if ($member_id > 0) {
- $condition_sql = " buyer_id = '" . $member_id . "' and ";
- }
- if ($store_id > 0) {
- $condition_sql = " store_id = '" . $store_id . "' and ";
- }
- $condition_sql = $condition_sql . $condition;
- $refund_array = array();
- $refund_array['refund_state'] = '2'; //状态:1为处理中,2为待管理员处理,3为已完成
- $refund_array['return_type'] = '1'; //退货类型:1为不用退货,2为需要退货
- $refund_array['seller_message'] = '超过' . $return_confirm . '天未处理收货,按弃货处理';
- $refund = Db::name('refundreturn')->field('refund_id,refund_sn,store_id,order_sn,refund_amount,order_lock,refund_type')->where($condition_sql)->select()->toArray();
- Db::name('refundreturn')->where($condition_sql)->update($refund_array);
- // 发送商家提醒
- foreach ((array) $refund as $val) {
- // 参数数组
- $message = array();
- $message['type'] = $val['order_lock'] == 2 ? '售前' : '售后';
- $message['refund_sn'] = $val['refund_sn'];
- $ten_message = array($message['type'], $message['refund_sn']);
- $weixin_param = array(
- 'url' => config('ds_config.h5_store_site_url') . '/pages/seller/refund/RefundView?refund_id=' . $val['refund_id'] . '&refund_type=' . $val['refund_type'],
- 'data' => array(
- "keyword1" => array(
- "value" => $val['order_sn'],
- "color" => "#333"
- ),
- "keyword2" => array(
- "value" => $val['refund_amount'],
- "color" => "#333"
- )
- )
- );
- $this->sendStoremsg('return_auto_receipt', $val['store_id'], $message, $weixin_param, $message, $ten_message);
- }
- }
- /**
- * 发送店铺消息
- * @access public
- * @author csdeshang
- * @param string $code 编码
- * @param int $store_id 店铺ID
- * @param array $message 消息
- */
- private function sendStoremsg($code, $store_id, $message, $weixin_param = array(), $ali_param = array(), $ten_param = array())
- {
- model('cron')->addCron(array('cron_exetime' => TIMESTAMP, 'cron_type' => 'sendStoremsg', 'cron_value' => serialize(array('code' => $code, 'store_id' => $store_id, 'param' => $message, 'weixin_param' => $weixin_param, 'ali_param' => $ali_param, 'ten_param' => $ten_param))));
- }
- }
|