shopxo/application/admin/form/Orderaftersale.php

306 lines
12 KiB
PHP
Raw Normal View History

2020-06-08 17:31:16 +08:00
<?php
// +----------------------------------------------------------------------
// | ShopXO 国内领先企业级B2C免费开源电商系统
// +----------------------------------------------------------------------
// | Copyright (c) 2011~2019 http://shopxo.net All rights reserved.
// +----------------------------------------------------------------------
// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
// +----------------------------------------------------------------------
// | Author: Devil
// +----------------------------------------------------------------------
namespace app\admin\form;
use think\Db;
/**
* 订单售后动态表格
* @author Devil
* @blog http://gong.gg/
* @version 1.0.0
* @date 2020-06-08
* @desc description
*/
class Orderaftersale
{
// 基础条件
public $condition_base = [];
/**
* 入口
* @author Devil
* @blog http://gong.gg/
* @version 1.0.0
* @date 2020-06-08
* @desc description
* @param [array] $params [输入参数]
*/
public function Run($params = [])
{
return [
// 基础配置
'base' => [
'key_field' => 'id',
'is_search' => 1,
'search_url' => MyUrl('admin/orderaftersale/index'),
'is_middle' => 0,
2020-06-08 17:31:16 +08:00
],
// 表单配置
'form' => [
[
'label' => '基础信息',
'view_type' => 'module',
2020-07-07 18:58:29 +08:00
'view_key' => 'orderaftersale/module/goods',
2020-06-08 17:31:16 +08:00
'grid_size' => 'lg',
'search_config' => [
'form_type' => 'input',
'form_name' => 'id',
'where_type' => 'like',
'where_type_custom' => 'in',
2020-08-20 23:38:41 +08:00
'where_value_custom' => 'WhereBaseGoodsInfo',
2020-07-25 00:13:18 +08:00
'placeholder' => '请输入订单号/商品名称/型号',
2020-06-08 17:31:16 +08:00
],
],
[
'label' => '用户信息',
'view_type' => 'module',
2020-06-27 22:48:16 +08:00
'view_key' => 'lib/module/user',
2020-06-08 17:31:16 +08:00
'grid_size' => 'sm',
'search_config' => [
'form_type' => 'input',
'form_name' => 'user_id',
'where_type' => 'like',
'where_type_custom' => 'in',
2020-08-20 23:38:41 +08:00
'where_value_custom' => 'WhereValueUserInfo',
2020-06-08 17:31:16 +08:00
'placeholder' => '请输入用户名/昵称/手机/邮箱',
],
],
[
'label' => '状态',
'view_type' => 'field',
2020-07-02 22:42:01 +08:00
'view_key' => 'status',
'view_data_key' => 'name',
'view_data' => lang('common_order_aftersale_status_list'),
2020-06-08 17:31:16 +08:00
'width' => 120,
'search_config' => [
'form_type' => 'select',
'where_type' => 'in',
'data' => lang('common_order_aftersale_status_list'),
'data_key' => 'value',
'data_name' => 'name',
'is_multiple' => 1,
],
],
[
'label' => '申请类型',
'view_type' => 'field',
2020-07-02 22:42:01 +08:00
'view_key' => 'type',
'view_data_key' => 'name',
'view_data' => lang('common_order_aftersale_type_list'),
2020-06-08 17:31:16 +08:00
'width' => 120,
'search_config' => [
'form_type' => 'select',
'where_type' => 'in',
'data' => lang('common_order_aftersale_type_list'),
'data_key' => 'value',
'data_name' => 'name',
'is_multiple' => 1,
],
],
[
'label' => '原因',
'view_type' => 'field',
'view_key' => 'reason',
'search_config' => [
'form_type' => 'input',
'where_type' => 'like',
],
],
[
'label' => '退款金额(元)',
'view_type' => 'field',
'view_key' => 'price',
'search_config' => [
'form_type' => 'section',
'is_point' => 1,
],
],
[
'label' => '退货数量',
'view_type' => 'field',
'view_key' => 'number',
'search_config' => [
'form_type' => 'section',
],
],
[
'label' => '退款说明',
'view_type' => 'field',
'view_key' => 'msg',
2020-06-30 23:32:16 +08:00
'grid_size' => 'sm',
2020-06-08 17:31:16 +08:00
'search_config' => [
'form_type' => 'input',
'where_type' => 'like',
],
],
[
'label' => '退款类型',
'view_type' => 'field',
2020-07-02 22:42:01 +08:00
'view_key' => 'refundment',
'view_data_key' => 'name',
'view_data' => lang('common_order_aftersale_refundment_list'),
2020-06-08 17:31:16 +08:00
'width' => 120,
'search_config' => [
'form_type' => 'select',
'where_type' => 'in',
'data' => lang('common_order_aftersale_refundment_list'),
'data_key' => 'value',
'data_name' => 'name',
'is_multiple' => 1,
],
],
[
'label' => '凭证',
'view_type' => 'module',
'view_key' => 'orderaftersale/module/voucher',
2020-06-16 23:27:12 +08:00
'is_list' => 0,
2020-06-08 17:31:16 +08:00
],
[
'label' => '快递公司',
'view_type' => 'field',
'view_key' => 'express_name',
'search_config' => [
'form_type' => 'input',
'where_type' => 'like',
],
],
[
'label' => '快递单号',
'view_type' => 'field',
'view_key' => 'express_number',
'search_config' => [
'form_type' => 'input',
'where_type' => 'like',
],
],
[
'label' => '拒绝原因',
'view_type' => 'field',
'view_key' => 'refuse_reason',
'grid_size' => 'sm',
'search_config' => [
'form_type' => 'input',
'where_type' => 'like',
],
],
2020-06-08 17:31:16 +08:00
[
'label' => '申请时间',
'view_type' => 'field',
'view_key' => 'apply_time_time',
'search_config' => [
'form_type' => 'datetime',
'form_name' => 'apply_time',
],
],
[
'label' => '确认时间',
'view_type' => 'field',
'view_key' => 'confirm_time_time',
'search_config' => [
'form_type' => 'datetime',
'form_name' => 'confirm_time',
],
],
[
'label' => '退货时间',
'view_type' => 'field',
'view_key' => 'delivery_time_time',
'search_config' => [
'form_type' => 'datetime',
'form_name' => 'delivery_time',
],
],
[
'label' => '审核时间',
'view_type' => 'field',
'view_key' => 'audit_time_time',
'search_config' => [
'form_type' => 'datetime',
'form_name' => 'audit_time',
],
],
[
'label' => '创建时间',
'view_type' => 'field',
'view_key' => 'add_time_time',
'search_config' => [
'form_type' => 'datetime',
'form_name' => 'add_time',
],
],
[
'label' => '更新时间',
'view_type' => 'field',
'view_key' => 'upd_time_time',
'search_config' => [
'form_type' => 'datetime',
'form_name' => 'upd_time',
],
],
[
'label' => '操作',
'view_type' => 'operate',
'view_key' => 'orderaftersale/module/operate',
'align' => 'center',
'fixed' => 'right',
],
],
];
}
/**
* 用户信息条件处理
* @author Devil
* @blog http://gong.gg/
* @version 1.0.0
* @date 2020-06-08
* @desc description
* @param [string] $value [条件值]
* @param [array] $params [输入参数]
*/
public function WhereValueUserInfo($value, $params = [])
{
if(!empty($value))
{
// 获取用户 id
$ids = Db::name('User')->where('username|nickname|mobile|email', 'like', '%'.$value.'%')->column('id');
// 避免空条件造成无效的错觉
return empty($ids) ? [0] : $ids;
}
return $value;
}
/**
2020-07-25 00:13:18 +08:00
* 基础条件处理
2020-06-08 17:31:16 +08:00
* @author Devil
* @blog http://gong.gg/
* @version 1.0.0
* @date 2020-06-08
* @desc description
* @param [string] $value [条件值]
* @param [array] $params [输入参数]
*/
2020-07-25 00:13:18 +08:00
public function WhereBaseGoodsInfo($value, $params = [])
2020-06-08 17:31:16 +08:00
{
if(!empty($value))
{
// 获取订单详情搜索的订单售后 id
2020-07-25 00:13:18 +08:00
$ids = Db::name('OrderAftersale')->alias('oa')->join(['__ORDER_DETAIL__'=>'od'], 'oa.order_detail_id=od.id')->whereOr('od.title|od.model', 'like', '%'.$value.'%')->whereOr('oa.order_no', '=', $value)->column('oa.id');
2020-06-08 17:31:16 +08:00
// 避免空条件造成无效的错觉
return empty($ids) ? [0] : $ids;
}
return $value;
}
}
?>