custom action

This commit is contained in:
Kavalar 2024-09-02 22:34:25 +03:00
parent ad18d94489
commit d747203d99
2 changed files with 20 additions and 16 deletions

View File

@ -68,6 +68,9 @@ $table->addColumn("Колонка 33", "k33", function ($id) {
$table->addColumn("Колонка 34", "k34", function ($id) { $table->addColumn("Колонка 34", "k34", function ($id) {
return "some34"; return "some34";
}); });
$table->addAction(function($row, $url){
return "<a href='mailto:". $row['email'] ."'>Написать</a>";
});
$table->create(); $table->create();
$table->render(); $table->render();

View File

@ -71,7 +71,7 @@ class ListJsonTable extends JasonTable
if ($this->showActionColumn) { if ($this->showActionColumn) {
$this->html .= "<th>Действия</th></th></tr>"; $this->html .= "<th>Действия</th></th></tr>";
} }
if($this->showFiltersRow){ if ($this->showFiltersRow) {
$this->getFilters($columnKeys); $this->getFilters($columnKeys);
$this->html .= "</thead>"; $this->html .= "</thead>";
} }
@ -92,8 +92,8 @@ class ListJsonTable extends JasonTable
} }
foreach ($row as $key => $cell) { foreach ($row as $key => $cell) {
if ($this->issetColumn($key) and $this->is_fillable($key)) { if ($this->issetColumn($key) and $this->is_fillable($key)) {
if($this->beforePrintCell) { if ($this->beforePrintCell) {
if ($key === "id" and $cell === 0){ if ($key === "id" and $cell === 0) {
$cell = $this->count; $cell = $this->count;
} }
$cell = $this->getCustomCell($key, $cell); $cell = $this->getCustomCell($key, $cell);
@ -104,7 +104,7 @@ class ListJsonTable extends JasonTable
$this->getCustomColumns($row["id"] ?? null); $this->getCustomColumns($row["id"] ?? null);
if ($this->showActionColumn) { if ($this->showActionColumn) {
if (isset($row["id"])) { if (isset($row["id"])) {
$actions = $this->getActions($row["id"]); $actions = $this->getActions($row);
$this->html .= "<td>$actions</td></tr>"; $this->html .= "<td>$actions</td></tr>";
} else { } 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; $this->customActionsArray[] = $actionColumn;
} }
@ -183,7 +183,6 @@ class ListJsonTable extends JasonTable
} }
private function getColumnKeys(): array private function getColumnKeys(): array
{ {
$columnKeys = []; $columnKeys = [];
@ -254,12 +253,16 @@ class ListJsonTable extends JasonTable
return false; return false;
} }
private function getActions(int $id): string private function getActions(array $row): string
{ {
$actions = ""; $actions = "";
foreach ($this->actionsArray as $item) { foreach ($this->actionsArray as $item) {
$objItem = new $item($this->baseUrl, $id); if (is_string($item)) {
$actions .= $objItem->fetch(); $objItem = new $item($this->baseUrl, $row['id']);
$actions .= $objItem->fetch();
} else {
$actions .= $item($row, $this->baseUrl);
}
} }
return $actions; return $actions;
@ -268,24 +271,22 @@ class ListJsonTable extends JasonTable
private function getFilters(array $columnKeys): void private function getFilters(array $columnKeys): void
{ {
$this->html .= "<tr><form action='$this->baseUrl/search'>"; $this->html .= "<tr><form action='$this->baseUrl/search'>";
foreach ($columnKeys as $key){ foreach ($columnKeys as $key) {
if ($this->issetFilter($key)){ if ($this->issetFilter($key)) {
$filter = $this->getCurrentFilter($key); $filter = $this->getCurrentFilter($key);
$params = [ $params = [
'param' => $filter['param'] ?? '', 'param' => $filter['param'] ?? '',
'name' => $key, 'name' => $key,
'value' => $filter['value'] ?? '', 'value' => $filter['value'] ?? '',
]; ];
if ($filter){ if ($filter) {
$class = new $filter['class']($params); $class = new $filter['class']($params);
$this->html .= $class->fetch(); $this->html .= $class->fetch();
} } else {
else {
$class = new InputTextFilter($params); $class = new InputTextFilter($params);
$this->html .= $class->fetch(); $this->html .= $class->fetch();
} }
} } else {
else {
$this->html .= "<td></td>"; $this->html .= "<td></td>";
} }
} }