From 6c124e9bb7f53320aaa3b68936183cb17dec9e63 Mon Sep 17 00:00:00 2001 From: stasbilay02 Date: Tue, 3 Dec 2024 16:16:36 +0300 Subject: [PATCH] slider --- app/modules/slider/SliderModule.php | 38 ++++++++++++++++ .../slider/controllers/SliderController.php | 35 +++++++++++++++ app/modules/slider/manifest.json | 13 ++++++ .../2024_12_03_124749_create_slider_table.php | 31 +++++++++++++ app/modules/slider/models/Slider.php | 39 +++++++++++++++++ app/modules/slider/routs/slider.php | 20 +++++++++ app/modules/slider/views/index.php | 43 +++++++++++++++++++ app/modules/slider/views/view.php | 29 +++++++++++++ 8 files changed, 248 insertions(+) create mode 100644 app/modules/slider/SliderModule.php create mode 100644 app/modules/slider/controllers/SliderController.php create mode 100644 app/modules/slider/manifest.json create mode 100644 app/modules/slider/migrations/2024_12_03_124749_create_slider_table.php create mode 100644 app/modules/slider/models/Slider.php create mode 100644 app/modules/slider/routs/slider.php create mode 100644 app/modules/slider/views/index.php create mode 100644 app/modules/slider/views/view.php diff --git a/app/modules/slider/SliderModule.php b/app/modules/slider/SliderModule.php new file mode 100644 index 0000000..41839b5 --- /dev/null +++ b/app/modules/slider/SliderModule.php @@ -0,0 +1,38 @@ +menuService = new MenuService(); + $this->migrationService = new MigrationService(); + } + + /** + * @throws \Exception + */ + public function init(): void + { + $this->migrationService->runAtPath("{KERNEL_APP_MODULES}/slider/migrations"); + + $this->menuService->createItem([ + "label" => "Слайдер", + "url" => "/admin/slider", + "slug" => "slider", + ]); + } + + public function deactivate(): void + { + $this->menuService->removeItemBySlug("slider"); + } +} \ No newline at end of file diff --git a/app/modules/slider/controllers/SliderController.php b/app/modules/slider/controllers/SliderController.php new file mode 100644 index 0000000..a2f5226 --- /dev/null +++ b/app/modules/slider/controllers/SliderController.php @@ -0,0 +1,35 @@ +cgView->viewPath = KERNEL_APP_MODULES_DIR . "/photo/views/"; + } + + + public function actionIndex($page_number = 1): void + { + $this->cgView->render("index.php", ['page_number' => $page_number]); + } + + /** + * @throws Exception + */ + public function actionView($id): void + { + $slide = Slider::find($id); + + if (!$slide){ + throw new Exception(message: "The slide not found"); + } + $this->cgView->render("view.php", ['slider' => $slide]); + } +} \ No newline at end of file diff --git a/app/modules/slider/manifest.json b/app/modules/slider/manifest.json new file mode 100644 index 0000000..65a4bfe --- /dev/null +++ b/app/modules/slider/manifest.json @@ -0,0 +1,13 @@ +{ + "name": "Slider", + "version": "0.1", + "author": "ITGuild", + "slug": "slider", + "type": "entity", + "description": "Slider module", + "app_module_path": "{APP}/modules/{slug}", + "module_class": "app\\modules\\slider\\SliderModule", + "module_class_file": "{APP}/modules/slider/SliderModule.php", + "routs": "routs/slider.php", + "dependence": "menu, user" +} diff --git a/app/modules/slider/migrations/2024_12_03_124749_create_slider_table.php b/app/modules/slider/migrations/2024_12_03_124749_create_slider_table.php new file mode 100644 index 0000000..0761ec2 --- /dev/null +++ b/app/modules/slider/migrations/2024_12_03_124749_create_slider_table.php @@ -0,0 +1,31 @@ +schema->create('slider', function (Blueprint $table) { + $table->increments('id'); + $table->string('title', 255)->nullable(false); + $table->string('additional_information', 255)->nullable(false); + $table->string('content', 255)->nullable(false); + $table->integer('status')->default(0); + $table->timestamps(); + }); + } + + /** + * Reverse the migrations. + */ + public function down(): void + { + \kernel\App::$db->schema->dropIfExists('slider'); + } +}; diff --git a/app/modules/slider/models/Slider.php b/app/modules/slider/models/Slider.php new file mode 100644 index 0000000..d960dcf --- /dev/null +++ b/app/modules/slider/models/Slider.php @@ -0,0 +1,39 @@ + 'Заголовок', + 'additional_information' => 'Дополнительная информация', + 'content' => 'Контент' + ]; + } + + public static function getStatus(): array + { + return [ + self::DISABLE_STATUS => "Не активный", + self::ACTIVE_STATUS => "Активный", + ]; + } + +} \ No newline at end of file diff --git a/app/modules/slider/routs/slider.php b/app/modules/slider/routs/slider.php new file mode 100644 index 0000000..b25a24c --- /dev/null +++ b/app/modules/slider/routs/slider.php @@ -0,0 +1,20 @@ +group(["prefix" => "admin"], function (CgRouteCollector $router) { + App::$collector->group(["before" => "auth"], function (RouteCollector $router) { + App::$collector->group(["prefix" => "slider"], function (CGRouteCollector $router) { + App::$collector->get('/', [\app\modules\slider\controllers\SliderController::class, 'actionIndex']); + App::$collector->get('/page/{page_number}', [\app\modules\slider\controllers\SliderController::class, 'actionIndex']); + App::$collector->get('/create', [\app\modules\slider\controllers\SliderController::class, 'actionCreate']); + App::$collector->post("/", [\app\modules\slider\controllers\SliderController::class, 'actionAdd']); + App::$collector->get('/view/{id}', [\app\modules\slider\controllers\SliderController::class, 'actionView']); + App::$collector->any('/update/{id}', [\app\modules\slider\controllers\SliderController::class, 'actionUpdate']); + App::$collector->any("/edit/{id}", [\app\modules\slider\controllers\SliderController::class, 'actionEdit']); + App::$collector->get('/delete/{id}', [\app\modules\slider\controllers\SliderController::class]); + }); + }); +}); \ No newline at end of file diff --git a/app/modules/slider/views/index.php b/app/modules/slider/views/index.php new file mode 100644 index 0000000..e652162 --- /dev/null +++ b/app/modules/slider/views/index.php @@ -0,0 +1,43 @@ + $page_number, + 'perPage' => 8, + 'params' => ["class" => "table table-bordered", "border" => "2"], + 'baseUrl' => "/admin/photo", +])); + +$table->beforePrint(function () { + return IconBtnCreateWidget::create(['url' => '/admin/slider/create'])->run(); +}); + +$table->columns([ + "status" => [ + "value" => function ($cell) { + return Slider::getStatus()[$cell]; + }] +]); + +$table->addAction(function($row) { + return IconBtnViewWidget::create(['url' => '/admin/slider/view/' . $row['id']])->run(); +}); +$table->addAction(function($row) { + return IconBtnEditWidget::create(['url' => '/admin/slider/update/' . $row['id']])->run(); +}); +$table->addAction(function($row) { + return IconBtnDeleteWidget::create(['url' => '/admin/slider/delete/' . $row['id']])->run(); +}); +$table->create(); +$table->render(); \ No newline at end of file diff --git a/app/modules/slider/views/view.php b/app/modules/slider/views/view.php new file mode 100644 index 0000000..8c799f6 --- /dev/null +++ b/app/modules/slider/views/view.php @@ -0,0 +1,29 @@ + ["class" => "table table-bordered", "border" => "2"], + 'baseUrl' => "/admin/slider", +])); +$table->beforePrint(function () use ($slider) { + $btn = PrimaryBtn::create("Список", "/admin/slider")->fetch(); + $btn .= SuccessBtn::create("Редактировать", "/admin/slider/update/" . $slider->id)->fetch(); + $btn .= DangerBtn::create("Удалить", "/admin/slider/delete/" . $slider->id)->fetch(); + return $btn; +}); +$table->rows([ + 'status' => (function ($data) { + return \app\modules\slider\models\Slider::getStatus()[$data]; + }) +]); +$table->create(); +$table->render(); \ No newline at end of file