123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244 |
- <?php
- // +----------------------------------------------------------------------
- // | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
- // +----------------------------------------------------------------------
- // | Copyright (c) 2016~2023 https://www.crmeb.com All rights reserved.
- // +----------------------------------------------------------------------
- // | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
- // +----------------------------------------------------------------------
- // | Author: CRMEB Team <admin@crmeb.com>
- // +----------------------------------------------------------------------
- namespace app\services\product\sku;
- use app\dao\product\sku\StoreProductAttrValueDao;
- use app\models\store\StoreProductAttrValue;
- use app\services\BaseServices;
- use crmeb\exceptions\AdminException;
- use app\services\product\product\StoreProductServices;
- use crmeb\services\CacheService;
- use crmeb\services\workerman\ChannelService;
- /**
- * Class StoreProductAttrValueService
- * @package app\services\product\sku
- * @method getProductAttrValue(array $where)
- * @method value(array $where, string $field = '') 获取单个键值的数据
- * @method decStockIncSales(array $where, int $num, string $stock = 'stock', string $sales = 'sales') 减库存加销量
- * @method count(array $where) 获取指定条件下的数量
- */
- class StoreProductAttrValueServices extends BaseServices
- {
- /**
- * StoreProductAttrValueServices constructor.
- * @param StoreProductAttrValueDao $dao
- */
- public function __construct(StoreProductAttrValueDao $dao)
- {
- $this->dao = $dao;
- }
- /**
- * 获取单规格规格
- * @param array $where
- * @throws \think\db\exception\DataNotFoundException
- * @throws \think\db\exception\DbException
- * @throws \think\db\exception\ModelNotFoundException
- */
- public function getOne(array $where)
- {
- return $this->dao->getOne($where);
- }
- /**
- * 获取指定条件下的数据以数组返回
- * @param array $where
- * @param string $field
- * @param string $key
- * @return array
- */
- public function getColumn(array $where, string $field = '*', string $key = 'suk')
- {
- return $this->dao->getColumn($where, $field, $key);
- }
- /**
- * 删除一条数据
- * @param int $id
- * @param int $type
- */
- public function del(int $id, int $type)
- {
- $this->dao->del($id, $type);
- }
- /**
- * 批量保存
- * @param array $data
- */
- public function saveAll(array $data)
- {
- $res = $this->dao->saveAll($data);
- if (!$res) throw new AdminException(100006);
- return $res;
- }
- /**
- * 获取sku
- * @param array $where
- * @return array
- */
- public function getSkuArray(array $where)
- {
- return $this->dao->getColumn($where, 'bar_code,cost,price,ot_price,stock,image as pic,weight,volume,brokerage,brokerage_two,quota,unique', 'suk');
- }
- /**
- * 交易排行榜
- * @return array
- * @throws \think\db\exception\DataNotFoundException
- * @throws \think\db\exception\DbException
- * @throws \think\db\exception\ModelNotFoundException
- */
- public function purchaseRanking()
- {
- $dlist = $this->dao->attrValue();
- /** @var StoreProductServices $proServices */
- $proServices = app()->make(StoreProductServices::class);
- $slist = $proServices->getProductLimit(['is_del' => 0], $limit = 20, 'id as product_id,store_name,sales * price as val');
- $data = array_merge($dlist, $slist);
- $last_names = array_column($data, 'val');
- array_multisort($last_names, SORT_DESC, $data);
- $list = array_splice($data, 0, 20);
- return $list;
- }
- /**获取商品的属性数量
- * @param $product_id
- * @param $unique
- * @param $type
- * @return int
- */
- public function getAttrvalueCount($product_id, $unique, $type)
- {
- return $this->dao->count(['product_id' => $product_id, 'unique' => $unique, 'type' => $type]);
- }
- /**
- * 获取唯一值下的库存
- * @param string $unique
- * @return int
- */
- public function uniqueByStock(string $unique)
- {
- if (!$unique) return 0;
- return $this->dao->uniqueByStock($unique);
- }
- /**
- * 减销量,加库存
- * @param $productId
- * @param $unique
- * @param $num
- * @param int $type
- * @return mixed
- */
- public function decProductAttrStock($productId, $unique, $num, $type = 0)
- {
- $res = $this->dao->decStockIncSales([
- 'product_id' => $productId,
- 'unique' => $unique,
- 'type' => $type
- ], $num);
- if ($res) {
- $this->workSendStock($productId, $unique, $type);
- }
- return $res;
- }
- /**
- * 减少销量增加库存
- * @param $productId
- * @param $unique
- * @param $num
- * @return bool
- */
- public function incProductAttrStock(int $productId, string $unique, int $num, int $type = 0)
- {
- return $this->dao->incStockDecSales(['unique' => $unique, 'product_id' => $productId, 'type' => $type], $num);
- }
- /**
- * 库存预警消息提醒
- * @param int $productId
- * @param string $unique
- * @param int $type
- */
- public function workSendStock(int $productId, string $unique, int $type)
- {
- $stock = $this->dao->value([
- 'product_id' => $productId,
- 'unique' => $unique,
- 'type' => $type
- ], 'stock');
- $replenishment_num = sys_config('store_stock') ?? 0;//库存预警界限
- if ($replenishment_num >= $stock) {
- try {
- ChannelService::instance()->send('STORE_STOCK', ['id' => $productId]);
- } catch (\Exception $e) {
- }
- }
- }
- /**
- * 获取秒杀库存
- * @param int $productId
- * @param string $unique
- * @param bool $isNew
- * @return array|mixed|\think\Model|null
- * @throws \Psr\SimpleCache\InvalidArgumentException
- * @throws \think\db\exception\DataNotFoundException
- * @throws \think\db\exception\DbException
- * @throws \think\db\exception\ModelNotFoundException
- */
- public function getSeckillAttrStock(int $productId, string $unique, bool $isNew = false)
- {
- $key = md5('seclkill_attr_stock_' . $productId . '_' . $unique);
- $stock = CacheService::get($key);
- if (!$stock || $isNew) {
- $stock = $this->dao->getOne(['product_id' => $productId, 'unique' => $unique, 'type' => 1], 'suk,quota');
- if ($stock) {
- CacheService::set($key, $stock, 60);
- }
- }
- return $stock;
- }
- /**
- * @param $product_id
- * @param string $suk
- * @param string $unique
- * @param bool $is_new
- * @return int|mixed
- * @throws \Psr\SimpleCache\InvalidArgumentException
- */
- public function getProductAttrStock(int $productId, string $suk = '', string $unique = '', $isNew = false)
- {
- if (!$suk && !$unique) return 0;
- $key = md5('product_attr_stock_' . $productId . '_' . $suk . '_' . $unique);
- $stock = CacheService::get($key);
- if (!$stock || $isNew) {
- $where = ['product_id' => $productId, 'type' => 0];
- if ($suk) {
- $where['suk'] = $suk;
- }
- if ($unique) {
- $where['unique'] = $unique;
- }
- $stock = $this->dao->value($where, 'stock');
- CacheService::set($key, $stock, 60);
- }
- return $stock;
- }
- }
|