EnVisageOnline/Main/Source/EnVisage/Views/Shared/EditorTemplates/ProjectPartModel.cshtml

299 lines
15 KiB
Plaintext

@using EnVisage.Code
@model EnVisage.Models.ProjectPartModel
<div class="panel pm-container" @(!Model.Id.Equals(Guid.Empty) ? "id=p_" + Model.Id.ToString("N") : "" )>
@Html.HiddenFor(t => t.Id)
@Html.HiddenFor(t => t.DeletedPart)
@Html.HiddenFor(t => t.ParentProjectId)
@Html.HiddenFor(t => t.CompanyId)
<div class="panel-heading">
<span class="panel-title ui-expander">
<a data-toggle="collapse" data-target="#@Html.IdFor(t => t.Id)_projectPart">
<i class="panel-title-icon fa fa-tasks"></i><span class="partTitle">Part Details</span>
</a>
</span>
<span class="pull-right">&nbsp;&nbsp;</span>
<div class="btn-group btn-group-xs pull-right pm-delete">
<button onclick="return removePart(this)" class="btn btn-xs btn-danger" href="javascript:void(0)" title="Delete" type="button"><i class="fa fa-trash-o"></i></button>
</div>
</div>
<div id="@Html.IdFor(t => t.Id)_projectPart" class="panel-collapse collapse in">
<div class="panel-body padding-sm">
<div class="row pm-partName">
<div class="col-sm-7 col-lg-5">
<div class="form-group no-margin-hr switcher-block">
@Html.LabelFor(model => model.Name, new { @class = "control-label" })
@Html.TextBoxFor(model => model.Name, new { @class = "form-control input-required" })
@Html.ValidationMessageFor(model => model.Name)
</div>
</div>
</div>
<div class="row">
<div class="col-sm-4 pm-type">
<div class="form-group no-margin-hr">
@Html.LabelFor(model => model.TypeId, new { @class = "control-label" })
@{
ViewBag.TypeSelected = false;
}
<select class="form-control forselect2 type input-required" data-val="true" data-val-required="The Type field is required." id="@Html.IdFor(m => m.TypeId)" name="@Html.NameFor(m => m.TypeId)">
<option value=""></option>
@foreach (var kvp in Utils.GetTypesWithGroups())
{
<optgroup label="@kvp.Key">
@foreach (var opt in kvp.Value)
{
if (Model != null && Model.TypeId == opt.Id && !ViewBag.TypeSelected)
{
<option value="@opt.Id" data-green="0" data-yellow="@opt.PerformanceYellowThreshold" data-red="@opt.PerformanceRedThreshold" selected>@opt.Name</option>
ViewBag.TypeSelected = true;
}
else
{
<option value="@opt.Id" data-green="0" data-yellow="@opt.PerformanceYellowThreshold" data-red="@opt.PerformanceRedThreshold">@opt.Name</option>
}
}
</optgroup>
}
</select>
@Html.ValidationMessageFor(model => model.TypeId)
</div>
</div>
<div class="col-sm-4">
<div class="form-group no-margin-hr">
@Html.LabelFor(model => model.ClientId, new { @class = "control-label" })
@Html.DropDownListFor(model => model.ClientId, Utils.GetClients(true), new { @class = "form-control forselect2 pm-clientId input-required" })
@Html.ValidationMessageFor(model => model.ClientId)
</div>
</div>
<div class="col-sm-4 pm-deadline">
<div class="form-group no-margin-hr">
@Html.LabelFor(model => model.Deadline, new { @class = "control-label text-normal text-italic" })
@Html.EditorFor(model => model.Deadline, new { @class = "form-control" })
@Html.ValidationMessageFor(model => model.Deadline)
</div>
</div>
</div>
<div class="row">
<div class="col-sm-4">
<div class="form-group no-margin-hr">
@Html.LabelFor(model => model.StatusId, new { @class = "control-label" })
@Html.DropDownListFor(model => model.StatusId, Utils.GetStatuses(true), new { @class = "form-control forselect2 pm-status input-required" })
@Html.ValidationMessageFor(model => model.StatusId)
</div>
</div>
<div class="col-sm-8 pm-probability">
<div class="form-group no-margin-hr">
@Html.LabelFor(model => model.Probability, new { @class = "control-label text-normal text-italic" })
@Html.EditorFor(model => model.Probability)
@Html.ValidationMessageFor(model => model.Probability)
</div>
</div>
</div>
<div class="row">
<div class="col-sm-4 pm-revenue">
<div class="form-group no-margin-hr switcher-block">
@Html.LabelFor(model => model.IsRevenueGenerating, new { @class = "control-label text-normal text-italic", style = "text-align: left;" })
@Html.CheckBoxFor(model => model.IsRevenueGenerating, new { @class = "switcher form-control" })
@Html.ValidationMessageFor(model => model.IsRevenueGenerating)
</div>
</div>
<div class="col-sm-3 pm-priority">
<div class="form-group no-margin-hr">
@Html.LabelFor(model => model.Priority, new { @class = "control-label" })
@Html.TextBoxFor(model => model.Priority, new { @class = "form-control input-required", Value = Model.Priority == 0 ? "" : Model.Priority.ToString() })
@Html.ValidationMessageFor(model => model.Priority)
</div>
</div>
<div class="col-sm-3">
<div class="form-group no-margin-hr select2-primary">
@Html.LabelFor(model => model.PortfolioTags, new { @class = "control-label text-normal text-italic" })
@if (SecurityManager.CheckSecurityObjectPermission(Areas.PortfolioTags, AccessLevel.Write))
{
<text> &nbsp; &nbsp;</text><a onclick="showAddTagModel('@Html.IdFor(t => t.PortfolioTags)','@((int) TagType.Portfolio)');" href="#" class="label label-primary pm-new-tags">New</a>
}
<select class="form-control forselect2 pm-portfolio-tags" multiple data-val="true" id="@Html.IdFor(m => m.PortfolioTags)" name="@Html.NameFor(m => m.PortfolioTags)">
<option value=""></option>
@foreach (var tg in Utils.GetTags((int) TagType.Portfolio))
{
if (Model.PortfolioTags != null && Model.PortfolioTags.Contains(tg.Id))
{
<option value="@tg.Id" selected="selected" partId=@Html.IdFor(m => m.PortfolioTags) id="@Html.IdFor(m => m.PortfolioTags)@tg.Id">@tg.TagName</option>
}
else
{
<option value="@tg.Id" partId=@Html.IdFor(m => m.PortfolioTags) id="@Html.IdFor(m => m.PortfolioTags)@tg.Id">@tg.TagName</option>
}
}
</select>
@Html.ValidationMessageFor(model => model.PortfolioTags)
</div>
</div>
<div class="col-sm-3">
<div class="form-group no-margin-hr select2-tags">
@Html.LabelFor(model => model.ProjectTags, new { @class = "control-label text-normal text-italic" })
@if (SecurityManager.CheckSecurityObjectPermission(Areas.ProjectTags, AccessLevel.Write))
{
<text> &nbsp; &nbsp;</text><a onclick="showAddTagModel('@Html.IdFor(t => t.ProjectTags)','@((int) TagType.Project)');" href="#" class="label label-success label-tag pm-new-tags">New</a>
}
<select class="form-control forselect2 pm-project-tags" multiple data-val="true" id="@Html.IdFor(m => m.ProjectTags)" name="@Html.NameFor(m => m.ProjectTags)">
<option value=""></option>
@foreach (var tg in Utils.GetTags((int) TagType.Project))
{
if (Model.ProjectTags != null && Model.ProjectTags.Contains(tg.Id))
{
<option value="@tg.Id" selected="selected" partId=@Html.IdFor(m => m.ProjectTags) id="@Html.IdFor(m => m.ProjectTags)@tg.Id">@tg.TagName</option>
}
else
{
<option value="@tg.Id" partId=@Html.IdFor(m => m.ProjectTags) id="@Html.IdFor(m => m.ProjectTags)@tg.Id">@tg.TagName</option>
}
}
</select>
</div>
</div>
</div>
<div class="row">
<div class="col-sm-12 pm-details">
<div class="form-group no-margin-hr">
@Html.LabelFor(model => model.Details, new { @class = "control-label text-normal text-italic" })
@Html.TextAreaFor(model => model.Details, new { @class = "form-control", rows = "4" })
@Html.ValidationMessageFor(model => model.Details)
</div>
</div>
</div>
<div class="row">
<div class="col-sm-12 pm-dependencies" data-part-id="@Model.Id" data-parent-id="@Model.ParentProjectId">
@Html.LabelFor(model => model.Dependencies, new { @class = "control-label text-normal text-italic" })
@Html.DisplayFor(model => model.Dependencies, new { @class = "form-control" })
</div>
</div>
<fieldset>
<div class="row">
<div class="col-sm-12 pm-threshold">
<div class="form-group" style="margin:0 5px 10px 5px;">
<div class="form-group no-margin-hr switcher-block">
@Html.LabelFor(model => model.UseThreshold, new { @class = "control-label text-normal text-italic" })
@Html.CheckBoxFor(model => model.UseThreshold, new { @class = "switcher form-control" })
<i>(**Performance indicators assume deviation of ACTUALS above or below the PROJECTED amount.)</i>
</div>
<div class="threshold-container" @(Model.UseThreshold ? string.Empty : "style=display:none;")>
<span class="sliderTitle amount" style="color: #ffd800;"><span class="sliderTitle amount-yellow"></span> - <span class="sliderTitle amount-red" style="color: red;"></span></span>
<div class="slider-range"></div>
@Html.HiddenFor(model => model.PerformanceRedThreshold)
@Html.HiddenFor(model => model.PerformanceYellowThreshold)
</div>
</div>
</div>
</div>
</fieldset>
<fieldset>
<div class="row">
<div class="col-sm-12">
<div class="form-group no-margin-hr select2-primary">
@Html.LabelFor(model => model.AssignedTeams, new { @class = "control-label text-normal text-italic" })
@Html.ListBoxFor(model => model.AssignedTeams, Utils.GetTeams(), new { @class = "pm-teams form-control" })
@Html.ValidationMessageFor(model => model.AssignedTeams)
</div>
</div>
</div>
</fieldset>
<fieldset>
<div class="row">
<div class="col-sm-12">
<div class="form-group no-margin-hr select2-primary">
@Html.LabelFor(model => model.StrategicGoals, new { @class = "control-label text-normal text-italic" })
@Html.ListBoxFor(model => model.StrategicGoals, Utils.GetStrategicGoals(Model.CompanyId), new { @class = "pm-goals form-control forselect2" })
@Html.ValidationMessageFor(model => model.StrategicGoals)
</div>
</div>
</div>
</fieldset>
<fieldset>
<legend class="text-bold">Contacts</legend>
<div class="row">
<div class="col-sm-6">
<div class="form-group no-margin-hr select2-primary">
@Html.LabelFor(model => model.InternalContacts, new { @class = "control-label text-normal text-italic" })
@Html.ListBoxFor(model => model.InternalContacts, EnVisage.Code.Utils.GetProjectInternalContacts(Model.CompanyId), new { @class = "int-contacts form-control forselect2" })
@Html.ValidationMessageFor(model => model.InternalContacts)
</div>
</div>
<div class="col-sm-6">
<div class="form-group no-margin-hr select2-primary">
@Html.LabelFor(model => model.ExternalContacts, new { @class = "control-label text-normal text-italic" })
@Html.ListBoxFor(model => model.ExternalContacts, EnVisage.Code.Utils.GetProjectExternalContacts(Model.ClientId), new { @class = "ext-contacts form-control forselect2" })
@Html.ValidationMessageFor(model => model.ExternalContacts)
</div>
</div>
</div>
</fieldset>
<fieldset>
<legend class="text-bold">Workflow</legend>
<div class="row">
<div class="col-sm-4">
<div class="form-group no-margin-hr select2-primary">
@Html.LabelFor(model => model.WorkFlowContacts, new { @class = "control-label text-normal text-italic" })
@Html.ListBoxFor(model => model.WorkFlowContacts, EnVisage.Code.Utils.GetWorkFlowProjectRoles((Model.Id == Guid.Empty ? Model.ParentProjectId.Value : Model.Id)), new { @class = "int-workflowcontacts form-control forselect2" })
@Html.ValidationMessageFor(model => model.WorkFlowContacts)
</div>
</div>
</div>
<div class="row">
<div class="col-sm-12">
<div class="form-group no-margin-hr select2-primary">
@Html.Partial("~/Views/Shared/EditorTemplates/_workflowScenarios.cshtml", new EnVisage.Models.WorkflowScenarioViewModel() { ProjectId = (Model.Id != Guid.Empty ? Model.Id : Model.ParentProjectId.Value), FullRefresh = true })
</div>
</div>
</div>
@{
if (Utils.ProjectHasWorkFlowHistory((Model.Id == Guid.Empty?Model.ParentProjectId.Value:Model.Id))) {
<div class="panel-heading workflowHistoryHeaderDiv">
<span class="panel-title ui-expander">
<a data-toggle="collapse" data-target="#@Html.IdFor(t => t.Id)_projectPart_workflowHistoryDiv">
<i class="fa fa-pencil"></i><span class=""> Workflow Approval History</span>
</a>
</span>
<span class="pull-right">&nbsp;&nbsp;</span>
</div>
<div class="form-group no-margin-hr">
<div id="@Html.IdFor(t => t.Id)_projectPart_workflowHistoryDiv" class="row">
<div class="col-sm-12">
<div class="form-group no-margin-hr select2-primary">
@Html.Partial("~/Views/Shared/EditorTemplates/_workflowApprovals.cshtml", (Model.Id != Guid.Empty ? Model.Id : Model.ParentProjectId))
</div>
</div>
</div>
</div>
}
}
</fieldset>
<fieldset>
<legend class="text-bold">Attachments</legend>
<div class="row">
<div class="col-md-12">
<div class="form-group no-margin-hr attachments">
@Html.EditorFor(model => model.Attachments)
@Html.ValidationMessageFor(model => model.Attachments)
</div>
</div>
</div>
</fieldset>
<fieldset>
<legend class="text-bold">Links</legend>
<div class="row">
<div class="col-md-12">
<div class="form-group no-margin-hr links">
@Html.EditorFor(model => model.Links)
@Html.ValidationMessageFor(model => model.Links)
</div>
</div>
</div>
</fieldset>
</div>
</div>
<!-- / .panel-body -->
</div>