. */ declare(strict_types=1); namespace FireflyIII\Models; use Carbon\Carbon; use FireflyIII\User; use Illuminate\Database\Eloquent\Model; use Illuminate\Database\Eloquent\Relations\BelongsTo; use Illuminate\Database\Eloquent\Relations\BelongsToMany; use Illuminate\Database\Eloquent\SoftDeletes; use Symfony\Component\HttpKernel\Exception\NotFoundHttpException; /** * Class Category. * * @property string $name * @property int $id * @property float $spent // used in category reports * @property Carbon|null lastActivity * @property bool encrypted * @property User $user * @property Carbon $created_at * @property Carbon $updated_at * @property \Illuminate\Support\Carbon|null $deleted_at * @property int $user_id * @property bool $encrypted * @property-read \Illuminate\Database\Eloquent\Collection|\FireflyIII\Models\TransactionJournal[] $transactionJournals * @property-read \Illuminate\Database\Eloquent\Collection|\FireflyIII\Models\Transaction[] $transactions * @method static bool|null forceDelete() * @method static \Illuminate\Database\Eloquent\Builder|\FireflyIII\Models\Category newModelQuery() * @method static \Illuminate\Database\Eloquent\Builder|\FireflyIII\Models\Category newQuery() * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\Category onlyTrashed() * @method static \Illuminate\Database\Eloquent\Builder|\FireflyIII\Models\Category query() * @method static bool|null restore() * @method static \Illuminate\Database\Eloquent\Builder|\FireflyIII\Models\Category whereCreatedAt($value) * @method static \Illuminate\Database\Eloquent\Builder|\FireflyIII\Models\Category whereDeletedAt($value) * @method static \Illuminate\Database\Eloquent\Builder|\FireflyIII\Models\Category whereEncrypted($value) * @method static \Illuminate\Database\Eloquent\Builder|\FireflyIII\Models\Category whereId($value) * @method static \Illuminate\Database\Eloquent\Builder|\FireflyIII\Models\Category whereName($value) * @method static \Illuminate\Database\Eloquent\Builder|\FireflyIII\Models\Category whereUpdatedAt($value) * @method static \Illuminate\Database\Eloquent\Builder|\FireflyIII\Models\Category whereUserId($value) * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\Category withTrashed() * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\Category withoutTrashed() * @mixin \Eloquent */ class Category extends Model { use SoftDeletes; /** * The attributes that should be casted to native types. * * @var array */ protected $casts = [ 'created_at' => 'datetime', 'updated_at' => 'datetime', 'deleted_at' => 'datetime', 'encrypted' => 'boolean', ]; /** @var array Fields that can be filled */ protected $fillable = ['user_id', 'name']; /** @var array Hidden from view */ protected $hidden = ['encrypted']; /** * Route binder. Converts the key in the URL to the specified object (or throw 404). * * @param string $value * * @return Category * @throws NotFoundHttpException */ public static function routeBinder(string $value): Category { if (auth()->check()) { $categoryId = (int)$value; /** @var User $user */ $user = auth()->user(); /** @var Category $category */ $category = $user->categories()->find($categoryId); if (null !== $category) { return $category; } } throw new NotFoundHttpException; } /** * @codeCoverageIgnore * @return BelongsToMany */ public function transactionJournals(): BelongsToMany { return $this->belongsToMany(TransactionJournal::class, 'category_transaction_journal', 'category_id'); } /** * @codeCoverageIgnore * @return BelongsToMany */ public function transactions(): BelongsToMany { return $this->belongsToMany(Transaction::class, 'category_transaction', 'category_id'); } /** * @codeCoverageIgnore * @return BelongsTo */ public function user(): BelongsTo { return $this->belongsTo(User::class); } }