feat: add book admin display fields

This commit is contained in:
2026-04-27 13:53:37 +08:00
parent 67c33d06be
commit 2fa15625b0
20 changed files with 472 additions and 70 deletions

View File

@@ -4,11 +4,15 @@ import (
"github.com/flipped-aurora/gin-vue-admin/server/global"
"github.com/flipped-aurora/gin-vue-admin/server/model/book"
bookReq "github.com/flipped-aurora/gin-vue-admin/server/model/book/request"
bookRes "github.com/flipped-aurora/gin-vue-admin/server/model/book/response"
commonReq "github.com/flipped-aurora/gin-vue-admin/server/model/common/request"
"gorm.io/gorm"
)
type BookReadRecordService struct{}
const bookReadRecordDisplaySelect = "brr.*, ch.title AS chapter_title"
func (s *BookReadRecordService) CreateBookReadRecord(item book.BookReadRecord) error {
if err := validateBookReadRecord(item); err != nil {
return err
@@ -31,23 +35,31 @@ func (s *BookReadRecordService) UpdateBookReadRecord(item book.BookReadRecord) e
return global.GVA_DB.Save(&item).Error
}
func (s *BookReadRecordService) GetBookReadRecord(id uint) (item book.BookReadRecord, err error) {
err = global.GVA_DB.Where("id = ?", id).First(&item).Error
func (s *BookReadRecordService) GetBookReadRecord(id uint) (item bookRes.BookReadRecordDisplay, err error) {
err = bookReadRecordDisplayDB().
Select(bookReadRecordDisplaySelect).
Where("brr.id = ?", id).
Take(&item).Error
return
}
func (s *BookReadRecordService) GetBookReadRecordInfoList(info bookReq.BookReadRecordSearch) (list []book.BookReadRecord, total int64, err error) {
db := global.GVA_DB.Model(&book.BookReadRecord{})
func (s *BookReadRecordService) GetBookReadRecordInfoList(info bookReq.BookReadRecordSearch) (list []bookRes.BookReadRecordListItem, total int64, err error) {
db := bookReadRecordDisplayDB()
if info.MemberUserID != nil {
db = db.Where("member_user_id = ?", *info.MemberUserID)
db = db.Where("brr.member_user_id = ?", *info.MemberUserID)
}
if info.BookID != nil {
db = db.Where("book_id = ?", *info.BookID)
db = db.Where("brr.book_id = ?", *info.BookID)
}
err = db.Count(&total).Error
if err != nil {
return
}
err = db.Scopes(paginate(info.PageInfo)).Order("last_read_at desc, id desc").Find(&list).Error
err = db.Select(bookReadRecordDisplaySelect).Scopes(paginate(info.PageInfo)).Order("brr.last_read_at desc, brr.id desc").Scan(&list).Error
return
}
func bookReadRecordDisplayDB() *gorm.DB {
return global.GVA_DB.Table("book_read_record AS brr").
Joins("LEFT JOIN book_chapter AS ch ON ch.id = brr.chapter_id")
}