Init commit

This commit is contained in:
Blake Ridgway 2025-06-17 13:22:51 -05:00
parent 9ab798fd0f
commit 1f50fedb80
87 changed files with 75678 additions and 0 deletions

View file

@ -0,0 +1,74 @@
using System.Diagnostics;
using Microsoft.AspNetCore.Mvc;
using Microsoft.EntityFrameworkCore;
using turf_tasker.Data;
using turf_tasker.Models;
namespace turf_tasker.Controllers;
public class HomeController : Controller
{
private readonly ApplicationDbContext _context;
// Step 2.1: Inject the database context
public HomeController(ApplicationDbContext context)
{
_context = context;
}
// Step 2.2: Make the Index action async
public async Task<IActionResult> Index()
{
// Step 2.3: Query for the last mow event to get its date and pattern
var lastMowEvent = await _context.LawnCareEvents
.Where(e => e.EventType == LawnCareEventType.Mowing)
.OrderByDescending(e => e.EventDate)
.FirstOrDefaultAsync();
// Step 2.4: Query for the last water and fertilize dates
var lastWaterDate = await _context.LawnCareEvents
.Where(e => e.EventType == LawnCareEventType.Watering)
.OrderByDescending(e => e.EventDate)
.Select(e => (DateTime?)e.EventDate) // Select just the date
.FirstOrDefaultAsync();
var lastFertilizeDate = await _context.LawnCareEvents
.Where(e => e.EventType == LawnCareEventType.Fertilizing)
.OrderByDescending(e => e.EventDate)
.Select(e => (DateTime?)e.EventDate)
.FirstOrDefaultAsync();
// Determine the next mowing pattern
MowingPattern? nextPattern = MowingPattern.Vertical; // Default
if (lastMowEvent?.MowingPattern != null)
{
// This logic cycles through the enum values
int currentPatternValue = (int)lastMowEvent.MowingPattern;
int nextPatternValue = (currentPatternValue + 1) % 4; // 4 patterns total
nextPattern = (MowingPattern)nextPatternValue;
}
// Step 2.5: Create the ViewModel and populate it
var viewModel = new DashboardViewModel
{
LastMowDate = lastMowEvent?.EventDate,
LastWaterDate = lastWaterDate,
LastFertilizeDate = lastFertilizeDate,
NextMowingPattern = nextPattern
};
// Step 2.6: Pass the populated ViewModel to the view
return View(viewModel);
}
public IActionResult Privacy()
{
return View();
}
[ResponseCache(Duration = 0, Location = ResponseCacheLocation.None, NoStore = true)]
public IActionResult Error()
{
return View(new ErrorViewModel { RequestId = Activity.Current?.Id ?? HttpContext.TraceIdentifier });
}
}

View file

@ -0,0 +1,186 @@
using Microsoft.AspNetCore.Mvc;
using Microsoft.EntityFrameworkCore;
using turf_tasker.Data;
using turf_tasker.Models;
namespace turf_tasker.Controllers
{
public class LawnCareEventsController : Controller
{
private readonly ApplicationDbContext _context;
public LawnCareEventsController(ApplicationDbContext context)
{
_context = context;
}
// GET: LawnCareEvents
public async Task<IActionResult> Index(string sortOrder, string searchString)
{
// Use ViewData to pass sort order info to the view
ViewData["DateSortParm"] = String.IsNullOrEmpty(sortOrder) ? "date_desc" : "";
ViewData["TypeSortParm"] = sortOrder == "Type" ? "type_desc" : "Type";
ViewData["CurrentFilter"] = searchString;
// Start with a base query that can be modified
var events = from e in _context.LawnCareEvents
select e;
// Apply the filter if a search string is provided
if (!String.IsNullOrEmpty(searchString))
{
events = events.Where(e =>
e.Notes!.Contains(searchString) ||
e.EventType.ToString().Contains(searchString)
);
}
// Apply the sorting based on the sortOrder parameter
switch (sortOrder)
{
case "date_desc":
events = events.OrderByDescending(e => e.EventDate);
break;
case "Type":
events = events.OrderBy(e => e.EventType);
break;
case "type_desc":
events = events.OrderByDescending(e => e.EventType);
break;
default: // Default sort order is by date, ascending
events = events.OrderBy(e => e.EventDate);
break;
}
// Execute the query and return the view with the filtered/sorted list
return View(await events.AsNoTracking().ToListAsync());
}
// GET: LawnCareEvents/Details/5
public async Task<IActionResult> Details(int? id)
{
if (id == null)
{
return NotFound();
}
var lawnCareEvent = await _context.LawnCareEvents
.FirstOrDefaultAsync(m => m.Id == id);
if (lawnCareEvent == null)
{
return NotFound();
}
return View(lawnCareEvent);
}
// GET: LawnCareEvents/Create
// MODIFIED: We now create a model with a default date.
public IActionResult Create()
{
var model = new LawnCareEvent { EventDate = DateTime.Now };
return View(model);
}
// POST: LawnCareEvents/Create
[HttpPost]
[ValidateAntiForgeryToken]
public async Task<IActionResult> Create([Bind("Id,EventType,EventDate,MowingPattern,Notes")] LawnCareEvent lawnCareEvent)
{
if (ModelState.IsValid)
{
_context.Add(lawnCareEvent);
await _context.SaveChangesAsync();
return RedirectToAction(nameof(Index));
}
return View(lawnCareEvent);
}
// GET: LawnCareEvents/Edit/5
public async Task<IActionResult> Edit(int? id)
{
if (id == null)
{
return NotFound();
}
var lawnCareEvent = await _context.LawnCareEvents.FindAsync(id);
if (lawnCareEvent == null)
{
return NotFound();
}
return View(lawnCareEvent);
}
// POST: LawnCareEvents/Edit/5
[HttpPost]
[ValidateAntiForgeryToken]
public async Task<IActionResult> Edit(int id, [Bind("Id,EventType,EventDate,MowingPattern,Notes")] LawnCareEvent lawnCareEvent)
{
if (id != lawnCareEvent.Id)
{
return NotFound();
}
if (ModelState.IsValid)
{
try
{
_context.Update(lawnCareEvent);
await _context.SaveChangesAsync();
}
catch (DbUpdateConcurrencyException)
{
if (!LawnCareEventExists(lawnCareEvent.Id))
{
return NotFound();
}
else
{
throw;
}
}
return RedirectToAction(nameof(Index));
}
return View(lawnCareEvent);
}
// GET: LawnCareEvents/Delete/5
public async Task<IActionResult> Delete(int? id)
{
if (id == null)
{
return NotFound();
}
var lawnCareEvent = await _context.LawnCareEvents
.FirstOrDefaultAsync(m => m.Id == id);
if (lawnCareEvent == null)
{
return NotFound();
}
return View(lawnCareEvent);
}
// POST: LawnCareEvents/Delete/5
[HttpPost, ActionName("Delete")]
[ValidateAntiForgeryToken]
public async Task<IActionResult> DeleteConfirmed(int id)
{
var lawnCareEvent = await _context.LawnCareEvents.FindAsync(id);
if (lawnCareEvent != null)
{
_context.LawnCareEvents.Remove(lawnCareEvent);
}
await _context.SaveChangesAsync();
return RedirectToAction(nameof(Index));
}
private bool LawnCareEventExists(int id)
{
return _context.LawnCareEvents.Any(e => e.Id == id);
}
}
}