1
0
mirror of https://github.com/invoiceninja/invoiceninja.git synced 2024-11-11 13:42:49 +01:00
invoiceninja/app/Models/Activity.php

551 lines
16 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).
2019-05-11 05:32:07 +02:00
*
* @link https://github.com/invoiceninja/invoiceninja source repository
*
2023-01-28 23:21:40 +01:00
* @copyright Copyright (c) 2023. Invoice Ninja LLC (https://invoiceninja.com)
2019-05-11 05:32:07 +02:00
*
2021-06-16 08:58:16 +02:00
* @license https://www.elastic.co/licensing/elastic-license
2019-05-11 05:32:07 +02:00
*/
2019-04-20 03:54:11 +02:00
namespace App\Models;
2023-06-24 06:57:57 +02:00
use App\Utils\Number;
2020-08-12 02:01:27 +02:00
use App\Utils\Traits\MakesHash;
2019-04-20 03:54:11 +02:00
2023-03-08 08:33:42 +01:00
/**
* App\Models\Activity
*
* @property int $id
* @property int|null $user_id
* @property int $company_id
* @property int|null $client_id
* @property int|null $client_contact_id
* @property int|null $account_id
* @property int|null $project_id
* @property int|null $vendor_id
* @property int|null $payment_id
* @property int|null $invoice_id
* @property int|null $credit_id
* @property int|null $invitation_id
* @property int|null $task_id
* @property int|null $expense_id
* @property int|null $activity_type_id
* @property string $ip
* @property bool $is_system
* @property string $notes
* @property int|null $created_at
* @property int|null $updated_at
* @property int|null $token_id
* @property int|null $quote_id
* @property int|null $subscription_id
* @property int|null $recurring_invoice_id
* @property int|null $recurring_expense_id
* @property int|null $recurring_quote_id
* @property int|null $purchase_order_id
* @property int|null $vendor_contact_id
* @property-read \App\Models\Backup|null $backup
* @property-read \App\Models\Client|null $client
* @property-read \App\Models\Company $company
* @property-read \App\Models\ClientContact|null $contact
* @property-read \App\Models\Credit|null $credit
* @property-read \App\Models\Expense|null $expense
* @property-read mixed $hashed_id
* @property-read \App\Models\Backup|null $history
* @property-read \App\Models\Invoice|null $invoice
* @property-read \App\Models\Payment|null $payment
* @property-read \App\Models\PurchaseOrder|null $purchase_order
* @property-read \App\Models\Quote|null $quote
* @property-read \App\Models\RecurringExpense|null $recurring_expense
* @property-read \App\Models\RecurringInvoice|null $recurring_invoice
* @property-read \App\Models\Subscription|null $subscription
* @property-read \App\Models\Task|null $task
* @property-read \App\Models\User|null $user
* @property-read \App\Models\Vendor|null $vendor
* @property-read \App\Models\VendorContact|null $vendor_contact
* @method static \Illuminate\Database\Eloquent\Builder|StaticModel company()
* @method static \Illuminate\Database\Eloquent\Builder|StaticModel exclude($columns)
* @method static \Illuminate\Database\Eloquent\Builder|Activity newModelQuery()
* @method static \Illuminate\Database\Eloquent\Builder|Activity newQuery()
* @method static \Illuminate\Database\Eloquent\Builder|Activity query()
* @method static \Illuminate\Database\Eloquent\Builder|Activity whereAccountId($value)
* @method static \Illuminate\Database\Eloquent\Builder|Activity whereActivityTypeId($value)
* @method static \Illuminate\Database\Eloquent\Builder|Activity whereClientContactId($value)
* @method static \Illuminate\Database\Eloquent\Builder|Activity whereClientId($value)
* @method static \Illuminate\Database\Eloquent\Builder|Activity whereCompanyId($value)
* @method static \Illuminate\Database\Eloquent\Builder|Activity whereCreatedAt($value)
* @method static \Illuminate\Database\Eloquent\Builder|Activity whereCreditId($value)
* @method static \Illuminate\Database\Eloquent\Builder|Activity whereExpenseId($value)
* @method static \Illuminate\Database\Eloquent\Builder|Activity whereId($value)
* @method static \Illuminate\Database\Eloquent\Builder|Activity whereInvitationId($value)
* @method static \Illuminate\Database\Eloquent\Builder|Activity whereInvoiceId($value)
* @method static \Illuminate\Database\Eloquent\Builder|Activity whereIp($value)
* @method static \Illuminate\Database\Eloquent\Builder|Activity whereIsSystem($value)
* @method static \Illuminate\Database\Eloquent\Builder|Activity whereNotes($value)
* @method static \Illuminate\Database\Eloquent\Builder|Activity wherePaymentId($value)
* @method static \Illuminate\Database\Eloquent\Builder|Activity whereProjectId($value)
* @method static \Illuminate\Database\Eloquent\Builder|Activity wherePurchaseOrderId($value)
* @method static \Illuminate\Database\Eloquent\Builder|Activity whereQuoteId($value)
* @method static \Illuminate\Database\Eloquent\Builder|Activity whereRecurringExpenseId($value)
* @method static \Illuminate\Database\Eloquent\Builder|Activity whereRecurringInvoiceId($value)
* @method static \Illuminate\Database\Eloquent\Builder|Activity whereRecurringQuoteId($value)
* @method static \Illuminate\Database\Eloquent\Builder|Activity whereSubscriptionId($value)
* @method static \Illuminate\Database\Eloquent\Builder|Activity whereTaskId($value)
* @method static \Illuminate\Database\Eloquent\Builder|Activity whereTokenId($value)
* @method static \Illuminate\Database\Eloquent\Builder|Activity whereUpdatedAt($value)
* @method static \Illuminate\Database\Eloquent\Builder|Activity whereUserId($value)
* @method static \Illuminate\Database\Eloquent\Builder|Activity whereVendorContactId($value)
* @method static \Illuminate\Database\Eloquent\Builder|Activity whereVendorId($value)
* @mixin \Eloquent
*/
class Activity extends StaticModel
2019-04-20 03:54:11 +02:00
{
2020-08-12 02:01:27 +02:00
use MakesHash;
const CREATE_CLIENT = 1; //
const ARCHIVE_CLIENT = 2; //
const DELETE_CLIENT = 3; //
const CREATE_INVOICE = 4; //
const UPDATE_INVOICE = 5; //
const EMAIL_INVOICE = 6; //
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; //
const CREATE_CREDIT = 14; //
const UPDATE_CREDIT = 15; //
const ARCHIVE_CREDIT = 16; //
const DELETE_CREDIT = 17; //
const CREATE_QUOTE = 18; //
const UPDATE_QUOTE = 19; //
const EMAIL_QUOTE = 20; //
const VIEW_QUOTE = 21; //
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; //
2020-11-03 06:44:50 +01: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; //
const VOIDED_PAYMENT = 39; //
const REFUNDED_PAYMENT = 40; //
const FAILED_PAYMENT = 41;
2020-11-03 11:04:15 +01:00
const CREATE_TASK = 42; //
2020-11-03 11:04:15 +01:00
const UPDATE_TASK = 43; //
2020-11-03 11:04:15 +01:00
const ARCHIVE_TASK = 44; //
2020-11-03 11:04:15 +01:00
const DELETE_TASK = 45; //
2020-11-03 11:04:15 +01:00
const RESTORE_TASK = 46; //
const UPDATE_EXPENSE = 47; //
const CREATE_USER = 48;
2021-01-14 04:44:52 +01:00
const UPDATE_USER = 49;
const ARCHIVE_USER = 50;
const DELETE_USER = 51;
const RESTORE_USER = 52;
const MARK_SENT_INVOICE = 53; // not needed?
const PAID_INVOICE = 54; //
const EMAIL_INVOICE_FAILED = 57;
const REVERSED_INVOICE = 58; //
const CANCELLED_INVOICE = 59; //
const VIEW_CREDIT = 60; //
2020-11-03 11:04:15 +01:00
const UPDATE_CLIENT = 61; //
2020-11-03 11:04:15 +01:00
const UPDATE_VENDOR = 62; //
2020-08-12 04:02:21 +02:00
2020-11-09 03:39:42 +01:00
const INVOICE_REMINDER1_SENT = 63;
2020-11-09 03:39:42 +01:00
const INVOICE_REMINDER2_SENT = 64;
2020-11-09 03:39:42 +01:00
const INVOICE_REMINDER3_SENT = 65;
2020-11-09 06:00:15 +01:00
const INVOICE_REMINDER_ENDLESS_SENT = 66;
2020-11-09 03:39:42 +01:00
const CREATE_SUBSCRIPTION = 80;
const UPDATE_SUBSCRIPTION = 81;
const ARCHIVE_SUBSCRIPTION = 82;
const DELETE_SUBSCRIPTION = 83;
const RESTORE_SUBSCRIPTION = 84;
const CREATE_RECURRING_INVOICE = 100;
const UPDATE_RECURRING_INVOICE = 101;
const ARCHIVE_RECURRING_INVOICE = 102;
const DELETE_RECURRING_INVOICE = 103;
const RESTORE_RECURRING_INVOICE = 104;
2021-08-24 07:55:14 +02:00
const CREATE_RECURRING_QUOTE = 110;
const UPDATE_RECURRING_QUOTE = 111;
const ARCHIVE_RECURRING_QUOTE = 112;
const DELETE_RECURRING_QUOTE = 113;
const RESTORE_RECURRING_QUOTE = 114;
2021-08-24 07:55:14 +02:00
const CREATE_RECURRING_EXPENSE = 120;
const UPDATE_RECURRING_EXPENSE = 121;
const ARCHIVE_RECURRING_EXPENSE = 122;
const DELETE_RECURRING_EXPENSE = 123;
const RESTORE_RECURRING_EXPENSE = 124;
2021-08-24 07:55:14 +02:00
const CREATE_PURCHASE_ORDER = 130;
const UPDATE_PURCHASE_ORDER = 131;
const ARCHIVE_PURCHASE_ORDER = 132;
const DELETE_PURCHASE_ORDER = 133;
const RESTORE_PURCHASE_ORDER = 134;
const EMAIL_PURCHASE_ORDER = 135;
const VIEW_PURCHASE_ORDER = 136;
2022-06-15 08:27:21 +02:00
const ACCEPT_PURCHASE_ORDER = 137;
2023-03-17 07:36:49 +01:00
const PAYMENT_EMAILED = 138;
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
2021-05-30 10:03:31 +02:00
protected $appends = [
'hashed_id',
];
2021-10-08 06:00:17 +02:00
protected $with = [
'backup',
];
2023-01-05 12:09:25 +01:00
/**
* @return mixed
*/
2021-05-30 10:03:31 +02:00
public function getHashedIdAttribute()
{
return $this->encodePrimaryKey($this->id);
}
2023-01-05 12:09:25 +01:00
/**
* @return mixed
*/
public function getEntityType()
{
return self::class;
}
2023-01-05 12:09:25 +01:00
/**
* @return mixed
*/
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
2023-01-05 12:09:25 +01:00
/**
* @return mixed
*/
public function history()
{
return $this->hasOne(Backup::class);
}
2019-04-20 14:09:40 +02:00
/**
* @return mixed
*/
public function user()
{
return $this->belongsTo(User::class)->withTrashed();
}
/**
* @return mixed
*/
public function contact()
{
2023-06-24 02:09:14 +02:00
return $this->belongsTo(ClientContact::class, 'client_contact_id', 'id')->withTrashed();
2019-04-20 14:09:40 +02:00
}
/**
* @return mixed
*/
public function client()
{
return $this->belongsTo(Client::class)->withTrashed();
}
/**
* @return mixed
*/
public function invoice()
{
return $this->belongsTo(Invoice::class)->withTrashed();
}
2023-01-05 12:09:25 +01:00
/**
* @return mixed
*/
2022-08-31 04:05:15 +02:00
public function vendor()
{
return $this->belongsTo(Vendor::class)->withTrashed();
}
2022-05-27 10:25:32 +02:00
/**
* @return mixed
*/
public function recurring_invoice()
{
return $this->belongsTo(RecurringInvoice::class)->withTrashed();
}
2023-01-05 12:09:25 +01:00
/**
* @return mixed
*/
2022-03-05 07:51:04 +01:00
public function credit()
{
return $this->belongsTo(Credit::class)->withTrashed();
}
2021-02-08 21:13:16 +01:00
/**
* @return mixed
*/
public function quote()
{
return $this->belongsTo(Quote::class)->withTrashed();
}
2022-11-24 01:38:57 +01:00
/**
* @return mixed
*/
public function subscription()
{
return $this->belongsTo(Subscription::class)->withTrashed();
}
2021-02-08 21:13:16 +01:00
2019-04-20 14:09:40 +02:00
/**
* @return mixed
*/
public function payment()
{
return $this->belongsTo(Payment::class)->withTrashed();
}
2023-01-05 12:09:25 +01:00
/**
* @return mixed
*/
2022-05-27 10:25:32 +02:00
public function expense()
{
return $this->belongsTo(Expense::class)->withTrashed();
}
2023-01-05 12:09:25 +01:00
/**
* @return mixed
*/
public function recurring_expense()
{
return $this->belongsTo(RecurringExpense::class)->withTrashed();
}
/**
* @return mixed
*/
public function purchase_order()
{
return $this->belongsTo(PurchaseOrder::class)->withTrashed();
}
2023-01-05 12:09:25 +01:00
/**
* @return mixed
*/
public function vendor_contact()
{
return $this->belongsTo(VendorContact::class)->withTrashed();
}
2023-01-05 12:09:25 +01:00
/**
* @return mixed
*/
2022-05-27 10:25:32 +02:00
public function task()
{
return $this->belongsTo(Task::class)->withTrashed();
}
2019-04-20 14:09:40 +02:00
2023-01-05 12:09:25 +01:00
/**
* @return mixed
*/
2019-09-27 06:31:13 +02:00
public function company()
{
return $this->belongsTo(Company::class);
2019-09-27 06:31:13 +02:00
}
2023-06-24 03:30:44 +02:00
public function activity_string()
{
$intersect = [
':invoice',
':client',
':contact',
':user',
':vendor',
':quote',
':credit',
':payment',
':task',
':expense',
':purchase_order',
':subscription',
':recurring_invoice',
':recurring_expense',
':amount',
':balance',
':number',
':payment_amount',
':gateway',
2023-06-24 15:02:38 +02:00
':adjustment'
2023-06-24 03:30:44 +02:00
];
2023-06-24 06:57:57 +02:00
$found_variables = array_intersect(explode(" ",trans("texts.activity_{$this->activity_type_id}")), $intersect);
2023-06-24 03:30:44 +02:00
$replacements = [];
2023-06-24 15:02:38 +02:00
foreach($found_variables as $var)
$replacements = array_merge($replacements, $this->matchVar($var));
2023-06-24 03:30:44 +02:00
2023-06-24 15:02:38 +02:00
if($this->client)
$replacements['client'] = ['label' => $this?->client?->present()->name() ?? '', 'hashed_id' => $this->client->hashed_id ?? ''];
2023-06-24 06:57:57 +02:00
2023-06-24 15:02:38 +02:00
if($this->vendor)
$replacements['vendor'] = ['label' => $this?->vendor?->present()->name() ?? '', 'hashed_id' => $this->vendor->hashed_id ?? ''];
$replacements['activity_type_id'] = $this->activity_type_id;
$replacements['id'] = $this->id;
$replacements['hashed_id'] = $this->hashed_id;
$replacements['notes'] = $this->notes ?? '';
$replacements['created_at'] = $this->created_at ?? '';
$replacements['ip'] = $this->ip ?? '';
2023-06-24 06:57:57 +02:00
return $replacements;
2023-06-24 03:30:44 +02:00
}
private function matchVar(string $variable)
{
2023-06-24 15:02:38 +02:00
$system = ctrans('texts.system');
2023-06-26 14:50:26 +02:00
match($variable) {
':invoice' => $translation = [substr($variable, 1) => [ 'label' => $this?->invoice?->number ?? '', 'hashed_id' => $this->invoice?->hashed_id ?? '']],
2023-06-24 15:02:38 +02:00
':user' => $translation = [substr($variable, 1) => [ 'label' => $this?->user?->present()->name() ?? $system, 'hashed_id' => $this->user->hashed_id ?? '']],
2023-06-24 06:57:57 +02:00
':quote' => $translation = [substr($variable, 1) => [ 'label' => $this?->quote?->number ?? '', 'hashed_id' => $this->quote->hashed_id ?? '']],
':credit' => $translation = [substr($variable, 1) => [ 'label' => $this?->credit?->number ?? '', 'hashed_id' => $this->credit->hashed_id ?? '']],
':payment' => $translation = [substr($variable, 1) => [ 'label' => $this?->payment?->number ?? '', 'hashed_id' => $this->payment->hashed_id ?? '']],
':task' => $translation = [substr($variable, 1) => [ 'label' => $this?->task?->number ?? '', 'hashed_id' => $this->task->hashed_id ?? '']],
':expense' => $translation = [substr($variable, 1) => [ 'label' => $this?->expense?->number ?? '', 'hashed_id' => $this->expense->hashed_id ?? '']],
':purchase_order' => $translation = [substr($variable, 1) => [ 'label' => $this?->purchase_order?->number ?? '', 'hashed_id' => $this->purchase_order->hashed_id ?? '']],
':subscription' => $translation = [substr($variable, 1) => [ 'label' => $this?->subscription?->number ?? '', 'hashed_id' => $this->subscription->hashed_id ?? '' ]],
':recurring_invoice' => $translation = [substr($variable, 1) =>[ 'label' => $this?->recurring_invoice?->number ??'', 'hashed_id' => $this->recurring_invoice->hashed_id ?? '']],
':recurring_expense' => $translation = [substr($variable, 1) => [ 'label' => $this?->recurring_expense?->number ??'', 'hashed_id' => $this->recurring_expense->hashed_id ?? '']],
2023-06-24 15:02:38 +02:00
':payment_amount' => $translation = [substr($variable, 1) =>[ 'label' => Number::formatMoney($this?->payment?->amount, $this?->payment?->client) ?? '', 'hashed_id' => '']],
':adjustment' => $translation = [substr($variable, 1) =>[ 'label' => Number::formatMoney($this?->payment?->refunded, $this?->payment?->client) ?? '', 'hashed_id' => '']],
2023-06-24 06:57:57 +02:00
':ip' => $translation = [ 'ip' => $this->ip ?? ''],
2023-06-26 14:50:26 +02:00
':contact' => $translation = $this->resolveContact(),
2023-06-24 15:02:38 +02:00
default => $translation = [],
2023-06-24 03:30:44 +02:00
};
return $translation;
}
2023-06-24 15:02:38 +02:00
private function resolveContact() : array
2023-06-24 06:57:57 +02:00
{
2023-06-24 15:02:38 +02:00
$contact = $this->contact ? $this->contact : $this->vendor_contact;
$entity = $this->contact ? $this->client : $this->vendor;
$contact_entity = $this->contact ? 'clients' : 'vendors';
2023-06-24 06:57:57 +02:00
2023-06-24 15:02:38 +02:00
return ['contact' => [ 'label' => $contact?->present()->name() ?? '', 'hashed_id' => $entity->hashed_id ?? '', 'contact_entity' => $contact_entity]];
2023-06-24 06:57:57 +02:00
}
2023-02-16 02:36:09 +01:00
}