add list item component
This commit is contained in:
parent
e467ca7e92
commit
69b7920f23
3 changed files with 26 additions and 8 deletions
|
|
@ -17,7 +17,7 @@
|
|||
}
|
||||
|
||||
.sidebar-link {
|
||||
@apply block bg-white rounded-xl shadow-md overflow-hidden hover:shadow-lg transition
|
||||
@apply block bg-white rounded-xl shadow-md overflow-hidden hover:shadow-lg transition w-full px-4 py-2 hover:bg-blue-100
|
||||
}
|
||||
|
||||
.sidebar-item-text {
|
||||
|
|
|
|||
20
frontend/src/components/RecipeListItem.tsx
Normal file
20
frontend/src/components/RecipeListItem.tsx
Normal file
|
|
@ -0,0 +1,20 @@
|
|||
import { Link } from "react-router-dom"
|
||||
|
||||
type RecipeListItemProps = {
|
||||
title: string
|
||||
targetPath: string
|
||||
}
|
||||
|
||||
/**
|
||||
* List item for the recipe list. Selecting an item navigates to the recipe
|
||||
*/
|
||||
export default function RecipeListItem({ title, targetPath: path}: RecipeListItemProps) {
|
||||
return (
|
||||
<Link
|
||||
to={path}
|
||||
className="sidebar-link"
|
||||
>
|
||||
<h2 className="sidebar-item-text">{title}</h2>
|
||||
</Link>
|
||||
)
|
||||
}
|
||||
|
|
@ -1,5 +1,5 @@
|
|||
import { Link } from "react-router-dom"
|
||||
import { recipes } from "../mock_data/recipes"
|
||||
import RecipeListItem from "./RecipeListItem"
|
||||
|
||||
/**
|
||||
* Displays a list of recipes in a sidebar layout.
|
||||
|
|
@ -12,13 +12,11 @@ export default function RecipeListView() {
|
|||
|
||||
<div className="flex flex-col gap-2">
|
||||
{recipes.map((recipe) => (
|
||||
<Link
|
||||
<RecipeListItem
|
||||
key={recipe.id}
|
||||
to={`/recipe/${recipe.id}`}
|
||||
className="sidebar-link block w-full px-4 py-2 rounded hover:bg-blue-100"
|
||||
>
|
||||
<h2 className="sidebar-item-text">{recipe.title}</h2>
|
||||
</Link>
|
||||
title = {recipe.title}
|
||||
targetPath={'recipe/'+recipe.id}
|
||||
/>
|
||||
))}
|
||||
</div>
|
||||
</div>
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue