065b14b158
Adds the ability to have expressions evaluated when flags are added and removed.
183 lines
8.3 KiB
Plaintext
183 lines
8.3 KiB
Plaintext
@model Disco.Web.Models.User.ShowModel
|
|
@using Disco.Services.Users.UserFlags;
|
|
@{
|
|
Authorization.Require(Claims.User.ShowFlagAssignments);
|
|
|
|
var hasRemove = Authorization.Has(Claims.User.Actions.RemoveFlags);
|
|
var hasEdit = Authorization.Has(Claims.User.Actions.EditFlags);
|
|
|
|
var hasUserFlagShow = Authorization.Has(Claims.Config.UserFlag.Show);
|
|
var activeAssignmentCount = Model.User.UserFlagAssignments == null ? 0 : Model.User.UserFlagAssignments.Count(a => !a.RemovedDate.HasValue);
|
|
|
|
var flagAssignments = Model.User.UserFlagAssignments.Select(a => Tuple.Create(a, UserFlagService.GetUserFlag(a.UserFlagId))).ToList();
|
|
}
|
|
<div id="UserDetailTab-Flags" class="UserPart">
|
|
@if (flagAssignments.Count > 0)
|
|
{
|
|
<table id="userFlags">
|
|
<tr>
|
|
<th class="name">Name</th>
|
|
<th class="added">Added</th>
|
|
<th class="sla">Comments</th>
|
|
<th class="removed">Removed</th>
|
|
</tr>
|
|
@foreach (var fa in flagAssignments.OrderByDescending(a => a.Item1.AddedDate))
|
|
{
|
|
<tr data-userflagassignmentid="@fa.Item1.Id" data-flagassignmentaddeddate="@(fa.Item1.AddedDate.ToString("s"))" class="@(!fa.Item1.RemovedDate.HasValue ? "added" : "removed")">
|
|
<td class="name">
|
|
<i class="fa fa-@(fa.Item2.Icon) fa-fw fa-lg d-@(fa.Item2.IconColour)"></i>
|
|
@if (hasUserFlagShow)
|
|
{
|
|
@Html.ActionLink(fa.Item2.Name, MVC.Config.UserFlag.Index(fa.Item2.Id))
|
|
}
|
|
else
|
|
{
|
|
@fa.Item2.Name
|
|
}
|
|
</td>
|
|
<td class="added">
|
|
@CommonHelpers.FriendlyDateAndUser(fa.Item1.AddedDate, fa.Item1.AddedUser)
|
|
@if (fa.Item1.OnAssignmentExpressionResult != null)
|
|
{
|
|
<div class="expressionResult">@fa.Item1.OnAssignmentExpressionResult</div>
|
|
}
|
|
</td>
|
|
<td class="comments">
|
|
@if (hasEdit)
|
|
{
|
|
<div class="editable"><i class="fa fa-fw fa-edit" title="Edit Comments"></i></div>
|
|
}
|
|
@if (fa.Item1.Comments == null)
|
|
{
|
|
<div class="comments smallMessage">[no comments]</div>
|
|
}
|
|
else
|
|
{
|
|
<div class="comments">@fa.Item1.Comments.ToHtmlComment()</div>
|
|
<div class="commentsRaw">@fa.Item1.Comments</div>
|
|
}
|
|
</td>
|
|
<td class="removed@(!fa.Item1.RemovedDate.HasValue ? " na" : null)">
|
|
@if (fa.Item1.RemovedDate.HasValue)
|
|
{
|
|
@CommonHelpers.FriendlyDateAndUser(fa.Item1.RemovedDate.Value, fa.Item1.RemovedUser)
|
|
if (fa.Item1.OnUnassignmentExpressionResult != null)
|
|
{
|
|
<div class="expressionResult">@fa.Item1.OnUnassignmentExpressionResult</div>
|
|
}
|
|
}
|
|
else if (fa.Item1.CanRemove())
|
|
{
|
|
<a href="#" class="button small remove">Remove</a>
|
|
}
|
|
</td>
|
|
</tr>
|
|
}
|
|
</table>
|
|
<div id="User_Show_Flags_Actions_Remove_Dialog" class="dialog" title="Remove this flag from the user?">
|
|
@using (Html.BeginForm(MVC.API.UserFlagAssignment.RemoveUser()))
|
|
{
|
|
<input id="User_Show_Flags_Actions_Remove_Dialog_Id" type="hidden" name="id" value="" />
|
|
<p>
|
|
<i class="fa fa-exclamation-triangle fa-lg"></i> Are you sure?
|
|
</p>
|
|
}
|
|
</div>
|
|
<div id="User_Show_Flags_Actions_EditComments_Dialog" class="dialog" title="Edit the Comments">
|
|
@using (Html.BeginForm(MVC.API.UserFlagAssignment.UpdateComments()))
|
|
{
|
|
<input id="User_Show_Flags_Actions_EditComments_Dialog_Id" type="hidden" name="id" value="" />
|
|
<input type="hidden" name="redirect" value="true" />
|
|
<h4>Comments:</h4>
|
|
<p>
|
|
<textarea id="User_Show_Flags_Actions_EditComments_Dialog_Comments" name="Comments" class="block"></textarea>
|
|
</p>
|
|
}
|
|
</div>
|
|
<script type="text/javascript">
|
|
$(function () {
|
|
var userFlags = $('#userFlags');
|
|
|
|
var dialog = null;
|
|
var dialogEditComments = null;
|
|
|
|
userFlags.on('click', 'a.remove', function (e) {
|
|
var $this = $(this);
|
|
var UserFlagAssignmentId = $this.closest('tr').attr('data-userflagassignmentid');
|
|
|
|
if (!dialog) {
|
|
dialog = $('#User_Show_Flags_Actions_Remove_Dialog');
|
|
dialog.dialog({
|
|
resizable: false,
|
|
modal: true,
|
|
autoOpen: false,
|
|
buttons: {
|
|
"Remove Flag": function () {
|
|
var $this = $(this);
|
|
$this.dialog("disable");
|
|
$this.dialog("option", "buttons", null);
|
|
$this.find('form').submit();
|
|
},
|
|
Cancel: function () {
|
|
$(this).dialog("close");
|
|
}
|
|
}
|
|
});
|
|
}
|
|
|
|
$('#User_Show_Flags_Actions_Remove_Dialog_Id').val(UserFlagAssignmentId);
|
|
dialog.dialog('open');
|
|
|
|
e.preventDefault();
|
|
return false;
|
|
});
|
|
|
|
userFlags.on('click', 'td.comments i.fa-edit', function (e) {
|
|
var $this = $(this);
|
|
var UserFlagAssignmentId = $this.closest('tr').attr('data-userflagassignmentid');
|
|
|
|
if (!dialogEditComments) {
|
|
dialogEditComments = $('#User_Show_Flags_Actions_EditComments_Dialog');
|
|
dialogEditComments.dialog({
|
|
resizable: false,
|
|
modal: true,
|
|
width: 320,
|
|
autoOpen: false,
|
|
buttons: {
|
|
"Save Changes": function () {
|
|
var $this = $(this);
|
|
$this.dialog("disable");
|
|
$this.dialog("option", "buttons", null);
|
|
$this.find('form').submit();
|
|
},
|
|
Cancel: function () {
|
|
$(this).dialog("close");
|
|
}
|
|
}
|
|
});
|
|
}
|
|
|
|
var $comments = $this.closest('td').find('.commentsRaw');
|
|
if ($comments.hasClass('smallMessage')) {
|
|
$('#User_Show_Flags_Actions_EditComments_Dialog_Comments').val('');
|
|
} else {
|
|
$('#User_Show_Flags_Actions_EditComments_Dialog_Comments').val($comments.text());
|
|
}
|
|
|
|
$('#User_Show_Flags_Actions_EditComments_Dialog_Id').val(UserFlagAssignmentId);
|
|
dialogEditComments.dialog('open');
|
|
e.preventDefault();
|
|
return false;
|
|
});
|
|
});
|
|
</script>
|
|
}
|
|
else
|
|
{
|
|
<div class="none">This user has no associated flags</div>
|
|
}
|
|
<script>
|
|
$('#UserDetailTabItems').append('<li><a href="#UserDetailTab-Flags">Flags [@activeAssignmentCount]</a></li>');
|
|
</script>
|
|
</div>
|