322 lines
9.0 KiB
PHP
322 lines
9.0 KiB
PHP
<?php
|
|
|
|
namespace app\admin\controller\shopro\activity;
|
|
|
|
use think\Db;
|
|
use app\admin\controller\shopro\Common;
|
|
use app\admin\model\shopro\activity\Activity as ActivityModel;
|
|
use app\admin\model\shopro\goods\Goods as GoodsModel;
|
|
use app\admin\model\shopro\goods\Sku as SkuModel;
|
|
use app\admin\model\shopro\goods\SkuPrice as SkuPriceModel;
|
|
use addons\shopro\library\activity\Activity as ActivityManager;
|
|
use addons\shopro\library\activity\traits\CheckActivity;
|
|
use addons\shopro\facade\Activity as ActivityFacade;
|
|
|
|
/**
|
|
* 活动管理
|
|
*/
|
|
class Activity extends Common
|
|
{
|
|
|
|
use CheckActivity;
|
|
|
|
protected $noNeedRight = ['getType', 'select', 'skus'];
|
|
|
|
protected $manager = null;
|
|
|
|
protected $model = null;
|
|
|
|
public function _initialize()
|
|
{
|
|
parent::_initialize();
|
|
$this->model = new ActivityModel;
|
|
$this->manager = ActivityFacade::instance();
|
|
}
|
|
|
|
|
|
/**
|
|
* 查看
|
|
*
|
|
* @return string|Json
|
|
* @throws \think\Exception
|
|
* @throws DbException
|
|
*/
|
|
public function index()
|
|
{
|
|
$type = $this->request->param('type', null);
|
|
|
|
if (!$this->request->isAjax()) {
|
|
if ($type) {
|
|
return $this->view->fetch('shopro/activity/activity/index');
|
|
}
|
|
|
|
return $this->view->fetch('shopro/activity/activity/activity');
|
|
}
|
|
|
|
$activities = $this->model->sheepFilter()->where('type', $type)->paginate(request()->param('list_rows', 10))->toArray();
|
|
|
|
$items = $activities['data'];
|
|
|
|
// 关联活动的商品
|
|
$goodsIds = array_values(array_filter(array_column($items, 'goods_ids')));
|
|
$goodsIdsArr = [];
|
|
foreach ($goodsIds as $ids) {
|
|
$idsArr = explode(',', $ids);
|
|
$goodsIdsArr = array_merge($goodsIdsArr, $idsArr);
|
|
}
|
|
$goodsIdsArr = array_values(array_filter(array_unique($goodsIdsArr)));
|
|
if ($goodsIdsArr) {
|
|
// 查询商品
|
|
$goods = GoodsModel::where('id', 'in', $goodsIdsArr)->select();
|
|
$goods = array_column($goods, null, 'id');
|
|
}
|
|
foreach ($items as $key => $activity) {
|
|
$items[$key]['goods'] = [];
|
|
if ($activity['goods_ids']) {
|
|
$idsArr = explode(',', $activity['goods_ids']);
|
|
foreach ($idsArr as $id) {
|
|
if (isset($goods[$id])) {
|
|
$items[$key]['goods'][] = $goods[$id];
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
$activities['data'] = $items;
|
|
|
|
$this->success('获取成功', null, $activities);
|
|
}
|
|
|
|
|
|
// 获取数据类型
|
|
public function getType()
|
|
{
|
|
if (!$this->request->isAjax()) {
|
|
return $this->view->fetch();
|
|
}
|
|
|
|
$typeList = $this->model->typeList();
|
|
|
|
$result = [
|
|
'type_list' => $typeList,
|
|
];
|
|
|
|
$data = [];
|
|
foreach ($result as $key => $list) {
|
|
$data[$key][] = ['name' => '全部', 'type' => 'all'];
|
|
|
|
foreach ($list as $k => $v) {
|
|
$data[$key][] = [
|
|
'name' => $v,
|
|
'type' => $k
|
|
];
|
|
}
|
|
}
|
|
|
|
$this->success('获取成功', null, $data);
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
* 添加
|
|
*/
|
|
public function add()
|
|
{
|
|
if (!$this->request->isAjax()) {
|
|
return $this->view->fetch();
|
|
}
|
|
|
|
$params = $this->request->only([
|
|
'title', 'goods_ids', 'type', 'prehead_time', 'start_time', 'end_time',
|
|
'rules', 'richtext_id', 'richtext_title', 'goods_list'
|
|
]);
|
|
if (isset($params['goods_list'])) {
|
|
$params['goods_list'] = json_decode($params['goods_list'], true);
|
|
}
|
|
$this->svalidate($params, ".add");
|
|
|
|
Db::transaction(function () use ($params) {
|
|
$this->manager->save($params);
|
|
});
|
|
|
|
$this->success('保存成功');
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
* 详情
|
|
*
|
|
* @param $id
|
|
* @return \think\Response
|
|
*/
|
|
public function detail($id)
|
|
{
|
|
$activity = $this->model->where('id', $id)->find();
|
|
if (!$activity) {
|
|
$this->error(__('No Results were found'));
|
|
}
|
|
$activity->goods_list = $activity->goods_list;
|
|
$activity->rules = $activity->rules;
|
|
|
|
$this->success('获取成功', null, $activity);
|
|
}
|
|
|
|
|
|
/**
|
|
* 编辑(支持批量)
|
|
*/
|
|
public function edit($id = null)
|
|
{
|
|
if (!$this->request->isAjax()) {
|
|
return $this->view->fetch('add');
|
|
}
|
|
|
|
$params = $this->request->only([
|
|
'title', 'goods_ids', 'prehead_time', 'start_time', 'end_time',
|
|
'rules', 'richtext_id', 'richtext_title', 'goods_list'
|
|
]);
|
|
if (isset($params['goods_list'])) {
|
|
$params['goods_list'] = json_decode($params['goods_list'], true);
|
|
}
|
|
$this->svalidate($params);
|
|
|
|
$id = explode(',', $id);
|
|
$items = $this->model->whereIn('id', $id)->select();
|
|
|
|
Db::transaction(function () use ($items, $params) {
|
|
foreach ($items as $activity) {
|
|
$this->manager->update($activity, $params);
|
|
}
|
|
});
|
|
|
|
$this->success('更新成功');
|
|
}
|
|
|
|
|
|
/**
|
|
* 获取活动商品规格并且初始化
|
|
*/
|
|
public function skus()
|
|
{
|
|
if (!$this->request->isAjax()) {
|
|
return $this->view->fetch();
|
|
}
|
|
|
|
$params = $this->request->param();
|
|
$id = $params['id'] ?? 0;
|
|
$goods_id = $params['goods_id'] ?? 0;
|
|
$activity_type = $params['activity_type'] ?? '';
|
|
$start_time = $params['start_time'] ?? '';
|
|
$end_time = $params['end_time'] ?? '';
|
|
$prehead_time = $params['prehead_time'] ?? '';
|
|
|
|
if ($start_time && $end_time && $activity_type) {
|
|
// 如果存在开始结束时间,并且是要修改
|
|
$goodsList = [$goods_id => ['id' => $goods_id]];
|
|
|
|
$this->checkActivityConflict([
|
|
'type' => $activity_type,
|
|
'classify' => $this->model->getClassify($activity_type),
|
|
'start_time' => $start_time,
|
|
'end_time' => $end_time,
|
|
'prehead_time' => $prehead_time
|
|
], $goodsList, $id);
|
|
}
|
|
|
|
// 商品规格
|
|
$skus = SkuModel::with('children')->where('goods_id', $goods_id)->where('parent_id', 0)->select();
|
|
|
|
// 获取规格
|
|
$skuPrices = SkuPriceModel::with(['activity_sku_price' => function ($query) use ($id) {
|
|
$query->where('activity_id', $id);
|
|
}])->where('goods_id', $goods_id)->select();
|
|
|
|
|
|
//编辑
|
|
$activitySkuPrices = [];
|
|
foreach ($skuPrices as $k => $skuPrice) {
|
|
$activitySkuPrices[$k] = $skuPrice->activity_sku_price ? $skuPrice->activity_sku_price->toArray() : [];
|
|
// 活动规格数据初始化
|
|
if (!$activitySkuPrices[$k]) {
|
|
$activitySkuPrices[$k]['id'] = 0;
|
|
$activitySkuPrices[$k]['status'] = 'down';
|
|
$activitySkuPrices[$k]['price'] = '';
|
|
$activitySkuPrices[$k]['stock'] = '';
|
|
$activitySkuPrices[$k]['sales'] = '0';
|
|
$activitySkuPrices[$k]['goods_sku_price_id'] = $skuPrice->id;
|
|
}
|
|
|
|
// 个性化初始化每个活动的 规格 字段
|
|
$activitySkuPrices[$k] = $this->manager->showSkuPrice($activity_type, $activitySkuPrices[$k]);
|
|
}
|
|
|
|
$this->success('获取成功', null, [
|
|
'skus' => $skus,
|
|
'sku_prices' => $skuPrices,
|
|
'activity_sku_prices' => $activitySkuPrices,
|
|
]);
|
|
}
|
|
|
|
|
|
|
|
public function select()
|
|
{
|
|
if (!$this->request->isAjax()) {
|
|
return $this->view->fetch();
|
|
}
|
|
|
|
$type = $this->request->param('type');
|
|
$activities = $this->model->sheepFilter()->whereIn('type', $type)->paginate(request()->param('list_rows', 10))->toArray();
|
|
|
|
$this->success('获取成功', null, $activities);
|
|
}
|
|
|
|
|
|
/**
|
|
* 删除(支持批量)
|
|
*
|
|
* @param $id
|
|
* @return \think\Response
|
|
*/
|
|
public function delete($id)
|
|
{
|
|
if (empty($id)) {
|
|
$this->error(__('Parameter %s can not be empty', 'id'));
|
|
}
|
|
|
|
$list = $this->model->where('id', 'in', $id)->select();
|
|
|
|
$result = Db::transaction(function () use ($list) {
|
|
$count = 0;
|
|
foreach ($list as $item) {
|
|
$count += $this->manager->delete($item);
|
|
}
|
|
|
|
return $count;
|
|
});
|
|
|
|
if ($result) {
|
|
$this->success('删除成功', null, $result);
|
|
} else {
|
|
$this->error(__('No rows were deleted'));
|
|
}
|
|
}
|
|
|
|
|
|
public function recyclebin()
|
|
{
|
|
if (!$this->request->isAjax()) {
|
|
return $this->view->fetch();
|
|
}
|
|
|
|
$type = $this->request->param('type');
|
|
$activities = $this->model->onlyTrashed()->sheepFilter()->where('type', $type)->paginate($this->request->param('list_rows', 10));
|
|
|
|
$this->success('获取成功', null, $activities);
|
|
}
|
|
}
|