汪总电商平台
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

385 lines
10 KiB

<?php
namespace app\admin\controller\wanlshop;
use app\common\controller\Backend;
use think\Db;
/**
* 拼团管理
*
* @icon fa fa-circle-o
*/
class Groups extends Backend
{
/**
* Groups模型对象
* @var \app\admin\model\wanlshop\Groups
*/
protected $model = null;
public function _initialize()
{
parent::_initialize();
$this->model = new \app\admin\model\wanlshop\Groups;
$this->view->assign("groupTypeList", $this->model->getGroupTypeList());
$this->view->assign("stateList", $this->model->getStateList());
$this->view->assign("statusList", $this->model->getStatusList());
}
public function import()
{
parent::import();
}
/**
* 查看
*/
public function index()
{
//当前是否为关联查询
$this->relationSearch = true;
//设置过滤方法
$this->request->filter(['strip_tags', 'trim']);
if ($this->request->isAjax()) {
//如果发送的来源是Selectpage,则转发到Selectpage
if ($this->request->request('keyField')) {
return $this->selectpage();
}
list($where, $sort, $order, $offset, $limit) = $this->buildparams();
$list = $this->model
->with(['shop','goods','user'])
->where($where)
->order($sort, $order)
->paginate($limit);
foreach ($list as $row) {
$row->getRelation('shop')->visible(['shopname','avatar']);
$row->getRelation('goods')->visible(['title','image']);
$row->getRelation('user')->visible(['username','nickname','avatar']);
}
$result = array("total" => $list->total(), "rows" => $list->items());
return json($result);
}
return $this->view->fetch();
}
/**
* Selectpage搜索
*
* @internal
*/
public function selectpage()
{
return parent::selectpage();
}
/**
* 查看拼团
*/
public function detail($ids = null, $group_no = null)
{
if($ids){
$where['id'] = $ids;
}else{
$where['group_no'] = $group_no;
}
$row = $this->model->where($where)->find();
if (!$row) {
$this->error(__('No Results were found'));
}
$row->team = model('app\admin\model\wanlshop\GroupsTeam')
->where('group_no', $row->group_no)
->select();
$row->ordergoods = model('app\admin\model\wanlshop\GroupsOrderGoods')
->where('group_no', $row->group_no)
->select();
$this->view->assign("row", $row);
return $this->view->fetch();
}
/**
* 查看
*/
public function order()
{
//当前是否为关联查询
$this->relationSearch = true;
//设置过滤方法
$this->request->filter(['strip_tags', 'trim']);
$this->model = model('app\admin\model\wanlshop\GroupsOrder');
if ($this->request->isAjax())
{
//如果发送的来源是Selectpage,则转发到Selectpage
if ($this->request->request('keyField'))
{
return $this->selectpage();
}
list($where, $sort, $order, $offset, $limit) = $this->buildparams();
$total = $this->model
->with(['user','shop','ordergoods'])
->where($where)
->order($sort, $order)
->count();
$list = $this->model
->with(['user','shop','ordergoods'])
->where($where)
->order($sort, $order)
->limit($offset, $limit)
->select();
foreach ($list as $row) {
$row->getRelation('user')->visible(['username','nickname']);
$row->getRelation('shop')->visible(['shopname']);
$row->pay = model('app\admin\model\wanlshop\Pay')
->where(['order_id' => $row['id'], 'type' => 'groups'])
->field('pay_no, price, order_price, freight_price, discount_price, actual_payment')
->find();
}
$list = collection($list)->toArray();
$result = array("total" => $total, "rows" => $list);
return json($result);
}
$this->view->assign("stateList", $this->model->getStateList());
$this->view->assign("statusList", $this->model->getStatusList());
return $this->view->fetch();
}
/**
* 详情
*/
public function orderDetail($id = null)
{
$this->model = model('app\admin\model\wanlshop\GroupsOrder');
$row = $this->model->get($id);
if (!$row) {
$this->error(__('No Results were found'));
}
$row['address'] = model('app\admin\model\wanlshop\GroupsOrderAddress')
->where(['order_id' => $id])
->order('isaddress desc')
->field('id,name,mobile,address,address_name')
->find();
$row['pay'] = model('app\admin\model\wanlshop\Pay')
->where(['order_id' => $row['id'], 'type' => 'groups'])
->find();
// 查询快递状态
switch ($row['state']) {
case 1:
$express = [
'context' => '付款后,即可将宝贝发出',
'status' => '尚未付款',
'time' => date('Y-m-d H:i:s', $row['createtime'])
];
break;
case 2:
$express = [
'context' => '商家正在处理订单',
'status' => '已付款',
'time' => date('Y-m-d H:i:s', $row['paymenttime'])
];
break;
default: // 获取物流
$eData = model('app\api\model\wanlshop\KuaidiSub')
->where(['express_no' => $row['express_no']])
->find();
// 获取数据 兼容PHP7.4 1.1.5升级
if(!empty($eData['data'])){
$ybData = json_decode($eData['data'], true);
// 运单状态 1.0.6升级
$statusText = ['在途','揽收','疑难','签收','退签','派件','退回','转投'];
$status = $statusText[0];
if(in_array('status', $ybData[0])){
$status = $ybData[0]['status'];
}else{
if($eData['ischeck'] === 1){
$status = $statusText[3];
}else{
$status = $statusText[$eData['state']];
}
}
$express = [
'status' => $status,
'context' => $ybData[0]['context'],
'time' => $ybData[0]['time'],
];
}else{
$express = [
'status' => '已发货',
'context' => '包裹正在等待快递小哥揽收~',
'time' => date('Y-m-d H:i:s', $row['delivertime'])
];
}
}
$this->view->assign("kuaidi", $express);
$this->view->assign("row", $row);
return $this->view->fetch();
}
/**
* 快递查询
*/
public function orderRelative($id = null)
{
$this->model = model('app\admin\model\wanlshop\GroupsOrder');
$row = $this->model->get($id);
if (!$row) {
$this->error(__('No Results were found'));
}
$data = model('app\api\model\wanlshop\KuaidiSub')
->where(['express_no' => $row['express_no']])
->find();
$list = [];
$week = array(
"0"=>"星期日",
"1"=>"星期一",
"2"=>"星期二",
"3"=>"星期三",
"4"=>"星期四",
"5"=>"星期五",
"6"=>"星期六"
);
if($data){
// 兼容PHP7.4 1.1.6升级
if(!empty($data['data'])){
foreach(json_decode($data['data'], true) as $vo){
$list[] = [
'time' => strtotime($vo['time']),
'status' => in_array('status', $vo) ? $vo['status'] : '在途', // 1.0.6升级
'context' => $vo['context'],
'week' => $week[date('w', strtotime($vo['time']))]
];
}
}
}
$this->view->assign("week", $week);
$this->view->assign("list", $list);
$this->view->assign("row", $row);
return $this->view->fetch();
}
/**
* 回收站
*/
public function orderRecyclebin()
{
$this->model = model('app\admin\model\wanlshop\GroupsOrder');
return $this->recyclebin();
}
/**
* 删除
*/
public function orderDel($ids = "")
{
$this->model = model('app\admin\model\wanlshop\GroupsOrder');
return $this->del();
}
/**
* 真实删除
*/
public function orderDestroy($ids = "")
{
$this->model = model('app\admin\model\wanlshop\GroupsOrder');
return $this->destroy();
}
/**
* 还原
*/
public function orderRestore($ids = "")
{
$this->model = model('app\admin\model\wanlshop\GroupsOrder');
return $this->restore();
}
/**
* 查看
*/
public function goods()
{
//当前是否为关联查询
$this->relationSearch = true;
//设置过滤方法
$this->request->filter(['strip_tags', 'trim']);
$this->model = model('app\admin\model\wanlshop\GroupsGoods');
if ($this->request->isAjax())
{
//如果发送的来源是Selectpage,则转发到Selectpage
if ($this->request->request('keyField'))
{
return $this->selectpage();
}
list($where, $sort, $order, $offset, $limit) = $this->buildparams();
$total = $this->model
->where($where)
->order($sort, $order)
->count();
$list = $this->model
->where($where)
->order($sort, $order)
->limit($offset, $limit)
->select();
foreach ($list as $row) {
$row->category->visible(['name']);
$row->shopsort->visible(['name']);
}
$list = collection($list)->toArray();
$result = array("total" => $total, "rows" => $list);
return json($result);
}
$this->view->assign("statusList", $this->model->getStatusList());
return $this->view->fetch();
}
/**
* 回收站
*/
public function goodsRecyclebin()
{
$this->model = model('app\admin\model\wanlshop\GroupsGoods');
return $this->recyclebin();
}
/**
* 删除
*/
public function goodsDel($ids = "")
{
$this->model = model('app\admin\model\wanlshop\GroupsGoods');
return $this->del();
}
/**
* 真实删除
*/
public function goodsDestroy($ids = "")
{
$this->model = model('app\admin\model\wanlshop\GroupsGoods');
return $this->destroy();
}
/**
* 还原
*/
public function goodsRestore($ids = "")
{
$this->model = model('app\admin\model\wanlshop\GroupsGoods');
return $this->restore();
}
}