Task.php 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. <?php
  2. namespace App\Module\Task\Models;
  3. use UCore\ModelCore;
  4. use Illuminate\Database\Eloquent\Relations\BelongsTo;
  5. use Illuminate\Database\Eloquent\Relations\HasMany;
  6. /**
  7. * 任务模型
  8. *
  9. * field start
  10. * @property int $id 主键
  11. * @property int $category_id 任务分类ID,外键关联task_categories表
  12. * @property string $name 任务名称
  13. * @property string $description 任务描述
  14. * @property string $type 任务类型(daily, weekly, achievement, event, tutorial, team)
  15. * @property object|array $prerequisite_tasks 前置任务ID(JSON格式)
  16. * @property int $level_required 所需等级
  17. * @property int $time_limit 时间限制(秒,NULL表示无限制)
  18. * @property int $max_completions 最大完成次数(用于限制任务可完成的次数)
  19. * @property string $reset_type 重置类型(none, daily, weekly, monthly)
  20. * @property object|array $display_params 显示参数(JSON格式,存储与任务显示相关的参数)
  21. * @property int $sort_order 排序权重(数值越大越靠前)
  22. * @property int $is_active 是否激活(0:否, 1:是)
  23. * @property string $start_time 开始时间(NULL表示立即开始)
  24. * @property string $end_time 结束时间(NULL表示永不结束)
  25. * @property \Carbon\Carbon $created_at 创建时间
  26. * @property \Carbon\Carbon $updated_at 更新时间
  27. * @property int $reset_interval 重置间隔(秒),根据重置类型自动计算
  28. * @property string $reset_time_field 重置时间字段,如"daily_reset_time",用于存储具体重置时间点
  29. * field end
  30. */
  31. class Task extends ModelCore
  32. {
  33. /**
  34. * 与模型关联的表名
  35. *
  36. * @var string
  37. */
  38. protected $table = 'task_tasks';
  39. /**
  40. * 主键
  41. *
  42. * @var string
  43. */
  44. protected $primaryKey = 'id';
  45. /**
  46. * 应该被转换为原生类型的属性
  47. *
  48. * @var array
  49. */
  50. protected $casts = [
  51. 'prerequisite_tasks' => 'array',
  52. 'display_params' => 'array',
  53. 'is_active' => 'boolean',
  54. ];
  55. /**
  56. * 应该被转换为日期的属性
  57. *
  58. * @var array
  59. */
  60. protected $dates = [
  61. 'start_time',
  62. 'end_time',
  63. 'created_at',
  64. 'updated_at',
  65. ];
  66. // attrlist start
  67. protected $fillable = [
  68. 'id',
  69. 'category_id',
  70. 'name',
  71. 'description',
  72. 'type',
  73. 'prerequisite_tasks',
  74. 'level_required',
  75. 'time_limit',
  76. 'max_completions',
  77. 'reset_type',
  78. 'display_params',
  79. 'sort_order',
  80. 'is_active',
  81. 'start_time',
  82. 'end_time',
  83. 'reset_interval',
  84. 'reset_time_field',
  85. ];
  86. // attrlist end
  87. /**
  88. * 获取任务所属分类
  89. *
  90. * @return BelongsTo
  91. */
  92. public function category(): BelongsTo
  93. {
  94. return $this->belongsTo(TaskCategory::class, 'category_id', 'id');
  95. }
  96. /**
  97. * 获取任务的奖励
  98. *
  99. * @return HasMany
  100. */
  101. public function rewards(): HasMany
  102. {
  103. return $this->hasMany(TaskReward::class, 'task_id', 'id');
  104. }
  105. /**
  106. * 获取任务的消耗
  107. *
  108. * @return HasMany
  109. */
  110. public function costs(): HasMany
  111. {
  112. return $this->hasMany(TaskCost::class, 'task_id', 'id');
  113. }
  114. /**
  115. * 获取任务的达成条件
  116. *
  117. * @return HasMany
  118. */
  119. public function achievementConditions(): HasMany
  120. {
  121. return $this->hasMany(TaskAchievementCondition::class, 'task_id', 'id');
  122. }
  123. /**
  124. * 获取用户任务关联
  125. *
  126. * @return HasMany
  127. */
  128. public function userTasks(): HasMany
  129. {
  130. return $this->hasMany(TaskUserTask::class, 'task_id', 'id');
  131. }
  132. }