public IActionResult RenderGridView([FromBody] EntityGridModel model) { QueryView.Domain.QueryView queryView = null; if (model.QueryViewId.HasValue && !model.QueryViewId.Equals(Guid.Empty)) { queryView = _queryViewFinder.FindById(model.QueryViewId.Value); } else if (model.EntityId.HasValue && !model.EntityId.Value.Equals(Guid.Empty)) { queryView = _queryViewFinder.FindEntityDefaultView(model.EntityId.Value); } else if (model.EntityName.IsNotEmpty()) { queryView = _queryViewFinder.FindEntityDefaultView(model.EntityName); } else { return(NotFound()); } if (queryView == null) { return(NotFound()); } if (!queryView.IsDefault && queryView.AuthorizationEnabled) { if (!_roleObjectAccessService.Exists(queryView.QueryViewId, QueryViewDefaults.ModuleName, CurrentUser.Roles.Select(n => n.RoleId).ToArray())) { return(Unauthorized()); } } model.QueryView = queryView; model.EntityId = queryView.EntityId; FetchDescriptor fetch = new FetchDescriptor { Page = model.Page, PageSize = model.PageSize, FetchConfig = queryView.FetchConfig, GetAll = !model.PagingEnabled }; if (model.IsSortBySeted) { QueryColumnSortInfo sort = new QueryColumnSortInfo(model.SortBy, model.SortDirection == 0); fetch.Sort = sort; } //查询关键字 if (model.Q.IsNotEmpty()) { fetch.Keyword = model.Q; fetch.Field = model.QField; } var canFetch = true; //filter by relationship if (model.RelationShipName.IsNotEmpty()) { var relationship = _relationShipFinder.FindByName(model.RelationShipName); if (relationship != null && model.ReferencedRecordId.HasValue && !model.ReferencedRecordId.Value.Equals(Guid.Empty)) { if (model.Filter == null) { model.Filter = new FilterExpression(); } var condition = new ConditionExpression(relationship.ReferencingAttributeName, ConditionOperator.Equal, model.ReferencedRecordId); model.Filter.AddCondition(condition); } model.RelationShipMeta = relationship; } if (model.RelationShipName.IsNotEmpty() && (!model.ReferencedRecordId.HasValue || model.ReferencedRecordId.Value.Equals(Guid.Empty))) { //如果被引用ID为空,则不查询数据 canFetch = false; } fetch.Filter = model.Filter; if (canFetch) { fetch.User = CurrentUser; var datas = _fetchService.Execute(fetch); if (model.OnlyData) { //var serializer = new DataContractJsonSerializer(typeof(User), new DataContractJsonSerializerSettings() //{ // UseSimpleDictionaryFormat = true//去掉Key和Value //}); //return new JsonResult() { Data = datas.Items.SerializeToJson(), JsonRequestBehavior = JsonRequestBehavior.AllowGet }; return(Content(datas.SerializeToJson())); } model.Grid = _gridService.Build(queryView, _fetchService.QueryResolver.EntityList, _fetchService.QueryResolver.AttributeList); model.EntityList = _fetchService.QueryResolver.EntityList; model.AttributeList = _fetchService.QueryResolver.AttributeList; model.RelationShipList = _fetchService.QueryResolver.RelationShipList; model.Items = datas.Items; model.TotalItems = datas.TotalItems; } else { _fetchService.GetMetaDatas(fetch); model.Grid = _gridService.Build(queryView, _fetchService.QueryResolver.EntityList, _fetchService.QueryResolver.AttributeList); model.EntityList = _fetchService.QueryResolver.EntityList; model.AttributeList = _fetchService.QueryResolver.AttributeList; model.RelationShipList = _fetchService.QueryResolver.RelationShipList; model.Items = new List <dynamic>(); model.TotalItems = 0; } var buttons = _ribbonbuttonFinder.Find(model.EntityId.Value, RibbonButtonArea.SubGrid); if (buttons.NotEmpty()) { buttons = buttons.OrderBy(x => x.DisplayOrder).ToList(); model.RibbonButtons = buttons; } if (model.IsSortBySeted == false) { if (_fetchService.QueryExpression.Orders.NotEmpty()) { model.SortBy = _fetchService.QueryExpression.Orders[0].AttributeName; model.SortDirection = (int)_fetchService.QueryExpression.Orders[0].OrderType; } } return(View($"~/Views/Entity/{WebContext.ActionName}.cshtml", model)); }
public AggregateRoot Retrieve(QueryBase request, bool ignorePermissions = false) { //查询单个实体,查询列表 //var entity = args.EntityId.Equals(Guid.Empty) ? _entityFinder.FindByName(args.EntityName) : _entityFinder.FindById(args.EntityId); //var record = _dataFinder.RetrieveById(entity.Name, args.RecordId.Value); string entityname = ""; Guid? recordId = null; Guid? formId = null; _aggregateRoot.MainEntity = _dataFinder.RetrieveById(entityname, recordId.Value); //表单列表 SystemForm formEntity = null; formEntity = _systemFormFinder.FindById(formId.Value); FormBuilder formBuilder = new FormBuilder(formEntity.FormConfig); List <PanelDescriptor> panelDescriptors = formBuilder.Form.Panels; foreach (var panel in panelDescriptors) { foreach (var section in panel.Sections) { foreach (var row in section.Rows) { foreach (var cell in row.Cells) { if (cell.Control.ControlType == FormControlType.SubGrid) { var param = (SubGridParameters)cell.Control.Parameters; //param.ViewId; //param.RelationshipName var queryView = _queryViewFinder.FindById(Guid.Parse(param.ViewId)); if (queryView != null) { //if (!queryView.IsDefault && queryView.IsAuthorization) { } FetchDescriptor fetch = new FetchDescriptor { //Page = model.Page, //PageSize = model.PageSize, //FetchConfig = queryView.FetchConfig, //GetAll = !model.PagingEnabled }; //排序,过滤 var relationship = _relationShipFinder.FindByName(param.RelationshipName); var filter = new FilterExpression(); var condition = new ConditionExpression(relationship.ReferencingAttributeName, ConditionOperator.Equal, recordId.Value); filter.AddCondition(condition); fetch.Filter = filter; fetch.User = User; var datas = _fetchService.Execute(fetch); //_aggregateRoot.grids.Add("", datas.Items); } } } } } } return(_aggregateRoot); }
public IActionResult Post([FromBody] EntityGridModel model) { QueryView.Domain.QueryView queryView = null; if (model.QueryViewId.HasValue && !model.QueryViewId.Equals(Guid.Empty)) { queryView = _queryViewFinder.FindById(model.QueryViewId.Value); } else if (model.EntityId.HasValue && !model.EntityId.Value.Equals(Guid.Empty)) { queryView = _queryViewFinder.FindEntityDefaultView(model.EntityId.Value); } else if (model.EntityName.IsNotEmpty()) { queryView = _queryViewFinder.FindEntityDefaultView(model.EntityName); } else { return(NotFound()); } if (queryView == null) { return(NotFound()); } if (!queryView.IsDefault && queryView.AuthorizationEnabled) { if (!_roleObjectAccessService.Exists(queryView.QueryViewId, QueryViewDefaults.ModuleName, CurrentUser.Roles.Select(n => n.RoleId).ToArray())) { return(Unauthorized()); } } model.QueryView = queryView; model.EntityId = queryView.EntityId; FetchDescriptor fetch = new FetchDescriptor { Page = model.Page, PageSize = model.PageSize, FetchConfig = queryView.FetchConfig, GetAll = !model.PagingEnabled }; if (model.IsSortBySeted) { QueryColumnSortInfo sort = new QueryColumnSortInfo(model.SortBy, model.SortDirection == 0); fetch.Sort = sort; } //查询关键字 if (model.Q.IsNotEmpty()) { fetch.Keyword = model.Q; fetch.Field = model.QField; } var canFetch = true; //filter by relationship if (model.RelationShipName.IsNotEmpty()) { var relationship = _relationShipFinder.FindByName(model.RelationShipName); if (relationship != null && model.ReferencedRecordId.HasValue && !model.ReferencedRecordId.Value.Equals(Guid.Empty)) { if (model.Filter == null) { model.Filter = new FilterExpression(); } var condition = new ConditionExpression(relationship.ReferencingAttributeName, ConditionOperator.Equal, model.ReferencedRecordId); model.Filter.AddCondition(condition); } model.RelationShipMeta = relationship; } if (model.RelationShipName.IsNotEmpty() && (!model.ReferencedRecordId.HasValue || model.ReferencedRecordId.Value.Equals(Guid.Empty))) { //如果被引用ID为空,则不查询数据 canFetch = false; } fetch.Filter = model.Filter; if (canFetch) { fetch.User = CurrentUser; var fetchDatas = _fetchService.Execute(fetch); object aggregateDatas = null; if (queryView.AggregateConfig.IsNotEmpty()) { var aggFields = new List <AggregateExpressionField>().DeserializeFromJson(queryView.AggregateConfig); if (aggFields.NotEmpty()) { var queryExp = new QueryExpression().DeserializeFromJson(queryView.FetchConfig); if (model.Filter != null && (model.Filter.Conditions.NotEmpty() || (model.Filter.Filters.NotEmpty() && model.Filter.Filters.First().Conditions.NotEmpty()))) { queryExp.Criteria.AddFilter(model.Filter); } var aggExp = new AggregateExpression { ColumnSet = queryExp.ColumnSet, Criteria = queryExp.Criteria, EntityName = queryExp.EntityName, LinkEntities = queryExp.LinkEntities, AggregateFields = aggFields }; var aggDatas = _aggregateService.Execute(aggExp); var attributes = _attributeFinder.FindByName(queryView.EntityId, aggFields.Select(x => x.AttributeName).ToArray()); foreach (dynamic item in aggDatas) { var line = item as IDictionary <string, object>; var attribute = attributes.Find(x => x.Name.IsCaseInsensitiveEqual(line.Keys.First())); item.metadata = new { attribute.Name, attribute.LocalizedName, attribute.AttributeTypeName, attribute.EntityId, attribute.EntityName, attribute.EntityLocalizedName }; item.aggregatetype = aggFields.Find(x => x.AttributeName.IsCaseInsensitiveEqual(attribute.Name)).AggregateType; } aggregateDatas = new { View = new { queryView.QueryViewId, queryView.Name }, Data = aggDatas }; } } return(Content(new { FetchData = fetchDatas, AggregateData = aggregateDatas }.SerializeToJson())); } if (!model.IsSortBySeted) { if (_fetchService.QueryExpression.Orders.NotEmpty()) { model.SortBy = _fetchService.QueryExpression.Orders[0].AttributeName; model.SortDirection = (int)_fetchService.QueryExpression.Orders[0].OrderType; } } return(View($"~/Views/Entity/{WebContext.ActionName}.cshtml", model)); }
public MemoryStream ToExcelStream(QueryView.Domain.QueryView queryView, FilterExpression filter, OrderExpression order, string fileName, bool includePrimaryKey = false, bool includeIndex = false, string title = "") { _fetchDataService.GetMetaDatas(queryView.FetchConfig); if (filter != null) { _fetchDataService.QueryExpression.Criteria.AddFilter(filter); } if (order != null) { _fetchDataService.QueryExpression.Orders.Clear(); _fetchDataService.QueryExpression.Orders.Add(order); } _fetchDataService.QueryExpression.PageInfo = new PagingInfo() { PageNumber = 1, PageSize = 99999 }; var data = _fetchDataService.Execute(_fetchDataService.QueryExpression); if (data.TotalItems == 0) { return(null); } Dictionary <string, string> columnNames = new Dictionary <string, string>(StringComparer.OrdinalIgnoreCase); List <string> hideColumns = new List <string>(); var grid = _gridService.Build(queryView, _fetchDataService.QueryResolver.EntityList, _fetchDataService.QueryResolver.AttributeList); if (includeIndex) { columnNames.Add("rownum", "序号"); if (data.Items.NotEmpty()) { for (int i = 0; i < data.Items.Count; i++) { data.Items[i].RowNum = i + 1; } } } if (includePrimaryKey) { var pk = _fetchDataService.QueryResolver.AttributeList.Find(n => n.EntityName.IsCaseInsensitiveEqual(_fetchDataService.QueryResolver.MainEntity.Name) && n.TypeIsPrimaryKey());//new Schema.AttributeService(user).Find(n => n.AttributeTypeName == AttributeTypeIds.PRIMARYKEY && n.EntityName == fetchService.QueryResolver.MainEntity.Name); columnNames.Add(pk.Name, pk.Name); hideColumns.Add(pk.Name); } foreach (var cell in grid.Rows[0].Cells) { var columnName = cell.Name.IndexOf(".") > 0 ? cell.Name.Split('.')[1] : cell.Name; var item = _fetchDataService.QueryResolver.AttributeList.Find(n => n.Name.IsCaseInsensitiveEqual(columnName) && n.EntityName.IsCaseInsensitiveEqual(cell.EntityName)); var label = cell.Label;//item.LocalizedName; if (cell.Label.IsEmpty()) { if (!item.EntityId.Equals(_fetchDataService.QueryResolver.MainEntity.EntityId)) { var le = _fetchDataService.QueryExpression.FindLinkEntityByName(item.EntityName); if (le != null) { var relationship = _fetchDataService.QueryResolver.RelationShipList.Find(n => n.Name.IsCaseInsensitiveEqual(cell.Name.Split('.')[0])); _relationShipFinder.WrapLocalizedLabel(relationship); label += "(" + relationship.ReferencingAttributeLocalizedName + ")"; columnName = le.EntityAlias + "." + columnName; } } else { label = item.LocalizedName; } } if (item.TypeIsPrimaryKey()) { var pkField = _fetchDataService.QueryResolver.AttributeList.Find(n => n.EntityName.IsCaseInsensitiveEqual(_fetchDataService.QueryResolver.MainEntity.Name) && n.IsPrimaryField); columnNames.Add(pkField.Name, label); } else if (item.TypeIsBit() || item.TypeIsState() || item.TypeIsStatus() || item.TypeIsPickList() || item.TypeIsLookUp() || item.TypeIsOwner() || item.TypeIsCustomer()) { columnNames.Add(cell.Name + "Name", label); } else { columnNames.Add(cell.Name, label); } } //字段权限 if (_fetchDataService.QueryResolver.AttributeList.Count(x => x.AuthorizationEnabled) > 0) { var noneRead = _systemUserPermissionService.GetNoneReadFields(_appContext.GetFeature <ICurrentUser>().SystemUserId, _fetchDataService.QueryResolver.AttributeList.Where(x => x.AuthorizationEnabled).Select(x => x.AttributeId).ToList()); if (noneRead.NotEmpty()) { var noneReadAttrs = _attributeFinder.Query(x => x.Where(f => f.AttributeId.In(noneRead))); foreach (var d in data.Items) { var _this = d as IDictionary <string, object>; foreach (var nr in noneReadAttrs) { _this[nr.Name.ToLower()] = null; if (nr.TypeIsBit() || nr.TypeIsState() || nr.TypeIsPickList() || nr.TypeIsStatus() || nr.TypeIsLookUp() || nr.TypeIsOwner() || nr.TypeIsCustomer()) { _this[nr.Name.ToLower() + "name"] = null; } } } } } var list = data.Items; //aggregation if (list.NotEmpty() && queryView.AggregateConfig.IsNotEmpty()) { var aggFields = new List <AggregateExpressionField>().DeserializeFromJson(queryView.AggregateConfig); if (aggFields.NotEmpty()) { var aggExp = new AggregateExpression { ColumnSet = _fetchDataService.QueryExpression.ColumnSet, Criteria = _fetchDataService.QueryExpression.Criteria, EntityName = _fetchDataService.QueryExpression.EntityName, LinkEntities = _fetchDataService.QueryExpression.LinkEntities, AggregateFields = aggFields }; var aggDatas = _aggregateService.Execute(aggExp); var aggData = aggDatas.NotEmpty() ? aggDatas.First() : null; if (aggData != null) { var tmpRow = list.First() as IDictionary <string, object>; var aggRow = new Dictionary <string, object>(); var aggDataRow = aggData as IDictionary <string, object>; foreach (var r in tmpRow) { var aggf = aggFields.Find(n => n.AttributeName.IsCaseInsensitiveEqual(r.Key)); if (aggf != null) { aggRow[r.Key] = aggDataRow[aggf.AttributeName.ToLower()]; } else { aggRow[r.Key] = null; } } list.Add(aggRow); } } } return(ToExcelStream(list, fileName, columnNames, hideColumns, title, _fetchDataService.QueryResolver.AttributeList)); }
public IActionResult RecordsDialog([FromBody] SelectEntityRecordsDialogModel model, DialogModel dm) { QueryView.Domain.QueryView queryView = null; if (model.QueryId.HasValue && !model.QueryId.Equals(Guid.Empty)) { queryView = _queryViewFinder.FindById(model.QueryId.Value); } else if (model.EntityId.HasValue && !model.EntityId.Equals(Guid.Empty)) { queryView = _queryViewFinder.FindEntityDefaultView(model.EntityId.Value); } else if (model.EntityName.IsNotEmpty()) { queryView = _queryViewFinder.FindEntityDefaultView(model.EntityName); } else { return(NotFound()); } if (queryView == null) { return(NotFound()); } model.QueryId = queryView.QueryViewId; model.QueryView = queryView; model.EntityId = queryView.EntityId; FetchDescriptor fetch = new FetchDescriptor { User = CurrentUser, Page = model.Page, PageSize = model.PageSize, FetchConfig = queryView.FetchConfig }; if (model.IsSortBySeted) { QueryColumnSortInfo sort = new QueryColumnSortInfo(model.SortBy, model.SortDirection == 0); fetch.Sort = sort; } if (model.Q.IsNotEmpty()) { fetch.Keyword = model.Q; fetch.Field = model.QField; } if (model.Filter == null) { model.Filter = new FilterExpression(); } //filter disabled records if (model.OnlyEnabledRecords) { if (model.Filter.Conditions.IsEmpty() || model.Filter.Conditions.Find(n => n.AttributeName.IsCaseInsensitiveEqual("statecode")) == null) { model.Filter.AddCondition("statecode", ConditionOperator.Equal, 1); } } //filter by relationship if (model.RelationShipName.IsNotEmpty()) { var relationship = _relationShipFinder.FindByName(model.RelationShipName); if (relationship != null && model.ReferencedRecordId.HasValue && !model.ReferencedRecordId.Value.Equals(Guid.Empty)) { var condition = new ConditionExpression(relationship.ReferencingAttributeName, ConditionOperator.Equal, model.ReferencedRecordId); model.Filter.AddCondition(condition); } model.RelationShipMeta = relationship; } fetch.Filter = model.Filter; var datas = _fetchDataService.Execute(fetch); model.Grid = _gridService.Build(queryView, _fetchDataService.QueryResolver.EntityList, _fetchDataService.QueryResolver.AttributeList); model.EntityList = _fetchDataService.QueryResolver.EntityList; model.AttributeList = _fetchDataService.QueryResolver.AttributeList; model.RelationShipList = _fetchDataService.QueryResolver.RelationShipList; model.Items = datas.Items; model.TotalItems = datas.TotalItems; if (model.IsSortBySeted == false) { if (_fetchDataService.QueryExpression.Orders.NotEmpty()) { model.SortBy = _fetchDataService.QueryExpression.Orders[0].AttributeName; model.SortDirection = (int)_fetchDataService.QueryExpression.Orders[0].OrderType; } } ViewData["DialogModel"] = dm; return(View($"~/Views/Entity/{WebContext.ActionName}.cshtml", model)); }
public IActionResult Post([FromBody] EntityGridModel model) { QueryView.Domain.QueryView queryView = null; if (model.QueryViewId.HasValue && !model.QueryViewId.Equals(Guid.Empty)) { queryView = _queryViewFinder.FindById(model.QueryViewId.Value); } else if (model.EntityId.HasValue && !model.EntityId.Value.Equals(Guid.Empty)) { queryView = _queryViewFinder.FindEntityDefaultView(model.EntityId.Value); } else if (model.EntityName.IsNotEmpty()) { queryView = _queryViewFinder.FindEntityDefaultView(model.EntityName); } else { return(NotFound()); } if (queryView == null) { return(NotFound()); } if (!queryView.IsDefault && queryView.AuthorizationEnabled) { if (!_roleObjectAccessService.Exists(queryView.QueryViewId, QueryViewDefaults.ModuleName, CurrentUser.Roles.Select(n => n.RoleId).ToArray())) { return(Unauthorized()); } } model.QueryView = queryView; model.EntityId = queryView.EntityId; FetchDescriptor fetch = new FetchDescriptor { Page = model.Page, PageSize = model.PageSize, FetchConfig = queryView.FetchConfig, GetAll = !model.PagingEnabled }; if (model.IsSortBySeted) { QueryColumnSortInfo sort = new QueryColumnSortInfo(model.SortBy, model.SortDirection == 0); fetch.Sort = sort; } //查询关键字 if (model.Q.IsNotEmpty()) { fetch.Keyword = model.Q; fetch.Field = model.QField; } var canFetch = true; //filter by relationship if (model.RelationShipName.IsNotEmpty()) { var relationship = _relationShipFinder.FindByName(model.RelationShipName); if (relationship != null && model.ReferencedRecordId.HasValue && !model.ReferencedRecordId.Value.Equals(Guid.Empty)) { if (model.Filter == null) { model.Filter = new FilterExpression(); } var condition = new ConditionExpression(relationship.ReferencingAttributeName, ConditionOperator.Equal, model.ReferencedRecordId); model.Filter.AddCondition(condition); } model.RelationShipMeta = relationship; } if (model.RelationShipName.IsNotEmpty() && (!model.ReferencedRecordId.HasValue || model.ReferencedRecordId.Value.Equals(Guid.Empty))) { //如果被引用ID为空,则不查询数据 canFetch = false; } fetch.Filter = model.Filter; if (canFetch) { fetch.User = CurrentUser; var datas = _fetchService.Execute(fetch); return(Content(datas.SerializeToJson())); } if (!model.IsSortBySeted) { if (_fetchService.QueryExpression.Orders.NotEmpty()) { model.SortBy = _fetchService.QueryExpression.Orders[0].AttributeName; model.SortDirection = (int)_fetchService.QueryExpression.Orders[0].OrderType; } } return(View($"~/Views/Entity/{WebContext.ActionName}.cshtml", model)); }