Skip to content

Commit 56e3c6d

Browse files
committed
Init Action page for library
1 parent 08e7e41 commit 56e3c6d

File tree

6 files changed

+197
-0
lines changed

6 files changed

+197
-0
lines changed
Lines changed: 29 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,29 @@
1+
@extends('layout')
2+
@section('title', 'Один класс — одна задача')
3+
@section('description', 'Каждый класс в приложении должен отвечать только за одну конкретную задачу или функциональность.')
4+
@section('content')
5+
6+
<x-header align="align-items-end">
7+
<x-slot name="sup">Чистота и порядок</x-slot>
8+
<x-slot name="title">Один класс — одна задача</x-slot>
9+
<x-slot name="description">
10+
Каждый класс в приложении должен отвечать только за одну конкретную задачу или функциональность.
11+
</x-slot>
12+
<x-slot name="content">
13+
<img src="/img/gusli.svg" class="img-fluid d-block mx-auto">
14+
</x-slot>
15+
</x-header>
16+
17+
@php
18+
$sections = collect([
19+
'basics',
20+
'focus',
21+
'conventions',
22+
'tests',
23+
])
24+
->map(fn ($file) => \Illuminate\Support\Str::of($file)->start('actions/'))
25+
->map(fn ($file) => new \App\Library($file));
26+
@endphp
27+
28+
@include('particles.library-section', ['sections' => $sections])
29+
@endsection

