|
|
|
@ -1,4 +1,5 @@
|
|
|
|
|
using System;
|
|
|
|
|
using System.Collections;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
using System.Text;
|
|
|
|
@ -48,12 +49,13 @@ namespace Contextlib
|
|
|
|
|
return new PaginationResult<Quote>(quotes.Count, index, pageSize, quotes);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public async Task<Quote> GetDailyQuote(DateOnly date, int lang)
|
|
|
|
|
public async Task<Quote?> GetDailyQuote(DateOnly date, int lang)
|
|
|
|
|
{
|
|
|
|
|
List<Quote> quotes = _context.quotes.Where(item => item.IsValid && item.Langage == (LangEnum)lang)
|
|
|
|
|
.Include(q => q.Source).Include(q => q.Character).ThenInclude(c => c.Images).Include(q => q.Favorite)
|
|
|
|
|
.ToList();
|
|
|
|
|
Quote quote = _repo.GetById(date.DayNumber % quotes.Count()) ?? quotes.First();
|
|
|
|
|
if (quotes.Count() == 0) return null;
|
|
|
|
|
Quote quote = quotes[ date.DayNumber % quotes.Count() ] ;
|
|
|
|
|
|
|
|
|
|
return quote;
|
|
|
|
|
}
|
|
|
|
@ -113,51 +115,115 @@ namespace Contextlib
|
|
|
|
|
|
|
|
|
|
public async Task<PaginationResult<Quote>> GetSomeQuote(int index, int pageSize)
|
|
|
|
|
{
|
|
|
|
|
throw new NotImplementedException();
|
|
|
|
|
List<Quote> quotes = _context.quotes.Where(item => item.IsValid)
|
|
|
|
|
.Include(q => q.Source).Include(q => q.Character).ThenInclude(c => c.Images)
|
|
|
|
|
.Skip(index * pageSize).Take(pageSize).ToList();
|
|
|
|
|
return new PaginationResult<Quote>(quotes.Count, index, pageSize, quotes);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public async Task<PaginationResult<Quote>> GetSuggestions(int index, int pageSize, int lang)
|
|
|
|
|
public async Task<PaginationResult<Quote>> GetSuggestions(int index, int pageSize, int lang) // A changer Suggestion Random
|
|
|
|
|
{
|
|
|
|
|
throw new NotImplementedException();
|
|
|
|
|
List<Quote> quotes = _context.quotes.Where(item => item.IsValid && item.Langage == (LangEnum)lang)
|
|
|
|
|
.Include(q => q.Source).Include(q => q.Character).ThenInclude(c => c.Images)
|
|
|
|
|
//.OrderBy(q=> new Random() )
|
|
|
|
|
.Skip(index * pageSize).Take(pageSize).ToList();
|
|
|
|
|
|
|
|
|
|
return new PaginationResult<Quote>(quotes.Count, index, pageSize, quotes);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public async Task<PaginationResult<Quote>> GetValidQuote(int index, int pageSize)
|
|
|
|
|
{
|
|
|
|
|
throw new NotImplementedException();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
List<Quote> quotes = _context.quotes.Where(item => item.IsValid)
|
|
|
|
|
.Include(q => q.Source).Include(q => q.Character).ThenInclude(c => c.Images)
|
|
|
|
|
.Skip(index * pageSize).Take(pageSize).ToList();
|
|
|
|
|
|
|
|
|
|
public async Task RemoveQuote(int quoteId)
|
|
|
|
|
{
|
|
|
|
|
throw new NotImplementedException();
|
|
|
|
|
return new PaginationResult<Quote>(quotes.Count, index, pageSize, quotes);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public async Task<PaginationResult<Quote>> SearchByCharacter(string character, int index, int pageSize, int lang)
|
|
|
|
|
{
|
|
|
|
|
throw new NotImplementedException();
|
|
|
|
|
List<Quote> quotes = _context.quotes.Where(item => item.IsValid && item.Langage==(LangEnum)lang && (item.Character.Name).Contains(character))
|
|
|
|
|
.Include(q => q.Source).Include(q => q.Character).ThenInclude(c => c.Images)
|
|
|
|
|
.Skip(index * pageSize).Take(pageSize).ToList();
|
|
|
|
|
|
|
|
|
|
return new PaginationResult<Quote>(quotes.Count, index, pageSize, quotes);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public async Task<PaginationResult<Quote>> SearchByContent(string content, int index, int pageSize, int lang)
|
|
|
|
|
{
|
|
|
|
|
throw new NotImplementedException();
|
|
|
|
|
List<Quote> quotes = _context.quotes.Where(item => item.IsValid && item.Langage == (LangEnum)lang && (item.Content).Contains(content))
|
|
|
|
|
.Include(q => q.Source).Include(q => q.Character).ThenInclude(c => c.Images)
|
|
|
|
|
.Skip(index * pageSize).Take(pageSize).ToList();
|
|
|
|
|
|
|
|
|
|
return new PaginationResult<Quote>(quotes.Count, index, pageSize, quotes);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public async Task<PaginationResult<Quote>> SearchBySource(string source, int index, int pageSize, int lang)
|
|
|
|
|
{
|
|
|
|
|
throw new NotImplementedException();
|
|
|
|
|
List<Quote> quotes = _context.quotes.Where(item => item.IsValid && item.Langage == (LangEnum)lang && (item.Source.Title).Contains(source))
|
|
|
|
|
.Include(q => q.Source).Include(q => q.Character).ThenInclude(c => c.Images)
|
|
|
|
|
.Skip(index * pageSize).Take(pageSize).ToList();
|
|
|
|
|
|
|
|
|
|
return new PaginationResult<Quote>(quotes.Count, index, pageSize, quotes);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public async Task RemoveQuote(int quoteId)
|
|
|
|
|
{
|
|
|
|
|
_repo.Delete( _repo.GetById(quoteId) );
|
|
|
|
|
await _context.SaveChangesAsync();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public async Task UpdateQuote(int quoteId, Quote quote)
|
|
|
|
|
{
|
|
|
|
|
throw new NotImplementedException();
|
|
|
|
|
Quote? q = _repo.GetById(quoteId);
|
|
|
|
|
if (q != null)
|
|
|
|
|
{
|
|
|
|
|
bool change = false;
|
|
|
|
|
if (quote.IdSource != 0)
|
|
|
|
|
{
|
|
|
|
|
q.IdSource = quote.IdSource;
|
|
|
|
|
change = true;
|
|
|
|
|
}
|
|
|
|
|
if (quote.IdCharacter != 0)
|
|
|
|
|
{
|
|
|
|
|
q.IdCharacter = quote.IdCharacter;
|
|
|
|
|
change = true;
|
|
|
|
|
}
|
|
|
|
|
if (quote.IdSource != 0)
|
|
|
|
|
{
|
|
|
|
|
q.IdSource = quote.IdSource;
|
|
|
|
|
change = true;
|
|
|
|
|
}
|
|
|
|
|
if (quote.IdUsersPropose !=0)
|
|
|
|
|
{
|
|
|
|
|
q.IdUsersPropose = quote.IdUsersPropose;
|
|
|
|
|
change = true;
|
|
|
|
|
}
|
|
|
|
|
if (quote.Content != null || quote.Content =="")
|
|
|
|
|
{
|
|
|
|
|
q.Content = quote.Content;
|
|
|
|
|
change = true;
|
|
|
|
|
}
|
|
|
|
|
_repo.Update(q);
|
|
|
|
|
if (change) _context.SaveChanges();
|
|
|
|
|
}
|
|
|
|
|
return ;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public async Task ValidateQuote(int quoteId, bool isValidate)
|
|
|
|
|
{
|
|
|
|
|
throw new NotImplementedException();
|
|
|
|
|
Quote? q = _repo.GetById(quoteId);
|
|
|
|
|
if (q != null)
|
|
|
|
|
{
|
|
|
|
|
q.IsValid = isValidate;
|
|
|
|
|
_repo.Update(q);
|
|
|
|
|
_context.SaveChanges();
|
|
|
|
|
}
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|