From bbf0c075b8eb79fea2408d5b4e138da682e56510 Mon Sep 17 00:00:00 2001 From: Jacek Pyziak Date: Sun, 8 Feb 2026 01:53:22 +0100 Subject: [PATCH] Release 0.246: migrate banners list to new table --- AGENTS.md | 10 ++ admin/templates/banners/banners-list.php | 81 +---------- autoload/Domain/Banner/BannerRepository.php | 84 +++++++++++ .../admin/Controllers/BannerController.php | 133 ++++++++++++++++-- autoload/admin/controls/class.Banners.php | 64 --------- autoload/admin/view/class.Banners.php | 8 +- updates/0.20/ver_0.246.zip | Bin 0 -> 4979 bytes updates/0.20/ver_0.246_files.txt | 1 + updates/changelog.php | 7 + updates/versions.php | 2 +- 10 files changed, 231 insertions(+), 159 deletions(-) create mode 100644 AGENTS.md delete mode 100644 autoload/admin/controls/class.Banners.php create mode 100644 updates/0.20/ver_0.246.zip create mode 100644 updates/0.20/ver_0.246_files.txt diff --git a/AGENTS.md b/AGENTS.md new file mode 100644 index 0000000..d77e1ff --- /dev/null +++ b/AGENTS.md @@ -0,0 +1,10 @@ +# Workflow + +## KONIEC PRACY + +Gdy użytkownik napisze `KONIEC PRACY`, wykonaj kolejno: + +1. Przeprowadzenie testów. +2. Przygotowanie aktualizacji (ZIP, plik z usuwanymi plikami, plik SQL jeśli wymagany). +3. Commit. +4. Push. diff --git a/admin/templates/banners/banners-list.php b/admin/templates/banners/banners-list.php index f8e485c..3e70c9a 100644 --- a/admin/templates/banners/banners-list.php +++ b/admin/templates/banners/banners-list.php @@ -1,78 +1,5 @@ - $this->viewModel]); ?> -$grid = new \grid( 'pp_banners' ); -$grid -> gdb_opt = $gdb; -$grid -> order = [ 'column' => 'name', 'type' => 'ASC' ]; -$grid -> search = [ - [ 'name' => 'Nazwa', 'db' => 'name', 'type' => 'text' ], - [ 'name' => 'Aktywny', 'db' => 'status', 'type' => 'select', 'replace' => [ 'array' => [ 0 => 'nie', 1 => 'tak' ] ] ] - ]; -$grid -> columns_view = [ - [ - 'name' => 'Lp.', - 'th' => [ 'class' => 'g-lp' ], - 'td' => [ 'class' => 'g-center' ], - 'autoincrement' => true - ], - [ - 'name' => 'Nazwa', - 'db' => 'name', - 'php' => 'echo "[name]";', - 'sort' => true - ], - [ - 'name' => 'Aktywny', - 'db' => 'status', - 'replace' => [ 'array' => [ 0 => 'nie', 1 => 'tak' ] ], - 'th' => [ 'class' => 'g-center', 'style' => 'width: 150px;' ], - 'td' => [ 'class' => 'g-center' ] - ], - [ - 'name' => 'Strona główna', - 'db' => 'home_page', - 'replace' => [ 'array' => [ 0 => 'nie', 1 => 'tak' ] ], - 'th' => [ 'class' => 'g-center', 'style' => 'width: 150px;' ], - 'td' => [ 'class' => 'g-center' ] - ], - [ - 'name' => 'Slajder', - 'db' => 'home_page', - 'replace' => [ 'array' => [ 1 => 'nie', 0 => 'tak' ] ], - 'th' => [ 'class' => 'g-center', 'style' => 'width: 150px;' ], - 'td' => [ 'class' => 'g-center' ] - ], - [ - 'name' => 'Data rozpoczęcia', - 'th' => [ 'class' => 'g-center', 'style' => 'width: 140px;' ], - 'td' => [ 'class' => 'g-center' ], - 'php' => 'if ( "[date_start]" ) echo date( "Y-m-d", strtotime( "[date_start]" ) ); else echo "-";' - ], - [ - 'name' => 'Data zakończenia', - 'th' => [ 'class' => 'g-center', 'style' => 'width: 140px;' ], - 'td' => [ 'class' => 'g-center' ], - 'php' => 'if ( "[date_end]" ) echo date( "Y-m-d", strtotime( "[date_end]" ) ); else echo "-";' - ], - [ - 'name' => 'Edytuj', - 'action' => [ 'type' => 'edit', 'url' => '/admin/banners/banner_edit/id=[id]' ], - 'th' => [ 'class' => 'g-center', 'style' => 'width: 70px;' ], - 'td' => [ 'class' => 'g-center' ] - ], - [ - 'name' => 'Usuń', - 'action' => [ 'type' => 'delete', 'url' => '/admin/banners/banner_delete/id=[id]' ], - 'th' => [ 'class' => 'g-center', 'style' => 'width: 70px;' ], - 'td' => [ 'class' => 'g-center' ] - ] - ]; -$grid -> buttons = [ - [ - 'label' => 'Dodaj baner', - 'url' => '/admin/banners/banner_edit/', - 'icon' => 'fa-plus-circle', - 'class' => 'btn-success' - ] - ]; -echo $grid -> draw(); \ No newline at end of file +viewModel->customScriptView)): ?> + viewModel->customScriptView, ['list' => $this->viewModel]); ?> + diff --git a/autoload/Domain/Banner/BannerRepository.php b/autoload/Domain/Banner/BannerRepository.php index 061609b..16ef283 100644 --- a/autoload/Domain/Banner/BannerRepository.php +++ b/autoload/Domain/Banner/BannerRepository.php @@ -6,6 +6,8 @@ namespace Domain\Banner; */ class BannerRepository { + private const MAX_PER_PAGE = 100; + private $db; public function __construct($db) @@ -82,6 +84,88 @@ class BannerRepository return (int)$bannerId; } + /** + * Zwraca liste banerow do panelu admin z filtrowaniem, sortowaniem i paginacja. + * + * @return array{items: array>, total: int} + */ + public function listForAdmin( + array $filters, + string $sortColumn = 'name', + string $sortDir = 'ASC', + int $page = 1, + int $perPage = 15 + ): array { + $sortColumn = trim($sortColumn); + $sortDir = strtoupper(trim($sortDir)); + + $allowedSortColumns = [ + 'name' => 'b.name', + 'status' => 'b.status', + 'home_page' => 'b.home_page', + 'date_start' => 'b.date_start', + 'date_end' => 'b.date_end', + ]; + + $sortSql = $allowedSortColumns[$sortColumn] ?? 'b.name'; + $sortDir = $sortDir === 'DESC' ? 'DESC' : 'ASC'; + $page = max(1, $page); + $perPage = min(self::MAX_PER_PAGE, max(1, $perPage)); + $offset = ($page - 1) * $perPage; + + $where = ['1=1']; + $params = []; + + $name = trim((string)($filters['name'] ?? '')); + if (strlen($name) > 255) { + $name = substr($name, 0, 255); + } + + if ($name !== '') { + $where[] = 'b.name LIKE :name'; + $params[':name'] = '%' . $name . '%'; + } + + if (($filters['status'] ?? '') !== '' && ($filters['status'] === '0' || $filters['status'] === '1')) { + $where[] = 'b.status = :status'; + $params[':status'] = (int)$filters['status']; + } + + $whereSql = implode(' AND ', $where); + + $sqlCount = " + SELECT COUNT(0) + FROM pp_banners AS b + WHERE {$whereSql} + "; + + $stmtCount = $this->db->query($sqlCount, $params); + $countRows = $stmtCount ? $stmtCount->fetchAll() : []; + $total = isset($countRows[0][0]) ? (int)$countRows[0][0] : 0; + + $sql = " + SELECT + b.id, + b.name, + b.status, + b.home_page, + b.date_start, + b.date_end + FROM pp_banners AS b + WHERE {$whereSql} + ORDER BY {$sortSql} {$sortDir}, b.id {$sortDir} + LIMIT {$perPage} OFFSET {$offset} + "; + + $stmt = $this->db->query($sql, $params); + $items = $stmt ? $stmt->fetchAll() : []; + + return [ + 'items' => is_array($items) ? $items : [], + 'total' => $total, + ]; + } + /** * Zapisuje tłumaczenia banera */ diff --git a/autoload/admin/Controllers/BannerController.php b/autoload/admin/Controllers/BannerController.php index a40e142..3978ff2 100644 --- a/autoload/admin/Controllers/BannerController.php +++ b/autoload/admin/Controllers/BannerController.php @@ -3,14 +3,6 @@ namespace admin\Controllers; use Domain\Banner\BannerRepository; -/** - * Kontroler banerów w panelu administratora (nowa architektura) - * - * Porównanie z starym kontrolerem admin\controls\Banners: - * - Używa Dependency Injection zamiast global $mdb - * - Deleguje logikę do Domain\Banner\BannerRepository - * - Kontroler zajmuje się TYLKO obsługą requestów i odpowiedzi - */ class BannerController { private BannerRepository $repository; @@ -21,12 +13,123 @@ class BannerController } /** - * Lista banerów + * Lista banerow */ public function list(): string { - // Widok nie zmienia się - nadal używamy starego systemu szablonów - return \admin\view\Banners::banners_list(); + $sortableColumns = ['name', 'status', 'home_page', 'date_start', 'date_end']; + + $filterDefinitions = [ + [ + 'key' => 'name', + 'label' => 'Nazwa', + 'type' => 'text', + ], + [ + 'key' => 'status', + 'label' => 'Aktywny', + 'type' => 'select', + 'options' => [ + '' => '- aktywny -', + '1' => 'tak', + '0' => 'nie', + ], + ], + ]; + + $listRequest = \admin\Support\TableListRequestFactory::fromRequest( + $filterDefinitions, + $sortableColumns, + 'name' + ); + + // Historycznie lista banerow domyslnie byla sortowana rosnaco po nazwie. + $sortDir = $listRequest['sortDir']; + if (trim((string)\S::get('sort')) === '') { + $sortDir = 'ASC'; + } + + $result = $this->repository->listForAdmin( + $listRequest['filters'], + $listRequest['sortColumn'], + $sortDir, + $listRequest['page'], + $listRequest['perPage'] + ); + + $rows = []; + $lp = ($listRequest['page'] - 1) * $listRequest['perPage'] + 1; + foreach ($result['items'] as $item) { + $id = (int)$item['id']; + $name = (string)($item['name'] ?? ''); + $homePage = (int)($item['home_page'] ?? 0); + $isActive = (int)($item['status'] ?? 0) === 1; + + $rows[] = [ + 'lp' => $lp++ . '.', + 'name' => '' . htmlspecialchars($name, ENT_QUOTES, 'UTF-8') . '', + 'status' => $isActive ? 'tak' : 'nie', + 'home_page' => $homePage === 1 ? 'tak' : 'nie', + 'slider' => $homePage === 1 ? 'nie' : 'tak', + 'date_start' => !empty($item['date_start']) ? date('Y-m-d', strtotime((string)$item['date_start'])) : '-', + 'date_end' => !empty($item['date_end']) ? date('Y-m-d', strtotime((string)$item['date_end'])) : '-', + '_actions' => [ + [ + 'label' => 'Edytuj', + 'url' => '/admin/banners/banner_edit/id=' . $id, + 'class' => 'btn btn-xs btn-primary', + ], + [ + 'label' => 'Usun', + 'url' => '/admin/banners/banner_delete/id=' . $id, + 'class' => 'btn btn-xs btn-danger', + 'confirm' => 'Na pewno chcesz usunac wybrany element?', + ], + ], + ]; + } + + $total = (int)$result['total']; + $totalPages = max(1, (int)ceil($total / $listRequest['perPage'])); + + $viewModel = new \admin\ViewModels\Common\PaginatedTableViewModel( + [ + ['key' => 'lp', 'label' => 'Lp.', 'class' => 'text-center', 'sortable' => false], + ['key' => 'name', 'sort_key' => 'name', 'label' => 'Nazwa', 'sortable' => true, 'raw' => true], + ['key' => 'status', 'sort_key' => 'status', 'label' => 'Aktywny', 'class' => 'text-center', 'sortable' => true, 'raw' => true], + ['key' => 'home_page', 'sort_key' => 'home_page', 'label' => 'Strona glowna', 'class' => 'text-center', 'sortable' => true, 'raw' => true], + ['key' => 'slider', 'label' => 'Slajder', 'class' => 'text-center', 'sortable' => false, 'raw' => true], + ['key' => 'date_start', 'sort_key' => 'date_start', 'label' => 'Data rozpoczecia', 'class' => 'text-center', 'sortable' => true], + ['key' => 'date_end', 'sort_key' => 'date_end', 'label' => 'Data zakonczenia', 'class' => 'text-center', 'sortable' => true], + ], + $rows, + $listRequest['viewFilters'], + [ + 'column' => $listRequest['sortColumn'], + 'dir' => $sortDir, + ], + [ + 'page' => $listRequest['page'], + 'per_page' => $listRequest['perPage'], + 'total' => $total, + 'total_pages' => $totalPages, + ], + array_merge($listRequest['queryFilters'], [ + 'sort' => $listRequest['sortColumn'], + 'dir' => $sortDir, + 'per_page' => $listRequest['perPage'], + ]), + $listRequest['perPageOptions'], + $sortableColumns, + '/admin/banners/view_list/', + 'Brak danych w tabeli.', + '/admin/banners/banner_edit/', + 'Dodaj baner' + ); + + return \Tpl::view('banners/banners-list', [ + 'viewModel' => $viewModel, + ]); } /** @@ -46,13 +149,13 @@ class BannerController */ public function save(): void { - $response = ['status' => 'error', 'msg' => 'Podczas zapisywania baneru wystąpił błąd. Proszę spróbować ponownie.']; + $response = ['status' => 'error', 'msg' => 'Podczas zapisywania baneru wystapil blad. Prosze sprobowac ponownie.']; $values = json_decode(\S::get('values'), true); $bannerId = $this->repository->save($values); if ($bannerId) { \S::delete_dir('../temp/'); - $response = ['status' => 'ok', 'msg' => 'Baner został zapisany.', 'id' => $bannerId]; + $response = ['status' => 'ok', 'msg' => 'Baner zostal zapisany.', 'id' => $bannerId]; } echo json_encode($response); @@ -60,14 +163,14 @@ class BannerController } /** - * Usunięcie banera + * Usuniecie banera */ public function delete(): void { $bannerId = (int)\S::get('id'); if ($this->repository->delete($bannerId)) { \S::delete_dir('../temp/'); - \S::alert('Baner został usunięty.'); + \S::alert('Baner zostal usuniety.'); } header('Location: /admin/banners/view_list/'); diff --git a/autoload/admin/controls/class.Banners.php b/autoload/admin/controls/class.Banners.php deleted file mode 100644 index 9166a66..0000000 --- a/autoload/admin/controls/class.Banners.php +++ /dev/null @@ -1,64 +0,0 @@ - 'error', 'msg' => 'Podczas zapisywania baneru wystąpił błąd. Proszę spróbować ponownie.' ]; - $values = json_decode( \S::get( 'values' ), true ); - - if ( $banner_id = \admin\factory\Banners::banner_save( $values['id'], $values['name'], $values['status'], $values['date_start'], $values['date_end'], - $values['home_page'], $values['src'], $values['url'], $values['html'], $values['text'] ) ) - $response = [ 'status' => 'ok', 'msg' => 'Baner został zapisany.', 'id' => $banner_id ]; - - echo json_encode( $response ); - exit; - } - - /** - * @deprecated Routing kieruje do admin\Controllers\BannerController::edit(). - * Ta metoda pozostaje tylko jako fallback dla starej architektury. - */ - public static function banner_edit() - { - return \admin\view\Banners::banner_edit( - \admin\factory\Banners::banner_details( - \S::get( 'id' ) - ), - \admin\factory\Languages::languages_list() - ); - } - - /** - * @deprecated Routing kieruje do admin\Controllers\BannerController::list(). - * Ta metoda pozostaje tylko jako fallback dla starej architektury. - */ - public static function view_list() - { - return \admin\view\Banners::banners_list(); - } -} -?> diff --git a/autoload/admin/view/class.Banners.php b/autoload/admin/view/class.Banners.php index ff1ee58..3be6e25 100644 --- a/autoload/admin/view/class.Banners.php +++ b/autoload/admin/view/class.Banners.php @@ -5,8 +5,12 @@ class Banners { public static function banners_list() { - $tpl = new \Tpl; - return $tpl -> render( 'banners/banners-list' ); + // Fallback dla legacy wywolan widoku. + global $mdb; + $controller = new \admin\Controllers\BannerController( + new \Domain\Banner\BannerRepository( $mdb ) + ); + return $controller->list(); } public static function banner_edit( $banner, $languages ) diff --git a/updates/0.20/ver_0.246.zip b/updates/0.20/ver_0.246.zip new file mode 100644 index 0000000000000000000000000000000000000000..6e5ef7e74628dd8e129fde17bb5ef944ea93ed09 GIT binary patch literal 4979 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 fB*Fi!%v{bP#)e``Kd%37DHLCoz?_d7|Y_pLH literal 0 HcmV?d00001 diff --git a/updates/0.20/ver_0.246_files.txt b/updates/0.20/ver_0.246_files.txt new file mode 100644 index 0000000..89f50e9 --- /dev/null +++ b/updates/0.20/ver_0.246_files.txt @@ -0,0 +1 @@ +F: ../autoload/admin/controls/class.Banners.php diff --git a/updates/changelog.php b/updates/changelog.php index db3f9e2..154a66a 100644 --- a/updates/changelog.php +++ b/updates/changelog.php @@ -1,4 +1,11 @@ ver. 0.245
+ver. 0.246
+- UPDATE - migracja listy banerow do nowego mechanizmu tabeli (`components/table-list`, filtrowanie, sortowanie, paginacja) +- UPDATE - `admin\Controllers\BannerController::list()` buduje `PaginatedTableViewModel` +- UPDATE - `Domain\Banner\BannerRepository::listForAdmin()` (bezpieczne filtrowanie i sortowanie) +- UPDATE - usunieto legacy kontroler `autoload/admin/controls/class.Banners.php` +- UPDATE - plik do usuniecia dodany w `updates/0.20/ver_0.246_files.txt` +
ver. 0.245
- UPDATE - refaktoryzacja listy artykulow: wspolny komponent `admin/templates/components/table-list.php` + `PaginatedTableViewModel` - NEW - `admin\Support\TableListRequestFactory` (wspolna obsluga filtrow, sortowania i paginacji dla list) - UPDATE - `Domain\Article\ArticleRepository::listForAdmin()` utwardzone pod katem bezpieczenstwa (whitelist sortowania, bind params, limit per_page) diff --git a/updates/versions.php b/updates/versions.php index 612883e..2fd9f0c 100644 --- a/updates/versions.php +++ b/updates/versions.php @@ -1,5 +1,5 @@