UserPledge.php 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. <?php
  2. namespace app\common\model;
  3. use fast\Asset;
  4. use fast\Http;
  5. use fast\Random;
  6. use think\Cache;
  7. use think\Log;
  8. use think\Model;
  9. use think\Request;
  10. class UserPledge extends Model
  11. {
  12. protected $name = "user_pledge";
  13. // 自动写入时间戳字段
  14. protected $autoWriteTimestamp = 'int';
  15. // 定义时间戳字段名
  16. protected $createTime = 'create_time';
  17. protected $updateTime = 'update_time';
  18. protected $deleteTime = false;
  19. // 追加属性
  20. protected $append = [
  21. 'create_time_text',
  22. 'update_time_text'
  23. ];
  24. //状态:1存储中 2解除 0关闭
  25. const Close = 0;
  26. const Ongoing= 1;
  27. const Remove = 2;
  28. //添加存储
  29. public static function setPledgeData($user_id, $pledge_id, $product_id, $product,$day_num, $num)
  30. {
  31. return self::create([
  32. 'user_id' => $user_id,
  33. 'pledge_id' => $pledge_id,
  34. 'product_id' => $product_id,
  35. 'details' => json_encode($product, JSON_UNESCAPED_UNICODE),
  36. 'day_num' => $day_num,
  37. 'end_time' => time() + config('pledge_end_time'), //结束时间
  38. 'num' => $num
  39. ]);
  40. }
  41. //所有有效质押订单的日产量X数量的和
  42. public static function getCountByTimeTeac():int
  43. {
  44. $list = self::alias('a')
  45. ->join('product_pledge b','a.pledge_id = b.id','left')
  46. ->where('a.status', self::Ongoing)
  47. ->field('b.day_num,a.num')
  48. ->select();
  49. $count = 0;
  50. foreach ($list as $item) {
  51. $count += bcmul($item['day_num'], $item['num'], 2);
  52. }
  53. return $count;
  54. }
  55. //获取用户组合存储数量
  56. public static function getPledgeCount(int $user_id): int
  57. {
  58. return self::alias('a')->where('a.user_id', $user_id)
  59. ->join('product_pledge b','a.pledge_id = b.id','left')
  60. ->where('a.status', self::Ongoing)->where('b.type_id', ProductPopular::TypeGroup)->sum('num');
  61. }
  62. //用户
  63. public function users()
  64. {
  65. return $this->hasOne('UserModel', 'id', 'user_id', [], 'LEFT')->setEagerlyType(0);
  66. }
  67. //低质押
  68. public function pledges()
  69. {
  70. return $this->hasOne('ProductPledges', 'id', 'pledge_id', [], 'LEFT')->setEagerlyType(0);
  71. }
  72. public function getCreateTimeTextAttr($value, $data)
  73. {
  74. $value = $value ? $value : (isset($data['create_time']) ? $data['create_time'] : '');
  75. return is_numeric($value) ? date("Y-m-d H:i:s", $value) : $value;
  76. }
  77. public function getUpdateTimeTextAttr($value, $data)
  78. {
  79. $value = $value ? $value : (isset($data['update_time']) ? $data['update_time'] : '');
  80. return is_numeric($value) ? date("Y-m-d H:i:s", $value) : $value;
  81. }
  82. protected function setCreateTimeAttr($value)
  83. {
  84. return $value === '' ? null : ($value && !is_numeric($value) ? strtotime($value) : $value);
  85. }
  86. protected function setUpdateTimeAttr($value)
  87. {
  88. return $value === '' ? null : ($value && !is_numeric($value) ? strtotime($value) : $value);
  89. }
  90. }