You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
170 lines
5.8 KiB
170 lines
5.8 KiB
using System;
|
|
using System.Collections.Generic;
|
|
using System.Runtime.CompilerServices;
|
|
using System.Runtime.Serialization;
|
|
using System.Security.Cryptography;
|
|
using System.Text;
|
|
|
|
namespace Model
|
|
{
|
|
/// <summary>
|
|
/// Define a Recipe for the preparation of a meal.
|
|
/// </summary>
|
|
[DataContract(Name = "recipe")]
|
|
public class Recipe : IEquatable<Recipe>
|
|
{
|
|
#region Attributes
|
|
[DataMember(Name = "title")]
|
|
private string _title = "";
|
|
#endregion
|
|
|
|
#region Properties
|
|
/// <summary>
|
|
/// The ID of the recipe - allows you to compare and/or get this item in an easier way.
|
|
/// </summary>
|
|
[DataMember(Name = "id")]
|
|
public int Id { get; init; }
|
|
|
|
/// <summary>
|
|
/// List of reviews of this recipe.
|
|
/// </summary>
|
|
[DataMember(Name = "reviews")]
|
|
public List<Review> Reviews { get; private set; }
|
|
|
|
/// <summary>
|
|
/// The Title of the recipe. <br/>
|
|
/// Set to "No title." when the value passed is null, empty or contain white spaces.
|
|
/// </summary>
|
|
public string Title
|
|
{
|
|
get => _title;
|
|
set
|
|
{
|
|
if (string.IsNullOrWhiteSpace(value))
|
|
_title = "No title.";
|
|
else
|
|
_title = value;
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// The steps of the preparation. See: <see cref="PreparationStep"/>.
|
|
/// </summary>
|
|
[DataMember(Name = "preparation-steps")]
|
|
public List<PreparationStep> PreparationSteps { get; set; }
|
|
#endregion
|
|
|
|
#region Constructors
|
|
/// <summary>
|
|
/// Construct a new recipe.
|
|
/// </summary>
|
|
/// <param name="title">The title of the recipe</param>
|
|
/// <param name="id">The id of the recipe. If not given, get a new id.</param>
|
|
/// <param name="preparationSteps">The steps of the preparation of the meal</param>
|
|
public Recipe(string title, int? id,
|
|
List<Review> reviews,
|
|
params PreparationStep[] preparationSteps)
|
|
{
|
|
Title = title;
|
|
PreparationSteps = new List<PreparationStep>(preparationSteps);
|
|
Reviews = reviews;
|
|
|
|
if (id == null)
|
|
{
|
|
var randomGenerator = RandomNumberGenerator.Create();
|
|
byte[] data = new byte[16];
|
|
randomGenerator.GetBytes(data);
|
|
Id = Math.Abs(BitConverter.ToInt16(data));
|
|
}
|
|
else Id = (int)id;
|
|
}
|
|
|
|
/// <summary>
|
|
/// <inheritdoc cref="Recipe.Recipe(string, int?, List{Review}, PreparationStep[])"/>
|
|
/// </summary>
|
|
/// <param name="title">The title of the recipe.</param>
|
|
public Recipe(string title)
|
|
: this(title, null, new List<Review>())
|
|
{
|
|
}
|
|
|
|
/// <summary>
|
|
/// <inheritdoc cref="Recipe.Recipe(string, int?, List{Review}, PreparationStep[])"/>
|
|
/// </summary>
|
|
/// <param name="title">The title of the recipe.</param>
|
|
/// <param name="preparationSteps">The steps of the preparation of the meal.</param>
|
|
public Recipe(string title, params PreparationStep[] preparationSteps)
|
|
: this(title, null, new List<Review>(), preparationSteps)
|
|
{
|
|
}
|
|
|
|
/// <summary>
|
|
/// <inheritdoc cref="Recipe.Recipe(string, int?, List{Review}, PreparationStep[])"/>
|
|
/// </summary>
|
|
/// <param name="title">The title of the recipe.</param>
|
|
/// <param name="id">The id of the recipe. If not given, get a new id.</param>
|
|
/// <param name="preparationSteps">The steps of the preparation of the meal.</param>
|
|
public Recipe(string title, int? id, params PreparationStep[] preparationSteps)
|
|
: this(title, id, new List<Review>(), preparationSteps)
|
|
{
|
|
}
|
|
#endregion
|
|
|
|
#region Methods
|
|
/// <summary>
|
|
/// Add a review for the recipe.
|
|
/// </summary>
|
|
/// <param name="review">The new review to add.</param>
|
|
public void AddReview(Review review)
|
|
=> Reviews.Add(review);
|
|
|
|
/// <summary>
|
|
/// Get a string representing all the reviews and their informations.
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
public string GetReviews()
|
|
{
|
|
StringBuilder sb = new StringBuilder("Reviews:\n------------------------------\n");
|
|
foreach (Review review in Reviews)
|
|
{
|
|
sb.AppendLine(review.ToString());
|
|
}
|
|
return sb.ToString();
|
|
}
|
|
|
|
public virtual bool Equals(Recipe? other)
|
|
{
|
|
if (other == null) return false;
|
|
if (other == this) return true;
|
|
return Title.Equals(other.Title) && PreparationSteps.Equals(other.PreparationSteps);
|
|
}
|
|
|
|
public override bool Equals(object? obj)
|
|
{
|
|
var item = obj as Recipe;
|
|
if (item == null) return false;
|
|
return Equals(obj);
|
|
}
|
|
|
|
public override int GetHashCode()
|
|
{
|
|
return Id.GetHashCode();
|
|
}
|
|
|
|
public override string ToString()
|
|
{
|
|
StringBuilder sb = new StringBuilder($"[Recipe n°{Id}] - {Title}\n");
|
|
foreach (PreparationStep ps in PreparationSteps)
|
|
{
|
|
sb.AppendFormat("\t* {0}\n", ps.ToString());
|
|
}
|
|
sb.AppendLine();
|
|
foreach (Review review in Reviews)
|
|
{
|
|
sb.AppendLine(review.ToString());
|
|
}
|
|
return sb.ToString();
|
|
}
|
|
#endregion
|
|
}
|
|
} |