PostModel.php 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | LARAVEL8.0 框架 [ LARAVEL ][ RXThinkCMF ]
  4. // +----------------------------------------------------------------------
  5. // | 版权所有 2017~2021 LARAVEL研发中心
  6. // +----------------------------------------------------------------------
  7. // | 官方网站: http://www.laravel.cn
  8. // +----------------------------------------------------------------------
  9. // | Author: laravel开发员 <laravel.qq.com>
  10. // +----------------------------------------------------------------------
  11. namespace App\Models;
  12. /**
  13. * 笔记动态-模型
  14. * @author laravel开发员
  15. * @since 2020/11/11
  16. * @package App\Models
  17. */
  18. class PostModel extends BaseModel
  19. {
  20. // 设置数据表
  21. protected $table = 'posts';
  22. protected $appends = ['time_text'];
  23. public function getTimeTextAttribute()
  24. {
  25. return $this->create_time? datetime($this->create_time) : '';
  26. }
  27. /**
  28. * 发布用户
  29. * @return \Illuminate\Database\Eloquent\Relations\HasOne
  30. */
  31. public function user()
  32. {
  33. return $this->hasOne(MemberModel::class, 'id', 'user_id')
  34. ->select(['id','openid', 'mobile', 'nickname','balance', 'realname', 'status']);
  35. }
  36. /**
  37. * 评论记录
  38. * @return \Illuminate\Database\Eloquent\Relations\hasMany
  39. */
  40. public function records()
  41. {
  42. return $this->hasMany(PostRecordModel::class, 'source_id', 'id')
  43. ->where(['type'=>1,'status'=>1,'mark'=>1]);
  44. }
  45. /**
  46. * 点赞记录
  47. * @return \Illuminate\Database\Eloquent\Relations\hasMany
  48. */
  49. public function likes()
  50. {
  51. return $this->hasMany(PostRecordModel::class, 'source_id', 'id')
  52. ->where(['type'=>2,'status'=>1,'mark'=>1]);
  53. }
  54. }