Activity 33: Angular Recipe Grid

Activity 33: Angular Recipe Grid

Create a List of Object Data Structures

recipe.service.ts

import { Injectable } from '@angular/core';
import { RecipeModel } from '../components/recipe';

@Injectable({
  providedIn: 'root'
})
export class RecipeService {
  private recipes: RecipeModel[] = [
    {
      id: 1,
      name: "Adobo",
      ingredients:  `Chicken or pork braised in soy sauce, vinegar, and garlic`,
      imageUrl: "https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcTmww5jTG0tVGxjPAoMtgYndRrcCm-NtAjyOQ&s"
    },
    {
      id: 2,
      name: "Sinigang",
      ingredients:  `Tamarind-based sour soup with pork.`,
      imageUrl: ""
    },
    {
      id: 3,
      name: "Lechon Manok",
      ingredients:  `Filipino-style roasted chicken marinated with spices, cooked over charcoal for flavorful tenderness.`,
      imageUrl: "https://www.unileverfoodsolutions.com.ph/dam/global-ufs/mcos/SEA/calcmenu/recipes/PH-recipes/chicken-&-other-poultry-dishes/lechon-manok/lechon-manok-main.jpg"
    },
    {
      id: 4,
      name: "Kare Kare",
      ingredients:  `Peanut stew with oxtail, tripe, and vegetables.`,
      imageUrl: "https://www.unileverfoodsolutions.com.ph/dam/global-ufs/mcos/SEA/calcmenu/recipes/PH-recipes/red-meats-&-red-meat-dishes/kare-kare/kare-kare-main.jpg"
    },
    {
      id: 5,
      name: "Pansit Canton",
      ingredients:  `Stir-fried noodles with vegetables, shrimp, and meat.`,
      imageUrl: "https://thefoodietakesflight.com/wp-content/uploads/2021/03/vegan-filipino-stir-fried-noodles-or-pancit-canton-recipe-2-682x1024.png"
    },
    {
      id: 6,
      name: "Chicken Inasal",
      ingredients:  `Grilled chicken marinated in vinegar and spices`,
      imageUrl: "https://pinoybites.com/wp-content/uploads/2021/08/File_000-22-scaled.jpeg"
    },
    {
      id: 7,
      name: "Tinola",
      ingredients:  ` Chicken soup with green papaya, malunggay, and ginger.`,
      imageUrl: "https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcQSTOfPBLx7vK2vNhqjPhaZxlByrY65PS9MgA&s"
    },
    {
      id: 8,
      name: "Bicol Express",
      ingredients:  `Spicy pork stew with coconut milk and chili peppers.`,
      imageUrl: ""
    },
    {
      id: 9,
      name: "Bibingka",
      ingredients:  `rice cake made from rice flour, coconut milk, sugar, and topped with salted eggs and cheese, baked in banana leaves`,
      imageUrl: "https://www.foxyfolksy.com/wp-content/uploads/2017/12/bibingka-t-500x500.jpg"
    },
    {
      id: 10,
      name: "Tocino",
      ingredients:  `sweet cured meat, usually pork, marinated with sugar, pineapple juice, and annatto for color.`,
      imageUrl: "https://norecipes.com/wp-content/uploads/2018/05/filipino-tocino-recipe_010.jpg  "
    }




  ];

  getRecipe(): RecipeModel[] {
    return this.recipes;
  }
}

recipe.model.ts

export interface RecipeModel{
  id: number;
  name: string;
  ingredients:  string;
  imageUrl: string;
  }

recipe.component.ts

    import { RecipeService } from './../../services/recipe.service';
import { Component, OnInit } from '@angular/core';
import { RecipeModel } from '../recipe';

@Component({
  selector: 'app-recipe',
  templateUrl: './recipe.component.html',
  styleUrl: './recipe.component.css'
})
export class RecipeComponent implements OnInit{
  recipeList: RecipeModel[] = [];

  constructor(private recipeService: RecipeService) {}

  ngOnInit(): void {
    this.recipeList = this.recipeService.getRecipe();
  }
}

recipe.component.html

<!DOCTYPE html>
<html>
<head>
  <title>Angular Recipe Grid</title>
</head>
<body>
  <div class="recipe-grid">
  <div *ngFor="let recipe of recipeList" class="recipe-grid__item">
    <img
      class="recipe-grid__image"
      [src]="recipe.imageUrl"
    />
    <h2 class="recipe-grid__name">{{ recipe.name }}</h2>
    <p class="recipe-grid__author">{{ recipe.ingredients }}</p>
  </div>
  </div>
</body>
</html>

OUTPUT:

https://act-33-recipe-2024e.web.app/