V025 migration drops the column. Removed from Recipe entity, RecipeDetailResponse, RecipeSummaryResponse, RecipeRepository JPQL, RecipeService, and RecipeController. Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
54 lines
2.2 KiB
Java
54 lines
2.2 KiB
Java
package com.recipeapp.recipe;
|
|
|
|
import com.recipeapp.recipe.dto.RecipeSummaryResponse;
|
|
import com.recipeapp.recipe.entity.Recipe;
|
|
import org.springframework.data.jpa.repository.JpaRepository;
|
|
import org.springframework.data.jpa.repository.Query;
|
|
import org.springframework.data.repository.query.Param;
|
|
|
|
import java.util.List;
|
|
import java.util.Optional;
|
|
import java.util.UUID;
|
|
|
|
public interface RecipeRepository extends JpaRepository<Recipe, UUID> {
|
|
|
|
Optional<Recipe> findByIdAndHouseholdIdAndDeletedAtIsNull(UUID id, UUID householdId);
|
|
|
|
List<Recipe> findByHouseholdIdAndDeletedAtIsNull(UUID householdId);
|
|
|
|
@Query("""
|
|
SELECT new com.recipeapp.recipe.dto.RecipeSummaryResponse(
|
|
r.id, r.name, r.serves, r.cookTimeMin, r.effort, r.heroImagePreview)
|
|
FROM Recipe r
|
|
WHERE r.household.id = :householdId
|
|
AND r.deletedAt IS NULL
|
|
AND (:search IS NULL OR LOWER(r.name) LIKE LOWER(CONCAT('%', CAST(:search AS string), '%')))
|
|
AND (:effort IS NULL OR r.effort = CAST(:effort AS string))
|
|
AND (:cookTimeMaxMin IS NULL OR r.cookTimeMin <= :cookTimeMaxMin)
|
|
ORDER BY r.createdAt DESC
|
|
""")
|
|
List<RecipeSummaryResponse> findFiltered(
|
|
@Param("householdId") UUID householdId,
|
|
@Param("search") String search,
|
|
@Param("effort") String effort,
|
|
@Param("cookTimeMaxMin") Integer cookTimeMaxMin,
|
|
@Param("sort") String sort,
|
|
@Param("limit") int limit,
|
|
@Param("offset") int offset);
|
|
|
|
@Query("""
|
|
SELECT COUNT(r)
|
|
FROM Recipe r
|
|
WHERE r.household.id = :householdId
|
|
AND r.deletedAt IS NULL
|
|
AND (:search IS NULL OR LOWER(r.name) LIKE LOWER(CONCAT('%', CAST(:search AS string), '%')))
|
|
AND (:effort IS NULL OR r.effort = CAST(:effort AS string))
|
|
AND (:cookTimeMaxMin IS NULL OR r.cookTimeMin <= :cookTimeMaxMin)
|
|
""")
|
|
long countFiltered(
|
|
@Param("householdId") UUID householdId,
|
|
@Param("search") String search,
|
|
@Param("effort") String effort,
|
|
@Param("cookTimeMaxMin") Integer cookTimeMaxMin);
|
|
}
|