Scheduler refinements
This commit is contained in:
@@ -10,33 +10,43 @@
|
||||
|
||||
|
||||
<MudPaper Class="pa-4 mt-5">
|
||||
<MudText>Include: @string.Join(", ", _requiredTeams) </MudText>
|
||||
@* <MudText>Include: @string.Join(", ", _requiredTeams) </MudText> *@
|
||||
<MudGrid>
|
||||
<MudItem Style="width:250px;">
|
||||
<MudNumericField @bind-Value="_parameters.TimeSlots"
|
||||
Label="Time Slots" Min="1" Max="4"></MudNumericField>
|
||||
<MudItem xs="6" lg="3">
|
||||
|
||||
<MudStack>
|
||||
|
||||
<MudButton OnClick="() => AddHighLevelOfEffort()">Add High Effort</MudButton>
|
||||
<MudButton OnClick="() => AddRegionals()">Add Regionals</MudButton>
|
||||
|
||||
<MudButton OnClick="() => RemoveIndividual()">Remove Individual</MudButton>
|
||||
<MudButton OnClick="() => RemoveLowLevelOfEffort()">Remove Low Effort</MudButton>
|
||||
|
||||
<MudItem>@string.Join(", ", (_possibleAdditions ?? []).Select(e => e.ToString()))</MudItem>
|
||||
|
||||
<MudToggleGroup T="Team"
|
||||
SelectionMode="SelectionMode.MultiSelection"
|
||||
@bind-Values="_requiredTeams"
|
||||
|
||||
Vertical="true" CheckMark>
|
||||
Vertical="true"
|
||||
CheckMark>
|
||||
@foreach (var team in _teams.OrderBy(e => e.Event.Name))
|
||||
{
|
||||
<MudToggleItem Value="@team" Text="@team.ToString()" Style="font-size: .6rem;"/>
|
||||
<MudToggleItem Value="@team" Style="font-size: .75rem;">
|
||||
<MudTooltip Text="@string.Join(", ", team.Students.Select(s => s.FirstName))">
|
||||
<div class="d-flex align-center justify-space-between flex-wrap">
|
||||
<MudText Class="ellipsis">@team.ToString()</MudText>
|
||||
<EventAttributes EventDefinition="@team.Event"></EventAttributes>
|
||||
</div>
|
||||
</MudTooltip>
|
||||
</MudToggleItem>
|
||||
}
|
||||
</MudToggleGroup>
|
||||
</MudStack>
|
||||
|
||||
|
||||
</MudItem>
|
||||
@* <TeamSelector Teams="@_teams" SelectedTeams="@_requiredTeams" Label="Required"></TeamSelector> *@
|
||||
|
||||
<MudItem xs="12" lg="4">
|
||||
<MudItem xs="6" lg="9">
|
||||
<MudText Typo="Typo.h4">Time Slots</MudText>
|
||||
<MudNumericField @bind-Value="_parameters.TimeSlots"
|
||||
Label="Time Slots" Min="1" Max="4"></MudNumericField>
|
||||
<MudButton Class="ma-3" OnClick="Solve" Variant="Variant.Filled" Color="Color.Primary" Disabled="@_isSolving">Solve</MudButton>
|
||||
<MudTable T="Team[]" ServerData="SolveSchedule" @ref="_solutionData">
|
||||
<HeaderContent>
|
||||
@@ -44,6 +54,7 @@
|
||||
</HeaderContent>
|
||||
<RowTemplate>
|
||||
<MudTd>
|
||||
<MudItem>Time slot: @context</MudItem>
|
||||
@{
|
||||
var ol = TeamSchedulerSolution.GetStudentTeamOverlaps(context);
|
||||
}
|
||||
@@ -61,14 +72,18 @@
|
||||
</MudItem>
|
||||
} *@
|
||||
|
||||
@{ var notInTimeSLot = TeamSchedulerSolution.GetStudentsNotInTimSlot(context, _students); }
|
||||
@if (notInTimeSLot.Any())
|
||||
@{ var unscheduled = TeamSchedulerSolution.GetStudentsNotInTimSlot(context, _students); }
|
||||
@if (unscheduled.Any())
|
||||
{
|
||||
<MudItem>
|
||||
<i>
|
||||
Not scheduled: @string.Join(", ", notInTimeSLot.Select(s => s.FirstName))
|
||||
</i>
|
||||
</MudItem>
|
||||
<MudItem>Unscheduled</MudItem>
|
||||
foreach (var student in unscheduled)
|
||||
{
|
||||
<MudItem>
|
||||
<i>@student.FirstName</i>
|
||||
@string.Join(", ", _solution.StudentUnassignedTeams(student).Select(e => e.ToString()))
|
||||
</MudItem>
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
</MudTd>
|
||||
@@ -76,12 +91,8 @@
|
||||
</MudTable>
|
||||
</MudItem>
|
||||
</MudGrid>
|
||||
|
||||
|
||||
</MudPaper>
|
||||
|
||||
|
||||
|
||||
@code {
|
||||
private Team[]? _teams;
|
||||
private Student[]? _students;
|
||||
@@ -90,30 +101,44 @@
|
||||
private TeamSchedulerOptions _parameters;
|
||||
bool _isSolving = false;
|
||||
private IEnumerable<Team> _requiredTeams = [];
|
||||
|
||||
private Team[]? _possibleAdditions;
|
||||
//private Team[] _requiredTeams = [];
|
||||
|
||||
private void OnSelectedValuesChanged(IEnumerable<Team> obj)
|
||||
private async Task OnSelectedValuesChanged(IEnumerable<Team> obj)
|
||||
{
|
||||
_requiredTeams = obj.ToList();
|
||||
await _solutionData.ReloadServerData();
|
||||
}
|
||||
|
||||
private void AddRegionals()
|
||||
private async Task AddRegionals()
|
||||
{
|
||||
_requiredTeams
|
||||
= _teams.Where(e => e.Event.RegionalEvent).Concat(_requiredTeams).Distinct();
|
||||
}
|
||||
|
||||
private void RemoveIndividual()
|
||||
private async Task AddHighLevelOfEffort()
|
||||
{
|
||||
_requiredTeams
|
||||
= _teams.Where(e => e.Event.LevelOfEffort >= 3).Concat(_requiredTeams).Distinct();
|
||||
}
|
||||
|
||||
private async Task RemoveIndividual()
|
||||
{
|
||||
_requiredTeams
|
||||
= _requiredTeams.Where(t => t.Event.EventFormat != EventFormat.Individual);
|
||||
}
|
||||
|
||||
private async Task RemoveLowLevelOfEffort()
|
||||
{
|
||||
_requiredTeams
|
||||
= _requiredTeams.Where(t => t.Event.LevelOfEffort > 1);
|
||||
}
|
||||
|
||||
protected override async Task OnInitializedAsync()
|
||||
{
|
||||
_parameters =
|
||||
new TeamSchedulerOptions(
|
||||
timeSlots: 4,
|
||||
timeSlots: 2,
|
||||
mustIncludeEvents:
|
||||
[
|
||||
// "Medical Technology", "Electrical Applications" , "RegionalTeam",
|
||||
@@ -140,7 +165,6 @@
|
||||
]
|
||||
);
|
||||
|
||||
|
||||
_teams
|
||||
= await Context.Teams
|
||||
.Include(e => e.Event)
|
||||
@@ -160,10 +184,9 @@
|
||||
|
||||
private async Task<TableData<Team[]>> SolveSchedule(TableState arg1, CancellationToken arg2)
|
||||
{
|
||||
var requiredTeams = _teams;
|
||||
|
||||
_isSolving = true;
|
||||
var teamScheduler = new TeamScheduler(_requiredTeams, _parameters.TimeSlots);
|
||||
|
||||
|
||||
// teamScheduler
|
||||
// .ScheduleSeparate(
|
||||
// _teams.First(e => e.Event.Name.Contains("Data Science")),
|
||||
@@ -172,15 +195,28 @@
|
||||
|
||||
_solution = teamScheduler.Solve();
|
||||
|
||||
var loe = new UnassignedStudentScheduler(_teams, _solution.TimeSlots).ScheduleStrategy(UnassignedScheduleStrategy.LevelOfEffort);
|
||||
var biggest = new UnassignedStudentScheduler(_teams, _solution.TimeSlots).ScheduleStrategy(UnassignedScheduleStrategy.BiggestGroup);
|
||||
var individual = new UnassignedStudentScheduler(_teams, _solution.TimeSlots).ScheduleStrategy(UnassignedScheduleStrategy.IndividualEvents);
|
||||
var anyNotMeetingAlready = new UnassignedStudentScheduler(_teams, _solution.TimeSlots).ScheduleStrategy(UnassignedScheduleStrategy.AnyNotMeetingAlready);
|
||||
|
||||
_possibleAdditions = loe;
|
||||
if (_possibleAdditions.Length == 0)
|
||||
_possibleAdditions = biggest;
|
||||
if (_possibleAdditions.Length == 0)
|
||||
_possibleAdditions = anyNotMeetingAlready;
|
||||
|
||||
if (_possibleAdditions.Length == 0)
|
||||
_possibleAdditions = individual;
|
||||
|
||||
await InvokeAsync(StateHasChanged); // let the UI know that the solution has been found
|
||||
|
||||
_isSolving = false;
|
||||
return new TableData<Team[]> { Items = _solution.TimeSlots};
|
||||
}
|
||||
|
||||
|
||||
private void Solve()
|
||||
{
|
||||
_solutionData.ReloadServerData();
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user