Files
marechai/Marechai/Services/NewsService.cs
2020-08-05 21:00:35 +01:00

140 lines
5.9 KiB
C#

/******************************************************************************
// MARECHAI: Master repository of computing history artifacts information
// ----------------------------------------------------------------------------
//
// Author(s) : Natalia Portillo <claunia@claunia.com>
//
// --[ License ] --------------------------------------------------------------
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as
// published by the Free Software Foundation, either version 3 of the
// License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
//
// ----------------------------------------------------------------------------
// Copyright © 2003-2020 Natalia Portillo
*******************************************************************************/
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Marechai.Database;
using Marechai.Database.Models;
using Marechai.ViewModels;
using Microsoft.EntityFrameworkCore;
using Microsoft.Extensions.Localization;
namespace Marechai.Services
{
public class NewsService
{
readonly MarechaiContext _context;
readonly IStringLocalizer<NewsService> _l;
public NewsService(MarechaiContext context, IStringLocalizer<NewsService> localizer)
{
_context = context;
_l = localizer;
}
public async Task<List<NewsViewModel>> GetAsync() => await _context.News.OrderByDescending(n => n.Date).
Select(n => new NewsViewModel
{
Id = n.Id,
Timestamp = n.Date,
Type = n.Type,
AffectedId = n.AddedId
}).ToListAsync();
public List<NewsViewModel> GetNews()
{
List<NewsViewModel> news = new List<NewsViewModel>();
foreach(News @new in _context.News.OrderByDescending(t => t.Date).Take(10).ToList())
{
Machine machine = _context.Machines.Find(@new.AddedId);
if(machine is null)
continue;
switch(@new.Type)
{
case NewsType.NewComputerInDb:
news.Add(new NewsViewModel(@new.AddedId, _l["New computer in database"], @new.Date, "machine",
$"{machine.Company.Name} {machine.Name}"));
break;
case NewsType.NewConsoleInDb:
news.Add(new NewsViewModel(@new.AddedId, _l["New console in database"], @new.Date, "machine",
$"{machine.Company.Name} {machine.Name}"));
break;
case NewsType.NewComputerInCollection:
news.Add(new NewsViewModel(@new.AddedId, _l["New computer in collection"], @new.Date, "machine",
$"{machine.Company.Name} {machine.Name}"));
break;
case NewsType.NewConsoleInCollection:
news.Add(new NewsViewModel(@new.AddedId, _l["New console in collection"], @new.Date, "machine",
$"{machine.Company.Name} {machine.Name}"));
break;
case NewsType.UpdatedComputerInDb:
news.Add(new NewsViewModel(@new.AddedId, _l["Updated computer in database"], @new.Date,
"machine", $"{machine.Company.Name} {machine.Name}"));
break;
case NewsType.UpdatedConsoleInDb:
news.Add(new NewsViewModel(@new.AddedId, _l["Updated console in database"], @new.Date,
"machine", $"{machine.Company.Name} {machine.Name}"));
break;
case NewsType.UpdatedComputerInCollection:
news.Add(new NewsViewModel(@new.AddedId, _l["Updated computer in collection"], @new.Date,
"machine", $"{machine.Company.Name} {machine.Name}"));
break;
case NewsType.UpdatedConsoleInCollection:
news.Add(new NewsViewModel(@new.AddedId, _l["Updated console in collection"], @new.Date,
"machine", $"{machine.Company.Name} {machine.Name}"));
break;
case NewsType.NewMoneyDonation:
// TODO
break;
default: continue;
}
}
return news;
}
public async Task DeleteAsync(int id, string userId)
{
News item = await _context.News.FindAsync(id);
if(item is null)
return;
_context.News.Remove(item);
await _context.SaveChangesWithUserAsync(userId);
}
}
}