NYT Noshing is a clone of the NYT Cooking website. Upon visiting the former site, before they can interact with any recipes, users must either login, create an account, or log in using a demo account. Afterwards, they can access individual recipes, leave comments, or save them to their Recipe Box, which users can view and sort their saves by category.
NYT Noshing was built with:
This project uses npm and nide. To run NYT Noshing locally, install npm and run npm start
for frontend and rails s
for backend.
const re = new RegExp("^[a-zA-Z]+$");
if (query.length > 0 && re.test(query)) {
queriedRecipeNames = recipeNames.filter(recipe => {
return (recipe.toLowerCase()).match(query.toLowerCase())
})
recipeResults = queriedRecipeNames.map(name => {
return recipesArr.find(recipe => recipe.name === name)
})
} else {
queriedRecipeNames = []
}
Challenge
How might we ensure that we're only querying the store if users actually input a query in the search bar, and how might we protect the integrity of the search if the query involves unusual chracters?
Solution
Create conditional statements to check whether the query for the search result index (passed from the search bar component via parameters) is not empty and – using Regex – only contains A-Z capitalized and uncapitalized characters; if so, query store for appropriate results. If these conditions are not met, return an empty array for the query to trigger the "zero results" component treatment.
{recipeCategories.map((category) => {
const taggedRecipes = savedRecipes
.filter(sr => sr.recipe.tags.includes(category))
.map(sr => sr.recipe)
return (
<li
className="recipebox-nav-category-tab" key={Math.random()}
onClick={() => setCategory(category)}>
<RecipeBoxCategoryItem
category={category}
taggedRecipes={taggedRecipes}
/>
</li>
)
})}
Challenge
Efficiently, how might we render the Recipe Box navigation that pulls the cateogries of all recipes the user has saved and the number of recipes within each category, while allowing users to view recipes that fall under this category upon click?
Solution
- Iterate through an array of all recipe categories and find the recipes that fall under this category that the user has saved, mapping to create an array of this subset.
- Render a component representing a tab within the Recipe Box navigation component that takes in the category and the array of tagged recipes to calculate the number within each tab.
- Create an event listener on the navigational tab that sets a local state variable to be the tab clicked, which filters the index to include only the recipes that call under the state variable.
Recipe category navigation
Below the search bar, allow users to view recipe indexes based on categories (i.e. "easy" recipes, dinners, vegetarian, dessert).
"Easy" recipe visual treatment
Indicate that a recipe is easy to prepare based on a visual tag that appears on a recipe's individual tile in an index, both in on the home page, search, and Recipe Box features.