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.
crmeb_php/app/common/repositories/store/PriceRuleRepository.php

90 lines
3.0 KiB

1 year ago
<?php
// +----------------------------------------------------------------------
// | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
// +----------------------------------------------------------------------
// | Copyright (c) 2016~2022 https://www.crmeb.com All rights reserved.
// +----------------------------------------------------------------------
// | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
// +----------------------------------------------------------------------
// | Author: CRMEB Team <admin@crmeb.com>
// +----------------------------------------------------------------------
namespace app\common\repositories\store;
use app\common\dao\store\PriceRuleDao;
use app\common\repositories\BaseRepository;
use app\common\repositories\system\RelevanceRepository;
use think\facade\Db;
/**
* @mixin PriceRuleDao
*/
class PriceRuleRepository extends BaseRepository
{
public function __construct(PriceRuleDao $dao)
{
$this->dao = $dao;
}
public function lst(array $where, $page, $limit)
{
$query = $this->dao->search($where)->order('sort DESC, rule_id DESC');
$count = $query->count();
$list = $query->page($page, $limit)->with(['cate'])->select();
return compact('count', 'list');
}
public function createRule(array $data)
{
$cateIds = (array)$data['cate_id'];
unset($data['cate_id']);
return Db::transaction(function () use ($cateIds, $data) {
$data['is_default'] = count($cateIds) ? 0 : 1;
$rule = $this->dao->create($data);
$inserts = [];
foreach ($cateIds as $id) {
$inserts[] = [
'left_id' => $rule['rule_id'],
'right_id' => (int)$id,
'type' => RelevanceRepository::PRICE_RULE_CATEGORY
];
}
if (count($inserts)) {
app()->make(RelevanceRepository::class)->insertAll($inserts);
}
return $rule;
});
}
public function updateRule(int $id, array $data)
{
$cateIds = (array)$data['cate_id'];
unset($data['cate_id']);
$data['update_time'] = date('Y-m-d H:i:s');
return Db::transaction(function () use ($id, $cateIds, $data) {
$data['is_default'] = count($cateIds) ? 0 : 1;
$this->dao->update($id, $data);
$inserts = [];
foreach ($cateIds as $cid) {
$inserts[] = [
'left_id' => $id,
'right_id' => (int)$cid,
'type' => RelevanceRepository::PRICE_RULE_CATEGORY
];
}
app()->make(RelevanceRepository::class)->query([
'left_id' => $id,
'type' => RelevanceRepository::PRICE_RULE_CATEGORY
])->delete();
if (count($inserts)) {
app()->make(RelevanceRepository::class)->insertAll($inserts);
}
});
}
}