From d747203d99871ab39a5f18c449727f150b937c44 Mon Sep 17 00:00:00 2001 From: Kavalar Date: Mon, 2 Sep 2024 22:34:25 +0300 Subject: [PATCH] custom action --- examples/simple.php | 3 +++ src/ListJsonTable.php | 33 +++++++++++++++++---------------- 2 files changed, 20 insertions(+), 16 deletions(-) diff --git a/examples/simple.php b/examples/simple.php index fe51fc2..e8ed8c5 100644 --- a/examples/simple.php +++ b/examples/simple.php @@ -68,6 +68,9 @@ $table->addColumn("Колонка 33", "k33", function ($id) { $table->addColumn("Колонка 34", "k34", function ($id) { return "some34"; }); +$table->addAction(function($row, $url){ + return "Написать"; +}); $table->create(); $table->render(); diff --git a/src/ListJsonTable.php b/src/ListJsonTable.php index 53a4d30..1907da8 100644 --- a/src/ListJsonTable.php +++ b/src/ListJsonTable.php @@ -71,7 +71,7 @@ class ListJsonTable extends JasonTable if ($this->showActionColumn) { $this->html .= "Действия"; } - if($this->showFiltersRow){ + if ($this->showFiltersRow) { $this->getFilters($columnKeys); $this->html .= ""; } @@ -92,8 +92,8 @@ class ListJsonTable extends JasonTable } foreach ($row as $key => $cell) { if ($this->issetColumn($key) and $this->is_fillable($key)) { - if($this->beforePrintCell) { - if ($key === "id" and $cell === 0){ + if ($this->beforePrintCell) { + if ($key === "id" and $cell === 0) { $cell = $this->count; } $cell = $this->getCustomCell($key, $cell); @@ -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 .= "$actions"; } 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; } @@ -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); - $actions .= $objItem->fetch(); + if (is_string($item)) { + $objItem = new $item($this->baseUrl, $row['id']); + $actions .= $objItem->fetch(); + } else { + $actions .= $item($row, $this->baseUrl); + } } return $actions; @@ -268,24 +271,22 @@ class ListJsonTable extends JasonTable private function getFilters(array $columnKeys): void { $this->html .= "
"; - foreach ($columnKeys as $key){ - if ($this->issetFilter($key)){ + foreach ($columnKeys as $key) { + if ($this->issetFilter($key)) { $filter = $this->getCurrentFilter($key); $params = [ 'param' => $filter['param'] ?? '', 'name' => $key, 'value' => $filter['value'] ?? '', ]; - if ($filter){ + 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 .= ""; } }