2024-12-23 11:26:41 +00:00
|
|
|
|
using data.RemoteData;
|
|
|
|
|
using data.RemoteData.DAO;
|
2024-12-23 11:20:09 +00:00
|
|
|
|
using domain.Models;
|
|
|
|
|
using Microsoft.EntityFrameworkCore;
|
|
|
|
|
|
|
|
|
|
namespace data.Repository
|
|
|
|
|
{
|
2024-12-23 11:26:41 +00:00
|
|
|
|
// Реализация интерфейса IPresenceRepository для работы с посещаемостью
|
2024-12-23 11:20:09 +00:00
|
|
|
|
public class SQLPresenceRepositoryImpl : IPresenceRepository
|
|
|
|
|
{
|
|
|
|
|
private readonly RemoteDatabaseContext _remoteDatabaseContext;
|
|
|
|
|
|
2024-12-23 11:26:41 +00:00
|
|
|
|
// Конструктор, принимающий контекст базы данных
|
2024-12-23 11:20:09 +00:00
|
|
|
|
public SQLPresenceRepositoryImpl(RemoteDatabaseContext remoteDatabaseContext)
|
|
|
|
|
{
|
|
|
|
|
_remoteDatabaseContext = remoteDatabaseContext;
|
|
|
|
|
}
|
|
|
|
|
|
2024-12-23 11:26:41 +00:00
|
|
|
|
// Добавление новой записи о посещаемости
|
2024-12-23 11:20:09 +00:00
|
|
|
|
public void AddPresence(PresenceLocalEntity presence)
|
|
|
|
|
{
|
2024-12-23 11:26:41 +00:00
|
|
|
|
if (presence == null) throw new ArgumentNullException(nameof(presence)); // Проверка на null
|
2024-12-23 11:20:09 +00:00
|
|
|
|
|
|
|
|
|
var newPresence = new PresenceDao
|
|
|
|
|
{
|
|
|
|
|
Date = DateOnly.FromDateTime(presence.Date),
|
|
|
|
|
UserGuid = presence.UserGuid,
|
|
|
|
|
LessonNumber = presence.LessonNumber,
|
|
|
|
|
IsAttedance = presence.IsAttedance
|
|
|
|
|
};
|
2024-12-23 11:26:41 +00:00
|
|
|
|
_remoteDatabaseContext.PresenceDaos.Add(newPresence); // Добавляем новую запись
|
2024-12-23 11:20:09 +00:00
|
|
|
|
}
|
|
|
|
|
|
2024-12-23 11:26:41 +00:00
|
|
|
|
// Очистка всех записей о посещаемости
|
|
|
|
|
public void ClearAllPresence()
|
2024-12-23 11:20:09 +00:00
|
|
|
|
{
|
2024-12-23 11:26:41 +00:00
|
|
|
|
var allPresenceRecords = _remoteDatabaseContext.PresenceDaos.ToList();
|
|
|
|
|
_remoteDatabaseContext.PresenceDaos.RemoveRange(allPresenceRecords); // Удаляем все записи
|
|
|
|
|
_remoteDatabaseContext.SaveChanges(); // Сохраняем изменения
|
2024-12-23 11:20:09 +00:00
|
|
|
|
}
|
|
|
|
|
|
2024-12-23 11:26:41 +00:00
|
|
|
|
// Получение посещаемости по ID группы
|
|
|
|
|
public List<PresenceDao> GetAttendanceByGroup(int groupId)
|
2024-12-23 11:20:09 +00:00
|
|
|
|
{
|
2024-12-23 11:26:41 +00:00
|
|
|
|
var userGuidsInGroup = _remoteDatabaseContext.Users
|
|
|
|
|
.Where(u => u.GroupID == groupId)
|
|
|
|
|
.Select(u => u.Guid)
|
|
|
|
|
.ToList();
|
|
|
|
|
|
|
|
|
|
// Фильтруем посещаемость по пользователям из этой группы
|
2024-12-23 11:20:09 +00:00
|
|
|
|
return _remoteDatabaseContext.PresenceDaos
|
2024-12-23 11:26:41 +00:00
|
|
|
|
.Where(p => userGuidsInGroup.Contains(p.UserGuid))
|
|
|
|
|
.Select(p => new PresenceDao
|
2024-12-23 11:20:09 +00:00
|
|
|
|
{
|
|
|
|
|
UserGuid = p.UserGuid,
|
2024-12-23 11:26:41 +00:00
|
|
|
|
Id = p.Id,
|
|
|
|
|
Date = p.Date,
|
2024-12-23 11:20:09 +00:00
|
|
|
|
LessonNumber = p.LessonNumber,
|
|
|
|
|
IsAttedance = p.IsAttedance
|
|
|
|
|
})
|
2024-12-23 11:26:41 +00:00
|
|
|
|
.ToList(); // Возвращаем список посещаемости
|
2024-12-23 11:20:09 +00:00
|
|
|
|
}
|
|
|
|
|
|
2024-12-23 11:26:41 +00:00
|
|
|
|
// Получение общей посещаемости для группы
|
2024-12-23 11:20:09 +00:00
|
|
|
|
public GroupPresenceSummary GetGeneralPresenceForGroup(int groupId)
|
|
|
|
|
{
|
|
|
|
|
var presences = _remoteDatabaseContext.PresenceDaos
|
|
|
|
|
.Where(p => p.UserDao.GroupID == groupId)
|
|
|
|
|
.OrderBy(p => p.Date).ThenBy(p => p.LessonNumber)
|
|
|
|
|
.ToList();
|
|
|
|
|
|
|
|
|
|
var distinctLessonDates = presences
|
|
|
|
|
.Select(p => new { p.Date, p.LessonNumber })
|
|
|
|
|
.Distinct()
|
|
|
|
|
.ToList();
|
|
|
|
|
|
2024-12-23 11:26:41 +00:00
|
|
|
|
int lessonCount = distinctLessonDates.Count; // Количество уроков
|
2024-12-23 11:20:09 +00:00
|
|
|
|
|
|
|
|
|
var userGuids = presences
|
|
|
|
|
.Select(p => p.UserGuid)
|
|
|
|
|
.Distinct()
|
|
|
|
|
.ToHashSet();
|
|
|
|
|
|
2024-12-23 11:26:41 +00:00
|
|
|
|
double totalAttendance = presences.Count(p => p.IsAttedance); // Общее количество присутствий
|
|
|
|
|
double totalPossibleAttendance = userGuids.Count * lessonCount; // Общее возможное количество присутствий
|
2024-12-23 11:20:09 +00:00
|
|
|
|
|
|
|
|
|
var userAttendances = userGuids.Select(userGuid =>
|
|
|
|
|
{
|
|
|
|
|
var userPresences = presences.Where(p => p.UserGuid == userGuid).ToList();
|
2024-12-23 11:26:41 +00:00
|
|
|
|
double attended = userPresences.Count(p => p.IsAttedance); // Количество присутствий пользователя
|
|
|
|
|
double missed = userPresences.Count(p => !p.IsAttedance); // Количество пропусков пользователя
|
2024-12-23 11:20:09 +00:00
|
|
|
|
|
|
|
|
|
return new UserAttendance
|
|
|
|
|
{
|
|
|
|
|
UserGuid = userGuid,
|
|
|
|
|
Attended = attended,
|
|
|
|
|
Missed = missed,
|
2024-12-23 11:26:41 +00:00
|
|
|
|
AttendanceRate = (attended / (attended + missed)) * 100 // Процент посещаемости
|
2024-12-23 11:20:09 +00:00
|
|
|
|
};
|
|
|
|
|
}).ToList();
|
|
|
|
|
|
|
|
|
|
// Рассчитываем процент посещаемости в заданной группе
|
|
|
|
|
double totalAttendancePercentage = (totalAttendance / totalPossibleAttendance) * 100;
|
|
|
|
|
|
|
|
|
|
return new GroupPresenceSummary
|
|
|
|
|
{
|
|
|
|
|
UserCount = userGuids.Count,
|
|
|
|
|
LessonCount = lessonCount,
|
|
|
|
|
TotalAttendancePercentage = totalAttendancePercentage,
|
|
|
|
|
UserAttendances = userAttendances
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
2024-12-23 11:26:41 +00:00
|
|
|
|
// Получение последней даты посещаемости для группы
|
|
|
|
|
public DateOnly? GetLastDateByGroupId(int groupId)
|
|
|
|
|
{
|
|
|
|
|
// Проверяем наличие записей о посещаемости в БД
|
|
|
|
|
var lastDate = _remoteDatabaseContext.PresenceDaos
|
|
|
|
|
.Where(p => p.UserDao.GroupID == groupId)
|
|
|
|
|
.OrderByDescending(p => p.Date)
|
|
|
|
|
.Select(p => p.Date)
|
|
|
|
|
.FirstOrDefault();
|
2024-12-23 11:20:09 +00:00
|
|
|
|
|
2024-12-23 11:26:41 +00:00
|
|
|
|
return lastDate == default ? (DateOnly?)null : lastDate; // Возвращаем последнюю дату или null
|
|
|
|
|
}
|
2024-12-23 11:20:09 +00:00
|
|
|
|
|
2024-12-23 11:26:41 +00:00
|
|
|
|
// Получение посещаемости по ID группы
|
|
|
|
|
public List<PresenceLocalEntity> GetPresenceByGroup(int groupId)
|
|
|
|
|
{
|
|
|
|
|
return _remoteDatabaseContext.PresenceDaos.Include(user => user.UserDao)
|
|
|
|
|
.Where(p => p.UserDao != null && p.UserDao.GroupID == groupId) // Проверка на null
|
|
|
|
|
.Select(p => new PresenceLocalEntity
|
|
|
|
|
{
|
|
|
|
|
Date = p.Date.ToDateTime(TimeOnly.MinValue), // Преобразование даты
|
|
|
|
|
UserGuid = p.UserGuid,
|
|
|
|
|
LessonNumber = p.LessonNumber,
|
|
|
|
|
IsAttedance = p.IsAttedance
|
|
|
|
|
})
|
|
|
|
|
.ToList(); // Возвращаем список посещаемости
|
|
|
|
|
}
|
2024-12-23 11:20:09 +00:00
|
|
|
|
|
2024-12-23 11:26:41 +00:00
|
|
|
|
// Получение посещаемости по ID группы и дате
|
|
|
|
|
public List<PresenceLocalEntity> GetPresenceByGroupAndDate(int groupId, DateTime date)
|
2024-12-23 11:20:09 +00:00
|
|
|
|
{
|
2024-12-23 11:26:41 +00:00
|
|
|
|
return _remoteDatabaseContext.PresenceDaos
|
|
|
|
|
.Where(p => p.UserDao != null && p.UserDao.GroupID == groupId && p.Date == DateOnly.FromDateTime(date))
|
|
|
|
|
.Select(p => new PresenceLocalEntity
|
|
|
|
|
{
|
|
|
|
|
Date = p.Date.ToDateTime(TimeOnly.MinValue), // Преобразование даты
|
|
|
|
|
UserGuid = p.UserGuid,
|
|
|
|
|
LessonNumber = p.LessonNumber,
|
|
|
|
|
IsAttedance = p.IsAttedance
|
|
|
|
|
})
|
|
|
|
|
.ToList(); // Возвращаем список посещаемости
|
|
|
|
|
}
|
2024-12-23 11:20:09 +00:00
|
|
|
|
|
2024-12-23 11:26:41 +00:00
|
|
|
|
// Пометка пользователя как отсутствующего на занятиях
|
|
|
|
|
public void MarkUserAsAbsent(Guid userGuid, int firstLessonNumber, int lastLessonNumber)
|
|
|
|
|
{
|
|
|
|
|
foreach (var lesson in Enumerable.Range(firstLessonNumber, lastLessonNumber - firstLessonNumber + 1))
|
2024-12-23 11:20:09 +00:00
|
|
|
|
{
|
2024-12-23 11:26:41 +00:00
|
|
|
|
var presence = _remoteDatabaseContext.PresenceDaos.FirstOrDefault(p =>
|
|
|
|
|
p.UserGuid == userGuid &&
|
|
|
|
|
p.LessonNumber == lesson);
|
|
|
|
|
|
|
|
|
|
if (presence != null)
|
2024-12-23 11:20:09 +00:00
|
|
|
|
{
|
2024-12-23 11:26:41 +00:00
|
|
|
|
presence.IsAttedance = false; // Устанавливаем отсутствие
|
2024-12-23 11:20:09 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2024-12-23 11:26:41 +00:00
|
|
|
|
|
|
|
|
|
// Сохранение посещаемости для списка записей
|
|
|
|
|
public void SavePresence(List<PresenceLocalEntity> presences)
|
2024-12-23 11:20:09 +00:00
|
|
|
|
{
|
2024-12-23 11:26:41 +00:00
|
|
|
|
foreach (var presence in presences)
|
|
|
|
|
{
|
|
|
|
|
// Проверяем, существует ли запись с указанными параметрами
|
|
|
|
|
var existing = _remoteDatabaseContext.PresenceDaos.FirstOrDefault(p =>
|
|
|
|
|
p.Date == DateOnly.FromDateTime(presence.Date) &&
|
|
|
|
|
p.UserGuid == presence.UserGuid &&
|
|
|
|
|
p.LessonNumber == presence.LessonNumber);
|
2024-12-23 11:20:09 +00:00
|
|
|
|
|
2024-12-23 11:26:41 +00:00
|
|
|
|
if (existing == null)
|
2024-12-23 11:20:09 +00:00
|
|
|
|
{
|
2024-12-23 11:26:41 +00:00
|
|
|
|
// Добавляем запись, если её не существует
|
|
|
|
|
_remoteDatabaseContext.PresenceDaos.Add(new PresenceDao
|
|
|
|
|
{
|
|
|
|
|
Date = DateOnly.FromDateTime(presence.Date),
|
|
|
|
|
IsAttedance = presence.IsAttedance,
|
|
|
|
|
LessonNumber = presence.LessonNumber,
|
|
|
|
|
UserGuid = presence.UserGuid
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
// Обновляем запись, если она уже существует
|
|
|
|
|
existing.IsAttedance = presence.IsAttedance;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
_remoteDatabaseContext.SaveChanges(); // Сохраняем изменения в базе данных
|
2024-12-23 11:20:09 +00:00
|
|
|
|
}
|
|
|
|
|
|
2024-12-23 11:26:41 +00:00
|
|
|
|
// Обновление записи о посещаемости
|
|
|
|
|
public void UpdateAttendance(PresenceLocalEntity attendance)
|
2024-12-23 11:20:09 +00:00
|
|
|
|
{
|
2024-12-23 11:26:41 +00:00
|
|
|
|
if (attendance == null)
|
|
|
|
|
throw new ArgumentNullException(nameof(attendance)); // Проверка на null
|
|
|
|
|
|
|
|
|
|
// Ищем запись в базе данных по идентификатору
|
|
|
|
|
var existingAttendance = _remoteDatabaseContext.PresenceDaos
|
|
|
|
|
.FirstOrDefault(p => p.Id == attendance.Id);
|
|
|
|
|
|
|
|
|
|
if (existingAttendance != null)
|
|
|
|
|
{
|
|
|
|
|
// Обновляем запись
|
|
|
|
|
existingAttendance.IsAttedance = attendance.IsAttedance;
|
|
|
|
|
_remoteDatabaseContext.SaveChanges(); // Сохраняем изменения
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
throw new InvalidOperationException("Запись с указанным ID не найдена."); // Исключение, если запись не найдена
|
|
|
|
|
}
|
2024-12-23 11:20:09 +00:00
|
|
|
|
}
|
|
|
|
|
|
2024-12-23 11:26:41 +00:00
|
|
|
|
// Обновление посещаемости пользователя
|
|
|
|
|
public bool UpdateAttention(Guid userGuid, int groupId, int firstLesson, int lastLesson, DateOnly date, bool isAttendance)
|
|
|
|
|
{
|
|
|
|
|
var presences = _remoteDatabaseContext.PresenceDaos
|
|
|
|
|
.Where(p => p.UserGuid == userGuid && p.UserDao.GroupID == groupId &&
|
|
|
|
|
p.LessonNumber >= firstLesson && p.LessonNumber <= lastLesson && p.Date == date)
|
|
|
|
|
.ToList();
|
|
|
|
|
|
|
|
|
|
if (presences.Any())
|
|
|
|
|
{
|
|
|
|
|
foreach (var presence in presences)
|
|
|
|
|
{
|
|
|
|
|
presence.IsAttedance = isAttendance; // Обновляем посещаемость
|
|
|
|
|
}
|
|
|
|
|
_remoteDatabaseContext.SaveChanges(); // Сохраняем изменения
|
|
|
|
|
return true; // Возвращаем true, если обновление прошло успешно
|
|
|
|
|
}
|
|
|
|
|
return false; // Возвращаем false, если записи не найдены
|
|
|
|
|
}
|
2024-12-23 11:20:09 +00:00
|
|
|
|
}
|
|
|
|
|
}
|