['text' => 'Exchange'], self::GET_TYPE_GRANT => ['text' => 'Grant'], ]; protected $fillable = [ 'name', 'description', 'image_large', 'image_small', 'price', 'duration', 'get_type', 'display_on_medal_page', 'sale_begin_time', 'sale_end_time', 'inventory', 'bonus_addition_factor', ]; public $timestamps = true; protected $casts = [ 'sale_begin_time' => 'datetime', 'sale_end_time' => 'datetime', ]; public static function listGetTypes($onlyKeyValues = false): array { $results = self::$getTypeText; $keyValues = []; foreach ($results as $type => &$info) { $text = nexus_trans("medal.get_types.$type"); $keyValues[$type] = $text; $info['text'] = $text; } if ($onlyKeyValues) { return $keyValues; } return $results; } public function getGetTypeTextAttribute($value): string { return nexus_trans("medal.get_types." . $this->get_type); } public function getDurationTextAttribute($value): string { if ($this->duration > 0) { return $this->duration; } return nexus_trans("label.permanent"); } public function users(): \Illuminate\Database\Eloquent\Relations\BelongsToMany { return $this->belongsToMany(User::class, 'user_medals', 'medal_id', 'uid')->withTimestamps(); } public function valid_users(): \Illuminate\Database\Eloquent\Relations\BelongsToMany { return $this->users()->where(function ($query) { $query->whereNull('user_medals.expire_at')->orWhere('user_medals.expire_at', '>=', Carbon::now()); }); } }