mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2024-11-10 13:12:50 +01:00
122 lines
4.9 KiB
PHP
122 lines
4.9 KiB
PHP
<?php namespace App\Services;
|
|
|
|
use HtmlString;
|
|
use Utils;
|
|
use Datatable;
|
|
use Auth;
|
|
|
|
class DatatableService
|
|
{
|
|
public function createDatatable($entityType, $query, $columns, $actions = null, $showCheckbox = true, $orderColumns = [])
|
|
{
|
|
$table = Datatable::query($query);
|
|
$calculateOrderColumns = empty($orderColumns);
|
|
|
|
if ($actions && $showCheckbox) {
|
|
$table->addColumn('checkbox', function ($model) {
|
|
$can_edit = Auth::user()->hasPermission('edit_all') || (isset($model->user_id) && Auth::user()->id == $model->user_id);
|
|
|
|
return !$can_edit?'':'<input type="checkbox" name="ids[]" value="' . $model->public_id
|
|
. '" ' . Utils::getEntityRowClass($model) . '>';
|
|
});
|
|
}
|
|
|
|
foreach ($columns as $column) {
|
|
// set visible to true by default
|
|
if (count($column) == 2) {
|
|
$column[] = true;
|
|
}
|
|
|
|
list($field, $value, $visible) = $column;
|
|
|
|
if ($visible) {
|
|
$table->addColumn($field, $value);
|
|
if ($calculateOrderColumns) {
|
|
$orderColumns[] = $field;
|
|
}
|
|
}
|
|
}
|
|
|
|
if ($actions) {
|
|
$this->createDropdown($entityType, $table, $actions);
|
|
}
|
|
|
|
return $table->orderColumns($orderColumns)->make();
|
|
}
|
|
|
|
private function createDropdown($entityType, $table, $actions)
|
|
{
|
|
$table->addColumn('dropdown', function ($model) use ($entityType, $actions) {
|
|
$hasAction = false;
|
|
$str = '<center style="min-width:100px">';
|
|
|
|
$can_edit = Auth::user()->hasPermission('edit_all') || (isset($model->user_id) && Auth::user()->id == $model->user_id);
|
|
|
|
if (property_exists($model, 'is_deleted') && $model->is_deleted) {
|
|
$str .= '<button type="button" class="btn btn-sm btn-danger tr-status">'.trans('texts.deleted').'</button>';
|
|
} elseif ($model->deleted_at && $model->deleted_at !== '0000-00-00') {
|
|
$str .= '<button type="button" class="btn btn-sm btn-warning tr-status">'.trans('texts.archived').'</button>';
|
|
} else {
|
|
$str .= '<div class="tr-status"></div>';
|
|
}
|
|
|
|
$str .= '<div class="btn-group tr-action" style="height:auto;display:none">
|
|
<button type="button" class="btn btn-xs btn-default dropdown-toggle" data-toggle="dropdown" style="width:100px">
|
|
'.trans('texts.select').' <span class="caret"></span>
|
|
</button>
|
|
<ul class="dropdown-menu" role="menu">';
|
|
|
|
$lastIsDivider = false;
|
|
if (!$model->deleted_at || $model->deleted_at == '0000-00-00') {
|
|
foreach ($actions as $action) {
|
|
if (count($action)) {
|
|
if (count($action) == 2) {
|
|
$action[] = function() {
|
|
return true;
|
|
};
|
|
}
|
|
list($value, $url, $visible) = $action;
|
|
if ($visible($model)) {
|
|
if($value == '--divider--'){
|
|
$str .= "<li class=\"divider\"></li>";
|
|
$lastIsDivider = true;
|
|
}
|
|
else {
|
|
$str .= "<li><a href=\"{$url($model)}\">{$value}</a></li>";
|
|
$hasAction = true;
|
|
$lastIsDivider = false;
|
|
}
|
|
}
|
|
} elseif ( ! $lastIsDivider) {
|
|
$str .= "<li class=\"divider\"></li>";
|
|
$lastIsDivider = true;
|
|
}
|
|
}
|
|
|
|
if ( ! $hasAction) {
|
|
return '';
|
|
}
|
|
|
|
if ( $can_edit && ! $lastIsDivider) {
|
|
$str .= "<li class=\"divider\"></li>";
|
|
}
|
|
|
|
if (($entityType != ENTITY_USER || $model->public_id) && $can_edit) {
|
|
$str .= "<li><a href=\"javascript:archiveEntity({$model->public_id})\">"
|
|
. trans("texts.archive_{$entityType}") . "</a></li>";
|
|
}
|
|
} else if($can_edit) {
|
|
$str .= "<li><a href=\"javascript:restoreEntity({$model->public_id})\">"
|
|
. trans("texts.restore_{$entityType}") . "</a></li>";
|
|
}
|
|
|
|
if (property_exists($model, 'is_deleted') && !$model->is_deleted && $can_edit) {
|
|
$str .= "<li><a href=\"javascript:deleteEntity({$model->public_id})\">"
|
|
. trans("texts.delete_{$entityType}") . "</a></li>";
|
|
}
|
|
|
|
return $str.'</ul></div></center>';
|
|
});
|
|
}
|
|
|
|
} |