StoreBargainUserHelp.php 9.0 KB

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