StoreBargainUserHelp.php 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219
  1. <?php
  2. namespace app\models\store;
  3. use app\models\user\User;
  4. use crmeb\basic\BaseModel;
  5. use crmeb\traits\ModelTrait;
  6. use think\db\exception\DataNotFoundException;
  7. use think\db\exception\DbException;
  8. use think\db\exception\ModelNotFoundException;
  9. /**
  10. * TODO 砍价帮砍Model
  11. * Class StoreBargainUserHelp
  12. * @package app\models\store
  13. */
  14. class StoreBargainUserHelp extends BaseModel
  15. {
  16. /**
  17. * 数据表主键
  18. * @var string
  19. */
  20. protected $pk = 'id';
  21. /**
  22. * 模型名称
  23. * @var string
  24. */
  25. protected $name = 'store_bargain_user_help';
  26. use ModelTrait;
  27. /**
  28. * TODO 获取砍价帮
  29. * @param $bargainUserTableId
  30. * @param int $page
  31. * @param int $limit
  32. * @return array
  33. * @throws \think\Exception
  34. * @throws DataNotFoundException
  35. * @throws ModelNotFoundException
  36. * @throws \think\exception\DbException
  37. */
  38. public static function getList($bargainUserTableId, $page = 1, $limit = 15)
  39. {
  40. if (!$bargainUserTableId) return [];
  41. if ($page) $list = self::where('bargain_user_id', $bargainUserTableId)->order('add_time desc')->page($page, $limit)->column("uid,price,from_unixtime(add_time,'%Y-%m-%d %H:%i:%s') as add_time", 'id');
  42. else $list = self::where('bargain_user_id', $bargainUserTableId)->order('add_time desc')->column("uid,price,from_unixtime(add_time,'%Y-%m-%d %H:%i:%s') as add_time", 'id');
  43. if ($list) {
  44. foreach ($list as $key => &$value) {
  45. $userInfo = User::getUserInfo($value['uid'], 'nickname,avatar');
  46. if ($userInfo) {
  47. $value['nickname'] = $userInfo['nickname'];
  48. $value['avatar'] = $userInfo['avatar'];
  49. } else {
  50. $value['nickname'] = '此用户已失效';
  51. $value['avatar'] = '';
  52. }
  53. unset($value['uid']);
  54. unset($value['id']);
  55. }
  56. }
  57. return array_values($list);
  58. }
  59. /**
  60. * TODO 帮忙砍价
  61. * @param int $bargainId
  62. * @param int $bargainUserUid
  63. * @param int $uid
  64. * @return bool
  65. * @throws \think\Exception
  66. * @throws DataNotFoundException
  67. * @throws ModelNotFoundException
  68. * @throws \think\exception\DbException
  69. */
  70. public static function setBargainUserHelp($bargainId = 0, $bargainUserUid = 0, $uid = 0)
  71. {
  72. if(!$bargainId || !$bargainUserUid || !$uid || !StoreBargain::validBargain($bargainId) || !StoreBargainUser::be(['bargain_id'=>$bargainId,'uid'=>$bargainUserUid,'status'=>1,'is_del'=>0])) return false;
  73. $bargainUserTableId = StoreBargainUser::getBargainUserTableId($bargainId,$bargainUserUid);//TODO 获取 用户参与砍价表编号
  74. $priceSection = StoreBargain::getBargainMaxMinPrice($bargainId); //TODO 获取随机砍掉的价格区间
  75. $coverPrice = StoreBargainUser::getBargainUserDiffPriceFloat($bargainUserTableId);//TODO 用户可以砍掉的金额 好友砍价之前获取可以砍价金额
  76. $alreadyPrice= StoreBargainUser::getBargainUserPrice($bargainUserTableId);//TODO 用户已经砍掉的价格
  77. $surplusPrice = (float)bcsub($coverPrice,$alreadyPrice,2);//TODO 用户剩余要砍掉的价格
  78. if(0.00 === (float)bcsub($surplusPrice,0,2)) return false;
  79. $data['uid'] = $uid;
  80. $data['bargain_id'] = $bargainId;
  81. $data['bargain_user_id'] = $bargainUserTableId;
  82. $data['price'] = self::randomFloat($priceSection['bargain_min_price'],$priceSection['bargain_max_price']);
  83. $data['add_time'] = time();
  84. if(0.00 === (float)$data['price']) $data['price'] = self::randomFloat($priceSection['bargain_min_price'],$priceSection['bargain_max_price']);
  85. if($data['price'] > $surplusPrice) $data['price'] = $surplusPrice;
  86. $price = bcadd($alreadyPrice,$data['price'],2);
  87. $bargainUserData['price'] = $price;
  88. self::beginTrans();
  89. $res1 = StoreBargainUser::setBargainUserPrice($bargainUserTableId,$bargainUserData);
  90. $res2 = self::create($data);
  91. $res = $res1 && $res2;
  92. self::checkTrans($res);
  93. return $res;
  94. }
  95. /**
  96. * TODO 获取俩个数之间的随机数
  97. * @param int $min $min 最小数
  98. * @param int $max $max 最大数
  99. * @return string
  100. */
  101. public static function randomFloat($min = 0, $max = 1)
  102. {
  103. $num = $min + mt_rand() / mt_getrandmax() * ($max - $min);
  104. return sprintf("%.2f", $num);
  105. }
  106. /**
  107. * TODO 判断用户是否还可以砍价
  108. * @param int $bargainId $bargainId 砍价商品编号
  109. * @param int $bargainUserUid $bargainUserUid 开启砍价用户编号
  110. * @param int $bargainUserHelpUid $bargainUserUid 当前用户编号
  111. * @return bool
  112. */
  113. public static function isBargainUserHelpCount($bargainId = 0, $bargainUserUid = 0, $bargainUserHelpUid = 0)
  114. {
  115. $bargainUserTableId = StoreBargainUser::getBargainUserTableId($bargainId,$bargainUserUid);
  116. $bargainNum = StoreBargain::getBargainNum($bargainId);//TODO 获取每个人可以砍价几次
  117. $count = self::where('bargain_id',$bargainId)->where('bargain_user_id',$bargainUserTableId)->where('uid',$bargainUserHelpUid)->count();//TODO 获取当前用户砍价了几次
  118. if($count < $bargainNum) return true;
  119. else return false;
  120. }
  121. /**
  122. * TODO 获取砍价帮总人数
  123. * @param int $bargainId $bargainId 砍价商品编号
  124. * @param int $bargainUserUid $bargainUserUid 开启砍价用户编号
  125. * @return int|string
  126. * @throws \think\Exception
  127. */
  128. public static function getBargainUserHelpPeopleCount($bargainId = 0, $bargainUserUid = 0)
  129. {
  130. if (!$bargainId || !$bargainUserUid) return 0;
  131. $bargainUserTableId = StoreBargainUser::getBargainUserTableId($bargainId, $bargainUserUid);//TODO 获取用户参与砍价表编号
  132. if ($bargainUserTableId) return self::where('bargain_user_id', $bargainUserTableId)->where('bargain_id', $bargainId)->count();
  133. else return 0;
  134. }
  135. /**
  136. * TODO 获取用户还剩余的砍价金额
  137. * @param int $bargainId $bargainId 砍价商品编号
  138. * @param int $bargainUserUid $bargainUserUid 开启砍价用户编号
  139. * @return float
  140. * @throws DataNotFoundException
  141. * @throws ModelNotFoundException
  142. * @throws DbException
  143. */
  144. public static function getSurplusPrice($bargainId = 0, $bargainUserUid = 0)
  145. {
  146. $bargainUserTableId = StoreBargainUser::getBargainUserTableId($bargainId, $bargainUserUid);// TODO 获取用户参与砍价表编号
  147. $coverPrice = StoreBargainUser::getBargainUserDiffPriceFloat($bargainUserTableId);//TODO 获取用户可以砍掉的金额 好友砍价之后获取砍价金额
  148. $alreadyPrice = StoreBargainUser::getBargainUserPrice($bargainUserTableId);//TODO 用户已经砍掉的价格 好友砍价之后获取用户已经砍掉的价格
  149. $surplusPrice = (float)bcsub($coverPrice, $alreadyPrice, 2);//TODO 用户剩余要砍掉的价格
  150. return $surplusPrice;
  151. }
  152. /**
  153. * TODO 获取砍价进度条
  154. * @param int $bargainId $bargainId 砍价商品编号
  155. * @param int $bargainUserUid $bargainUserUid 开启砍价用户编号
  156. * @return int|string
  157. * @throws DataNotFoundException
  158. * @throws ModelNotFoundException
  159. * @throws \think\exception\DbException
  160. */
  161. public static function getSurplusPricePercent($bargainId = 0, $bargainUserUid = 0)
  162. {
  163. $bargainUserTableId = StoreBargainUser::getBargainUserTableId($bargainId, $bargainUserUid); // TODO 获取用户参与砍价表编号 计算进度条
  164. $coverPrice = StoreBargainUser::getBargainUserDiffPriceFloat($bargainUserTableId);//TODO 用户可以砍掉的金额 计算进度条
  165. $alreadyPrice = StoreBargainUser::getBargainUserPrice($bargainUserTableId);//TODO 用户已经砍掉的价格 计算进度条
  166. if ($alreadyPrice) return (int)bcmul(bcdiv($alreadyPrice, $coverPrice, 2), 100, 0);
  167. else return 100;
  168. }
  169. /**
  170. * TODO 获取用户砍掉的金额
  171. * @param int $bargainId $bargainId 砍价商品编号
  172. * @param int $bargainUserTableId $bargainUserTableId 用户参与砍价表编号
  173. * @param int $uid $uid 帮忙砍价人编号
  174. * @param string $field
  175. * @return bool|mixed
  176. */
  177. public static function getBargainUserBargainPrice($bargainId = 0, $bargainUserTableId = 0, $uid = 0, $field = 'price')
  178. {
  179. if (!$bargainId || !$bargainUserTableId || !$uid) return false;
  180. return self::where('uid', $uid)->where('bargain_id', $bargainId)->where('bargain_user_id', $bargainUserTableId)->value($field);
  181. }
  182. /**
  183. * TODO 获取用的昵称和头像
  184. * @param int $uid
  185. * @return array
  186. */
  187. public static function getBargainUserHelpUserInfo($uid = 0)
  188. {
  189. if (!$uid) return [];
  190. $userInfo = User::where('uid', $uid)->column('nickname,avatar', 'uid');
  191. return $userInfo;
  192. }
  193. /**
  194. * 获取帮忙砍价人数
  195. * @param int $bargainId
  196. * @return int|string
  197. */
  198. public static function getCountPeopleHelp($bargainId = 0)
  199. {
  200. if (!$bargainId) return 0;
  201. return self::where('bargain_id', $bargainId)->count();
  202. }
  203. }