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.
87 lines
2.2 KiB
87 lines
2.2 KiB
<?php
|
|
|
|
|
|
namespace app\admin\controller\mall;
|
|
|
|
|
|
use app\admin\model\MallGoods;
|
|
use app\admin\traits\Curd;
|
|
use app\common\controller\AdminController;
|
|
use EasyAdmin\annotation\ControllerAnnotation;
|
|
use EasyAdmin\annotation\NodeAnotation;
|
|
use think\App;
|
|
|
|
/**
|
|
* Class Goods
|
|
* @package app\admin\controller\mall
|
|
* @ControllerAnnotation(title="商城商品管理")
|
|
*/
|
|
class Goods extends AdminController
|
|
{
|
|
|
|
use Curd;
|
|
|
|
protected $relationSearch = true;
|
|
|
|
public function __construct(App $app)
|
|
{
|
|
parent::__construct($app);
|
|
$this->model = new MallGoods();
|
|
}
|
|
|
|
/**
|
|
* @NodeAnotation(title="列表")
|
|
*/
|
|
public function index()
|
|
{
|
|
if ($this->request->isAjax()) {
|
|
if (input('selectFields')) {
|
|
return $this->selectList();
|
|
}
|
|
list($page, $limit, $where) = $this->buildTableParames();
|
|
$count = $this->model
|
|
->withJoin('cate', 'LEFT')
|
|
->where($where)
|
|
->count();
|
|
$list = $this->model
|
|
->withJoin('cate', 'LEFT')
|
|
->where($where)
|
|
->page($page, $limit)
|
|
->order($this->sort)
|
|
->select();
|
|
$data = [
|
|
'code' => 0,
|
|
'msg' => '',
|
|
'count' => $count,
|
|
'data' => $list,
|
|
];
|
|
return json($data);
|
|
}
|
|
return $this->fetch();
|
|
}
|
|
|
|
/**
|
|
* @NodeAnotation(title="入库")
|
|
*/
|
|
public function stock($id)
|
|
{
|
|
$row = $this->model->find($id);
|
|
empty($row) && $this->error('数据不存在');
|
|
if ($this->request->isPost()) {
|
|
$post = $this->request->post();
|
|
$rule = [];
|
|
$this->validate($post, $rule);
|
|
try {
|
|
$post['total_stock'] = $row->total_stock + $post['stock'];
|
|
$post['stock'] = $row->stock + $post['stock'];
|
|
$save = $row->save($post);
|
|
} catch (\Exception $e) {
|
|
$this->error('保存失败');
|
|
}
|
|
$save ? $this->success('保存成功') : $this->error('保存失败');
|
|
}
|
|
$this->assign('row', $row);
|
|
return $this->fetch();
|
|
}
|
|
|
|
}
|