mirror of
https://github.com/alexmickelson/canvasManagement.git
synced 2026-03-26 15:48:32 -06:00
refactored assignment drop logic
This commit is contained in:
33
Management.Web/Pages/AssignmentForm.razor
Normal file
33
Management.Web/Pages/AssignmentForm.razor
Normal file
@@ -0,0 +1,33 @@
|
|||||||
|
@page "/course/{CourseName}/assignment/{AssignmentId}"
|
||||||
|
@using CanvasModel.EnrollmentTerms
|
||||||
|
@using Management.Web.Shared.Course
|
||||||
|
@using Management.Web.Shared.Module.Assignment.Templates
|
||||||
|
@using Management.Web.Shared.Semester
|
||||||
|
@using CanvasModel.Courses
|
||||||
|
@using Microsoft.AspNetCore.Components.Server.ProtectedBrowserStorage
|
||||||
|
@using LocalModels
|
||||||
|
@using Management.Web.Shared.Module.Assignment
|
||||||
|
@using Management.Web.Shared.Components
|
||||||
|
|
||||||
|
@inject YamlManager yamlManager
|
||||||
|
@inject CanvasService canvas
|
||||||
|
@inject CoursePlanner planner
|
||||||
|
|
||||||
|
@code {
|
||||||
|
[Parameter]
|
||||||
|
public string CourseName { get; set; }
|
||||||
|
[Parameter]
|
||||||
|
public string AssignmentId { get; set; }
|
||||||
|
|
||||||
|
protected override async Task OnInitializedAsync()
|
||||||
|
{
|
||||||
|
if(planner.LocalCourse == null)
|
||||||
|
{
|
||||||
|
var courses = await yamlManager.LoadSavedCourses();
|
||||||
|
planner.LocalCourse = courses.First(c => c.Name == CourseName);
|
||||||
|
}
|
||||||
|
base.OnInitialized();
|
||||||
|
@* loading = false; *@
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -5,10 +5,9 @@
|
|||||||
@inject CoursePlanner planner
|
@inject CoursePlanner planner
|
||||||
@inject AssignmentEditorContext assignmentContext
|
@inject AssignmentEditorContext assignmentContext
|
||||||
|
|
||||||
|
@inherits DroppableAssignment
|
||||||
|
|
||||||
@code {
|
@code {
|
||||||
[Parameter]
|
|
||||||
[EditorRequired]
|
|
||||||
public LocalAssignment Assignment { get; set; } = new();
|
|
||||||
[Parameter]
|
[Parameter]
|
||||||
[EditorRequired]
|
[EditorRequired]
|
||||||
public LocalModule Module { get; set; } = new();
|
public LocalModule Module { get; set; } = new();
|
||||||
@@ -28,84 +27,7 @@
|
|||||||
}
|
}
|
||||||
private bool showAll { get; set; } = false;
|
private bool showAll { get; set; } = false;
|
||||||
|
|
||||||
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 defaultDueTimeDate = new DateTime(
|
|
||||||
year: dropDate.Year,
|
|
||||||
month: dropDate.Month,
|
|
||||||
day: dropDate.Day,
|
|
||||||
hour: planner.LocalCourse.DefaultDueTime.Hour,
|
|
||||||
minute: planner.LocalCourse.DefaultDueTime.Minute,
|
|
||||||
second: 0
|
|
||||||
);
|
|
||||||
|
|
||||||
var moduleWithUpdatedAssignment = currentModule with
|
|
||||||
{
|
|
||||||
Assignments = currentModule.Assignments.Select(a =>
|
|
||||||
a.Id != Assignment.Id
|
|
||||||
? a
|
|
||||||
: a with
|
|
||||||
{
|
|
||||||
DueAt=defaultDueTimeDate
|
|
||||||
}
|
|
||||||
)
|
|
||||||
};
|
|
||||||
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)
|
|
||||||
{
|
|
||||||
if (module == null)
|
|
||||||
{
|
|
||||||
dropOnDate(dropDate ?? Assignment.DueAt);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
dropOnModule(module);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
private void HandleDragStart()
|
private void HandleDragStart()
|
||||||
{
|
{
|
||||||
dragContainer.DropCallback = DropCallback;
|
dragContainer.DropCallback = DropCallback;
|
||||||
|
|||||||
@@ -0,0 +1,90 @@
|
|||||||
|
using Microsoft.AspNetCore.Components;
|
||||||
|
|
||||||
|
namespace Management.Web.Shared.Module.Assignment;
|
||||||
|
public class DroppableAssignment : ComponentBase
|
||||||
|
{
|
||||||
|
[Inject]
|
||||||
|
protected CoursePlanner planner { get; set; } = default!;
|
||||||
|
|
||||||
|
[Parameter, EditorRequired]
|
||||||
|
public LocalAssignment Assignment { get; set; } = default!;
|
||||||
|
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 defaultDueTimeDate = new DateTime(
|
||||||
|
year: dropDate.Year,
|
||||||
|
month: dropDate.Month,
|
||||||
|
day: dropDate.Day,
|
||||||
|
hour: planner.LocalCourse.DefaultDueTime.Hour,
|
||||||
|
minute: planner.LocalCourse.DefaultDueTime.Minute,
|
||||||
|
second: 0
|
||||||
|
);
|
||||||
|
|
||||||
|
var moduleWithUpdatedAssignment = currentModule with
|
||||||
|
{
|
||||||
|
Assignments = currentModule.Assignments.Select(a =>
|
||||||
|
a.Id != Assignment.Id
|
||||||
|
? a
|
||||||
|
: a with
|
||||||
|
{
|
||||||
|
DueAt = defaultDueTimeDate
|
||||||
|
}
|
||||||
|
)
|
||||||
|
};
|
||||||
|
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;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void DropCallback(DateTime? dropDate, LocalModule? module)
|
||||||
|
{
|
||||||
|
if (module == null)
|
||||||
|
{
|
||||||
|
dropOnDate(dropDate ?? Assignment.DueAt);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
dropOnModule(module);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -1,12 +1,12 @@
|
|||||||
|
@using Management.Web.Shared.Module.Assignment
|
||||||
|
|
||||||
@inject DragContainer dragContainer
|
@inject DragContainer dragContainer
|
||||||
@inject CoursePlanner planner
|
@inject CoursePlanner planner
|
||||||
@inject AssignmentEditorContext assignmentContext
|
@inject AssignmentEditorContext assignmentContext
|
||||||
|
|
||||||
|
@inherits DroppableAssignment
|
||||||
|
|
||||||
@code {
|
@code {
|
||||||
[Parameter]
|
|
||||||
[EditorRequired]
|
|
||||||
public LocalAssignment Assignment { get; set; } = new();
|
|
||||||
protected override void OnInitialized()
|
protected override void OnInitialized()
|
||||||
{
|
{
|
||||||
planner.StateHasChanged += reload;
|
planner.StateHasChanged += reload;
|
||||||
@@ -20,84 +20,6 @@
|
|||||||
planner.StateHasChanged -= reload;
|
planner.StateHasChanged -= reload;
|
||||||
}
|
}
|
||||||
|
|
||||||
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 defaultDueTimeDate = new DateTime(
|
|
||||||
year: dropDate.Year,
|
|
||||||
month: dropDate.Month,
|
|
||||||
day: dropDate.Day,
|
|
||||||
hour: planner.LocalCourse.DefaultDueTime.Hour,
|
|
||||||
minute: planner.LocalCourse.DefaultDueTime.Minute,
|
|
||||||
second: 0
|
|
||||||
);
|
|
||||||
|
|
||||||
var moduleWithUpdatedAssignment = currentModule with
|
|
||||||
{
|
|
||||||
Assignments = currentModule.Assignments.Select(a =>
|
|
||||||
a.Id != Assignment.Id
|
|
||||||
? a
|
|
||||||
: a with
|
|
||||||
{
|
|
||||||
DueAt=defaultDueTimeDate
|
|
||||||
}
|
|
||||||
)
|
|
||||||
};
|
|
||||||
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)
|
|
||||||
{
|
|
||||||
if (module == null)
|
|
||||||
{
|
|
||||||
dropOnDate(dropDate ?? Assignment.DueAt);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
dropOnModule(module);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
private void HandleDragStart()
|
private void HandleDragStart()
|
||||||
{
|
{
|
||||||
dragContainer.DropCallback = DropCallback;
|
dragContainer.DropCallback = DropCallback;
|
||||||
|
|||||||
Reference in New Issue
Block a user