Initial test, but meh
This commit is contained in:
@@ -1,17 +1,26 @@
|
||||
package database
|
||||
|
||||
type Manga struct {
|
||||
type MangaDefinition struct {
|
||||
Id int `gorm:"primary_key;AUTO_INCREMENT"`
|
||||
Title string
|
||||
TimeStampUnix int64
|
||||
Thumbnail []byte
|
||||
LastChapterNum string
|
||||
Chapters []Chapter
|
||||
// Chapters []Chapter
|
||||
//`gorm:"foreignkey:MangaID"`
|
||||
}
|
||||
|
||||
func NewManga(id int, title string, timeStampUnix int64) Manga {
|
||||
return Manga{
|
||||
type Manga struct {
|
||||
Id int `gorm:"primary_key;AUTO_INCREMENT"`
|
||||
MangaDefinitionId int
|
||||
Definition MangaDefinition `gorm:"foreignKey:MangaDefinitionId"`
|
||||
UserId int
|
||||
TimeStampUnix int64
|
||||
Chapters []Chapter `gorm:"foreignKey:MangaId"`
|
||||
}
|
||||
|
||||
func NewMangaDefinition(id int, title string, timeStampUnix int64) MangaDefinition {
|
||||
return MangaDefinition{
|
||||
Id: id,
|
||||
Title: title,
|
||||
TimeStampUnix: timeStampUnix,
|
||||
@@ -21,20 +30,20 @@ func NewManga(id int, title string, timeStampUnix int64) Manga {
|
||||
|
||||
// GetLatestChapter TODO: Cache this somehow
|
||||
func (m *Manga) GetLatestChapter() (*Chapter, bool) {
|
||||
highest := int64(0)
|
||||
index := 0
|
||||
for i, chapter := range m.Chapters {
|
||||
if chapter.MangaId == m.Id && highest < chapter.TimeStampUnix {
|
||||
highest = chapter.TimeStampUnix
|
||||
index = i
|
||||
}
|
||||
}
|
||||
// highest := int64(0)
|
||||
// index := 0
|
||||
// for i, chapter := range m.Chapters {
|
||||
// if chapter.MangaId == m.Manga.Id && highest < chapter.TimeStampUnix {
|
||||
// highest = chapter.TimeStampUnix
|
||||
// index = i
|
||||
// }
|
||||
// }
|
||||
|
||||
if highest == 0 {
|
||||
return nil, false
|
||||
}
|
||||
// if highest == 0 {
|
||||
return nil, false
|
||||
// }
|
||||
|
||||
return &m.Chapters[index], true
|
||||
// return &m.Chapters[index], true
|
||||
|
||||
//result := db.Where("manga.id = ?", m.Id).Order("TimeStampUnix desc").Take(&chapter)
|
||||
//if result.Error != nil && !errors.Is(result.Error, gorm.ErrRecordNotFound) {
|
||||
|
||||
Reference in New Issue
Block a user