added input validation for poll creation
This commit is contained in:
parent
2a69ccc1b6
commit
1f5a1f4fe2
3 changed files with 37 additions and 5 deletions
|
@ -1,4 +1,6 @@
|
|||
namespace Lieb.Models.Poll
|
||||
using System.ComponentModel.DataAnnotations;
|
||||
|
||||
namespace Lieb.Models.Poll
|
||||
{
|
||||
public enum AnswerType
|
||||
{
|
||||
|
@ -8,6 +10,9 @@
|
|||
public class Poll
|
||||
{
|
||||
public int PollId { get; set; }
|
||||
|
||||
[Required]
|
||||
[StringLength(200, ErrorMessage = "Question too long (200 character limit).")]
|
||||
public string Question { get; set; }
|
||||
public ICollection<PollOption> Options { get; set; } = new List<PollOption>();
|
||||
public ICollection<PollAnswer> Answers { get; set; } = new List<PollAnswer>();
|
||||
|
|
|
@ -1,8 +1,13 @@
|
|||
namespace Lieb.Models.Poll
|
||||
using System.ComponentModel.DataAnnotations;
|
||||
|
||||
namespace Lieb.Models.Poll
|
||||
{
|
||||
public class PollOption
|
||||
{
|
||||
public int PollOptionId { get; set; }
|
||||
|
||||
[Required]
|
||||
[StringLength(100, ErrorMessage = "Option too long (100 character limit).")]
|
||||
public string Name { get; set;} = string.Empty;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -40,7 +40,10 @@
|
|||
Poll Type:
|
||||
<InputSelect @bind-Value="_pollType">
|
||||
<option value="@POLL_TYPE_RAID">Raid</option>
|
||||
@if(_availabeGroups.Count > 0)
|
||||
{
|
||||
<option value="@POLL_TYPE_GROUP">Group</option>
|
||||
}
|
||||
</InputSelect>
|
||||
</label>
|
||||
</p>
|
||||
|
@ -149,8 +152,12 @@
|
|||
{
|
||||
_availabeGroups = UserService.GetUserRoles(_user.Id).Where(u => u.Type == RoleType.UserDefinedRole).ToList();
|
||||
}
|
||||
_poll.AnswerType = AnswerType.Dropdown;
|
||||
if(_availabeGroups.Count > 0)
|
||||
{
|
||||
_chosenRole = _availabeGroups.First().LiebRoleId;
|
||||
}
|
||||
}
|
||||
|
||||
async Task AddOptionClicked()
|
||||
{
|
||||
|
@ -165,6 +172,21 @@
|
|||
|
||||
private async Task HandleValidSubmit()
|
||||
{
|
||||
if(_poll.Options.Count < 2)
|
||||
{
|
||||
_errorMessage = "At least 2 options are needed for a Poll.";
|
||||
return;
|
||||
}
|
||||
|
||||
foreach(PollOption option in _poll.Options)
|
||||
{
|
||||
if(string.IsNullOrWhiteSpace(option.Name))
|
||||
{
|
||||
_errorMessage = "Options must not be empty.";
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
if(_pollType == POLL_TYPE_RAID)
|
||||
{
|
||||
await PollService.CreatePoll(_poll, _chosenRaid);
|
||||
|
@ -174,6 +196,6 @@
|
|||
await PollService.CreatePoll(_poll, UserService.GetGroupMembers(_chosenRole).Select(u => u.Id).ToList());
|
||||
}
|
||||
|
||||
NavigationManager.NavigateTo("raidoverview");
|
||||
NavigationManager.NavigateTo("polloverview");
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue