Compare commits
No commits in common. "8a3deee5f06bc0614c2d70d76d16e7a27934f4f6" and "09e07694ca9ea8cd78fc72f3252cf7db9e7e78f9" have entirely different histories.
8a3deee5f0
...
09e07694ca
|
@ -826,9 +826,7 @@ if (!function_exists('getEarthSquareRangePoint')) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* 获取两个地点之鉴的距离
|
|
||||||
* */
|
|
||||||
if (!function_exists('get_distance')) {
|
if (!function_exists('get_distance')) {
|
||||||
function get_distance($lat1, $lng1, $lat2, $lng2)
|
function get_distance($lat1, $lng1, $lat2, $lng2)
|
||||||
{
|
{
|
||||||
|
@ -844,32 +842,4 @@ if (!function_exists('get_distance')) {
|
||||||
$calculatedDistance = $earthRadius * $stepTwo;
|
$calculatedDistance = $earthRadius * $stepTwo;
|
||||||
return round($calculatedDistance);
|
return round($calculatedDistance);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* 格式化优惠券的使用周期
|
|
||||||
* */
|
|
||||||
if (!function_exists('encodeCouponCycle')) {
|
|
||||||
function encodeCouponCycle(array $week)
|
|
||||||
{
|
|
||||||
$font =[
|
|
||||||
"0"=>"星期天",
|
|
||||||
"1"=>"星期一",
|
|
||||||
"2"=>"星期二",
|
|
||||||
"3"=>"星期三",
|
|
||||||
"4"=>"星期四",
|
|
||||||
"5"=>"星期五",
|
|
||||||
"6"=>"星期六",
|
|
||||||
];
|
|
||||||
|
|
||||||
$str = [];
|
|
||||||
foreach ($week as $value){
|
|
||||||
if (isset($font[$value])) {
|
|
||||||
$str[] = $font[$value];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return implode(",",$str);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
|
@ -6,12 +6,13 @@ use app\model\BusinessCircle;
|
||||||
use app\model\Category;
|
use app\model\Category;
|
||||||
use app\repository\AccountRepository;
|
use app\repository\AccountRepository;
|
||||||
use app\repository\BusinessRepository;
|
use app\repository\BusinessRepository;
|
||||||
use app\repository\CouponRepository;
|
|
||||||
use app\repository\DictionaryRepository;
|
use app\repository\DictionaryRepository;
|
||||||
use app\validate\BusinessValidate;
|
use app\validate\BusinessValidate;
|
||||||
use think\Collection;
|
|
||||||
use think\exception\ValidateException;
|
use think\exception\ValidateException;
|
||||||
use app\model\{Business as BusinessModel, Account as AccountModel, CouponMain};
|
use app\model\{
|
||||||
|
Business as BusinessModel,
|
||||||
|
Account as AccountModel
|
||||||
|
};
|
||||||
use think\response\Json;
|
use think\response\Json;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -22,10 +23,6 @@ use think\response\Json;
|
||||||
*/
|
*/
|
||||||
class Business extends Base
|
class Business extends Base
|
||||||
{
|
{
|
||||||
|
|
||||||
protected $noNeedLogin = [
|
|
||||||
'couponDetail',
|
|
||||||
];
|
|
||||||
/**
|
/**
|
||||||
* 商家认证注册
|
* 商家认证注册
|
||||||
*
|
*
|
||||||
|
@ -220,59 +217,6 @@ class Business extends Base
|
||||||
$data = BusinessCircle::getList();
|
$data = BusinessCircle::getList();
|
||||||
return $this->json(1,"ok",$data);
|
return $this->json(1,"ok",$data);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* 商家优惠券详情
|
|
||||||
* */
|
|
||||||
public function couponDetail()
|
|
||||||
{
|
|
||||||
$accountId = $this->request->user['user_id'] ?? 0;
|
|
||||||
$account = AccountRepository::getInstance()->findById($accountId, [], function ($q) {
|
|
||||||
return $q->with(['business', 'parent']);
|
|
||||||
});
|
|
||||||
|
|
||||||
$couponMainId = input("id/d");
|
|
||||||
$couponMain = CouponMain::findOne(["id"=>$couponMainId]);
|
|
||||||
if(empty($couponMain)){
|
|
||||||
return $this->json(4001,"优惠券不存在");
|
|
||||||
}
|
|
||||||
if(!$business = BusinessRepository::getInstance()->findOneByWhere(["code"=>$couponMain["business_code"]])){
|
|
||||||
return $this->json(4001,"优惠券商家信息不存在");
|
|
||||||
}
|
|
||||||
|
|
||||||
$list = $business->toArray();
|
|
||||||
$list = DictionaryRepository::getInstance()->parseAreaText($list);
|
|
||||||
|
|
||||||
$data = [];
|
|
||||||
|
|
||||||
$data["businessAddress"] = $list['province_text'] . $list['city_text'] . $list['county_text'] . $business['business_address'];
|
|
||||||
$data["businessName"] = $list['business_name'];
|
|
||||||
$data["count"] = $couponMain->count;
|
|
||||||
$data["couponName"] = $couponMain->name;
|
|
||||||
$data["deductionMoney"] = $couponMain->deduction_money;
|
|
||||||
$data["startTime"] = $couponMain->start_time;
|
|
||||||
$data["endTime"] = $couponMain->end_time;
|
|
||||||
$data["id"] = $couponMain->id;
|
|
||||||
$data["imageUrl"] = $this->request->domain(). $couponMain->image_url;
|
|
||||||
$data["intro"] = $couponMain->intro;//简介
|
|
||||||
$data["lat"] = $couponMain->lat;
|
|
||||||
$data["lng"] = $couponMain->lng;
|
|
||||||
$data["money"] = $couponMain->money;
|
|
||||||
$data["usingRule"] = DictionaryRepository::getInstance()->getUsingRuleByCouponMainId($couponMain->id);
|
|
||||||
$data["punishRule"] = '';//处罚规则 已取消
|
|
||||||
|
|
||||||
//未登录可以领取 0可领取 1已领取
|
|
||||||
if (empty($account)) {
|
|
||||||
$data["receiveStatus"] = CouponMain::COMMON_OFF;//领取状态
|
|
||||||
}else{
|
|
||||||
$data["receiveStatus"] = AccountRepository::getInstance()->getCouponReceiveStatus($account->user_code,$couponMain);//领取状态
|
|
||||||
}
|
|
||||||
$data["receivedCount"] = $couponMain->received_count;//已领取数量
|
|
||||||
$data["typeName"] = $couponMain->type_name;
|
|
||||||
|
|
||||||
return $this->json(0,"success",$data);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -3,13 +3,9 @@ namespace app\controller\api;
|
||||||
|
|
||||||
use app\model\CouponMain;
|
use app\model\CouponMain;
|
||||||
use app\model\Slide;
|
use app\model\Slide;
|
||||||
use app\repository\AccountRepository;
|
|
||||||
use app\repository\BusinessRepository;
|
|
||||||
use app\repository\CouponRepository;
|
use app\repository\CouponRepository;
|
||||||
use app\repository\OperationRepository;
|
use app\repository\OperationRepository;
|
||||||
use think\Collection;
|
use think\Collection;
|
||||||
use think\Exception;
|
|
||||||
use think\exception\ValidateException;
|
|
||||||
use think\response\Json;
|
use think\response\Json;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -34,7 +30,6 @@ class Consumer extends Base
|
||||||
$params = [
|
$params = [
|
||||||
'businessType' => $this->request->param('businessType/d', 0), // 商家类型
|
'businessType' => $this->request->param('businessType/d', 0), // 商家类型
|
||||||
'couponType' => $this->request->param('couponType/d', 0), // 优惠卷类型
|
'couponType' => $this->request->param('couponType/d', 0), // 优惠卷类型
|
||||||
'businessCode' => $this->request->param('businessCode/s'), // 商家code
|
|
||||||
'dis' => $this->request->param('dis/d', -1), // 距离,单位为km
|
'dis' => $this->request->param('dis/d', -1), // 距离,单位为km
|
||||||
'lng' => $this->request->param('lng/f', 0), // 经度 104.752890
|
'lng' => $this->request->param('lng/f', 0), // 经度 104.752890
|
||||||
'lat' => $this->request->param('lat/f', 0), // 纬度 31.465040
|
'lat' => $this->request->param('lat/f', 0), // 纬度 31.465040
|
||||||
|
@ -56,12 +51,12 @@ class Consumer extends Base
|
||||||
|
|
||||||
$whereMap[] = ['status', '=', CouponMain::status_on];
|
$whereMap[] = ['status', '=', CouponMain::status_on];
|
||||||
$whereMap[] = ['on_shelf', '=', CouponMain::on_shelf_on];
|
$whereMap[] = ['on_shelf', '=', CouponMain::on_shelf_on];
|
||||||
//$whereMap[] = ['start_time', '< TIME', $nowDate];
|
$whereMap[] = ['start_time', '> TIME', $nowDate];
|
||||||
$whereMap[] = ['end_time', '> TIME', $nowDate];
|
$whereMap[] = ['end_time', '< TIME', $nowDate];
|
||||||
$whereMap[] = ['using_count', '>', 0];
|
$whereMap[] = ['using_count', '>', 0];
|
||||||
|
|
||||||
if (!empty($params['keyword'])) {
|
if (!empty($params['keyword'])) {
|
||||||
$whereMap[] = ['name', 'like', "%".$params['keyword']."%"];
|
$whereMap[] = ['name', 'like', "%{$params['keyword']}%"];
|
||||||
}
|
}
|
||||||
if ($params['businessType'] > 0) {
|
if ($params['businessType'] > 0) {
|
||||||
$whereMap[] = ['business_type', '=', $params['businessType']];
|
$whereMap[] = ['business_type', '=', $params['businessType']];
|
||||||
|
@ -69,9 +64,6 @@ class Consumer extends Base
|
||||||
if ($params['couponType'] > 0) {
|
if ($params['couponType'] > 0) {
|
||||||
$whereMap[] = ['type', '=', $params['couponType']];
|
$whereMap[] = ['type', '=', $params['couponType']];
|
||||||
}
|
}
|
||||||
if (!empty($params['businessCode'])) {
|
|
||||||
$whereMap[] = ['business_code', '=', $params['businessCode']];
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($params['dis'] > 0) {
|
if ($params['dis'] > 0) {
|
||||||
$pointList = getEarthSquareRangePoint($params['lat'],$params['lng'], $params['dis']);
|
$pointList = getEarthSquareRangePoint($params['lat'],$params['lng'], $params['dis']);
|
||||||
|
@ -84,9 +76,7 @@ class Consumer extends Base
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$res = $repo->findCouponMainList($whereMap, [], $params['page'], $params['size'], function ($q) use($lngRange, $latRange, $params) {
|
||||||
|
|
||||||
$res = $repo->findCouponMainList($whereMap,[], $params['page'], $params['size'], function ($q) use($lngRange, $latRange, $params) {
|
|
||||||
return $q->when(!empty($lngRange) && !empty($latRange), function($query) use($lngRange, $latRange){
|
return $q->when(!empty($lngRange) && !empty($latRange), function($query) use($lngRange, $latRange){
|
||||||
$query->where(function ($queryB) use($lngRange) {
|
$query->where(function ($queryB) use($lngRange) {
|
||||||
$queryB->whereOr($lngRange);
|
$queryB->whereOr($lngRange);
|
||||||
|
@ -95,20 +85,8 @@ class Consumer extends Base
|
||||||
->field("*, abs( (IFNULL(lat,0) - {$params['lat']}) * (IFNULL(lng,0) - {$params['lng']}) ) as square");
|
->field("*, abs( (IFNULL(lat,0) - {$params['lat']}) * (IFNULL(lng,0) - {$params['lng']}) ) as square");
|
||||||
}, $sortOrder);
|
}, $sortOrder);
|
||||||
|
|
||||||
$accountRepo= AccountRepository::getInstance();
|
|
||||||
|
|
||||||
$accountId = $this->request->user['user_id'] ?? 0;
|
$res['list']->each(function ($item)use($params){
|
||||||
$flowArray = [];
|
|
||||||
if ($accountId) {
|
|
||||||
$account = $accountRepo->findById($accountId, [], function ($q) {
|
|
||||||
return $q->with(['business', 'parent']);
|
|
||||||
});
|
|
||||||
if (!empty($account)) {
|
|
||||||
$flowArray = $accountRepo->getBusinessFlowCodeArray($account->user_code);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$res['list']->each(function ($item)use($params,$flowArray){
|
|
||||||
unset($item->square);
|
unset($item->square);
|
||||||
$distance = (get_distance($params["lat"], $params["lng"], $item["lat"],$item["lng"]));
|
$distance = (get_distance($params["lat"], $params["lng"], $item["lat"],$item["lng"]));
|
||||||
if ($distance >= 1000) {
|
if ($distance >= 1000) {
|
||||||
|
@ -117,14 +95,6 @@ class Consumer extends Base
|
||||||
$item->distance_text = $distance . "m";
|
$item->distance_text = $distance . "m";
|
||||||
}
|
}
|
||||||
|
|
||||||
//是否收藏了该优惠券的商家
|
|
||||||
$item->isFlow = in_array($item->business_code,$flowArray);
|
|
||||||
|
|
||||||
$item->couponId = $item->id;
|
|
||||||
$item->businessCode = $item->business_code;
|
|
||||||
$item->businessName = $item->business_name;
|
|
||||||
$item->cover = $this->request->domain().$item->image_url;
|
|
||||||
$item->couponName = $item->name;
|
|
||||||
});
|
});
|
||||||
|
|
||||||
return $this->json(0, 'success', $res);
|
return $this->json(0, 'success', $res);
|
||||||
|
@ -157,47 +127,4 @@ class Consumer extends Base
|
||||||
}, $orders);
|
}, $orders);
|
||||||
return $this->json(1,"ok",$list["list"]);
|
return $this->json(1,"ok",$list["list"]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 关注/取消关注一个商家
|
|
||||||
* */
|
|
||||||
public function flowBusiness()
|
|
||||||
{
|
|
||||||
|
|
||||||
$accountId = $this->request->user['user_id'] ?? 0;
|
|
||||||
|
|
||||||
|
|
||||||
$accountRepo = AccountRepository::getInstance();
|
|
||||||
try {
|
|
||||||
$account = $accountRepo->findById($accountId, [], function ($q) {
|
|
||||||
return $q->with(['business', 'parent']);
|
|
||||||
});
|
|
||||||
if (empty($account)) {
|
|
||||||
throw new ValidateException('用户无效!');
|
|
||||||
}
|
|
||||||
|
|
||||||
$businessCode = input("businessCode/s");
|
|
||||||
$business = BusinessRepository::getInstance()->findOneByWhere(["code"=>$businessCode]);
|
|
||||||
if(empty($business)){
|
|
||||||
throw new ValidateException('商家无效!');
|
|
||||||
}
|
|
||||||
$businessFlow = $accountRepo->hasBusinessFlow($account->user_code,$businessCode);
|
|
||||||
|
|
||||||
//如果关注了 就删除
|
|
||||||
if($businessFlow){
|
|
||||||
$businessFlow->delete();
|
|
||||||
}else{
|
|
||||||
//没有关注就添加
|
|
||||||
$accountRepo->createBusinessFlow($account->user_code,$businessCode,$business->business_name);
|
|
||||||
}
|
|
||||||
return $this->json();
|
|
||||||
|
|
||||||
} catch (ValidateException $e) {
|
|
||||||
return $this->json(4001, $e->getError());
|
|
||||||
} catch (Exception $e) {
|
|
||||||
return $this->json(5001, '服务器繁忙!');
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
}
|
|
@ -2,12 +2,7 @@
|
||||||
namespace app\controller\api;
|
namespace app\controller\api;
|
||||||
|
|
||||||
use app\exception\RepositoryException;
|
use app\exception\RepositoryException;
|
||||||
use app\model\CouponMain;
|
|
||||||
use app\repository\AccountRepository;
|
|
||||||
use app\repository\CouponRepository;
|
use app\repository\CouponRepository;
|
||||||
use think\Exception;
|
|
||||||
use think\facade\Db;
|
|
||||||
use think\facade\Log;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 优惠卷相关
|
* 优惠卷相关
|
||||||
|
@ -69,87 +64,5 @@ class Coupon extends Base
|
||||||
} catch (RepositoryException | \Exception $e) {
|
} catch (RepositoryException | \Exception $e) {
|
||||||
return $this->json(5001, '优惠卷查询失败!');
|
return $this->json(5001, '优惠卷查询失败!');
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 领取优惠券
|
|
||||||
* */
|
|
||||||
public function receiveCoupon()
|
|
||||||
{
|
|
||||||
$accountId = $this->request->user['user_id'] ?? 0;
|
|
||||||
$lat = input("lat/f",0);
|
|
||||||
$lng = input("lng/f",0);
|
|
||||||
$account = AccountRepository::getInstance()->findById($accountId, [], function ($q) {
|
|
||||||
return $q->with(['business', 'parent']);
|
|
||||||
});
|
|
||||||
if(empty($account)){
|
|
||||||
return $this->json(6001,"无效的用户");
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($lat <= 0 || $lng <= 0) {
|
|
||||||
return $this->json(4001, "请授权定位");
|
|
||||||
}
|
|
||||||
|
|
||||||
$couponMainId = input("couponId/d", 0);
|
|
||||||
$couponMain = CouponMain::findOne(["id" => $couponMainId],[],function ($q){
|
|
||||||
//执行领取 开启锁
|
|
||||||
return $q->with("business")->lock(true);
|
|
||||||
});
|
|
||||||
|
|
||||||
//检查优惠券状态
|
|
||||||
$checkCouponMainReceiveStatus = CouponRepository::getInstance()->checkCouponMainReceiveStatus($couponMain);
|
|
||||||
if( $checkCouponMainReceiveStatus !== true ){
|
|
||||||
return $checkCouponMainReceiveStatus;
|
|
||||||
}
|
|
||||||
|
|
||||||
try {
|
|
||||||
//检查是否可以领取 0可领取 1已领取
|
|
||||||
AccountRepository::getInstance()->getCouponReceiveStatusText($account->user_code,$couponMain);//领取状态
|
|
||||||
}catch (RepositoryException $e){
|
|
||||||
return $this->json(4001,$e->getMessage());
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//检查通过 执行领取
|
|
||||||
$time = time();
|
|
||||||
Db::startTrans();
|
|
||||||
try {
|
|
||||||
//写入领取记录
|
|
||||||
$data = [
|
|
||||||
"coupon_id" =>$couponMain->id,
|
|
||||||
"name" =>$couponMain->name,
|
|
||||||
"type_id" =>$couponMain->type,
|
|
||||||
"type_name" =>$couponMain->type_name,
|
|
||||||
"business_code" =>$couponMain->business_code,
|
|
||||||
"business_name" =>$couponMain->business?$couponMain->business->business_name:'',
|
|
||||||
"consumer_code" =>$account->user_code,
|
|
||||||
"consumer_name" =>$account->nick_name,
|
|
||||||
"money" => $couponMain->money,
|
|
||||||
"content" => createUuid(),//未知作用
|
|
||||||
"received_time" => date("Y-m-d H:i:s",$time),
|
|
||||||
"lat" => $lat,
|
|
||||||
"lng" => $lng,
|
|
||||||
"end_time" => date($couponMain->end_time . " 00:00:00"),
|
|
||||||
"edition" => couponMain::COMMON_ON,//版本 未知作用
|
|
||||||
"is_verificated" => couponMain::COMMON_OFF,//版本 未知作用
|
|
||||||
];
|
|
||||||
CouponRepository::getInstance()->receiveCoupon($data);
|
|
||||||
Db::commit();
|
|
||||||
return $this->json();
|
|
||||||
}catch (RepositoryException $e){
|
|
||||||
Log::error("优惠券领取失败RepositoryException:".$e->getMessage());
|
|
||||||
Db::rollback();
|
|
||||||
return $this->json(5001,"领取失败");
|
|
||||||
}catch (Exception $e){
|
|
||||||
Log::error("优惠券领取失败:".$e->getMessage());
|
|
||||||
Db::rollback();
|
|
||||||
return $this->json(5001,"领取失败");
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -231,25 +231,8 @@ class User extends Base
|
||||||
* */
|
* */
|
||||||
public function businessFlowList()
|
public function businessFlowList()
|
||||||
{
|
{
|
||||||
return false;
|
|
||||||
$page = $this->request->param('page/d', 1);
|
$page = $this->request->param('page/d', 1);
|
||||||
$size = $this->request->param('size/d', 30);
|
$size = $this->request->param('size/d', 30);
|
||||||
|
|
||||||
$accountRepo = AccountRepository::getInstance();
|
|
||||||
try {
|
|
||||||
$account = $accountRepo->findById($accountId, [], function ($q) {
|
|
||||||
return $q->with(['business', 'parent']);
|
|
||||||
});
|
|
||||||
if (empty($account)) {
|
|
||||||
throw new ValidateException('用户无效!');
|
|
||||||
}
|
|
||||||
}catch (ValidateException $e) {
|
|
||||||
return $this->json(4001, $e->getError());
|
|
||||||
} catch (Exception $e) {
|
|
||||||
return $this->json(5001, '服务器繁忙!获取用户个人信息失败');
|
|
||||||
}
|
|
||||||
$data = AccountRepository::getInstance()->getBusinessFlowList();
|
$data = AccountRepository::getInstance()->getBusinessFlowList();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
|
@ -5,7 +5,6 @@ namespace app\model;
|
||||||
//用户关注的商家
|
//用户关注的商家
|
||||||
class BusinessFlow extends Base
|
class BusinessFlow extends Base
|
||||||
{
|
{
|
||||||
|
|
||||||
public function account()
|
public function account()
|
||||||
{
|
{
|
||||||
return $this->hasOne(Account::class,"user_code","user_code");
|
return $this->hasOne(Account::class,"user_code","user_code");
|
||||||
|
|
|
@ -9,7 +9,6 @@ use app\model\Deduction;
|
||||||
use app\model\Recharge;
|
use app\model\Recharge;
|
||||||
use app\service\Repository;
|
use app\service\Repository;
|
||||||
use app\traits\CouponBillTrait;
|
use app\traits\CouponBillTrait;
|
||||||
use app\traits\CouponMainTrait;
|
|
||||||
use think\Collection;
|
use think\Collection;
|
||||||
use think\Model;
|
use think\Model;
|
||||||
|
|
||||||
|
@ -23,7 +22,6 @@ use think\Model;
|
||||||
class BusinessRepository extends Repository
|
class BusinessRepository extends Repository
|
||||||
{
|
{
|
||||||
use CouponBillTrait;
|
use CouponBillTrait;
|
||||||
use CouponMainTrait;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 根据条件查询列表
|
* 根据条件查询列表
|
||||||
|
|
|
@ -8,7 +8,6 @@ use app\model\CouponMain;
|
||||||
use app\model\CouponType;
|
use app\model\CouponType;
|
||||||
use app\model\UsingRule;
|
use app\model\UsingRule;
|
||||||
use app\service\Repository;
|
use app\service\Repository;
|
||||||
use app\traits\CouponMainTrait;
|
|
||||||
use Exception;
|
use Exception;
|
||||||
use think\Collection;
|
use think\Collection;
|
||||||
use think\Db;
|
use think\Db;
|
||||||
|
@ -24,7 +23,6 @@ use think\Model;
|
||||||
*/
|
*/
|
||||||
class CouponRepository extends Repository
|
class CouponRepository extends Repository
|
||||||
{
|
{
|
||||||
use CouponMainTrait;
|
|
||||||
/**
|
/**
|
||||||
* 优惠券持有信息列表
|
* 优惠券持有信息列表
|
||||||
*
|
*
|
||||||
|
@ -100,18 +98,4 @@ class CouponRepository extends Repository
|
||||||
return CouponMain::findList($where, $fields, $page, $size, $call, $sortOrder);
|
return CouponMain::findList($where, $fields, $page, $size, $call, $sortOrder);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* 写入一个领取优惠券
|
|
||||||
* @param array $data
|
|
||||||
* @return Coupon|Model
|
|
||||||
*/
|
|
||||||
public function receiveCoupon(array $data)
|
|
||||||
{
|
|
||||||
return Coupon::create($data);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
|
@ -6,7 +6,6 @@ use app\model\Area;
|
||||||
use app\model\BusinessCircle;
|
use app\model\BusinessCircle;
|
||||||
use app\model\Category;
|
use app\model\Category;
|
||||||
use app\model\Model;
|
use app\model\Model;
|
||||||
use app\model\UsingRule;
|
|
||||||
use app\service\Repository;
|
use app\service\Repository;
|
||||||
use think\Collection;
|
use think\Collection;
|
||||||
|
|
||||||
|
@ -75,11 +74,6 @@ class DictionaryRepository extends Repository
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取商家分类数据
|
* 获取商家分类数据
|
||||||
* @param array $where
|
|
||||||
* @param array $fields
|
|
||||||
* @param callable|null $call
|
|
||||||
* @param array $order
|
|
||||||
* @return mixed|Collection
|
|
||||||
*/
|
*/
|
||||||
public function getBusinessTypeList(array $where=[], array $fields = [], callable $call=null, array $order = [])
|
public function getBusinessTypeList(array $where=[], array $fields = [], callable $call=null, array $order = [])
|
||||||
{
|
{
|
||||||
|
@ -137,9 +131,6 @@ class DictionaryRepository extends Repository
|
||||||
/**
|
/**
|
||||||
* 解析地址编码
|
* 解析地址编码
|
||||||
* [province, city, county]
|
* [province, city, county]
|
||||||
* @param array $list
|
|
||||||
* @param array $areaList
|
|
||||||
* @return array
|
|
||||||
*/
|
*/
|
||||||
public function parseAreaText(array $list, array $areaList = []): array
|
public function parseAreaText(array $list, array $areaList = []): array
|
||||||
{
|
{
|
||||||
|
@ -158,23 +149,4 @@ class DictionaryRepository extends Repository
|
||||||
return $list;
|
return $list;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* 获取一个优惠券的使用规则
|
|
||||||
* @param int $couponMainId
|
|
||||||
* @return string
|
|
||||||
* @throws \think\db\exception\DataNotFoundException
|
|
||||||
* @throws \think\db\exception\DbException
|
|
||||||
* @throws \think\db\exception\ModelNotFoundException
|
|
||||||
*/
|
|
||||||
public function getUsingRuleByCouponMainId(int $couponMainId)
|
|
||||||
{
|
|
||||||
$usingRule =UsingRule::where("coupon_id",$couponMainId)->find();
|
|
||||||
if(empty($usingRule)){
|
|
||||||
return '';
|
|
||||||
}
|
|
||||||
return "<div class='disPaperList'><div class='circleOrange'>●</div>该优惠券可以在" . encodeCouponCycle($usingRule->cycle) . "进行使用</div>
|
|
||||||
<div class='disPaperList'><div class='circleOrange'>●</div>该优惠券可以在每天的" . $usingRule->day_start_time ."到" .$usingRule->day_end_time ."进行使用</div>
|
|
||||||
<div class='disPaperList'><div class='circleOrange'>●</div>该优惠券每天每人可以领取". $usingRule->person_day_total ."张</div>
|
|
||||||
<div class='disPaperList'><div class='circleOrange'>●</div>该优惠券每人总共可以领取". $usingRule->person_total ."张</div>";
|
|
||||||
}
|
|
||||||
}
|
}
|
|
@ -1,40 +0,0 @@
|
||||||
<?php
|
|
||||||
|
|
||||||
namespace app\traits;
|
|
||||||
|
|
||||||
use app\model\CouponMain;
|
|
||||||
use app\model\UsingRule;
|
|
||||||
use app\model\Coupon;
|
|
||||||
|
|
||||||
trait CouponMainTrait
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* 检查优惠券状态是否可以领取
|
|
||||||
* @param CouponMain $couponMain
|
|
||||||
* @return bool
|
|
||||||
*/
|
|
||||||
public function checkCouponMainReceiveStatus(CouponMain $couponMain){
|
|
||||||
if (empty($couponMain)) {
|
|
||||||
return $this->json(4001, "优惠券不存在");
|
|
||||||
}
|
|
||||||
if ($couponMain->status != CouponMain::status_on) {
|
|
||||||
return $this->json(4002, "优惠券已停用");
|
|
||||||
}
|
|
||||||
if ($couponMain->on_shelf != CouponMain::on_shelf_on) {
|
|
||||||
return $this->json(4003, "优惠券已下架");
|
|
||||||
}
|
|
||||||
$time = time();
|
|
||||||
if (strtotime($couponMain->start_time) > $time) {
|
|
||||||
return $this->json(4004, "优惠券还未发行");
|
|
||||||
}
|
|
||||||
|
|
||||||
if (strtotime($couponMain->end_time) < $time) {
|
|
||||||
return $this->json(4004, "优惠券已结束使用");
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($couponMain->using_count <= 0) {
|
|
||||||
return $this->json(4004, "优惠券已经被领完了");
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -2,9 +2,6 @@
|
||||||
|
|
||||||
namespace app\traits;
|
namespace app\traits;
|
||||||
|
|
||||||
use app\exception\RepositoryException;
|
|
||||||
use app\model\CouponMain;
|
|
||||||
use app\model\UsingRule;
|
|
||||||
use think\Model;
|
use think\Model;
|
||||||
use app\model\Coupon;
|
use app\model\Coupon;
|
||||||
|
|
||||||
|
@ -24,6 +21,8 @@ trait CouponTrait
|
||||||
|
|
||||||
/**消费者已使用优惠券总数
|
/**消费者已使用优惠券总数
|
||||||
* @param string $userCode
|
* @param string $userCode
|
||||||
|
*
|
||||||
|
*
|
||||||
* @return int
|
* @return int
|
||||||
*/
|
*/
|
||||||
public function consumerUsedTotalCoupon($userCode)
|
public function consumerUsedTotalCoupon($userCode)
|
||||||
|
@ -31,9 +30,10 @@ trait CouponTrait
|
||||||
return Coupon::where("consumer_code", $userCode)->where("is_verificated", Coupon::is_verificated_on)->count("id");
|
return Coupon::where("consumer_code", $userCode)->where("is_verificated", Coupon::is_verificated_on)->count("id");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**消费者已使用优惠券总数
|
||||||
* 消费者已使用优惠券总数
|
|
||||||
* @param string $userCode
|
* @param string $userCode
|
||||||
|
*
|
||||||
|
*
|
||||||
* @return int
|
* @return int
|
||||||
*/
|
*/
|
||||||
public function consumerNotUsedTotalCoupon($userCode)
|
public function consumerNotUsedTotalCoupon($userCode)
|
||||||
|
@ -41,9 +41,10 @@ trait CouponTrait
|
||||||
return Coupon::where("consumer_code", $userCode)->where("is_verificated", Coupon::is_verificated_off)->count("id");
|
return Coupon::where("consumer_code", $userCode)->where("is_verificated", Coupon::is_verificated_off)->count("id");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**消费者已使用优惠券总数
|
||||||
* 消费者已使用优惠券总数
|
|
||||||
* @param string $userCode
|
* @param string $userCode
|
||||||
|
*
|
||||||
|
*
|
||||||
* @return array
|
* @return array
|
||||||
* @throws \Exception
|
* @throws \Exception
|
||||||
*/
|
*/
|
||||||
|
@ -54,112 +55,5 @@ trait CouponTrait
|
||||||
}, ["id" => "desc"]);
|
}, ["id" => "desc"]);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* 查看某个优惠券的是否可以领取 0 可以领取 1 已领取不能再领取
|
|
||||||
* @param $accountCode
|
|
||||||
* @param CouponMain $couponMain
|
|
||||||
* @return int
|
|
||||||
* @throws \think\db\exception\DataNotFoundException
|
|
||||||
* @throws \think\db\exception\DbException
|
|
||||||
* @throws \think\db\exception\ModelNotFoundException
|
|
||||||
*/
|
|
||||||
public function getCouponReceiveStatus($accountCode,CouponMain $couponMain )
|
|
||||||
{
|
|
||||||
//没有领取记录就可以领取
|
|
||||||
$ReceiveCount = Coupon::where("coupon_id",$couponMain->id)
|
|
||||||
->where("consumer_code",$accountCode)
|
|
||||||
->count();
|
|
||||||
if($ReceiveCount <= 0){
|
|
||||||
return CouponMain::COMMON_OFF;
|
|
||||||
}
|
|
||||||
|
|
||||||
//确定使用规则
|
|
||||||
$usingRule =UsingRule::where("coupon_id",$couponMain->id)->find();
|
|
||||||
if(empty($usingRule)){
|
|
||||||
return CouponMain::COMMON_OFF;
|
|
||||||
}
|
|
||||||
|
|
||||||
//单人日限量
|
|
||||||
$todayReceivesCount = Coupon::where("coupon_id",$couponMain->id)
|
|
||||||
->where("consumer_code",$accountCode)
|
|
||||||
->whereTime("received_time","between",[date("Y-m-d 00:00:00"),date("Y-m-d 23:59:59")])
|
|
||||||
->count();
|
|
||||||
|
|
||||||
if($todayReceivesCount >= $usingRule->person_day_total ){
|
|
||||||
|
|
||||||
return CouponMain::COMMON_ON;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//单人总限量
|
|
||||||
if($ReceiveCount >= $usingRule->person_total ){
|
|
||||||
return CouponMain::COMMON_ON;
|
|
||||||
}
|
|
||||||
|
|
||||||
return CouponMain::COMMON_OFF;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 查看某个优惠券的是否可以领取 0 可以领取 1 已领取不能再领取
|
|
||||||
* @param $accountCode
|
|
||||||
* @param CouponMain $couponMain
|
|
||||||
* @return void
|
|
||||||
* @throws RepositoryException
|
|
||||||
* @throws \think\db\exception\DataNotFoundException
|
|
||||||
* @throws \think\db\exception\DbException
|
|
||||||
* @throws \think\db\exception\ModelNotFoundException
|
|
||||||
*/
|
|
||||||
public function getCouponReceiveStatusText($accountCode,CouponMain $couponMain )
|
|
||||||
{
|
|
||||||
//没有领取记录就可以领取
|
|
||||||
$ReceiveCount = Coupon::where("coupon_id",$couponMain->id)
|
|
||||||
->where("consumer_code",$accountCode)->count();
|
|
||||||
|
|
||||||
|
|
||||||
//确定使用规则
|
|
||||||
$usingRule =UsingRule::where("coupon_id",$couponMain->id)->find();
|
|
||||||
if(empty($usingRule)){
|
|
||||||
throw new RepositoryException("使用规则错误,不能领取");
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//一天的总限量
|
|
||||||
$dayTotalReceivesCount = Coupon::where("coupon_id",$couponMain->id)
|
|
||||||
->whereTime("received_time","between",[date("Y-m-d 00:00:00"),date("Y-m-d 23:59:59")])
|
|
||||||
->count();
|
|
||||||
if($dayTotalReceivesCount >= $usingRule->day_total){
|
|
||||||
throw new RepositoryException("单日领取总限量达到上限");
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//单人日限量
|
|
||||||
$todayReceivesCount = Coupon::where("coupon_id",$couponMain->id)
|
|
||||||
->where("consumer_code",$accountCode)
|
|
||||||
->whereTime("received_time","between",[date("Y-m-d 00:00:00"),date("Y-m-d 23:59:59")])
|
|
||||||
->count();
|
|
||||||
if($todayReceivesCount >= $usingRule->person_day_total ){
|
|
||||||
throw new RepositoryException("单人日限量达到上限");
|
|
||||||
}
|
|
||||||
|
|
||||||
//单人总限量
|
|
||||||
if($ReceiveCount >= $usingRule->person_total ){
|
|
||||||
throw new RepositoryException("单人总限量达到上限");
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
$time = time();
|
|
||||||
//一天的开始时间
|
|
||||||
if(strtotime(date("Y-m-d " . $usingRule->day_start_time)) > $time){
|
|
||||||
throw new RepositoryException("请在当天{$usingRule->day_start_time}后来领取");
|
|
||||||
}
|
|
||||||
//一天的结束时间
|
|
||||||
if(strtotime(date("Y-m-d ".$usingRule->day_end_time)) < $time){
|
|
||||||
throw new RepositoryException("请在当天{$usingRule->day_start_time}前领取");
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
}
|
|
@ -29,49 +29,4 @@ trait BusinessFlowTrait
|
||||||
->page($page,$size)
|
->page($page,$size)
|
||||||
->select();
|
->select();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
/**
|
|
||||||
* 获取关注的商家的code
|
|
||||||
* @param $accountCode
|
|
||||||
* @return array
|
|
||||||
*/
|
|
||||||
public function getBusinessFlowCodeArray($accountCode)
|
|
||||||
{
|
|
||||||
return BusinessFlow::where("user_code",$accountCode)
|
|
||||||
->column("business_code");
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 获取关注的商家的code
|
|
||||||
* @param $accountCode
|
|
||||||
* @param $businessCode
|
|
||||||
* @return BusinessFlow|array|\think\Model|null
|
|
||||||
* @throws \think\db\exception\DataNotFoundException
|
|
||||||
* @throws \think\db\exception\DbException
|
|
||||||
* @throws \think\db\exception\ModelNotFoundException
|
|
||||||
*/
|
|
||||||
public function hasBusinessFlow($accountCode,$businessCode)
|
|
||||||
{
|
|
||||||
return BusinessFlow::where("user_code",$accountCode)
|
|
||||||
->where("business_code",$businessCode)
|
|
||||||
->find();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 关注一个商家
|
|
||||||
* @param $accountCode
|
|
||||||
* @param $businessCode
|
|
||||||
* @param $businessName
|
|
||||||
* @return BusinessFlow|\think\Model
|
|
||||||
*/
|
|
||||||
public function createBusinessFlow($accountCode,$businessCode,$businessName)
|
|
||||||
{
|
|
||||||
return BusinessFlow::create([
|
|
||||||
"user_code"=>$accountCode,
|
|
||||||
"business_code"=>$businessCode,
|
|
||||||
"business_name"=>$businessName,
|
|
||||||
"create_time"=>date("Y-m-d H:i:s")
|
|
||||||
]);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -10,12 +10,11 @@
|
||||||
// +----------------------------------------------------------------------
|
// +----------------------------------------------------------------------
|
||||||
use think\facade\Route;
|
use think\facade\Route;
|
||||||
|
|
||||||
//Route::rule('account/loginByCode', "\\app\\controller\\api\\user@login");//用户登录
|
Route::rule('account/loginByCode', "\\app\\controller\\api\\user@login");//用户登录
|
||||||
//Route::rule('consumer/home', "\\app\\controller\\api\\consumer@home");//首页列表(优惠券列表)
|
Route::rule('consumer/home', "\\app\\controller\\api\\Consumer@home");//首页列表(优惠券列表)
|
||||||
//Route::rule('consumer/bannerList', "\\app\\controller\\api\\consumer@bannerList");//首页列表(优惠券列表)
|
Route::rule('consumer/bannerList', "\\app\\controller\\api\\Consumer@bannerList");//首页列表(优惠券列表)
|
||||||
//Route::rule('dic/getDisList', "\\app\\controller\\api\\dictionary@getDisList");//距离选项列表
|
Route::rule('dic/getDisList', "\\app\\controller\\api\\dictionary@getDisList");//距离选项列表
|
||||||
//Route::rule('dic/getBusinessTypeListByPid', "\\app\\controller\\api\\dictionary@getBusinessTypeList");//首页获取商家类型
|
Route::rule('dic/getBusinessTypeListByPid', "\\app\\controller\\api\\dictionary@getBusinessTypeList");//首页获取商家类型
|
||||||
//Route::rule('dic/getCouponTypeList', "\\app\\controller\\api\\dictionary@getCouponTypeList");//首页获取优惠券类型
|
Route::rule('dic/getCouponTypeList', "\\app\\controller\\api\\dictionary@getCouponTypeList");//首页获取优惠券类型
|
||||||
//Route::rule('dic/getBusinessTypeList', "\\app\\controller\\api\\business@getBusinessTypeList");//首页获取商家类型
|
Route::rule('dic/getBusinessTypeList', "\\app\\controller\\api\\business@getBusinessTypeList");//首页获取商家类型
|
||||||
//Route::rule('dic/getBusinessCircle', "\\app\\controller\\api\\business@getBusinessCircle");//首页获取商家商圈
|
Route::rule('dic/getBusinessCircle', "\\app\\controller\\api\\business@getBusinessCircle");//首页获取商家商圈
|
||||||
//Route::rule('consumer/flowBusiness', "\\app\\controller\\api\\consumer@flowBusiness");//首页获取商家商圈
|
|
||||||
|
|
|
@ -121,13 +121,13 @@
|
||||||
<div class="layui-inline">
|
<div class="layui-inline">
|
||||||
<label class="layui-form-label">开始时间</label>
|
<label class="layui-form-label">开始时间</label>
|
||||||
<div class="layui-inline">
|
<div class="layui-inline">
|
||||||
<input type="text" name="using_rule[day_start_time]" class="layui-input" value="00:00:00" id="using_rule_day_start_time" placeholder="HH:mm:ss">
|
<input type="text" name="using_rule[day_start_time]" class="layui-input" id="using_rule_day_start_time" placeholder="HH:mm:ss">
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="layui-inline">
|
<div class="layui-inline">
|
||||||
<label class="layui-form-label">结束</label>
|
<label class="layui-form-label">结束</label>
|
||||||
<div class="layui-inline">
|
<div class="layui-inline">
|
||||||
<input type="text" name="using_rule[day_end_time]" class="layui-input" value="23:59:59" id="using_rule_day_end_time" placeholder="HH:mm:ss">
|
<input type="text" name="using_rule[day_end_time]" class="layui-input" id="using_rule_day_end_time" placeholder="HH:mm:ss">
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -176,8 +176,8 @@
|
||||||
<div class="layui-form-item">
|
<div class="layui-form-item">
|
||||||
<label class="layui-form-label">内容</label>
|
<label class="layui-form-label">内容</label>
|
||||||
<div class="layui-input-block editor-text">
|
<div class="layui-input-block editor-text">
|
||||||
<!-- <div class="editor"></div>-->
|
<div class="editor"></div>
|
||||||
<textarea name="item[intro]" id="ueditor" class="layui-textarea"></textarea>
|
<textarea name="item[intro]" id="ueditor" class="layui-textarea layui-hide"></textarea>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
|
@ -178,8 +178,8 @@
|
||||||
<div class="layui-form-item">
|
<div class="layui-form-item">
|
||||||
<label class="layui-form-label">内容</label>
|
<label class="layui-form-label">内容</label>
|
||||||
<div class="layui-input-block editor-text">
|
<div class="layui-input-block editor-text">
|
||||||
<!-- <div class="editor"></div>-->
|
<div class="editor"></div>
|
||||||
<textarea name="item[intro]" id="ueditor" class="layui-textarea">{$item["intro"]}</textarea>
|
<textarea name="item[intro]" id="ueditor" class="layui-textarea layui-hide">{$item["intro"]|raw}</textarea>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
@ -234,21 +234,4 @@
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<script src="__MANAGER__/js/coupon/index.js?v={:mt_rand()}"></script>
|
<script src="__MANAGER__/js/coupon/index.js?v={:mt_rand()}"></script>
|
||||||
|
|
||||||
<script>
|
|
||||||
layui.use(['laydate'], function () {
|
|
||||||
laydate = layui.laydate;
|
|
||||||
//日期时间选择器
|
|
||||||
laydate.render({
|
|
||||||
elem: '#using_rule_day_start_time'
|
|
||||||
,type: 'time'
|
|
||||||
});
|
|
||||||
|
|
||||||
//日期时间选择器
|
|
||||||
laydate.render({
|
|
||||||
elem: '#using_rule_day_end_time'
|
|
||||||
,type: 'time'
|
|
||||||
});
|
|
||||||
})
|
|
||||||
</script>
|
|
Loading…
Reference in New Issue