mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2024-11-10 13:12:50 +01:00
179 lines
5.4 KiB
PHP
179 lines
5.4 KiB
PHP
<?php
|
|
|
|
namespace App\Ninja\Presenters;
|
|
|
|
use Carbon;
|
|
use Domain;
|
|
use App\Models\TaxRate;
|
|
use Laracasts\Presenter\Presenter;
|
|
use stdClass;
|
|
use Utils;
|
|
|
|
/**
|
|
* Class AccountPresenter.
|
|
*/
|
|
class AccountPresenter extends Presenter
|
|
{
|
|
/**
|
|
* @return mixed
|
|
*/
|
|
public function name()
|
|
{
|
|
return $this->entity->name ?: trans('texts.untitled_account');
|
|
}
|
|
|
|
/**
|
|
* @return string
|
|
*/
|
|
public function website()
|
|
{
|
|
return Utils::addHttp($this->entity->website);
|
|
}
|
|
|
|
/**
|
|
* @return mixed
|
|
*/
|
|
public function currencyCode()
|
|
{
|
|
$currencyId = $this->entity->getCurrencyId();
|
|
$currency = Utils::getFromCache($currencyId, 'currencies');
|
|
|
|
return $currency->code;
|
|
}
|
|
|
|
public function clientPortalLink()
|
|
{
|
|
return Domain::getLinkFromId($this->entity->domain_id);
|
|
}
|
|
|
|
public function industry()
|
|
{
|
|
return $this->entity->industry ? $this->entity->industry->name : '';
|
|
}
|
|
|
|
public function size()
|
|
{
|
|
return $this->entity->size ? $this->entity->size->name : '';
|
|
}
|
|
|
|
public function paymentTerms()
|
|
{
|
|
$terms = $this->entity->payment_terms;
|
|
|
|
if ($terms == 0) {
|
|
return '';
|
|
} elseif ($terms == -1) {
|
|
$terms = 0;
|
|
}
|
|
|
|
return trans('texts.payment_terms_net') . ' ' . $terms;
|
|
}
|
|
|
|
public function dueDatePlaceholder()
|
|
{
|
|
if ($this->entity->payment_terms == 0) {
|
|
return ' ';
|
|
}
|
|
|
|
$date = $this->entity->defaultDueDate();
|
|
|
|
return $date ? Utils::fromSqlDate($date) : ' ';
|
|
}
|
|
|
|
private function createRBit($type, $source, $properties)
|
|
{
|
|
$data = new stdClass();
|
|
$data->receive_time = time();
|
|
$data->type = $type;
|
|
$data->source = $source;
|
|
$data->properties = new stdClass();
|
|
|
|
foreach ($properties as $key => $val) {
|
|
$data->properties->$key = $val;
|
|
}
|
|
|
|
return $data;
|
|
}
|
|
|
|
public function rBits()
|
|
{
|
|
$account = $this->entity;
|
|
$user = $account->users()->first();
|
|
$data = [];
|
|
|
|
$data[] = $this->createRBit('business_name', 'user', ['business_name' => $account->name]);
|
|
$data[] = $this->createRBit('industry_code', 'user', ['industry_detail' => $account->present()->industry]);
|
|
$data[] = $this->createRBit('comment', 'partner_database', ['comment_text' => 'Logo image not present']);
|
|
$data[] = $this->createRBit('business_description', 'user', ['business_description' => $account->present()->size]);
|
|
|
|
$data[] = $this->createRBit('person', 'user', ['name' => $user->getFullName()]);
|
|
$data[] = $this->createRBit('email', 'user', ['email' => $user->email]);
|
|
$data[] = $this->createRBit('phone', 'user', ['phone' => $user->phone]);
|
|
$data[] = $this->createRBit('website_uri', 'user', ['uri' => $account->website]);
|
|
$data[] = $this->createRBit('external_account', 'partner_database', ['is_partner_account' => 'yes', 'account_type' => 'Invoice Ninja', 'create_time' => time()]);
|
|
|
|
return $data;
|
|
}
|
|
|
|
public function dateRangeOptions()
|
|
{
|
|
$yearStart = Carbon::parse($this->entity->financialYearStart() ?: date('Y') . '-01-01');
|
|
$month = $yearStart->month - 1;
|
|
$year = $yearStart->year;
|
|
$lastYear = $year - 1;
|
|
|
|
$str = '{
|
|
"' . trans('texts.last_7_days') . '": [moment().subtract(6, "days"), moment()],
|
|
"' . trans('texts.last_30_days') . '": [moment().subtract(29, "days"), moment()],
|
|
"' . trans('texts.this_month') . '": [moment().startOf("month"), moment().endOf("month")],
|
|
"' . trans('texts.last_month') . '": [moment().subtract(1, "month").startOf("month"), moment().subtract(1, "month").endOf("month")],
|
|
"' . trans('texts.this_year') . '": [moment().date(1).month(' . $month . ').year(' . $year . '), moment()],
|
|
"' . trans('texts.last_year') . '": [moment().date(1).month(' . $month . ').year(' . $lastYear . '), moment().date(1).month(' . $month . ').year(' . $year . ').subtract(1, "day")],
|
|
}';
|
|
|
|
return $str;
|
|
}
|
|
|
|
public function taxRateOptions()
|
|
{
|
|
$rates = TaxRate::scope()->orderBy('name')->get();
|
|
$options = [];
|
|
|
|
foreach ($rates as $rate) {
|
|
$name = $rate->name . ' ' . ($rate->rate + 0) . '%';
|
|
if ($rate->is_inclusive) {
|
|
$name .= ' - ' . trans('texts.inclusive');
|
|
}
|
|
$options[($rate->is_inclusive ? '1 ' : '0 ') . $rate->rate . ' ' . $rate->name] = $name;
|
|
}
|
|
|
|
return $options;
|
|
}
|
|
|
|
public function customTextFields()
|
|
{
|
|
$fields = [
|
|
'custom_client_label1' => 'custom_client1',
|
|
'custom_client_label2' => 'custom_client2',
|
|
'custom_contact_label1' => 'custom_contact1',
|
|
'custom_contact_label2' => 'custom_contact2',
|
|
'custom_invoice_text_label1' => 'custom_invoice1',
|
|
'custom_invoice_text_label2' => 'custom_invoice2',
|
|
'custom_invoice_item_label1' => 'custom_product1',
|
|
'custom_invoice_item_label2' => 'custom_product2',
|
|
];
|
|
$data = [];
|
|
|
|
foreach ($fields as $key => $val) {
|
|
if ($this->$key) {
|
|
$data[$this->$key] = [
|
|
'value' => $val,
|
|
'name' => $val,
|
|
];
|
|
}
|
|
}
|
|
|
|
return $data;
|
|
}
|
|
}
|