This commit is contained in:
@@ -5,6 +5,7 @@ using Microsoft.AspNetCore.Mvc;
|
|||||||
using Microsoft.EntityFrameworkCore;
|
using Microsoft.EntityFrameworkCore;
|
||||||
using Microsoft.Extensions.Configuration;
|
using Microsoft.Extensions.Configuration;
|
||||||
using Microsoft.Extensions.Hosting;
|
using Microsoft.Extensions.Hosting;
|
||||||
|
using System.Globalization;
|
||||||
using System.Net.Http.Headers;
|
using System.Net.Http.Headers;
|
||||||
using System.Text.Json;
|
using System.Text.Json;
|
||||||
|
|
||||||
@@ -111,7 +112,71 @@ namespace Aberwyn.Controllers
|
|||||||
|
|
||||||
#region Skolmat
|
#region Skolmat
|
||||||
[HttpGet("skolmat")]
|
[HttpGet("skolmat")]
|
||||||
public async Task<IActionResult> GetSkolmat(int week, [FromQuery] string sensor = "sensor.engelbrektsskolan")
|
public async Task<IActionResult> GetSkolmat(int week, [FromQuery] string sensor = "sensor.engelbrektsskolan")
|
||||||
|
{
|
||||||
|
var token = "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiI3M2Q5ODIyYzU4ZWI0MjM4OWEyMGQ2MWQ2MWVhOWYzYyIsImlhdCI6MTc0OTE1MzY1MCwiZXhwIjoyMDY0NTEzNjUwfQ.8C_dKm7P1BbFVJKc_wT76YnQqiZxkP9EzrsLbfD0Ml8";
|
||||||
|
var client = new HttpClient();
|
||||||
|
client.BaseAddress = new Uri("https://ha.zcz.se");
|
||||||
|
client.DefaultRequestHeaders.Authorization =
|
||||||
|
new AuthenticationHeaderValue("Bearer", token);
|
||||||
|
|
||||||
|
var res = await client.GetAsync($"/api/states/{sensor}");
|
||||||
|
|
||||||
|
if (!res.IsSuccessStatusCode)
|
||||||
|
return StatusCode((int)res.StatusCode, $"Kunde inte hämta data för {sensor}");
|
||||||
|
|
||||||
|
var json = await res.Content.ReadAsStringAsync();
|
||||||
|
using var doc = JsonDocument.Parse(json);
|
||||||
|
|
||||||
|
var attr = doc.RootElement.GetProperty("attributes");
|
||||||
|
|
||||||
|
if (!attr.TryGetProperty("calendar", out var calendar))
|
||||||
|
return NotFound("Ingen kalender hittades i attributen");
|
||||||
|
|
||||||
|
var result = new List<SchoolMealDto>();
|
||||||
|
var culture = CultureInfo.InvariantCulture;
|
||||||
|
var calendarSystem = culture.Calendar;
|
||||||
|
|
||||||
|
foreach (var property in calendar.EnumerateObject())
|
||||||
|
{
|
||||||
|
var dateString = property.Name; // t.ex 2026-02-09
|
||||||
|
if (!DateTime.TryParse(dateString, out var date))
|
||||||
|
continue;
|
||||||
|
|
||||||
|
int weekNumber = calendarSystem.GetWeekOfYear(
|
||||||
|
date,
|
||||||
|
CalendarWeekRule.FirstFourDayWeek,
|
||||||
|
DayOfWeek.Monday);
|
||||||
|
|
||||||
|
if (weekNumber != week)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
var dishes = property.Value.EnumerateArray()
|
||||||
|
.Select(x => x.GetProperty("dish").GetString())
|
||||||
|
.ToList();
|
||||||
|
|
||||||
|
result.Add(new SchoolMealDto
|
||||||
|
{
|
||||||
|
Weekday = date.ToString("dddd", new CultureInfo("sv-SE")),
|
||||||
|
Date = date.ToString("yyyy-MM-dd"),
|
||||||
|
Courses = dishes
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!result.Any())
|
||||||
|
return NotFound("Ingen skolmat för vecka " + week);
|
||||||
|
|
||||||
|
return Ok(result.OrderBy(x => x.Date));
|
||||||
|
}
|
||||||
|
public class SchoolMealDto
|
||||||
|
{
|
||||||
|
public string Weekday { get; set; }
|
||||||
|
public string Date { get; set; }
|
||||||
|
public List<string> Courses { get; set; }
|
||||||
|
}
|
||||||
|
|
||||||
|
public async Task<IActionResult> GetSkolmatv0(int week, [FromQuery] string sensor = "sensor.engelbrektsskolan")
|
||||||
{
|
{
|
||||||
var token = "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiI3M2Q5ODIyYzU4ZWI0MjM4OWEyMGQ2MWQ2MWVhOWYzYyIsImlhdCI6MTc0OTE1MzY1MCwiZXhwIjoyMDY0NTEzNjUwfQ.8C_dKm7P1BbFVJKc_wT76YnQqiZxkP9EzrsLbfD0Ml8";
|
var token = "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiI3M2Q5ODIyYzU4ZWI0MjM4OWEyMGQ2MWQ2MWVhOWYzYyIsImlhdCI6MTc0OTE1MzY1MCwiZXhwIjoyMDY0NTEzNjUwfQ.8C_dKm7P1BbFVJKc_wT76YnQqiZxkP9EzrsLbfD0Ml8";
|
||||||
var client = new HttpClient();
|
var client = new HttpClient();
|
||||||
|
|||||||
@@ -79,8 +79,8 @@
|
|||||||
<div class="card-container" ng-show="school.expanded">
|
<div class="card-container" ng-show="school.expanded">
|
||||||
<div class="meal-card" ng-repeat="day in school.days">
|
<div class="meal-card" ng-repeat="day in school.days">
|
||||||
<div class="card-content school-meal-card-content">
|
<div class="card-content school-meal-card-content">
|
||||||
<div class="day">{{ day.weekday }}</div>
|
<div class="day">{{ day.Weekday }}</div>
|
||||||
<div class="meal" ng-repeat="meal in day.courses">{{ meal }}</div>
|
<div class="meal" ng-repeat="meal in day.Courses">{{ meal }}</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -51,9 +51,9 @@ angular.module('mealMenuApp', ['ngSanitize'])
|
|||||||
$scope.schoolMealsBySchool = [];
|
$scope.schoolMealsBySchool = [];
|
||||||
|
|
||||||
$scope.schoolSensors = [
|
$scope.schoolSensors = [
|
||||||
{ name: "William – Engelbrektsskolan", entity: "sensor.engelbrektsskolan" },
|
{ name: "William – Engelbrektsskolan", entity: "sensor.william_lunch" },
|
||||||
{ name: "Louise - Nyeds skolan", entity: "sensor.nyedsskola" },
|
{ name: "Louise - Nyeds skolan", entity: "sensor.louise_lunch" },
|
||||||
{ name: "Ludwig - Skogsgläntan", entity: "sensor.skogsglantan" }
|
{ name: "Ludwig - Skogsgläntan", entity: "sensor.ludwig_lunch" }
|
||||||
];
|
];
|
||||||
|
|
||||||
$scope.schoolMealsBySchool = [];
|
$scope.schoolMealsBySchool = [];
|
||||||
|
|||||||
Reference in New Issue
Block a user