티켓 대시 보드를 만들었으며 관리자 계정으로 로그인 한 후 두 가지 티켓 요약을 보여줍니다. 하나는 "귀하의 티켓 요약"이고 다른 하나는 "모든 티켓 요약"입니다. 지금은 내 관리자 계정에 다른 계정의 티켓 요약 (예 : this)을 볼 계획이지만, 티켓 대시 보드에 추가하는 방법을 모르겠습니다. 누군가 어떻게 저에게 보여 줄 수 있습니까?과수원에 새 티켓 요약을 추가하는 방법?
1
A
답변
1
이전 게시물에서도 댓글을 달았습니다. 하지만 어쨌든,
그렇게하는 데는 여러 가지 방법이 있습니다. Orchard Collaboration은 위젯을 사용하여 티켓 요약을 나타냅니다 (사용자 및 관리자 모두). 주요 로직은 모듈/Orchard.CRM.Core/Drivers의 DashboardDriver에 있습니다.
private DriverResult DisplayDetail(DashboardPart part, dynamic shapeHelper)
{
if (this.services.WorkContext.CurrentUser == null)
{
return null;
}
var contentQuery = this.services.ContentManager.HqlQuery().ForVersion(VersionOptions.Published);
var statusRecords = this.basicDataService.GetStatusRecords().OrderBy(c => c.OrderId).ToList();
DashboardViewModel model = new DashboardViewModel();
model.CurrentUserId = this.services.WorkContext.CurrentUser.Id;
model.IsCustomer = this.crmContentOwnershipService.IsCurrentUserCustomer();
model.IsOperator = this.services.Authorizer.Authorize(Permissions.OperatorPermission);
dynamic state = new JObject();
// Query items created by customer
if (model.IsCustomer)
{
// Ticket contentType
state.ContentTypes = "Ticket";
contentQuery = this.projectionManagerWithDynamicSort.ApplyFilter(contentQuery, "Content", "ContentTypes", state);
state.RequestingUser_Id = model.CurrentUserId.ToString(CultureInfo.InvariantCulture);
contentQuery = this.projectionManagerWithDynamicSort.ApplyFilter(contentQuery, TicketFieldsFilter.CategoryName, TicketFieldsFilter.RequestingUserType, state);
var userTicketsCountByStateIds = groupQuery.GetCount(contentQuery, "TicketPartRecord", "StatusRecord.Id");
model.CurrentUserRequestingTickets = new Collection<dynamic>();
CRMHelper.AddStatusGroupRecordsToModel(statusRecords, userTicketsCountByStateIds, model.CurrentUserRequestingTickets);
// overrude items of current users
state.MaxDueDate = DateTime.UtcNow.Date;
contentQuery = this.projectionManagerWithDynamicSort.ApplyFilter(contentQuery, TicketFieldsFilter.CategoryName, TicketFieldsFilter.TicketDueDateType, state);
model.CurrentUserOverrudeRequestingTicketCount = contentQuery.Count();
}
// Query the counts of the current user tickets group by stateId
// *******************************************************
if (model.IsOperator)
{
// Ticket contentType
state.ContentTypes = "Ticket";
contentQuery = this.projectionManagerWithDynamicSort.ApplyFilter(contentQuery, "Content", "ContentTypes", state);
dynamic temp = new
{
Users = new int[] { model.CurrentUserId },
Teams = new int[] { },
BusinessUnits = new int[] { },
AccessType = ContentItemPermissionAccessTypes.Assignee
};
contentQuery = this.projectionManagerWithDynamicSort.ApplyFilter(contentQuery, ContentItemPermissionFilter.CategoryName, ContentItemPermissionFilter.AnySelectedUserTeamBusinessUnit, temp);
var userTicketsCountByStateIds = groupQuery.GetCount(contentQuery, "TicketPartRecord", "StatusRecord.Id");
model.CurrentUserTickets = new Collection<dynamic>();
CRMHelper.AddStatusGroupRecordsToModel(statusRecords, userTicketsCountByStateIds, model.CurrentUserTickets);
// overrude items of current users
state.MaxDueDate = DateTime.UtcNow.Date;
contentQuery = this.projectionManagerWithDynamicSort.ApplyFilter(contentQuery, TicketFieldsFilter.CategoryName, TicketFieldsFilter.TicketDueDateType, state);
model.CurrentUserOverrudeItemsCount = contentQuery.Count();
//*******************************************************
}
bool isAdmin = this.services.Authorizer.Authorize(Permissions.AdvancedOperatorPermission);
if (isAdmin)
{
// Query the counts of the whole tickets in the system based on stateId
state = new JObject();
contentQuery = this.services.ContentManager.HqlQuery().ForVersion(VersionOptions.Published);
state.ContentTypes = "Ticket";
contentQuery = this.projectionManagerWithDynamicSort.ApplyFilter(contentQuery, "Content", "ContentTypes", state);
var ticketCountsByStateIds = groupQuery.GetCount(contentQuery, "TicketPartRecord", "StatusRecord.Id");
model.AllTickets = new Collection<dynamic>();
CRMHelper.AddStatusGroupRecordsToModel(statusRecords, ticketCountsByStateIds, model.AllTickets);
state.MaxDueDate = DateTime.UtcNow.Date;
contentQuery = this.projectionManagerWithDynamicSort.ApplyFilter(contentQuery, TicketFieldsFilter.CategoryName, TicketFieldsFilter.TicketDueDateType, state);
model.AllOverrudeItemsCount = contentQuery.Count();
}
// get items without any owner
contentQuery = this.services.ContentManager.HqlQuery().ForVersion(VersionOptions.Published);
state.ContentTypes = "Ticket";
contentQuery = this.projectionManagerWithDynamicSort.ApplyFilter(contentQuery, "Content", "ContentTypes", state);
contentQuery = this.projectionManagerWithDynamicSort.ApplyFilter(contentQuery, ContentItemPermissionFilter.CategoryName, "ContentItemPermissionPartRecord.ItemsWithoutAnyOwner", state);
model.AllItemsWithoutOwnerCount = contentQuery.Count();
// get overrude items count
// display
// 1) Number of your open, new, in progress, and closed tickets
// 2) number of the unassigned, new, open, in progress and closed tickets in the system.
return ContentShape("Parts_Dashboard",
() => shapeHelper.Parts_Dashboard(
Model: model
));
}
위젯과 비슷한 새 위젯을 만들어야합니다. DashboardDriver는 로그인 한 사용자의 티켓과 모든 티켓의 요약을 나타냅니다. 새로운 위젯에서는 사용자의 요약 티켓 만 나타낼 수 있습니다. 새 위젯은 UserId 속성을 가져야하며 로그인 된 사용자 대신 해당 사용자의 티켓 요약을 나타냅니다. 다음과 같은 내용 :
private DriverResult DisplayDetail(NewUserDashboardPart part, dynamic shapeHelper)
{
if (this.services.WorkContext.CurrentUser == null)
{
return null;
}
var contentQuery = this.services.ContentManager.HqlQuery().ForVersion(VersionOptions.Published);
var statusRecords = this.basicDataService.GetStatusRecords().OrderBy(c => c.OrderId).ToList();
DashboardViewModel model = new DashboardViewModel();
model.CurrentUserId = NewUserDashboardPart.UserId;
dynamic state = new JObject();
// Query the counts of the current user tickets group by stateId
// *******************************************************
// Ticket contentType
state.ContentTypes = "Ticket";
contentQuery = this.projectionManagerWithDynamicSort.ApplyFilter(contentQuery, "Content", "ContentTypes", state);
dynamic temp = new
{
Users = new int[] { model.CurrentUserId },
Teams = new int[] { },
BusinessUnits = new int[] { },
AccessType = ContentItemPermissionAccessTypes.Assignee
};
contentQuery = this.projectionManagerWithDynamicSort.ApplyFilter(contentQuery, ContentItemPermissionFilter.CategoryName, ContentItemPermissionFilter.AnySelectedUserTeamBusinessUnit, temp);
var userTicketsCountByStateIds = groupQuery.GetCount(contentQuery, "TicketPartRecord", "StatusRecord.Id");
model.CurrentUserTickets = new Collection<dynamic>();
CRMHelper.AddStatusGroupRecordsToModel(statusRecords, userTicketsCountByStateIds, model.CurrentUserTickets);
// overrude items of current users
state.MaxDueDate = DateTime.UtcNow.Date;
contentQuery = this.projectionManagerWithDynamicSort.ApplyFilter(contentQuery, TicketFieldsFilter.CategoryName, TicketFieldsFilter.TicketDueDateType, state);
model.CurrentUserOverrudeItemsCount = contentQuery.Count();
//*******************************************************
// display
// 1) Number of your open, new, in progress, and closed tickets
// 2) number of the unassigned, new, open, in progress and closed tickets in the system.
return ContentShape("Parts_Dashboard",
() => shapeHelper.Parts_Dashboard(
Model: model
));
}