1
0
mirror of https://github.com/invoiceninja/invoiceninja.git synced 2024-09-21 17:01:33 +02:00
invoiceninja/app/Models/Activity.php

167 lines
3.9 KiB
PHP
Raw Normal View History

2019-04-20 03:54:11 +02:00
<?php
2019-05-11 05:32:07 +02:00
/**
* Invoice Ninja (https://invoiceninja.com)
*
* @link https://github.com/invoiceninja/invoiceninja source repository
*
* @copyright Copyright (c) 2020. Invoice Ninja LLC (https://invoiceninja.com)
2019-05-11 05:32:07 +02:00
*
* @license https://opensource.org/licenses/AAL
*/
2019-04-20 03:54:11 +02:00
namespace App\Models;
2020-08-12 02:01:27 +02:00
use App\Utils\Traits\MakesHash;
2019-04-20 03:54:11 +02:00
use Illuminate\Database\Eloquent\Model;
class Activity extends StaticModel
2019-04-20 03:54:11 +02:00
{
2020-08-12 02:01:27 +02:00
use MakesHash;
2020-07-17 02:31:19 +02:00
const CREATE_CLIENT=1; //
const ARCHIVE_CLIENT=2; //
const DELETE_CLIENT=3; //
const CREATE_INVOICE=4; //
const UPDATE_INVOICE=5; //
const EMAIL_INVOICE=6; //
2020-07-17 03:28:54 +02:00
const VIEW_INVOICE=7; //
const ARCHIVE_INVOICE=8; //
const DELETE_INVOICE=9; //
const CREATE_PAYMENT=10; //
const UPDATE_PAYMENT=11; //
const ARCHIVE_PAYMENT=12; //
const DELETE_PAYMENT=13; //
2020-07-17 06:44:34 +02:00
const CREATE_CREDIT=14; //
const UPDATE_CREDIT=15; //
2020-07-20 01:02:31 +02:00
const ARCHIVE_CREDIT=16; //
const DELETE_CREDIT=17; //
const CREATE_QUOTE=18; //
const UPDATE_QUOTE=19; //
const EMAIL_QUOTE=20; //
const VIEW_QUOTE=21; //
2020-07-22 09:53:14 +02:00
const ARCHIVE_QUOTE=22; //
const DELETE_QUOTE=23; //
const RESTORE_QUOTE=24; //
const RESTORE_INVOICE=25; //
const RESTORE_CLIENT=26; //
const RESTORE_PAYMENT=27; //
const RESTORE_CREDIT=28; //
const APPROVE_QUOTE=29; //
2019-04-20 14:09:40 +02:00
const CREATE_VENDOR=30;
const ARCHIVE_VENDOR=31;
const DELETE_VENDOR=32;
const RESTORE_VENDOR=33;
const CREATE_EXPENSE=34;
const ARCHIVE_EXPENSE=35;
const DELETE_EXPENSE=36;
const RESTORE_EXPENSE=37;
2020-08-12 03:45:40 +02:00
const VOIDED_PAYMENT=39; //
const REFUNDED_PAYMENT=40; //
2019-04-20 14:09:40 +02:00
const FAILED_PAYMENT=41;
const CREATE_TASK=42;
const UPDATE_TASK=43;
const ARCHIVE_TASK=44;
const DELETE_TASK=45;
const RESTORE_TASK=46;
const UPDATE_EXPENSE=47;
2020-08-12 03:45:40 +02:00
const CREATE_USER=48; // only used in CreateUser::job
const UPDATE_USER=49; // not needed?
const ARCHIVE_USER=50; // not needed?
const DELETE_USER=51; // not needed?
const RESTORE_USER=52; // not needed?
const MARK_SENT_INVOICE=53; // not needed?
2020-08-12 04:02:21 +02:00
const PAID_INVOICE=54; //
const EMAIL_INVOICE_FAILED=57;
2020-08-12 04:02:21 +02:00
const REVERSED_INVOICE=58; //
2020-08-12 05:13:39 +02:00
const CANCELLED_INVOICE=59; //
2020-08-12 04:02:21 +02:00
const VIEW_CREDIT=60; //
2019-09-17 12:27:48 +02:00
protected $casts = [
'is_system' => 'boolean',
'updated_at' => 'timestamp',
'created_at' => 'timestamp',
'deleted_at' => 'timestamp',
2019-09-17 12:27:48 +02:00
];
2019-04-20 14:09:40 +02:00
public function getEntityType()
{
return Activity::class;
}
2019-04-21 14:24:26 +02:00
public function backup()
{
return $this->hasOne(Backup::class);
2019-04-21 14:24:26 +02:00
}
2019-04-22 01:15:07 +02:00
2019-04-20 14:09:40 +02:00
/**
* @return mixed
*/
public function user()
{
return $this->belongsTo(User::class)->withTrashed();
}
/**
* @return mixed
*/
public function contact()
{
return $this->belongsTo(ClientContact::class)->withTrashed();
}
/**
* @return mixed
*/
public function client()
{
return $this->belongsTo(Client::class)->withTrashed();
}
/**
* @return mixed
*/
public function invoice()
{
return $this->belongsTo(Invoice::class)->withTrashed();
}
/**
* @return mixed
*/
public function payment()
{
return $this->belongsTo(Payment::class)->withTrashed();
}
// public function task()
// {
// return $this->belongsTo(Task::class)->withTrashed();
// }
2019-04-20 14:09:40 +02:00
// public function expense()
// {
// return $this->belongsTo(Expense::class)->withTrashed();
// }
2019-04-20 14:09:40 +02:00
2019-09-27 06:31:13 +02:00
public function company()
{
return $this->belongsTo(Company::class);
2019-09-27 06:31:13 +02:00
}
2020-08-12 02:01:27 +02:00
public function resolveRouteBinding($value)
{
if (is_numeric($value)) {
throw new ModelNotFoundException("Record with value {$value} not found");
}
return $this
//->withTrashed()
->where('id', $this->decodePrimaryKey($value))->firstOrFail();
}
2019-04-20 03:54:11 +02:00
}