erp/app/admin/logic/order/CartLogic.php
2024-04-29 16:36:12 +08:00

100 lines
2.4 KiB
PHP

<?php
namespace app\admin\logic\order;
use app\common\model\order\Cart;
use app\common\logic\BaseLogic;
use think\facade\Db;
/**
* 购物车表逻辑
* Class CartLogic
* @package app\admin\logic\order
*/
class CartLogic extends BaseLogic
{
/**
* @notes 添加购物车表
* @param array $params
* @return bool
* @author likeadmin
* @date 2024/04/24 10:37
*/
public static function add(array $params): bool
{
Db::startTrans();
try {
Cart::create([
'cart_num' => $params['cart_num'],
'goods_id' => $params['goods_id'],
'uid' => $params['uid'],
'source' => $params['source']??0,
'mer_id' => $params['mer_id']??0,
'staff_id' => $params['staff_id']??0,
'is_new' => $params['is_new']??0,
]);
Db::commit();
return true;
} catch (\Exception $e) {
Db::rollback();
self::setError($e->getMessage());
return false;
}
}
/**
* @notes 编辑购物车表
* @param array $params
* @return bool
* @author likeadmin
* @date 2024/04/24 10:37
*/
public static function edit(array $params,$type='inc'): bool
{
Db::startTrans();
try {
if($type=='inc'){
Cart::where(['uid'=>$params['uid'],'goods_id'=>$params['goods_id']])->inc('cart_num',$params['cart_num'])->update();
}else{
Cart::where(['uid'=>$params['uid'],'goods_id'=>$params['goods_id']])->dec('cart_num',$params['cart_num'])->update();
}
Db::commit();
return true;
} catch (\Exception $e) {
Db::rollback();
self::setError($e->getMessage());
return false;
}
}
/**
* @notes 删除购物车表
* @param array $params
* @return bool
* @author likeadmin
* @date 2024/04/24 10:37
*/
public static function delete(array $params): bool
{
return Cart::destroy($params['cart_id']);
}
/**
* @notes 获取购物车表详情
* @param $params
* @return array
* @author likeadmin
* @date 2024/04/24 10:37
*/
public static function detail($params): array
{
return Cart::findOrEmpty($params['cart_id'])->toArray();
}
}