ConfigureDay.cshtml 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196
  1. @model Recepie.ViewModels.DayPlanConfigViewModel
  2. <!DOCTYPE html>
  3. <html lang="en">
  4. <head>
  5. <meta charset="utf-8" />
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  7. <title>Configure Day - Recipe Manager</title>
  8. <link rel="stylesheet" href="~/lib/bootstrap/dist/css/bootstrap.min.css" />
  9. <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0/css/all.min.css" />
  10. <link rel="stylesheet" href="~/css/site.css" />
  11. </head>
  12. <body>
  13. <header>
  14. <nav class="navbar navbar-expand-sm navbar-toggleable-sm navbar-dark bg-primary border-bottom box-shadow mb-3">
  15. <div class="container-fluid">
  16. <a class="navbar-brand" href="/">
  17. <i class="fas fa-utensils"></i> Recipe Manager
  18. </a>
  19. <button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target=".navbar-collapse"
  20. aria-controls="navbarSupportedContent" aria-expanded="false" aria-label="Toggle navigation">
  21. <span class="navbar-toggler-icon"></span>
  22. </button>
  23. <div class="navbar-collapse collapse d-sm-inline-flex justify-content-between">
  24. <ul class="navbar-nav flex-grow-1">
  25. <li class="nav-item">
  26. <a class="nav-link" href="/">
  27. <i class="fas fa-home"></i> All Recipes
  28. </a>
  29. </li>
  30. <li class="nav-item">
  31. <a class="nav-link active" href="/WeekPlanner">
  32. <i class="fas fa-calendar-week"></i> Week Planner
  33. </a>
  34. </li>
  35. <li class="nav-item">
  36. <a class="nav-link" href="/Recipe/Create">
  37. <i class="fas fa-plus"></i> Add Recipe
  38. </a>
  39. </li>
  40. </ul>
  41. </div>
  42. </div>
  43. </nav>
  44. </header>
  45. <div class="container-fluid">
  46. <main role="main" class="pb-3">
  47. <nav aria-label="breadcrumb">
  48. <ol class="breadcrumb">
  49. <li class="breadcrumb-item"><a href="/Recipe">All Recipes</a></li>
  50. <li class="breadcrumb-item"><a href="/WeekPlanner">Week Planner</a></li>
  51. <li class="breadcrumb-item active">Configure Day</li>
  52. </ol>
  53. </nav>
  54. <h1 class="mb-4">🍽️ Configure Day Plan</h1>
  55. <div class="row">
  56. <div class="col-lg-8">
  57. <form action="/WeekPlanner/UpdateDayPlan" method="post">
  58. <input type="hidden" name="DayPlanId" value="@Model.DayPlanId" />
  59. <div class="card mb-4">
  60. <div class="card-header">
  61. <h5 class="mb-0">🥘 Meal Preferences for @Model.DayOfWeek</h5>
  62. </div>
  63. <div class="card-body">
  64. <div class="mb-3">
  65. <label for="SelectedMainIngredient" class="form-label">Main Ingredient</label>
  66. <select name="SelectedMainIngredient" class="form-select">
  67. <option value="">No preference</option>
  68. @foreach (var ingredient in Model.AvailableMainIngredients)
  69. {
  70. <option value="@ingredient"
  71. selected="@(ingredient == Model.SelectedMainIngredient)">@ingredient
  72. </option>
  73. }
  74. </select>
  75. <div class="form-text">Choose a main ingredient to focus the meal around</div>
  76. </div>
  77. <div class="mb-3">
  78. <label for="RequiredIngredients" class="form-label">Required Ingredients</label>
  79. <input name="RequiredIngredients" class="form-control"
  80. placeholder="e.g., tomatoes, cheese, basil" value="@Model.RequiredIngredients">
  81. <div class="form-text">Comma-separated list of ingredients that must be included
  82. </div>
  83. </div>
  84. <div class="mb-3">
  85. <label for="BannedIngredients" class="form-label">Avoid Ingredients</label>
  86. <input name="BannedIngredients" class="form-control"
  87. placeholder="e.g., nuts, dairy, shellfish" value="@Model.BannedIngredients">
  88. <div class="form-text">Comma-separated list of ingredients to avoid</div>
  89. </div>
  90. @if (Model.SuggestedRecipes != null && Model.SuggestedRecipes.Any())
  91. {
  92. <div class="mb-3">
  93. <label for="SelectedRecipeId" class="form-label">Suggested Recipes</label>
  94. <select name="SelectedRecipeId" class="form-select">
  95. <option value="">No recipe selected</option>
  96. @foreach (var recipe in Model.SuggestedRecipes)
  97. {
  98. <option value="@recipe.Id" selected="@(recipe.Id == Model.SelectedRecipeId)">
  99. @recipe.Title</option>
  100. }
  101. </select>
  102. <div class="form-text">Choose from recipes that match your preferences</div>
  103. </div>
  104. }
  105. </div>
  106. </div>
  107. <div class="d-flex gap-2">
  108. <button type="submit" class="btn btn-primary">💾 Save Configuration</button>
  109. <a href="/WeekPlanner" class="btn btn-outline-secondary">↩️ Back to Week Plan</a>
  110. </div>
  111. </form>
  112. </div>
  113. <div class="col-lg-4">
  114. <div class="card mb-3">
  115. <div class="card-header">
  116. <h6 class="mb-0">📊 Week Overview</h6>
  117. </div>
  118. <div class="card-body">
  119. <p class="small mb-2"><strong>Day:</strong> @Model.DayOfWeek</p>
  120. <p class="small mb-2"><strong>Date:</strong> @Model.Date.ToString("MMM dd, yyyy")</p>
  121. @if (!string.IsNullOrEmpty(Model.SelectedMainIngredient))
  122. {
  123. <p class="small mb-2"><strong>Main Ingredient:</strong> @Model.SelectedMainIngredient</p>
  124. }
  125. @if (Model.SuggestedRecipes != null && Model.SuggestedRecipes.Any())
  126. {
  127. <p class="small mb-0"><strong>Available Recipes:</strong> @Model.SuggestedRecipes.Count</p>
  128. }
  129. </div>
  130. </div>
  131. <div class="card mb-3">
  132. <div class="card-header">
  133. <h6 class="mb-0">💡 Tips</h6>
  134. </div>
  135. <div class="card-body">
  136. <ul class="small mb-0 ps-3">
  137. <li>Choose a main ingredient to see relevant recipes</li>
  138. <li>Add ingredients to avoid (allergies, dislikes)</li>
  139. <li>Specify required ingredients for specific dishes</li>
  140. <li>Use "Random Recipe" for variety in your week</li>
  141. </ul>
  142. </div>
  143. </div>
  144. @if (Model.SuggestedRecipes != null && Model.SuggestedRecipes.Any())
  145. {
  146. <div class="card">
  147. <div class="card-header">
  148. <h6 class="mb-0">🍽️ Recipe Suggestions</h6>
  149. </div>
  150. <div class="card-body">
  151. @foreach (var recipe in Model.SuggestedRecipes.Take(5))
  152. {
  153. <div class="d-flex justify-content-between align-items-center mb-2">
  154. <span class="small">@recipe.Title</span>
  155. @if (!string.IsNullOrEmpty(recipe.Time))
  156. {
  157. <span class="badge bg-info">@recipe.Time min</span>
  158. }
  159. </div>
  160. }
  161. @if (Model.SuggestedRecipes.Count > 5)
  162. {
  163. <small class="text-muted">... and @(Model.SuggestedRecipes.Count - 5) more</small>
  164. }
  165. </div>
  166. </div>
  167. }
  168. </div>
  169. </div>
  170. </main>
  171. </div>
  172. <footer class="border-top footer text-muted mt-5">
  173. <div class="container">
  174. &copy; @DateTime.Now.Year - Recipe Manager - Your Personal Recipe Collection
  175. </div>
  176. </footer>
  177. <script src="~/lib/jquery/dist/jquery.min.js"></script>
  178. <script src="~/lib/bootstrap/dist/js/bootstrap.bundle.min.js"></script>
  179. <script src="~/js/site.js"></script>
  180. </body>
  181. </html>