. */ declare(strict_types=1); namespace FireflyIII\Models; use Illuminate\Database\Eloquent\Model; use Illuminate\Database\Eloquent\Relations\HasMany; use Illuminate\Database\Eloquent\SoftDeletes; use Symfony\Component\HttpKernel\Exception\NotFoundHttpException; /** * Class TransactionType. * * @property string $type * @property int $id * @property \Illuminate\Support\Carbon|null $created_at * @property \Illuminate\Support\Carbon|null $updated_at * @property \Illuminate\Support\Carbon|null $deleted_at * @property-read \Illuminate\Database\Eloquent\Collection|\FireflyIII\Models\TransactionJournal[] $transactionJournals * @method static bool|null forceDelete() * @method static \Illuminate\Database\Eloquent\Builder|\FireflyIII\Models\TransactionType newModelQuery() * @method static \Illuminate\Database\Eloquent\Builder|\FireflyIII\Models\TransactionType newQuery() * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\TransactionType onlyTrashed() * @method static \Illuminate\Database\Eloquent\Builder|\FireflyIII\Models\TransactionType query() * @method static bool|null restore() * @method static \Illuminate\Database\Eloquent\Builder|\FireflyIII\Models\TransactionType whereCreatedAt($value) * @method static \Illuminate\Database\Eloquent\Builder|\FireflyIII\Models\TransactionType whereDeletedAt($value) * @method static \Illuminate\Database\Eloquent\Builder|\FireflyIII\Models\TransactionType whereId($value) * @method static \Illuminate\Database\Eloquent\Builder|\FireflyIII\Models\TransactionType whereType($value) * @method static \Illuminate\Database\Eloquent\Builder|\FireflyIII\Models\TransactionType whereUpdatedAt($value) * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\TransactionType withTrashed() * @method static \Illuminate\Database\Query\Builder|\FireflyIII\Models\TransactionType withoutTrashed() * @mixin \Eloquent */ class TransactionType extends Model { use SoftDeletes; /** * */ public const WITHDRAWAL = 'Withdrawal'; /** * */ public const DEPOSIT = 'Deposit'; /** * */ public const TRANSFER = 'Transfer'; /** * */ public const OPENING_BALANCE = 'Opening balance'; /** * */ public const RECONCILIATION = 'Reconciliation'; /** * The attributes that should be casted to native types. * * @var array */ protected $casts = [ 'created_at' => 'datetime', 'updated_at' => 'datetime', 'deleted_at' => 'datetime', ]; /** @var array Fields that can be filled */ protected $fillable = ['type']; /** * Route binder. Converts the key in the URL to the specified object (or throw 404). * * @param string $type * * @return Model|null|static * @throws NotFoundHttpException */ public static function routeBinder(string $type): TransactionType { if (!auth()->check()) { throw new NotFoundHttpException(); } $transactionType = self::where('type', ucfirst($type))->first(); if (null !== $transactionType) { return $transactionType; } throw new NotFoundHttpException(); } /** * @codeCoverageIgnore * @return bool */ public function isDeposit(): bool { return self::DEPOSIT === $this->type; } /** * @codeCoverageIgnore * @return bool */ public function isOpeningBalance(): bool { return self::OPENING_BALANCE === $this->type; } /** * @codeCoverageIgnore * @return bool */ public function isTransfer(): bool { return self::TRANSFER === $this->type; } /** * @codeCoverageIgnore * @return bool */ public function isWithdrawal(): bool { return self::WITHDRAWAL === $this->type; } /** * @codeCoverageIgnore * @return HasMany */ public function transactionJournals(): HasMany { return $this->hasMany(TransactionJournal::class); } }