From b555453cfc021f2f929cd14dc904d26115b268a3 Mon Sep 17 00:00:00 2001 From: root Date: Tue, 3 Dec 2019 17:19:20 +0800 Subject: [PATCH] =?UTF-8?q?feat:=20=E5=95=86=E5=93=81,=E8=B4=AD=E7=89=A9?= =?UTF-8?q?=E8=BD=A6,=E8=AE=A2=E5=8D=95=E7=9A=84=E4=B8=9A=E5=8A=A1?= =?UTF-8?q?=E9=80=BB=E8=BE=91?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- api/config/main.php | 15 +- api/config/params.php | 2 +- api/controllers/CartController.php | 47 +++ api/controllers/CommonController.php | 53 +++ api/controllers/GoodsController.php | 49 +++ api/controllers/OrderController.php | 55 +++ api/controllers/SiteController.php | 18 +- api/controllers/TestController.php | 9 +- api/controllers/UserController.php | 31 +- api/logic/CartLogic.php | 144 ++++++++ api/logic/Helper.php | 114 ++++++ api/logic/OrderLogic.php | 349 ++++++++++++++++++ backend/config/main.php | 6 +- backend/controllers/OrderController.php | 17 +- backend/controllers/SiteController.php | 1 + backend/web/css/site.css | 3 + common/models/ars/Order.php | 59 ++- .../antgoods/goods/src/models/ars/Goods.php | 21 +- .../goods/src/models/searchs/GoodsSearch.php | 1 - vendor/iron/grid/GridView.php | 8 +- 20 files changed, 934 insertions(+), 68 deletions(-) create mode 100644 api/controllers/CartController.php create mode 100644 api/controllers/CommonController.php create mode 100644 api/controllers/GoodsController.php create mode 100644 api/controllers/OrderController.php create mode 100644 api/logic/CartLogic.php create mode 100644 api/logic/Helper.php create mode 100644 api/logic/OrderLogic.php diff --git a/api/config/main.php b/api/config/main.php index a95bc9b..086cf79 100644 --- a/api/config/main.php +++ b/api/config/main.php @@ -11,6 +11,8 @@ return [ 'bootstrap' => ['log'], 'modules' => [], 'components' => [ + 'cartLogic'=>['class'=>'api\logic\CartLogic'], + 'orderLogic'=>['class'=>'api\logic\OrderLogic'], 'request' => [ 'parsers' => [ 'application/json' => 'yii\web\JsonParser', @@ -43,13 +45,24 @@ return [ 'enableStrictParsing' => true, 'showScriptName' => false, 'rules' => [ - ['class' => 'yii\rest\UrlRule', + ['class' => 'yii\rest\UrlRule', 'controller' => 'goods', 'pluralize' => false,], + ['class' => 'yii\rest\UrlRule', 'controller' => 'cart'], + ['class' => 'yii\rest\UrlRule', 'controller' => 'order'], + [ + 'class' => 'yii\rest\UrlRule', 'controller' => 'user', 'extraPatterns' => [ 'GET menu' => 'menu', 'GET create' => 'create' ] ], + [ + 'class' => 'yii\rest\UrlRule', + 'controller' => 'site', + 'extraPatterns' => [ + 'GET index' => 'index', + ] + ], ], ], ], diff --git a/api/config/params.php b/api/config/params.php index 0b7fa93..9704f79 100644 --- a/api/config/params.php +++ b/api/config/params.php @@ -52,7 +52,7 @@ return [ ], ], '商品管理' => [ - 'icon' => 'fa-archive', + 'icon' => 'fa-shopping-bag', 'items' => [ ['商城分类', '/antgoods/shop-category'], ['后台分类', '/antgoods/category'], diff --git a/api/controllers/CartController.php b/api/controllers/CartController.php new file mode 100644 index 0000000..b7e3416 --- /dev/null +++ b/api/controllers/CartController.php @@ -0,0 +1,47 @@ +request->post('type'); + return Yii::$app->cartLogic->addOrSubGoods($type); + } + + /** + * @return ActiveRecord + * 创建商品 + */ + public function actionCreate() + { + $goodsId = Yii::$app->request->getBodyParam('goodsId'); + $count = Yii::$app->request->getBodyParam('count'); + $skuId = Yii::$app->request->getBodyParam('skuId'); + return Yii::$app->cartLogic->addGoods($goodsId, $count, $skuId); + } + + /** + * 删除商品 + */ + public function actionDelete() + { + Yii::$app->cartLogic->delete(); + } +} diff --git a/api/controllers/CommonController.php b/api/controllers/CommonController.php new file mode 100644 index 0000000..70523af --- /dev/null +++ b/api/controllers/CommonController.php @@ -0,0 +1,53 @@ + [ +// 'class' => HttpBearerAuth::className(), +// 'except' => [], +// ] +// ]); +// } + + public function actions() + { + $action = parent::actions(); + unset($action['delete']); + unset($action['create']); + unset($action['update']); + $action['index'] = [ + 'class' => 'yii\rest\IndexAction', + 'checkAccess' => [$this, 'checkAccess'], + 'modelClass' => $this->modelClass, + 'dataFilter' => $this->getFilter() + ]; + return $action; + } + + protected function getFilter() + { + $data = \Yii::$app->request->getBodyParams(); + $data['user'] = true; + \Yii::$app->request->setBodyParams($data); + $filter = ['class' => 'yii\data\ActiveDataFilter', + 'filter' => ['user_id' => \Yii::$app->user->getId()], + 'searchModel' => ['class' => 'antgoods\goods\models\searchs\GoodsSearch']]; + return $filter; + } + + +} diff --git a/api/controllers/GoodsController.php b/api/controllers/GoodsController.php new file mode 100644 index 0000000..770daad --- /dev/null +++ b/api/controllers/GoodsController.php @@ -0,0 +1,49 @@ + 'yii\rest\IndexAction', + 'modelClass' => $this->modelClass, + 'dataFilter' => $this->getFilter() + ]; + return $action; + } + + protected function getFilter() + { + $keyword = \Yii::$app->request->getBodyParam('keyword'); + $category = \Yii::$app->request->getBodyParam('category'); + if (empty($keyword) && empty($category)) { + return null; + } + $array = []; + if ($keyword) { + $array['name'] = ['like' => $keyword]; + } + if ($category) { + $array['cat_id'] = $category; + } + $filter = ['class' => 'yii\data\ActiveDataFilter', + 'filter' => $array, + 'searchModel' => ['class' => 'antgoods\goods\models\searchs\GoodsSearch']]; + return $filter; + } +} diff --git a/api/controllers/OrderController.php b/api/controllers/OrderController.php new file mode 100644 index 0000000..9c4b62b --- /dev/null +++ b/api/controllers/OrderController.php @@ -0,0 +1,55 @@ +request->getBodyParam('status'); + $data = \Yii::$app->request->getBodyParams(); + $data['user'] = true; + \Yii::$app->request->setBodyParams($data); + $array = ['user_id' => Yii::$app->user->getId()]; + if ($status) { + $array['status'] = $status; + } + $filter = ['class' => 'yii\data\ActiveDataFilter', + 'filter' => $array, + 'searchModel' => ['class' => 'common\models\searchs\OrderSearch']]; + return $filter; + } + + public function actionCreate() + { + $originId = Yii::$app->request->getBodyParam('goodsId'); + $count = Yii::$app->request->getBodyParam('count'); + $skuId = Yii::$app->request->getBodyParam('skuId'); + return Yii::$app->orderLogic->addGoods($originId, $count, $skuId); + } + + /** + * @return mixed + * @throws \yii\base\InvalidConfigException + */ + public function actionUpdate() + { + $data = Yii::$app->request->getBodyParams(); + return Yii::$app->orderLogic->update($data); + } + + + + + +} diff --git a/api/controllers/SiteController.php b/api/controllers/SiteController.php index 7f3e9b2..e6d6588 100644 --- a/api/controllers/SiteController.php +++ b/api/controllers/SiteController.php @@ -2,21 +2,25 @@ namespace api\controllers; -use yii\web\Controller; - +use antgoods\goods\models\ars\Goods; +use yii\rest\Controller; /** - * Created by PhpStorm. - * User: iron - * Date: 2018/5/25 - * Time: 16:42 + * @author iron + * @email weiriron@gmail.com */ class SiteController extends Controller { - public function actions() { + public function actions() + { return [ 'error' => [ 'class' => 'yii\web\ErrorAction', ], ]; } + + public function actionIndex() + { + return Goods::findOne(1); + } } diff --git a/api/controllers/TestController.php b/api/controllers/TestController.php index 7ede9df..b56fb7c 100644 --- a/api/controllers/TestController.php +++ b/api/controllers/TestController.php @@ -2,7 +2,6 @@ /* * The MIT License * - * Copyright 2019 Blobt. * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal @@ -29,8 +28,8 @@ namespace api\controllers; * @email weiriron@gmail.com */ -use common\models\ars\Goods; -use common\models\searchs\GoodsSearch; + +use antgoods\goods\models\ars\Goods; use yii\data\ActiveDataProvider; use yii\db\ActiveRecord; use yii\rest\ActiveController; @@ -38,7 +37,7 @@ use yii\web\NotFoundHttpException; class TestController extends ActiveController { - public $modelClass = 'common\models\ars\Goods'; + public $modelClass = 'antgoods\goods\models\ars\Goods'; public function actions() { @@ -52,7 +51,7 @@ class TestController extends ActiveController return new ActiveDataProvider([ 'query' => Goods::find(), 'pagination' => [ - 'pageSize' => 1, + 'pageSize' => 10, ], ]); } diff --git a/api/controllers/UserController.php b/api/controllers/UserController.php index b1c8360..bbb3a42 100644 --- a/api/controllers/UserController.php +++ b/api/controllers/UserController.php @@ -1,29 +1,6 @@ userLogic->createUser($data, $key); - $response = Yii::$app->getResponse(); - $response->setStatusCode(201); - return ['status' => true]; + } diff --git a/api/logic/CartLogic.php b/api/logic/CartLogic.php new file mode 100644 index 0000000..823c0c2 --- /dev/null +++ b/api/logic/CartLogic.php @@ -0,0 +1,144 @@ +where(['goods_id' => $goodsId]) + ->andWhere(['user_id' => Yii::$app->user->getId()]) + ->one(); + if ($cart) { + if (!$cart->updateCounters(['goods_count' => $count])) { + throw new ServerErrorHttpException('服务器添加购物车商品失败'); + } + } else { + $cart = $this->create($goodsId, $skuId, $count); + } + Helper::createdResponse($cart, $this->viewAction); + return $cart; + + } + + /** + * @param int $type + * @return bool + * @throws BadRequestHttpException + * @throws NotFoundHttpException + */ + public function addOrSubGoods($type) + { + if (empty($type) || ($type != self::TYPE_SUB && $type != self::TYPE_ADD)) { + throw new BadRequestHttpException('无效参数'); + } + $cart = $this->findCart(); + if (!$cart) { + throw new NotFoundHttpException('未找到该购物车'); + } + if ($cart->goods_count == 1 && $type == self::TYPE_SUB) { + throw new BadRequestHttpException('购物商品需至少1件'); + } + return $cart->updateCounters(['goods_count' => $type]); + } + + /** + * @throws NotFoundHttpException + * @throws ServerErrorHttpException + * @throws \Throwable + * @throws \yii\db\StaleObjectException + * 删除购物车 + */ + public function delete() + { + $cart = $this->findCart(); + if (!$cart) { + throw new NotFoundHttpException('未找到该购物车'); + } + if ($cart->delete()) { + Yii::$app->getResponse()->setStatusCode(204); + } else { + throw new ServerErrorHttpException('服务器无法删除购物车'); + } + } + + /** + * @param $goodsId + * @param $skuId + * @param $count + * @return Cart; + * 创建新购物车 + * @throws ServerErrorHttpException + * @throws NotFoundHttpException + */ + private function create($goodsId, $skuId, $count) + { + $goods = Goods::findOne($goodsId); + if (!$goods) { + throw new NotFoundHttpException('商品未找到'); + } + $cart = new Cart(); + $cart->goods_id = $goods->id; + $cart->user_id = Yii::$app->user->getId(); + $cart->goods_count = $count; + $cart->sku_id = $skuId ?: 0; + $cart->goods_img = $goods->image; + $cart->goods_name = $goods->name; + $cart->goods_price = Helper::countPrice($goodsId, $skuId); + if (!$cart->save()) { + throw new ServerErrorHttpException('服务器创建购物车失败'); + } + return $cart; + } + + /** + * @return ActiveRecord|null|Cart + * 获取购物车实例 + */ + private function findCart() + { + $id = Yii::$app->request->getQueryParam('id'); + return Cart::find() + ->where(['id' => $id]) + ->andWhere(['user_id' => Yii::$app->user->getId()]) + ->one(); + } + +} \ No newline at end of file diff --git a/api/logic/Helper.php b/api/logic/Helper.php new file mode 100644 index 0000000..ff14dde --- /dev/null +++ b/api/logic/Helper.php @@ -0,0 +1,114 @@ + $v) { + $data[] = implode(' ', $v); + } + return implode(' ', $data); + } + + /** + * @param $goodsId + * @param $count + * @param null $skuId + * @throws BadRequestHttpException + * @throws NotFoundHttpException + * 判断库存 + */ + public static function checkStock($goodsId, $count, $skuId = null) + { + $sku = GoodsSku::findOne($skuId); + $goods = Goods::findOne($goodsId); + if (!$goods) { + throw new NotFoundHttpException('商品未找到'); + } + if (!$sku && $goods->stock == Goods::UNLIMITED_STOCK) { + return; + } + $stock = $sku ? $sku->stock : $goods->stock; + if ($stock < $count) { + throw new BadRequestHttpException("商品{$goods->name}库存不足"); + } + return; + } + + public static function createdResponse($model, $view) + { + $response = Yii::$app->getResponse()->setStatusCode(201); + $id = implode(',', array_values($model->getPrimaryKey(true))); + $response->getHeaders()->set('Location', Url::toRoute([$view, 'id' => $id], true)); + } + + /** + * @param $goodsId + * @param $skuId + * @return int + * @throws NotFoundHttpException + * 计算商品价格 + */ + public static function countPrice($goodsId, $skuId) + { + $goods = Goods::findOne($goodsId); + if (!$goods) { + throw new NotFoundHttpException('商品未找到'); + } + $price = $goods->price; + $sku = GoodsSku::findOne($skuId); + if ($sku) { + $price = $sku->price; + } + return $price; + } + + /** + * @param $skuId + * @return string + * @throws NotFoundHttpException + */ + public static function skuValue($skuId) + { + $sku = GoodsSku::findOne($skuId); + if ($sku) { + return ''; + } + $data = []; + $goodsAttr = array_filter(explode(',', $sku->goods_attr)); + if (empty($goodsAttr)) { + throw new NotFoundHttpException('sku无对应商品属性'); + } + foreach ($goodsAttr as $k => $v) { + $attr = GoodsAttr::findOne($v); + if (!$attr) { + throw new NotFoundHttpException('商品属性未找到'); + } + $data[] = $attr->attr_value; + } + return implode(',', $data); + + } +} \ No newline at end of file diff --git a/api/logic/OrderLogic.php b/api/logic/OrderLogic.php new file mode 100644 index 0000000..c2acc13 --- /dev/null +++ b/api/logic/OrderLogic.php @@ -0,0 +1,349 @@ +request->getQueryParam('type'); + $order = $this->findOrder(); + $tra = Yii::$app->db->beginTransaction(); + try { + switch ($type) { + case self::TYPE_CONFIRM : + $this->confirm($order, $data); + break; + case self::TYPE_CANCEL: + $this->cancel($order); + break; + case self::TYPE_TAKE: + $this->take($order); + break; + case self::TYPE_CHANGE_SHIPPING_TYPE: + $this->updateShippingType($order, $data); + break; + case self::TYPE_CHANGE_ADDRESS: + $this->changeAddress($order, $data); + break; + case self::TYPE_CHANGE_TAKING_SITE: + $this->changeTakingSite($order, $data); + break; + } + if (!$order->save()) { + throw new ServerErrorHttpException('服务器更新订单失败'); + } + $tra->commit(); + return true; + } catch (\yii\base\Exception $e) { + $tra->rollBack(); + return $e; + } + } + + /** + * @param Order $order + * @param array $data + * @throws BadRequestHttpException + * @throws NotFoundHttpException + */ + private function changeAddress($order, $data) + { + if (!isset($data['address_id'])) { + throw new BadRequestHttpException('无效参数'); + } + if ($order->shipping_type !== Order::SHIPPING_TYPE_EXPRESS) { + throw new BadRequestHttpException('配送方式异常'); + } + $address = Address::find() + ->where(['id' => $data['address_id'], 'user_id' => Yii::$app->user->getId()]) + ->one(); + if (!$address) { + throw new NotFoundHttpException('收货地址未找到'); + } + $order->consignee = $address->consignee; + $order->phone = $address->phone; + $order->city = $address->city; + $order->area = $address->area; + $order->province = $address->province; + $order->address = $address->address; + } + + /** + * @param Order $order + * @param array $data + * @throws BadRequestHttpException + * @throws NotFoundHttpException + */ + private function changeTakingSite($order, $data) + { + if (!isset($data['taking_site_id']) || empty($data['taking_site_id'])) { + throw new BadRequestHttpException('无效参数'); + } + if ($order->shipping_type !== Order::SHIPPING_TYPE_PICKED_UP) { + throw new BadRequestHttpException('配送方式异常'); + } + $site = TakingSite::findOne($data['taking_site_id']); + if (!$site) { + throw new NotFoundHttpException('自提点未找到'); + } + $order->taking_site = $data['taking_site_id']; + } + + + /** + * @param Order $order + * @param array $data + * @throws BadRequestHttpException + */ + private function updateShippingType($order, $data) + { + if (!isset($data['shipping_type'])) { + throw new BadRequestHttpException('无效参数'); + } + if ($order->status !== Order::STATUS_UNCONFIRMED) { + throw new BadRequestHttpException('订单状态异常'); + } + $order->shipping_type = $data['shipping_type']; + } + + /** + * @param Order $order + * @param array $data + * @throws BadRequestHttpException + * @throws NotFoundHttpException + * @throws ServerErrorHttpException + */ + private function confirm($order, $data) + { + if ($order->status !== Order::STATUS_UNCONFIRMED) { + throw new BadRequestHttpException('订单状态异常'); + } + if ($order->shipping_type === Order::SHIPPING_TYPE_PICKED_UP) { + if (!isset($data['consignee']) || !isset($data['phone']) + || empty($data['consignee']) || empty($data['phone'])) { + throw new BadRequestHttpException('(联系人)参数无效'); + } + } + if (isset($data['remarks'])) { + $order->remarks = $data['remarks']; + } + $order->status = Order::STATUS_NONPAYMENT; + $this->updateStock($order, self::TYPE_SUB_STOCK); + } + + /** + * @param Order $order + * @throws BadRequestHttpException + * @throws NotFoundHttpException + * @throws ServerErrorHttpException + */ + private function cancel($order) + { + if ($order->status !== Order::STATUS_NONPAYMENT) { + throw new BadRequestHttpException('订单状态异常'); + } + $order->status = Order::STATUS_CANCEL; + $this->updateStock($order, self::TYPE_ADD_STOCK); + } + + /** + * @param Order $order + * @throws BadRequestHttpException + */ + private function take($order) + { + if ($order->status !== Order::STATUS_SHIPMENT_ALL) { + throw new BadRequestHttpException('订单状态异常'); + } + $order->status = Order::STATUS_FINISH; + } + + /** + * @param $id + * @param $type + * @throws BadRequestHttpException + * @throws NotFoundHttpException + * @throws ServerErrorHttpException + */ + private function updateStock($id, $type) + { + $allOrderGoods = $this->findOrderGoods($id); + foreach ($allOrderGoods as $orderGoods) { + /*检查库存*/ + Helper::checkStock($orderGoods->goods_id, $orderGoods->goods_count, $orderGoods->sku_id); + if ($orderGoods->sku_id) { + $goods = GoodsSku::findOne($orderGoods->sku_id); + } else { + $goods = Goods::findOne($orderGoods->goods_id); + } + if ($type) { + $count = $orderGoods->goods_count; + } else { + $count = -$orderGoods->goods_count; + } + if (!$goods->updateCounters(['stock' => $count])) { + throw new ServerErrorHttpException('更新库存失败'); + } + } + } + + /** + * @param $originId + * @param $count + * @param $skuId + * @return \Exception|bool; + * @throws BadRequestHttpException + * @throws NotFoundHttpException + * 创建订单并添加商品 + */ + public function addGoods($originId, $count, $skuId) + { + $type = Yii::$app->request->getQueryParam('type'); + if (($type === self::TYPE_ADD_GOODS_CART && empty($originId)) || + ($type == self::TYPE_ADD_GOODS_PURCHASE && empty($count) && empty($originId))) { + throw new BadRequestHttpException('无效参数'); + } + if ($type === self::TYPE_ADD_GOODS_PURCHASE) { + $goodsId = $originId; + } else { + $cart = Cart::findOne($originId); + if (!$cart) { + throw new NotFoundHttpException('购物车未找到'); + } + $goodsId = $cart->goods_id; + $skuId = $cart->sku_id; + $count = $cart->goods_count; + } + /*检查库存*/ + Helper::checkStock($goodsId, $count, $skuId); + $tra = Yii::$app->db->beginTransaction(); + try { + $order = new Order(); + $order->type = Order::TYPE_SHOPPING; + if ($order->save()) { + throw new ServerErrorHttpException('服务器创建订单失败'); + } + $this->createOrderGoods($order->id, $goodsId, $skuId, $count);/*创建订单商品*/ + $this->saveGoodsInfo($order);/*保存订单商品信息*/ + $tra->commit(); + return true; + } catch (\Exception $e) { + $tra->rollBack(); + return $e; + } + } + + /** + * @param Order $order + * @throws ServerErrorHttpException + */ + private function saveGoodsInfo($order) + { + $orderGoods = $this->findOrderGoods($order->id); + foreach ($orderGoods as $goods) { + $order->goods_amount += $goods->price; + $order->goods_count += $goods->goods_count; + } + if (!$order->save()) { + throw new ServerErrorHttpException('服务器创建订单失败'); + } + } + + + /** + * @param int $id + * @param int $goodsId + * @param int $skuId + * @param int $count + * @throws NotFoundHttpException + * @throws ServerErrorHttpException + * 创建订单商品 + */ + private function createOrderGoods($id, $goodsId, $skuId, $count) + { + $goods = Goods::findOne($goodsId); + if (!$goods) { + throw new NotFoundHttpException('商品未找到'); + } + $orderGoods = new OrderGoods(); + $orderGoods->order_id = $id; + $orderGoods->goods_id = $skuId; + $orderGoods->sku_value = Helper::skuValue($skuId); + $orderGoods->goods_count = $count; + $orderGoods->goods_img = $goods->image; + $orderGoods->goods_name = $goods->name; + $orderGoods->price = Helper::countPrice($goodsId, $skuId); + if (!$orderGoods->save()) { + throw new ServerErrorHttpException('服务器创建订单商品失败'); + } + } + + /** + * @return array|Order|null + * 获取订单 + */ + private function findOrder() + { + $id = Yii::$app->request->getQueryParam('id'); + return Order::find() + ->where(['id' => $id]) + ->andWhere(['user_id' => Yii::$app->user->getId()]) + ->one(); + } + + /** + * @param $id + * @return array|ActiveRecord[]|OrderGoods[] + */ + private function findOrderGoods($id) + { + return OrderGoods::find() + ->where(['order_id' => $id]) + ->all(); + } + + +} \ No newline at end of file diff --git a/backend/config/main.php b/backend/config/main.php index c2f2fc8..e2f4a6c 100644 --- a/backend/config/main.php +++ b/backend/config/main.php @@ -58,8 +58,8 @@ return [ 'file' => ['class' => 'backend\logic\file\FileManager'], 'goods' => ['class' => 'antgoods\goods\logic\goods\GoodsManager'], ], - 'as access' => [ - 'class' => 'iron\components\AccessControl', - ], +// 'as access' => [ +// 'class' => 'iron\components\AccessControl', +// ], 'params' => $params, ]; diff --git a/backend/controllers/OrderController.php b/backend/controllers/OrderController.php index fd50941..2d338ad 100755 --- a/backend/controllers/OrderController.php +++ b/backend/controllers/OrderController.php @@ -2,9 +2,11 @@ namespace backend\controllers; +use antgoods\goods\models\ars\Goods; use Yii; use common\models\ars\Order; use common\models\searchs\OrderSearch; +use yii\debug\components\search\matchers\GreaterThanOrEqual; use yii\web\Controller; use yii\web\NotFoundHttpException; use yii\filters\VerbFilter; @@ -42,7 +44,7 @@ class OrderController extends Controller 'searchModel' => $searchModel, 'dataProvider' => $dataProvider, 'columns' => $searchModel->columns() - ]); + ]); } /** @@ -125,24 +127,25 @@ class OrderController extends Controller throw new NotFoundHttpException('The requested page does not exist.'); } + /** - * @author iron - * 文件导出 - */ + * @author iron + * 文件导出 + */ public function actionExport() { $searchModel = new OrderSearch(); $params = Yii::$app->request->queryParams; if ($params['page-type'] == 'all') { - $dataProvider = $searchModel->allData($params); + $dataProvider = $searchModel->allData($params); } else { $dataProvider = $searchModel->search($params); } - \iron\widget\Excel::export([ + \iron\widget\Excel::export([ 'models' => $dataProvider->getModels(), 'format' => 'Xlsx', 'asAttachment' => true, - 'fileName' =>'Orders'. "-" .date('Y-m-d H/i/s', time()), + 'fileName' => 'Orders' . "-" . date('Y-m-d H/i/s', time()), 'columns' => $searchModel->columns() ]); } diff --git a/backend/controllers/SiteController.php b/backend/controllers/SiteController.php index 897f2e5..e19447c 100755 --- a/backend/controllers/SiteController.php +++ b/backend/controllers/SiteController.php @@ -2,6 +2,7 @@ namespace backend\controllers; +use antgoods\goods\models\ars\Goods; use Yii; use yii\base\NotSupportedException; use yii\web\Controller; diff --git a/backend/web/css/site.css b/backend/web/css/site.css index 990cd94..75e6539 100644 --- a/backend/web/css/site.css +++ b/backend/web/css/site.css @@ -53,4 +53,7 @@ body::-webkit-scrollbar{ width: 1px; height: 1px; +} +body{ + margin:10px; } \ No newline at end of file diff --git a/common/models/ars/Order.php b/common/models/ars/Order.php index 6f03a52..a964de8 100644 --- a/common/models/ars/Order.php +++ b/common/models/ars/Order.php @@ -37,6 +37,23 @@ use yii\behaviors\TimestampBehavior; */ class Order extends \yii\db\ActiveRecord { + const TYPE_SHOPPING = 1;//普通购物订单 + + const SHIPPING_TYPE_VIRTUAL_GOODS = 0;//虚拟货物 + const SHIPPING_TYPE_PICKED_UP = 1;//自提 + const SHIPPING_TYPE_EXPRESS = 2;//快递物流 + + const STATUS_UNCONFIRMED = 0; + const STATUS_NONPAYMENT = 1; + const STATUS_CANCEL = 2; + const STATUS_PAYMENT_TO_BE_CONFIRMED = 3; + const STATUS_TO_BE_SHIPPING = 6; + const STATUS_APPLY_REFUND = 4; + const STATUS_REFUND = 5; + const STATUS_SHIPMENT_ALL = 7; + const STATUS_SHIPMENT_PORTION = 8; + const STATUS_FINISH = 9; + /** * {@inheritdoc} */ @@ -45,6 +62,14 @@ class Order extends \yii\db\ActiveRecord return 'ats_order'; } + public function fields() + { + $fields = parent::fields(); + unset($fields['user_id']); + unset($fields['payment_sn']); + return $fields; + } + /** * {@inheritdoc} */ @@ -96,15 +121,33 @@ class Order extends \yii\db\ActiveRecord 'created_at' => '创建时间', ]; } - + + public function beforeSave($insert) + { + if ($this->status === self::STATUS_UNCONFIRMED && $this->type == self::TYPE_SHOPPING) { + $this->shipping_amount = $this->countShippingAmount(); + $this->receivables = $this->goods_amount + $this->shipping_amount; + $this->payment_amount = $this->receivables - $this->discount_amount; + } + return parent::beforeSave($insert); + } + + private function countShippingAmount() + { + //TODO 根据运费模板计算运费 + if ($this->shipping_type !== Order::SHIPPING_TYPE_EXPRESS) { + return 0; + } + return 0; + } /** - * @author linyao - * @email 602604991@qq.com - * @created Nov 8, 2019 - * - * 行为存储创建时间和更新时间 - */ + * @author linyao + * @email 602604991@qq.com + * @created Nov 8, 2019 + * + * 行为存储创建时间和更新时间 + */ public function behaviors() { return [ @@ -112,7 +155,7 @@ class Order extends \yii\db\ActiveRecord 'class' => TimestampBehavior::className(), 'createdAtAttribute' => 'created_at', 'updatedAtAttribute' => 'updated_at', - 'value' => function() { + 'value' => function () { return time(); }, ], diff --git a/vendor/antgoods/goods/src/models/ars/Goods.php b/vendor/antgoods/goods/src/models/ars/Goods.php index d446283..9a04e3d 100644 --- a/vendor/antgoods/goods/src/models/ars/Goods.php +++ b/vendor/antgoods/goods/src/models/ars/Goods.php @@ -60,6 +60,8 @@ class Goods extends \yii\db\ActiveRecord self::IS_SALE_NO => '否', self::IS_SALE_YES => '是' ]; + //无限库存 + const UNLIMITED_STOCK = -1; /** * {@inheritdoc} */ @@ -68,13 +70,30 @@ class Goods extends \yii\db\ActiveRecord return 'antgoods_goods'; } + public function fields() + { + $fields = parent::fields(); + unset($fields['is_sale']); + unset($fields['sort_order']); + unset($fields['pid']); + unset($fields['cat_id']); + unset($fields['brand_id']); + unset($fields['shop_cat_id']); + unset($fields['is_delete']); + unset($fields['express_template']); + unset($fields['model_id']); + return $fields; + } + /** * {@inheritdoc} */ public function rules() { return [ - [['pid', 'cat_id', 'brand_id', 'shop_cat_id', 'supplier_id', 'weight', 'length', 'width', 'height', 'diameter', 'sold_count', 'limit_count', 'stock', 'stock_warn', 'market_price', 'price', 'image', 'model_id', 'is_sale', 'sort_order', 'bouns_points', 'experience_points', 'is_delete', 'express_template'], 'integer'], + [['pid', 'cat_id', 'brand_id', 'shop_cat_id', 'supplier_id', 'weight', 'length', 'width', 'height', + 'diameter', 'sold_count', 'limit_count', 'stock', 'stock_warn', 'market_price', 'price', 'image', + 'model_id', 'is_sale', 'sort_order', 'bouns_points', 'experience_points', 'is_delete', 'express_template'], 'integer'], [['cat_id', 'brand_id', 'shop_cat_id', 'name'], 'required'], [['sn'], 'checkExist'], [['description', 'coverImageId', 'detailImageId'], 'string'], diff --git a/vendor/antgoods/goods/src/models/searchs/GoodsSearch.php b/vendor/antgoods/goods/src/models/searchs/GoodsSearch.php index 618b320..e13bfd4 100644 --- a/vendor/antgoods/goods/src/models/searchs/GoodsSearch.php +++ b/vendor/antgoods/goods/src/models/searchs/GoodsSearch.php @@ -180,7 +180,6 @@ class GoodsSearch extends Goods 'created_at' => $this->created_at, 'updated_at' => $this->updated_at, ]); - $query->andFilterWhere(['like', 'name', $this->name]) ->andFilterWhere(['like', 'sn', $this->sn]) ->andFilterWhere(['like', 'code', $this->code]) diff --git a/vendor/iron/grid/GridView.php b/vendor/iron/grid/GridView.php index 4f83b4a..78ff15e 100644 --- a/vendor/iron/grid/GridView.php +++ b/vendor/iron/grid/GridView.php @@ -219,13 +219,13 @@ class GridView extends BaseListView
{batch} - 添加 + 添加
@@ -446,7 +446,7 @@ SCRIPT; case '{batch}': return $this->renderBatch(); case '{url}': - return Yii::$app->request->url; + return strpos(Yii::$app->request->url,'index') ?'': Yii::$app->request->url.'/'; default: return false; }