|
3 | 3 | <MudText Typo="Typo.h4">New Exercise</MudText> |
4 | 4 | </TitleContent> |
5 | 5 | <DialogContent> |
6 | | - <MudForm @ref="form" Model="@value" @bind-IsValid="@success" @bind-Errors="@errors"> |
7 | | - <MudTextField T="string" Label="Name" For="@(() => value.Name)" @bind-Value="value.Name" Required="true"></MudTextField> |
8 | | - <MudTextField T="string" Label="GitHub Prefix" For="@(() => value.GithubPrefix)" @bind-Value="value.GithubPrefix" Required="true"></MudTextField> |
9 | | - <MudTextField T="string" Label="GitHub Classroom URL" For="@(() => value.ClassroomUrl)" @bind-Value="value.ClassroomUrl" Required="true"></MudTextField> |
10 | | - <MudTextField T="string" Label="Moodle score name prefix" For="@(() => value.MoodleScoreNamePrefix)" @bind-Value="value.MoodleScoreNamePrefix" Required="true"></MudTextField> |
11 | | - @* <MudTextField T="string" Label="Github Prefix" For="@(() => value.DueDate)" @bind-Value="value.DueDate" Required="true"></MudTextField> *@ |
12 | | - @* <MudTextField T="string" Label="Github Prefix" For="@(() => value.ScoreTypes)" @bind-Value="value.ScoreTypes" Required="true"></MudTextField> *@ |
| 6 | + <MudForm @ref="form" Model="@Value" @bind-IsValid="@success" @bind-Errors="@errors"> |
| 7 | + <MudTextField T="string" Label="Name" For="@(() => Value.Name)" @bind-Value="Value.Name" Required="true"/> |
| 8 | + <MudTextField T="string" Label="GitHub Prefix" For="@(() => Value.GithubPrefix)" |
| 9 | + @bind-Value="Value.GithubPrefix" Required="true"/> |
| 10 | + <MudTextField T="string" Label="GitHub Classroom URL" For="@(() => Value.ClassroomUrl)" |
| 11 | + @bind-Value="Value.ClassroomUrl" Required="true"/> |
| 12 | + <MudTextField T="string" Label="Moodle score name prefix" For="@(() => Value.MoodleScoreNamePrefix)" |
| 13 | + @bind-Value="Value.MoodleScoreNamePrefix" Required="true"/> |
13 | 14 | </MudForm> |
| 15 | + |
| 16 | + <MudDivider Class="my-4"/> |
| 17 | + <MudText Typo="Typo.h6">Score Types</MudText> |
| 18 | + <MudStack Spacing="2"> |
| 19 | + @foreach (var item in OrderedScoreTypes.Select((kvp, index) => new { kvp.Key, kvp.Value, index })) |
| 20 | + { |
| 21 | + <MudPaper Class="p-2 d-flex align-items-center justify-content-between"> |
| 22 | + <MudTextField T="string" Class="me-2" Value="@item.Value" |
| 23 | + ValueChanged="val => UpdateScoreType(item.index, val)"/> |
| 24 | + <MudIconButton Icon="@Icons.Material.Filled.ArrowUpward" Disabled="@(item.index == 0)" |
| 25 | + OnClick="@(() => MoveScoreTypeUp(item.index))"/> |
| 26 | + <MudIconButton Icon="@Icons.Material.Filled.ArrowDownward" |
| 27 | + Disabled="@(item.index == OrderedScoreTypes.Count - 1)" |
| 28 | + OnClick="@(() => MoveScoreTypeDown(item.index))"/> |
| 29 | + <MudIconButton Icon="@Icons.Material.Filled.Delete" OnClick="@(() => RemoveScoreType(item.index))" |
| 30 | + Color="Color.Error"/> |
| 31 | + </MudPaper> |
| 32 | + } |
| 33 | + |
| 34 | + <MudButton Variant="Variant.Outlined" Color="Color.Primary" OnClick="AddScoreType"> |
| 35 | + <MudIcon Icon="@Icons.Material.Filled.Add"/> |
| 36 | + Add Score Type |
| 37 | + </MudButton> |
| 38 | + </MudStack> |
14 | 39 | </DialogContent> |
15 | 40 | <DialogActions> |
16 | 41 | <MudButton OnClick="@Cancel">Cancel</MudButton> |
|
25 | 50 | private bool success; |
26 | 51 | private string[] errors; |
27 | 52 |
|
28 | | - private void Submit() => MudDialog.Close(DialogResult.Ok(value)); |
| 53 | + [Parameter] |
| 54 | + public ExerciseRequest Value { get; set; } = new() |
| 55 | + { |
| 56 | + DueDate = DateTime.Now, |
| 57 | + ScoreTypes = new Dictionary<string, string>() |
| 58 | + }; |
| 59 | + |
| 60 | + private void Submit() => MudDialog.Close(DialogResult.Ok(Value)); |
29 | 61 | private void Cancel() => MudDialog.Cancel(); |
30 | 62 |
|
31 | 63 | async void OnSubmitClicked() |
|
37 | 69 | } |
38 | 70 | } |
39 | 71 |
|
40 | | - public ExerciseRequest value = new() |
| 72 | + // ScoreTypes Logic |
| 73 | + private List<KeyValuePair<string, string>> OrderedScoreTypes => |
| 74 | + Value.ScoreTypes.OrderBy(kvp => int.Parse(kvp.Key)).ToList(); |
| 75 | + |
| 76 | + private void AddScoreType() |
41 | 77 | { |
42 | | - DueDate = DateTime.Now, |
43 | | - ScoreTypes = new Dictionary<string, string>() |
44 | | - }; |
| 78 | + int nextKey = Value.ScoreTypes.Count + 1; |
| 79 | + Value.ScoreTypes[nextKey.ToString()] = ""; |
| 80 | + } |
| 81 | + |
| 82 | + private void RemoveScoreType(int index) |
| 83 | + { |
| 84 | + var list = OrderedScoreTypes; |
| 85 | + if (index < 0 || index >= list.Count) return; |
| 86 | + |
| 87 | + list.RemoveAt(index); |
| 88 | + ReorderScoreTypes(list); |
| 89 | + } |
| 90 | + |
| 91 | + private void MoveScoreTypeUp(int index) |
| 92 | + { |
| 93 | + if (index <= 0) return; |
| 94 | + var list = OrderedScoreTypes; |
| 95 | + (list[index - 1], list[index]) = (list[index], list[index - 1]); |
| 96 | + ReorderScoreTypes(list); |
| 97 | + } |
| 98 | + |
| 99 | + private void MoveScoreTypeDown(int index) |
| 100 | + { |
| 101 | + var list = OrderedScoreTypes; |
| 102 | + if (index >= list.Count - 1) return; |
| 103 | + (list[index + 1], list[index]) = (list[index], list[index + 1]); |
| 104 | + ReorderScoreTypes(list); |
| 105 | + } |
| 106 | + |
| 107 | + private void UpdateScoreType(int index, string newValue) |
| 108 | + { |
| 109 | + var list = OrderedScoreTypes; |
| 110 | + var pair = list[index]; |
| 111 | + list[index] = new KeyValuePair<string, string>(pair.Key, newValue); |
| 112 | + ReorderScoreTypes(list); |
| 113 | + } |
| 114 | + |
| 115 | + private void ReorderScoreTypes(List<KeyValuePair<string, string>> list) |
| 116 | + { |
| 117 | + Value.ScoreTypes = list |
| 118 | + .Select((kvp, idx) => new KeyValuePair<string, string>((idx + 1).ToString(), kvp.Value)) |
| 119 | + .ToDictionary(kvp => kvp.Key, kvp => kvp.Value); |
| 120 | + } |
45 | 121 |
|
46 | 122 | } |
0 commit comments