package sql import ( "context" "gorm.io/gorm" "tercul/internal/domain/translation" ) type translationRepository struct { domain.BaseRepository[domain.Translation] db *gorm.DB } // NewTranslationRepository creates a new TranslationRepository. func NewTranslationRepository(db *gorm.DB) translation.TranslationRepository { return &translationRepository{ BaseRepository: NewBaseRepositoryImpl[domain.Translation](db), db: db, } } // ListByWorkID finds translations by work ID func (r *translationRepository) ListByWorkID(ctx context.Context, workID uint) ([]domain.Translation, error) { var translations []domain.Translation if err := r.db.WithContext(ctx).Where("translatable_id = ? AND translatable_type = ?", workID, "Work").Find(&translations).Error; err != nil { return nil, err } return translations, nil } // ListByEntity finds translations by entity type and ID func (r *translationRepository) ListByEntity(ctx context.Context, entityType string, entityID uint) ([]domain.Translation, error) { var translations []domain.Translation if err := r.db.WithContext(ctx).Where("translatable_id = ? AND translatable_type = ?", entityID, entityType).Find(&translations).Error; err != nil { return nil, err } return translations, nil } // ListByTranslatorID finds translations by translator ID func (r *translationRepository) ListByTranslatorID(ctx context.Context, translatorID uint) ([]domain.Translation, error) { var translations []domain.Translation if err := r.db.WithContext(ctx).Where("translator_id = ?", translatorID).Find(&translations).Error; err != nil { return nil, err } return translations, nil } // ListByStatus finds translations by status func (r *translationRepository) ListByStatus(ctx context.Context, status domain.TranslationStatus) ([]domain.Translation, error) { var translations []domain.Translation if err := r.db.WithContext(ctx).Where("status = ?", status).Find(&translations).Error; err != nil { return nil, err } return translations, nil }