package services import ( "app/internal/dal" "app/internal/database" "app/internal/dialogs" "app/internal/extras/excel" "app/internal/models" "app/internal/utils" "errors" "fmt" "gorm.io/gen/field" "gorm.io/gorm" ) type PostService struct{} type Post = models.Post func (service *PostService) Create(item Post) (Post, error) { utils.ReplaceEmptySlicesWithNil(&item) err := dal.Post.Preload(field.Associations).Create(&item) if err != nil { return item, err } err = utils.AppendAssociations(database.GetInstance(), &item) return item, err } func (service *PostService) GetAll() ([]*Post, error) { var posts []*Post posts, err := dal.Post.Preload(field.Associations).Find() return posts, err } func (service *PostService) GetById(id uint) (*Post, error) { item, err := dal.Post.Preload(field.Associations).Where(dal.Post.Id.Eq(id)).First() if err != nil { if errors.Is(err, gorm.ErrRecordNotFound) { return nil, nil } else { return nil, err } } return item, nil } func (service *PostService) Update(item Post) (Post, error) { utils.ReplaceEmptySlicesWithNil(&item) err := dal.Post.Preload(field.Associations).Save(&item) if err != nil { return item, err } err = utils.UpdateAssociations(database.GetInstance(), &item) if err != nil { return item, err } return item, err } func (service *PostService) Delete(id uint) error { _, err := dal.Post.Unscoped().Where(dal.Post.Id.Eq(id)).Delete() return err } func (service *PostService) Count() (int64, error) { amount, err := dal.Post.Count() return amount, err } func (service *PostService) ExportToExcel() { exporter := excel.Exporter[Post]{ SheetName: "Посты", Entity: Post{}, Provider: service.GetAll, } err := excel.ExportEntitiesToSpreadsheet("report.xlsx", exporter) if err != nil { dialogs.ErrorDialog("Ошибка экспорта", fmt.Sprintf("Ошибка при экспорте данных: %s", err)) } } func (service *PostService) SortedByOrder(fieldsSortOrder map[string]string) ([]*Post, error) { return utils.SortByOrder(fieldsSortOrder, Post{}) }