1
This commit is contained in:
parent
6b34badf87
commit
2c8c78f116
@ -0,0 +1,80 @@
|
||||
<?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\parameter;
|
||||
|
||||
use app\common\dao\store\parameter\ParameterDao;
|
||||
use app\common\repositories\BaseRepository;
|
||||
|
||||
class ParameterRepository extends BaseRepository
|
||||
{
|
||||
/**
|
||||
* @var ParameterDao
|
||||
*/
|
||||
protected $dao;
|
||||
|
||||
|
||||
/**
|
||||
* ParameterRepository constructor.
|
||||
* @param ParameterDao $dao
|
||||
*/
|
||||
public function __construct(ParameterDao $dao)
|
||||
{
|
||||
$this->dao = $dao;
|
||||
}
|
||||
|
||||
/**
|
||||
* TODO 更新或者添加参数
|
||||
* @param $id
|
||||
* @param $merId
|
||||
* @param $data
|
||||
* @author Qinii
|
||||
* @day 2022/11/22
|
||||
*/
|
||||
public function createOrUpdate($id, $merId, $data)
|
||||
{
|
||||
foreach ($data as $datum) {
|
||||
if (isset($datum['parameter_id']) && $datum['parameter_id']) {
|
||||
$update = [
|
||||
'name' => $datum['name'],
|
||||
'value' => $datum['value'],
|
||||
'sort' => $datum['sort'],
|
||||
];
|
||||
$this->dao->update($datum['parameter_id'], $update);
|
||||
$changeKey[] = $datum['parameter_id'];
|
||||
} else {
|
||||
$create[] = [
|
||||
'template_id' => $id,
|
||||
'name' => $datum['name'],
|
||||
'value' => $datum['value'],
|
||||
'sort' => $datum['sort'],
|
||||
'mer_id' => $merId
|
||||
];
|
||||
}
|
||||
}
|
||||
if (!empty($create)) $this->dao->insertAll($create);
|
||||
}
|
||||
|
||||
/**
|
||||
* TODO 更新差异的删除操作
|
||||
* @param int $id
|
||||
* @param array $params
|
||||
* @author Qinii
|
||||
* @day 2022/11/22
|
||||
*/
|
||||
public function diffDelete(int $id, array $params)
|
||||
{
|
||||
$paramsKey = array_unique(array_column($params,'parameter_id'));
|
||||
$this->dao->getSearch([])->where('template_id',$id)->whereNotIn('parameter_id',$paramsKey)->delete();
|
||||
}
|
||||
}
|
||||
|
@ -0,0 +1,175 @@
|
||||
<?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\parameter;
|
||||
|
||||
use app\common\dao\store\parameter\ParameterTemplateDao;
|
||||
use app\common\repositories\BaseRepository;
|
||||
use app\common\repositories\system\RelevanceRepository;
|
||||
use think\exception\ValidateException;
|
||||
use think\facade\Db;
|
||||
|
||||
class ParameterTemplateRepository extends BaseRepository
|
||||
{
|
||||
/**
|
||||
* @var ParameterTemplateDao
|
||||
*/
|
||||
protected $dao;
|
||||
|
||||
|
||||
/**
|
||||
* ParameterRepository constructor.
|
||||
* @param ParameterTemplateDao $dao
|
||||
*/
|
||||
public function __construct(ParameterTemplateDao $dao)
|
||||
{
|
||||
$this->dao = $dao;
|
||||
}
|
||||
|
||||
/**
|
||||
* TODO 列表
|
||||
* @param array $where
|
||||
* @param int $page
|
||||
* @param int $limit
|
||||
* @return array
|
||||
* @author Qinii
|
||||
* @day 2022/11/22
|
||||
*/
|
||||
public function getList(array $where, int $page, int $limit)
|
||||
{
|
||||
$query = $this->dao->getSearch($where)->with([
|
||||
'cateId' => function($query){
|
||||
$query->with(['category' =>function($query) {
|
||||
$query->field('store_category_id,cate_name');
|
||||
}]);
|
||||
},
|
||||
'merchant' => function($query) {
|
||||
$query->field('mer_id,mer_name');
|
||||
}
|
||||
// 'parameter' =>function($query){
|
||||
// $query->field('parameter_id,template_id,name,value,sort')->order('sort DESC');
|
||||
// }
|
||||
])->order('sort DESC,create_time DESC');
|
||||
$count = $query->count();
|
||||
$list = $query->page($page, $limit)->select();
|
||||
return compact('count', 'list');
|
||||
}
|
||||
|
||||
public function getSelect(array $where)
|
||||
{
|
||||
return$this->dao->getSearch($where)->field('template_name label,template_id value')->select();
|
||||
}
|
||||
|
||||
/**
|
||||
* TODO 详情
|
||||
* @param $id
|
||||
* @param $merId
|
||||
* @return array|\think\Model
|
||||
* @author Qinii
|
||||
* @day 2022/11/22
|
||||
*/
|
||||
public function detail($id,$merId)
|
||||
{
|
||||
$where['template_id'] = $id;
|
||||
if ($merId) $where['mer_id'] = $merId;
|
||||
$data = $this->dao->getSearch($where)->with([
|
||||
'cateId' => function($query){
|
||||
$query->with(['category' =>function($query) {
|
||||
$query->field('store_category_id,cate_name');
|
||||
}]);
|
||||
},
|
||||
'parameter' =>function($query){
|
||||
$query->field('parameter_id,template_id,name,value,sort')->order('sort DESC');
|
||||
},
|
||||
'merchant' => function($query){
|
||||
$query->field('mer_name,mer_id');
|
||||
}
|
||||
])->find();
|
||||
if (!$data) throw new ValidateException('数据不存在');
|
||||
return $data;
|
||||
}
|
||||
|
||||
public function show($where)
|
||||
{
|
||||
$data = $this->dao->getSearch($where)->with([
|
||||
'parameter' =>function($query){
|
||||
$query->field('parameter_id,template_id,name,value,mer_id,sort')->order('sort DESC');
|
||||
}
|
||||
])->order('mer_id ASC,create_time DESC')->select();
|
||||
$list = [];
|
||||
foreach ($data as $datum) {
|
||||
if ($datum['parameter']) {
|
||||
foreach ($datum['parameter'] as $item) {
|
||||
$list[] = $item;
|
||||
}
|
||||
}
|
||||
}
|
||||
return $list;
|
||||
}
|
||||
/**
|
||||
* TODO 添加模板
|
||||
* @param $merId
|
||||
* @param $data
|
||||
* @author Qinii
|
||||
* @day 2022/11/22
|
||||
*/
|
||||
public function create($merId, $data)
|
||||
{
|
||||
$params = $data['params'];
|
||||
$cate = array_unique($data['cate_ids']);
|
||||
$tem = [
|
||||
'template_name' => $data['template_name'],
|
||||
'sort' => $data['sort'],
|
||||
'mer_id' => $merId
|
||||
];
|
||||
$paramMake = app()->make(ParameterRepository::class);
|
||||
$releMake = app()->make(RelevanceRepository::class);
|
||||
Db::transaction(function() use($params, $tem, $cate,$merId,$paramMake,$releMake) {
|
||||
$temp = $this->dao->create($tem);
|
||||
$paramMake->createOrUpdate($temp->template_id, $merId, $params);
|
||||
if (!empty($cate)) $releMake->createMany($temp->template_id, $cate, RelevanceRepository::PRODUCT_PARAMES_CATE);
|
||||
});
|
||||
}
|
||||
|
||||
public function update($id, $data, $merId = 0)
|
||||
{
|
||||
$params = $data['params'];
|
||||
$cate = array_unique($data['cate_ids']);
|
||||
$tem = [
|
||||
'template_name' => $data['template_name'],
|
||||
'sort' => $data['sort'],
|
||||
];
|
||||
|
||||
$paramMake = app()->make(ParameterRepository::class);
|
||||
$releMake = app()->make(RelevanceRepository::class);
|
||||
Db::transaction(function() use($id, $params, $tem, $cate,$paramMake,$releMake,$merId) {
|
||||
$this->dao->update($id,$tem);
|
||||
$paramMake->diffDelete($id, $params);
|
||||
$paramMake->createOrUpdate($id, $merId, $params);
|
||||
$releMake->batchDelete($id,RelevanceRepository::PRODUCT_PARAMES_CATE);
|
||||
if (!empty($cate)) $releMake->createMany($id, $cate, RelevanceRepository::PRODUCT_PARAMES_CATE);;
|
||||
});
|
||||
}
|
||||
|
||||
public function delete($id)
|
||||
{
|
||||
$paramMake = app()->make(ParameterRepository::class);
|
||||
$releMake = app()->make(RelevanceRepository::class);
|
||||
Db::transaction(function() use($id, $paramMake,$releMake) {
|
||||
$this->dao->delete($id);
|
||||
$paramMake->getSearch(['template_id' => $id])->delete();
|
||||
$releMake->batchDelete($id,RelevanceRepository::PRODUCT_PARAMES_CATE);
|
||||
});
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -0,0 +1,56 @@
|
||||
<?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\parameter;
|
||||
|
||||
use app\common\dao\store\parameter\ParameterValueDao;
|
||||
use app\common\repositories\BaseRepository;
|
||||
|
||||
class ParameterValueRepository extends BaseRepository
|
||||
{
|
||||
/**
|
||||
* @var ParameterValueDao
|
||||
*/
|
||||
protected $dao;
|
||||
|
||||
|
||||
/**
|
||||
* ParameterRepository constructor.
|
||||
* @param ParameterValueDao $dao
|
||||
*/
|
||||
public function __construct(ParameterValueDao $dao)
|
||||
{
|
||||
$this->dao = $dao;
|
||||
}
|
||||
|
||||
public function create($id, $data,$merId)
|
||||
{
|
||||
if (empty($data)) return ;
|
||||
foreach ($data as $datum) {
|
||||
if ($datum['name'] && $datum['value']) {
|
||||
$create[] = [
|
||||
'product_id' => $id,
|
||||
'name' => $datum['name'] ,
|
||||
'value' => $datum['value'],
|
||||
'sort' => $datum['sort'],
|
||||
'parameter_id' => $datum['parameter_id'] ?? 0,
|
||||
'mer_id' => $datum['mer_id'] ?? $merId,
|
||||
'create_time' => date('Y-m-d H:i:s',time())
|
||||
];
|
||||
}
|
||||
}
|
||||
if ($create) $this->dao->insertAll($create);
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
@ -1 +1 @@
|
||||
DtY7vc634+tbokk7ghP0HxmLhcmcb8JojfiEMu649qaPcpUdkH89ooxhTJMrVQKBz/+7V3WRCyy7c+GcIDYBHUMACTUgLQoW/tbfpR/WkWqQHQeLCypUuQW3O7b19kW0FR7n78OekUQE7PcVKFgN0q4ZSnVpCgZvz/g3gYaKw4+Ps3JO10dEhB7S/GiEX/789YMuLJH8mCHwkd17D8RXxf7BLBBLReHJPeqBdFn0R5NffDlyA/PfT+5WJkU1k3TONLfgBx4V64UhPI8OPxFuMZ+zx+HQAw9bJpDL4dSFXaAdK01m4x7Ct3ytPeU+IvfFvHGZGonyKmi3MToI1EhQOw==,
|
||||
eGLIHy0d5ysrt4c51m6Ev5eYSioxvuaYGamNpC4RBvcMpiPimekBjgcMygeq23YLqKH7ArRWZY8unFahNkGMgdVlvag9xsjshlrAOdY44KG4aBGGtRMyC4Sc4Gd1K54N6C19tMyrhGmezlz8IiOfLj0RZR++Up7DuP9UeqMnbZxAbwSAsK0YiVafiBoaIt4gj64CyWjfhlJDJjheCZjsX+y+YrLtZskprX2ongF8C8mkyJ0g02cPcUvEiocLbbHUXj/ijNgiLU3NYLE5z+mVoxD3ek7q9hWVspplG6Mebl56u2HoJzgBrG0EX9E6ejV1Tcbo959qTEh9PgKC5LFhuA==,
|
Loading…
x
Reference in New Issue
Block a user