311 lines
9.5 KiB
PHP
311 lines
9.5 KiB
PHP
<?php
|
|
|
|
|
|
|
|
|
|
namespace app\common\model\system\merchant;
|
|
|
|
|
|
use app\common\dao\store\product\ProductDao;
|
|
use app\common\model\BaseModel;
|
|
use app\common\model\store\coupon\StoreCouponProduct;
|
|
use app\common\model\store\coupon\StoreCouponUser;
|
|
use app\common\model\store\order\StoreOrder;
|
|
use app\common\model\store\product\Product;
|
|
use app\common\model\store\product\Spu;
|
|
use app\common\model\store\service\StoreService;
|
|
use app\common\model\system\config\SystemConfigValue;
|
|
use app\common\model\system\financial\Financial;
|
|
use app\common\model\system\serve\ServeOrder;
|
|
use app\common\repositories\store\order\StoreOrderRepository;
|
|
use app\common\repositories\store\StoreActivityRepository;
|
|
use app\common\repositories\system\merchant\MerchantRepository;
|
|
|
|
class Merchant extends BaseModel
|
|
{
|
|
|
|
/**
|
|
* @return string
|
|
* @author xaboy
|
|
* @day 2020-03-30
|
|
*/
|
|
public static function tablePk(): string
|
|
{
|
|
return 'mer_id';
|
|
}
|
|
|
|
/**
|
|
* @return string
|
|
* @author xaboy
|
|
* @day 2020-03-30
|
|
*/
|
|
public static function tableName(): string
|
|
{
|
|
return 'merchant';
|
|
}
|
|
|
|
public function getDeliveryWayAttr($value)
|
|
{
|
|
if (!$value) return [];
|
|
return explode(',',$value);
|
|
}
|
|
|
|
public function product()
|
|
{
|
|
return $this->hasMany(Product::class, 'mer_id', 'mer_id');
|
|
}
|
|
|
|
public function config()
|
|
{
|
|
return $this->hasMany(SystemConfigValue::class, 'mer_id', 'mer_id');
|
|
}
|
|
|
|
public function showProduct()
|
|
{
|
|
return $this->hasMany(Product::class, 'mer_id', 'mer_id')
|
|
->where((new ProductDao())->productShow())
|
|
->field('mer_id,product_id,store_name,image,price,is_show,status,is_gift_bag,is_good')
|
|
->order('is_good DESC,sort DESC');
|
|
}
|
|
|
|
/**
|
|
* TODO 商户列表下的推荐
|
|
* @return \think\Collection
|
|
* @author Qinii
|
|
* @day 4/20/22
|
|
*/
|
|
public function getAllRecommendAttr()
|
|
{
|
|
$list = Product::where('mer_id', $this['mer_id'])
|
|
->where((new ProductDao())->productShow())
|
|
->with(['brand'=>function($query){
|
|
$query->bind(['brand_name']);
|
|
}])
|
|
->field('mer_id,product_id,store_name,image,price,ot_price,is_show,status,is_gift_bag,is_good,cate_id,brand_id')
|
|
->order('is_good DESC, sort DESC, create_time DESC')
|
|
->limit(3)
|
|
->select()->append(['show_svip_info']);
|
|
if ($list) {
|
|
$data = [];
|
|
$make = app()->make(StoreActivityRepository::class);
|
|
foreach ($list as $item) {
|
|
$spu_id = Spu::where('product_id',$item->product_id)->where('product_type' ,0)->value('spu_id');
|
|
$act = $make->getActivityBySpu(StoreActivityRepository::ACTIVITY_TYPE_BORDER,$spu_id,$item['cate_id'],$item['mer_id']);
|
|
$item['border_pic'] = $act['pic'] ?? '';
|
|
$data[] = $item;
|
|
}
|
|
return $data;
|
|
}
|
|
return [];
|
|
}
|
|
|
|
public function getCityRecommendAttr()
|
|
{
|
|
$list = Product::where('mer_id', $this['mer_id'])
|
|
->where((new ProductDao())->productShow())
|
|
->whereLike('delivery_way',"%1%")
|
|
->field('mer_id,product_id,store_name,image,price,is_show,status,is_gift_bag,is_good,cate_id')
|
|
->order('sort DESC, create_time DESC')
|
|
->limit(3)
|
|
->select();
|
|
if ($list) {
|
|
$data = [];
|
|
$make = app()->make(StoreActivityRepository::class);
|
|
foreach ($list as $item) {
|
|
$spu_id = Spu::where('product_id',$item->product_id)->where('product_type' ,0)->value('spu_id');
|
|
$act = $make->getActivityBySpu(StoreActivityRepository::ACTIVITY_TYPE_BORDER,$spu_id,$item['cate_id'],$item['mer_id']);
|
|
$item['border_pic'] = $act['pic'] ?? '';
|
|
$data[] = $item;
|
|
}
|
|
return $data;
|
|
}
|
|
return [];
|
|
}
|
|
|
|
|
|
public function recommend()
|
|
{
|
|
return $this->hasMany(Product::class, 'mer_id', 'mer_id')
|
|
->where((new ProductDao())->productShow())
|
|
->where('is_good', 1)
|
|
->field('mer_id,product_id,store_name,image,price,is_show,status,is_gift_bag,is_good,sales,create_time')
|
|
->order('is_good DESC,sort DESC,create_time DESC')
|
|
->limit(3);
|
|
}
|
|
|
|
|
|
public function coupon()
|
|
{
|
|
$time = date('Y-m-d H:i:s');
|
|
return $this->hasMany(StoreCouponUser::class, 'mer_id', 'mer_id')->where('start_time', '<', $time)->where('end_time', '>', $time)
|
|
->where('is_fail', 0)->where('status', 0)->order('coupon_price DESC, coupon_user_id ASC')
|
|
->with(['product' => function ($query) {
|
|
$query->field('coupon_id,product_id');
|
|
}, 'coupon' => function ($query) {
|
|
$query->field('coupon_id,type');
|
|
}]);
|
|
}
|
|
|
|
public function getServicesTypeAttr()
|
|
{
|
|
//0 支持在线聊天 1 支持电话 -1 暂无客服
|
|
$services_type = merchantConfig($this->mer_id,'services_type');
|
|
if ($services_type) {
|
|
if (!$this->service_phone) $services_type = -1;
|
|
} else {
|
|
$services_type = 0;
|
|
$where = ['mer_id' => $this->mer_id, 'is_open' => 1,'status' => 1];
|
|
$service = StoreService::where($where)->count();
|
|
if (!$service) $services_type = -1;
|
|
}
|
|
return $services_type;
|
|
}
|
|
|
|
public function marginOrder()
|
|
{
|
|
return $this->hasMany(ServeOrder::class, 'mer_id','mer_id')->where('type', 10)->order('create_time DESC');
|
|
}
|
|
|
|
public function refundMarginOrder()
|
|
{
|
|
return $this->hasOne(Financial::class, 'mer_id', 'mer_id')
|
|
->where('type',1)
|
|
->where('status', -1)
|
|
->order('create_time DESC')
|
|
->limit(1);
|
|
}
|
|
|
|
public function merchantCategory()
|
|
{
|
|
return $this->hasOne(MerchantCategory::class, 'merchant_category_id', 'category_id');
|
|
}
|
|
|
|
public function merchantType()
|
|
{
|
|
return $this->hasOne(MerchantType::class, 'mer_type_id', 'type_id');
|
|
}
|
|
|
|
public function typeName()
|
|
{
|
|
return $this->merchantType()->bind(['type_name']);
|
|
}
|
|
public function categoryName()
|
|
{
|
|
return $this->merchantCategory()->bind(['category_name']);
|
|
}
|
|
|
|
public function getMerCommissionRateAttr()
|
|
{
|
|
return $this->commission_swtich ? $this->commission_rate : $this->merchantCategory->commission_rate;
|
|
}
|
|
|
|
public function getOpenReceiptAttr()
|
|
{
|
|
return merchantConfig($this->mer_id, 'mer_open_receipt');
|
|
}
|
|
|
|
public function admin()
|
|
{
|
|
return $this->hasOne(MerchantAdmin::class, 'mer_id', 'mer_id')->where('level', 0);
|
|
}
|
|
|
|
|
|
public function searchKeywordAttr($query, $value)
|
|
{
|
|
$query->whereLike('mer_name|mer_keyword', "%{$value}%");
|
|
}
|
|
|
|
public function getFinancialAlipayAttr($value)
|
|
{
|
|
return $value ? json_decode($value) : $value;
|
|
}
|
|
|
|
public function getFinancialWechatAttr($value)
|
|
{
|
|
return $value ? json_decode($value) : $value;
|
|
}
|
|
|
|
public function getFinancialBankAttr($value)
|
|
{
|
|
return $value ? json_decode($value) : $value;
|
|
}
|
|
|
|
public function getMerCertificateAttr()
|
|
{
|
|
return merchantConfig($this->mer_id, 'mer_certificate');
|
|
}
|
|
|
|
public function getIssetCertificateAttr()
|
|
{
|
|
return count(merchantConfig($this->mer_id, 'mer_certificate') ?: []) > 0;
|
|
}
|
|
|
|
public function getMarginRemindStatusAttr()
|
|
{
|
|
if (systemConfig('margin_remind_switch') == '1' && $this->mer_state) {
|
|
if ($this->is_margin == 10) {
|
|
if($this->ot_margin > $this->margin) {
|
|
if (!$this->margin_remind_time) {
|
|
$day = systemConfig('margin_remind_day') ?: 0;
|
|
if($day) {
|
|
$time = strtotime(date('Y-m-d 23:59:59',strtotime("+ $day day",time())));
|
|
$this->margin_remind_time = $time;
|
|
} else {
|
|
$this->status = 0;
|
|
$this->mer_state = 0;
|
|
}
|
|
$this->save();
|
|
}
|
|
return $this->margin_remind_time;
|
|
}
|
|
}
|
|
}
|
|
return null;
|
|
}
|
|
|
|
public function searchMerIdsAttr($query, $value)
|
|
{
|
|
$query->whereIn('mer_id',$value);
|
|
}
|
|
// 在线买单二维码
|
|
public function getOnlinePaymentQrCodeAttr(){
|
|
|
|
return app()->make(MerchantRepository::class)->createQrCode(['mer_id'=>$this->mer_id],'online_payment');
|
|
}
|
|
|
|
// 商户查询关联的酒道馆
|
|
public function shopMer(){
|
|
return $this->hasOne(self::class,'shop_mer_id', 'mer_id');
|
|
}
|
|
// 酒道馆查询关联的商户
|
|
public function merShop(){
|
|
return $this->hasOne(self::class,'mer_id', 'shop_mer_id');
|
|
}
|
|
|
|
public function brand(){
|
|
return $this->hasOne(MerchantBrand::class,'id', 'brand_id');
|
|
}
|
|
|
|
/**
|
|
* Common: 获取本月销售数量
|
|
* Author: wu-hui
|
|
* Time: 2023/11/17 15:42
|
|
* @return int
|
|
*/
|
|
public function getMonthSalesAttr(){
|
|
$startTime = strtotime(date("Y-m-1 00:00:00"));// 本月1号0点
|
|
$monthOrderCount = app()->make(StoreOrder::class)
|
|
->where('mer_id',$this->mer_id)
|
|
->where('pay_time','>=',date('Y/m/1 00:00:00', time()))
|
|
->whereNotIn('status',[11,-1])
|
|
->count();
|
|
|
|
return (int)$monthOrderCount;
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|