maybe got default time selector less insane

This commit is contained in:
2023-07-26 13:39:49 -06:00
parent 900cf9b074
commit cc09d32bcf
5 changed files with 226 additions and 163 deletions

View File

@@ -1,4 +1,6 @@
@inject CoursePlanner planner
@code {
[Parameter]
[EditorRequired]
@@ -7,47 +9,51 @@
[Parameter]
[EditorRequired]
public Action<SimpleTimeOnly> UpdateTime { get; set; }= default!;
protected override void OnInitialized()
{
planner.StateHasChanged += reload;
}
private void reload()
{
this.InvokeAsync(this.StateHasChanged);
}
public void Dispose()
{
planner.StateHasChanged -= reload;
}
private string AmPm
{
get => Time.Hour < 12 ? "AM" : "PM";
}
private int AdjustedHour
{
get => convert24to12Hour(Time.Hour);
}
private int convert24to12Hour(int hour)
{
if (hour == 0)
get
{
// 12 AM
return 12;
}
else if (hour <= 12)
{
@* if (Time.Hour == 0)
return 12; *@
// AM hours
return hour;
}
else
{
if (Time.Hour <= 11)
return Time.Hour;
// PM hours
return hour - 12;
return Time.Hour + 1 - 12;
}
}
private int convert12To24Hour(int hour, string? amPm)
private int convertTo24Hour(int hour, string? amPm)
{
if (amPm == null) return -1;
if (amPm.ToUpper() == "PM" && hour < 12)
if(amPm == "AM")
{
return hour + 12;
return hour % 12;
}
else if (amPm.ToUpper() == "AM" && hour == 12)
else
{
return 0;
}
else
{
return hour;
if (hour == 12)
return 12;
else
return hour + 12;
}
}
}
@@ -57,16 +63,22 @@
UpdateTime(
new SimpleTimeOnly
{
Hour=convert24to12Hour(Convert.ToInt32(e.Value)),
Hour=convertTo24Hour(Convert.ToInt32(e.Value), AmPm),
Minute=Time.Minute
}
)"
class="form-control w-auto d-inline"
>
@foreach (var hour in Enumerable.Range(1, 12))
<option
value="12"
selected="@(12 == Time.Hour)"
>
12
</option>
@foreach (var hour in Enumerable.Range(1, 11))
{
<option
value="@hour"
value="@hour"
selected="@(hour == Time.Hour)"
>
@hour.ToString("00")
@@ -79,7 +91,7 @@
UpdateTime(
new SimpleTimeOnly
{
Hour=AdjustedHour,
Hour=Time.Hour,
Minute=Convert.ToInt32(e.Value)
}
)"
@@ -101,7 +113,7 @@
UpdateTime(
new SimpleTimeOnly
{
Hour=convert12To24Hour(Time.Hour, e.Value?.ToString()),
Hour=convertTo24Hour(Time.Hour, e.Value?.ToString()),
Minute=Time.Minute
}
)"

View File

@@ -4,6 +4,18 @@
@code
{
protected override void OnInitialized()
{
planner.StateHasChanged += reload;
}
private void reload()
{
this.InvokeAsync(this.StateHasChanged);
}
public void Dispose()
{
planner.StateHasChanged -= reload;
}
private IEnumerable<EnrollmentTermModel>? terms { get; set; } = null;
private ulong? _selectedTermId {get; set;}
private ulong? selectedTermId {

View File

@@ -26,62 +26,71 @@
}
private Modal? assignmentEditorModal {get; set;}
private void dropOnDate(DateTime dropDate)
{
if (planner.LocalCourse == null) return;
var currentModule = planner
.LocalCourse
.Modules
.First(m =>
m.Assignments
.Select(a => a.id)
.Contains(Assignment.id)
) ?? throw new Exception("in day callback, could not find module");
var moduleWithUpdatedAssignment = currentModule with
{
Assignments = currentModule.Assignments.Select(a =>
a.id != Assignment.id
? a
: a with
{
due_at=dropDate
}
)
};
var updatedModules = planner.LocalCourse.Modules
.Select(m =>
m.Name == moduleWithUpdatedAssignment.Name
? moduleWithUpdatedAssignment
: m
);
var newCourse = planner.LocalCourse with
{
Modules = updatedModules
};
planner.LocalCourse = newCourse;
}
private void dropOnModule(LocalModule module)
{
if (planner.LocalCourse == null) return;
var newModules = planner.LocalCourse.Modules.Select(m =>
m.Name != module.Name
? m with
{
Assignments = m.Assignments.Where(a => a.id != Assignment.id).DistinctBy(a => a.id)
}
: m with
{
Assignments = m.Assignments.Append(Assignment).DistinctBy(a => a.id)
}
);
var newCourse = planner.LocalCourse with
{
Modules = newModules
};
planner.LocalCourse = newCourse;
}
private void DropCallback (DateTime? dropDate, LocalModule? module)
{
@* only supports changing date or module, not both *@
if (planner.LocalCourse == null) return;
if (module == null)
{
var currentModule = planner
.LocalCourse
.Modules
.First(m =>
m.Assignments
.Select(a => a.id)
.Contains(Assignment.id)
) ?? throw new Exception("in day callback, could not find module");
var moduleWithUpdatedAssignment = currentModule with
{
Assignments = currentModule.Assignments.Select(a =>
a.id != Assignment.id
? a
: a with
{
due_at=dropDate ?? Assignment.due_at
}
)
};
var updatedModules = planner.LocalCourse.Modules
.Select(m =>
m.Name == moduleWithUpdatedAssignment.Name
? moduleWithUpdatedAssignment
: m
);
var newCourse = planner.LocalCourse with
{
Modules = updatedModules
};
planner.LocalCourse = newCourse;
dropOnDate(dropDate ?? Assignment.due_at);
}
else
{
var newModules = planner.LocalCourse.Modules.Select(m =>
m.Name != module.Name
? m with
{
Assignments = m.Assignments.Where(a => a.id != Assignment.id).DistinctBy(a => a.id)
}
: m with
{
Assignments = m.Assignments.Append(Assignment).DistinctBy(a => a.id)
}
);
var newCourse = planner.LocalCourse with
{
Modules = newModules
};
planner.LocalCourse = newCourse;
dropOnModule(module);
}
}
private void HandleDragStart()
@@ -106,41 +115,44 @@
>
<div class="card">
<div class="card-body">
<div class="card-title">@Assignment.name</div>
<div class="card-title">
<h4 class="text-center">
@Assignment.name
</h4>
</div>
<div class="card-text">
@Assignment.description
<div>Due At: @Assignment.due_at</div>
<div>Lock At: @Assignment.lock_at</div>
<div>Points: @Assignment.points_possible</div>
@if(Assignment.canvasId != null)
{
<div>Synced with canvas</div>
}
else
{
<div>Not synced with canvas</div>
}
<div class="ms-3">
<div class="row p-1">
<div class="col border-end my-auto text-end">
Label
</div>
<div class="col my-auto">
Points
</div>
<div class="row">
<div class="col">
@Assignment.description
</div>
@foreach(var rubricItem in Assignment.rubric)
{
<div class="row p-1">
<div class="col border-end my-auto text-end">
@rubricItem.Label
</div>
<div class="col my-auto">
@rubricItem.Points
</div>
<div class="col-auto">
<div>Points: @Assignment.points_possible</div>
<div>Due At: @Assignment.due_at</div>
<div>Lock At: @Assignment.lock_at</div>
@if(Assignment.canvasId != null)
{
<div>Synced with canvas</div>
}
else
{
<div>Not synced with canvas</div>
}
<div>
Rubric:
</div>
}
@foreach(var rubricItem in Assignment.rubric)
{
<div class="row p-1">
<div class="col border-end my-auto text-end">
@rubricItem.Label
</div>
<div class="col-2 my-auto">
@rubricItem.Points
</div>
</div>
}
</div>
</div>
</div>

View File

@@ -7,62 +7,72 @@
[EditorRequired]
public LocalAssignment Assignment { get; set; } = new();
private void dropOnDate(DateTime dropDate)
{
if (planner.LocalCourse == null) return;
var currentModule = planner
.LocalCourse
.Modules
.First(m =>
m.Assignments
.Select(a => a.id)
.Contains(Assignment.id)
) ?? throw new Exception("in day callback, could not find module");
var moduleWithUpdatedAssignment = currentModule with
{
Assignments = currentModule.Assignments.Select(a =>
a.id != Assignment.id
? a
: a with
{
due_at=dropDate
}
)
};
var updatedModules = planner.LocalCourse.Modules
.Select(m =>
m.Name == moduleWithUpdatedAssignment.Name
? moduleWithUpdatedAssignment
: m
);
var newCourse = planner.LocalCourse with
{
Modules = updatedModules
};
planner.LocalCourse = newCourse;
}
private void dropOnModule(LocalModule module)
{
if (planner.LocalCourse == null) return;
var newModules = planner.LocalCourse.Modules.Select(m =>
m.Name != module.Name
? m with
{
Assignments = m.Assignments.Where(a => a.id != Assignment.id)
}
: m with
{
Assignments = m.Assignments.Append(Assignment)
}
);
var newCourse = planner.LocalCourse with
{
Modules = newModules
};
planner.LocalCourse = newCourse;
}
private void DropCallback (DateTime? dropDate, LocalModule? module)
{
@* only supports changing date or module, not both *@
if (planner.LocalCourse == null) return;
if (module == null)
{
var currentModule = planner
.LocalCourse
.Modules
.First(m =>
m.Assignments
.Select(a => a.id)
.Contains(Assignment.id)
) ?? throw new Exception("in day callback, could not find module");
var moduleWithUpdatedAssignment = currentModule with
{
Assignments = currentModule.Assignments.Select(a =>
a.id != Assignment.id
? a
: a with
{
due_at=dropDate ?? Assignment.due_at
}
)
};
var updatedModules = planner.LocalCourse.Modules
.Select(m =>
m.Name == moduleWithUpdatedAssignment.Name
? moduleWithUpdatedAssignment
: m
);
var newCourse = planner.LocalCourse with
{
Modules = updatedModules
};
planner.LocalCourse = newCourse;
dropOnDate(dropDate ?? Assignment.due_at);
}
else
{
var newModules = planner.LocalCourse.Modules.Select(m =>
m.Name != module.Name
? m with
{
Assignments = m.Assignments.Where(a => a.id != Assignment.id).DistinctBy(a => a.id)
}
: m with
{
Assignments = m.Assignments.Append(Assignment).DistinctBy(a => a.id)
}
);
var newCourse = planner.LocalCourse with
{
Modules = newModules
};
planner.LocalCourse = newCourse;
dropOnModule(module);
}
}
private void HandleDragStart()

View File

@@ -18,14 +18,31 @@ public class CoursePlanner
get => _localCourse;
set
{
// ignore initial load of course
if (_localCourse != null && value != null)
if (value == null)
{
yamlManager.SaveCourse(value);
_localCourse = null;
StateHasChanged?.Invoke();
return;
}
_localCourse = value;
var verifiedCourse = verifyCourse(value);
// ignore initial load of course
if (_localCourse != null)
{
yamlManager.SaveCourse(verifiedCourse);
}
_localCourse = verifiedCourse;
StateHasChanged?.Invoke();
}
}
public event Action? StateHasChanged;
private LocalCourse verifyCourse(LocalCourse incomingCourse)
{
var modulesWithUniqueAssignments = incomingCourse.Modules.Select(
module => module with { Assignments = module.Assignments.DistinctBy(a => a.id) }
);
return incomingCourse with { Modules = modulesWithUniqueAssignments };
}
}