routes/web.php

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -63,6 +63,7 @@
6363
Route::view('/library/how-to-ask', 'library.how-to-ask')->name('library.how-to-ask');
6464
Route::view('/library/collection', 'library.collection')->name('library.collection');
6565
Route::view('/library/solid', 'library.solid')->name('library.solid');
66+
Route::view('/library/actions', 'library.actions')->name('library.actions');
6667
/*
6768
|--------------------------------------------------------------------------
6869
| Open Quiz

storage/library/actions/basics.md

Lines changed: 21 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,21 @@
1+
---
2+
title: "Основы"
3+
description: "Что такое принцип 'Один класс — одна задача'?"
4+
---
5+
6+
Принцип «Один класс — одна задача» (One Class, One Task) предполагает, что каждый класс в приложении должен отвечать
7+
только за одну конкретную задачу или функциональность. Это упрощает структуру кода, делает его более понятным и легким
8+
для поддержки. В контексте Laravel этот подход помогает организовать бизнес-логику в виде отдельных классов, которые
9+
выполняют конкретные действия, что позволяет избежать перегруженности классов и улучшает читаемость кода.
10+
11+
Преимущества использования принципа «Один класс — одна задача»:
12+
13+
- **Читаемость кода**: каждый класс отвечает только за одну задачу, что упрощает понимание его назначения и логики.
14+
- **Поддерживаемость**: изменение и тестирование классов становится проще, так как каждый класс содержит только одну
15+
задачу.
16+
- **Изоляция логики**: каждый класс действия изолирован от других частей приложения, что упрощает его тестирование и
17+
поддержку.
18+
- **Повторное использование**: классы действий могут быть повторно использованы в разных частях приложения, что
19+
упрощает разработку и поддержку кода.
20+
- **Улучшение архитектуры**: применение принципа «Один класс — одна задача» помогает улучшить архитектуру вашего
21+
приложения, сделав его более гибким и масштабируемым.
Lines changed: 62 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,62 @@
1+
---
2+
title: "Рекомендуемые соглашения"
3+
description: "Помогут вам оставаться последовательными при организации вашего приложения"
4+
---
5+
6+
**Начните с глагола**
7+
8+
Назовите свои классы действий как небольшие явные предложения, начинающиеся с глагола. Например, действие, которое
9+
«отправляет электронное письмо пользователю для сброса пароля», можно назвать `SendResetPasswordEmail`. Такой подход
10+
делает названия классов самодокументированными и легко понятными, что улучшает читабельность кода.
11+
12+
**Используйте папку `Actions`**
13+
14+
Создайте папку `app/Actions` и сгруппируйте свои действия внутри неё по темам. Это помогает поддерживать структуру
15+
вашего кода организованной и логичной. Например:
16+
17+
```php
18+
app/
19+
├── Actions/
20+
│ ├── Authentication/
21+
│ │ ├── LoginUser.php
22+
│ │ ├── RegisterUser.php
23+
│ │ ├── ResetUserPassword.php
24+
│ │ └── SendResetPasswordEmail.php
25+
│ ├── Leads/
26+
│ │ ├── BulkRemoveLead.php
27+
│ │ ├── CreateNewLead.php
28+
│ │ ├── GetLeadDetails.php
29+
│ │ ├── MarkLeadAsCustomer.php
30+
│ │ ├── MarkLeadAsLost.php
31+
│ │ ├── RemoveLead.php
32+
│ │ ├── SearchLeadsForUser.php
33+
│ │ └── UpdateLeadDetails.php
34+
│ └── Settings/
35+
│ ├── GetUserSettings.php
36+
│ ├── UpdateUserAvatar.php
37+
│ ├── UpdateUserDetails.php
38+
│ ├── UpdateUserPassword.php
39+
│ └── DeleteUserAccount.php
40+
├── Models/
41+
└── ...
42+
```
43+
44+
В качестве альтернативы, если ваше приложение уже разделено на темы — или модули — вы можете создать папку `Actions` под
45+
каждым из этих модулей. Например:
46+
47+
```php
48+
app/
49+
├── Authentication/
50+
│ ├── Actions/
51+
│ ├── Models/
52+
│ └── ...
53+
├── Leads/
54+
│ ├── Actions/
55+
│ ├── Models/
56+
│ └── ...
57+
└── Settings/
58+
├── Actions/
59+
└── ...
60+
```
61+
62+
Такая организация помогает вам поддерживать порядок в коде и упрощает его навигацию.

storage/library/actions/focus.md

Lines changed: 77 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,77 @@
1+
---
2+
title: "Фокус на работе приложения"
3+
description: "Что такое принцип 'Один класс — одна задача'?"
4+
---
5+
6+
Использование `Actions` позволяет сосредоточиться на бизнес-логике приложения, а не на технических деталях.
7+
Классы `Action` выполняют конкретные задачи и изолируют их от других частей приложения, что упрощает понимание кода и
8+
его поддержку. Логика, связанная с выполнением одной задачи, собирается в одном месте, что облегчает её изменение и тестирование.
9+
10+
11+
```php
12+
class GenerateReservationCode
13+
{
14+
const UNAMBIGUOUS_ALPHABET = 'BCDFGHJLMNPRSTVWXYZ2456789';
15+
16+
public function __invoke(int $characters = 7): string
17+
{
18+
do {
19+
$code = $this->generateCode($characters);
20+
} while (Reservation::where('code', $code)->exists());
21+
22+
return $code;
23+
}
24+
25+
protected function generateCode(int $characters): string
26+
{
27+
return substr(str_shuffle(str_repeat(static::UNAMBIGUOUS_ALPHABET, $characters)), 0, $characters);
28+
}
29+
}
30+
```
31+
32+
Это позволит вам вызывать объект класса, как если бы он был функцией. Например:
33+
```php
34+
$generator = new GenerateReservationCode();
35+
$reservationCode = $generator(8); // Генерация кода длиной 8 символов
36+
```
37+
38+
39+
В это системе Laravel есть прекрасный пакет `Laravel Actions` — это пакет, который предлагает новый способ организации
40+
логики вашего Laravel-приложения, сосредоточив внимание на действиях, которые выполняет ваше приложение. Вместо создания
41+
контроллеров, джобов, слушателей и других элементов, этот пакет позволяет создавать PHP-классы, каждый из которых
42+
выполняет одну конкретную задачу. Эти классы можно запускать как угодно: из контроллеров, консольных команд, событий и
43+
так далее.
44+
45+
```php
46+
class GenerateReservationCode
47+
{
48+
use AsAction;
49+
50+
const UNAMBIGUOUS_ALPHABET = 'BCDFGHJLMNPRSTVWXYZ2456789';
51+
52+
public function handle(int $characters = 7): string
53+
{
54+
do {
55+
$code = $this->generateCode($characters);
56+
} while(Reservation::where('code', $code)->exists());
57+
58+
return $code;
59+
}
60+
61+
protected function generateCode(int $characters): string
62+
{
63+
return substr(str_shuffle(str_repeat(static::UNAMBIGUOUS_ALPHABET, $characters)), 0, $characters);
64+
}
65+
}
66+
```
67+
68+
и вызывать его так:
69+
```php
70+
GenerateReservationCode::run() // Генерация кода длиной 7 символов
71+
```
72+
73+
> **Примечание** Вы можете узнать больше об удобстве использование действий с пакетом `Laravel Actions` на его [официальном сайте](https://laravelactions.com/).
74+
75+
Но вам не обязательно использовать пакет, чтобы следовать принципу «Один класс — одна задача». Вы можете создавать свои
76+
собственные классы действий, используя стандартные средства Laravel/PHP. Важно помнить, что главная цель — разделить логику
77+
вашего приложения на небольшие, легко понимаемые и поддерживаемые части.

storage/library/actions/tests.md

Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,7 @@
1+
---
2+
title: "Тестирование"
3+
description: "Что такое принцип 'Один класс — одна задача'?"
4+
---
5+
6+
Поскольку каждый `Action` отвечает за одну задачу, его тестирование становится более простым и эффективным.
7+
Вы можете изолировать и протестировать каждое действие отдельно, что упрощает написание и выполнение тестов.

0 commit comments

Comments
 (0)