. */ 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\Relations\HasMany; use Illuminate\Database\Eloquent\SoftDeletes; use Illuminate\Support\Collection; use Symfony\Component\HttpKernel\Exception\NotFoundHttpException; /** * Class Budget. * * @property int $id * @property string $name * @property bool $active * @property int $user_id * @property-read string $email * @property bool encrypted * @property Collection budgetlimits * @property int $order * @property Carbon created_at * @property Carbon updated_at * @property User $user * @property \Illuminate\Support\Carbon|null $created_at * @property \Illuminate\Support\Carbon|null $updated_at * @property \Illuminate\Support\Carbon|null $deleted_at * @property bool $encrypted * @property-read \Illuminate\Database\Eloquent\Collection|\FireflyIII\Models\BudgetLimit[] $budgetlimits * @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\Budget newModelQuery() * @method static \Illuminate\Database\Eloquent\Builder|\FireflyIII\Models\Budget newQuery() * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\Budget onlyTrashed() * @method static \Illuminate\Database\Eloquent\Builder|\FireflyIII\Models\Budget query() * @method static bool|null restore() * @method static \Illuminate\Database\Eloquent\Builder|\FireflyIII\Models\Budget whereActive($value) * @method static \Illuminate\Database\Eloquent\Builder|\FireflyIII\Models\Budget whereCreatedAt($value) * @method static \Illuminate\Database\Eloquent\Builder|\FireflyIII\Models\Budget whereDeletedAt($value) * @method static \Illuminate\Database\Eloquent\Builder|\FireflyIII\Models\Budget whereEncrypted($value) * @method static \Illuminate\Database\Eloquent\Builder|\FireflyIII\Models\Budget whereId($value) * @method static \Illuminate\Database\Eloquent\Builder|\FireflyIII\Models\Budget whereName($value) * @method static \Illuminate\Database\Eloquent\Builder|\FireflyIII\Models\Budget whereOrder($value) * @method static \Illuminate\Database\Eloquent\Builder|\FireflyIII\Models\Budget whereUpdatedAt($value) * @method static \Illuminate\Database\Eloquent\Builder|\FireflyIII\Models\Budget whereUserId($value) * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\Budget withTrashed() * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\Budget withoutTrashed() * @mixin \Eloquent */ class Budget 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', 'active' => 'boolean', 'encrypted' => 'boolean', ]; /** @var array Fields that can be filled */ protected $fillable = ['user_id', 'name', 'active', 'order']; /** @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 Budget * @throws NotFoundHttpException */ public static function routeBinder(string $value): Budget { if (auth()->check()) { $budgetId = (int)$value; /** @var User $user */ $user = auth()->user(); /** @var Budget $budget */ $budget = $user->budgets()->find($budgetId); if (null !== $budget) { return $budget; } } throw new NotFoundHttpException; } /** * @codeCoverageIgnore * @return HasMany */ public function budgetlimits(): HasMany { return $this->hasMany(BudgetLimit::class); } /** * @codeCoverageIgnore * @return BelongsToMany */ public function transactionJournals(): BelongsToMany { return $this->belongsToMany(TransactionJournal::class, 'budget_transaction_journal', 'budget_id'); } /** * @codeCoverageIgnore * @return BelongsToMany */ public function transactions(): BelongsToMany { return $this->belongsToMany(Transaction::class, 'budget_transaction', 'budget_id'); } /** * @codeCoverageIgnore * @return BelongsTo */ public function user(): BelongsTo { return $this->belongsTo(User::class); } }