Activity 33: Angular Recipe Grid

Jerome BerisoJerome Beriso
3 min read

This documentation outlines the structure and functionality of the Recipe Application, a simple application that manages recipe data. The application is built using TypeScript and Angular, and consists of the following components:

1. recipe.service.ts:

  • Purpose: The recipe.service.ts file houses the service responsible for managing recipe data. It provides methods for creating, reading, updating, and deleting (CRUD) recipes.

  • Key Methods:

    • getRecipes(): Retrieves all recipes from the data source.

    • getRecipe(id: number): Retrieves a specific recipe by its ID.

    • addRecipe(recipe: Recipe): Adds a new recipe to the data source.

    • updateRecipe(recipe: Recipe): Updates an existing recipe in the data source.

    • deleteRecipe(id: number): Deletes a recipe from the data source.

  • Example Usage:


import { Injectable } from '@angular/core';
import { Recipe } from '../models/library.mode';

@Injectable({
  providedIn: 'root',
})
export class RecipeService {
  private recipeList: Recipe[] = [
    {
      name: 'Adobo',
      price: '250',
      star: '★★★☆☆',
      image:'',

    },
    {
      name: 'Sinigang',
      price: '300',
      star: '★★★★☆',
      image: 'https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcTImaYPY_rHxSgGg1ogioWhOaNxeEp4TTNiIw&s',
    },
    {
      name: 'Tinola',
      price: '150',
      star: '★☆☆☆☆',
      image:
        'https://panlasangpinoy.com/wp-content/uploads/2014/12/Tinola.jpg',
    },
    {
      name: 'Kare-kare',
      price: '250',
      star: '★★☆☆☆',
      image:'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',

    },
    {
      name: 'Letchon Kawali',
      price: '100',
      star: '★★★☆☆',
      image: 'https://www.sentro1771.com/ews/wp-content/uploads/2023/06/Lechon-Kawali_V2-scaled.jpg',
    },


  ];

  getRecipe() {
    return this.recipeList;
  }
}

2. recipe.model.ts:

  • Purpose: The recipe.model.ts file defines the Recipe interface, which represents the structure of a recipe object. It defines the properties that each recipe object should have.

  • Interface Definition:


export interface Recipe {
  name: string;
  price: string;
  image: string;
  star: string
}

3. recipe.component.ts:

  • Purpose: The recipe.component.ts file contains the logic for the Recipe component, which displays and interacts with recipe data. It handles user interactions, data binding, and communication with the recipe.service.ts.

  • Key Methods:

    • ngOnInit(): Initializes the component, typically fetching initial recipe data from the service.

    • addRecipe(): Handles the addition of a new recipe.

    • updateRecipe(recipe: Recipe): Handles the updating of an existing recipe.

    • deleteRecipe(id: number): Handles the deletion of a recipe.

  • Example Usage:


import { Component } from '@angular/core';
import {Recipe} from '../../models/library.mode';
import { RecipeService } from '../../services/library.service';
import { OnInit } from '@angular/core';


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

  constructor(private libraryService: RecipeService) {}

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

4. recipe.component.html:

  • Purpose: The recipe.component.html file defines the template for the Recipe component. It uses Angular's template syntax to display recipe data and provide user interaction elements.

  • Template Structure:


<h1>Activity 33: Angular Recipe Grid</h1>
<main class="roboto-regular">
  @for(book of recipeList; track $index){
    <div class="book-card">
      <div class="book-card__image__container">
        <img class="book-card__image" [src]="book.image" />
      </div>
      <div class="book-card__details">
        <p class="book-card__details__information roboto-bold">
          Title: <span class="roboto-regular">{{ book.name }}</span>
        </p>

        <p class="book-card__details__information roboto-bold">
          Price: <span class="roboto-regular">{{ book.price }}</span>
        </p>
        <p class="book-card__details__information roboto-bold">
          Star: <span class="roboto-regular">{{ book.star }}</span>
        </p>
        <div class="button-container">
          <button class="button-borrow roboto-medium"> Show Ingredient</button>
        </div>

      </div>
    </div>
  }
</main>
  • Key Elements:

    • *ngFor: Iterates over the recipes array to display each recipe.

    • {{ recipe.name }}: Data binding to display the recipe name.

    • (click)="deleteRecipe(recipe.id)": Event binding to trigger the deleteRecipe() method when the delete button is clicked.

Overall Application Flow:

  1. The recipe.component.ts initializes and fetches recipe data from the recipe.service.ts.

  2. The recipe.component.html displays the recipe data using Angular's template syntax.

  3. User interactions, such as adding, updating, or deleting recipes, are handled by the recipe.component.ts.

  4. The recipe.component.ts communicates with the recipe.service.ts to perform CRUD operations on recipe data.

This documentation provides a basic overview of the Recipe Application. For a more detailed understanding, please refer to the source code files.

GITHUB LINK:https://github.com/jerome09232/acitivity33
FIREBASE LINK:
https://acitivity33.web.app/

0
Subscribe to my newsletter

Read articles from Jerome Beriso directly inside your inbox. Subscribe to the newsletter, and don't miss out.

Written by

Jerome Beriso
Jerome Beriso