Adding recipe-details front
continuous-integration/drone/push Build is failing
Details
continuous-integration/drone/push Build is failing
Details
parent
18c4c617de
commit
0e5f4b300c
@ -1,7 +1,85 @@
|
|||||||
<h1>{{recipe?.$name}}</h1>
|
<style>
|
||||||
<p> {{recipe?.$createdAt}}</p>
|
.recipe-details {
|
||||||
|
font-family: Arial, sans-serif;
|
||||||
|
background-color: #bab6b6;
|
||||||
|
margin: 0;
|
||||||
|
padding: 20px;
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
|
||||||
<h3>{{recipe?.$description}}</h3>
|
.recipe-card {
|
||||||
|
background-color: #fff;
|
||||||
|
border-radius: 10px;
|
||||||
|
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
|
||||||
|
overflow: hidden;
|
||||||
|
transition: transform 0.2s;
|
||||||
|
width: 80%;
|
||||||
|
margin: 20px;
|
||||||
|
padding: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
<img [src]="recipe?.$image" alt="Recette 1" class="recipe-image"
|
.recipe-card:hover {
|
||||||
onerror="this.onerror=null;this.src='https://placehold.co/100x100/black/white?text=Not+Found';">
|
transform: scale(1.05);
|
||||||
|
}
|
||||||
|
|
||||||
|
.recipe-image {
|
||||||
|
width: 100%;
|
||||||
|
max-width: 300px;
|
||||||
|
border-radius: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.recipe-content {
|
||||||
|
padding: 15px;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.recipe-title {
|
||||||
|
font-size: 2em;
|
||||||
|
margin: 0 0 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.recipe-date {
|
||||||
|
color: #777;
|
||||||
|
margin-bottom: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.recipe-description {
|
||||||
|
font-size: 1.2em;
|
||||||
|
margin: 20px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.ingredient-list {
|
||||||
|
list-style-type: none;
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.ingredient-item {
|
||||||
|
background-color: #f9f9f9;
|
||||||
|
border: 1px solid #ddd;
|
||||||
|
border-radius: 5px;
|
||||||
|
padding: 10px;
|
||||||
|
margin: 5px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
</style>
|
||||||
|
|
||||||
|
|
||||||
|
<div class="recipe-details">
|
||||||
|
<div class="recipe-card">
|
||||||
|
<h1 class="recipe-title">{{ recipe?.$name }}</h1>
|
||||||
|
<p class="recipe-date">{{ recipe?.$createdAt }}</p>
|
||||||
|
<img [src]="recipe?.$image" alt="{{ recipe?.$name }}" class="recipe-image"
|
||||||
|
onerror="this.onerror=null;this.src='https://placehold.co/300x300/black/white?text=Not+Found';">
|
||||||
|
<div class="recipe-content">
|
||||||
|
<h3 class="recipe-description">{{ recipe?.$description }}</h3>
|
||||||
|
<h4>Ingrédients</h4>
|
||||||
|
<ul class="ingredient-list">
|
||||||
|
<li class="ingredient-item" *ngFor="let ingredient of ingredients">
|
||||||
|
{{ ingredient.ingredient.name }} : {{ ingredient.quantity }} {{ ingredient.unit }}
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
@ -0,0 +1,23 @@
|
|||||||
|
import { Unity } from "./unity";
|
||||||
|
import { Ingredient } from "./ingredient.model";
|
||||||
|
import { QuantifiedIngredient } from "./quantified-ingredient.model";
|
||||||
|
|
||||||
|
export class QuantifiedIngredientGetter implements QuantifiedIngredient {
|
||||||
|
constructor(
|
||||||
|
public $quantity: number,
|
||||||
|
public $unit: Unity,
|
||||||
|
public $ingredient: Ingredient
|
||||||
|
) {}
|
||||||
|
|
||||||
|
get quantity(): number {
|
||||||
|
return this.$quantity;
|
||||||
|
}
|
||||||
|
|
||||||
|
get unit(): Unity {
|
||||||
|
return this.$unit;
|
||||||
|
}
|
||||||
|
|
||||||
|
get ingredient(): Ingredient {
|
||||||
|
return this.$ingredient;
|
||||||
|
}
|
||||||
|
}
|
@ -1,8 +1,8 @@
|
|||||||
import {Unity} from "./unity";
|
import { Unity } from "./unity";
|
||||||
import {Ingredient} from "./ingredient.model";
|
import { Ingredient } from "./ingredient.model";
|
||||||
|
|
||||||
export interface QuantifiedIngredient {
|
export interface QuantifiedIngredient {
|
||||||
$quantity : number,
|
$quantity: number;
|
||||||
$unit : Unity,
|
$unit: Unity;
|
||||||
$ingredient : Ingredient
|
$ingredient: Ingredient;
|
||||||
}
|
}
|
||||||
|
@ -1,10 +1,10 @@
|
|||||||
import {QuantifiedIngredient} from "./quantified-ingredient.model";
|
import {QuantifiedIngredientGetter} from "./quantified-ingredient-getter.model";
|
||||||
|
|
||||||
export interface Recipe {
|
export interface Recipe {
|
||||||
$id : number,
|
$id : number,
|
||||||
$name : string,
|
$name : string,
|
||||||
$description: string,
|
$description: string,
|
||||||
$createdAt : Date,
|
$createdAt : Date,
|
||||||
$ingredients: QuantifiedIngredient[],
|
$ingredients: QuantifiedIngredientGetter[],
|
||||||
$image?: string
|
$image?: string
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in new issue