|
|
|
@ -104,7 +104,7 @@ class ListJsonTable extends JasonTable
|
|
|
|
|
$this->getCustomColumns($row["id"] ?? null);
|
|
|
|
|
if ($this->showActionColumn) {
|
|
|
|
|
if (isset($row["id"])) {
|
|
|
|
|
$actions = $this->getActions($row["id"]);
|
|
|
|
|
$actions = $this->getActions($row);
|
|
|
|
|
|
|
|
|
|
$this->html .= "<td>$actions</td></tr>";
|
|
|
|
|
} else {
|
|
|
|
@ -115,7 +115,7 @@ class ListJsonTable extends JasonTable
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function addAction(string $actionColumn): void
|
|
|
|
|
public function addAction(string|\Closure $actionColumn): void
|
|
|
|
|
{
|
|
|
|
|
$this->customActionsArray[] = $actionColumn;
|
|
|
|
|
}
|
|
|
|
@ -148,9 +148,9 @@ class ListJsonTable extends JasonTable
|
|
|
|
|
|
|
|
|
|
private function getCurrentFilter(string $column)
|
|
|
|
|
{
|
|
|
|
|
if (is_array($this->beforePrintCell[$column])) {
|
|
|
|
|
if (isset($this->beforePrintCell[$column]) and is_array($this->beforePrintCell[$column])) {
|
|
|
|
|
if (isset($this->beforePrintCell[$column]['filter'])) {
|
|
|
|
|
if (is_array($this->beforePrintCell[$column]['filter'])) {
|
|
|
|
|
if (isset($this->beforePrintCell[$column]['filter']) and is_array($this->beforePrintCell[$column]['filter'])) {
|
|
|
|
|
return $this->beforePrintCell[$column]['filter'];
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
@ -183,7 +183,6 @@ class ListJsonTable extends JasonTable
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private function getColumnKeys(): array
|
|
|
|
|
{
|
|
|
|
|
$columnKeys = [];
|
|
|
|
@ -254,12 +253,16 @@ class ListJsonTable extends JasonTable
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private function getActions(int $id): string
|
|
|
|
|
private function getActions(array $row): string
|
|
|
|
|
{
|
|
|
|
|
$actions = "";
|
|
|
|
|
foreach ($this->actionsArray as $item) {
|
|
|
|
|
$objItem = new $item($this->baseUrl, $id);
|
|
|
|
|
if (is_string($item)) {
|
|
|
|
|
$objItem = new $item($this->baseUrl, $row['id']);
|
|
|
|
|
$actions .= $objItem->fetch();
|
|
|
|
|
} else {
|
|
|
|
|
$actions .= $item($row, $this->baseUrl);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return $actions;
|
|
|
|
@ -279,16 +282,17 @@ class ListJsonTable extends JasonTable
|
|
|
|
|
if ($filter) {
|
|
|
|
|
$class = new $filter['class']($params);
|
|
|
|
|
$this->html .= $class->fetch();
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
} else {
|
|
|
|
|
$class = new InputTextFilter($params);
|
|
|
|
|
$this->html .= $class->fetch();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
} else {
|
|
|
|
|
$this->html .= "<td></td>";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if ($this->showActionColumn) {
|
|
|
|
|
$this->html .= "<td></td>";
|
|
|
|
|
}
|
|
|
|
|
$this->html .= "</form></tr>";
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -325,7 +329,7 @@ class ListJsonTable extends JasonTable
|
|
|
|
|
$hookAfter = $this->afterPrintHook;
|
|
|
|
|
$this->html .= $hookAfter($this->data['meta']);
|
|
|
|
|
|
|
|
|
|
if ($this->pagination) {
|
|
|
|
|
if ($this->pagination && $this->data['data']) {
|
|
|
|
|
$options = [
|
|
|
|
|
'countItem' => $this->data['meta']['total'],
|
|
|
|
|
'perPage' => $this->data['meta']['perPage'] ?? 10,
|
|
|
|
|