glhcp/server/app/shop/logic/CommonLogic.php

98 lines
3.4 KiB
PHP

<?php
namespace app\shop\logic;
use app\common\basics\Logic;
use app\common\model\goods\Goods;
use app\common\model\goods\GoodsItem;
use app\common\server\UrlServer;
use app\common\enum\GoodsEnum;
class CommonLogic extends Logic
{
public static function getGoodsList($get)
{
$where = [
['shop_id', '=', $get['shop_id']],
['del', '=', GoodsEnum::DEL_NORMAL], // 未删除
['audit_status', '=', GoodsEnum::AUDIT_STATUS_OK], // 审核通过
['status', '=', GoodsEnum::STATUS_SHELVES], // 上架中
['type', '=', GoodsEnum::TYPE_ACTUAL] // 实物商品才参与
];
if(!empty($get['keyword'])) {
$where[] = ['name', 'like','%'. $get['keyword'].'%'];
}
if(!empty($get['cid'])) {
$where[] = ['shop_cate_id', '=', $get['cid']];
}
$lists = Goods::field('id,name,image,min_price as min_max_price,min_price,max_price,stock')
->where($where)
->order('id', 'desc')
->page($get['page'], $get['limit'])
->select()
->toArray();
$count = Goods::field('id,name,image,min_price,max_price,stock')
->where($where)
->count();
foreach($lists as &$item) {
$item['image'] = UrlServer::getFileUrl($item['image']);
}
return [
'count' => $count,
'lists' => $lists
];
}
//获取商品列表
public static function getGoodsListTwo($get,$is_item = false){
$where = [
['shop_id', '=', $get['shop_id']],
['del', '=', GoodsEnum::DEL_NORMAL], // 未删除
['audit_status', '=', GoodsEnum::AUDIT_STATUS_OK], // 审核通过
['status', '=', GoodsEnum::STATUS_SHELVES], // 上架中
['type', '=', GoodsEnum::TYPE_ACTUAL] // 实物商品才参与
];
if (isset($get['keyword']) && $get['keyword']) {
$where[] = ['name', 'like', '%' . $get['keyword'] . '%'];
}
if(!empty($get['cid'])) {
$where[] = ['shop_cate_id', '=', $get['cid']];
}
$goods_count = Goods::where($where)->count();
$goods_list = Goods::where($where)
->page($get['page'], $get['limit'])
->column('*','id');
foreach ($goods_list as &$item) {
$item['goods_item'] = [];
$item['price'] = '¥'.$item['min_price'];
if($item['max_price'] != $item['min_price']){
$item['price'] = '¥'.$item['min_price'].'~'.'¥'.$item['max_price'];
}
$item['create_time_desc'] = date('Y-m-d H:i:s',$item['create_time']);
$item['image'] = UrlServer::getFileUrl($item['image']);
}
if($is_item){
$goods_ids = array_keys($goods_list);
$goods_item = GoodsItem::where(['goods_id'=>$goods_ids])->select()->toArray();
foreach ($goods_item as $items){
if(isset($goods_list[$items['goods_id']])){
if($items['image']){
$items['image'] = UrlServer::getFileUrl($items['image']);
}else{
$items['image'] = $goods_list[$items['goods_id']]['image'];
}
$goods_list[$items['goods_id']]['goods_item'][] = $items;
}
}
}
return ['count' => $goods_count, 'list' =>array_values($goods_list)];
}
}