www.lightcourse.com/app/admin/controller/Refund.php

453 lines
18 KiB
PHP

<?php
namespace app\admin\controller;
use think\facade\View;
use think\facade\Lang;
/**
* ============================================================================
* 联课教育商城系统
* ============================================================================
* 版权所有 2022 刻羽互动科技有限公司,并保留所有权利。
* 网站地址: http://www.o1h.cn
* ----------------------------------------------------------------------------
* 这不是一个自由软件!您只能在不用于商业目的的前提下对程序代码进行修改和使用 .
* 不允许对程序代码以任何形式任何目的的再发布。
* ============================================================================
* 控制器
*/
class Refund extends AdminControl
{
const EXPORT_SIZE = 1000;
public function initialize()
{
parent::initialize();
Lang::load(base_path() . 'admin/lang/'.config('lang.default_lang').'/refund.lang.php');
//向模板页面输出退款退货状态
$this->getRefundStateArray();
}
function getRefundStateArray($type = 'all')
{
$state_array = array(
'1' => lang('ds_examine'), '2' => lang('ds_agree'), '3' => lang('ds_disagree')
); //卖家处理状态:1为待审核,2为同意,3为不同意
View::assign('state_array', $state_array);
$admin_array = array(
'1' => '处理中', '2' => '待处理', '3' => '已完成'
); //确认状态:1为买家或卖家处理中,2为待平台管理员处理,3为退款退货已完成
View::assign('admin_array', $admin_array);
$state_data = array(
'admin' => $admin_array
);
if ($type == 'all') {
return $state_data; //返回所有
}
return $state_data[$type];
}
/**
* 待处理列表
*/
public function refund_manage()
{
$refundreturn_model = model('refundreturn');
$condition = array();
$condition[] = array('refund_type','=',1);
$condition[] = array('refund_state','=',1); //状态:1为处理中,2为待管理员处理,3为已完成
$keyword_type = array('order_sn', 'refund_sn', 'buyer_name', 'goods_name');
$key = input('get.key');
$type = input('get.type');
if (trim($key) != '' && in_array($type, $keyword_type)) {
$condition[] = array($type,'like', '%' . $key . '%');
}
$add_time_from = input('get.add_time_from');
$add_time_to = input('get.add_time_to');
if (trim($add_time_from) != '') {
$add_time_from = strtotime(trim($add_time_from));
if ($add_time_from !== false) {
$condition[] = array('add_time','>=', $add_time_from);
}
}
if (trim($add_time_to) != '') {
$add_time_to = strtotime(trim($add_time_to))+86399;
if ($add_time_to !== false) {
$condition[] = array('add_time','<=', $add_time_to);
}
}
$refund_list = $refundreturn_model->getRefundList($condition, 10);
View::assign('show_page', $refundreturn_model->page_info->render());
View::assign('refund_list', $refund_list);
$this->setAdminCurItem('refund_manage');
return View::fetch('refund_manage');
}
/**
* 所有记录
*/
public function refund_all()
{
$refundreturn_model = model('refundreturn');
$condition = array();
$keyword_type = array('order_sn', 'refund_sn', 'buyer_name', 'goods_name');
$key = input('get.key');
$type = input('get.type');
if (trim($key) != '' && in_array($type, $keyword_type)) {
$condition[] = array($type,'like', '%' . $key . '%');
}
$add_time_from = input('get.add_time_from');
$add_time_to = input('get.add_time_to');
if (trim($add_time_from) != '') {
$add_time_from = strtotime(trim($add_time_from));
if ($add_time_from !== false) {
$condition[] = array('add_time','>=', $add_time_from);
}
}
if (trim($add_time_to) != '') {
$add_time_to = strtotime(trim($add_time_to))+86399;
if ($add_time_to !== false) {
$condition[] = array('add_time','<=', $add_time_to);
}
}
$refund_list = $refundreturn_model->getRefundList($condition, 10);
View::assign('show_page', $refundreturn_model->page_info->render());
View::assign('refund_list', $refund_list);
$this->setAdminCurItem('refund_all');
return View::fetch('refund_all');
}
/**
* 退款处理页
*
*/
public function edit()
{
$refundreturn_model = model('refundreturn');
$condition = array();
$condition[] = array('refund_id','=',intval(input('param.refund_id')));
$refund_list = $refundreturn_model->getRefundList($condition);
$refund = $refund_list[0];
//查询交易凭证
$order_model = model('order');
$order = $order_model->getOrderInfo(array('order_id' => $refund['order_id']));
if (request()->isPost()) {
if(!in_array(input('post.examine_type'),[2,3])){
$this->error(lang('refund_state_null'));
}
$check = request()->checkToken('__token__');
if(false === $check) {
$this->error('invalid token');
}
if ($refund['refund_state'] != '1') {//检查状态,防止页面刷新不及时造成数据错误
$this->error(lang('ds_common_save_fail'));
}
$refund_array = array();
$refund_array['admin_time'] = TIMESTAMP;
$refund_array['refund_state'] = '3'; //状态:1为处理中,2为待管理员处理,3为已完成
$refund_array['examine_type'] = intval(input('param.examine_type'));
$refund_array['admin_message'] = input('post.admin_message');
if ($refund_array['examine_type'] == '3' && $refund['order_lock'] == '2') {
$state = $refundreturn_model->editOrderUnlock($refund['order_id']); //订单解锁
}else{
$trade_no=input('param.trade_no');
if($trade_no && $trade_no!=$order['trade_no']){
$order_model->editOrder(array('trade_no'=>$trade_no), array(
'order_id' => $order['order_id']
));
//添加订单日志
$data = array();
$data['order_id'] = $order['order_id'];
$data['log_role'] = 'system';
$data['log_user'] = $this->admin_info['admin_name'];
$data['log_msg'] = '修改支付平台交易号 : ' . $trade_no;
$data['log_orderstate'] = $order['order_state'];
$order_model->addOrderlog($data);
}
$res = $refundreturn_model->editOrderRefund($refund);
$state=$res['code'];
if(!$state){
$this->error($res['msg']);
}
}
if ($state) {
$refundreturn_model->editRefundreturn($condition, $refund_array);
// 发送买家消息
$param = array();
$param['code'] = 'refund_return_notice';
$param['member_id'] = $refund['buyer_id'];
//阿里短信参数
$param['ali_param'] = array(
'refund_sn' => $refund['refund_sn']
);
$param['ten_param'] = array(
$refund['refund_sn']
);
$param['param'] = array_merge($param['ali_param'],array(
'refund_url' => HOME_SITE_URL .'/memberrefund/view?refund_id='.$refund['refund_id'],
));
//微信模板消息
$param['weixin_param'] = array(
'url' => config('ds_config.h5_site_url').'/member/refund_view?refund_id='.$refund['refund_id'],
'data'=>array(
"keyword1" => array(
"value" => $refund['order_sn'],
"color" => "#333"
),
"keyword2" => array(
"value" => $refund['refund_amount'],
"color" => "#333"
)
),
);
model('cron')->addCron(array('cron_exetime'=>TIMESTAMP,'cron_type'=>'sendMemberMsg','cron_value'=>serialize($param)));
$this->log('退款确认,退款编号' . $refund['refund_sn']);
dsLayerOpenSuccess(lang('ds_common_save_succ'));
}
else {
$this->error(lang('ds_common_save_fail'));
}
}
View::assign('trade_no', $order['trade_no']);
View::assign('refund', $refund);
$info['buyer'] = array();
if (!empty($refund['pic_info'])) {
$info = unserialize($refund['pic_info']);
}
View::assign('pic_list', $info['buyer']);
$this->setAdminCurItem('edit');
return View::fetch('edit');
}
/**
* 退款记录查看页
*
*/
public function view()
{
$refundreturn_model = model('refundreturn');
$condition = array();
$condition[] = array('refund_id','=',intval(input('param.refund_id')));
$refund_list = $refundreturn_model->getRefundList($condition);
$refund = $refund_list[0];
View::assign('refund', $refund);
$info['buyer'] = array();
if (!empty($refund['pic_info'])) {
$info = unserialize($refund['pic_info']);
}
View::assign('pic_list', $info['buyer']);
return View::fetch('view');
}
/**
* 退款退货原因
*/
public function reason()
{
$refundreturn_model = model('refundreturn');
$condition = array();
$reason_list = $refundreturn_model->getReasonList($condition, 10);
View::assign('reason_list', $reason_list);
View::assign('show_page', $refundreturn_model->page_info->render());
$this->setAdminCurItem('reason');
return View::fetch('reason');
}
/**
* 新增退款退货原因
*/
public function add_reason()
{
$refundreturn_model = model('refundreturn');
if (request()->post()) {
$reason_array = array();
$reason_array['reason_info'] = input('post.reason_info');
$reason_array['reason_sort'] = intval(input('post.reason_sort'));
$reason_array['reason_updatetime'] = TIMESTAMP;
$state = $refundreturn_model->addReason($reason_array);
if ($state) {
$this->log('新增退款退货原因,编号' . $state);
dsLayerOpenSuccess(lang('ds_common_save_succ'));
}
else {
$this->error(lang('ds_common_save_fail'));
}
}
return View::fetch('add_reason');
}
/**
* 编辑退款退货原因
*
*/
public function edit_reason()
{
$refundreturn_model = model('refundreturn');
$reason_id = intval(input('param.reason_id'));
$condition = array();
$condition[] = array('reason_id','=',$reason_id);
$reason_list = $refundreturn_model->getReasonList($condition);
$reason = $reason_list[$reason_id];
if (request()->post()) {
$reason_array = array();
$reason_array['reason_info'] = input('post.reason_info');
$reason_array['reason_sort'] = intval(input('post.reason_sort'));
$reason_array['reason_updatetime'] = TIMESTAMP;
$state = $refundreturn_model->editReason($condition, $reason_array);
if ($state) {
$this->log('编辑退款退货原因,编号' . $reason_id);
dsLayerOpenSuccess(lang('ds_common_save_succ'));
}
else {
$this->error(lang('ds_common_save_fail'));
}
}
View::assign('reason', $reason);
return View::fetch('edit_reason');
}
/**
* 删除退款退货原因
*
*/
public function del_reason()
{
$refundreturn_model = model('refundreturn');
$reason_id = input('param.reason_id');
$reason_id_array = ds_delete_param($reason_id);
if($reason_id_array === FALSE){
ds_json_encode('10001', lang('param_error'));
}
$condition = array();
$condition[] = array('reason_id','in', $reason_id_array);
$state = $refundreturn_model->delReason($condition);
if ($state) {
$this->log('删除退款退货原因,编号' . $reason_id);
ds_json_encode('10000', lang('ds_common_del_succ'));
}
else {
ds_json_encode('10001', lang('ds_common_del_fail'));
}
}
/**
* 导出
*
*/
public function export_step1() {
$refundreturn_model = model('refundreturn');
$condition = array();
$keyword_type = array('order_sn', 'refund_sn', 'store_name', 'buyer_name', 'goods_name');
$key = input('get.key');
$type = input('get.type');
if (trim($key) != '' && in_array($type, $keyword_type)) {
$condition[] = array($type,'like', '%' . $key . '%');
}
$add_time_from = input('get.add_time_from');
$add_time_to = input('get.add_time_to');
if (trim($add_time_from) != '') {
$add_time_from = strtotime(trim($add_time_from));
if ($add_time_from !== false) {
$condition[] = array('add_time','>=', $add_time_from);
}
}
if (trim($add_time_to) != '') {
$add_time_to = strtotime(trim($add_time_to))+86399;
if ($add_time_to !== false) {
$condition[] = array('add_time','<=', $add_time_to);
}
}
if (!is_numeric(input('param.page'))) {
$count = $refundreturn_model->getRefundCount($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 = $refundreturn_model->getRefundList($condition, '', '*', 'refund_id desc', self::EXPORT_SIZE);
$this->createExcel($data);
}
} else { //下载
$limit1 = (input('param.page') - 1) * self::EXPORT_SIZE;
$limit2 = self::EXPORT_SIZE;
$data = $refundreturn_model->getRefundList($condition, $limit2, '*', 'refund_id desc');
$this->createExcel($data);
}
}
/**
* 生成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('exp_tk_order_ordersn'));
$excel_data[0][] = array('styleid' => 's_title', 'data' => lang('exp_tk_order_refundsn'));
$excel_data[0][] = array('styleid' => 's_title', 'data' => lang('exp_tk_store_name'));
$excel_data[0][] = array('styleid' => 's_title', 'data' => lang('exp_tk_goods_name'));
$excel_data[0][] = array('styleid' => 's_title', 'data' => lang('exp_tk_order_buyer'));
$excel_data[0][] = array('styleid' => 's_title', 'data' => lang('exp_tk_order_add_time'));
$excel_data[0][] = array('styleid' => 's_title', 'data' => lang('exp_tk_order_refund'));
//data
foreach ((array) $data as $k => $v) {
$tmp = array();
$tmp[] = array('data' => 'DS' . $v['order_sn']);
$tmp[] = array('data' => $v['refund_sn']);
$tmp[] = array('data' => $v['store_name']);
$tmp[] = array('data' => $v['goods_name']);
$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['refund_amount']));
$excel_data[] = $tmp;
}
$excel_data = $excel_obj->charset($excel_data, CHARSET);
$excel_obj->addArray($excel_data);
$excel_obj->addWorksheet($excel_obj->charset(lang('exp_tk_refund'), CHARSET));
$excel_obj->generateXML($excel_obj->charset(lang('exp_tk_refund'), CHARSET) . input('param.page') . '-' . date('Y-m-d-H', TIMESTAMP));
}
/**
* 获取卖家栏目列表,针对控制器下的栏目
*/
protected function getAdminItemList()
{
$menu_array = array(
array(
'name' => 'refund_manage', 'text' => '待处理', 'url' => url('Refund/refund_manage')
), array(
'name' => 'refund_all', 'text' => '所有记录', 'url' => url('Refund/refund_all')
), array(
'name' => 'reason', 'text' => '退款退货原因', 'url' => url('Refund/reason')
),
);
if (request()->action() == 'reason') {
$menu_array[] = [
'name' => 'add_reason', 'text' => '新增原因', 'url' =>"javascript:dsLayerOpen('".url('Refund/add_reason')."','新增原因')"
];
}
return $menu_array;
}
}
?>