mirror of
https://github.com/alexmickelson/canvasManagement.git
synced 2026-03-25 23:28:33 -06:00
built ui for default due time
This commit is contained in:
@@ -55,11 +55,9 @@ protected override void OnInitialized()
|
|||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="row justify-content-center">
|
<div class="border rounded bg-dark-subtle p-3 my-3">
|
||||||
<div class="col-auto border rounded bg-light p-3">
|
|
||||||
<InitializeYamlFromCanvas />
|
<InitializeYamlFromCanvas />
|
||||||
</div>
|
</div>
|
||||||
</div>
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -75,3 +73,4 @@ protected override void OnInitialized()
|
|||||||
</div>
|
</div>
|
||||||
<CourseDetails />
|
<CourseDetails />
|
||||||
}
|
}
|
||||||
|
<br>
|
||||||
@@ -5,6 +5,7 @@ global using CanvasModel.EnrollmentTerms;
|
|||||||
global using CanvasModel.Courses;
|
global using CanvasModel.Courses;
|
||||||
global using CanvasModel;
|
global using CanvasModel;
|
||||||
global using LocalModels;
|
global using LocalModels;
|
||||||
|
global using Management.Web.Shared.Components;
|
||||||
global using Management.Web.Shared.Course;
|
global using Management.Web.Shared.Course;
|
||||||
|
|
||||||
using Microsoft.AspNetCore.Components;
|
using Microsoft.AspNetCore.Components;
|
||||||
|
|||||||
120
Management.Web/Shared/Components/TimePicker.razor
Normal file
120
Management.Web/Shared/Components/TimePicker.razor
Normal file
@@ -0,0 +1,120 @@
|
|||||||
|
|
||||||
|
@code {
|
||||||
|
[Parameter]
|
||||||
|
[EditorRequired]
|
||||||
|
public SimpleTimeOnly Time { get; set; } = default!;
|
||||||
|
|
||||||
|
[Parameter]
|
||||||
|
[EditorRequired]
|
||||||
|
public Action<SimpleTimeOnly> UpdateTime { get; set; }= default!;
|
||||||
|
|
||||||
|
private string AmPm
|
||||||
|
{
|
||||||
|
get => Time.Hour < 12 ? "AM" : "PM";
|
||||||
|
}
|
||||||
|
private int AdjustedHour
|
||||||
|
{
|
||||||
|
get => convert24to12Hour(Time.Hour);
|
||||||
|
}
|
||||||
|
private int convert24to12Hour(int hour)
|
||||||
|
{
|
||||||
|
if (hour == 0)
|
||||||
|
{
|
||||||
|
// 12 AM
|
||||||
|
return 12;
|
||||||
|
}
|
||||||
|
else if (hour <= 12)
|
||||||
|
{
|
||||||
|
// AM hours
|
||||||
|
return hour;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// PM hours
|
||||||
|
return hour - 12;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private int convert12To24Hour(int hour, string? amPm)
|
||||||
|
{
|
||||||
|
if (amPm == null) return -1;
|
||||||
|
if (amPm.ToUpper() == "PM" && hour < 12)
|
||||||
|
{
|
||||||
|
return hour + 12;
|
||||||
|
}
|
||||||
|
else if (amPm.ToUpper() == "AM" && hour == 12)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return hour;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
<div>
|
||||||
|
<select
|
||||||
|
@onchange="async (e) =>
|
||||||
|
UpdateTime(
|
||||||
|
new SimpleTimeOnly
|
||||||
|
{
|
||||||
|
Hour=convert24to12Hour(Convert.ToInt32(e.Value)),
|
||||||
|
Minute=Time.Minute
|
||||||
|
}
|
||||||
|
)"
|
||||||
|
class="form-control w-auto d-inline"
|
||||||
|
>
|
||||||
|
@foreach (var hour in Enumerable.Range(1, 12))
|
||||||
|
{
|
||||||
|
<option
|
||||||
|
value="@hour"
|
||||||
|
selected="@(hour == Time.Hour)"
|
||||||
|
>
|
||||||
|
@hour.ToString("00")
|
||||||
|
</option>
|
||||||
|
}
|
||||||
|
</select>
|
||||||
|
<span class="pl-0">:</span>
|
||||||
|
<select
|
||||||
|
@onchange="async (e) =>
|
||||||
|
UpdateTime(
|
||||||
|
new SimpleTimeOnly
|
||||||
|
{
|
||||||
|
Hour=AdjustedHour,
|
||||||
|
Minute=Convert.ToInt32(e.Value)
|
||||||
|
}
|
||||||
|
)"
|
||||||
|
class="form-control w-auto d-inline"
|
||||||
|
>
|
||||||
|
@foreach (var minute in new int[] {0, 15, 30, 45, 59})
|
||||||
|
{
|
||||||
|
<option
|
||||||
|
value="@minute"
|
||||||
|
selected="@(minute == Time.Minute)"
|
||||||
|
>
|
||||||
|
@(minute.ToString("00"))
|
||||||
|
</option>
|
||||||
|
}
|
||||||
|
</select>
|
||||||
|
|
||||||
|
<select
|
||||||
|
@onchange="(e) =>
|
||||||
|
UpdateTime(
|
||||||
|
new SimpleTimeOnly
|
||||||
|
{
|
||||||
|
Hour=convert12To24Hour(Time.Hour, e.Value?.ToString()),
|
||||||
|
Minute=Time.Minute
|
||||||
|
}
|
||||||
|
)"
|
||||||
|
class="form-control w-auto d-inline"
|
||||||
|
>
|
||||||
|
@foreach (var amPm in new string[] {"AM", "PM"})
|
||||||
|
{
|
||||||
|
<option
|
||||||
|
value="@amPm"
|
||||||
|
selected="@(amPm == AmPm)"
|
||||||
|
>
|
||||||
|
@amPm
|
||||||
|
</option>
|
||||||
|
}
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
@@ -40,17 +40,20 @@ else
|
|||||||
|
|
||||||
|
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col">
|
<div class="col overflow-y-auto border rounded " style="max-height: 95vh;">
|
||||||
@if (planner.LocalCourse != null)
|
@if (planner.LocalCourse != null)
|
||||||
{
|
{
|
||||||
|
<div class="py-2">
|
||||||
|
|
||||||
@foreach (var month in SemesterPlanner.GetMonthsBetweenDates(planner.LocalCourse.StartDate, planner.LocalCourse.EndDate))
|
@foreach (var month in SemesterPlanner.GetMonthsBetweenDates(planner.LocalCourse.StartDate, planner.LocalCourse.EndDate))
|
||||||
{
|
{
|
||||||
<MonthDetail Month="month" />
|
<MonthDetail Month="month" />
|
||||||
<hr />
|
<hr />
|
||||||
}
|
}
|
||||||
|
</div>
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
<div class="col-4">
|
<div class="col-4 overflow-y-auto" style="max-height: 95vh;">
|
||||||
<Modules />
|
<Modules />
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -1,3 +1,4 @@
|
|||||||
|
@using Management.Web.Shared.Components
|
||||||
@inject CanvasService canvas
|
@inject CanvasService canvas
|
||||||
@inject CoursePlanner planner
|
@inject CoursePlanner planner
|
||||||
|
|
||||||
@@ -98,3 +99,23 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@if(planner.LocalCourse != null)
|
||||||
|
{
|
||||||
|
<div class="row justify-content-center m-3 text-center">
|
||||||
|
<div class="col-auto">
|
||||||
|
<div>Default Assignment Due Time</div>
|
||||||
|
<TimePicker
|
||||||
|
Time="planner.LocalCourse.DefaultDueTime"
|
||||||
|
UpdateTime="@((newTime) =>
|
||||||
|
planner.LocalCourse =
|
||||||
|
planner.LocalCourse with
|
||||||
|
{ DefaultDueTime=newTime }
|
||||||
|
)"
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
}
|
||||||
|
|
||||||
|
<br>
|
||||||
@@ -20,10 +20,8 @@
|
|||||||
set
|
set
|
||||||
{
|
{
|
||||||
_selectedTermId = value;
|
_selectedTermId = value;
|
||||||
|
this.InvokeAsync(updateCourses);
|
||||||
@* updateCourses(); *@
|
@* updateCourses(); *@
|
||||||
var task = Task.Run(async () => await updateCourses());
|
|
||||||
task.Wait();
|
|
||||||
StateHasChanged();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
private EnrollmentTermModel? selectedTerm
|
private EnrollmentTermModel? selectedTerm
|
||||||
|
|||||||
@@ -45,8 +45,8 @@
|
|||||||
<div
|
<div
|
||||||
id="@accordionId"
|
id="@accordionId"
|
||||||
class="accordion-collapse collapse"
|
class="accordion-collapse collapse"
|
||||||
data-bs-parent="#modulesAccordion"
|
|
||||||
>
|
>
|
||||||
|
@* data-bs-parent="#modulesAccordion" include to limit expanded sections *@
|
||||||
<div class="accordion-body pt-1">
|
<div class="accordion-body pt-1">
|
||||||
|
|
||||||
<div class="row m-1">
|
<div class="row m-1">
|
||||||
|
|||||||
64
Management.Web/Shared/Semester/AssignmentInDay.razor
Normal file
64
Management.Web/Shared/Semester/AssignmentInDay.razor
Normal file
@@ -0,0 +1,64 @@
|
|||||||
|
|
||||||
|
@inject AssignmentDragContainer dragContainer
|
||||||
|
@inject CoursePlanner planner
|
||||||
|
|
||||||
|
@code {
|
||||||
|
[Parameter]
|
||||||
|
[EditorRequired]
|
||||||
|
public LocalAssignment Assignment { get; set; } = new();
|
||||||
|
|
||||||
|
private void HandleDragStart()
|
||||||
|
{
|
||||||
|
dragContainer.DropCallback = (DateTime dropDate) => {
|
||||||
|
var module = planner
|
||||||
|
.LocalCourse?
|
||||||
|
.Modules
|
||||||
|
.First(m =>
|
||||||
|
m.Assignments
|
||||||
|
.Select(a => a.id)
|
||||||
|
.Contains(Assignment.id)
|
||||||
|
);
|
||||||
|
if (module == null)
|
||||||
|
{
|
||||||
|
Console.WriteLine("module is null");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (planner.LocalCourse != null)
|
||||||
|
{
|
||||||
|
var newCourse = planner.LocalCourse with
|
||||||
|
{
|
||||||
|
Modules = planner.LocalCourse.Modules.Select(m =>
|
||||||
|
m.Name != module.Name
|
||||||
|
? m
|
||||||
|
: m with
|
||||||
|
{
|
||||||
|
Assignments = module.Assignments.Select(a =>
|
||||||
|
a.id != Assignment.id
|
||||||
|
? a
|
||||||
|
: a with
|
||||||
|
{
|
||||||
|
due_at=dropDate
|
||||||
|
}
|
||||||
|
)
|
||||||
|
}
|
||||||
|
)
|
||||||
|
};
|
||||||
|
planner.LocalCourse = newCourse;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
private void HandleDragEnd()
|
||||||
|
{
|
||||||
|
dragContainer.DropCallback = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
<div
|
||||||
|
draggable="true"
|
||||||
|
@ondragstart="HandleDragStart"
|
||||||
|
@ondragend="HandleDragEnd"
|
||||||
|
role="button"
|
||||||
|
>
|
||||||
|
@Assignment.name
|
||||||
|
</div>
|
||||||
@@ -56,7 +56,9 @@
|
|||||||
&& date < planner.LocalCourse.EndDate
|
&& date < planner.LocalCourse.EndDate
|
||||||
&& date > planner.LocalCourse.StartDate;
|
&& date > planner.LocalCourse.StartDate;
|
||||||
|
|
||||||
var totalClasses = dayInSemester ? $"bg-light-subtle text-light " + baseClasses : baseClasses;
|
var totalClasses = dayInSemester
|
||||||
|
? "bg-light-subtle text-light " + baseClasses
|
||||||
|
: " " + baseClasses;
|
||||||
|
|
||||||
return totalClasses;
|
return totalClasses;
|
||||||
}
|
}
|
||||||
@@ -97,10 +99,10 @@
|
|||||||
ondragover="event.preventDefault();"
|
ondragover="event.preventDefault();"
|
||||||
>
|
>
|
||||||
@(isWeekDay ? date?.Day : "")
|
@(isWeekDay ? date?.Day : "")
|
||||||
<ul class="m-0 ps-3">
|
<div class="m-0 ps-3">
|
||||||
@foreach (var assignment in TodaysAssignments)
|
@foreach (var assignment in TodaysAssignments)
|
||||||
{
|
{
|
||||||
<li>@assignment.name</li>
|
<AssignmentInDay Assignment="assignment" />
|
||||||
}
|
}
|
||||||
</ul>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -35,20 +35,6 @@
|
|||||||
<div class="row m-3">
|
<div class="row m-3">
|
||||||
@foreach (var day in week)
|
@foreach (var day in week)
|
||||||
{
|
{
|
||||||
|
|
||||||
@* var baseClasses = "col border rounded rounded-3 pb-5 m-1";
|
|
||||||
DayOfWeek? weekDay = day?.DayOfWeek;
|
|
||||||
if (weekDay != null)
|
|
||||||
{
|
|
||||||
DayOfWeek notNullDay = weekDay ?? default;
|
|
||||||
var dayInSemester = Semester.Days.Contains(notNullDay) && day < Semester.LastDay && day > Semester.FirstDay;
|
|
||||||
var totalClasses = dayInSemester ? $"bg-light {baseClasses}" : baseClasses;
|
|
||||||
<div class="@totalClasses">@day?.Day</div>
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
<div class="@baseClasses"></div>
|
|
||||||
} *@
|
|
||||||
<Day date="day"></Day>
|
<Day date="day"></Day>
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -8,4 +8,11 @@ public record LocalCourse
|
|||||||
public ulong? CanvasId { get; init; }
|
public ulong? CanvasId { get; init; }
|
||||||
public DateTime StartDate { get; init; }
|
public DateTime StartDate { get; init; }
|
||||||
public DateTime EndDate { get; init; }
|
public DateTime EndDate { get; init; }
|
||||||
|
public SimpleTimeOnly DefaultDueTime { get; init; } = new SimpleTimeOnly();
|
||||||
|
}
|
||||||
|
|
||||||
|
public record SimpleTimeOnly
|
||||||
|
{
|
||||||
|
public int Hour { get; init; } = 1;
|
||||||
|
public int Minute { get; init; } = 0;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user