mirror of
				https://github.com/invoiceninja/invoiceninja.git
				synced 2025-10-31 15:47:32 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			380 lines
		
	
	
		
			9.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			380 lines
		
	
	
		
			9.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php namespace App\Models;
 | |
| 
 | |
| use Eloquent;
 | |
| use Utils;
 | |
| use Session;
 | |
| 
 | |
| use Illuminate\Database\Eloquent\SoftDeletes;
 | |
| 
 | |
| class Account extends Eloquent
 | |
| {
 | |
|     use SoftDeletes;
 | |
|     protected $dates = ['deleted_at'];
 | |
| 
 | |
|     public function users()
 | |
|     {
 | |
|         return $this->hasMany('App\Models\User');
 | |
|     }
 | |
| 
 | |
|     public function clients()
 | |
|     {
 | |
|         return $this->hasMany('App\Models\Client');
 | |
|     }
 | |
| 
 | |
|     public function invoices()
 | |
|     {
 | |
|         return $this->hasMany('App\Models\Invoice');
 | |
|     }
 | |
| 
 | |
|     public function account_gateways()
 | |
|     {
 | |
|         return $this->hasMany('App\Models\AccountGateway');
 | |
|     }
 | |
| 
 | |
|     public function tax_rates()
 | |
|     {
 | |
|         return $this->hasMany('App\Models\TaxRate');
 | |
|     }
 | |
| 
 | |
|     public function country()
 | |
|     {
 | |
|         return $this->belongsTo('App\Models\Country');
 | |
|     }
 | |
| 
 | |
|     public function timezone()
 | |
|     {
 | |
|         return $this->belongsTo('App\Models\Timezone');
 | |
|     }
 | |
| 
 | |
|     public function language()
 | |
|     {
 | |
|         return $this->belongsTo('App\Models\Language');
 | |
|     }
 | |
| 
 | |
|     public function date_format()
 | |
|     {
 | |
|         return $this->belongsTo('App\Models\DateFormat');
 | |
|     }
 | |
| 
 | |
|     public function datetime_format()
 | |
|     {
 | |
|         return $this->belongsTo('App\Models\DatetimeFormat');
 | |
|     }
 | |
| 
 | |
|     public function size()
 | |
|     {
 | |
|         return $this->belongsTo('App\Models\Size');
 | |
|     }
 | |
| 
 | |
|     public function currency()
 | |
|     {
 | |
|         return $this->belongsTo('App\Models\Currency');
 | |
|     }
 | |
| 
 | |
|     public function industry()
 | |
|     {
 | |
|         return $this->belongsTo('App\Models\Industry');
 | |
|     }
 | |
| 
 | |
|     public function isGatewayConfigured($gatewayId = 0)
 | |
|     {
 | |
|         $this->load('account_gateways');
 | |
| 
 | |
|         if ($gatewayId) {
 | |
|             return $this->getGatewayConfig($gatewayId) != false;
 | |
|         } else {
 | |
|             return count($this->account_gateways) > 0;
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     public function getDisplayName()
 | |
|     {
 | |
|         if ($this->name) {
 | |
|             return $this->name;
 | |
|         }
 | |
| 
 | |
|         $this->load('users');
 | |
|         $user = $this->users()->first();
 | |
| 
 | |
|         return $user->getDisplayName();
 | |
|     }
 | |
| 
 | |
|     public function getTimezone()
 | |
|     {
 | |
|         if ($this->timezone) {
 | |
|             return $this->timezone->name;
 | |
|         } else {
 | |
|             return 'US/Eastern';
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     public function getGatewayByType($type = PAYMENT_TYPE_ANY)
 | |
|     {
 | |
|         foreach ($this->account_gateways as $gateway) {
 | |
|             if (!$type || $type == PAYMENT_TYPE_ANY) {
 | |
|                 return $gateway;
 | |
|             } elseif ($gateway->isPayPal() && $type == PAYMENT_TYPE_PAYPAL) {
 | |
|                 return $gateway;
 | |
|             } elseif (!$gateway->isPayPal() && $type == PAYMENT_TYPE_CREDIT_CARD) {
 | |
|                 return $gateway;
 | |
|             }
 | |
|         }
 | |
|         
 | |
|         return false;
 | |
|     }
 | |
| 
 | |
|     public function getGatewayConfig($gatewayId)
 | |
|     {
 | |
|         foreach ($this->account_gateways as $gateway) {
 | |
|             if ($gateway->gateway_id == $gatewayId) {
 | |
|                 return $gateway;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         return false;
 | |
|     }
 | |
| 
 | |
|     public function getLogoPath()
 | |
|     {
 | |
|         return 'logo/'.$this->account_key.'.jpg';
 | |
|     }
 | |
| 
 | |
|     public function getLogoWidth()
 | |
|     {
 | |
|         $path = $this->getLogoPath();
 | |
|         if (!file_exists($path)) {
 | |
|             return 0;
 | |
|         }
 | |
|         list($width, $height) = getimagesize($path);
 | |
| 
 | |
|         return $width;
 | |
|     }
 | |
| 
 | |
|     public function getLogoHeight()
 | |
|     {
 | |
|         $path = $this->getLogoPath();
 | |
|         if (!file_exists($path)) {
 | |
|             return 0;
 | |
|         }
 | |
|         list($width, $height) = getimagesize($path);
 | |
| 
 | |
|         return $height;
 | |
|     }
 | |
| 
 | |
|     public function getNextInvoiceNumber($isQuote = false)
 | |
|     {
 | |
|         $counter = $isQuote && !$this->share_counter ? $this->quote_number_counter : $this->invoice_number_counter;
 | |
|         $prefix = $isQuote ? $this->quote_number_prefix : $this->invoice_number_prefix;
 | |
| 
 | |
|         return $prefix.str_pad($counter, 4, "0", STR_PAD_LEFT);
 | |
|     }
 | |
| 
 | |
|     public function incrementCounter($invoiceNumber, $isQuote = false, $isRecurring)
 | |
|     {
 | |
|         // check if the user modified the invoice number
 | |
|         if (!$isRecurring && $invoiceNumber != $this->getNextInvoiceNumber($isQuote)) {
 | |
|             $number = intval(preg_replace('/[^0-9]/', '', $invoiceNumber));
 | |
|             if ($isQuote && !$this->share_counter) {
 | |
|                 $this->quote_number_counter = $number + 1;
 | |
|             } else {
 | |
|                 $this->invoice_number_counter = $number + 1;
 | |
|             }
 | |
|         // otherwise, just increment the counter
 | |
|         } else {
 | |
|             if ($isQuote && !$this->share_counter) {
 | |
|                 $this->quote_number_counter += 1;
 | |
|             } else {
 | |
|                 $this->invoice_number_counter += 1;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         $this->save();
 | |
|     }
 | |
| 
 | |
|     public function getLocale()
 | |
|     {
 | |
|         $language = Language::where('id', '=', $this->account->language_id)->first();
 | |
| 
 | |
|         return $language->locale;
 | |
|     }
 | |
| 
 | |
|     public function loadLocalizationSettings()
 | |
|     {
 | |
|         $this->load('timezone', 'date_format', 'datetime_format', 'language');
 | |
| 
 | |
|         Session::put(SESSION_TIMEZONE, $this->timezone ? $this->timezone->name : DEFAULT_TIMEZONE);
 | |
|         Session::put(SESSION_DATE_FORMAT, $this->date_format ? $this->date_format->format : DEFAULT_DATE_FORMAT);
 | |
|         Session::put(SESSION_DATE_PICKER_FORMAT, $this->date_format ? $this->date_format->picker_format : DEFAULT_DATE_PICKER_FORMAT);
 | |
|         Session::put(SESSION_DATETIME_FORMAT, $this->datetime_format ? $this->datetime_format->format : DEFAULT_DATETIME_FORMAT);
 | |
|         Session::put(SESSION_CURRENCY, $this->currency_id ? $this->currency_id : DEFAULT_CURRENCY);
 | |
|         Session::put(SESSION_LOCALE, $this->language_id ? $this->language->locale : DEFAULT_LOCALE);
 | |
|     }
 | |
| 
 | |
|     public function getInvoiceLabels()
 | |
|     {
 | |
|         $data = [];
 | |
|         $fields = [
 | |
|             'invoice',
 | |
|             'invoice_date',
 | |
|             'due_date',
 | |
|             'invoice_number',
 | |
|             'po_number',
 | |
|             'discount',
 | |
|             'taxes',
 | |
|             'tax',
 | |
|             'item',
 | |
|             'description',
 | |
|             'unit_cost',
 | |
|             'quantity',
 | |
|             'line_total',
 | |
|             'subtotal',
 | |
|             'paid_to_date',
 | |
|             'balance_due',
 | |
|             'terms',
 | |
|             'your_invoice',
 | |
|             'quote',
 | |
|             'your_quote',
 | |
|             'quote_date',
 | |
|             'quote_number',
 | |
|             'total',
 | |
|             'invoice_issued_to',
 | |
|         ];
 | |
| 
 | |
|         foreach ($fields as $field) {
 | |
|             $data[$field] = trans("texts.$field");
 | |
|         }
 | |
| 
 | |
|         return $data;
 | |
|     }
 | |
| 
 | |
|     public function isPro()
 | |
|     {
 | |
|         if (!Utils::isNinjaProd()) {
 | |
|             return true;
 | |
|         }
 | |
| 
 | |
|         if ($this->account_key == NINJA_ACCOUNT_KEY) {
 | |
|             return true;
 | |
|         }
 | |
| 
 | |
|         $datePaid = $this->pro_plan_paid;
 | |
| 
 | |
|         if (!$datePaid || $datePaid == '0000-00-00') {
 | |
|             return false;
 | |
|         } elseif ($datePaid == NINJA_DATE) {
 | |
|             return true;
 | |
|         }
 | |
| 
 | |
|         $today = new DateTime('now');
 | |
|         $datePaid = DateTime::createFromFormat('Y-m-d', $datePaid);
 | |
|         $interval = $today->diff($datePaid);
 | |
| 
 | |
|         return $interval->y == 0;
 | |
|     }
 | |
| 
 | |
|     public function isWhiteLabel()
 | |
|     {
 | |
|         if (Utils::isNinjaProd()) {
 | |
|             return false;
 | |
|         }
 | |
| 
 | |
|         return $this->pro_plan_paid == NINJA_DATE;
 | |
|     }
 | |
| 
 | |
|     public function getSubscription($eventId)
 | |
|     {
 | |
|         return Subscription::where('account_id', '=', $this->id)->where('event_id', '=', $eventId)->first();
 | |
|     }
 | |
| 
 | |
|     public function hideFieldsForViz()
 | |
|     {
 | |
|         foreach ($this->clients as $client) {
 | |
|             $client->setVisible([
 | |
|                 'public_id',
 | |
|                 'name',
 | |
|                 'balance',
 | |
|                 'paid_to_date',
 | |
|                 'invoices',
 | |
|                 'contacts',
 | |
|             ]);
 | |
| 
 | |
|             foreach ($client->invoices as $invoice) {
 | |
|                 $invoice->setVisible([
 | |
|                     'public_id',
 | |
|                     'invoice_number',
 | |
|                     'amount',
 | |
|                     'balance',
 | |
|                     'invoice_status_id',
 | |
|                     'invoice_items',
 | |
|                     'created_at',
 | |
|                 ]);
 | |
| 
 | |
|                 foreach ($invoice->invoice_items as $invoiceItem) {
 | |
|                     $invoiceItem->setVisible([
 | |
|                         'product_key',
 | |
|                         'cost',
 | |
|                         'qty',
 | |
|                     ]);
 | |
|                 }
 | |
|             }
 | |
| 
 | |
|             foreach ($client->contacts as $contact) {
 | |
|                 $contact->setVisible([
 | |
|                     'public_id',
 | |
|                     'first_name',
 | |
|                     'last_name',
 | |
|                     'email', ]);
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     public function getEmailTemplate($entityType, $message = false)
 | |
|     {
 | |
|         $field = "email_template_$entityType";
 | |
|         $template = $this->$field;
 | |
| 
 | |
|         if ($template) {
 | |
|             return $template;
 | |
|         }
 | |
| 
 | |
|         $template = "\$client,<p/>\r\n\r\n" .
 | |
|                     trans("texts.{$entityType}_message", ['amount' => '$amount']) . "<p/>\r\n\r\n";
 | |
| 
 | |
|         if ($entityType != ENTITY_PAYMENT) {
 | |
|             $template .= "<a href=\"\$link\">\$link</a><p/>\r\n\r\n";
 | |
|         }
 | |
| 
 | |
|         if ($message) {
 | |
|             $template .= "$message<p/>\r\n\r\n";
 | |
|         }
 | |
| 
 | |
|         return $template . "\$footer";
 | |
|     }
 | |
| 
 | |
|     public function getEmailFooter()
 | |
|     {
 | |
|         if ($this->email_footer) {
 | |
|             return $this->email_footer;
 | |
|         } else {
 | |
|             return "<p>" . trans('texts.email_signature') . "<br>\$account</p>";
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     public function showTokenCheckbox()
 | |
|     {
 | |
|         if (!$this->isGatewayConfigured(GATEWAY_STRIPE)) {
 | |
|             return false;
 | |
|         }
 | |
| 
 | |
|         return $this->token_billing_type_id == TOKEN_BILLING_OPT_IN
 | |
|                 || $this->token_billing_type_id == TOKEN_BILLING_OPT_OUT;
 | |
|     }
 | |
| 
 | |
|     public function selectTokenCheckbox()
 | |
|     {
 | |
|         return $this->token_billing_type_id == TOKEN_BILLING_OPT_OUT;
 | |
|     }
 | |
| }
 |