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; | ||
|  |         } | ||
|  |     } | ||
|  | } |