1
0
mirror of https://github.com/invoiceninja/invoiceninja.git synced 2024-11-10 05:02:36 +01:00
invoiceninja/app/Ninja/Datatables/CreditDatatable.php

78 lines
2.0 KiB
PHP
Raw Normal View History

<?php
namespace App\Ninja\Datatables;
2016-05-23 18:52:20 +02:00
use Utils;
use URL;
use Auth;
/**
* Class CreditDatatable
*/
2016-05-23 18:52:20 +02:00
class CreditDatatable extends EntityDatatable
{
public $entityType = ENTITY_CREDIT;
/**
* @return array
*/
2016-05-23 18:52:20 +02:00
public function columns()
{
return [
[
'client_name',
function ($model) {
if(!Auth::user()->can('viewByOwner', [ENTITY_CLIENT, $model->client_user_id])){
return Utils::getClientDisplayName($model);
}
return $model->client_public_id ? link_to("clients/{$model->client_public_id}", Utils::getClientDisplayName($model))->toHtml() : '';
},
! $this->hideClient
],
[
'amount',
function ($model) {
return Utils::formatMoney($model->amount, $model->currency_id, $model->country_id) . '<span '.Utils::getEntityRowClass($model).'/>';
}
],
[
'balance',
function ($model) {
return Utils::formatMoney($model->balance, $model->currency_id, $model->country_id);
}
],
[
'credit_date',
function ($model) {
return Utils::fromSqlDate($model->credit_date);
}
],
[
'private_notes',
function ($model) {
return $model->private_notes;
}
]
];
}
/**
* @return array
*/
2016-05-23 18:52:20 +02:00
public function actions()
{
return [
[
trans('texts.apply_credit'),
function ($model) {
return URL::to("payments/create/{$model->client_public_id}") . '?paymentTypeId=1';
},
function () {
2016-05-23 18:52:20 +02:00
return Auth::user()->can('create', ENTITY_PAYMENT);
}
]
];
}
}