package sql import ( "context" "errors" "tercul/internal/domain" "tercul/internal/domain/category" "gorm.io/gorm" ) type categoryRepository struct { domain.BaseRepository[domain.Category] db *gorm.DB } // NewCategoryRepository creates a new CategoryRepository. func NewCategoryRepository(db *gorm.DB) category.CategoryRepository { return &categoryRepository{ BaseRepository: NewBaseRepositoryImpl[domain.Category](db), db: db, } } // FindByName finds a category by name func (r *categoryRepository) FindByName(ctx context.Context, name string) (*domain.Category, error) { var category domain.Category if err := r.db.WithContext(ctx).Where("name = ?", name).First(&category).Error; err != nil { if errors.Is(err, gorm.ErrRecordNotFound) { return nil, ErrEntityNotFound } return nil, err } return &category, nil } // ListByWorkID finds categories by work ID func (r *categoryRepository) ListByWorkID(ctx context.Context, workID uint) ([]domain.Category, error) { var categories []domain.Category if err := r.db.WithContext(ctx).Joins("JOIN work_categories ON work_categories.category_id = categories.id"). Where("work_categories.work_id = ?", workID). Find(&categories).Error; err != nil { return nil, err } return categories, nil } // ListByParentID finds categories by parent ID func (r *categoryRepository) ListByParentID(ctx context.Context, parentID *uint) ([]domain.Category, error) { var categories []domain.Category if parentID == nil { if err := r.db.WithContext(ctx).Where("parent_id IS NULL").Find(&categories).Error; err != nil { return nil, err } } else { if err := r.db.WithContext(ctx).Where("parent_id = ?", *parentID).Find(&categories).Error; err != nil { return nil, err } } return categories, nil }