302 lines
10 KiB
PHP
302 lines
10 KiB
PHP
|
<?php
|
||
|
|
||
|
|
||
|
namespace app\admin\logic\shop;
|
||
|
|
||
|
|
||
|
use app\common\basics\Logic;
|
||
|
use app\common\enum\ShopEnum;
|
||
|
use app\common\model\shop\Shop;
|
||
|
use app\common\model\shop\ShopAdmin;
|
||
|
use app\common\server\UrlServer;
|
||
|
use Exception;
|
||
|
use think\facade\Db;
|
||
|
|
||
|
class StoreLogic extends Logic
|
||
|
{
|
||
|
/**
|
||
|
* NOTE: 商家列表
|
||
|
* @author: 张无忌
|
||
|
* @param $get
|
||
|
* @return array|bool
|
||
|
*/
|
||
|
public static function lists($get)
|
||
|
{
|
||
|
try {
|
||
|
$where = [
|
||
|
['del', '=', 0]
|
||
|
];
|
||
|
|
||
|
if (!empty($get['name']) and $get['name'])
|
||
|
$where[] = ['name', 'like', '%'.$get['name'].'%'];
|
||
|
|
||
|
if (!empty($get['type']) and is_numeric($get['type']))
|
||
|
$where[] = ['type', '=', $get['type']];
|
||
|
|
||
|
if (!empty($get['cid']) and is_numeric($get['cid']))
|
||
|
$where[] = ['cid', '=', $get['cid']];
|
||
|
|
||
|
if (isset($get['is_recommend']) && $get['is_recommend'] != '')
|
||
|
$where[] = ['is_recommend', '=', $get['is_recommend']];
|
||
|
|
||
|
if (isset($get['is_run']) && $get['is_run'] != '')
|
||
|
$where[] = ['is_run', '=', $get['is_run']];
|
||
|
|
||
|
if (isset($get['is_freeze']) and $get['is_freeze'] != '')
|
||
|
$where[] = ['is_freeze', '=', $get['is_freeze']];
|
||
|
|
||
|
if (!empty($get['expire_start_time']) and $get['expire_start_time'])
|
||
|
$where[] = ['expire_time', '>=', strtotime($get['expire_start_time'])];
|
||
|
|
||
|
if (!empty($get['expire_end_time']) and $get['expire_end_time'])
|
||
|
$where[] = ['expire_time', '<=', strtotime($get['expire_end_time'])];
|
||
|
|
||
|
$condition = 'del=0';
|
||
|
// 到期状态
|
||
|
if (isset($get['expire_status']) and $get['expire_status'] != '') {
|
||
|
if ($get['expire_status']) {
|
||
|
// 已到期
|
||
|
$where[] = ['expire_time', '<', time()];
|
||
|
$where[] = ['expire_time', '>', 0];
|
||
|
} else {
|
||
|
// 未到期
|
||
|
$condition = "expire_time=0 OR expire_time >". time();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
$model = new Shop();
|
||
|
$lists = $model->field(true)
|
||
|
->where($where)
|
||
|
->whereRaw($condition)
|
||
|
->order('id', 'desc')
|
||
|
->order('weight', 'asc')
|
||
|
->with(['category', 'admin'])
|
||
|
->append(['expire_desc'])
|
||
|
->paginate([
|
||
|
'page' => $get['page'],
|
||
|
'list_rows' => $get['limit'],
|
||
|
'var_page' => 'page'
|
||
|
])
|
||
|
->toArray();
|
||
|
|
||
|
foreach ($lists['data'] as &$item) {
|
||
|
$item['category'] = $item['category']['name'] ?? '未知';
|
||
|
$item['type'] = ShopEnum::getShopTypeDesc($item['type']);
|
||
|
$item['is_run'] = ShopEnum::getShopIsRunDesc($item['is_run']);
|
||
|
$item['is_freeze'] = ShopEnum::getShopFreezeDesc($item['is_freeze']);
|
||
|
$item['is_recommend'] = ShopEnum::getShopIsRecommendDesc($item['is_recommend']);
|
||
|
$item['account'] = $item['admin']['account'] ?? '';
|
||
|
}
|
||
|
|
||
|
return ['count'=>$lists['total'], 'lists'=>$lists['data']];
|
||
|
} catch (Exception $e) {
|
||
|
return ['error'=>$e->getMessage()];
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* NOTE: 商家详细
|
||
|
* @author: 张无忌
|
||
|
* @param $id
|
||
|
* @return array
|
||
|
*/
|
||
|
public static function detail($id)
|
||
|
{
|
||
|
$model = new Shop();
|
||
|
$detail = $model->json(['other_qualifications'],true)->findOrEmpty($id)->toArray();
|
||
|
$detail['expire_time'] = $detail['expire_time'] == '无期限' ? 0 : $detail['expire_time'];
|
||
|
|
||
|
$detail['business_license'] = $detail['business_license'] ? UrlServer::getFileUrl($detail['business_license']) : '';
|
||
|
if (!empty($detail['other_qualifications'])) {
|
||
|
foreach ($detail['other_qualifications'] as &$val) {
|
||
|
$val = UrlServer::getFileUrl($val);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return $detail;
|
||
|
}
|
||
|
|
||
|
public static function getAccountInfo($id)
|
||
|
{
|
||
|
$detail = ShopAdmin::field('id,account')->where(['shop_id' => $id, 'root' => 1])->findOrEmpty()->toArray();
|
||
|
return $detail;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* NOTE: 新增商家
|
||
|
* @author: 张无忌
|
||
|
* @param $post
|
||
|
* @return bool
|
||
|
*/
|
||
|
public static function add($post)
|
||
|
{
|
||
|
Db::startTrans();
|
||
|
try {
|
||
|
// 创建商家
|
||
|
$shop = Shop::create([
|
||
|
'cid' => $post['cid'],
|
||
|
'type' => $post['type'],
|
||
|
'name' => $post['name'],
|
||
|
'nickname' => $post['nickname'],
|
||
|
'mobile' => $post['mobile'],
|
||
|
'logo' => $post['logo'] ?? '',
|
||
|
'background' => $post['background'] ?? '',
|
||
|
'license' => $post['license'] ?? '',
|
||
|
'keywords' => $post['keywords'] ?? '',
|
||
|
'intro' => $post['intro'] ?? '',
|
||
|
'weight' => $post['weight'] ?? 0,
|
||
|
'trade_service_fee' => $post['trade_service_fee'],
|
||
|
'is_run' => $post['is_run'],
|
||
|
'is_freeze' => $post['is_freeze'],
|
||
|
'is_product_audit' => $post['is_product_audit'],
|
||
|
'is_recommend' => $post['is_recommend'] ?? 0,
|
||
|
'expire_time' => !empty($post['expire_time']) ? strtotime($post['expire_time']) : 0
|
||
|
]);
|
||
|
// 创建账号
|
||
|
// 新增商家登录账号
|
||
|
$time = time();
|
||
|
$salt = substr(md5($time . $post['name']), 0, 4);//随机4位密码盐
|
||
|
ShopAdmin::create([
|
||
|
'root' => 1,
|
||
|
'shop_id' => $shop->id,
|
||
|
'name' => $shop->name,
|
||
|
'account' => $post['account'],
|
||
|
'password' => generatePassword($post['password'], $salt),
|
||
|
'salt' => $salt,
|
||
|
'role_id' => 0,
|
||
|
'create_time' => $time,
|
||
|
'update_time' => $time,
|
||
|
'disable' => 0,
|
||
|
'del' => 0
|
||
|
]);
|
||
|
|
||
|
Db::commit();
|
||
|
return true;
|
||
|
} catch (Exception $e) {
|
||
|
Db::rollback();
|
||
|
static::$error = $e->getMessage();
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* NOTE: 编辑商家
|
||
|
* @author: 张无忌
|
||
|
* @param $post
|
||
|
* @return bool
|
||
|
*/
|
||
|
public static function edit($post)
|
||
|
{
|
||
|
try {
|
||
|
Shop::update([
|
||
|
'cid' => $post['cid'],
|
||
|
'type' => $post['type'],
|
||
|
'name' => $post['name'],
|
||
|
'nickname' => $post['nickname'],
|
||
|
'mobile' => $post['mobile'],
|
||
|
'logo' => $post['logo'] ?? '',
|
||
|
'keywords' => $post['keywords'] ?? '',
|
||
|
'intro' => $post['intro'] ?? '',
|
||
|
'trade_service_fee' => $post['trade_service_fee'],
|
||
|
'is_run' => $post['is_run'],
|
||
|
'is_freeze' => $post['is_freeze'],
|
||
|
'is_product_audit' => $post['is_product_audit'],
|
||
|
'expire_time' => !empty($post['expire_time']) ? strtotime($post['expire_time']) : 0
|
||
|
], ['id'=>$post['id']]);
|
||
|
|
||
|
return true;
|
||
|
} catch (Exception $e) {
|
||
|
static::$error = $e->getMessage();
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* NOTE: 设置商家
|
||
|
* @author: 张无忌
|
||
|
* @param $post
|
||
|
* @return bool
|
||
|
*/
|
||
|
public static function set($post)
|
||
|
{
|
||
|
try {
|
||
|
Shop::update([
|
||
|
'is_distribution' => $post['is_distribution'] ?? 0,
|
||
|
'is_recommend' => $post['is_recommend'] ?? 0,
|
||
|
'is_pay' => $post['is_pay'] ?? 1, //是否开启支付功能,默认开启
|
||
|
'weight' => $post['weight']
|
||
|
], ['id'=>$post['id']]);
|
||
|
|
||
|
return true;
|
||
|
} catch (Exception $e) {
|
||
|
static::$error = $e->getMessage();
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* NOTE: 更新账号密码
|
||
|
* @author: 张无忌
|
||
|
* @param $post
|
||
|
* @return bool
|
||
|
*/
|
||
|
public static function account($post)
|
||
|
{
|
||
|
Db::startTrans();
|
||
|
try {
|
||
|
if(!isset($post['account']) || empty($post['account'])) {
|
||
|
throw new \think\Exception('账户不能为空');
|
||
|
}
|
||
|
$shopAdmin = ShopAdmin::where([
|
||
|
['account', '=', trim($post['account'])],
|
||
|
['shop_id', '<>', $post['id']]
|
||
|
])->findOrEmpty();
|
||
|
if(!$shopAdmin->isEmpty()) {
|
||
|
throw new \think\Exception('账户已存在,请更换其他名称重试');
|
||
|
}
|
||
|
|
||
|
$shopAdmin = ShopAdmin::where(['shop_id' => $post['id'], 'root' => 1])->findOrEmpty();
|
||
|
|
||
|
$shopAdminUpdateData = [
|
||
|
'account' => $post['account'],
|
||
|
'update_time' => time()
|
||
|
];
|
||
|
if (!empty($post['password'])) {
|
||
|
$shopAdminUpdateData['password'] = generatePassword($post['password'], $shopAdmin->salt);
|
||
|
}
|
||
|
ShopAdmin::where(['shop_id' => $post['id'], 'root' => 1])->update($shopAdminUpdateData);
|
||
|
|
||
|
Db::commit();
|
||
|
return true;
|
||
|
} catch (Exception $e) {
|
||
|
Db::rollback();
|
||
|
static::$error = $e->getMessage();
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* @notes 批量更新商家营业状态或冻结状态
|
||
|
* @param $ids
|
||
|
* @param $field
|
||
|
* @param $value
|
||
|
* @return Shop|false
|
||
|
* @author 段誉
|
||
|
* @date 2022/3/17 10:42
|
||
|
*/
|
||
|
public static function batchOperation($ids, $field, $value)
|
||
|
{
|
||
|
try {
|
||
|
$result = Shop::whereIn('id', $ids)->update([
|
||
|
$field => $value,
|
||
|
'update_time' => time()
|
||
|
]);
|
||
|
return $result;
|
||
|
} catch (\Exception $e) {
|
||
|
self::$error = $e->getMessage();
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
}
|