Приложение Projects, системы Карта Успеха
Материал из m6a
Содержание
Общее описание
Приложение `projects` отвечает за управление проектами в системе "Карта успеха". Каждый проект связан с целью и содержит набор задач для её достижения.
Модель данных
Project
class Project(models.Model): user = models.ForeignKey(User, on_delete=models.CASCADE, related_name='projects') goal = models.ForeignKey(Goal, on_delete=models.CASCADE, related_name='projects') name = models.CharField(max_length=100) description = models.TextField(blank=True) start_date = models.DateField(null=True, blank=True) end_date = models.DateField(null=True, blank=True) completion_percentage = models.IntegerField( default=0, validators=[MinValueValidator(0), MaxValueValidator(100)] ) share_percentage = models.DecimalField( max_digits=5, decimal_places=2, default=0, validators=[MinValueValidator(0), MaxValueValidator(100)] ) is_archived = models.BooleanField(default=False)
Методы модели
def clean(self): """Валидация для дат и процентов.""" if self.start_date and self.end_date and self.end_date < self.start_date: raise ValidationError('End date cannot be earlier than start date.') if not (0 <= self.completion_percentage <= 100): raise ValidationError('Completion percentage must be between 0 and 100.') if not (0 <= self.share_percentage <= 100): raise ValidationError('Share percentage must be between 0 and 100.')
Функциональность
Основные операции
- Создание проектов
- Редактирование проектов
- Удаление проектов
- Просмотр списка проектов
- Просмотр деталей проекта
Управление статусом
- Архивация проектов
- Фильтрация активных/архивных проектов
- Отслеживание прогресса
Дополнительные функции
- Расчет длительности мероприятий
- Управление задачами
- Обновление процента выполнения
URL маршруты
/projects/ ├── # Список проектов ├── '<int:pk>/' # Детали проекта ├── 'create/<int:goal_id>/' # Создание ├── '<int:pk>/update/' # Обновление ├── '<int:pk>/delete/' # Удаление └── 'update_project_completion/<int:pk>/' # Обновление прогресса
Формы
ProjectForm
%%(python nomark) class ProjectForm(forms.ModelForm): fields = [ 'goal', 'name', 'description', 'start_date', 'end_date', 'completion_percentage', 'share_percentage', 'is_archived' ] labels = { 'name': 'Название', 'description': 'Описание', 'goal': 'Цель', 'start_date': 'Дата начала', 'end_date': 'Дата окончания', 'completion_percentage': 'Процент завершения', 'share_percentage': 'Доля в достижении цели', 'is_archived': 'Архивный проект', }
Шаблоны
Основные шаблоны
- `project_list.html` - список проектов
- `project_detail.html` - детали проекта
- `project_form.html` - форма создания/редактирования
Особенности шаблонов
- Фильтрация проектов
- Отображение прогресса
- Управление задачами
- Навигация по хлебным крошкам
Тестирование
Модульные тесты
- Валидация процента выполнения
- Проверка дат
- Тест пустых полей
- Валидация доли в достижении цели
Проверяемые аспекты
- Корректность данных
- Ограничения модели
- Валидация полей
- Связи с целями
Безопасность
Защита
- Декоратор `@login_required`
- Валидация данных
- Проверка прав доступа
- CSRF защита
Валидация
- Проверка процентов
- Валидация дат
- Обязательные поля
- Форматы данных
Интеграция
С другими приложениями
- Связь с целями
- Связь с задачами
- Интеграция с пользователями
Сигналы
- `post_save` - после сохранения
- `post_delete` - после удаления
- Обновление прогресса цели
- Расчет взвешенного завершения
Особенности реализации
Управление прогрессом
- Автоматический расчет
- Взвешенное завершение
- Обновление связанных целей
Отслеживание времени
- Даты начала и окончания
- Длительность мероприятий
- Расчет прогресса
Дополнительные поля
- Доля в достижении цели
- Архивный статус
- Описание проекта