public ApiDevelopersController(IErpService service) : base(service) { em = new EntityManager(service.StorageService); rm = new EntityRelationManager(service.StorageService); recMan = new RecordManager(service); fs = service.StorageService.GetFS(); }
public WebHooks() { recMan = new RecordManager(); secMan = new SecurityManager(); entMan = new EntityManager(); relMan = new EntityRelationManager(); }
public ApiController() { recMan = new RecordManager(); secMan = new SecurityManager(); entMan = new EntityManager(); relMan = new EntityRelationManager(); }
/// <summary> /// The contructor /// </summary> /// <param name="service"></param> public RecordManager(IErpService service) { erpService = service; entityCache = new List<Entity>(); entityManager = new EntityManager(erpService.StorageService); entityRelationManager = new EntityRelationManager(erpService.StorageService); }
internal RecordManager(bool ignoreSecurity = false) { entityCache = new List<Entity>(); entityManager = new EntityManager(); entityRelationManager = new EntityRelationManager(); relationRepository = DbContext.Current.RelationRepository; this.ignoreSecurity = ignoreSecurity; }
public ApiController(IWebHookService hooksService) { recMan = new RecordManager(); secMan = new SecurityManager(); entMan = new EntityManager(); relMan = new EntityRelationManager(); this.hooksService = hooksService; }
internal RecordManager(IErpService service, bool ignoreSecurity = false) { erpService = service; entityCache = new List<Entity>(); entityManager = new EntityManager(erpService.StorageService); entityRelationManager = new EntityRelationManager(erpService.StorageService); this.ignoreSecurity = ignoreSecurity; }
internal RecordManager(bool ignoreSecurity = false) { entityCache = new List <Entity>(); entityManager = new EntityManager(); entityRelationManager = new EntityRelationManager(); relationRepository = DbContext.Current.RelationRepository; this.ignoreSecurity = ignoreSecurity; }
private List<ErrorModel> ValidateRecordTree(Entity entity, InputRecordTree recordTree) { List<ErrorModel> errorList = new List<ErrorModel>(); if (!recordTree.Id.HasValue || recordTree.Id == Guid.Empty) errorList.Add(new ErrorModel("id", null, "Id is required!")); if (string.IsNullOrWhiteSpace(recordTree.Name)) errorList.Add(new ErrorModel("name", null, "Name is required!")); if (string.IsNullOrWhiteSpace(recordTree.Name)) errorList.Add(new ErrorModel("label", null, "Label is required!")); if (errorList.Any()) return errorList; if (entity.RecordTrees.Any(f => f.Id != recordTree.Id && f.Name.ToLowerInvariant() == recordTree.Name.ToLowerInvariant())) errorList.Add(new ErrorModel("name", null, "There is already a tree with same name!")); if (entity.RecordTrees.Any(f => f.Id != recordTree.Id && f.Label.ToLowerInvariant() == recordTree.Label.ToLowerInvariant())) errorList.Add(new ErrorModel("label", null, "There is already a tree with same label!")); EntityRelation relation = null; if (recordTree.RelationId == null || recordTree.RelationId == Guid.Empty) { errorList.Add(new ErrorModel("relationId", null, "Relation is required!")); return errorList; } else { EntityRelationManager relationManager = new EntityRelationManager(Storage); EntityRelationResponse relationResponse = relationManager.Read(recordTree.RelationId); if (relationResponse.Object != null) relation = relationResponse.Object; } if (relation == null) { errorList.Add(new ErrorModel("relationId", null, "Cannot find relation for specified id!")); return errorList; } if (!(relation.OriginEntityId == entity.Id && relation.TargetEntityId == relation.OriginEntityId) || relation.RelationType == EntityRelationType.OneToOne) { errorList.Add(new ErrorModel("relationId", null, "Specified relation cannot be used as tree relation!")); return errorList; } if (recordTree.NodeIdFieldId == null) recordTree.NodeIdFieldId = relation.OriginFieldId; else if (recordTree.NodeIdFieldId != relation.OriginFieldId) errorList.Add(new ErrorModel("nodeIdFieldId", null, "Node field does not correspond to specified relation target field!")); if (recordTree.NodeParentIdFieldId == null) recordTree.NodeParentIdFieldId = relation.TargetFieldId; else if (recordTree.NodeParentIdFieldId != relation.TargetFieldId) errorList.Add(new ErrorModel("nodeParentIdFieldId", null, "Node parent field does not correspond to specified relation origin field!")); var idField = entity.Fields.Single(f => f.Name == "id"); if (recordTree.NodeNameFieldId == null) recordTree.NodeNameFieldId = idField.Id; if (recordTree.NodeLabelFieldId == null) recordTree.NodeLabelFieldId = idField.Id; if (!entity.Fields.Any(f => f.Id == recordTree.NodeIdFieldId)) errorList.Add(new ErrorModel("nodeIdFieldId", null, "Node field is not found in entity fields collection!")); if (!entity.Fields.Any(f => f.Id == recordTree.NodeParentIdFieldId)) errorList.Add(new ErrorModel("nodeParentIdFieldId", null, "Node parent field is not found in entity fields collection!")); if (!entity.Fields.Any(f => f.Id == recordTree.NodeNameFieldId)) errorList.Add(new ErrorModel("nodeNameFieldId", null, "Node name field is not found in entity fields collection!")); if (!entity.Fields.Any(f => f.Id == recordTree.NodeLabelFieldId)) errorList.Add(new ErrorModel("nodeLabelFieldId", null, "Node label field is not found in entity fields collection!")); if (recordTree.DepthLimit == null) errorList.Add(new ErrorModel("depthLimit", null, "Depth limit is required!")); else if (recordTree.DepthLimit <= 0) errorList.Add(new ErrorModel("depthLimit", null, "Depth limit should be a positive number!")); else if (recordTree.DepthLimit > 50) errorList.Add(new ErrorModel("depthLimit", null, "Depth limit cannot be more than 20!")); if (errorList.Any()) return errorList; if (recordTree.RootNodes != null) { IStorageRecordRepository recRep = Storage.GetRecordRepository(); List<RecordTreeNode> expiredNodes = new List<RecordTreeNode>(); foreach (var node in recordTree.RootNodes) { var recData = recRep.Find(entity.Name, node.RecordId); if (recData != null) { var parentIdField = entity.Fields.SingleOrDefault(x => x.Id == recordTree.NodeParentIdFieldId); var nameField = entity.Fields.SingleOrDefault(x => x.Id == recordTree.NodeNameFieldId); var labelField = entity.Fields.SingleOrDefault(x => x.Id == recordTree.NodeLabelFieldId); var valuePair = recData.SingleOrDefault(x => x.Key == idField.Name); node.Id = (valuePair.Value as Guid?) ?? Guid.Empty; valuePair = recData.SingleOrDefault(x => x.Key == parentIdField.Name); node.ParentId = (valuePair.Value as Guid?) ?? Guid.Empty; valuePair = recData.SingleOrDefault(x => x.Key == nameField.Name); node.Name = (valuePair.Value ?? string.Empty).ToString(); valuePair = recData.SingleOrDefault(x => x.Key == labelField.Name); node.Label = (valuePair.Value ?? string.Empty).ToString(); } else expiredNodes.Add(node); } foreach (var node in expiredNodes) recordTree.RootNodes.Remove(node); } else recordTree.RootNodes = new List<RecordTreeNode>(); //verify and init node properties bellow if (recordTree.NodeObjectProperties == null) recordTree.NodeObjectProperties = new List<Guid>(); List<Guid> expiredFields = new List<Guid>(); foreach (var fieldId in recordTree.NodeObjectProperties) { if (!entity.Fields.Any(f => f.Id == fieldId)) expiredFields.Add(fieldId); } foreach (var expiredId in expiredFields) recordTree.NodeObjectProperties.Remove(expiredId); if (!recordTree.NodeObjectProperties.Contains(idField.Id)) recordTree.NodeObjectProperties.Add(idField.Id); if (!recordTree.NodeObjectProperties.Contains(recordTree.NodeIdFieldId.Value)) recordTree.NodeObjectProperties.Add(recordTree.NodeIdFieldId.Value); if (!recordTree.NodeObjectProperties.Contains(recordTree.NodeIdFieldId.Value)) recordTree.NodeObjectProperties.Add(recordTree.NodeIdFieldId.Value); if (!recordTree.NodeObjectProperties.Contains(recordTree.NodeParentIdFieldId.Value)) recordTree.NodeObjectProperties.Add(recordTree.NodeParentIdFieldId.Value); if (!recordTree.NodeObjectProperties.Contains(recordTree.NodeNameFieldId.Value)) recordTree.NodeObjectProperties.Add(recordTree.NodeNameFieldId.Value); if (!recordTree.NodeObjectProperties.Contains(recordTree.NodeLabelFieldId.Value)) recordTree.NodeObjectProperties.Add(recordTree.NodeLabelFieldId.Value); return errorList; }
public IActionResult GetEntityRelationMetaList(string hash = null) { var response = new EntityRelationManager().Read(); //check hash and clear data if hash match if (response.Success && response.Object != null && !string.IsNullOrWhiteSpace(hash) && response.Hash == hash) response.Object = null; return DoResponse(response); }
public IActionResult GetTreeRecords(string entityName, string treeName) { List<Entity> entities = entMan.ReadEntities().Object; RecordTreeRecordResponse response = new RecordTreeRecordResponse(); response.Message = "Success"; response.Timestamp = DateTime.UtcNow; response.Success = true; response.Object = new RecordTreeRecord(); Entity entity = entities.FirstOrDefault(e => e.Name == entityName); if (entity == null) { response.Timestamp = DateTime.UtcNow; response.Success = false; response.Message = "Entity with such name does not exist!"; response.Errors.Add(new ErrorModel("entityName", entityName, "Entity with such name does not exist!")); return DoResponse(response); } RecordTree tree = entity.RecordTrees.SingleOrDefault(x => x.Name == treeName); if (tree == null) { response.Timestamp = DateTime.UtcNow; response.Success = false; response.Message = "Tree with such name does not exist!"; response.Errors.Add(new ErrorModel("treeName", treeName, "Tree with such name does not exist!")); return DoResponse(response); } bool hasPermisstion = SecurityContext.HasEntityPermission(EntityPermission.Read, entity); if (!hasPermisstion) { response.Success = false; response.Message = "Trying to read records from entity '" + entity.Name + "' with no read access."; response.Errors.Add(new ErrorModel { Message = "Access denied." }); return DoResponse(response); } try { List<EntityRelation> relationList = new EntityRelationManager().Read().Object ?? new List<EntityRelation>(); response.Object.Data = Helpers.GetTreeRecords(entities, relationList, tree); response.Object.Meta = tree; } catch (Exception ex) { response.Timestamp = DateTime.UtcNow; response.Success = false; response.Message = ex.Message; return DoResponse(response); } return DoResponse(response); }
private List<ErrorModel> ValidateRecordView(Entity entity, InputRecordView recordView, bool checkId = false) { List<ErrorModel> errorList = new List<ErrorModel>(); List<IStorageEntity> storageEntityList = EntityRepository.Read(); List<Entity> entities = storageEntityList.MapTo<Entity>(); EntityRelationManager relationManager = new EntityRelationManager(Storage); EntityRelationListResponse relationListResponse = relationManager.Read(); List<EntityRelation> relationList = new List<EntityRelation>(); if (relationListResponse.Object != null) relationList = relationListResponse.Object; if (!recordView.Id.HasValue || recordView.Id == Guid.Empty) errorList.Add(new ErrorModel("id", null, "Id is required!")); if (checkId) { int viewSameIdCount = entity.RecordLists.Where(f => f.Id == recordView.Id).Count(); if (viewSameIdCount > 1) errorList.Add(new ErrorModel("id", null, "There is already a view with such Id!")); int viewSameNameCount = entity.Fields.Where(f => f.Name == recordView.Name).Count(); if (viewSameNameCount > 1) errorList.Add(new ErrorModel("name", null, "There is already a view with such Name!")); } errorList.AddRange(ValidationUtility.ValidateViewName(recordView.Name)); errorList.AddRange(ValidationUtility.ValidateLabel(recordView.Label)); if (!recordView.Weight.HasValue) recordView.Weight = 1; if (!recordView.Default.HasValue) recordView.Default = false; if (!recordView.System.HasValue) recordView.System = false; if (string.IsNullOrWhiteSpace(recordView.Type)) errorList.Add(new ErrorModel("type", null, "Type is required!")); else { RecordViewType type; if (!Enum.TryParse(recordView.Type, true, out type)) errorList.Add(new ErrorModel("type", recordView.Type, "Type is not valid!")); } if (recordView.Regions != null && recordView.Regions.Count > 0) { foreach (var region in recordView.Regions) { if (string.IsNullOrWhiteSpace(region.Name)) errorList.Add(new ErrorModel("regions.name", region.Name, "Name is required!")); else { if (recordView.Regions.Where(r => r.Name == region.Name).Count() > 1) errorList.Add(new ErrorModel("regions.name", region.Name, "There is already region with such name!")); errorList.AddRange(ValidationUtility.ValidateName(region.Name, key: "regions.name")); } if (!region.Render.HasValue) region.Render = false; if (region.Sections != null && region.Sections.Count > 0) { foreach (var section in region.Sections) { if (!section.Id.HasValue || section.Id == Guid.Empty) { errorList.Add(new ErrorModel("regions.sections.id", null, "Id is required!")); } else { if (region.Sections.Where(s => s.Id == section.Id).Count() > 1) errorList.Add(new ErrorModel("regions.sections.id", null, "There is already a section with such Id!")); } if (string.IsNullOrWhiteSpace(section.Name)) { errorList.Add(new ErrorModel("regions.sections.name", region.Name, "Name is required!")); } else { if (region.Sections.Where(s => s.Name == section.Name).Count() > 1) errorList.Add(new ErrorModel("regions.sections.name", section.Name, "There is already section with such name!")); errorList.AddRange(ValidationUtility.ValidateName(section.Name, key: "regions.sections.name")); } errorList.AddRange(ValidationUtility.ValidateLabel(section.Label, key: "regions.sections.label")); if (!section.ShowLabel.HasValue) section.ShowLabel = false; if (!section.Collapsed.HasValue) section.Collapsed = false; if (!section.Weight.HasValue) section.Weight = 1; if (section.Rows != null && section.Rows.Count > 0) { foreach (var row in section.Rows) { if (!row.Id.HasValue || row.Id == Guid.Empty) { errorList.Add(new ErrorModel("regions.sections.rows.id", null, "Id is required!")); } else { if (section.Rows.Where(r => r.Id == row.Id).Count() > 1) errorList.Add(new ErrorModel("regions.sections.rows.id", null, "There is already a row with such Id!")); } if (!row.Weight.HasValue) row.Weight = 1; if (row.Columns != null && row.Columns.Count > 0) { foreach (var column in row.Columns) { if (column.Items != null && column.Items.Count > 0) { foreach (var item in column.Items) { if (item is InputRecordViewFieldItem) { InputRecordViewFieldItem inputItem = (InputRecordViewFieldItem)item; if (string.IsNullOrWhiteSpace(inputItem.FieldName) && inputItem.FieldId == null) errorList.Add(new ErrorModel("regions.sections.rows.columns.items.fieldName", null, "Filed name and id are missing!")); else { if (inputItem.FieldId == null) { if (column.Items.Where(i => i is InputRecordViewFieldItem && ((InputRecordViewFieldItem)i).FieldName == inputItem.FieldName).Count() > 1) errorList.Add(new ErrorModel("regions.sections.rows.columns.items.fieldName", null, "There is already an item with such field name!")); if (!entity.Fields.Any(f => f.Name == inputItem.FieldName)) errorList.Add(new ErrorModel("regions.sections.rows.columns.items.fieldName", null, "Wrong Name. There is no field with such name!")); else inputItem.FieldId = entity.Fields.FirstOrDefault(f => f.Name == inputItem.FieldName).Id; } else if (string.IsNullOrWhiteSpace(inputItem.FieldName)) { if (column.Items.Where(i => i is InputRecordViewFieldItem && ((InputRecordViewFieldItem)i).FieldId == inputItem.FieldId).Count() > 1) errorList.Add(new ErrorModel("regions.sections.rows.columns.items.fieldId", null, "There is already an item with such field id!")); if (!entity.Fields.Any(f => f.Id == inputItem.FieldId)) errorList.Add(new ErrorModel("regions.sections.rows.columns.items.fieldId", null, "Wrong Id. There is no field with such id!")); else inputItem.FieldName = entity.Fields.FirstOrDefault(f => f.Id == inputItem.FieldId).Name; } } inputItem.EntityId = entity.Id; inputItem.EntityName = entity.Name; } else if (item is InputRecordViewListItem) { InputRecordViewListItem inputItem = (InputRecordViewListItem)item; if (string.IsNullOrWhiteSpace(inputItem.ListName) && inputItem.ListId == null) errorList.Add(new ErrorModel("regions.sections.rows.columns.items.listName", null, "List name and id are missing!")); else { if (inputItem.ListId == null) { if (column.Items.Where(i => i is InputRecordViewListItem && ((InputRecordViewListItem)i).ListName == inputItem.ListName).Count() > 1) errorList.Add(new ErrorModel("regions.sections.rows.columns.items.listName", null, "There is already an item with such list name!")); if (!entity.RecordLists.Any(l => l.Name == inputItem.ListName)) errorList.Add(new ErrorModel("regions.sections.rows.columns.items.listName", null, "Wrong name. There is no list with such name!")); else inputItem.ListId = entity.RecordLists.FirstOrDefault(l => l.Name == inputItem.ListName).Id; } else if (string.IsNullOrWhiteSpace(inputItem.ListName)) { if (column.Items.Where(i => i is InputRecordViewListItem && ((InputRecordViewListItem)i).ListId == inputItem.ListId).Count() > 1) errorList.Add(new ErrorModel("regions.sections.rows.columns.items.listName", null, "There is already an item with such list id!")); if (!entity.RecordLists.Any(l => l.Id == inputItem.ListId)) errorList.Add(new ErrorModel("regions.sections.rows.columns.items.listName", null, "Wrong id. There is no list with such id!")); else inputItem.ListName = entity.RecordLists.FirstOrDefault(l => l.Id == inputItem.ListId).Name; } } inputItem.EntityId = entity.Id; inputItem.EntityName = entity.Name; } else if (item is InputRecordViewViewItem) { InputRecordViewViewItem inputItem = (InputRecordViewViewItem)item; if (string.IsNullOrWhiteSpace(inputItem.ViewName) && inputItem.ViewId == null) errorList.Add(new ErrorModel("regions.sections.rows.columns.items.viewName", null, "View name and id are missing!")); else { if (inputItem.ViewId == null) { if (column.Items.Where(i => i is InputRecordViewViewItem && ((InputRecordViewViewItem)i).ViewName == inputItem.ViewName).Count() > 1) errorList.Add(new ErrorModel("regions.sections.rows.columns.items.viewName", null, "There is already an item with such view name!")); if (!entity.RecordViews.Any(v => v.Name == inputItem.ViewName)) errorList.Add(new ErrorModel("regions.sections.rows.columns.items.viewName", null, "Wrong name. There is no view with such name!")); else inputItem.ViewId = entity.RecordViews.FirstOrDefault(v => v.Name == inputItem.ViewName).Id; } else if (string.IsNullOrWhiteSpace(inputItem.ViewName)) { if (column.Items.Where(i => i is InputRecordViewViewItem && ((InputRecordViewViewItem)i).ViewId == inputItem.ViewId).Count() > 1) errorList.Add(new ErrorModel("regions.sections.rows.columns.items.viewName", null, "There is already an item with such view id!")); if (!entity.RecordViews.Any(v => v.Id == inputItem.ViewId)) errorList.Add(new ErrorModel("regions.sections.rows.columns.items.viewName", null, "Wrong id. There is no view with such id!")); else inputItem.ViewName = entity.RecordViews.FirstOrDefault(v => v.Id == inputItem.ViewId).Name; } } inputItem.EntityId = entity.Id; inputItem.EntityName = entity.Name; } else if (item is InputRecordViewRelationFieldItem) { EntityRelation relation = null; InputRecordViewRelationFieldItem inputItem = (InputRecordViewRelationFieldItem)item; if (string.IsNullOrWhiteSpace(inputItem.RelationName) && inputItem.RelationId == null) { errorList.Add(new ErrorModel("regions.sections.rows.columns.items.relationName", null, "Relation name or id is required!")); } else { if (inputItem.RelationId != null) relation = relationList.FirstOrDefault(r => r.Id == inputItem.RelationId); else relation = relationList.FirstOrDefault(r => r.Name == inputItem.RelationName); if (relation == null) errorList.Add(new ErrorModel("regions.sections.rows.columns.items.relationName", null, "Wrong name or id. There is no relation with such name or id!")); else { inputItem.RelationId = relation.Id; inputItem.RelationName = relation.Name; } } if (string.IsNullOrWhiteSpace(inputItem.FieldName) && inputItem.FieldId == null) { errorList.Add(new ErrorModel("regions.sections.rows.columns.items.fieldName", null, "Field name or id is required!")); } else if (inputItem.RelationId.HasValue && inputItem.RelationId != Guid.Empty) { bool foundMoreThanOneTime = false; if (inputItem.FieldId == null) foundMoreThanOneTime = column.Items.Where(i => i is InputRecordViewRelationFieldItem && ((InputRecordViewRelationFieldItem)i).FieldName == inputItem.FieldName).Count() > 1; else foundMoreThanOneTime = column.Items.Where(i => i is InputRecordViewRelationFieldItem && ((InputRecordViewRelationFieldItem)i).FieldId == inputItem.FieldId).Count() > 1; if (foundMoreThanOneTime) errorList.Add(new ErrorModel("regions.sections.rows.columns.items.fieldName", null, "There is already an item with such field name or id!")); if (relation != null) { Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); if (relEntity != null) { inputItem.EntityId = entity.Id; inputItem.EntityName = entity.Name; Field relField = null; if( !string.IsNullOrWhiteSpace(inputItem.FieldName)) relField = relEntity.Fields.FirstOrDefault(f => f.Name == inputItem.FieldName); else relField = relEntity.Fields.FirstOrDefault(f => f.Id == inputItem.FieldId); if (relField == null) errorList.Add(new ErrorModel("regions.sections.rows.columns.items.fieldName", null, "Wrong name. There is no field with such name!")); else { inputItem.FieldId = relField.Id; inputItem.FieldName = relField.Name; } } } } } else if (item is InputRecordViewRelationListItem) { EntityRelation relation = null; InputRecordViewRelationListItem inputItem = (InputRecordViewRelationListItem)item; if (string.IsNullOrWhiteSpace(inputItem.RelationName) && inputItem.RelationId == null ) { errorList.Add(new ErrorModel("regions.sections.rows.columns.items.relationName", null, "Relation name or id is required!")); } else { if(string.IsNullOrWhiteSpace(inputItem.RelationName)) relation = relationList.SingleOrDefault(r => r.Id == inputItem.RelationId); else relation = relationList.SingleOrDefault(r => r.Name == inputItem.RelationName); if (relation == null) errorList.Add(new ErrorModel("regions.sections.rows.columns.items.relationName", null, "Wrong name or id. There is no relation with such name or id!")); else { inputItem.RelationId = relation.Id; inputItem.RelationName = relation.Name; } } if (string.IsNullOrWhiteSpace(inputItem.ListName) && inputItem.ListId == null ) { errorList.Add(new ErrorModel("regions.sections.rows.columns.items.listName", null, "List name or id is required!")); } else if (inputItem.RelationId.HasValue && inputItem.RelationId != Guid.Empty) { InputRecordViewRelationListItem listItm = null; if (string.IsNullOrWhiteSpace(inputItem.ListName)) listItm = (InputRecordViewRelationListItem)column.Items.Where(i => i is InputRecordViewRelationListItem && ((InputRecordViewRelationListItem)i).ListId == inputItem.ListId); else listItm = (InputRecordViewRelationListItem)column.Items.Where(i => i is InputRecordViewRelationListItem && ((InputRecordViewRelationListItem)i).ListName == inputItem.ListName); if (listItm != null) errorList.Add(new ErrorModel("regions.sections.rows.columns.items.listName", null, "There is already an item with such list name or id!")); if (relation != null) { Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); if (relEntity != null) { inputItem.EntityId = entity.Id; inputItem.EntityName = entity.Name; RecordList relList = null; if( string.IsNullOrWhiteSpace(inputItem.ListName) ) relList = relEntity.RecordLists.FirstOrDefault(l => l.Id == inputItem.ListId); else relList = relEntity.RecordLists.FirstOrDefault(l => l.Name == inputItem.ListName); if (relList != null) { inputItem.ListId = relList.Id; inputItem.ListName = relList.Name; } else errorList.Add(new ErrorModel("regions.sections.rows.columns.items.listName", null, "Wrong Name. There is no list with such name or id!")); } } } } else if (item is InputRecordViewRelationViewItem) { EntityRelation relation = null; InputRecordViewRelationViewItem inputItem = (InputRecordViewRelationViewItem)item; if (string.IsNullOrWhiteSpace(inputItem.RelationName) && inputItem.RelationId == null ) { errorList.Add(new ErrorModel("regions.sections.rows.columns.items.relationName", null, "Relation name or id is required!")); } else { if (string.IsNullOrWhiteSpace(inputItem.RelationName)) relation = relationList.SingleOrDefault(r => r.Id == inputItem.RelationId); else relation = relationList.SingleOrDefault(r => r.Name == inputItem.RelationName); if (relation == null) errorList.Add(new ErrorModel("regions.sections.rows.columns.items.relationName", null, "Wrong name or. There is no relation with such name or id!")); else inputItem.RelationId = relationList.FirstOrDefault(r => r.Name == inputItem.RelationName).Id; } if (string.IsNullOrWhiteSpace(inputItem.ViewName)) { errorList.Add(new ErrorModel("regions.sections.rows.columns.items.viewName", null, "View name is required!")); } else if (inputItem.RelationId.HasValue && inputItem.RelationId != Guid.Empty) { if (relation != null) { Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); if (relEntity != null) { inputItem.EntityId = entity.Id; inputItem.EntityName = entity.Name; RecordView relView = null; if (string.IsNullOrWhiteSpace(inputItem.ViewName)) relView = relEntity.RecordViews.FirstOrDefault(l => l.Id == inputItem.ViewId); else relView = relEntity.RecordViews.FirstOrDefault(l => l.Name == inputItem.ViewName); if (relView != null) { inputItem.ViewId = relView.Id; inputItem.ViewName = relView.Name; } else errorList.Add(new ErrorModel("regions.sections.rows.columns.items.viewName", null, "Wrong name. There is no view with such name!")); } } if (column.Items.Where(i => i is InputRecordViewRelationViewItem && ((InputRecordViewRelationViewItem)i).ViewName == inputItem.ViewName).Count() > 1) errorList.Add(new ErrorModel("regions.sections.rows.columns.items.viewName", null, "There is already an item with such view name!")); } } else if (item is InputRecordViewHtmlItem) { ((InputRecordViewHtmlItem)item).Tag = ((InputRecordViewHtmlItem)item).Tag.Trim(); ((InputRecordViewHtmlItem)item).Content = ((InputRecordViewHtmlItem)item).Content.Trim(); } } } } } } } } } } } if (recordView.Sidebar != null) { if (recordView.Sidebar.Items != null && recordView.Sidebar.Items.Count > 0) { foreach (var item in recordView.Sidebar.Items) { if (item is InputRecordViewSidebarListItem) { InputRecordViewSidebarListItem inputItem = (InputRecordViewSidebarListItem)item; if (string.IsNullOrWhiteSpace(inputItem.ListName) && inputItem.ListId == null ) { errorList.Add(new ErrorModel("sidebar.items.listName", null, "List name or id is required!")); } else { RecordList list = null; if (string.IsNullOrWhiteSpace(inputItem.ListName)) list = entity.RecordLists.SingleOrDefault(l => l.Id == inputItem.ListId); else list = entity.RecordLists.SingleOrDefault(l => l.Name == inputItem.ListName); if (list == null ) errorList.Add(new ErrorModel("sidebar.items.listName", null, "Wrong name. There is no list with such name or id!")); else { inputItem.ListId = list.Id; inputItem.ListName = list.Name; } if (recordView.Sidebar.Items.Where(i => i is InputRecordViewSidebarListItem && ((InputRecordViewSidebarListItem)i).ListName == inputItem.ListName).Count() > 1) errorList.Add(new ErrorModel("sidebar.items.listName", null, "There is already an item with such list name or id!")); } } else if (item is InputRecordViewSidebarViewItem) { InputRecordViewSidebarViewItem inputItem = (InputRecordViewSidebarViewItem)item; if (string.IsNullOrWhiteSpace(inputItem.ViewName) && inputItem.ViewId == null ) { errorList.Add(new ErrorModel("sidebar.items.viewName", null, "View name or id is required!")); } else { RecordView view = null; if (string.IsNullOrWhiteSpace(inputItem.ViewName)) view = entity.RecordViews.SingleOrDefault(l => l.Id == inputItem.ViewId); else view = entity.RecordViews.SingleOrDefault(l => l.Name == inputItem.ViewName); if (view == null) errorList.Add(new ErrorModel("sidebar.items.viewName", null, "Wrong name. There is no view with such name or id!")); else { inputItem.ViewId = entity.RecordViews.FirstOrDefault(v => v.Name == inputItem.ViewName).Id; } if (recordView.Sidebar.Items.Where(i => i is InputRecordViewSidebarViewItem && ((InputRecordViewSidebarViewItem)i).ViewName == inputItem.ViewName).Count() > 1) errorList.Add(new ErrorModel("sidebar.items.viewName", null, "There is already an item with such view name or id!")); } } else if (item is InputRecordViewSidebarRelationListItem) { EntityRelation relation = null; InputRecordViewSidebarRelationListItem inputItem = (InputRecordViewSidebarRelationListItem)item; if (string.IsNullOrWhiteSpace(inputItem.RelationName) && inputItem.RelationId == null ) { errorList.Add(new ErrorModel("sidebar.items.relationName", null, "Relation name or id is required!")); } else { if (string.IsNullOrWhiteSpace(inputItem.RelationName)) relation = relationList.SingleOrDefault(r => r.Id == inputItem.RelationId.Value); else relation = relationList.SingleOrDefault(r => r.Name == inputItem.RelationName); if (relation == null) errorList.Add(new ErrorModel("sidebar.items.relationName", null, "Wrong name. There is no relation with such name or id!")); else { inputItem.RelationId = relation.Id; inputItem.RelationName = relation.Name; } } if (string.IsNullOrWhiteSpace(inputItem.ListName) && inputItem.ListId == null ) { errorList.Add(new ErrorModel("sidebar.items.listName", null, "List name or id is required!")); } else if (inputItem.RelationId.HasValue && inputItem.RelationId != Guid.Empty) { if (relation != null) { Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); inputItem.EntityId = relEntity.Id; inputItem.EntityName = relEntity.Name; if (relEntity != null) { RecordList relList = null; if (string.IsNullOrWhiteSpace(inputItem.ListName)) relList = relEntity.RecordLists.FirstOrDefault(l => l.Id == inputItem.ListId); else relList = relEntity.RecordLists.FirstOrDefault(l => l.Name == inputItem.ListName); if (relList != null) { inputItem.ListId = relList.Id; inputItem.ListName = relList.Name; } else errorList.Add(new ErrorModel("sidebar.items.listName", null, "Wrong name. There is no list with such name or id!")); } } if (recordView.Sidebar.Items.Where(i => i is InputRecordViewSidebarRelationListItem && ((InputRecordViewSidebarRelationListItem)i).ListName == inputItem.ListName).Count() > 1) errorList.Add(new ErrorModel("sidebar.items.listName", null, "There is already an item with such list name!")); } } else if (item is InputRecordViewSidebarRelationViewItem) { EntityRelation relation = null; InputRecordViewSidebarRelationViewItem inputItem = (InputRecordViewSidebarRelationViewItem)item; if (string.IsNullOrWhiteSpace(inputItem.RelationName) && inputItem.RelationId == null ) { errorList.Add(new ErrorModel("sidebar.items.relationName", null, "Relation name or id is required!")); } else { if (string.IsNullOrWhiteSpace(inputItem.RelationName)) relation = relationList.SingleOrDefault(r => r.Id == inputItem.RelationId.Value); else relation = relationList.SingleOrDefault(r => r.Name == inputItem.RelationName); if (relation == null) errorList.Add(new ErrorModel("sidebar.items.relationName", null, "Wrong name. There is no relation with such name or id!")); else { inputItem.RelationId = relation.Id; inputItem.RelationName = relation.Name; } } if (string.IsNullOrWhiteSpace(inputItem.ViewName) && inputItem.ViewId == null) { errorList.Add(new ErrorModel("sidebar.items.viewName", null, "View name is required!")); } else if (inputItem.RelationId.HasValue && inputItem.RelationId != Guid.Empty) { if (relation != null) { Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); if (relEntity != null) { inputItem.EntityId = relEntity.Id; inputItem.EntityName = relEntity.Name; RecordView relView = null; if (string.IsNullOrWhiteSpace(inputItem.ViewName)) relView = relEntity.RecordViews.FirstOrDefault(l => l.Id == inputItem.ViewId); else relView = relEntity.RecordViews.FirstOrDefault(l => l.Name == inputItem.ViewName); if (relView != null) { inputItem.ViewId = relView.Id; inputItem.ViewName = relView.Name; } else errorList.Add(new ErrorModel("sidebar.items.viewName", null, "Wrong name. There is no view with such name or id!")); } } if (recordView.Sidebar.Items.Where(i => i is InputRecordViewSidebarRelationViewItem && ((InputRecordViewSidebarRelationViewItem)i).ViewName == inputItem.ViewName).Count() > 1) errorList.Add(new ErrorModel("sidebar.items.viewName", null, "There is already an item with such view name!")); } } } } } return errorList; }
public EntityListResponse ReadEntities() { EntityListResponse response = new EntityListResponse { Success = true, Message = "The entity was successfully returned!", }; try { List<IStorageEntity> storageEntityList = EntityRepository.Read(); List<Entity> entities = storageEntityList.MapTo<Entity>(); EntityRelationManager relationManager = new EntityRelationManager(Storage); EntityRelationListResponse relationListResponse = relationManager.Read(); List<EntityRelation> relationList = new List<EntityRelation>(); if (relationListResponse.Object != null) relationList = relationListResponse.Object; List<RecordList> recordLists = new List<RecordList>(); List<RecordView> recordViews = new List<RecordView>(); List<Field> fields = new List<Field>(); foreach (var entity in entities) { recordLists.AddRange(entity.RecordLists); recordViews.AddRange(entity.RecordViews); fields.AddRange(entity.Fields); } foreach (var entity in entities) { if (entity.RecordLists != null) { foreach (var recordList in entity.RecordLists) { if (recordList.Columns != null) { foreach (var column in recordList.Columns) { if (column is RecordListFieldItem) { Field field = fields.FirstOrDefault(f => f.Id == ((RecordListFieldItem)column).FieldId); if (field != null) { //((RecordListFieldItem)column).DataName = string.Format("$field${0}", field.Name); ((RecordListFieldItem)column).DataName = field.Name; ((RecordListFieldItem)column).FieldName = field.Name; ((RecordListFieldItem)column).Meta = field; ((RecordListFieldItem)column).EntityName = entity.Name; ((RecordListFieldItem)column).EntityLabel = entity.Label; ((RecordListFieldItem)column).EntityLabelPlural = entity.LabelPlural; } } if (column is RecordListRelationFieldItem) { Entity relEntity = GetEntityByFieldId(((RecordListRelationFieldItem)column).FieldId, entities); if (relEntity != null) { ((RecordListRelationFieldItem)column).EntityName = relEntity.Name; ((RecordListRelationFieldItem)column).EntityLabel = relEntity.Label; ((RecordListRelationFieldItem)column).EntityLabelPlural = entity.LabelPlural; } var relation = relationList.FirstOrDefault(r => r.Id == ((RecordListRelationFieldItem)column).RelationId); ((RecordListRelationFieldItem)column).RelationName = relation != null ? relation.Name : string.Empty; Field field = fields.FirstOrDefault(f => f.Id == ((RecordListRelationFieldItem)column).FieldId); if (field != null) { ((RecordListRelationFieldItem)column).DataName = string.Format("$field${0}${1}", ((RecordListRelationFieldItem)column).RelationName, field.Name); ((RecordListRelationFieldItem)column).FieldName = field.Name; ((RecordListRelationFieldItem)column).Meta = field; } } if (column is RecordListViewItem) { RecordView view = recordViews.FirstOrDefault(v => v.Id == ((RecordListViewItem)column).ViewId); if (view != null) { ((RecordListViewItem)column).DataName = string.Format("$view${0}", view.Name); ((RecordListViewItem)column).ViewName = view.Name; ((RecordListViewItem)column).Meta = view; ((RecordListViewItem)column).EntityName = entity.Name; ((RecordListViewItem)column).EntityLabel = entity.Label; ((RecordListViewItem)column).EntityLabelPlural = entity.LabelPlural; } } if (column is RecordListRelationViewItem) { Entity relEntity = GetEntityByViewId(((RecordListRelationViewItem)column).ViewId, entities); if (relEntity != null) { ((RecordListRelationViewItem)column).EntityName = relEntity.Name; ((RecordListRelationViewItem)column).EntityLabel = relEntity.Label; ((RecordListRelationViewItem)column).EntityLabelPlural = entity.LabelPlural; } var relation = relationList.FirstOrDefault(r => r.Id == ((RecordListRelationViewItem)column).RelationId); ((RecordListRelationViewItem)column).RelationName = relation != null ? relation.Name : string.Empty; RecordView view = recordViews.FirstOrDefault(v => v.Id == ((RecordListRelationViewItem)column).ViewId); if (view != null) { ((RecordListRelationViewItem)column).DataName = string.Format("$view${0}${1}", ((RecordListRelationViewItem)column).RelationName, view.Name); ((RecordListRelationViewItem)column).ViewName = view.Name; ((RecordListRelationViewItem)column).Meta = view; } } if (column is RecordListListItem) { RecordList list = recordLists.FirstOrDefault(l => l.Id == ((RecordListListItem)column).ListId); if (list != null) { ((RecordListListItem)column).DataName = string.Format("list${0}", list.Name); ((RecordListListItem)column).ListName = list.Name; ((RecordListListItem)column).Meta = list; ((RecordListListItem)column).EntityName = entity.Name; ((RecordListListItem)column).EntityLabel = entity.Label; ((RecordListListItem)column).EntityLabelPlural = entity.LabelPlural; } } if (column is RecordListRelationListItem) { Entity relEntity = GetEntityByListId(((RecordListRelationListItem)column).ListId, entities); if (relEntity != null) { ((RecordListRelationListItem)column).EntityName = relEntity.Name; ((RecordListRelationListItem)column).EntityLabel = relEntity.Label; ((RecordListRelationListItem)column).EntityLabelPlural = entity.LabelPlural; } var relation = relationList.FirstOrDefault(r => r.Id == ((RecordListRelationListItem)column).RelationId); ((RecordListRelationListItem)column).RelationName = relation != null ? relation.Name : string.Empty; RecordList list = recordLists.FirstOrDefault(l => l.Id == ((RecordListRelationListItem)column).ListId); if (list != null) { ((RecordListRelationListItem)column).DataName = string.Format("$list${0}${1}", ((RecordListRelationListItem)column).RelationName, list.Name); ((RecordListRelationListItem)column).ListName = list.Name; ((RecordListRelationListItem)column).Meta = list; } } } } } } if (entity.RecordViews != null) { foreach (var recordView in entity.RecordViews) { if (recordView.Regions == null) continue; foreach (var region in recordView.Regions) { if (region.Sections == null) continue; foreach (var section in region.Sections) { if (section.Rows == null) continue; foreach (var row in section.Rows) { if (row.Columns == null) continue; foreach (var column in row.Columns) { if (column.Items == null) continue; foreach (var item in column.Items) { if (item is RecordViewFieldItem) { Field field = fields.FirstOrDefault(f => f.Id == ((RecordViewFieldItem)item).FieldId); if (field != null) { //((RecordViewFieldItem)item).DataName = string.Format("$field${0}", field.Name); ((RecordViewFieldItem)item).DataName = field.Name; ((RecordViewFieldItem)item).FieldName = field.Name; ((RecordViewFieldItem)item).Meta = field; ((RecordViewFieldItem)item).EntityId = entity.Id; ((RecordViewFieldItem)item).EntityName = entity.Name; ((RecordViewFieldItem)item).EntityLabel = entity.Label; ((RecordViewFieldItem)item).EntityLabelPlural = entity.LabelPlural; } } if (item is RecordViewListItem) { RecordList list = entity.RecordLists.FirstOrDefault(l => l.Id == ((RecordViewListItem)item).ListId); if (list != null) { ((RecordViewListItem)item).DataName = string.Format("$list${0}", list.Name); ((RecordViewListItem)item).Meta = list; ((RecordViewListItem)item).ListName = list.Name; ((RecordViewListItem)item).EntityId = entity.Id; ((RecordViewListItem)item).EntityName = entity.Name; ((RecordViewListItem)item).EntityLabel = entity.Label; ((RecordViewListItem)item).EntityLabelPlural = entity.LabelPlural; } } if (item is RecordViewViewItem) { RecordView recView = entity.RecordViews.FirstOrDefault(v => v.Id == ((RecordViewViewItem)item).ViewId); if (recView != null) { ((RecordViewViewItem)item).DataName = string.Format("$view${0}", recView.Name); ((RecordViewViewItem)item).Meta = recView; ((RecordViewViewItem)item).ViewName = recView.Name; ((RecordViewViewItem)item).EntityId = entity.Id; ((RecordViewViewItem)item).EntityName = entity.Name; ((RecordViewViewItem)item).EntityLabel = entity.Label; ((RecordViewViewItem)item).EntityLabelPlural = entity.LabelPlural; } } if (item is RecordViewRelationFieldItem) { Entity relEntity = GetEntityByFieldId(((RecordViewRelationFieldItem)item).FieldId, entities); if (relEntity != null) { ((RecordViewRelationFieldItem)item).EntityId = relEntity.Id; ((RecordViewRelationFieldItem)item).EntityName = relEntity.Name; ((RecordViewRelationFieldItem)item).EntityLabel = relEntity.Label; } var relation = relationList.FirstOrDefault(r => r.Id == ((RecordViewRelationFieldItem)item).RelationId); ((RecordViewRelationFieldItem)item).RelationName = relation != null ? relation.Name : string.Empty; Field field = fields.FirstOrDefault(f => f.Id == ((RecordViewRelationFieldItem)item).FieldId); if (field != null) { ((RecordViewRelationFieldItem)item).DataName = string.Format("$field${0}${1}", ((RecordViewRelationFieldItem)item).RelationName, field.Name); ((RecordViewRelationFieldItem)item).Meta = field; ((RecordViewRelationFieldItem)item).FieldName = field.Name; } } if (item is RecordViewRelationViewItem) { var relation = relationList.FirstOrDefault(r => r.Id == ((RecordViewRelationViewItem)item).RelationId); ((RecordViewRelationViewItem)item).RelationName = relation != null ? relation.Name : string.Empty; Entity relEntity = GetEntityByViewId(((RecordViewRelationViewItem)item).ViewId, entities); if (relEntity != null) { ((RecordViewRelationViewItem)item).EntityId = relEntity.Id; ((RecordViewRelationViewItem)item).EntityName = relEntity.Name; ((RecordViewRelationViewItem)item).EntityLabel = relEntity.Label; RecordView view = relEntity.RecordViews.FirstOrDefault(f => f.Id == ((RecordViewRelationViewItem)item).ViewId); if (view != null) { ((RecordViewRelationViewItem)item).DataName = string.Format("$view${0}${1}", ((RecordViewRelationViewItem)item).RelationName, view.Name); ((RecordViewRelationViewItem)item).Meta = view; ((RecordViewRelationViewItem)item).ViewName = view.Name; } } } if (item is RecordViewRelationListItem) { var relation = relationList.FirstOrDefault(r => r.Id == ((RecordViewRelationListItem)item).RelationId); ((RecordViewRelationListItem)item).RelationName = relation != null ? relation.Name : string.Empty; Entity relEntity = GetEntityByListId(((RecordViewRelationListItem)item).ListId, entities); if (relEntity != null) { ((RecordViewRelationListItem)item).EntityId = relEntity.Id; ((RecordViewRelationListItem)item).EntityName = relEntity.Name; ((RecordViewRelationListItem)item).EntityLabel = relEntity.Label; ((RecordViewRelationListItem)item).EntityLabelPlural = relEntity.LabelPlural; RecordList list = relEntity.RecordLists.FirstOrDefault(f => f.Id == ((RecordViewRelationListItem)item).ListId); if (list != null) { ((RecordViewRelationListItem)item).DataName = string.Format("$list${0}${1}", ((RecordViewRelationListItem)item).RelationName, list.Name); ((RecordViewRelationListItem)item).Meta = list; ((RecordViewRelationListItem)item).ListName = list.Name; } } } } } } } } if (recordView.Sidebar != null) { foreach (var item in recordView.Sidebar.Items) { if (item is RecordViewSidebarListItem) { RecordList list = entity.RecordLists.FirstOrDefault(l => l.Id == ((RecordViewSidebarListItem)item).ListId); if (list != null) { ((RecordViewSidebarListItem)item).DataName = string.Format("$list${0}", list.Name); ((RecordViewSidebarListItem)item).Meta = list; ((RecordViewSidebarListItem)item).ListName = list.Name; ((RecordViewSidebarListItem)item).EntityId = entity.Id; ((RecordViewSidebarListItem)item).EntityName = entity.Name; ((RecordViewSidebarListItem)item).EntityLabel = entity.Label; ((RecordViewSidebarListItem)item).EntityLabelPlural = entity.LabelPlural; } } if (item is RecordViewSidebarViewItem) { RecordView recView = entity.RecordViews.FirstOrDefault(v => v.Id == ((RecordViewSidebarViewItem)item).ViewId); if (recView != null) { ((RecordViewSidebarViewItem)item).DataName = string.Format("$view${0}", recView.Name); ((RecordViewSidebarViewItem)item).Meta = recView; ((RecordViewSidebarViewItem)item).ViewName = recView.Name; ((RecordViewSidebarViewItem)item).EntityId = entity.Id; ((RecordViewSidebarViewItem)item).EntityName = entity.Name; ((RecordViewSidebarViewItem)item).EntityLabel = entity.Label; ((RecordViewSidebarViewItem)item).EntityLabelPlural = entity.LabelPlural; } } if (item is RecordViewSidebarRelationViewItem) { var relation = relationList.FirstOrDefault(r => r.Id == ((RecordViewSidebarRelationViewItem)item).RelationId); ((RecordViewSidebarRelationViewItem)item).RelationName = relation != null ? relation.Name : string.Empty; Entity relEntity = GetEntityByViewId(((RecordViewSidebarRelationViewItem)item).ViewId, entities); if (relEntity != null) { ((RecordViewSidebarRelationViewItem)item).EntityId = relEntity.Id; ((RecordViewSidebarRelationViewItem)item).EntityName = relEntity.Name; ((RecordViewSidebarRelationViewItem)item).EntityLabel = relEntity.Label; RecordView view = relEntity.RecordViews.FirstOrDefault(f => f.Id == ((RecordViewSidebarRelationViewItem)item).ViewId); if (view != null) { ((RecordViewSidebarRelationViewItem)item).DataName = string.Format("$view${0}${1}", ((RecordViewSidebarRelationViewItem)item).RelationName, view.Name); ((RecordViewSidebarRelationViewItem)item).Meta = view; ((RecordViewSidebarRelationViewItem)item).ViewName = view.Name; } } } if (item is RecordViewSidebarRelationListItem) { var relation = relationList.FirstOrDefault(r => r.Id == ((RecordViewSidebarRelationListItem)item).RelationId); ((RecordViewSidebarRelationListItem)item).RelationName = relation != null ? relation.Name : string.Empty; Entity relEntity = GetEntityByListId(((RecordViewSidebarRelationListItem)item).ListId, entities); if (relEntity != null) { ((RecordViewSidebarRelationListItem)item).EntityId = relEntity.Id; ((RecordViewSidebarRelationListItem)item).EntityName = relEntity.Name; ((RecordViewSidebarRelationListItem)item).EntityLabel = relEntity.Label; ((RecordViewSidebarRelationListItem)item).EntityLabelPlural = relEntity.LabelPlural; RecordList list = relEntity.RecordLists.FirstOrDefault(f => f.Id == ((RecordViewSidebarRelationListItem)item).ListId); if (list != null) { ((RecordViewSidebarRelationListItem)item).DataName = string.Format("$list${0}${1}", ((RecordViewSidebarRelationListItem)item).RelationName, list.Name); ((RecordViewSidebarRelationListItem)item).Meta = list; ((RecordViewSidebarRelationListItem)item).ListName = list.Name; } } } } } } } } EntityList entityList = new EntityList(); entityList.Entities = entities; response.Object = entityList; } catch (Exception e) { response.Timestamp = DateTime.UtcNow; response.Success = false; #if DEBUG response.Message = e.Message + e.StackTrace; #else response.Message = "An internal error occurred!"; #endif return response; } response.Timestamp = DateTime.Now; return response; }
public void InitializeSystemEntities() { EntityResponse response = null; FieldResponse fieldResponse = null; EntityManager em = new EntityManager(StorageService); EntityRelationManager rm = new EntityRelationManager(StorageService); RecordManager recMan = new RecordManager(this); var transaction = recMan.CreateTransaction(); try { transaction.Begin(); IStorageSystemSettingsRepository systemSettingsRepository = StorageService.GetSystemSettingsRepository(); IStorageSystemSettings storeSystemSettings = systemSettingsRepository.Read(); Guid systemSettingsId = new Guid("F3223177-B2FF-43F5-9A4B-FF16FC67D186"); SystemSettings systemSettings = new SystemSettings(); systemSettings.Id = systemSettingsId; int currentVersion = 0; if (storeSystemSettings != null) { systemSettings = new SystemSettings(storeSystemSettings); currentVersion = systemSettings.Version; } EntityManager entityManager = new EntityManager(StorageService); //tmp code - during debug only //em.DeleteEntity(SystemIds.UserEntityId); //em.DeleteEntity(SystemIds.RoleEntityId); //rm.Delete(SystemIds.UserRoleRelationId); //currentVersion = 0; if (currentVersion < 150508) { systemSettings.Version = 150508; List<Guid> allowedRoles = new List<Guid>(); allowedRoles.Add(new Guid("F42EBA3B-6433-752B-6C34-B322A7B4CE7D")); #region << create role entity >> { InputEntity roleEntity = new InputEntity(); roleEntity.Id = SystemIds.RoleEntityId; roleEntity.Name = "role"; roleEntity.Label = "Role"; roleEntity.LabelPlural = "Roles"; roleEntity.System = true; roleEntity.RecordPermissions = new RecordPermissions(); roleEntity.RecordPermissions.CanRead = allowedRoles; roleEntity.RecordPermissions.CanCreate = allowedRoles; roleEntity.RecordPermissions.CanUpdate = allowedRoles; roleEntity.RecordPermissions.CanDelete = allowedRoles; response = entityManager.CreateEntity(roleEntity); InputTextField nameRoleField = new InputTextField(); nameRoleField.Id = new Guid("36F91EBD-5A02-4032-8498-B7F716F6A349"); nameRoleField.Name = "name"; nameRoleField.Label = "Name"; nameRoleField.PlaceholderText = ""; nameRoleField.Description = "The name of the role"; nameRoleField.HelpText = ""; nameRoleField.Required = true; nameRoleField.Unique = false; nameRoleField.Searchable = false; nameRoleField.Auditable = false; nameRoleField.System = true; nameRoleField.DefaultValue = ""; nameRoleField.MaxLength = 200; fieldResponse = entityManager.CreateField(roleEntity.Id.Value, nameRoleField,false); InputTextField descriptionRoleField = new InputTextField(); descriptionRoleField.Id = new Guid("4A8B9E0A-1C36-40C6-972B-B19E2B5D265B"); descriptionRoleField.Name = "description"; descriptionRoleField.Label = "Description"; descriptionRoleField.PlaceholderText = ""; descriptionRoleField.Description = ""; descriptionRoleField.HelpText = ""; descriptionRoleField.Required = true; descriptionRoleField.Unique = false; descriptionRoleField.Searchable = false; descriptionRoleField.Auditable = false; descriptionRoleField.System = true; descriptionRoleField.DefaultValue = ""; descriptionRoleField.MaxLength = 200; fieldResponse = entityManager.CreateField(roleEntity.Id.Value, descriptionRoleField,false); } #endregion #region << create user entity >> { InputEntity userEntity = new InputEntity(); userEntity.Id = SystemIds.UserEntityId; userEntity.Name = "user"; userEntity.Label = "User"; userEntity.LabelPlural = "Users"; userEntity.System = true; userEntity.RecordPermissions = new RecordPermissions(); userEntity.RecordPermissions.CanRead = allowedRoles; userEntity.RecordPermissions.CanCreate = allowedRoles; userEntity.RecordPermissions.CanUpdate = allowedRoles; userEntity.RecordPermissions.CanDelete = allowedRoles; response = entityManager.CreateEntity(userEntity); InputTextField firstName = new InputTextField(); firstName.Id = new Guid("DF211549-41CC-4D11-BB43-DACA4C164411"); firstName.Name = "first_name"; firstName.Label = "First Name"; firstName.PlaceholderText = ""; firstName.Description = "First name of the user"; firstName.HelpText = ""; firstName.Required = true; firstName.Unique = false; firstName.Searchable = false; firstName.Auditable = false; firstName.System = true; firstName.DefaultValue = ""; firstName.MaxLength = 200; fieldResponse = entityManager.CreateField(userEntity.Id.Value, firstName,false); InputTextField lastName = new InputTextField(); lastName.Id = new Guid("63E685B1-B2C6-4961-B393-2B6723EBD1BF"); lastName.Name = "last_name"; lastName.Label = "Last Name"; lastName.PlaceholderText = ""; lastName.Description = "Last name of the user"; lastName.HelpText = ""; lastName.Required = true; lastName.Unique = false; lastName.Searchable = false; lastName.Auditable = false; lastName.System = true; lastName.DefaultValue = ""; lastName.MaxLength = 200; fieldResponse = entityManager.CreateField(userEntity.Id.Value, lastName,false); InputEmailField email = new InputEmailField(); email.Id = new Guid("9FC75C8F-CE80-4A64-81D7-E2BEFA5E4815"); email.Name = "email"; email.Label = "Email"; email.PlaceholderText = ""; email.Description = "Email address of the user"; email.HelpText = ""; email.Required = true; email.Unique = true; email.Searchable = false; email.Auditable = false; email.System = true; email.DefaultValue = ""; email.MaxLength = 255; fieldResponse = entityManager.CreateField(userEntity.Id.Value, email,false); InputPasswordField password = new InputPasswordField(); password.Id = new Guid("4EDE88D9-217A-4462-9300-EA0D6AFCDCEA"); password.Name = "password"; password.Label = "Password"; password.PlaceholderText = ""; password.Description = "Password for the user account"; password.HelpText = ""; password.Required = true; password.Unique = true; password.Searchable = false; password.Auditable = false; password.System = true; password.MinLength = 6; password.MaxLength = 24; password.Encrypted = true; fieldResponse = entityManager.CreateField(userEntity.Id.Value, password, false); InputDateTimeField lastLoggedIn = new InputDateTimeField(); lastLoggedIn.Id = new Guid("3C85CCEC-D526-4E47-887F-EE169D1F508D"); lastLoggedIn.Name = "last_logged_in"; lastLoggedIn.Label = "Last Logged In"; lastLoggedIn.PlaceholderText = ""; lastLoggedIn.Description = ""; lastLoggedIn.HelpText = ""; lastLoggedIn.Required = false; lastLoggedIn.Unique = true; lastLoggedIn.Searchable = false; lastLoggedIn.Auditable = true; lastLoggedIn.System = true; lastLoggedIn.DefaultValue = null; lastLoggedIn.Format = "MM/dd/YYYY"; lastLoggedIn.UseCurrentTimeAsDefaultValue = true; fieldResponse = entityManager.CreateField(userEntity.Id.Value, lastLoggedIn, false); InputCheckboxField enabledField = new InputCheckboxField(); enabledField.Id = new Guid("C0C63650-7572-4252-8E4B-4E25C94897A6"); enabledField.Name = "enabled"; enabledField.Label = "Enabled"; enabledField.PlaceholderText = ""; enabledField.Description = "Shows if the user account is enabled"; enabledField.HelpText = ""; enabledField.Required = true; enabledField.Unique = false; enabledField.Searchable = false; enabledField.Auditable = false; enabledField.System = true; enabledField.DefaultValue = false; fieldResponse = entityManager.CreateField(userEntity.Id.Value, enabledField,false); InputCheckboxField verifiedUserField = new InputCheckboxField(); verifiedUserField.Id = new Guid("F1BA5069-8CC9-4E66-BCC3-60E33C79C265"); verifiedUserField.Name = "verified"; verifiedUserField.Label = "Verified"; verifiedUserField.PlaceholderText = ""; verifiedUserField.Description = "Shows if the user email is verified"; verifiedUserField.HelpText = ""; verifiedUserField.Required = true; verifiedUserField.Unique = false; verifiedUserField.Searchable = false; verifiedUserField.Auditable = false; verifiedUserField.System = true; verifiedUserField.DefaultValue = false; fieldResponse = entityManager.CreateField(userEntity.Id.Value, verifiedUserField, false); } #endregion #region << create user - role relation >> { var userEntity = em.ReadEntity(SystemIds.UserEntityId).Object; var roleEntity = em.ReadEntity(SystemIds.RoleEntityId).Object; EntityRelation userRoleRelation = new EntityRelation(); userRoleRelation.Id = SystemIds.UserRoleRelationId; ; userRoleRelation.Name = "user_role"; userRoleRelation.Label = "User-Role"; userRoleRelation.System = true; userRoleRelation.RelationType = EntityRelationType.ManyToMany; userRoleRelation.TargetEntityId = userEntity.Id; userRoleRelation.TargetFieldId = userEntity.Fields.Single(x => x.Name == "id").Id; userRoleRelation.OriginEntityId = roleEntity.Id; userRoleRelation.OriginFieldId = roleEntity.Fields.Single(x => x.Name == "id").Id; { var result = rm.Create(userRoleRelation); if (!result.Success) throw new Exception("CREATE USER-ROLE RELATION:" + result.Message); } } #endregion #region << create system records >> { EntityRecord user = new EntityRecord(); user["id"] = SystemIds.FirstUserId; user["first_name"] = "WebVella"; user["last_name"] = "Erp"; user["password"] = "******"; user["email"] = "*****@*****.**"; user["created_by"] = SystemIds.FirstUserId; user["last_modified_by"] = SystemIds.FirstUserId; user["created_on"] = DateTime.UtcNow; QueryResponse result = recMan.CreateRecord("user", user); if (!result.Success) throw new Exception("CREATE FIRST USER RECORD:" + result.Message); } { EntityRecord adminRole = new EntityRecord(); adminRole["id"] = SystemIds.AdministratorRoleId; adminRole["name"] = "Administrator"; adminRole["description"] = ""; adminRole["created_by"] = SystemIds.FirstUserId; adminRole["last_modified_by"] = SystemIds.FirstUserId; adminRole["created_on"] = DateTime.UtcNow; QueryResponse result = recMan.CreateRecord("role", adminRole); if (!result.Success) throw new Exception("CREATE ADMINITRATOR ROLE RECORD:" + result.Message); } { EntityRecord regularRole = new EntityRecord(); regularRole["id"] = SystemIds.RegularRoleId; regularRole["name"] = "Regular"; regularRole["description"] = ""; regularRole["created_by"] = SystemIds.FirstUserId; regularRole["last_modified_by"] = SystemIds.FirstUserId; regularRole["created_on"] = DateTime.UtcNow; QueryResponse result = recMan.CreateRecord("role", regularRole); if (!result.Success) throw new Exception("CREATE REGULAR ROLE RECORD:" + result.Message); } { EntityRecord guestRole = new EntityRecord(); guestRole["id"] = SystemIds.GuestRoleId; guestRole["name"] = "Guest"; guestRole["description"] = ""; guestRole["created_by"] = SystemIds.FirstUserId; guestRole["last_modified_by"] = SystemIds.FirstUserId; guestRole["created_on"] = DateTime.UtcNow; QueryResponse result = recMan.CreateRecord("role", guestRole); if (!result.Success) throw new Exception("CREATE GUEST ROLE RECORD:" + result.Message); } { QueryResponse result = recMan.CreateRelationManyToManyRecord(SystemIds.UserRoleRelationId, SystemIds.FirstUserId, SystemIds.AdministratorRoleId); if (!result.Success) throw new Exception("CREATE FIRST-USER <-> ADMINISTRATOR ROLE RELATION RECORD:" + result.Message); result = recMan.CreateRelationManyToManyRecord(SystemIds.UserRoleRelationId, SystemIds.FirstUserId, SystemIds.RegularRoleId); if (!result.Success) throw new Exception("CREATE FIRST-USER <-> REGULAR ROLE RELATION RECORD:" + result.Message); result = recMan.CreateRelationManyToManyRecord(SystemIds.UserRoleRelationId, SystemIds.FirstUserId, SystemIds.GuestRoleId); if (!result.Success) throw new Exception("CREATE FIRST-USER <-> GUEST ROLE RELATION RECORD:" + result.Message); } #endregion #region << create Area entity >> { InputEntity areaEntity = new InputEntity(); areaEntity.Id = SystemIds.AreaEntityId; areaEntity.Name = "area"; areaEntity.Label = "Area"; areaEntity.LabelPlural = "areas"; areaEntity.System = true; areaEntity.IconName = "folder"; areaEntity.Weight = 10; areaEntity.RecordPermissions = new RecordPermissions(); areaEntity.RecordPermissions.CanRead = allowedRoles; areaEntity.RecordPermissions.CanCreate = allowedRoles; areaEntity.RecordPermissions.CanUpdate = allowedRoles; areaEntity.RecordPermissions.CanDelete = allowedRoles; { var createResponse = entityManager.CreateEntity(areaEntity); if (!createResponse.Success) throw new Exception("System error 10330. Message:" + createResponse.Message); } InputTextField color = new InputTextField(); color.Id = new Guid("2B4AACD9-3C34-4C44-B3A3-8AFF1520CFF6"); color.Name = "color"; color.Label = "Color"; color.PlaceholderText = ""; color.Description = ""; color.HelpText = ""; color.Required = true; color.Unique = false; color.Searchable = false; color.Auditable = false; color.System = true; color.DefaultValue = "teal"; color.MaxLength = null; { var createResponse = entityManager.CreateField(SystemIds.AreaEntityId, color, false); if (!createResponse.Success) throw new Exception("System error 10340. Message:" + createResponse.Message); } InputTextField label = new InputTextField(); label.Id = new Guid("F050E7A1-AFB7-4346-B57B-1F12B2BD5AE5"); label.Name = "label"; label.Label = "Label"; label.PlaceholderText = ""; label.Description = ""; label.HelpText = ""; label.Required = true; label.Unique = false; label.Searchable = false; label.Auditable = false; label.System = true; label.DefaultValue = "Default"; label.MaxLength = null; { var createResponse = entityManager.CreateField(SystemIds.AreaEntityId, label, false); if (!createResponse.Success) throw new Exception("System error 10340. Message:" + createResponse.Message); } InputTextField iconName = new InputTextField(); iconName.Id = new Guid("5EA0C872-D219-4D94-9EFA-C5DA978D316B"); iconName.Name = "icon_name"; iconName.Label = "Icon Name"; iconName.PlaceholderText = ""; iconName.Description = ""; iconName.HelpText = ""; iconName.Required = true; iconName.Unique = false; iconName.Searchable = false; iconName.Auditable = false; iconName.System = true; iconName.DefaultValue = "database"; iconName.MaxLength = null; { var createResponse = entityManager.CreateField(SystemIds.AreaEntityId, iconName, false); if (!createResponse.Success) throw new Exception("System error 10340. Message:" + createResponse.Message); } InputNumberField weight = new InputNumberField(); weight.Id = new Guid("9B169431-6C31-4141-80EB-5844B8333E63"); weight.Name = "weight"; weight.Label = "Weight"; weight.PlaceholderText = ""; weight.Description = ""; weight.HelpText = ""; weight.Required = true; weight.Unique = false; weight.Searchable = false; weight.Auditable = false; weight.System = true; weight.DefaultValue = 10; weight.MinValue = 0; weight.DecimalPlaces = 2; { var createResponse = entityManager.CreateField(SystemIds.AreaEntityId, weight, false); if (!createResponse.Success) throw new Exception("System error 10340. Message:" + createResponse.Message); } InputTextField subscriptions = new InputTextField(); subscriptions.Id = new Guid("288EA657-C12C-4AC1-B701-81D6F9F39363"); subscriptions.Name = "subscriptions"; subscriptions.Label = "Subscriptions JSON String"; subscriptions.PlaceholderText = ""; subscriptions.Description = "Stringified Array of subscription objects"; subscriptions.HelpText = ""; subscriptions.Required = false; subscriptions.Unique = false; subscriptions.Searchable = false; subscriptions.Auditable = false; subscriptions.System = true; subscriptions.DefaultValue = null; subscriptions.MaxLength = null; { var createResponse = entityManager.CreateField(SystemIds.AreaEntityId, subscriptions, false); if (!createResponse.Success) throw new Exception("System error 10340. Message:" + createResponse.Message); } InputTextField name = new InputTextField(); name.Id = new Guid("F297577B-073E-4D18-81F3-675C1AFB466D"); name.Name = "name"; name.Label = "Name"; name.PlaceholderText = ""; name.Description = ""; name.HelpText = ""; name.Required = true; name.Unique = false; name.Searchable = false; name.Auditable = false; name.System = true; name.DefaultValue = "default"; name.MaxLength = null; { var createResponse = entityManager.CreateField(SystemIds.AreaEntityId, name, false); if (!createResponse.Success) throw new Exception("System error 10340. Message:" + createResponse.Message); } InputTextField roles = new InputTextField(); roles.Id = new Guid("8E486F76-D0C1-4D0E-8617-9EF868BF1C55"); roles.Name = "roles"; roles.Label = "Subscriptions JSON String"; roles.PlaceholderText = ""; roles.Description = "Stringified Array of roles that have access to this area"; roles.HelpText = ""; roles.Required = false; roles.Unique = false; roles.Searchable = false; roles.Auditable = false; roles.System = true; roles.DefaultValue = null; roles.MaxLength = null; { var createResponse = entityManager.CreateField(SystemIds.AreaEntityId, roles, false); if (!createResponse.Success) throw new Exception("System error 10340. Message:" + createResponse.Message); } } #endregion } storeSystemSettings = systemSettingsRepository.Convert(systemSettings); systemSettingsRepository.Save(storeSystemSettings); //if (currentVersion == 150508) //update to 150510 //{ // systemSettings.Version = 150510; // storeSystemSettings = systemSettingsRepository.Convert(systemSettings); // systemSettingsRepository.Save(storeSystemSettings); //} transaction.Commit(); } catch( Exception ) { transaction.Rollback(); throw; } }
public IActionResult GetEntityLibrary(string entityName) { var result = new EntityLibraryItemsResponse() { Success = true, Timestamp = DateTime.UtcNow }; var relMan = new EntityRelationManager(service.StorageService); if (string.IsNullOrWhiteSpace(entityName)) { result.Errors.Add(new ErrorModel { Message = "Invalid entity name." }); result.Success = false; return DoResponse(result); } var entity = entityManager.ReadEntity(entityName).Object; if (entity == null) { result.Errors.Add(new ErrorModel { Message = "Entity not found." }); result.Success = false; return DoResponse(result); } List<object> itemList = new List<object>(); itemList.Add(new { type = "html", tag = "", content = "" }); foreach (var field in entity.Fields) { itemList.Add(new RecordViewFieldItem { FieldId = field.Id, FieldName = field.Name, Meta = field, EntityId = entity.Id, EntityName = entity.Name, EntityLabel = entity.Label, EntityLabelPlural = entity.LabelPlural, DataName = field.Name }); } foreach (var view in entity.RecordViews) { itemList.Add(new RecordViewViewItem { ViewId = view.Id, ViewName = view.Name, Meta = view, EntityId = entity.Id, EntityName = entity.Name, EntityLabel = entity.Label, EntityLabelPlural = entity.LabelPlural, DataName = string.Format("view{0}", view.Name) }); } foreach (var list in entity.RecordLists) { itemList.Add(new RecordViewListItem { ListId = list.Id, ListName = list.Name, Meta = list, EntityId = entity.Id, EntityName = entity.Name, EntityLabel = entity.Label, EntityLabelPlural = entity.LabelPlural, DataName = string.Format("$list${0}", list.Name) }); } var relations = relMan.Read().Object; var entityRelations = relations.Where(x => x.OriginEntityId == entity.Id || x.TargetEntityId == entity.Id).ToList(); foreach (var relation in entityRelations) { Guid relatedEntityId = relation.OriginEntityId == entity.Id ? relation.TargetEntityId : relation.OriginEntityId; Entity relatedEntity = entityManager.ReadEntity(relatedEntityId).Object; //TODO validation if (relatedEntity == null) throw new Exception(string.Format("Invalid relation '{0}'. Related entity '{1}' do not exist.", relation.Name, relatedEntityId)); foreach (var field in relatedEntity.Fields) { itemList.Add(new RecordViewRelationFieldItem { RelationId = relation.Id, RelationName = relation.Name, EntityId = relatedEntity.Id, EntityName = relatedEntity.Name, EntityLabel = relatedEntity.Label, EntityLabelPlural = relatedEntity.LabelPlural, FieldId = field.Id, FieldName = field.Name, Meta = field, DataName = string.Format("$field${0}${1}", relation.Name, field.Name) }); } foreach (var view in relatedEntity.RecordViews) { itemList.Add(new RecordViewRelationViewItem { RelationId = relation.Id, RelationName = relation.Name, EntityId = relatedEntity.Id, EntityName = relatedEntity.Name, EntityLabel = relatedEntity.Label, EntityLabelPlural = relatedEntity.LabelPlural, ViewId = view.Id, ViewName = view.Name, Meta = view, DataName = string.Format("$view${0}${1}", relation.Name, view.Name) }); } foreach (var list in relatedEntity.RecordLists) { itemList.Add(new RecordViewRelationListItem { RelationId = relation.Id, RelationName = relation.Name, EntityId = relatedEntity.Id, EntityName = relatedEntity.Name, EntityLabel = relatedEntity.Label, EntityLabelPlural = relatedEntity.LabelPlural, ListId = list.Id, ListName = list.Name, Meta = list, DataName = string.Format("$list${0}${1}", relation.Name, list.Name) }); } } result.Object = itemList; return DoResponse(result); }
private List<EntityRecord> GetListRecords(List<Entity> entities, Entity entity, string listName, int? page = null, QueryObject queryObj = null, string filter = null) { var filterQuery = CreateFilterQuery(filter, entities); if (filterQuery != null) { if (queryObj != null) queryObj = EntityQuery.QueryAND(queryObj, filterQuery); else queryObj = filterQuery; } EntityQuery resultQuery = new EntityQuery(entity.Name, "*", queryObj, null, null, null); EntityRelationManager relManager = new EntityRelationManager(Storage); EntityRelationListResponse relListResponse = relManager.Read(); List<EntityRelation> relationList = new List<EntityRelation>(); if (relListResponse.Object != null) relationList = relListResponse.Object; RecordList list = null; if (entity != null && entity.RecordLists != null) list = entity.RecordLists.FirstOrDefault(l => l.Name == listName); if (list != null) { List<QuerySortObject> sortList = new List<QuerySortObject>(); if (list.Sorts != null && list.Sorts.Count > 0) { foreach (var sort in list.Sorts) { QuerySortType sortType; if (Enum.TryParse<QuerySortType>(sort.SortType, true, out sortType)) sortList.Add(new QuerySortObject(sort.FieldName, sortType)); } resultQuery.Sort = sortList.ToArray(); } if (list.Query != null) { if (queryObj != null) { List<QueryObject> subQueries = new List<QueryObject>(); subQueries.Add(RecordListQuery.ConvertQuery(list.Query)); queryObj.SubQueries = subQueries; } else queryObj = RecordListQuery.ConvertQuery(list.Query); resultQuery.Query = queryObj; } string queryFields = "id,"; if (list.Columns != null) { foreach (var column in list.Columns) { if (column is RecordListFieldItem) { if (((RecordListFieldItem)column).Meta.Name != "id") queryFields += ((RecordListFieldItem)column).Meta.Name + ", "; } else if (column is RecordListRelationFieldItem) { EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordListRelationFieldItem)column).RelationId); queryFields += string.Format("${0}.{1}, ", relation.Name, ((RecordListRelationFieldItem)column).Meta.Name); //add ID field automatically if not added if (!queryFields.Contains(string.Format("${0}.id", relation.Name))) queryFields += string.Format("${0}.id,", relation.Name); //always add origin field in query, its value may be required for relative view and list Guid fieldId = entity.Id == relation.OriginEntityId ? relation.OriginFieldId : relation.TargetFieldId; Field field = entity.Fields.FirstOrDefault(f => f.Id == fieldId); queryFields += field.Name + ", "; } else if (column is RecordListListItem || column is RecordListViewItem) { if (!queryFields.Contains(" id, ") && !queryFields.StartsWith("id,")) queryFields += "id, "; } else if (column is RecordListRelationListItem) { EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordListRelationListItem)column).RelationId); string relName = relation != null ? string.Format("${0}.", relation.Name) : ""; Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Guid relFieldId = entity.Id == relation.OriginEntityId ? relation.TargetFieldId : relation.OriginFieldId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); Field relField = relEntity.Fields.FirstOrDefault(f => f.Id == relFieldId); string queryFieldName = string.Format("{0}{1}, ", relName, relField.Name); if (!queryFields.Contains(queryFieldName)) queryFields += queryFieldName; //always add origin field in query, its value may be required for relative view and list Guid fieldId = entity.Id == relation.OriginEntityId ? relation.OriginFieldId : relation.TargetFieldId; Field field = entity.Fields.FirstOrDefault(f => f.Id == fieldId); queryFields += field.Name + ", "; } else if (column is RecordListRelationViewItem) { EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordListRelationViewItem)column).RelationId); string relName = relation != null ? string.Format("${0}.", relation.Name) : ""; Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Guid relFieldId = entity.Id == relation.OriginEntityId ? relation.TargetFieldId : relation.OriginFieldId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); Field relField = relEntity.Fields.FirstOrDefault(f => f.Id == relFieldId); string queryFieldName = string.Format("{0}{1}, ", relName, relField.Name); if (!queryFields.Contains(queryFieldName)) queryFields += queryFieldName; //always add origin field in query, its value may be required for relative view and list Guid fieldId = entity.Id == relation.OriginEntityId ? relation.OriginFieldId : relation.TargetFieldId; Field field = entity.Fields.FirstOrDefault(f => f.Id == fieldId); queryFields += field.Name + ", "; } } if (queryFields.EndsWith(", ")) queryFields = queryFields.Remove(queryFields.Length - 2); resultQuery.Fields = queryFields; } if (list.PageSize > 0) { resultQuery.Limit = list.PageSize; if (page != null && page > 0) resultQuery.Skip = (page - 1) * resultQuery.Limit; } } List<EntityRecord> resultDataList = new List<EntityRecord>(); QueryResponse result = recMan.Find(resultQuery); if (!result.Success) return resultDataList; if (list != null) { foreach (var record in result.Object.Data) { EntityRecord dataRecord = new EntityRecord(); //always add id value dataRecord["id"] = record["id"]; foreach (var column in list.Columns) { if (column is RecordListFieldItem) { dataRecord[column.DataName] = record[((RecordListFieldItem)column).FieldName]; } else if (column is RecordListRelationFieldItem) { string propName = string.Format("${0}", ((RecordListRelationFieldItem)column).RelationName); List<EntityRecord> relFieldRecords = (List<EntityRecord>)record[propName]; string idDataName = "$field" + propName + "$id"; if (!dataRecord.Properties.ContainsKey(idDataName)) { List<object> idFieldRecord = new List<object>(); if (relFieldRecords != null) { foreach (var relFieldRecord in relFieldRecords) idFieldRecord.Add(relFieldRecord["id"]); } dataRecord[idDataName] = idFieldRecord; } List<object> resultFieldRecord = new List<object>(); if (relFieldRecords != null) { foreach (var relFieldRecord in relFieldRecords) { resultFieldRecord.Add(relFieldRecord[((RecordListRelationFieldItem)column).FieldName]); } } dataRecord[column.DataName] = resultFieldRecord; } else if (column is RecordListListItem) { QueryObject subListQueryObj = new QueryObject(); subListQueryObj.QueryType = QueryType.AND; subListQueryObj.SubQueries = new List<QueryObject>(); subListQueryObj.SubQueries.Add(new QueryObject { FieldName = "id", FieldValue = record["id"], QueryType = QueryType.EQ }); List<EntityRecord> subListResult = GetListRecords(entities, entity, ((RecordListListItem)column).ListName, queryObj: subListQueryObj); dataRecord[column.DataName] = subListResult; } else if (column is RecordListRelationListItem) { EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordListRelationListItem)column).RelationId); string relName = string.Format("${0}", relation.Name); Guid fieldId = entity.Id == relation.OriginEntityId ? relation.OriginFieldId : relation.TargetFieldId; Field field = entity.Fields.FirstOrDefault(f => f.Id == fieldId); Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Guid relFieldId = entity.Id == relation.OriginEntityId ? relation.TargetFieldId : relation.OriginFieldId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); Field relField = relEntity.Fields.FirstOrDefault(f => f.Id == relFieldId); QueryObject subListQueryObj = EntityQuery.QueryEQ(relField.Name, record[field.Name]); List<EntityRecord> subListResult = GetListRecords(entities, relEntity, ((RecordListRelationListItem)column).ListName, queryObj: subListQueryObj); dataRecord[column.DataName] = subListResult; } else if (column is RecordListViewItem) { List<EntityRecord> subViewResult = GetViewRecords(entities, entity, ((RecordListViewItem)column).ViewName, "id", record["id"]); dataRecord[column.DataName] = subViewResult; } else if (column is RecordListRelationViewItem) { EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordListRelationViewItem)column).RelationId); string relName = string.Format("${0}", relation.Name); Guid fieldId = entity.Id == relation.OriginEntityId ? relation.OriginFieldId : relation.TargetFieldId; Field field = entity.Fields.FirstOrDefault(f => f.Id == fieldId); Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Guid relFieldId = entity.Id == relation.OriginEntityId ? relation.TargetFieldId : relation.OriginFieldId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); Field relField = relEntity.Fields.FirstOrDefault(f => f.Id == relFieldId); List<EntityRecord> subViewResult = GetViewRecords(entities, relEntity, ((RecordListRelationViewItem)column).ViewName, relField.Name, record[field.Name]); dataRecord[column.DataName] = subViewResult; } } resultDataList.Add(dataRecord); } } else { foreach (var record in result.Object.Data) { EntityRecord dataRecord = new EntityRecord(); foreach (var prop in record.Properties) { //string propName = "$field" + (prop.Key.StartsWith("$") ? prop.Key : "$" + prop.Key); string propName = prop.Key; dataRecord[propName] = record[prop.Key]; } resultDataList.Add(dataRecord); } } return resultDataList; }
private static void Patch160430(EntityManager entMan, EntityRelationManager relMan, RecordManager recMan, bool createSampleRecords = false) { #region << Create CRM admin area >> //The areas are the main object for navigation for the user. You can attach entities and URLs later to them { var area = new EntityRecord(); area["id"] = CRM_ADMIN_AREA_ID; area["name"] = "crm_admin"; area["label"] = "CRM Admin"; area["icon_name"] = "users"; area["color"] = "pink"; area["folder"] = "Admin"; area["weight"] = 100; var areaRoles = new List<Guid>(); areaRoles.Add(SystemIds.AdministratorRoleId); area["roles"] = JsonConvert.SerializeObject(areaRoles); var createAreaResult = recMan.CreateRecord("area", area); if (!createAreaResult.Success) { throw new Exception("System error 10060. Area create with name : project_admin. Message:" + createAreaResult.Message); } } #endregion #region << wv_customer >> { #region << entity >> { InputEntity entity = new InputEntity(); entity.Id = CUSTOMER_ENTITY_ID; entity.Name = CUSTOMER_ENTITY_NAME; entity.Label = "Customer"; entity.LabelPlural = "Customers"; entity.System = true; entity.IconName = "building-o"; entity.Weight = 2; entity.RecordPermissions = new RecordPermissions(); entity.RecordPermissions.CanCreate = new List<Guid>(); entity.RecordPermissions.CanRead = new List<Guid>(); entity.RecordPermissions.CanUpdate = new List<Guid>(); entity.RecordPermissions.CanDelete = new List<Guid>(); //Create entity.RecordPermissions.CanCreate.Add(SystemIds.AdministratorRoleId); entity.RecordPermissions.CanCreate.Add(SystemIds.RegularRoleId); //READ entity.RecordPermissions.CanRead.Add(SystemIds.AdministratorRoleId); entity.RecordPermissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE entity.RecordPermissions.CanUpdate.Add(SystemIds.AdministratorRoleId); entity.RecordPermissions.CanUpdate.Add(SystemIds.RegularRoleId); //System fields and relations Ids should be hardcoded for the compare/change code generation to work later on correctly var systemItemIdDictionary = new Dictionary<string, Guid>(); systemItemIdDictionary["id"] = new Guid("e8564a56-9917-4c45-a264-4c080f2d2b31"); systemItemIdDictionary["created_on"] = new Guid("1ca9c660-0042-47b3-91c7-e0f2b817633c"); systemItemIdDictionary["created_by"] = new Guid("12c29d6a-b5e5-4293-9e8a-91475d10dac9"); systemItemIdDictionary["last_modified_on"] = new Guid("b6a172aa-b50a-403f-a178-f923a0d7576f"); systemItemIdDictionary["last_modified_by"] = new Guid("6aab2af3-6909-4f8d-8c54-6a2403d6a25a"); systemItemIdDictionary["user_wv_customer_created_by"] = new Guid("2d2045f4-0553-4ffd-bd12-cbef17aea14a"); systemItemIdDictionary["user_wv_customer_modified_by"] = new Guid("2ba6c8c5-2550-4f26-8611-f397c529a61c"); { var response = entMan.CreateEntity(entity, false, false, systemItemIdDictionary); if (!response.Success) throw new Exception("System error 10050. Entity: " + CUSTOMER_ENTITY_NAME + " Field: entity creation" + " Message:" + response.Message); } } #endregion #region << name >> { InputTextField textboxField = new InputTextField(); textboxField.Id = new Guid("7fb95d0f-ab59-421d-974d-ab357e28a1f9"); textboxField.Name = "name"; textboxField.Label = "Name"; textboxField.PlaceholderText = ""; textboxField.Description = ""; textboxField.HelpText = ""; textboxField.Required = true; textboxField.Unique = false; textboxField.Searchable = true; textboxField.Auditable = false; textboxField.System = true; textboxField.DefaultValue = string.Empty; textboxField.MaxLength = null; textboxField.EnableSecurity = true; textboxField.Permissions = new FieldPermissions(); textboxField.Permissions.CanRead = new List<Guid>(); textboxField.Permissions.CanUpdate = new List<Guid>(); //READ textboxField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); textboxField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE textboxField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); { var response = entMan.CreateField(CUSTOMER_ENTITY_ID, textboxField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + CUSTOMER_ENTITY_NAME + " Field: name" + " Message:" + response.Message); } } #endregion } #endregion #region << View name: admin_details >> { var createViewEntity = entMan.ReadEntity(CUSTOMER_ENTITY_ID).Object; var createViewInput = new InputRecordView(); var viewRegion = new InputRecordViewRegion(); var viewSection = new InputRecordViewSection(); var viewRow = new InputRecordViewRow(); var viewColumn = new InputRecordViewColumn(); var viewItem = new InputRecordViewFieldItem(); #region << details >> createViewInput.Id = new Guid("3a0e1319-5357-49ec-9e85-8d9be2363fcf"); createViewInput.Type = "hidden"; createViewInput.Name = "admin_details"; createViewInput.Label = "Details"; createViewInput.Title = ""; createViewInput.Default = false; createViewInput.System = true; createViewInput.Weight = 15; createViewInput.CssClass = null; createViewInput.IconName = "building-o"; createViewInput.DynamicHtmlTemplate = null; createViewInput.DataSourceUrl = null; createViewInput.ServiceCode = null; createViewInput.Regions = new List<InputRecordViewRegion>(); #endregion #region << Header Region >> viewRegion = new InputRecordViewRegion(); viewRegion.Name = "header"; viewRegion.Label = "Header"; viewRegion.Render = true; viewRegion.Weight = 1; viewRegion.CssClass = ""; viewRegion.Sections = new List<InputRecordViewSection>(); #region << Section >> viewSection = new InputRecordViewSection(); viewSection.Id = new Guid("201882a6-c1f8-4f84-878d-fddfacdcb2d7"); viewSection.Name = "details"; viewSection.Label = "Details"; viewSection.ShowLabel = false; viewSection.CssClass = ""; viewSection.Collapsed = false; viewSection.TabOrder = "left-right"; viewSection.Weight = 1; viewSection.Rows = new List<InputRecordViewRow>(); #region << Row >> viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("ce09fdad-bb23-4f7f-b64b-190fec656711"); viewRow.Weight = 1; viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = 12; viewColumn.Items = new List<InputRecordViewItemBase>(); #region << name >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = CUSTOMER_ENTITY_ID; viewItem.EntityName = CUSTOMER_ENTITY_NAME; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "name").Id; viewItem.FieldName = "name"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); #endregion //Save row viewSection.Rows.Add(viewRow); #endregion //Save section viewRegion.Sections.Add(viewSection); #endregion //Save region createViewInput.Regions.Add(viewRegion); #endregion #region << relation options >> createViewInput.RelationOptions = new List<EntityRelationOptionsItem>(); #endregion #region << Sidebar >> createViewInput.Sidebar = new InputRecordViewSidebar(); createViewInput.Sidebar.CssClass = ""; createViewInput.Sidebar.Render = true; createViewInput.Sidebar.Render = true; createViewInput.Sidebar.Items = new List<InputRecordViewSidebarItemBase>(); #endregion #region << action items >> createViewInput.ActionItems = new List<ActionItem>(); var actionItem = new ActionItem(); { actionItem = new ActionItem(); actionItem.Name = "wv_record_delete"; actionItem.Menu = "page-title-dropdown"; actionItem.Weight = 1; actionItem.Template = "" + @"<a href=""javascript:void(0)"" confirmed-click=""ngCtrl.deleteRecord(ngCtrl)"" ng-confirm-click=""Are you sure?"" ng-if=""::ngCtrl.userHasRecordPermissions('canDelete')""> <i class=""fa fa-trash go-red""></i> Delete Record </a>"; createViewInput.ActionItems.Add(actionItem); } { actionItem = new ActionItem(); actionItem.Name = "wv_back_button"; actionItem.Menu = "sidebar-top"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""back clearfix"" href=""javascript:void(0)"" ng-click=""sidebarData.goBack()""><i class=""fa fa-fw fa-arrow-left""></i> <span class=""text"">Back</span></a>"; createViewInput.ActionItems.Add(actionItem); } #endregion { var response = entMan.CreateRecordView(CUSTOMER_ENTITY_ID, createViewInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + CUSTOMER_ENTITY_NAME + " Updated view: admin_details" + " Message:" + response.Message); } } #endregion #region << View name: admin_create >> { var createViewEntity = entMan.ReadEntity(CUSTOMER_ENTITY_ID).Object; var createViewInput = new InputRecordView(); var viewRegion = new InputRecordViewRegion(); var viewSection = new InputRecordViewSection(); var viewRow = new InputRecordViewRow(); var viewColumn = new InputRecordViewColumn(); var viewItem = new InputRecordViewFieldItem(); #region << details >> createViewInput.Id = new Guid("93043954-ae70-41a3-b4b7-665531a23a76"); createViewInput.Type = "create"; createViewInput.Name = "admin_create"; createViewInput.Label = "Create customer"; createViewInput.Title = ""; createViewInput.Default = false; createViewInput.System = true; createViewInput.Weight = 25; createViewInput.CssClass = null; createViewInput.IconName = "building-o"; createViewInput.DynamicHtmlTemplate = null; createViewInput.DataSourceUrl = null; createViewInput.ServiceCode = null; createViewInput.Regions = new List<InputRecordViewRegion>(); #endregion #region << Header Region >> viewRegion = new InputRecordViewRegion(); viewRegion.Name = "header"; viewRegion.Label = "Header"; viewRegion.Render = true; viewRegion.Weight = 1; viewRegion.CssClass = ""; viewRegion.Sections = new List<InputRecordViewSection>(); #region << Section >> viewSection = new InputRecordViewSection(); viewSection.Id = new Guid("8d82e33e-139a-4c80-99ac-3721138bdc65"); viewSection.Name = "details"; viewSection.Label = "Details"; viewSection.ShowLabel = false; viewSection.CssClass = ""; viewSection.Collapsed = false; viewSection.TabOrder = "left-right"; viewSection.Weight = 1; viewSection.Rows = new List<InputRecordViewRow>(); #region << Row >> viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("cdc2da04-f92a-47e1-9259-6526816fe84d"); viewRow.Weight = 1; viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = 12; viewColumn.Items = new List<InputRecordViewItemBase>(); #region << name >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = CUSTOMER_ENTITY_ID; viewItem.EntityName = CUSTOMER_ENTITY_NAME; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "name").Id; viewItem.FieldName = "name"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); #endregion //Save row viewSection.Rows.Add(viewRow); #endregion //Save section viewRegion.Sections.Add(viewSection); #endregion //Save region createViewInput.Regions.Add(viewRegion); #endregion #region << relation options >> createViewInput.RelationOptions = new List<EntityRelationOptionsItem>(); #endregion #region << Sidebar >> createViewInput.Sidebar = new InputRecordViewSidebar(); createViewInput.Sidebar.CssClass = ""; createViewInput.Sidebar.Render = true; createViewInput.Sidebar.Render = true; createViewInput.Sidebar.Items = new List<InputRecordViewSidebarItemBase>(); #endregion #region << action items >> createViewInput.ActionItems = new List<ActionItem>(); var actionItem = new ActionItem(); { actionItem = new ActionItem(); actionItem.Name = "wv_create_and_list"; actionItem.Menu = "create-bottom"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-primary"" ng-click='ngCtrl.create(""default"")' ng-if=""ngCtrl.createViewRegion != null"">Create</a>"; createViewInput.ActionItems.Add(actionItem); } { actionItem = new ActionItem(); actionItem.Name = "wv_create_and_details"; actionItem.Menu = "create-bottom"; actionItem.Weight = 2; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline"" ng-click='ngCtrl.create(""details"")' ng-if=""ngCtrl.createViewRegion != null"">Create & Details</a>"; createViewInput.ActionItems.Add(actionItem); } { actionItem = new ActionItem(); actionItem.Name = "wv_create_cancel"; actionItem.Menu = "create-bottom"; actionItem.Weight = 3; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline"" ng-click=""ngCtrl.cancel()"">Cancel</a>"; createViewInput.ActionItems.Add(actionItem); } { actionItem = new ActionItem(); actionItem.Name = "wv_back_button"; actionItem.Menu = "sidebar-top"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""back clearfix"" href=""javascript:void(0)"" ng-click=""sidebarData.goBack()""><i class=""fa fa-fw fa-arrow-left""></i> <span class=""text"">Back</span></a>"; createViewInput.ActionItems.Add(actionItem); } #endregion { var response = entMan.CreateRecordView(CUSTOMER_ENTITY_ID, createViewInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + CUSTOMER_ENTITY_NAME + " Updated view: admin_create" + " Message:" + response.Message); } } #endregion #region << List name: admin >> { var createListEntity = entMan.ReadEntity(CUSTOMER_ENTITY_ID).Object; var createListInput = new InputRecordList(); var listItem = new InputRecordListFieldItem(); var listSort = new InputRecordListSort(); var listQuery = new InputRecordListQuery(); #region << details >> createListInput.Id = new Guid("ff15f200-8e68-4683-8576-4c8244405ca9"); createListInput.Type = "hidden"; createListInput.Name = "admin"; createListInput.Label = "Customers"; createListInput.Weight = 11; createListInput.Default = false; createListInput.System = true; createListInput.CssClass = null; createListInput.IconName = "building-o"; createListInput.VisibleColumnsCount = 7; createListInput.ColumnWidthsCSV = null; createListInput.PageSize = 10; createListInput.DynamicHtmlTemplate = null; createListInput.DataSourceUrl = null; createListInput.ServiceCode = null; #endregion #region << action items >> createListInput.ActionItems = new List<ActionItem>(); var actionItem = new ActionItem(); { actionItem = new ActionItem(); actionItem.Name = "wv_record_details"; actionItem.Menu = "record-row"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline"" ng-href=""{{::ngCtrl.getRecordDetailsUrl(record, ngCtrl)}}""> <i class=""fa fa-fw fa-eye""></i> </a>"; createListInput.ActionItems.Add(actionItem); } { actionItem = new ActionItem(); actionItem.Name = "wv_create_record"; actionItem.Menu = "page-title"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline hidden-xs"" ng-show=""::ngCtrl.userHasRecordPermissions('canCreate')"" ng-href=""{{::ngCtrl.getRecordCreateUrl(ngCtrl)}}"">Add New</a>"; createListInput.ActionItems.Add(actionItem); } #endregion #region << Columns >> createListInput.Columns = new List<InputRecordListItemBase>(); #region << name >> { var fieldName = "name"; listItem = new InputRecordListFieldItem(); listItem.EntityId = CUSTOMER_ENTITY_ID; listItem.EntityName = CUSTOMER_ENTITY_NAME; listItem.FieldId = createListEntity.Fields.Single(x => x.Name == fieldName).Id; listItem.FieldName = fieldName; listItem.Type = "field"; createListInput.Columns.Add(listItem); } #endregion #endregion #region << relation options >> createListInput.RelationOptions = new List<EntityRelationOptionsItem>(); #endregion #region << query >> listQuery = new InputRecordListQuery(); #endregion #region << Sort >> listSort = new InputRecordListSort(); #endregion { var response = entMan.CreateRecordList(CUSTOMER_ENTITY_ID, createListInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + CUSTOMER_ENTITY_NAME + " Updated List: admin" + " Message:" + response.Message); } } #endregion #region << area add subscription: CRM Admin -> Customer >> { var updatedAreaId = CRM_ADMIN_AREA_ID; var updateAreaResult = Helpers.UpsertEntityAsAreaSubscription(entMan, recMan, updatedAreaId, CUSTOMER_ENTITY_NAME, "admin_details", "admin_create", "admin"); if (!updateAreaResult.Success) { throw new Exception("System error 10060. Area update with id : " + updatedAreaId + " Message:" + updateAreaResult.Message); } } #endregion #region << customer lookup list >> { var createListEntity = entMan.ReadEntity(CUSTOMER_ENTITY_ID).Object; var createListInput = new InputRecordList(); var listItem = new InputRecordListFieldItem(); var listSort = new InputRecordListSort(); var listQuery = new InputRecordListQuery(); //General list details createListInput.Id = new Guid("2287d4dc-0e9e-4c00-a1d4-cc2b8bf0f315"); createListInput.Name = "lookup"; createListInput.Label = "Lookup"; createListInput.Type = "lookup"; createListInput.Default = true; createListInput.VisibleColumnsCount = 5; createListInput.System = true; createListInput.Weight = 10; createListInput.CssClass = null; createListInput.IconName = "list"; createListInput.Columns = new List<InputRecordListItemBase>(); //Fields #region << name >> listItem = new InputRecordListFieldItem(); listItem.EntityId = CUSTOMER_ENTITY_ID; listItem.EntityName = "customer"; listItem.FieldId = createListEntity.Fields.Single(x => x.Name == "name").Id; listItem.FieldName = "name"; listItem.Type = "field"; createListInput.Columns.Add(listItem); #endregion //Query #region << query descr >> listQuery = new InputRecordListQuery(); #endregion //Sort #region << Sort >> createListInput.Sorts = new List<InputRecordListSort>(); listSort = new InputRecordListSort(); listSort.FieldName = "name"; listSort.SortType = "ascending"; createListInput.Sorts.Add(listSort); #endregion var newActionItemList = new List<ActionItem>(); { var actionItem = new ActionItem(); actionItem.Name = "wv_create_record"; actionItem.Menu = "page-title"; actionItem.Template = "<a class=\"btn btn-default btn-outline hidden-xs\" ng-show=\"::ngCtrl.userHasRecordPermissions('canCreate')\" \n ng-href=\"{{::ngCtrl.getRecordCreateUrl()}}\">Add New</a>"; actionItem.Weight = 1; newActionItemList.Add(actionItem); } { var actionItem = new ActionItem(); actionItem.Name = "wv_record_details"; actionItem.Menu = "record-row"; actionItem.Template = "<a class=\"btn btn-default btn-outline\" ng-href=\"{{::ngCtrl.getRecordDetailsUrl(record)}}\">\n <i class=\"fa fa-fw fa-eye\"></i>\n</a>"; actionItem.Weight = 1; newActionItemList.Add(actionItem); } createListInput.ActionItems = newActionItemList; { var responseObject = entMan.CreateRecordList(CUSTOMER_ENTITY_ID, createListInput); if (!responseObject.Success) throw new Exception("System error 10060. Entity: " + "user" + " Updated List: list_name" + " Message:" + responseObject.Message); } } #endregion if (createSampleRecords) { #region << Create Sample Customer >> { var sampleRecord = new EntityRecord(); sampleRecord["id"] = new Guid("fb06213f-7632-495b-bb8d-ed5ff07dc515"); sampleRecord["name"] = "Buckley Miller & Wright"; var createSampleRecordResult = recMan.CreateRecord(CUSTOMER_ENTITY_NAME, sampleRecord); if (!createSampleRecordResult.Success) { throw new Exception("System error 10060. Create sample record. Message:" + createSampleRecordResult.Message); } } #endregion #region << Create Sample Customer User >> { var sampleRecord = new EntityRecord(); sampleRecord["id"] = new Guid("307fe376-a1c6-495e-a7c0-2a78797565f2"); sampleRecord["first_name"] = "Sample"; sampleRecord["last_name"] = "Customer"; sampleRecord["username"] = "******"; sampleRecord["email"] = "*****@*****.**"; sampleRecord["password"] = "******"; sampleRecord["enabled"] = true; sampleRecord["verified"] = true; sampleRecord["image"] = "/plugins/webvella-core/assets/avatar-deep-purple.png"; var createSampleRecordResult = recMan.CreateRecord(SystemIds.UserEntityId, sampleRecord); if (!createSampleRecordResult.Success) { throw new Exception("System error 10060. Create sample customer record. Message:" + createSampleRecordResult.Message); } } #endregion #region << Create Sample User Role>> { var sampleRecord = new EntityRecord(); sampleRecord["id"] = new Guid("27745245-09bd-4adb-8831-3870bcae46fe"); sampleRecord["name"] = "crm_customer"; sampleRecord["description"] = "Sample Customer role for CRM application"; var createSampleRecordResult = recMan.CreateRecord(SystemIds.RoleEntityId, sampleRecord); if (!createSampleRecordResult.Success) { throw new Exception("System error 10060. Create sample role record. Message:" + createSampleRecordResult.Message); } } #endregion #region << Create relation between sample customer and role >> { var createRelationNtoNResponse = recMan.CreateRelationManyToManyRecord(new Guid("0c4b119e-1d7b-4b40-8d2c-9e447cc656ab"), new Guid("27745245-09bd-4adb-8831-3870bcae46fe"), new Guid("307fe376-a1c6-495e-a7c0-2a78797565f2")); if (!createRelationNtoNResponse.Success) { throw new Exception("Could not create item image relation" + createRelationNtoNResponse.Message); } } #endregion #region << Create relation between sample customer and regular role >> { var createRelationNtoNResponse = recMan.CreateRelationManyToManyRecord(new Guid("0c4b119e-1d7b-4b40-8d2c-9e447cc656ab"), new Guid("f16ec6db-626d-4c27-8de0-3e7ce542c55f"), new Guid("307fe376-a1c6-495e-a7c0-2a78797565f2")); if (!createRelationNtoNResponse.Success) { throw new Exception("Could not create item image relation" + createRelationNtoNResponse.Message); } } #endregion } }
private static void Patch160613(EntityManager entMan, EntityRelationManager relMan, RecordManager recMan, bool createSampleRecords = false) { #region << Update Enity: wv_project_comment name: task_comments >> { var createListEntity = entMan.ReadEntity(new Guid("7a57d17e-98f0-4356-baf0-9a8798da0b99")).Object; var createListInput = new InputRecordList(); #region << details >> createListInput.Id = createListEntity.RecordLists.SingleOrDefault(x => x.Name == "task_comments").Id; createListInput.Type = "Hidden"; createListInput.Name = "task_comments"; createListInput.Label = "Comments"; createListInput.Title = ""; createListInput.Weight = Decimal.Parse("10.0"); createListInput.Default = false; createListInput.System = true; createListInput.CssClass = null; createListInput.IconName = "comments-o"; createListInput.VisibleColumnsCount = Int32.Parse("5"); createListInput.ColumnWidthsCSV = null; createListInput.PageSize = Int32.Parse("0"); createListInput.DynamicHtmlTemplate = "/plugins/webvella-projects/templates/task-comments.html"; createListInput.DataSourceUrl = null; createListInput.ServiceCode = ""; #endregion #region << Relation options >> { createListInput.RelationOptions = new List<EntityRelationOptionsItem>(); } #endregion #region << Action items >> { createListInput.ActionItems = new List<ActionItem>(); } #endregion #region << Columns >> { createListInput.Columns = new List<InputRecordListItemBase>(); #region << created_on >> { var listField = new InputRecordListFieldItem(); listField.EntityId = new Guid("7a57d17e-98f0-4356-baf0-9a8798da0b99"); listField.EntityName = "wv_project_comment"; listField.FieldId = new Guid("c205c60f-598a-4db7-bd41-a7fd2ae3abd0"); listField.FieldName = "created_on"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << field from Relation: username >> { var listItemFromRelation = new InputRecordListRelationFieldItem(); listItemFromRelation.EntityId = new Guid("b9cebc3b-6443-452a-8e34-b311a73dcc8b"); listItemFromRelation.EntityName = "user"; listItemFromRelation.Type = "fieldFromRelation"; listItemFromRelation.FieldId = new Guid("263c0b21-88c1-4c2b-80b4-db7402b0d2e2"); listItemFromRelation.FieldName = "username"; listItemFromRelation.FieldLabel = null; listItemFromRelation.FieldPlaceholder = null; listItemFromRelation.FieldHelpText = null; listItemFromRelation.FieldRequired = false; listItemFromRelation.FieldLookupList = null; listItemFromRelation.RelationId = new Guid("2f3635a3-298e-475e-90f4-7d512da6cf95"); listItemFromRelation.RelationName = "user_wv_project_comment_created_by"; createListInput.Columns.Add(listItemFromRelation); } #endregion #region << content >> { var listField = new InputRecordListFieldItem(); listField.EntityId = new Guid("7a57d17e-98f0-4356-baf0-9a8798da0b99"); listField.EntityName = "wv_project_comment"; listField.FieldId = new Guid("23afb07b-438f-4e31-9372-c850a5789cc6"); listField.FieldName = "content"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << field from Relation: image >> { var listItemFromRelation = new InputRecordListRelationFieldItem(); listItemFromRelation.EntityId = new Guid("b9cebc3b-6443-452a-8e34-b311a73dcc8b"); listItemFromRelation.EntityName = "user"; listItemFromRelation.Type = "fieldFromRelation"; listItemFromRelation.FieldId = new Guid("bf199b74-4448-4f58-93f5-6b86d888843b"); listItemFromRelation.FieldName = "image"; listItemFromRelation.FieldLabel = null; listItemFromRelation.FieldPlaceholder = null; listItemFromRelation.FieldHelpText = null; listItemFromRelation.FieldRequired = false; listItemFromRelation.FieldLookupList = null; listItemFromRelation.RelationId = new Guid("2f3635a3-298e-475e-90f4-7d512da6cf95"); listItemFromRelation.RelationName = "user_wv_project_comment_created_by"; createListInput.Columns.Add(listItemFromRelation); } #endregion #region << created_by >> { var listField = new InputRecordListFieldItem(); listField.EntityId = new Guid("7a57d17e-98f0-4356-baf0-9a8798da0b99"); listField.EntityName = "wv_project_comment"; listField.FieldId = new Guid("46208807-7bc8-4f54-8618-45134189e763"); listField.FieldName = "created_by"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion } #endregion #region << Query >> { createListInput.Query = null; } #endregion #region << Sorts >> { createListInput.Sorts = new List<InputRecordListSort>(); #region << sort >> { var sort = new InputRecordListSort(); sort.FieldName = "created_on"; sort.SortType = "Ascending"; createListInput.Sorts.Add(sort); } #endregion } #endregion { var response = entMan.UpdateRecordList(new Guid("7a57d17e-98f0-4356-baf0-9a8798da0b99"), createListInput); if (!response.Success) throw new Exception("System error 10060. Entity: wv_project_comment Updated list: task_comments Message:" + response.Message); } } #endregion #region << Update Enity: wv_bug View: general >> { var updateViewEntity = entMan.ReadEntity(new Guid("c11655fa-e4a3-4c2b-8f1e-0a6d87cfd20c")).Object; var createViewInput = new InputRecordView(); #region << details >> createViewInput.Id = updateViewEntity.RecordViews.SingleOrDefault(x => x.Name == "general").Id; createViewInput.Type = "General"; createViewInput.Name = "general"; createViewInput.Label = "[{code}] {subject}"; createViewInput.Title = ""; createViewInput.Default = true; createViewInput.System = false; createViewInput.Weight = Decimal.Parse("10.0"); createViewInput.CssClass = ""; createViewInput.IconName = "bug"; createViewInput.DynamicHtmlTemplate = null; createViewInput.DataSourceUrl = null; createViewInput.ServiceCode = ""; #endregion #region << regions >> createViewInput.Regions = new List<InputRecordViewRegion>(); #region << Region: header >> { var viewRegion = new InputRecordViewRegion(); viewRegion.Name = "header"; viewRegion.Label = "Header"; viewRegion.Render = true; viewRegion.Weight = Decimal.Parse("10.0"); viewRegion.CssClass = ""; viewRegion.Sections = new List<InputRecordViewSection>(); #region << Section: details >> { var viewSection = new InputRecordViewSection(); viewSection.Id = new Guid("b3679dee-d30d-46d7-b5ac-300ed8f1e922"); viewSection.Name = "details"; viewSection.Label = "Details"; viewSection.ShowLabel = false; viewSection.CssClass = ""; viewSection.Collapsed = false; viewSection.TabOrder = "left-right"; viewSection.Weight = Decimal.Parse("1.0"); viewSection.Rows = new List<InputRecordViewRow>(); #region << Row 1>> { var viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("f9099d26-96ad-4fe2-9c81-db7a8f5daa47"); viewRow.Weight = Decimal.Parse("1.0"); viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> { var viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = Int32.Parse("8"); viewColumn.Items = new List<InputRecordViewItemBase>(); #region << subject >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("c11655fa-e4a3-4c2b-8f1e-0a6d87cfd20c"); viewItem.EntityName = "wv_bug"; viewItem.FieldId = new Guid("335a4500-130e-4739-b774-2f53f33ea22a"); viewItem.FieldName = "subject"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << description >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("c11655fa-e4a3-4c2b-8f1e-0a6d87cfd20c"); viewItem.EntityName = "wv_bug"; viewItem.FieldId = new Guid("4afe9621-39ee-40b9-a3ef-cb9b98131a6a"); viewItem.FieldName = "description"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << List from relation: bug_comments >> { var viewItemFromRelation = new InputRecordViewRelationListItem(); viewItemFromRelation.EntityId = new Guid("7a57d17e-98f0-4356-baf0-9a8798da0b99"); viewItemFromRelation.EntityName = "wv_project_comment"; viewItemFromRelation.ListId = new Guid("b143b82f-b79f-47c1-87e7-ecba6f6f2a32"); viewItemFromRelation.ListName = "bug_comments"; viewItemFromRelation.FieldLabel = "Comments"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldHelpText = ""; viewItemFromRelation.FieldRequired = false; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = new Guid("5af026bd-d046-42ba-b6a0-e9090727348f"); viewItemFromRelation.RelationName = "bug_1_n_comment"; viewItemFromRelation.Type = "listFromRelation"; viewColumn.Items.Add(viewItemFromRelation); } #endregion //Save column viewRow.Columns.Add(viewColumn); } #endregion #region << Column 2 >> { var viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = Int32.Parse("4"); viewColumn.Items = new List<InputRecordViewItemBase>(); #region << status >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("c11655fa-e4a3-4c2b-8f1e-0a6d87cfd20c"); viewItem.EntityName = "wv_bug"; viewItem.FieldId = new Guid("48be1e6e-df47-46f0-b4e1-6e9e1cbaf71c"); viewItem.FieldName = "status"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << priority >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("c11655fa-e4a3-4c2b-8f1e-0a6d87cfd20c"); viewItem.EntityName = "wv_bug"; viewItem.FieldId = new Guid("e506dfc7-6d49-4d00-9f61-8befd56c1a6e"); viewItem.FieldName = "priority"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << field from Relation: name >> { var viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = new Guid("7821ece9-42ce-470b-84d4-afc9eb35aa32"); viewItemFromRelation.EntityName = "wv_project"; viewItemFromRelation.Type = "fieldFromRelation"; viewItemFromRelation.FieldId = new Guid("d13427b7-e518-4305-b2cc-bc814a299b55"); viewItemFromRelation.FieldName = "name"; viewItemFromRelation.FieldLabel = "Project"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldHelpText = null; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = new Guid("d94f100c-024c-47e7-af32-d67a49be2b6c"); viewItemFromRelation.RelationName = "project_1_n_bug"; viewColumn.Items.Add(viewItemFromRelation); } #endregion #region << field from Relation: username >> { var viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = new Guid("b9cebc3b-6443-452a-8e34-b311a73dcc8b"); viewItemFromRelation.EntityName = "user"; viewItemFromRelation.Type = "fieldFromRelation"; viewItemFromRelation.FieldId = new Guid("263c0b21-88c1-4c2b-80b4-db7402b0d2e2"); viewItemFromRelation.FieldName = "username"; viewItemFromRelation.FieldLabel = "Owner"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldHelpText = null; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = new Guid("cddc10b6-30ff-4a86-96e4-645b3ea59fd9"); viewItemFromRelation.RelationName = "user_1_n_bug_owner"; viewColumn.Items.Add(viewItemFromRelation); } #endregion #region << field from Relation: username >> { var viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = new Guid("b9cebc3b-6443-452a-8e34-b311a73dcc8b"); viewItemFromRelation.EntityName = "user"; viewItemFromRelation.Type = "fieldFromRelation"; viewItemFromRelation.FieldId = new Guid("263c0b21-88c1-4c2b-80b4-db7402b0d2e2"); viewItemFromRelation.FieldName = "username"; viewItemFromRelation.FieldLabel = "Watchers"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldHelpText = null; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = new Guid("b71d0c52-1626-48da-91bc-e10999ba79b8"); viewItemFromRelation.RelationName = "user_n_n_bug_watchers"; viewColumn.Items.Add(viewItemFromRelation); } #endregion //Save column viewRow.Columns.Add(viewColumn); } #endregion //Save row viewSection.Rows.Add(viewRow); } #endregion //Save section viewRegion.Sections.Add(viewSection); } #endregion //Save region createViewInput.Regions.Add(viewRegion); } #endregion #endregion #region << Relation options >> { createViewInput.RelationOptions = new List<EntityRelationOptionsItem>(); } #endregion #region << Action items >> { createViewInput.ActionItems = new List<ActionItem>(); #region << action item: wv_record_delete >> { var actionItem = new ActionItem(); actionItem.Name = "wv_record_delete"; actionItem.Menu = "page-title-dropdown"; actionItem.Weight = Decimal.Parse("1.0"); actionItem.Template = @"<a href=""javascript:void(0)"" confirmed-click=""::ngCtrl.deleteRecord(ngCtrl)"" ng-confirm-click=""Are you sure?"" ng-if=""::ngCtrl.userHasRecordPermissions('canDelete')""> <i class=""fa fa-trash go-red""></i> Delete Record </a>"; createViewInput.ActionItems.Add(actionItem); } #endregion #region << action item: wv_back_button >> { var actionItem = new ActionItem(); actionItem.Name = "wv_back_button"; actionItem.Menu = "sidebar-top"; actionItem.Weight = Decimal.Parse("1.0"); actionItem.Template = @"<a class=""back clearfix"" href=""javascript:void(0)"" ng-click=""sidebarData.goBack()""><i class=""fa fa-fw fa-arrow-left""></i> <span class=""text"">Back</span></a>"; createViewInput.ActionItems.Add(actionItem); } #endregion } #endregion #region << Sidebar >> createViewInput.Sidebar = new InputRecordViewSidebar(); createViewInput.Sidebar.CssClass = ""; createViewInput.Sidebar.Render = false; createViewInput.Sidebar.Items = new List<InputRecordViewSidebarItemBase>(); #region << list from relation: bug_attachments >> { var viewItemFromRelation = new InputRecordViewSidebarRelationListItem(); viewItemFromRelation.EntityId = new Guid("c11655fa-e4a3-4c2b-8f1e-0a6d87cfd20c"); viewItemFromRelation.EntityName = "wv_bug"; viewItemFromRelation.ListId = new Guid("2b83e4e3-6878-4b5b-9391-6e59429c0b5e"); viewItemFromRelation.ListName = "bug_attachments"; viewItemFromRelation.FieldLabel = "Attachments"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldHelpText = ""; viewItemFromRelation.FieldRequired = false; viewItemFromRelation.FieldManageView = "general"; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = new Guid("a4f60f87-66a9-4541-a2ef-29e00f2b418b"); viewItemFromRelation.RelationName = "bug_1_n_attachment"; viewItemFromRelation.Type = "listFromRelation"; createViewInput.Sidebar.Items.Add(viewItemFromRelation); } #endregion #region << list from relation: bug_timelogs >> { var viewItemFromRelation = new InputRecordViewSidebarRelationListItem(); viewItemFromRelation.EntityId = new Guid("c11655fa-e4a3-4c2b-8f1e-0a6d87cfd20c"); viewItemFromRelation.EntityName = "wv_bug"; viewItemFromRelation.ListId = new Guid("f9a12626-08db-4fd2-a443-b521162be2b5"); viewItemFromRelation.ListName = "bug_timelogs"; viewItemFromRelation.FieldLabel = "Time logs"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldHelpText = ""; viewItemFromRelation.FieldRequired = false; viewItemFromRelation.FieldManageView = "general"; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = new Guid("97909e49-50d4-4534-aa7b-61c523b55d87"); viewItemFromRelation.RelationName = "bug_1_n_time_log"; viewItemFromRelation.Type = "listFromRelation"; createViewInput.Sidebar.Items.Add(viewItemFromRelation); } #endregion #region << list from relation: bug_activities >> { var viewItemFromRelation = new InputRecordViewSidebarRelationListItem(); viewItemFromRelation.EntityId = new Guid("c11655fa-e4a3-4c2b-8f1e-0a6d87cfd20c"); viewItemFromRelation.EntityName = "wv_bug"; viewItemFromRelation.ListId = new Guid("57c3062c-df6e-488a-a432-dd927b0dd013"); viewItemFromRelation.ListName = "bug_activities"; viewItemFromRelation.FieldLabel = "Activities"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldHelpText = ""; viewItemFromRelation.FieldRequired = false; viewItemFromRelation.FieldManageView = "general"; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = new Guid("b96189f7-a880-4da4-b9a9-2274a9745d2d"); viewItemFromRelation.RelationName = "bug_1_n_activity"; viewItemFromRelation.Type = "listFromRelation"; createViewInput.Sidebar.Items.Add(viewItemFromRelation); } #endregion #endregion { var response = entMan.UpdateRecordView(new Guid("c11655fa-e4a3-4c2b-8f1e-0a6d87cfd20c"), createViewInput); if (!response.Success) throw new Exception("System error 10060. Entity: wv_bug Updated view: general Message:" + response.Message); } } #endregion #region << Create Enity: wv_task field: estimation >> { InputNumberField numberField = new InputNumberField(); numberField.Id = new Guid("848e2a24-8d58-451b-9cf8-9ba1254a169a"); numberField.Name = "estimation"; numberField.Label = "Estimation"; numberField.PlaceholderText = ""; numberField.Description = ""; numberField.HelpText = ""; numberField.Required = true; numberField.Unique = false; numberField.Searchable = false; numberField.Auditable = false; numberField.System = false; numberField.DefaultValue = Decimal.Parse("0.0"); numberField.MinValue = null; numberField.MaxValue = null; numberField.DecimalPlaces = byte.Parse("2"); numberField.EnableSecurity = false; numberField.Permissions = new FieldPermissions(); numberField.Permissions.CanRead = new List<Guid>(); numberField.Permissions.CanUpdate = new List<Guid>(); //READ //UPDATE { var response = entMan.CreateField(new Guid("65acced0-1650-4ff0-bbff-9937c382cd89"), numberField, false); if (!response.Success) throw new Exception("System error 10060. Entity: wv_task Field: estimation Message:" + response.Message); } } #endregion #region << Update Enity: wv_task View: create >> { var updateViewEntity = entMan.ReadEntity(new Guid("65acced0-1650-4ff0-bbff-9937c382cd89")).Object; var createViewInput = new InputRecordView(); #region << details >> createViewInput.Id = updateViewEntity.RecordViews.SingleOrDefault(x => x.Name == "create").Id; createViewInput.Type = "Create"; createViewInput.Name = "create"; createViewInput.Label = "Create"; createViewInput.Title = ""; createViewInput.Default = true; createViewInput.System = false; createViewInput.Weight = Decimal.Parse("10.0"); createViewInput.CssClass = ""; createViewInput.IconName = "file-text-o"; createViewInput.DynamicHtmlTemplate = null; createViewInput.DataSourceUrl = null; createViewInput.ServiceCode = null; #endregion #region << regions >> createViewInput.Regions = new List<InputRecordViewRegion>(); #region << Region: header >> { var viewRegion = new InputRecordViewRegion(); viewRegion.Name = "header"; viewRegion.Label = "Header"; viewRegion.Render = true; viewRegion.Weight = Decimal.Parse("10.0"); viewRegion.CssClass = ""; viewRegion.Sections = new List<InputRecordViewSection>(); #region << Section: details >> { var viewSection = new InputRecordViewSection(); viewSection.Id = new Guid("8b628f5d-16b3-49d0-a433-a910ea208b39"); viewSection.Name = "details"; viewSection.Label = "Details"; viewSection.ShowLabel = false; viewSection.CssClass = ""; viewSection.Collapsed = false; viewSection.TabOrder = "left-right"; viewSection.Weight = Decimal.Parse("1.0"); viewSection.Rows = new List<InputRecordViewRow>(); #region << Row 1>> { var viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("818f516c-f6c2-4073-8574-75c13a72aee4"); viewRow.Weight = Decimal.Parse("1.0"); viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> { var viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = Int32.Parse("12"); viewColumn.Items = new List<InputRecordViewItemBase>(); #region << subject >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("65acced0-1650-4ff0-bbff-9937c382cd89"); viewItem.EntityName = "wv_task"; viewItem.FieldId = new Guid("7843bfbd-30c1-4438-af48-ffe56b7f294a"); viewItem.FieldName = "subject"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << field from Relation: name >> { var viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = new Guid("7821ece9-42ce-470b-84d4-afc9eb35aa32"); viewItemFromRelation.EntityName = "wv_project"; viewItemFromRelation.Type = "fieldFromRelation"; viewItemFromRelation.FieldId = new Guid("d13427b7-e518-4305-b2cc-bc814a299b55"); viewItemFromRelation.FieldName = "name"; viewItemFromRelation.FieldLabel = "Project"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldHelpText = null; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = new Guid("1f860b8c-7fa1-40fa-874f-19c2b5309817"); viewItemFromRelation.RelationName = "project_1_n_task"; viewColumn.Items.Add(viewItemFromRelation); } #endregion #region << description >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("65acced0-1650-4ff0-bbff-9937c382cd89"); viewItem.EntityName = "wv_task"; viewItem.FieldId = new Guid("a00eb247-918a-46ba-9869-8d1168ea8f45"); viewItem.FieldName = "description"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); } #endregion //Save row viewSection.Rows.Add(viewRow); } #endregion #region << Row 2>> { var viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("2144c60b-4974-44e2-86ef-5ceec72d04f8"); viewRow.Weight = Decimal.Parse("2.0"); viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> { var viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = Int32.Parse("6"); viewColumn.Items = new List<InputRecordViewItemBase>(); #region << status >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("65acced0-1650-4ff0-bbff-9937c382cd89"); viewItem.EntityName = "wv_task"; viewItem.FieldId = new Guid("0702e611-6fe5-42e4-9bad-d549cba9cbb1"); viewItem.FieldName = "status"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << estimation >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("65acced0-1650-4ff0-bbff-9937c382cd89"); viewItem.EntityName = "wv_task"; viewItem.FieldId = new Guid("848e2a24-8d58-451b-9cf8-9ba1254a169a"); viewItem.FieldName = "estimation"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); } #endregion #region << Column 2 >> { var viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = Int32.Parse("6"); viewColumn.Items = new List<InputRecordViewItemBase>(); #region << priority >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("65acced0-1650-4ff0-bbff-9937c382cd89"); viewItem.EntityName = "wv_task"; viewItem.FieldId = new Guid("04ede478-99ec-4f7f-97af-0df3e89409b1"); viewItem.FieldName = "priority"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << start_date >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("65acced0-1650-4ff0-bbff-9937c382cd89"); viewItem.EntityName = "wv_task"; viewItem.FieldId = new Guid("5bf852bf-5e6c-4791-bc8b-f1366440c04b"); viewItem.FieldName = "start_date"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << end_date >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("65acced0-1650-4ff0-bbff-9937c382cd89"); viewItem.EntityName = "wv_task"; viewItem.FieldId = new Guid("c6dc9db2-0081-4a91-b0e2-78f9c1c45a51"); viewItem.FieldName = "end_date"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); } #endregion //Save row viewSection.Rows.Add(viewRow); } #endregion //Save section viewRegion.Sections.Add(viewSection); } #endregion //Save region createViewInput.Regions.Add(viewRegion); } #endregion #endregion #region << Relation options >> { createViewInput.RelationOptions = new List<EntityRelationOptionsItem>(); } #endregion #region << Action items >> { createViewInput.ActionItems = new List<ActionItem>(); #region << action item: wv_back_button >> { var actionItem = new ActionItem(); actionItem.Name = "wv_back_button"; actionItem.Menu = "sidebar-top"; actionItem.Weight = Decimal.Parse("1.0"); actionItem.Template = @"<a class=""back clearfix"" href=""javascript:void(0)"" ng-click=""sidebarData.goBack()""><i class=""fa fa-fw fa-arrow-left""></i> <span class=""text"">Back</span></a>"; createViewInput.ActionItems.Add(actionItem); } #endregion #region << action item: wv_create_and_list >> { var actionItem = new ActionItem(); actionItem.Name = "wv_create_and_list"; actionItem.Menu = "create-bottom"; actionItem.Weight = Decimal.Parse("1.0"); actionItem.Template = @"<a class=""btn btn-primary"" ng-click='ngCtrl.create(""default"")' ng-if=""::ngCtrl.createViewRegion != null"">Create</a>"; createViewInput.ActionItems.Add(actionItem); } #endregion #region << action item: wv_create_and_details >> { var actionItem = new ActionItem(); actionItem.Name = "wv_create_and_details"; actionItem.Menu = "create-bottom"; actionItem.Weight = Decimal.Parse("2.0"); actionItem.Template = @"<a class=""btn btn-default btn-outline"" ng-click='ngCtrl.create(""details"")' ng-if=""::ngCtrl.createViewRegion != null"">Create & Details</a>"; createViewInput.ActionItems.Add(actionItem); } #endregion #region << action item: wv_create_cancel >> { var actionItem = new ActionItem(); actionItem.Name = "wv_create_cancel"; actionItem.Menu = "create-bottom"; actionItem.Weight = Decimal.Parse("3.0"); actionItem.Template = @"<a class=""btn btn-default btn-outline"" ng-click=""ngCtrl.cancel()"">Cancel</a>"; createViewInput.ActionItems.Add(actionItem); } #endregion } #endregion #region << Sidebar >> createViewInput.Sidebar = new InputRecordViewSidebar(); createViewInput.Sidebar.CssClass = ""; createViewInput.Sidebar.Render = false; createViewInput.Sidebar.Items = new List<InputRecordViewSidebarItemBase>(); #endregion { var response = entMan.UpdateRecordView(new Guid("65acced0-1650-4ff0-bbff-9937c382cd89"), createViewInput); if (!response.Success) throw new Exception("System error 10060. Entity: wv_task Updated view: create Message:" + response.Message); } } #endregion #region << Update Enity: wv_task View: general >> { var updateViewEntity = entMan.ReadEntity(new Guid("65acced0-1650-4ff0-bbff-9937c382cd89")).Object; var createViewInput = new InputRecordView(); #region << details >> createViewInput.Id = updateViewEntity.RecordViews.SingleOrDefault(x => x.Name == "general").Id; createViewInput.Type = "General"; createViewInput.Name = "general"; createViewInput.Label = "[{code}] {subject}"; createViewInput.Title = ""; createViewInput.Default = true; createViewInput.System = false; createViewInput.Weight = Decimal.Parse("10.0"); createViewInput.CssClass = ""; createViewInput.IconName = "tasks"; createViewInput.DynamicHtmlTemplate = null; createViewInput.DataSourceUrl = null; createViewInput.ServiceCode = ""; #endregion #region << regions >> createViewInput.Regions = new List<InputRecordViewRegion>(); #region << Region: header >> { var viewRegion = new InputRecordViewRegion(); viewRegion.Name = "header"; viewRegion.Label = "Header"; viewRegion.Render = true; viewRegion.Weight = Decimal.Parse("10.0"); viewRegion.CssClass = ""; viewRegion.Sections = new List<InputRecordViewSection>(); #region << Section: details >> { var viewSection = new InputRecordViewSection(); viewSection.Id = new Guid("0289b876-b6be-4d5f-915b-22dc0428bc25"); viewSection.Name = "details"; viewSection.Label = "Details"; viewSection.ShowLabel = false; viewSection.CssClass = ""; viewSection.Collapsed = false; viewSection.TabOrder = "left-right"; viewSection.Weight = Decimal.Parse("1.0"); viewSection.Rows = new List<InputRecordViewRow>(); #region << Row 1>> { var viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("cbf260ae-07e3-4e66-be57-beb7a36779bf"); viewRow.Weight = Decimal.Parse("1.0"); viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> { var viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = Int32.Parse("8"); viewColumn.Items = new List<InputRecordViewItemBase>(); #region << subject >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("65acced0-1650-4ff0-bbff-9937c382cd89"); viewItem.EntityName = "wv_task"; viewItem.FieldId = new Guid("7843bfbd-30c1-4438-af48-ffe56b7f294a"); viewItem.FieldName = "subject"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << description >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("65acced0-1650-4ff0-bbff-9937c382cd89"); viewItem.EntityName = "wv_task"; viewItem.FieldId = new Guid("a00eb247-918a-46ba-9869-8d1168ea8f45"); viewItem.FieldName = "description"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << List from relation: task_comments >> { var viewItemFromRelation = new InputRecordViewRelationListItem(); viewItemFromRelation.EntityId = new Guid("7a57d17e-98f0-4356-baf0-9a8798da0b99"); viewItemFromRelation.EntityName = "wv_project_comment"; viewItemFromRelation.ListId = new Guid("b8a7a81d-9176-47e6-90c5-3cabc2a4ceff"); viewItemFromRelation.ListName = "task_comments"; viewItemFromRelation.FieldLabel = "Comments"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldHelpText = ""; viewItemFromRelation.FieldRequired = false; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = new Guid("884b9480-dc1c-468a-98f0-2d5f10084622"); viewItemFromRelation.RelationName = "task_1_n_comment"; viewItemFromRelation.Type = "listFromRelation"; viewColumn.Items.Add(viewItemFromRelation); } #endregion //Save column viewRow.Columns.Add(viewColumn); } #endregion #region << Column 2 >> { var viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = Int32.Parse("4"); viewColumn.Items = new List<InputRecordViewItemBase>(); #region << status >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("65acced0-1650-4ff0-bbff-9937c382cd89"); viewItem.EntityName = "wv_task"; viewItem.FieldId = new Guid("0702e611-6fe5-42e4-9bad-d549cba9cbb1"); viewItem.FieldName = "status"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << priority >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("65acced0-1650-4ff0-bbff-9937c382cd89"); viewItem.EntityName = "wv_task"; viewItem.FieldId = new Guid("04ede478-99ec-4f7f-97af-0df3e89409b1"); viewItem.FieldName = "priority"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << View: project_milestone >> { var viewItem = new InputRecordViewViewItem(); viewItem.EntityId = new Guid("65acced0-1650-4ff0-bbff-9937c382cd89"); viewItem.EntityName = "wv_task"; viewItem.ViewId = new Guid("820b6771-3100-4393-982b-3813d79f4df2"); viewItem.ViewName = "project_milestone"; viewItem.Type = "view"; viewColumn.Items.Add(viewItem); } #endregion #region << estimation >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("65acced0-1650-4ff0-bbff-9937c382cd89"); viewItem.EntityName = "wv_task"; viewItem.FieldId = new Guid("848e2a24-8d58-451b-9cf8-9ba1254a169a"); viewItem.FieldName = "estimation"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << field from Relation: username >> { var viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = new Guid("b9cebc3b-6443-452a-8e34-b311a73dcc8b"); viewItemFromRelation.EntityName = "user"; viewItemFromRelation.Type = "fieldFromRelation"; viewItemFromRelation.FieldId = new Guid("263c0b21-88c1-4c2b-80b4-db7402b0d2e2"); viewItemFromRelation.FieldName = "username"; viewItemFromRelation.FieldLabel = "Owner"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldHelpText = null; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = new Guid("7ce76c81-e604-401e-907f-23de982b930e"); viewItemFromRelation.RelationName = "user_1_n_task_owner"; viewColumn.Items.Add(viewItemFromRelation); } #endregion #region << start_date >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("65acced0-1650-4ff0-bbff-9937c382cd89"); viewItem.EntityName = "wv_task"; viewItem.FieldId = new Guid("5bf852bf-5e6c-4791-bc8b-f1366440c04b"); viewItem.FieldName = "start_date"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << end_date >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("65acced0-1650-4ff0-bbff-9937c382cd89"); viewItem.EntityName = "wv_task"; viewItem.FieldId = new Guid("c6dc9db2-0081-4a91-b0e2-78f9c1c45a51"); viewItem.FieldName = "end_date"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << field from Relation: username >> { var viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = new Guid("b9cebc3b-6443-452a-8e34-b311a73dcc8b"); viewItemFromRelation.EntityName = "user"; viewItemFromRelation.Type = "fieldFromRelation"; viewItemFromRelation.FieldId = new Guid("263c0b21-88c1-4c2b-80b4-db7402b0d2e2"); viewItemFromRelation.FieldName = "username"; viewItemFromRelation.FieldLabel = "Watchers"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldHelpText = null; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = new Guid("de7e1578-8f8f-4454-a954-0fb62d3bf425"); viewItemFromRelation.RelationName = "user_n_n_task_watchers"; viewColumn.Items.Add(viewItemFromRelation); } #endregion //Save column viewRow.Columns.Add(viewColumn); } #endregion //Save row viewSection.Rows.Add(viewRow); } #endregion //Save section viewRegion.Sections.Add(viewSection); } #endregion #region << Section: hidden >> { var viewSection = new InputRecordViewSection(); viewSection.Id = new Guid("23557322-9c2c-4824-b817-9d4d5bc0e83b"); viewSection.Name = "hidden"; viewSection.Label = "Hidden"; viewSection.ShowLabel = false; viewSection.CssClass = "ng-hide"; viewSection.Collapsed = false; viewSection.TabOrder = "left-right"; viewSection.Weight = Decimal.Parse("2.0"); viewSection.Rows = new List<InputRecordViewRow>(); #region << Row 1>> { var viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("19c54fd0-b594-4e96-a727-adac8518fd38"); viewRow.Weight = Decimal.Parse("1.0"); viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> { var viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = Int32.Parse("12"); viewColumn.Items = new List<InputRecordViewItemBase>(); #region << code >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("65acced0-1650-4ff0-bbff-9937c382cd89"); viewItem.EntityName = "wv_task"; viewItem.FieldId = new Guid("04f31ad8-4583-4237-8d54-f82c3f44b918"); viewItem.FieldName = "code"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); } #endregion //Save row viewSection.Rows.Add(viewRow); } #endregion //Save section viewRegion.Sections.Add(viewSection); } #endregion //Save region createViewInput.Regions.Add(viewRegion); } #endregion #endregion #region << Relation options >> { createViewInput.RelationOptions = new List<EntityRelationOptionsItem>(); } #endregion #region << Action items >> { createViewInput.ActionItems = new List<ActionItem>(); #region << action item: wv_back_button >> { var actionItem = new ActionItem(); actionItem.Name = "wv_back_button"; actionItem.Menu = "sidebar-top"; actionItem.Weight = Decimal.Parse("1.0"); actionItem.Template = @"<a class=""back clearfix"" href=""javascript:void(0)"" ng-click=""sidebarData.goBack()""><i class=""fa fa-fw fa-arrow-left""></i> <span class=""text"">Back</span></a>"; createViewInput.ActionItems.Add(actionItem); } #endregion } #endregion #region << Sidebar >> createViewInput.Sidebar = new InputRecordViewSidebar(); createViewInput.Sidebar.CssClass = ""; createViewInput.Sidebar.Render = false; createViewInput.Sidebar.Items = new List<InputRecordViewSidebarItemBase>(); #region << list from relation: task_attachments >> { var viewItemFromRelation = new InputRecordViewSidebarRelationListItem(); viewItemFromRelation.EntityId = new Guid("65acced0-1650-4ff0-bbff-9937c382cd89"); viewItemFromRelation.EntityName = "wv_task"; viewItemFromRelation.ListId = new Guid("6fc374ac-ba6b-4009-ade4-988304071f29"); viewItemFromRelation.ListName = "task_attachments"; viewItemFromRelation.FieldLabel = "Attachments"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldHelpText = ""; viewItemFromRelation.FieldRequired = false; viewItemFromRelation.FieldManageView = "general"; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = new Guid("f79f76e2-06b1-463a-9675-63845814bf22"); viewItemFromRelation.RelationName = "task_1_n_attachment"; viewItemFromRelation.Type = "listFromRelation"; createViewInput.Sidebar.Items.Add(viewItemFromRelation); } #endregion #region << list from relation: task_timelogs >> { var viewItemFromRelation = new InputRecordViewSidebarRelationListItem(); viewItemFromRelation.EntityId = new Guid("65acced0-1650-4ff0-bbff-9937c382cd89"); viewItemFromRelation.EntityName = "wv_task"; viewItemFromRelation.ListId = new Guid("c105b3f8-e140-4150-a587-a31cf600d99b"); viewItemFromRelation.ListName = "task_timelogs"; viewItemFromRelation.FieldLabel = "Time logs"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldHelpText = ""; viewItemFromRelation.FieldRequired = false; viewItemFromRelation.FieldManageView = "general"; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = new Guid("61f1cd54-bcd6-4061-9c96-7934e01f0857"); viewItemFromRelation.RelationName = "task_1_n_time_log"; viewItemFromRelation.Type = "listFromRelation"; createViewInput.Sidebar.Items.Add(viewItemFromRelation); } #endregion #region << list from relation: task_activities >> { var viewItemFromRelation = new InputRecordViewSidebarRelationListItem(); viewItemFromRelation.EntityId = new Guid("65acced0-1650-4ff0-bbff-9937c382cd89"); viewItemFromRelation.EntityName = "wv_task"; viewItemFromRelation.ListId = new Guid("121ce540-7838-4459-8357-d0d0ad2b65a4"); viewItemFromRelation.ListName = "task_activities"; viewItemFromRelation.FieldLabel = "Activities"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldHelpText = ""; viewItemFromRelation.FieldRequired = false; viewItemFromRelation.FieldManageView = "general"; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = new Guid("8f294277-fd60-496e-bff7-9391fffcda41"); viewItemFromRelation.RelationName = "task_1_n_activity"; viewItemFromRelation.Type = "listFromRelation"; createViewInput.Sidebar.Items.Add(viewItemFromRelation); } #endregion #endregion { var response = entMan.UpdateRecordView(new Guid("65acced0-1650-4ff0-bbff-9937c382cd89"), createViewInput); if (!response.Success) throw new Exception("System error 10060. Entity: wv_task Updated view: general Message:" + response.Message); } } #endregion }
public IActionResult UpdateEntityRelationRecord([FromBody]InputEntityRelationRecordUpdateModel model) { var recMan = new RecordManager(service); var entMan = new EntityManager(service.StorageService); BaseResponseModel response = new BaseResponseModel { Timestamp = DateTime.UtcNow, Success = true, Errors = new List<ErrorModel>() }; if (model == null) { response.Errors.Add(new ErrorModel { Message = "Invalid model." }); response.Success = false; return DoResponse(response); } EntityRelation relation = null; if (string.IsNullOrWhiteSpace(model.RelationName)) { response.Errors.Add(new ErrorModel { Message = "Invalid relation name.", Key = "relationName" }); response.Success = false; return DoResponse(response); } else { relation = new EntityRelationManager(service.StorageService).Read(model.RelationName).Object; if (relation == null) { response.Errors.Add(new ErrorModel { Message = "Invalid relation name. No relation with that name.", Key = "relationName" }); response.Success = false; return DoResponse(response); } } var originEntity = entMan.ReadEntity(relation.OriginEntityId).Object; var targetEntity = entMan.ReadEntity(relation.TargetEntityId).Object; var originField = originEntity.Fields.Single(x => x.Id == relation.OriginFieldId); var targetField = targetEntity.Fields.Single(x => x.Id == relation.TargetFieldId); if (model.DetachTargetFieldRecordIds != null && model.DetachTargetFieldRecordIds.Any() && targetField.Required && relation.RelationType != EntityRelationType.ManyToMany) { response.Errors.Add(new ErrorModel { Message = "Cannot detach records, when target field is required.", Key = "originFieldRecordId" }); response.Success = false; return DoResponse(response); } EntityQuery query = new EntityQuery(originEntity.Name, "*", EntityQuery.QueryEQ("id", model.OriginFieldRecordId), null, null, null); QueryResponse result = recMan.Find(query); if (result.Object.Data.Count == 0) { response.Errors.Add(new ErrorModel { Message = "Origin record was not found. Id=[" + model.OriginFieldRecordId + "]", Key = "originFieldRecordId" }); response.Success = false; return DoResponse(response); } var originRecord = result.Object.Data[0]; object originValue = originRecord[originField.Name]; List<EntityRecord> attachTargetRecords = new List<EntityRecord>(); List<EntityRecord> detachTargetRecords = new List<EntityRecord>(); foreach (var targetId in model.AttachTargetFieldRecordIds) { query = new EntityQuery(targetEntity.Name, "*", EntityQuery.QueryEQ("id", targetId), null, null, null); result = recMan.Find(query); if (result.Object.Data.Count == 0) { response.Errors.Add(new ErrorModel { Message = "Attach target record was not found. Id=[" + targetEntity + "]", Key = "targetRecordId" }); response.Success = false; return DoResponse(response); } else if (attachTargetRecords.Any(x => (Guid)x["id"] == targetId)) { response.Errors.Add(new ErrorModel { Message = "Attach target id was duplicated. Id=[" + targetEntity + "]", Key = "targetRecordId" }); response.Success = false; return DoResponse(response); } attachTargetRecords.Add(result.Object.Data[0]); } foreach (var targetId in model.DetachTargetFieldRecordIds) { query = new EntityQuery(targetEntity.Name, "*", EntityQuery.QueryEQ("id", targetId), null, null, null); result = recMan.Find(query); if (result.Object.Data.Count == 0) { response.Errors.Add(new ErrorModel { Message = "Detach target record was not found. Id=[" + targetEntity + "]", Key = "targetRecordId" }); response.Success = false; return DoResponse(response); } else if (attachTargetRecords.Any(x => (Guid)x["id"] == targetId)) { response.Errors.Add(new ErrorModel { Message = "Detach target id was duplicated. Id=[" + targetEntity + "]", Key = "targetRecordId" }); response.Success = false; return DoResponse(response); } detachTargetRecords.Add(result.Object.Data[0]); } var transaction = recMan.CreateTransaction(); try { transaction.Begin(); switch (relation.RelationType) { case EntityRelationType.OneToOne: case EntityRelationType.OneToMany: { foreach (var record in detachTargetRecords) { record[targetField.Name] = null; var updResult = recMan.UpdateRecord(targetEntity, record); if (!updResult.Success) { transaction.Rollback(); response.Errors = updResult.Errors; response.Message = "Target record id=[" + record["id"] + "] detach operation failed."; response.Success = false; return DoResponse(response); } } foreach (var record in attachTargetRecords) { record[targetField.Name] = originValue; var updResult = recMan.UpdateRecord(targetEntity, record); if (!updResult.Success) { transaction.Rollback(); response.Errors = updResult.Errors; response.Message = "Target record id=[" + record["id"] + "] attach operation failed."; response.Success = false; return DoResponse(response); } } } break; case EntityRelationType.ManyToMany: { foreach (var record in detachTargetRecords) { QueryResponse updResult = recMan.RemoveRelationManyToManyRecord(relation.Id, (Guid)originValue, (Guid)record[targetField.Name]); if (!updResult.Success) { transaction.Rollback(); response.Errors = updResult.Errors; response.Message = "Target record id=[" + record["id"] + "] detach operation failed."; response.Success = false; return DoResponse(response); } } foreach (var record in attachTargetRecords) { QueryResponse updResult = recMan.CreateRelationManyToManyRecord(relation.Id, (Guid)originValue, (Guid)record[targetField.Name]); if (!updResult.Success) { transaction.Rollback(); response.Errors = updResult.Errors; response.Message = "Target record id=[" + record["id"] + "] attach operation failed."; response.Success = false; return DoResponse(response); } } } break; default: { transaction.Rollback(); throw new Exception("Not supported relation type"); } } transaction.Commit(); } catch (Exception ex) { if (transaction != null) transaction.Rollback(); response.Success = false; response.Message = ex.Message; return DoResponse(response); } return DoResponse(response); }
private static void Patch160714(EntityManager entMan, EntityRelationManager relMan, RecordManager recMan, bool createSampleRecords = false) { }
private List<EntityRecord> GetListRecords(List<Entity> entities, Entity entity, string listName, int? page = null, QueryObject queryObj = null, string filter = null, string search = null) { RecordList list = null; if (entity != null && entity.RecordLists != null) list = entity.RecordLists.FirstOrDefault(l => l.Name == listName); var searchQuery = CreateSearchQuery(search, list, entity); if (searchQuery != null) { if (queryObj != null) queryObj = EntityQuery.QueryAND(queryObj, searchQuery); else queryObj = searchQuery; } var filterQuery = CreateFilterQuery(filter, entities); if (filterQuery != null) { if (queryObj != null) queryObj = EntityQuery.QueryAND(queryObj, filterQuery); else queryObj = filterQuery; } EntityQuery resultQuery = new EntityQuery(entity.Name, "*", queryObj, null, null, null); EntityRelationManager relManager = new EntityRelationManager(Storage); EntityRelationListResponse relListResponse = relManager.Read(); List<EntityRelation> relationList = new List<EntityRelation>(); if (relListResponse.Object != null) relationList = relListResponse.Object; if (list != null) { List<QuerySortObject> sortList = new List<QuerySortObject>(); if (list.Sorts != null && list.Sorts.Count > 0) { foreach (var sort in list.Sorts) { QuerySortType sortType; if (Enum.TryParse<QuerySortType>(sort.SortType, true, out sortType)) sortList.Add(new QuerySortObject(sort.FieldName, sortType)); } resultQuery.Sort = sortList.ToArray(); } if (list.Query != null) { var listQuery = RecordListQuery.ConvertQuery(list.Query); if (queryObj != null) { if (queryObj.SubQueries != null && queryObj.SubQueries.Any()) queryObj.SubQueries.Add(listQuery); else queryObj = EntityQuery.QueryAND(listQuery, queryObj); } else queryObj = listQuery; resultQuery.Query = queryObj; } string queryFields = "id,"; if (list.Columns != null) { foreach (var column in list.Columns) { if (column is RecordListFieldItem) { if (((RecordListFieldItem)column).Meta.Name != "id") queryFields += ((RecordListFieldItem)column).Meta.Name + ", "; } else if (column is RecordListRelationTreeItem) { EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordListRelationTreeItem)column).RelationId); string relName = relation != null ? string.Format("${0}.", relation.Name) : ""; Guid relEntityId = relation.OriginEntityId; Guid relFieldId = relation.OriginFieldId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); Field relField = relEntity.Fields.FirstOrDefault(f => f.Id == relFieldId); var treeId = (column as RecordListRelationTreeItem).TreeId; RecordTree tree = relEntity.RecordTrees.Single(x => x.Id == treeId); var relIdField = relEntity.Fields.Single(x => x.Name == "id"); List<Guid> fieldIdsToInclude = new List<Guid>(); fieldIdsToInclude.AddRange(tree.NodeObjectProperties); if (!fieldIdsToInclude.Contains(relIdField.Id)) fieldIdsToInclude.Add(relIdField.Id); if (!fieldIdsToInclude.Contains(tree.NodeNameFieldId)) fieldIdsToInclude.Add(tree.NodeNameFieldId); if (!fieldIdsToInclude.Contains(tree.NodeLabelFieldId)) fieldIdsToInclude.Add(tree.NodeLabelFieldId); if (!fieldIdsToInclude.Contains(relField.Id)) fieldIdsToInclude.Add(relField.Id); foreach (var fieldId in fieldIdsToInclude) { var f = relEntity.Fields.SingleOrDefault(x => x.Id == fieldId); if (f != null) { string qFieldName = string.Format("{0}{1},", relName, f.Name); if (!queryFields.Contains(qFieldName)) queryFields += qFieldName; } } //always add target field in query, its value may be required for relative view and list Field field = entity.Fields.FirstOrDefault(f => f.Id == relation.TargetFieldId); queryFields += field.Name + ", "; } else if (column is RecordListRelationFieldItem) { string targetOriginPrefix = ""; if (list.RelationOptions != null) { var options = list.RelationOptions.SingleOrDefault(x => x.RelationId == ((RecordListRelationFieldItem)column).RelationId); if (options != null && options.Direction == "target-origin") targetOriginPrefix = "$"; } EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordListRelationFieldItem)column).RelationId); queryFields += string.Format(targetOriginPrefix + "${0}.{1}, ", relation.Name, ((RecordListRelationFieldItem)column).Meta.Name); //add ID field automatically if not added if (!queryFields.Contains(string.Format(targetOriginPrefix + "${0}.id", relation.Name))) queryFields += string.Format(targetOriginPrefix + "${0}.id,", relation.Name); //always add origin field in query, its value may be required for relative view and list Guid fieldId = entity.Id == relation.OriginEntityId ? relation.OriginFieldId : relation.TargetFieldId; Field field = entity.Fields.FirstOrDefault(f => f.Id == fieldId); queryFields += field.Name + ", "; } else if (column is RecordListListItem || column is RecordListViewItem) { if (!queryFields.Contains(" id, ") && !queryFields.StartsWith("id,")) queryFields += "id, "; } else if (column is RecordListRelationListItem) { EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordListRelationListItem)column).RelationId); string targetOriginPrefix = ""; if (list.RelationOptions != null) { var options = list.RelationOptions.SingleOrDefault(x => x.RelationId == ((RecordListRelationListItem)column).RelationId); if (options != null && options.Direction == "target-origin") targetOriginPrefix = "$"; } string relName = relation != null ? string.Format(targetOriginPrefix + "${0}.", relation.Name) : ""; Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Guid relFieldId = entity.Id == relation.OriginEntityId ? relation.TargetFieldId : relation.OriginFieldId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); Field relField = relEntity.Fields.FirstOrDefault(f => f.Id == relFieldId); string queryFieldName = string.Format("{0}{1}, ", relName, relField.Name); if (!queryFields.Contains(queryFieldName)) queryFields += queryFieldName; //always add origin field in query, its value may be required for relative view and list Guid fieldId = entity.Id == relation.OriginEntityId ? relation.OriginFieldId : relation.TargetFieldId; Field field = entity.Fields.FirstOrDefault(f => f.Id == fieldId); queryFields += field.Name + ", "; } else if (column is RecordListRelationViewItem) { EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordListRelationViewItem)column).RelationId); string targetOriginPrefix = ""; if (list.RelationOptions != null) { var options = list.RelationOptions.SingleOrDefault(x => x.RelationId == ((RecordListRelationViewItem)column).RelationId); if (options != null && options.Direction == "target-origin") targetOriginPrefix = "$"; } string relName = relation != null ? string.Format(targetOriginPrefix + "${0}.", relation.Name) : ""; Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Guid relFieldId = entity.Id == relation.OriginEntityId ? relation.TargetFieldId : relation.OriginFieldId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); Field relField = relEntity.Fields.FirstOrDefault(f => f.Id == relFieldId); string queryFieldName = string.Format("{0}{1}, ", relName, relField.Name); if (!queryFields.Contains(queryFieldName)) queryFields += queryFieldName; //always add origin field in query, its value may be required for relative view and list Guid fieldId = entity.Id == relation.OriginEntityId ? relation.OriginFieldId : relation.TargetFieldId; Field field = entity.Fields.FirstOrDefault(f => f.Id == fieldId); queryFields += field.Name + ", "; } } if (queryFields.EndsWith(", ")) queryFields = queryFields.Remove(queryFields.Length - 2); resultQuery.Fields = queryFields; } if (list.PageSize > 0) { resultQuery.Limit = list.PageSize; if (page != null && page > 0) resultQuery.Skip = (page - 1) * resultQuery.Limit; } } List<EntityRecord> resultDataList = new List<EntityRecord>(); QueryResponse result = recMan.Find(resultQuery); if (!result.Success) throw new Exception(result.Message); if (list != null) { foreach (var record in result.Object.Data) { EntityRecord dataRecord = new EntityRecord(); //always add id value dataRecord["id"] = record["id"]; foreach (var column in list.Columns) { if (column is RecordListFieldItem) { dataRecord[column.DataName] = record[((RecordListFieldItem)column).FieldName]; } else if (column is RecordListRelationFieldItem) { string propName = string.Format("${0}", ((RecordListRelationFieldItem)column).RelationName); List<EntityRecord> relFieldRecords = (List<EntityRecord>)record[propName]; string idDataName = "$field" + propName + "$id"; if (!dataRecord.Properties.ContainsKey(idDataName)) { List<object> idFieldRecord = new List<object>(); if (relFieldRecords != null) { foreach (var relFieldRecord in relFieldRecords) idFieldRecord.Add(relFieldRecord["id"]); } dataRecord[idDataName] = idFieldRecord; } List<object> resultFieldRecord = new List<object>(); if (relFieldRecords != null) { foreach (var relFieldRecord in relFieldRecords) { resultFieldRecord.Add(relFieldRecord[((RecordListRelationFieldItem)column).FieldName]); } } dataRecord[column.DataName] = resultFieldRecord; } else if (column is RecordListListItem) { dataRecord[column.DataName] = GetListRecords(entities, entity, ((RecordListListItem)column).ListName); } else if (column is RecordListRelationListItem) { EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordListRelationListItem)column).RelationId); string relName = string.Format("${0}", relation.Name); Guid fieldId = entity.Id == relation.OriginEntityId ? relation.OriginFieldId : relation.TargetFieldId; Field field = entity.Fields.FirstOrDefault(f => f.Id == fieldId); Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Guid relFieldId = entity.Id == relation.OriginEntityId ? relation.TargetFieldId : relation.OriginFieldId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); Field relField = relEntity.Fields.FirstOrDefault(f => f.Id == relFieldId); var relatedRecords = record["$" + relation.Name] as List<EntityRecord>; List<QueryObject> queries = new List<QueryObject>(); foreach (var relatedRecord in relatedRecords) queries.Add(EntityQuery.QueryEQ(relField.Name, relatedRecord[relField.Name])); if (queries.Count > 0) { QueryObject subListQueryObj = EntityQuery.QueryOR(queries.ToArray()); List<EntityRecord> subListResult = GetListRecords(entities, relEntity, ((RecordListRelationListItem)column).ListName, queryObj: subListQueryObj); dataRecord[((RecordListRelationListItem)column).DataName] = subListResult; } else dataRecord[((RecordListRelationListItem)column).DataName] = new List<object>(); } else if (column is RecordListViewItem) { dataRecord[column.DataName] = GetViewRecords(entities, entity, ((RecordListViewItem)column).ViewName, "id", record["id"]); } else if (column is RecordListRelationTreeItem) { EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordListRelationTreeItem)column).RelationId); string relName = string.Format("${0}", relation.Name); Guid fieldId = entity.Id == relation.OriginEntityId ? relation.OriginFieldId : relation.TargetFieldId; Field field = entity.Fields.FirstOrDefault(f => f.Id == fieldId); Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Guid relFieldId = entity.Id == relation.OriginEntityId ? relation.TargetFieldId : relation.OriginFieldId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); Field relField = relEntity.Fields.FirstOrDefault(f => f.Id == relFieldId); var relatedRecords = record["$" + relation.Name] as List<EntityRecord>; dataRecord[((RecordListRelationTreeItem)column).DataName] = relatedRecords; } else if (column is RecordListRelationViewItem) { EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordListRelationViewItem)column).RelationId); string relName = string.Format("${0}", relation.Name); Guid fieldId = entity.Id == relation.OriginEntityId ? relation.OriginFieldId : relation.TargetFieldId; Field field = entity.Fields.FirstOrDefault(f => f.Id == fieldId); Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Guid relFieldId = entity.Id == relation.OriginEntityId ? relation.TargetFieldId : relation.OriginFieldId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); Field relField = relEntity.Fields.FirstOrDefault(f => f.Id == relFieldId); List<EntityRecord> subViewResult = new List<EntityRecord>(); var relatedRecords = record["$" + relation.Name] as List<EntityRecord>; foreach (var relatedRecord in relatedRecords) { subViewResult.AddRange(GetViewRecords(entities, relEntity, ((RecordListRelationViewItem)column).ViewName, relField.Name, relatedRecord[relField.Name])); } dataRecord[((RecordListRelationViewItem)column).DataName] = subViewResult; } } resultDataList.Add(dataRecord); } } else { foreach (var record in result.Object.Data) { EntityRecord dataRecord = new EntityRecord(); foreach (var prop in record.Properties) { //string propName = "$field" + (prop.Key.StartsWith("$") ? prop.Key : "$" + prop.Key); string propName = prop.Key; dataRecord[propName] = record[prop.Key]; } resultDataList.Add(dataRecord); } } return resultDataList; }
private List<ErrorModel> ValidateRecordList(Entity entity, InputRecordList recordlist, bool checkId = false) { List<ErrorModel> errorList = new List<ErrorModel>(); List<IStorageEntity> storageEntityList = EntityRepository.Read(); List<Entity> entities = storageEntityList.MapTo<Entity>(); EntityRelationManager relationManager = new EntityRelationManager(Storage); EntityRelationListResponse relationListResponse = relationManager.Read(); List<EntityRelation> relationList = new List<EntityRelation>(); if (relationListResponse.Object != null) relationList = relationListResponse.Object; //List<RecordList> recordLists = new List<RecordList>(); //List<RecordView> recordViews = new List<RecordView>(); //List<Field> fields = new List<Field>(); //foreach (var ent in entities) //{ // recordLists.AddRange(ent.RecordLists); // recordViews.AddRange(ent.RecordViews); // fields.AddRange(ent.Fields); //} if (!recordlist.Id.HasValue || recordlist.Id.Value == Guid.Empty) errorList.Add(new ErrorModel("id", null, "Id is required!")); if (checkId) { int listSameIdCount = entity.RecordLists.Where(f => f.Id == recordlist.Id).Count(); if (listSameIdCount > 1) errorList.Add(new ErrorModel("id", null, "There is already a list with such Id!")); int listSameNameCount = entity.Fields.Where(f => f.Name == recordlist.Name).Count(); if (listSameNameCount > 1) errorList.Add(new ErrorModel("name", null, "There is already a list with such Name!")); } errorList.AddRange(ValidationUtility.ValidateName(recordlist.Name)); errorList.AddRange(ValidationUtility.ValidateLabel(recordlist.Label)); if (!recordlist.Default.HasValue) recordlist.Default = false; if (!recordlist.System.HasValue) recordlist.System = false; if (!recordlist.Weight.HasValue) recordlist.Weight = 1; if (!recordlist.PageSize.HasValue) recordlist.PageSize = 10; if (recordlist.CssClass != null) recordlist.CssClass = recordlist.CssClass.Trim(); if (recordlist.Type != null) { RecordListType type; if (!Enum.TryParse<RecordListType>(recordlist.Type, true, out type)) errorList.Add(new ErrorModel("type", recordlist.Type, "There is no such type!")); } else errorList.Add(new ErrorModel("type", recordlist.Type, "Type is required!")); if (recordlist.Columns != null && recordlist.Columns.Count > 0) { foreach (var column in recordlist.Columns) { if (column is InputRecordListFieldItem) { InputRecordListFieldItem inputColumn = (InputRecordListFieldItem)column; if (string.IsNullOrWhiteSpace(((InputRecordListFieldItem)column).FieldName) && ((InputRecordListFieldItem)column).FieldId == null) { errorList.Add(new ErrorModel("columns.fieldName", null, "Field name or id is required!")); } else { if (((InputRecordListFieldItem)column).FieldId == null) { if (recordlist.Columns.Where(i => i is InputRecordListFieldItem && ((InputRecordListFieldItem)i).FieldName == inputColumn.FieldName).Count() > 1) errorList.Add(new ErrorModel("columns.fieldName", null, "There is already an item with such field name!")); if (!entity.Fields.Any(f => f.Name == inputColumn.FieldName)) errorList.Add(new ErrorModel("columns.fieldName", null, "Wrong name. There is no field with such name!")); else inputColumn.FieldId = entity.Fields.FirstOrDefault(f => f.Name == inputColumn.FieldName).Id; } else if (string.IsNullOrWhiteSpace(((InputRecordListFieldItem)column).FieldName)) { if (recordlist.Columns.Where(i => i is InputRecordListFieldItem && ((InputRecordListFieldItem)i).FieldId == inputColumn.FieldId).Count() > 1) errorList.Add(new ErrorModel("columns.fieldId", null, "There is already an item with such field identifier!")); if (!entity.Fields.Any(f => f.Id == inputColumn.FieldId.Value)) errorList.Add(new ErrorModel("columns.fieldId", null, "Wrong id. There is no field with such id!")); else inputColumn.FieldName = entity.Fields.FirstOrDefault(f => f.Id == inputColumn.FieldId).Name; } else { //TODO validate if id does not fit the name if (recordlist.Columns.Where(i => i is InputRecordListFieldItem && ((InputRecordListFieldItem)i).FieldId == inputColumn.FieldId).Count() > 1) errorList.Add(new ErrorModel("columns.fieldId", null, "There is already an item with such field identifier!")); if (!entity.Fields.Any(f => f.Id == inputColumn.FieldId.Value)) errorList.Add(new ErrorModel("columns.fieldId", null, "Wrong id. There is no field with such id!")); } } inputColumn.EntityId = entity.Id; inputColumn.EntityName = entity.Name; } else if (column is InputRecordListListItem) { InputRecordListListItem inputColumn = (InputRecordListListItem)column; if (string.IsNullOrWhiteSpace(inputColumn.ListName) && inputColumn.ListId == null) { errorList.Add(new ErrorModel("columns.listName", null, "List name or id is required!")); } else { if (inputColumn.ListId == null) { if (recordlist.Columns.Where(i => i is InputRecordListListItem && ((InputRecordListListItem)i).ListName == inputColumn.ListName).Count() > 1) errorList.Add(new ErrorModel("columns.listName", null, "There is already an item with such list name!")); if (!entity.RecordLists.Any(f => f.Name == inputColumn.ListName)) errorList.Add(new ErrorModel("columns.listName", null, "Wrong name. There is no list with such name!")); else inputColumn.ListId = entity.RecordLists.FirstOrDefault(l => l.Name == inputColumn.ListName).Id; } else if (string.IsNullOrWhiteSpace(inputColumn.ListName)) { if (recordlist.Columns.Where(i => i is InputRecordListListItem && ((InputRecordListListItem)i).ListId == inputColumn.ListId).Count() > 1) errorList.Add(new ErrorModel("columns.listId", null, "There is already an item with sane id!")); if (!entity.RecordLists.Any(f => f.Id == inputColumn.ListId)) errorList.Add(new ErrorModel("columns.listId", null, "Wrong list id. There is no list with such id!")); else inputColumn.ListName = entity.RecordLists.FirstOrDefault(l => l.Id == inputColumn.ListId).Name; } else { //TODO validate if id does not fit the name if (recordlist.Columns.Where(i => i is InputRecordListListItem && ((InputRecordListListItem)i).ListId == inputColumn.ListId).Count() > 1) errorList.Add(new ErrorModel("columns.listId", null, "There is already an item with sane id!")); if (!entity.RecordLists.Any(f => f.Id == inputColumn.ListId)) errorList.Add(new ErrorModel("columns.listId", null, "Wrong list id. There is no list with such id!")); } } inputColumn.EntityId = entity.Id; inputColumn.EntityName = entity.Name; } else if (column is InputRecordListViewItem) { InputRecordListViewItem inputColumn = (InputRecordListViewItem)column; if (string.IsNullOrWhiteSpace(inputColumn.ViewName) && inputColumn.ViewId == null) { errorList.Add(new ErrorModel("columns.viewName", null, "View name or id is required!")); } else { if (inputColumn.ViewId == null) { if (recordlist.Columns.Where(i => i is InputRecordListViewItem && ((InputRecordListViewItem)i).ViewName == inputColumn.ViewName).Count() > 1) errorList.Add(new ErrorModel("columns.viewName", null, "There is already an item with such view name!")); if (!entity.RecordViews.Any(f => f.Name == inputColumn.ViewName)) errorList.Add(new ErrorModel("columns.viewName", null, "Wrong name. There is no view with such name!")); else inputColumn.ViewId = entity.RecordViews.FirstOrDefault(v => v.Name == inputColumn.ViewName).Id; } else if (string.IsNullOrWhiteSpace(inputColumn.ViewName)) { if (recordlist.Columns.Where(i => i is InputRecordListViewItem && ((InputRecordListViewItem)i).ViewId == inputColumn.ViewId).Count() > 1) errorList.Add(new ErrorModel("columns.viewId", null, "There is already an item with such view id!")); if (!entity.RecordViews.Any(f => f.Id == inputColumn.ViewId)) errorList.Add(new ErrorModel("columns.viewId", null, "Wrong id. There is no view with such id!")); else inputColumn.ViewName = entity.RecordViews.FirstOrDefault(v => v.Id == inputColumn.ViewId).Name; } else { //TODO validate if id does not fit the name if (recordlist.Columns.Where(i => i is InputRecordListViewItem && ((InputRecordListViewItem)i).ViewId == inputColumn.ViewId).Count() > 1) errorList.Add(new ErrorModel("columns.viewId", null, "There is already an item with such view id!")); if (!entity.RecordViews.Any(f => f.Id == inputColumn.ViewId)) errorList.Add(new ErrorModel("columns.viewId", null, "Wrong id. There is no view with such id!")); } } inputColumn.EntityId = entity.Id; inputColumn.EntityName = entity.Name; } else if (column is InputRecordListRelationFieldItem) { InputRecordListRelationFieldItem inputColumn = (InputRecordListRelationFieldItem)column; if (string.IsNullOrWhiteSpace(inputColumn.RelationName)) { errorList.Add(new ErrorModel("columns.relationName", null, "Relation name is required!")); } else { if (!relationList.Any(r => r.Name == inputColumn.RelationName)) errorList.Add(new ErrorModel("columns.relationName", null, "Wrong name. There is no relation with such name!")); else { inputColumn.RelationId = relationList.FirstOrDefault(r => r.Name == inputColumn.RelationName).Id; } } if (string.IsNullOrWhiteSpace(inputColumn.FieldName)) { errorList.Add(new ErrorModel("columns.fieldName", null, "Field name is required!")); } else if (inputColumn.RelationId.HasValue && inputColumn.RelationId != Guid.Empty) { if (recordlist.Columns.Where(i => i is InputRecordListRelationFieldItem && ((InputRecordListRelationFieldItem)i).FieldName == inputColumn.FieldName).Count() > 1) errorList.Add(new ErrorModel("columns.fieldName", null, "There is already an item with such field name!")); else { EntityRelation relation = relationList.FirstOrDefault(r => r.Id == inputColumn.RelationId.Value); if (relation != null) { Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); if (relEntity != null) { inputColumn.EntityId = entity.Id; inputColumn.EntityName = entity.Name; Field relField = relEntity.Fields.FirstOrDefault(f => f.Name == inputColumn.FieldName); if (relField != null) inputColumn.FieldId = relField.Id; else errorList.Add(new ErrorModel("columns.fieldName", null, "Wrong name. There is no field with such name!")); } } } } } else if (column is InputRecordListRelationListItem) { InputRecordListRelationListItem inputColumn = (InputRecordListRelationListItem)column; if (string.IsNullOrWhiteSpace(inputColumn.RelationName)) { errorList.Add(new ErrorModel("columns.relationName", null, "Relation name is required!")); } else { if (!relationList.Any(r => r.Name == inputColumn.RelationName)) errorList.Add(new ErrorModel("columns.relationName", null, "Wrong name. There is no relation with such name!")); else { inputColumn.RelationId = relationList.FirstOrDefault(r => r.Name == inputColumn.RelationName).Id; } } if (string.IsNullOrWhiteSpace(inputColumn.ListName)) { errorList.Add(new ErrorModel("columns.listName", null, "List name is required!")); } else if (inputColumn.RelationId.HasValue && inputColumn.RelationId != Guid.Empty) { if (recordlist.Columns.Where(i => i is InputRecordListRelationListItem && ((InputRecordListRelationListItem)i).ListName == inputColumn.ListName).Count() > 1) errorList.Add(new ErrorModel("columns.listName", null, "There is already an item with such list name!")); else { EntityRelation relation = relationList.FirstOrDefault(r => r.Id == inputColumn.RelationId.Value); if (relation != null) { Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); if (relEntity != null) { inputColumn.EntityId = entity.Id; inputColumn.EntityName = entity.Name; RecordList relList = relEntity.RecordLists.FirstOrDefault(l => l.Name == inputColumn.ListName); if (relList != null) inputColumn.ListId = relList.Id; else errorList.Add(new ErrorModel("columns.listId", null, "Wrong Id. There is no list with such id!")); } } } } } else if (column is InputRecordListRelationViewItem) { InputRecordListRelationViewItem inputColumn = (InputRecordListRelationViewItem)column; if (string.IsNullOrWhiteSpace(inputColumn.RelationName)) { errorList.Add(new ErrorModel("columns.relationName", null, "Relation name is required!")); } else { if (!relationList.Any(r => r.Name == inputColumn.RelationName)) errorList.Add(new ErrorModel("columns.relationName", null, "Wrong name. There is no relation with such name!")); else { inputColumn.RelationId = relationList.FirstOrDefault(r => r.Name == inputColumn.RelationName).Id; } } if (string.IsNullOrWhiteSpace(inputColumn.ViewName)) { errorList.Add(new ErrorModel("columns.viewName", null, "View name is required!")); } else if (inputColumn.RelationId.HasValue && inputColumn.RelationId != Guid.Empty) { if (recordlist.Columns.Where(i => i is InputRecordListRelationViewItem && ((InputRecordListRelationViewItem)i).ViewName == inputColumn.ViewName).Count() > 1) errorList.Add(new ErrorModel("columns.viewName", null, "There is already an item with such view name!")); else { EntityRelation relation = relationList.FirstOrDefault(r => r.Id == inputColumn.RelationId.Value); if (relation != null) { Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); if (relEntity != null) { inputColumn.EntityId = entity.Id; inputColumn.EntityName = entity.Name; RecordView relView = relEntity.RecordViews.FirstOrDefault(v => v.Name == inputColumn.ViewName); if (relView != null) inputColumn.ViewId = relView.Id; else errorList.Add(new ErrorModel("columns.viewName", null, "Wrong name. There is no view with such name!")); } } } } } } } if (recordlist.Query != null) { List<ErrorModel> queryErrors = ValidateRecordListQuery(recordlist.Query); errorList.AddRange(queryErrors); } if (recordlist.Sorts != null) { foreach (var sort in recordlist.Sorts) { if (string.IsNullOrWhiteSpace(sort.FieldName)) errorList.Add(new ErrorModel("sorts.fieldName", sort.FieldName, "FieldName is required!")); if (string.IsNullOrWhiteSpace(sort.SortType)) errorList.Add(new ErrorModel("sorts.sortType", sort.SortType, "SortType is required!")); else { QuerySortType sortType; if (!Enum.TryParse<QuerySortType>(sort.SortType, true, out sortType)) errorList.Add(new ErrorModel("sorts.sortType", sort.SortType, "There is no such sort type!")); } } } return errorList; }
public List<EntityRecord> GetViewRecords(List<Entity> entities, Entity entity, string viewName, string queryFieldName, object queryFieldValue) { EntityQuery resultQuery = new EntityQuery(entity.Name, "*", EntityQuery.QueryEQ(queryFieldName, queryFieldValue)); EntityRelationManager relManager = new EntityRelationManager(); EntityRelationListResponse relListResponse = relManager.Read(); List<EntityRelation> relationList = new List<EntityRelation>(); if (relListResponse.Object != null) relationList = relListResponse.Object; RecordView view = null; if (entity != null && entity.RecordViews != null) view = entity.RecordViews.FirstOrDefault(v => v.Name == viewName); List<EntityRecord> resultDataList = new List<EntityRecord>(); string queryFields = "id,"; //List<RecordViewItemBase> items = new List<RecordViewItemBase>(); List<object> items = new List<object>(); if (view != null) { if (view.Sidebar.Items.Any()) items.AddRange(view.Sidebar.Items); foreach (var region in view.Regions) { if (region.Sections == null) continue; foreach (var section in region.Sections) { if (section.Rows == null) continue; foreach (var row in section.Rows) { if (row.Columns == null) continue; foreach (var column in row.Columns) { if (column.Items != null && column.Items.Count > 0) items.AddRange(column.Items); } } } } foreach (var item in items) { if (item is RecordViewFieldItem) { if (((RecordViewFieldItem)item).Meta.Name != "id") queryFields += ((RecordViewFieldItem)item).Meta.Name; } else if (item is RecordViewRelationFieldItem) { string targetOriginPrefix = ""; if (view.RelationOptions != null) { var options = view.RelationOptions.SingleOrDefault(x => x.RelationId == ((RecordViewRelationFieldItem)item).RelationId); if (options != null && options.Direction == "target-origin") targetOriginPrefix = "$"; } EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordViewRelationFieldItem)item).RelationId); //add ID field automatically if not added if (!queryFields.Contains(string.Format(targetOriginPrefix + "${0}.id", relation.Name))) queryFields += string.Format(targetOriginPrefix + "${0}.id,", relation.Name); Guid fieldId = entity.Id == relation.OriginEntityId ? relation.OriginFieldId : relation.TargetFieldId; Field field = entity.Fields.FirstOrDefault(f => f.Id == fieldId); queryFields += field.Name + ", "; queryFields += string.Format(targetOriginPrefix + "${0}.{1}, ", relation.Name, ((RecordViewRelationFieldItem)item).Meta.Name); } else if (item is RecordViewListItem || item is RecordViewViewItem) { if (!queryFields.Contains(" id, ") && !queryFields.StartsWith("id,")) queryFields += "id"; } else if (item is RecordViewRelationTreeItem) { EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordViewRelationTreeItem)item).RelationId); string relName = relation != null ? string.Format("${0}.", relation.Name) : ""; Guid relEntityId = relation.OriginEntityId; Guid relFieldId = relation.OriginFieldId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); Field relField = relEntity.Fields.FirstOrDefault(f => f.Id == relFieldId); var treeId = (item as RecordViewRelationTreeItem).TreeId; RecordTree tree = relEntity.RecordTrees.Single(x => x.Id == treeId); var relIdField = relEntity.Fields.Single(x => x.Name == "id"); List<Guid> fieldIdsToInclude = new List<Guid>(); fieldIdsToInclude.AddRange(tree.NodeObjectProperties); if (!fieldIdsToInclude.Contains(relIdField.Id)) fieldIdsToInclude.Add(relIdField.Id); if (!fieldIdsToInclude.Contains(tree.NodeNameFieldId)) fieldIdsToInclude.Add(tree.NodeNameFieldId); if (!fieldIdsToInclude.Contains(tree.NodeLabelFieldId)) fieldIdsToInclude.Add(tree.NodeLabelFieldId); if (!fieldIdsToInclude.Contains(relField.Id)) fieldIdsToInclude.Add(relField.Id); foreach (var fieldId in fieldIdsToInclude) { var f = relEntity.Fields.SingleOrDefault(x => x.Id == fieldId); if (f != null) { string qFieldName = string.Format("{0}{1},", relName, f.Name); if (!queryFields.Contains(qFieldName)) queryFields += qFieldName; } } //always add target field in query, its value may be required for relative view and list Field field = entity.Fields.FirstOrDefault(f => f.Id == relation.TargetFieldId); queryFields += field.Name + ", "; } else if (item is RecordViewRelationListItem) { EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordViewRelationListItem)item).RelationId); string targetOriginPrefix = ""; if (view.RelationOptions != null) { var options = view.RelationOptions.SingleOrDefault(x => x.RelationId == ((RecordViewRelationListItem)item).RelationId); if (options != null && options.Direction == "target-origin") targetOriginPrefix = "$"; } string relName = relation != null ? string.Format(targetOriginPrefix + "${0}.", relation.Name) : ""; Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Guid relFieldId = entity.Id == relation.OriginEntityId ? relation.TargetFieldId : relation.OriginFieldId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); Field relField = relEntity.Fields.FirstOrDefault(f => f.Id == relFieldId); string qFieldName = string.Format("{0}{1},", relName, relField.Name); if (!queryFields.Contains(qFieldName)) queryFields += qFieldName; //always add origin field in query, its value may be required for relative view and list Guid fieldId = entity.Id == relation.OriginEntityId ? relation.OriginFieldId : relation.TargetFieldId; Field field = entity.Fields.FirstOrDefault(f => f.Id == fieldId); queryFields += field.Name + ", "; } else if (item is RecordViewRelationViewItem) { EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordViewRelationViewItem)item).RelationId); string targetOriginPrefix = ""; if (view.RelationOptions != null) { var options = view.RelationOptions.SingleOrDefault(x => x.RelationId == ((RecordViewRelationViewItem)item).RelationId); if (options != null && options.Direction == "target-origin") targetOriginPrefix = "$"; } string relName = relation != null ? string.Format(targetOriginPrefix + "${0}.", relation.Name) : ""; Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Guid relFieldId = entity.Id == relation.OriginEntityId ? relation.TargetFieldId : relation.OriginFieldId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); Field relField = relEntity.Fields.FirstOrDefault(f => f.Id == relFieldId); string qFieldName = string.Format("{0}{1},", relName, relField.Name); if (!queryFields.Contains(qFieldName)) queryFields += qFieldName; //always add origin field in query, its value may be required for relative view and list Guid fieldId = entity.Id == relation.OriginEntityId ? relation.OriginFieldId : relation.TargetFieldId; Field field = entity.Fields.FirstOrDefault(f => f.Id == fieldId); queryFields += field.Name + ", "; } else if (item is RecordViewSidebarViewItem) { //nothing to add, just check for record id if (!queryFields.Contains(" id, ") && !queryFields.StartsWith("id,")) queryFields += "id"; } else if (item is RecordViewSidebarListItem) { //nothing to add, just check for record id if (!queryFields.Contains(" id, ") && !queryFields.StartsWith("id,")) queryFields += "id"; } else if (item is RecordViewSidebarRelationTreeItem) { EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordViewSidebarRelationTreeItem)item).RelationId); string relName = relation != null ? string.Format("${0}.", relation.Name) : ""; Guid relEntityId = relation.OriginEntityId; Guid relFieldId = relation.OriginFieldId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); Field relField = relEntity.Fields.FirstOrDefault(f => f.Id == relFieldId); string qFieldName = string.Format("{0}{1},", relName, relField.Name); if (!queryFields.Contains(qFieldName)) queryFields += qFieldName; //always add target field in query, its value may be required for relative view and list Field field = entity.Fields.FirstOrDefault(f => f.Id == relation.TargetFieldId); queryFields += field.Name + ", "; } else if (item is RecordViewSidebarRelationListItem) { EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordViewSidebarRelationListItem)item).RelationId); string targetOriginPrefix = ""; if (view.RelationOptions != null) { var options = view.RelationOptions.SingleOrDefault(x => x.RelationId == ((RecordViewSidebarRelationListItem)item).RelationId); if (options != null && options.Direction == "target-origin") targetOriginPrefix = "$"; } string relName = relation != null ? string.Format(targetOriginPrefix + "${0}.", relation.Name) : ""; Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Guid relFieldId = entity.Id == relation.OriginEntityId ? relation.TargetFieldId : relation.OriginFieldId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); Field relField = relEntity.Fields.FirstOrDefault(f => f.Id == relFieldId); string qFieldName = string.Format("{0}{1},", relName, relField.Name); if (!queryFields.Contains(qFieldName)) queryFields += qFieldName; //always add origin field in query, its value may be required for relative view and list Guid fieldId = entity.Id == relation.OriginEntityId ? relation.OriginFieldId : relation.TargetFieldId; Field field = entity.Fields.FirstOrDefault(f => f.Id == fieldId); queryFields += field.Name + ", "; } else if (item is RecordViewSidebarRelationViewItem) { EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordViewSidebarRelationViewItem)item).RelationId); string targetOriginPrefix = ""; if (view.RelationOptions != null) { var options = view.RelationOptions.SingleOrDefault(x => x.RelationId == ((RecordViewSidebarRelationViewItem)item).RelationId); if (options != null && options.Direction == "target-origin") targetOriginPrefix = "$"; } string relName = relation != null ? string.Format(targetOriginPrefix + "${0}.", relation.Name) : ""; Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Guid relFieldId = entity.Id == relation.OriginEntityId ? relation.TargetFieldId : relation.OriginFieldId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); Field relField = relEntity.Fields.FirstOrDefault(f => f.Id == relFieldId); string qFieldName = string.Format("{0}{1},", relName, relField.Name); if (!queryFields.Contains(qFieldName)) queryFields += qFieldName; //always add origin field in query, its value may be required for relative view and list Guid fieldId = entity.Id == relation.OriginEntityId ? relation.OriginFieldId : relation.TargetFieldId; Field field = entity.Fields.FirstOrDefault(f => f.Id == fieldId); queryFields += field.Name + ", "; } queryFields += ","; } queryFields = queryFields.Trim(); if (queryFields.EndsWith(",")) queryFields = queryFields.Remove(queryFields.Length - 1); resultQuery.Fields = queryFields; } QueryResponse result = Find(resultQuery); if (!result.Success) return resultDataList; if (view != null) { foreach (var record in result.Object.Data) { EntityRecord dataRecord = new EntityRecord(); //always add id value dataRecord["id"] = record["id"]; foreach (var item in items) { if (item is RecordViewFieldItem) { dataRecord[((RecordViewFieldItem)item).DataName] = record[((RecordViewFieldItem)item).FieldName]; } else if (item is RecordViewListItem) { dataRecord[((RecordViewListItem)item).DataName] = GetListRecords(entities, entity, ((RecordViewListItem)item).ListName); } else if (item is RecordViewViewItem) { dataRecord[((RecordViewViewItem)item).DataName] = GetViewRecords(entities, entity, ((RecordViewViewItem)item).ViewName, "id", record["id"]); } else if (item is RecordViewRelationFieldItem) { string propName = string.Format("${0}", ((RecordViewRelationFieldItem)item).RelationName); List<EntityRecord> relFieldRecords = (List<EntityRecord>)record[propName]; string idDataName = "$field" + propName + "$id"; if (!dataRecord.Properties.ContainsKey(idDataName)) { List<object> idFieldRecord = new List<object>(); if (relFieldRecords != null) { foreach (var relFieldRecord in relFieldRecords) idFieldRecord.Add(relFieldRecord["id"]); } dataRecord[idDataName] = idFieldRecord; } List<object> resultFieldRecord = new List<object>(); if (relFieldRecords != null) { foreach (var relFieldRecord in relFieldRecords) { resultFieldRecord.Add(relFieldRecord[((RecordViewRelationFieldItem)item).FieldName]); } } dataRecord[((RecordViewRelationFieldItem)item).DataName] = resultFieldRecord; } else if (item is RecordViewRelationTreeItem) { EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordViewRelationTreeItem)item).RelationId); string relName = string.Format("${0}", relation.Name); Guid fieldId = entity.Id == relation.OriginEntityId ? relation.OriginFieldId : relation.TargetFieldId; Field field = entity.Fields.FirstOrDefault(f => f.Id == fieldId); Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Guid relFieldId = entity.Id == relation.OriginEntityId ? relation.TargetFieldId : relation.OriginFieldId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); Field relField = relEntity.Fields.FirstOrDefault(f => f.Id == relFieldId); var relatedRecords = record["$" + relation.Name] as List<EntityRecord>; dataRecord[((RecordViewRelationTreeItem)item).DataName] = relatedRecords; } else if (item is RecordViewRelationListItem) { EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordViewRelationListItem)item).RelationId); string relName = string.Format("${0}", relation.Name); Guid fieldId = entity.Id == relation.OriginEntityId ? relation.OriginFieldId : relation.TargetFieldId; Field field = entity.Fields.FirstOrDefault(f => f.Id == fieldId); Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Guid relFieldId = entity.Id == relation.OriginEntityId ? relation.TargetFieldId : relation.OriginFieldId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); Field relField = relEntity.Fields.FirstOrDefault(f => f.Id == relFieldId); var relatedRecords = record["$" + relation.Name] as List<EntityRecord>; List<QueryObject> queries = new List<QueryObject>(); foreach (var relatedRecord in relatedRecords) queries.Add(EntityQuery.QueryEQ(relField.Name, relatedRecord[relField.Name])); if (queries.Count > 0) { QueryObject subListQueryObj = EntityQuery.QueryOR(queries.ToArray()); List<EntityRecord> subListResult = GetListRecords(entities, relEntity, ((RecordViewRelationListItem)item).ListName, queryObj: subListQueryObj); dataRecord[((RecordViewRelationListItem)item).DataName] = subListResult; } else dataRecord[((RecordViewRelationListItem)item).DataName] = new List<object>(); } else if (item is RecordViewRelationViewItem) { EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordViewRelationViewItem)item).RelationId); string relName = string.Format("${0}", relation.Name); Guid fieldId = entity.Id == relation.OriginEntityId ? relation.OriginFieldId : relation.TargetFieldId; Field field = entity.Fields.FirstOrDefault(f => f.Id == fieldId); Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Guid relFieldId = entity.Id == relation.OriginEntityId ? relation.TargetFieldId : relation.OriginFieldId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); Field relField = relEntity.Fields.FirstOrDefault(f => f.Id == relFieldId); List<EntityRecord> subViewResult = new List<EntityRecord>(); var relatedRecords = record["$" + relation.Name] as List<EntityRecord>; foreach (var relatedRecord in relatedRecords) { subViewResult.AddRange(GetViewRecords(entities, relEntity, ((RecordViewRelationViewItem)item).ViewName, "id", relatedRecord["id"])); } dataRecord[((RecordViewRelationViewItem)item).DataName] = subViewResult; } else if (item is RecordViewSidebarViewItem) { List<EntityRecord> subViewResult = GetViewRecords(entities, entity, ((RecordViewSidebarViewItem)item).ViewName, "id", record["id"]); dataRecord[((RecordViewSidebarViewItem)item).DataName] = subViewResult; } else if (item is RecordViewSidebarListItem) { var query = EntityQuery.QueryEQ("id", record["id"]); List<EntityRecord> subListResult = GetListRecords(entities, entity, ((RecordViewSidebarListItem)item).ListName, queryObj: query); dataRecord[((RecordViewSidebarListItem)item).DataName] = subListResult; } else if (item is RecordViewSidebarRelationTreeItem) { EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordViewSidebarRelationTreeItem)item).RelationId); string relName = string.Format("${0}", relation.Name); Guid fieldId = entity.Id == relation.OriginEntityId ? relation.OriginFieldId : relation.TargetFieldId; Field field = entity.Fields.FirstOrDefault(f => f.Id == fieldId); Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Guid relFieldId = entity.Id == relation.OriginEntityId ? relation.TargetFieldId : relation.OriginFieldId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); Field relField = relEntity.Fields.FirstOrDefault(f => f.Id == relFieldId); var relatedRecords = record["$" + relation.Name] as List<EntityRecord>; dataRecord[((RecordViewSidebarRelationTreeItem)item).DataName] = relatedRecords; } else if (item is RecordViewSidebarRelationListItem) { EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordViewSidebarRelationListItem)item).RelationId); string relName = string.Format("${0}", relation.Name); Guid fieldId = entity.Id == relation.OriginEntityId ? relation.OriginFieldId : relation.TargetFieldId; Field field = entity.Fields.FirstOrDefault(f => f.Id == fieldId); Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Guid relFieldId = entity.Id == relation.OriginEntityId ? relation.TargetFieldId : relation.OriginFieldId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); Field relField = relEntity.Fields.FirstOrDefault(f => f.Id == relFieldId); var relatedRecords = record["$" + relation.Name] as List<EntityRecord>; List<QueryObject> queries = new List<QueryObject>(); foreach (var relatedRecord in relatedRecords) queries.Add(EntityQuery.QueryEQ(relField.Name, relatedRecord[relField.Name])); if (queries.Count > 0) { //QueryObject subListQueryObj = EntityQuery.QueryEQ(relField.Name, record[field.Name]); QueryObject subListQueryObj = EntityQuery.QueryOR(queries.ToArray()); List<EntityRecord> subListResult = GetListRecords(entities, relEntity, ((RecordViewSidebarRelationListItem)item).ListName, queryObj: subListQueryObj); dataRecord[((RecordViewSidebarRelationListItem)item).DataName] = subListResult; } else dataRecord[((RecordViewSidebarRelationListItem)item).DataName] = new List<object>(); } else if (item is RecordViewSidebarRelationViewItem) { EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordViewSidebarRelationViewItem)item).RelationId); string relName = string.Format("${0}", relation.Name); Guid fieldId = entity.Id == relation.OriginEntityId ? relation.OriginFieldId : relation.TargetFieldId; Field field = entity.Fields.FirstOrDefault(f => f.Id == fieldId); Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Guid relFieldId = entity.Id == relation.OriginEntityId ? relation.TargetFieldId : relation.OriginFieldId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); Field relField = relEntity.Fields.FirstOrDefault(f => f.Id == relFieldId); List<EntityRecord> subViewResult = new List<EntityRecord>(); var relatedRecords = record["$" + relation.Name] as List<EntityRecord>; foreach (var relatedRecord in relatedRecords) { subViewResult.AddRange(GetViewRecords(entities, relEntity, ((RecordViewSidebarRelationViewItem)item).ViewName, "id", relatedRecord["id"])); } dataRecord[((RecordViewSidebarRelationViewItem)item).DataName] = subViewResult; } } resultDataList.Add(dataRecord); } } else { foreach (var record in result.Object.Data) { EntityRecord dataRecord = new EntityRecord(); foreach (var prop in record.Properties) { //string propName = "$field" + (prop.Key.StartsWith("$") ? prop.Key : "$" + prop.Key); string propName = prop.Key; dataRecord[propName] = record[prop.Key]; } resultDataList.Add(dataRecord); } } return resultDataList; }
private static void Patch160707(EntityManager entMan, EntityRelationManager relMan, RecordManager recMan, bool createSampleRecords = false) { #region << Create relation: role_n_n_wv_sprint >> { var relation = new EntityRelation(); var originEntity = entMan.ReadEntity(new Guid("c4541fee-fbb6-4661-929e-1724adec285a")).Object; var originField = originEntity.Fields.SingleOrDefault(x => x.Name == "id"); var targetEntity = entMan.ReadEntity(new Guid("a8de737a-9610-424d-9cf1-1b86e6cd17cd")).Object; var targetField = targetEntity.Fields.SingleOrDefault(x => x.Name == "id"); relation.Id = new Guid("e77b7a71-134e-41bf-a079-008e8931303f"); relation.Name = "role_n_n_wv_sprint"; relation.Label = "role_n_n_wv_sprint"; relation.Description = ""; relation.System = true; relation.RelationType = EntityRelationType.ManyToMany; relation.OriginEntityId = originEntity.Id; relation.OriginEntityName = originEntity.Name; relation.OriginFieldId = originField.Id; relation.OriginFieldName = originField.Name; relation.TargetEntityId = targetEntity.Id; relation.TargetEntityName = targetEntity.Name; relation.TargetFieldId = targetField.Id; relation.TargetFieldName = targetField.Name; { var response = relMan.Create(relation); if (!response.Success) throw new Exception("System error 10060. Relation: role_n_n_wv_sprint Create. Message:" + response.Message); } } #endregion #region << Update Entity: wv_project View: admin_create >> { var updateViewEntity = entMan.ReadEntity(new Guid("7821ece9-42ce-470b-84d4-afc9eb35aa32")).Object; var createViewInput = new InputRecordView(); #region << details >> createViewInput.Id = updateViewEntity.RecordViews.SingleOrDefault(x => x.Name == "admin_create").Id; createViewInput.Type = "Hidden"; createViewInput.Name = "admin_create"; createViewInput.Label = "Project create"; createViewInput.Title = ""; createViewInput.Default = false; createViewInput.System = true; createViewInput.Weight = Decimal.Parse("10.0"); createViewInput.CssClass = null; createViewInput.IconName = "product-hunt"; createViewInput.DynamicHtmlTemplate = null; createViewInput.DataSourceUrl = null; createViewInput.ServiceCode = null; #endregion #region << regions >> createViewInput.Regions = new List<InputRecordViewRegion>(); #region << Region: header >> { var viewRegion = new InputRecordViewRegion(); viewRegion.Name = "header"; viewRegion.Label = "Header"; viewRegion.Render = true; viewRegion.Weight = Decimal.Parse("1.0"); viewRegion.CssClass = ""; viewRegion.Sections = new List<InputRecordViewSection>(); #region << Section: details >> { var viewSection = new InputRecordViewSection(); viewSection.Id = new Guid("88077697-7a36-4a5a-b021-3d2a8638dade"); viewSection.Name = "details"; viewSection.Label = "Details"; viewSection.ShowLabel = false; viewSection.CssClass = ""; viewSection.Collapsed = false; viewSection.TabOrder = "left-right"; viewSection.Weight = Decimal.Parse("1.0"); viewSection.Rows = new List<InputRecordViewRow>(); #region << Row 1>> { var viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("27fb37e4-774a-4b07-a678-a435dcd6be55"); viewRow.Weight = Decimal.Parse("1.0"); viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> { var viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = Int32.Parse("4"); viewColumn.Items = new List<InputRecordViewItemBase>(); #region << code >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("7821ece9-42ce-470b-84d4-afc9eb35aa32"); viewItem.EntityName = "wv_project"; viewItem.FieldId = new Guid("d9c6a939-e2e3-4617-900e-e056f0638fa8"); viewItem.FieldName = "code"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); } #endregion #region << Column 2 >> { var viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = Int32.Parse("8"); viewColumn.Items = new List<InputRecordViewItemBase>(); #region << name >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("7821ece9-42ce-470b-84d4-afc9eb35aa32"); viewItem.EntityName = "wv_project"; viewItem.FieldId = new Guid("d13427b7-e518-4305-b2cc-bc814a299b55"); viewItem.FieldName = "name"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); } #endregion //Save row viewSection.Rows.Add(viewRow); } #endregion #region << Row 2>> { var viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("cc65d58f-0cfd-4f3d-b9c6-3c8faff6c8b4"); viewRow.Weight = Decimal.Parse("2.0"); viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> { var viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = Int32.Parse("12"); viewColumn.Items = new List<InputRecordViewItemBase>(); #region << description >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("7821ece9-42ce-470b-84d4-afc9eb35aa32"); viewItem.EntityName = "wv_project"; viewItem.FieldId = new Guid("d5e2c42c-c0b8-4f03-92e0-e91bede1e7b3"); viewItem.FieldName = "description"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); } #endregion //Save row viewSection.Rows.Add(viewRow); } #endregion #region << Row 3>> { var viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("d88b3da7-d501-48ba-b61d-2eb3485bce21"); viewRow.Weight = Decimal.Parse("3.0"); viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> { var viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = Int32.Parse("6"); viewColumn.Items = new List<InputRecordViewItemBase>(); #region << field from Relation: username >> { var viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = new Guid("b9cebc3b-6443-452a-8e34-b311a73dcc8b"); viewItemFromRelation.EntityName = "user"; viewItemFromRelation.Type = "fieldFromRelation"; viewItemFromRelation.FieldId = new Guid("263c0b21-88c1-4c2b-80b4-db7402b0d2e2"); viewItemFromRelation.FieldName = "username"; viewItemFromRelation.FieldLabel = "Owner / Project manager"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldHelpText = null; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = new Guid("0cad07c3-73bd-4c1f-a5d6-552256f679a4"); viewItemFromRelation.RelationName = "user_1_n_project_owner"; viewColumn.Items.Add(viewItemFromRelation); } #endregion #region << field from Relation: name >> { var viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = new Guid("c4541fee-fbb6-4661-929e-1724adec285a"); viewItemFromRelation.EntityName = "role"; viewItemFromRelation.Type = "fieldFromRelation"; viewItemFromRelation.FieldId = new Guid("36f91ebd-5a02-4032-8498-b7f716f6a349"); viewItemFromRelation.FieldName = "name"; viewItemFromRelation.FieldLabel = "Project team roles"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldHelpText = null; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = new Guid("4860a4b6-d07e-416f-b548-60491607e93f"); viewItemFromRelation.RelationName = "role_n_n_project_team"; viewColumn.Items.Add(viewItemFromRelation); } #endregion #region << start_date >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("7821ece9-42ce-470b-84d4-afc9eb35aa32"); viewItem.EntityName = "wv_project"; viewItem.FieldId = new Guid("417ce7d7-a472-499b-8e70-43a1cb54723d"); viewItem.FieldName = "start_date"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << billable_hour_price >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("7821ece9-42ce-470b-84d4-afc9eb35aa32"); viewItem.EntityName = "wv_project"; viewItem.FieldId = new Guid("7179f4ab-0376-4ded-a334-a21ff451538e"); viewItem.FieldName = "billable_hour_price"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); } #endregion #region << Column 2 >> { var viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = Int32.Parse("6"); viewColumn.Items = new List<InputRecordViewItemBase>(); #region << field from Relation: name >> { var viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = new Guid("90bcdb47-2cde-4137-a412-0198348fecc0"); viewItemFromRelation.EntityName = "wv_customer"; viewItemFromRelation.Type = "fieldFromRelation"; viewItemFromRelation.FieldId = new Guid("7fb95d0f-ab59-421d-974d-ab357e28a1f9"); viewItemFromRelation.FieldName = "name"; viewItemFromRelation.FieldLabel = "Customer"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldHelpText = null; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = new Guid("d7f1ec35-9f59-4d75-b8a2-554c7eaeab11"); viewItemFromRelation.RelationName = "customer_1_n_project"; viewColumn.Items.Add(viewItemFromRelation); } #endregion #region << field from Relation: name >> { var viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = new Guid("c4541fee-fbb6-4661-929e-1724adec285a"); viewItemFromRelation.EntityName = "role"; viewItemFromRelation.Type = "fieldFromRelation"; viewItemFromRelation.FieldId = new Guid("36f91ebd-5a02-4032-8498-b7f716f6a349"); viewItemFromRelation.FieldName = "name"; viewItemFromRelation.FieldLabel = "Project customer roles"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldHelpText = null; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = new Guid("e6d75feb-3c8f-410b-9ff4-54ef8489dc2f"); viewItemFromRelation.RelationName = "role_n_n_project_customer"; viewColumn.Items.Add(viewItemFromRelation); } #endregion #region << end_date >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("7821ece9-42ce-470b-84d4-afc9eb35aa32"); viewItem.EntityName = "wv_project"; viewItem.FieldId = new Guid("57198778-636d-47ec-b33e-edfc5705cc05"); viewItem.FieldName = "end_date"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); } #endregion //Save row viewSection.Rows.Add(viewRow); } #endregion //Save section viewRegion.Sections.Add(viewSection); } #endregion //Save region createViewInput.Regions.Add(viewRegion); } #endregion #endregion #region << Relation options >> { createViewInput.RelationOptions = new List<EntityRelationOptionsItem>(); } #endregion #region << Action items >> { createViewInput.ActionItems = new List<ActionItem>(); #region << action item: wv_create_and_list >> { var actionItem = new ActionItem(); actionItem.Name = "wv_create_and_list"; actionItem.Menu = "create-bottom"; actionItem.Weight = Decimal.Parse("1.0"); actionItem.Template = @"<a class=""btn btn-primary"" ng-click='ngCtrl.create(""default"")' ng-if=""ngCtrl.createViewRegion != null"">Create</a>"; createViewInput.ActionItems.Add(actionItem); } #endregion #region << action item: wv_create_and_details >> { var actionItem = new ActionItem(); actionItem.Name = "wv_create_and_details"; actionItem.Menu = "create-bottom"; actionItem.Weight = Decimal.Parse("2.0"); actionItem.Template = @"<a class=""btn btn-default btn-outline"" ng-click='ngCtrl.create(""details"")' ng-if=""ngCtrl.createViewRegion != null"">Create & Details</a>"; createViewInput.ActionItems.Add(actionItem); } #endregion #region << action item: wv_create_cancel >> { var actionItem = new ActionItem(); actionItem.Name = "wv_create_cancel"; actionItem.Menu = "create-bottom"; actionItem.Weight = Decimal.Parse("3.0"); actionItem.Template = @"<a class=""btn btn-default btn-outline"" ng-click=""ngCtrl.cancel()"">Cancel</a>"; createViewInput.ActionItems.Add(actionItem); } #endregion #region << action item: wv_back_button >> { var actionItem = new ActionItem(); actionItem.Name = "wv_back_button"; actionItem.Menu = "sidebar-top"; actionItem.Weight = Decimal.Parse("1.0"); actionItem.Template = @"<a class=""back clearfix"" href=""javascript:void(0)"" ng-click=""sidebarData.goBack()""><i class=""fa fa-fw fa-arrow-left""></i> <span class=""text"">Back</span></a>"; createViewInput.ActionItems.Add(actionItem); } #endregion } #endregion #region << Sidebar >> createViewInput.Sidebar = new InputRecordViewSidebar(); createViewInput.Sidebar.CssClass = ""; createViewInput.Sidebar.Render = true; createViewInput.Sidebar.Items = new List<InputRecordViewSidebarItemBase>(); #endregion { var response = entMan.UpdateRecordView(new Guid("7821ece9-42ce-470b-84d4-afc9eb35aa32"), createViewInput); if (!response.Success) throw new Exception("System error 10060. Entity: wv_project Updated view: admin_create Message:" + response.Message); } } #endregion #region << Update Entity: wv_project View: admin_details >> { var updateViewEntity = entMan.ReadEntity(new Guid("7821ece9-42ce-470b-84d4-afc9eb35aa32")).Object; var createViewInput = new InputRecordView(); #region << details >> createViewInput.Id = updateViewEntity.RecordViews.SingleOrDefault(x => x.Name == "admin_details").Id; createViewInput.Type = "Hidden"; createViewInput.Name = "admin_details"; createViewInput.Label = "Project details"; createViewInput.Title = ""; createViewInput.Default = false; createViewInput.System = true; createViewInput.Weight = Decimal.Parse("10.0"); createViewInput.CssClass = null; createViewInput.IconName = "product-hunt"; createViewInput.DynamicHtmlTemplate = null; createViewInput.DataSourceUrl = null; createViewInput.ServiceCode = null; #endregion #region << regions >> createViewInput.Regions = new List<InputRecordViewRegion>(); #region << Region: header >> { var viewRegion = new InputRecordViewRegion(); viewRegion.Name = "header"; viewRegion.Label = "Header"; viewRegion.Render = true; viewRegion.Weight = Decimal.Parse("1.0"); viewRegion.CssClass = ""; viewRegion.Sections = new List<InputRecordViewSection>(); #region << Section: details >> { var viewSection = new InputRecordViewSection(); viewSection.Id = new Guid("6f8fdcc2-8a8f-4cf6-bf26-47bf1c6f0438"); viewSection.Name = "details"; viewSection.Label = "Details"; viewSection.ShowLabel = false; viewSection.CssClass = ""; viewSection.Collapsed = false; viewSection.TabOrder = "left-right"; viewSection.Weight = Decimal.Parse("1.0"); viewSection.Rows = new List<InputRecordViewRow>(); #region << Row 1>> { var viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("ca9aedde-ce06-4c57-8942-8a346d594535"); viewRow.Weight = Decimal.Parse("1.0"); viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> { var viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = Int32.Parse("4"); viewColumn.Items = new List<InputRecordViewItemBase>(); #region << code >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("7821ece9-42ce-470b-84d4-afc9eb35aa32"); viewItem.EntityName = "wv_project"; viewItem.FieldId = new Guid("d9c6a939-e2e3-4617-900e-e056f0638fa8"); viewItem.FieldName = "code"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); } #endregion #region << Column 2 >> { var viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = Int32.Parse("8"); viewColumn.Items = new List<InputRecordViewItemBase>(); #region << name >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("7821ece9-42ce-470b-84d4-afc9eb35aa32"); viewItem.EntityName = "wv_project"; viewItem.FieldId = new Guid("d13427b7-e518-4305-b2cc-bc814a299b55"); viewItem.FieldName = "name"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); } #endregion //Save row viewSection.Rows.Add(viewRow); } #endregion #region << Row 2>> { var viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("5d7ce054-f592-41e7-b8f1-424cfd6d38b7"); viewRow.Weight = Decimal.Parse("2.0"); viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> { var viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = Int32.Parse("12"); viewColumn.Items = new List<InputRecordViewItemBase>(); #region << description >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("7821ece9-42ce-470b-84d4-afc9eb35aa32"); viewItem.EntityName = "wv_project"; viewItem.FieldId = new Guid("d5e2c42c-c0b8-4f03-92e0-e91bede1e7b3"); viewItem.FieldName = "description"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); } #endregion //Save row viewSection.Rows.Add(viewRow); } #endregion #region << Row 3>> { var viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("22d11cfc-a763-472b-b509-7ddfe36476bb"); viewRow.Weight = Decimal.Parse("3.0"); viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> { var viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = Int32.Parse("6"); viewColumn.Items = new List<InputRecordViewItemBase>(); #region << field from Relation: username >> { var viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = new Guid("b9cebc3b-6443-452a-8e34-b311a73dcc8b"); viewItemFromRelation.EntityName = "user"; viewItemFromRelation.Type = "fieldFromRelation"; viewItemFromRelation.FieldId = new Guid("263c0b21-88c1-4c2b-80b4-db7402b0d2e2"); viewItemFromRelation.FieldName = "username"; viewItemFromRelation.FieldLabel = "Owner / Project manager"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldHelpText = null; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = new Guid("0cad07c3-73bd-4c1f-a5d6-552256f679a4"); viewItemFromRelation.RelationName = "user_1_n_project_owner"; viewColumn.Items.Add(viewItemFromRelation); } #endregion #region << field from Relation: name >> { var viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = new Guid("c4541fee-fbb6-4661-929e-1724adec285a"); viewItemFromRelation.EntityName = "role"; viewItemFromRelation.Type = "fieldFromRelation"; viewItemFromRelation.FieldId = new Guid("36f91ebd-5a02-4032-8498-b7f716f6a349"); viewItemFromRelation.FieldName = "name"; viewItemFromRelation.FieldLabel = "Project team roles"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldHelpText = null; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = new Guid("4860a4b6-d07e-416f-b548-60491607e93f"); viewItemFromRelation.RelationName = "role_n_n_project_team"; viewColumn.Items.Add(viewItemFromRelation); } #endregion #region << start_date >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("7821ece9-42ce-470b-84d4-afc9eb35aa32"); viewItem.EntityName = "wv_project"; viewItem.FieldId = new Guid("417ce7d7-a472-499b-8e70-43a1cb54723d"); viewItem.FieldName = "start_date"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << billable_hour_price >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("7821ece9-42ce-470b-84d4-afc9eb35aa32"); viewItem.EntityName = "wv_project"; viewItem.FieldId = new Guid("7179f4ab-0376-4ded-a334-a21ff451538e"); viewItem.FieldName = "billable_hour_price"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); } #endregion #region << Column 2 >> { var viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = Int32.Parse("6"); viewColumn.Items = new List<InputRecordViewItemBase>(); #region << field from Relation: name >> { var viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = new Guid("90bcdb47-2cde-4137-a412-0198348fecc0"); viewItemFromRelation.EntityName = "wv_customer"; viewItemFromRelation.Type = "fieldFromRelation"; viewItemFromRelation.FieldId = new Guid("7fb95d0f-ab59-421d-974d-ab357e28a1f9"); viewItemFromRelation.FieldName = "name"; viewItemFromRelation.FieldLabel = "Customer"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldHelpText = null; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = new Guid("d7f1ec35-9f59-4d75-b8a2-554c7eaeab11"); viewItemFromRelation.RelationName = "customer_1_n_project"; viewColumn.Items.Add(viewItemFromRelation); } #endregion #region << field from Relation: name >> { var viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = new Guid("c4541fee-fbb6-4661-929e-1724adec285a"); viewItemFromRelation.EntityName = "role"; viewItemFromRelation.Type = "fieldFromRelation"; viewItemFromRelation.FieldId = new Guid("36f91ebd-5a02-4032-8498-b7f716f6a349"); viewItemFromRelation.FieldName = "name"; viewItemFromRelation.FieldLabel = "Project customer roles"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldHelpText = null; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = new Guid("e6d75feb-3c8f-410b-9ff4-54ef8489dc2f"); viewItemFromRelation.RelationName = "role_n_n_project_customer"; viewColumn.Items.Add(viewItemFromRelation); } #endregion #region << end_date >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("7821ece9-42ce-470b-84d4-afc9eb35aa32"); viewItem.EntityName = "wv_project"; viewItem.FieldId = new Guid("57198778-636d-47ec-b33e-edfc5705cc05"); viewItem.FieldName = "end_date"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); } #endregion //Save row viewSection.Rows.Add(viewRow); } #endregion //Save section viewRegion.Sections.Add(viewSection); } #endregion //Save region createViewInput.Regions.Add(viewRegion); } #endregion #endregion #region << Relation options >> { createViewInput.RelationOptions = new List<EntityRelationOptionsItem>(); } #endregion #region << Action items >> { createViewInput.ActionItems = new List<ActionItem>(); #region << action item: wv_record_delete >> { var actionItem = new ActionItem(); actionItem.Name = "wv_record_delete"; actionItem.Menu = "page-title-dropdown"; actionItem.Weight = Decimal.Parse("1.0"); actionItem.Template = @"<a href=""javascript:void(0)"" confirmed-click=""ngCtrl.deleteRecord(ngCtrl)"" ng-confirm-click=""Are you sure?"" ng-if=""::ngCtrl.userHasRecordPermissions('canDelete')""> <i class=""fa fa-trash go-red""></i> Delete Record </a>"; createViewInput.ActionItems.Add(actionItem); } #endregion #region << action item: wv_back_button >> { var actionItem = new ActionItem(); actionItem.Name = "wv_back_button"; actionItem.Menu = "sidebar-top"; actionItem.Weight = Decimal.Parse("1.0"); actionItem.Template = @"<a class=""back clearfix"" href=""javascript:void(0)"" ng-click=""sidebarData.goBack()""><i class=""fa fa-fw fa-arrow-left""></i> <span class=""text"">Back</span></a>"; createViewInput.ActionItems.Add(actionItem); } #endregion } #endregion #region << Sidebar >> createViewInput.Sidebar = new InputRecordViewSidebar(); createViewInput.Sidebar.CssClass = ""; createViewInput.Sidebar.Render = true; createViewInput.Sidebar.Items = new List<InputRecordViewSidebarItemBase>(); #endregion { var response = entMan.UpdateRecordView(new Guid("7821ece9-42ce-470b-84d4-afc9eb35aa32"), createViewInput); if (!response.Success) throw new Exception("System error 10060. Entity: wv_project Updated view: admin_details Message:" + response.Message); } } #endregion #region << Update Entity: wv_bug name: all_bugs >> { var createListEntity = entMan.ReadEntity(new Guid("c11655fa-e4a3-4c2b-8f1e-0a6d87cfd20c")).Object; var createListInput = new InputRecordList(); #region << details >> createListInput.Id = createListEntity.RecordLists.SingleOrDefault(x => x.Name == "all_bugs").Id; createListInput.Type = "General"; createListInput.Name = "all_bugs"; createListInput.Label = "All Bugs"; createListInput.Title = ""; createListInput.Weight = Decimal.Parse("12.0"); createListInput.Default = false; createListInput.System = true; createListInput.CssClass = "bug-list"; createListInput.IconName = "bug"; createListInput.VisibleColumnsCount = Int32.Parse("7"); createListInput.ColumnWidthsCSV = "100px,auto,30px,120px,120px,120px,120px"; createListInput.PageSize = Int32.Parse("10"); createListInput.DynamicHtmlTemplate = null; createListInput.DataSourceUrl = "/plugins/webvella-projects/api/bug/list/all"; createListInput.ServiceCode = null; #endregion #region << Relation options >> { createListInput.RelationOptions = new List<EntityRelationOptionsItem>(); } #endregion #region << Action items >> { createListInput.ActionItems = new List<ActionItem>(); #region << action item: wv_record_details >> { var actionItem = new ActionItem(); actionItem.Name = "wv_record_details"; actionItem.Menu = "record-row"; actionItem.Weight = Decimal.Parse("1.0"); actionItem.Template = @"<a class=""btn btn-default btn-outline"" ng-href=""{{::ngCtrl.getRecordDetailsUrl(record, ngCtrl)}}""> <i class=""fa fa-fw fa-eye""></i> </a>"; createListInput.ActionItems.Add(actionItem); } #endregion #region << action item: wv_create_record >> { var actionItem = new ActionItem(); actionItem.Name = "wv_create_record"; actionItem.Menu = "page-title"; actionItem.Weight = Decimal.Parse("1.0"); actionItem.Template = @"<a class=""btn btn-default btn-outline hidden-xs"" ng-show=""::ngCtrl.userHasRecordPermissions('canCreate')"" ng-href=""{{::ngCtrl.getRecordCreateUrl(ngCtrl)}}"">Add New</a>"; createListInput.ActionItems.Add(actionItem); } #endregion } #endregion #region << Columns >> { createListInput.Columns = new List<InputRecordListItemBase>(); #region << code >> { var listField = new InputRecordListFieldItem(); listField.EntityId = new Guid("c11655fa-e4a3-4c2b-8f1e-0a6d87cfd20c"); listField.EntityName = "wv_bug"; listField.FieldId = new Guid("6f2030e9-edd7-42ac-bb2a-2766b76c3da1"); listField.FieldName = "code"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << subject >> { var listField = new InputRecordListFieldItem(); listField.EntityId = new Guid("c11655fa-e4a3-4c2b-8f1e-0a6d87cfd20c"); listField.EntityName = "wv_bug"; listField.FieldId = new Guid("335a4500-130e-4739-b774-2f53f33ea22a"); listField.FieldName = "subject"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << field from Relation: image >> { var listItemFromRelation = new InputRecordListRelationFieldItem(); listItemFromRelation.EntityId = new Guid("b9cebc3b-6443-452a-8e34-b311a73dcc8b"); listItemFromRelation.EntityName = "user"; listItemFromRelation.Type = "fieldFromRelation"; listItemFromRelation.FieldId = new Guid("bf199b74-4448-4f58-93f5-6b86d888843b"); listItemFromRelation.FieldName = "image"; listItemFromRelation.FieldLabel = "Owner"; listItemFromRelation.FieldPlaceholder = null; listItemFromRelation.FieldHelpText = null; listItemFromRelation.FieldRequired = false; listItemFromRelation.FieldLookupList = null; listItemFromRelation.RelationId = new Guid("cddc10b6-30ff-4a86-96e4-645b3ea59fd9"); listItemFromRelation.RelationName = "user_1_n_bug_owner"; createListInput.Columns.Add(listItemFromRelation); } #endregion #region << status >> { var listField = new InputRecordListFieldItem(); listField.EntityId = new Guid("c11655fa-e4a3-4c2b-8f1e-0a6d87cfd20c"); listField.EntityName = "wv_bug"; listField.FieldId = new Guid("48be1e6e-df47-46f0-b4e1-6e9e1cbaf71c"); listField.FieldName = "status"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << priority >> { var listField = new InputRecordListFieldItem(); listField.EntityId = new Guid("c11655fa-e4a3-4c2b-8f1e-0a6d87cfd20c"); listField.EntityName = "wv_bug"; listField.FieldId = new Guid("e506dfc7-6d49-4d00-9f61-8befd56c1a6e"); listField.FieldName = "priority"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion } #endregion #region << Query >> { createListInput.Query = new InputRecordListQuery(); var queryDictionary = new Dictionary<Guid,InputRecordListQuery>(); var subQueryDictionary = new Dictionary<Guid,List<InputRecordListQuery>>(); //Main query rule createListInput.Query.FieldName = null; createListInput.Query.FieldValue = null; createListInput.Query.QueryType = "AND"; createListInput.Query.SubQueries = new List<InputRecordListQuery>(); { queryDictionary[new Guid("0137bb5c-b9e6-42eb-a3d3-4b954203205b")] = new InputRecordListQuery(); queryDictionary[new Guid("0137bb5c-b9e6-42eb-a3d3-4b954203205b")].FieldName = "code"; queryDictionary[new Guid("0137bb5c-b9e6-42eb-a3d3-4b954203205b")].FieldValue = "{\"name\":\"url_query\", \"option\": \"code\", \"default\": null, \"settings\":{}}"; queryDictionary[new Guid("0137bb5c-b9e6-42eb-a3d3-4b954203205b")].QueryType = "CONTAINS"; queryDictionary[new Guid("0137bb5c-b9e6-42eb-a3d3-4b954203205b")].SubQueries = new List<InputRecordListQuery>(); if(subQueryDictionary.ContainsKey(new Guid("0137bb5c-b9e6-42eb-a3d3-4b954203205b"))) {queryDictionary[new Guid("0137bb5c-b9e6-42eb-a3d3-4b954203205b")].SubQueries = subQueryDictionary[new Guid("0137bb5c-b9e6-42eb-a3d3-4b954203205b")];} if(!subQueryDictionary.ContainsKey(new Guid("48180ab7-1e06-48e9-8aeb-7625e166a945"))) {subQueryDictionary[new Guid("48180ab7-1e06-48e9-8aeb-7625e166a945")] = new List<InputRecordListQuery>();} subQueryDictionary[new Guid("48180ab7-1e06-48e9-8aeb-7625e166a945")].Add(queryDictionary[new Guid("0137bb5c-b9e6-42eb-a3d3-4b954203205b")]); } { queryDictionary[new Guid("5172023d-a3cb-4945-af23-ff539f40b479")] = new InputRecordListQuery(); queryDictionary[new Guid("5172023d-a3cb-4945-af23-ff539f40b479")].FieldName = "subject"; queryDictionary[new Guid("5172023d-a3cb-4945-af23-ff539f40b479")].FieldValue = "{\"name\":\"url_query\", \"option\": \"subject\", \"default\": null, \"settings\":{}}"; queryDictionary[new Guid("5172023d-a3cb-4945-af23-ff539f40b479")].QueryType = "CONTAINS"; queryDictionary[new Guid("5172023d-a3cb-4945-af23-ff539f40b479")].SubQueries = new List<InputRecordListQuery>(); if(subQueryDictionary.ContainsKey(new Guid("5172023d-a3cb-4945-af23-ff539f40b479"))) {queryDictionary[new Guid("5172023d-a3cb-4945-af23-ff539f40b479")].SubQueries = subQueryDictionary[new Guid("5172023d-a3cb-4945-af23-ff539f40b479")];} if(!subQueryDictionary.ContainsKey(new Guid("48180ab7-1e06-48e9-8aeb-7625e166a945"))) {subQueryDictionary[new Guid("48180ab7-1e06-48e9-8aeb-7625e166a945")] = new List<InputRecordListQuery>();} subQueryDictionary[new Guid("48180ab7-1e06-48e9-8aeb-7625e166a945")].Add(queryDictionary[new Guid("5172023d-a3cb-4945-af23-ff539f40b479")]); } { queryDictionary[new Guid("50fd915f-aadf-4f29-9e68-5c60b7ed2f39")] = new InputRecordListQuery(); queryDictionary[new Guid("50fd915f-aadf-4f29-9e68-5c60b7ed2f39")].FieldName = "status"; queryDictionary[new Guid("50fd915f-aadf-4f29-9e68-5c60b7ed2f39")].FieldValue = "{\"name\":\"url_query\", \"option\": \"status\", \"default\": null, \"settings\":{}}"; queryDictionary[new Guid("50fd915f-aadf-4f29-9e68-5c60b7ed2f39")].QueryType = "EQ"; queryDictionary[new Guid("50fd915f-aadf-4f29-9e68-5c60b7ed2f39")].SubQueries = new List<InputRecordListQuery>(); if(subQueryDictionary.ContainsKey(new Guid("50fd915f-aadf-4f29-9e68-5c60b7ed2f39"))) {queryDictionary[new Guid("50fd915f-aadf-4f29-9e68-5c60b7ed2f39")].SubQueries = subQueryDictionary[new Guid("50fd915f-aadf-4f29-9e68-5c60b7ed2f39")];} if(!subQueryDictionary.ContainsKey(new Guid("48180ab7-1e06-48e9-8aeb-7625e166a945"))) {subQueryDictionary[new Guid("48180ab7-1e06-48e9-8aeb-7625e166a945")] = new List<InputRecordListQuery>();} subQueryDictionary[new Guid("48180ab7-1e06-48e9-8aeb-7625e166a945")].Add(queryDictionary[new Guid("50fd915f-aadf-4f29-9e68-5c60b7ed2f39")]); } { queryDictionary[new Guid("98093a42-d6cb-48e1-a2d2-d93f1bb5591e")] = new InputRecordListQuery(); queryDictionary[new Guid("98093a42-d6cb-48e1-a2d2-d93f1bb5591e")].FieldName = "priority"; queryDictionary[new Guid("98093a42-d6cb-48e1-a2d2-d93f1bb5591e")].FieldValue = "{\"name\":\"url_query\", \"option\": \"priority\", \"default\": null, \"settings\":{}}"; queryDictionary[new Guid("98093a42-d6cb-48e1-a2d2-d93f1bb5591e")].QueryType = "EQ"; queryDictionary[new Guid("98093a42-d6cb-48e1-a2d2-d93f1bb5591e")].SubQueries = new List<InputRecordListQuery>(); if(subQueryDictionary.ContainsKey(new Guid("98093a42-d6cb-48e1-a2d2-d93f1bb5591e"))) {queryDictionary[new Guid("98093a42-d6cb-48e1-a2d2-d93f1bb5591e")].SubQueries = subQueryDictionary[new Guid("98093a42-d6cb-48e1-a2d2-d93f1bb5591e")];} if(!subQueryDictionary.ContainsKey(new Guid("48180ab7-1e06-48e9-8aeb-7625e166a945"))) {subQueryDictionary[new Guid("48180ab7-1e06-48e9-8aeb-7625e166a945")] = new List<InputRecordListQuery>();} subQueryDictionary[new Guid("48180ab7-1e06-48e9-8aeb-7625e166a945")].Add(queryDictionary[new Guid("98093a42-d6cb-48e1-a2d2-d93f1bb5591e")]); } if(subQueryDictionary.ContainsKey(new Guid("48180ab7-1e06-48e9-8aeb-7625e166a945"))) {createListInput.Query.SubQueries = subQueryDictionary[new Guid("48180ab7-1e06-48e9-8aeb-7625e166a945")];} } #endregion #region << Sorts >> { createListInput.Sorts = new List<InputRecordListSort>(); #region << sort >> { var sort = new InputRecordListSort(); sort.FieldName = "{\"name\":\"url_sort\", \"option\": \"sortBy\", \"default\": \"end_date\", \"settings\":{\"order\":\"sortOrder\"}}"; sort.SortType = "Ascending"; createListInput.Sorts.Add(sort); } #endregion } #endregion { var response = entMan.UpdateRecordList(new Guid("c11655fa-e4a3-4c2b-8f1e-0a6d87cfd20c"), createListInput); if (!response.Success) throw new Exception("System error 10060. Entity: wv_bug Updated list: all_bugs Message:" + response.Message); } } #endregion #region << Update Entity: wv_sprint field: start_date >> { var currentEntity = entMan.ReadEntity(new Guid("a8de737a-9610-424d-9cf1-1b86e6cd17cd")).Object; InputDateField dateField = new InputDateField(); dateField.Id = currentEntity.Fields.SingleOrDefault(x => x.Name == "start_date").Id; dateField.Name = "start_date"; dateField.Label = "Start date"; dateField.PlaceholderText = ""; dateField.Description = ""; dateField.HelpText = ""; dateField.Required = true; dateField.Unique = false; dateField.Searchable = true; dateField.Auditable = false; dateField.System = true; dateField.DefaultValue = DateTime.Parse("11/30/2015 10:00:00 PM"); dateField.Format = "yyyy-MMM-dd"; dateField.UseCurrentTimeAsDefaultValue = false; dateField.EnableSecurity = false; dateField.Permissions = new FieldPermissions(); dateField.Permissions.CanRead = new List<Guid>(); dateField.Permissions.CanUpdate = new List<Guid>(); //READ //UPDATE { var response = entMan.UpdateField(new Guid("a8de737a-9610-424d-9cf1-1b86e6cd17cd"), dateField); if (!response.Success) throw new Exception("System error 10060. Entity: wv_sprint Field: start_date Message:" + response.Message); } } #endregion #region << Update Entity: wv_sprint View: general >> { var updateViewEntity = entMan.ReadEntity(new Guid("a8de737a-9610-424d-9cf1-1b86e6cd17cd")).Object; var createViewInput = new InputRecordView(); #region << details >> createViewInput.Id = updateViewEntity.RecordViews.SingleOrDefault(x => x.Name == "general").Id; createViewInput.Type = "General"; createViewInput.Name = "general"; createViewInput.Label = "General"; createViewInput.Title = "{name}"; createViewInput.Default = true; createViewInput.System = false; createViewInput.Weight = Decimal.Parse("10.0"); createViewInput.CssClass = ""; createViewInput.IconName = "file-text-o"; createViewInput.DynamicHtmlTemplate = null; createViewInput.DataSourceUrl = null; createViewInput.ServiceCode = null; #endregion #region << regions >> createViewInput.Regions = new List<InputRecordViewRegion>(); #region << Region: header >> { var viewRegion = new InputRecordViewRegion(); viewRegion.Name = "header"; viewRegion.Label = "Header"; viewRegion.Render = true; viewRegion.Weight = Decimal.Parse("1.0"); viewRegion.CssClass = ""; viewRegion.Sections = new List<InputRecordViewSection>(); #region << Section: section >> { var viewSection = new InputRecordViewSection(); viewSection.Id = new Guid("f1aa9f94-1c67-4a38-bab6-6c3e9a2d9834"); viewSection.Name = "section"; viewSection.Label = "Section name"; viewSection.ShowLabel = false; viewSection.CssClass = ""; viewSection.Collapsed = false; viewSection.TabOrder = "left-right"; viewSection.Weight = Decimal.Parse("1.0"); viewSection.Rows = new List<InputRecordViewRow>(); #region << Row 1>> { var viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("9a1a6e16-9dbc-4690-9e29-52627f099e33"); viewRow.Weight = Decimal.Parse("1.0"); viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> { var viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = Int32.Parse("12"); viewColumn.Items = new List<InputRecordViewItemBase>(); #region << name >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("a8de737a-9610-424d-9cf1-1b86e6cd17cd"); viewItem.EntityName = "wv_sprint"; viewItem.FieldId = new Guid("a313b778-392d-4214-8c1a-e2a591b8a9dd"); viewItem.FieldName = "name"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); } #endregion //Save row viewSection.Rows.Add(viewRow); } #endregion #region << Row 2>> { var viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("5477e48f-1925-4881-98f9-bbc2c0e961fb"); viewRow.Weight = Decimal.Parse("2.0"); viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> { var viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = Int32.Parse("6"); viewColumn.Items = new List<InputRecordViewItemBase>(); #region << start_date >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("a8de737a-9610-424d-9cf1-1b86e6cd17cd"); viewItem.EntityName = "wv_sprint"; viewItem.FieldId = new Guid("0d2f3748-5ae8-40ab-bba2-fe5a6f249568"); viewItem.FieldName = "start_date"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << field from Relation: name >> { var viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = new Guid("c4541fee-fbb6-4661-929e-1724adec285a"); viewItemFromRelation.EntityName = "role"; viewItemFromRelation.Type = "fieldFromRelation"; viewItemFromRelation.FieldId = new Guid("36f91ebd-5a02-4032-8498-b7f716f6a349"); viewItemFromRelation.FieldName = "name"; viewItemFromRelation.FieldLabel = "Allowed roles"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldHelpText = ""; viewItemFromRelation.FieldRequired = false; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = new Guid("e77b7a71-134e-41bf-a079-008e8931303f"); viewItemFromRelation.RelationName = "role_n_n_wv_sprint"; viewColumn.Items.Add(viewItemFromRelation); } #endregion //Save column viewRow.Columns.Add(viewColumn); } #endregion #region << Column 2 >> { var viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = Int32.Parse("6"); viewColumn.Items = new List<InputRecordViewItemBase>(); #region << end_date >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("a8de737a-9610-424d-9cf1-1b86e6cd17cd"); viewItem.EntityName = "wv_sprint"; viewItem.FieldId = new Guid("63bd86c4-adac-4de1-a24a-5cb4a3a0a73f"); viewItem.FieldName = "end_date"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); } #endregion //Save row viewSection.Rows.Add(viewRow); } #endregion //Save section viewRegion.Sections.Add(viewSection); } #endregion //Save region createViewInput.Regions.Add(viewRegion); } #endregion #endregion #region << Relation options >> { createViewInput.RelationOptions = new List<EntityRelationOptionsItem>(); } #endregion #region << Action items >> { createViewInput.ActionItems = new List<ActionItem>(); #region << action item: wv_back_button >> { var actionItem = new ActionItem(); actionItem.Name = "wv_back_button"; actionItem.Menu = "sidebar-top"; actionItem.Weight = Decimal.Parse("1.0"); actionItem.Template = @"<a class=""back clearfix"" href=""javascript:void(0)"" ng-click=""sidebarData.goBack()""><i class=""fa fa-fw fa-arrow-left""></i> <span class=""text"">Back</span></a>"; createViewInput.ActionItems.Add(actionItem); } #endregion #region << action item: wv_record_delete >> { var actionItem = new ActionItem(); actionItem.Name = "wv_record_delete"; actionItem.Menu = "page-title-dropdown"; actionItem.Weight = Decimal.Parse("1.0"); actionItem.Template = @"<a href=""javascript:void(0)"" confirmed-click=""ngCtrl.deleteRecord(ngCtrl)"" ng-confirm-click=""{{'DELETE_CONFIRMATION_ALERT_MESSAGE' | translate}}"" ng-if=""::ngCtrl.userHasRecordPermissions('canDelete')""> <i class=""fa fa-trash go-red""></i> Delete Record </a>"; createViewInput.ActionItems.Add(actionItem); } #endregion } #endregion #region << Sidebar >> createViewInput.Sidebar = new InputRecordViewSidebar(); createViewInput.Sidebar.CssClass = ""; createViewInput.Sidebar.Render = false; createViewInput.Sidebar.Items = new List<InputRecordViewSidebarItemBase>(); #endregion { var response = entMan.UpdateRecordView(new Guid("a8de737a-9610-424d-9cf1-1b86e6cd17cd"), createViewInput); if (!response.Success) throw new Exception("System error 10060. Entity: wv_sprint Updated view: general Message:" + response.Message); } } #endregion #region << Update Entity: wv_sprint View: create >> { var updateViewEntity = entMan.ReadEntity(new Guid("a8de737a-9610-424d-9cf1-1b86e6cd17cd")).Object; var createViewInput = new InputRecordView(); #region << details >> createViewInput.Id = updateViewEntity.RecordViews.SingleOrDefault(x => x.Name == "create").Id; createViewInput.Type = "Create"; createViewInput.Name = "create"; createViewInput.Label = "create"; createViewInput.Title = "Create sprint"; createViewInput.Default = true; createViewInput.System = false; createViewInput.Weight = Decimal.Parse("10.0"); createViewInput.CssClass = ""; createViewInput.IconName = "file-text-o"; createViewInput.DynamicHtmlTemplate = null; createViewInput.DataSourceUrl = null; createViewInput.ServiceCode = null; #endregion #region << regions >> createViewInput.Regions = new List<InputRecordViewRegion>(); #region << Region: header >> { var viewRegion = new InputRecordViewRegion(); viewRegion.Name = "header"; viewRegion.Label = "Header"; viewRegion.Render = true; viewRegion.Weight = Decimal.Parse("1.0"); viewRegion.CssClass = ""; viewRegion.Sections = new List<InputRecordViewSection>(); #region << Section: section >> { var viewSection = new InputRecordViewSection(); viewSection.Id = new Guid("f1aa9f94-1c67-4a38-bab6-6c3e9a2d9834"); viewSection.Name = "section"; viewSection.Label = "Section name"; viewSection.ShowLabel = false; viewSection.CssClass = ""; viewSection.Collapsed = false; viewSection.TabOrder = "left-right"; viewSection.Weight = Decimal.Parse("1.0"); viewSection.Rows = new List<InputRecordViewRow>(); #region << Row 1>> { var viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("9a1a6e16-9dbc-4690-9e29-52627f099e33"); viewRow.Weight = Decimal.Parse("1.0"); viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> { var viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = Int32.Parse("12"); viewColumn.Items = new List<InputRecordViewItemBase>(); #region << name >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("a8de737a-9610-424d-9cf1-1b86e6cd17cd"); viewItem.EntityName = "wv_sprint"; viewItem.FieldId = new Guid("a313b778-392d-4214-8c1a-e2a591b8a9dd"); viewItem.FieldName = "name"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); } #endregion //Save row viewSection.Rows.Add(viewRow); } #endregion #region << Row 2>> { var viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("5477e48f-1925-4881-98f9-bbc2c0e961fb"); viewRow.Weight = Decimal.Parse("2.0"); viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> { var viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = Int32.Parse("6"); viewColumn.Items = new List<InputRecordViewItemBase>(); #region << start_date >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("a8de737a-9610-424d-9cf1-1b86e6cd17cd"); viewItem.EntityName = "wv_sprint"; viewItem.FieldId = new Guid("0d2f3748-5ae8-40ab-bba2-fe5a6f249568"); viewItem.FieldName = "start_date"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << field from Relation: name >> { var viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = new Guid("c4541fee-fbb6-4661-929e-1724adec285a"); viewItemFromRelation.EntityName = "role"; viewItemFromRelation.Type = "fieldFromRelation"; viewItemFromRelation.FieldId = new Guid("36f91ebd-5a02-4032-8498-b7f716f6a349"); viewItemFromRelation.FieldName = "name"; viewItemFromRelation.FieldLabel = "Allowed roles"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldHelpText = ""; viewItemFromRelation.FieldRequired = false; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = new Guid("e77b7a71-134e-41bf-a079-008e8931303f"); viewItemFromRelation.RelationName = "role_n_n_wv_sprint"; viewColumn.Items.Add(viewItemFromRelation); } #endregion //Save column viewRow.Columns.Add(viewColumn); } #endregion #region << Column 2 >> { var viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = Int32.Parse("6"); viewColumn.Items = new List<InputRecordViewItemBase>(); #region << end_date >> { var viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = new Guid("a8de737a-9610-424d-9cf1-1b86e6cd17cd"); viewItem.EntityName = "wv_sprint"; viewItem.FieldId = new Guid("63bd86c4-adac-4de1-a24a-5cb4a3a0a73f"); viewItem.FieldName = "end_date"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); } #endregion //Save row viewSection.Rows.Add(viewRow); } #endregion //Save section viewRegion.Sections.Add(viewSection); } #endregion //Save region createViewInput.Regions.Add(viewRegion); } #endregion #endregion #region << Relation options >> { createViewInput.RelationOptions = new List<EntityRelationOptionsItem>(); } #endregion #region << Action items >> { createViewInput.ActionItems = new List<ActionItem>(); #region << action item: wv_create_and_list >> { var actionItem = new ActionItem(); actionItem.Name = "wv_create_and_list"; actionItem.Menu = "create-bottom"; actionItem.Weight = Decimal.Parse("1.0"); actionItem.Template = @"<a class=""btn btn-primary"" ng-click='ngCtrl.create(""default"")' ng-if=""::ngCtrl.createViewRegion != null"">Create</a>"; createViewInput.ActionItems.Add(actionItem); } #endregion #region << action item: wv_back_button >> { var actionItem = new ActionItem(); actionItem.Name = "wv_back_button"; actionItem.Menu = "sidebar-top"; actionItem.Weight = Decimal.Parse("1.0"); actionItem.Template = @"<a class=""back clearfix"" href=""javascript:void(0)"" ng-click=""sidebarData.goBack()""><i class=""fa fa-fw fa-arrow-left""></i> <span class=""text"">Back</span></a>"; createViewInput.ActionItems.Add(actionItem); } #endregion #region << action item: wv_create_cancel >> { var actionItem = new ActionItem(); actionItem.Name = "wv_create_cancel"; actionItem.Menu = "create-bottom"; actionItem.Weight = Decimal.Parse("3.0"); actionItem.Template = @"<a class=""btn btn-default btn-outline"" ng-click=""ngCtrl.cancel()"">Cancel</a>"; createViewInput.ActionItems.Add(actionItem); } #endregion } #endregion #region << Sidebar >> createViewInput.Sidebar = new InputRecordViewSidebar(); createViewInput.Sidebar.CssClass = ""; createViewInput.Sidebar.Render = false; createViewInput.Sidebar.Items = new List<InputRecordViewSidebarItemBase>(); #endregion { var response = entMan.UpdateRecordView(new Guid("a8de737a-9610-424d-9cf1-1b86e6cd17cd"), createViewInput); if (!response.Success) throw new Exception("System error 10060. Entity: wv_sprint Updated view: create Message:" + response.Message); } } #endregion #region << Update Entity: wv_customer name: admin >> { var createListEntity = entMan.ReadEntity(new Guid("90bcdb47-2cde-4137-a412-0198348fecc0")).Object; var createListInput = new InputRecordList(); #region << details >> createListInput.Id = createListEntity.RecordLists.SingleOrDefault(x => x.Name == "admin").Id; createListInput.Type = "Hidden"; createListInput.Name = "admin"; createListInput.Label = "Customers"; createListInput.Title = null; createListInput.Weight = Decimal.Parse("11.0"); createListInput.Default = false; createListInput.System = true; createListInput.CssClass = null; createListInput.IconName = "building-o"; createListInput.VisibleColumnsCount = Int32.Parse("7"); createListInput.ColumnWidthsCSV = null; createListInput.PageSize = Int32.Parse("10"); createListInput.DynamicHtmlTemplate = null; createListInput.DataSourceUrl = null; createListInput.ServiceCode = null; #endregion #region << Relation options >> { createListInput.RelationOptions = new List<EntityRelationOptionsItem>(); } #endregion #region << Action items >> { createListInput.ActionItems = new List<ActionItem>(); #region << action item: wv_create_record >> { var actionItem = new ActionItem(); actionItem.Name = "wv_create_record"; actionItem.Menu = "page-title"; actionItem.Weight = Decimal.Parse("1.0"); actionItem.Template = @"<a class=""btn btn-default btn-outline hidden-xs"" ng-show=""::ngCtrl.userHasRecordPermissions('canCreate')"" ng-href=""{{::ngCtrl.getRecordCreateUrl(ngCtrl)}}"">Add New</a>"; createListInput.ActionItems.Add(actionItem); } #endregion #region << action item: wv_record_details >> { var actionItem = new ActionItem(); actionItem.Name = "wv_record_details"; actionItem.Menu = "record-row"; actionItem.Weight = Decimal.Parse("1.0"); actionItem.Template = @"<a class=""btn btn-default btn-outline"" ng-href=""{{::ngCtrl.getRecordDetailsUrl(record, ngCtrl)}}""> <i class=""fa fa-fw fa-eye""></i> </a>"; createListInput.ActionItems.Add(actionItem); } #endregion #region << action item: wv_export_records >> { var actionItem = new ActionItem(); actionItem.Name = "wv_export_records"; actionItem.Menu = "page-title-dropdown"; actionItem.Weight = Decimal.Parse("11.0"); actionItem.Template = @"<a ng-click=""ngCtrl.openExportModal()"" class=""ng-hide"" ng-show=""::ngCtrl.userHasRecordPermissions('canCreate,canUpdate')""> <i class=""fa fa-fw fa-download""></i> Export CSV </a>"; createListInput.ActionItems.Add(actionItem); } #endregion } #endregion #region << Columns >> { createListInput.Columns = new List<InputRecordListItemBase>(); #region << name >> { var listField = new InputRecordListFieldItem(); listField.EntityId = new Guid("90bcdb47-2cde-4137-a412-0198348fecc0"); listField.EntityName = "wv_customer"; listField.FieldId = new Guid("7fb95d0f-ab59-421d-974d-ab357e28a1f9"); listField.FieldName = "name"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion } #endregion #region << Query >> { createListInput.Query = new InputRecordListQuery(); var queryDictionary = new Dictionary<Guid,InputRecordListQuery>(); var subQueryDictionary = new Dictionary<Guid,List<InputRecordListQuery>>(); //Main query rule createListInput.Query.FieldName = null; createListInput.Query.FieldValue = null; createListInput.Query.QueryType = "AND"; createListInput.Query.SubQueries = new List<InputRecordListQuery>(); { queryDictionary[new Guid("8a8380ab-b6eb-4d55-bf94-a7be70e8d37e")] = new InputRecordListQuery(); queryDictionary[new Guid("8a8380ab-b6eb-4d55-bf94-a7be70e8d37e")].FieldName = "name"; queryDictionary[new Guid("8a8380ab-b6eb-4d55-bf94-a7be70e8d37e")].FieldValue = "{\"name\":\"url_query\", \"option\": \"name\", \"default\": null, \"settings\":{}}"; queryDictionary[new Guid("8a8380ab-b6eb-4d55-bf94-a7be70e8d37e")].QueryType = "CONTAINS"; queryDictionary[new Guid("8a8380ab-b6eb-4d55-bf94-a7be70e8d37e")].SubQueries = new List<InputRecordListQuery>(); if(subQueryDictionary.ContainsKey(new Guid("8a8380ab-b6eb-4d55-bf94-a7be70e8d37e"))) {queryDictionary[new Guid("8a8380ab-b6eb-4d55-bf94-a7be70e8d37e")].SubQueries = subQueryDictionary[new Guid("8a8380ab-b6eb-4d55-bf94-a7be70e8d37e")];} if(!subQueryDictionary.ContainsKey(new Guid("da2c6f8f-75ad-4ba5-847b-85f7ceecebd3"))) {subQueryDictionary[new Guid("da2c6f8f-75ad-4ba5-847b-85f7ceecebd3")] = new List<InputRecordListQuery>();} subQueryDictionary[new Guid("da2c6f8f-75ad-4ba5-847b-85f7ceecebd3")].Add(queryDictionary[new Guid("8a8380ab-b6eb-4d55-bf94-a7be70e8d37e")]); } if(subQueryDictionary.ContainsKey(new Guid("da2c6f8f-75ad-4ba5-847b-85f7ceecebd3"))) {createListInput.Query.SubQueries = subQueryDictionary[new Guid("da2c6f8f-75ad-4ba5-847b-85f7ceecebd3")];} } #endregion #region << Sorts >> { createListInput.Sorts = new List<InputRecordListSort>(); #region << sort >> { var sort = new InputRecordListSort(); sort.FieldName = "{\"name\":\"url_sort\", \"option\": \"sortBy\", \"default\": null, \"settings\":{\"order\":\"sortOrder\"}}"; sort.SortType = "Ascending"; createListInput.Sorts.Add(sort); } #endregion } #endregion { var response = entMan.UpdateRecordList(new Guid("90bcdb47-2cde-4137-a412-0198348fecc0"), createListInput); if (!response.Success) throw new Exception("System error 10060. Entity: wv_customer Updated list: admin Message:" + response.Message); } } #endregion }
public List<EntityRecord> GetListRecords(List<Entity> entities, Entity entity, string listName, int? page = null, QueryObject queryObj = null, int? pageSize = null, bool export = false, EntityRelation auxRelation = null, Guid? auxRelatedRecordId = null, string auxRelationDirection = "origin-target", List<KeyValuePair<string, string>> overwriteArgs = null, bool returnAllRecords = false) { if (entity == null) throw new Exception($"Entity '{entity.Name}' do not exist"); RecordList list = null; if (entity != null && entity.RecordLists != null) list = entity.RecordLists.FirstOrDefault(l => l.Name == listName); if (list == null) throw new Exception($"Entity '{entity.Name}' do not have list named '{listName}'"); //List<KeyValuePair<string, string>> queryStringOverwriteParameters = new List<KeyValuePair<string, string>>(); //foreach (var key in Request.Query.Keys) // queryStringOverwriteParameters.Add(new KeyValuePair<string, string>(key, Request.Query[key])); EntityQuery resultQuery = new EntityQuery(entity.Name, "*", queryObj, null, null, null, overwriteArgs); EntityRelationManager relManager = new EntityRelationManager(); EntityRelationListResponse relListResponse = relManager.Read(); List<EntityRelation> relationList = new List<EntityRelation>(); if (relListResponse.Object != null) relationList = relListResponse.Object; if (list != null) { List<QuerySortObject> sortList = new List<QuerySortObject>(); if (list.Sorts != null && list.Sorts.Count > 0) { foreach (var sort in list.Sorts) { QuerySortType sortType; if (Enum.TryParse<QuerySortType>(sort.SortType, true, out sortType)) sortList.Add(new QuerySortObject(sort.FieldName, sortType)); } resultQuery.Sort = sortList.ToArray(); } if (list.Query != null) { var listQuery = RecordListQuery.ConvertQuery(list.Query); if (queryObj != null) { //if (queryObj.SubQueries != null && queryObj.SubQueries.Any()) // queryObj.SubQueries.Add(listQuery); //else queryObj = EntityQuery.QueryAND(listQuery, queryObj); } else queryObj = listQuery; resultQuery.Query = queryObj; } if (auxRelation != null && auxRelatedRecordId != null) { string relationField = $"${auxRelation.Name}.id"; if (auxRelationDirection == "target-origin") relationField = "$" + relationField; var auxRelQuery = EntityQuery.QueryEQ(relationField, auxRelatedRecordId); if (resultQuery.Query != null) resultQuery.Query = EntityQuery.QueryAND(resultQuery.Query, auxRelQuery); else resultQuery.Query = auxRelQuery; } string queryFields = "id,"; if (list.Columns != null) { foreach (var column in list.Columns) { if (column is RecordListFieldItem) { if (((RecordListFieldItem)column).Meta.Name != "id") queryFields += ((RecordListFieldItem)column).Meta.Name + ", "; } else if (column is RecordListRelationTreeItem) { if (export) continue; EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordListRelationTreeItem)column).RelationId); string relName = relation != null ? string.Format("${0}.", relation.Name) : ""; Guid relEntityId = relation.OriginEntityId; Guid relFieldId = relation.OriginFieldId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); Field relField = relEntity.Fields.FirstOrDefault(f => f.Id == relFieldId); var treeId = (column as RecordListRelationTreeItem).TreeId; RecordTree tree = relEntity.RecordTrees.Single(x => x.Id == treeId); var relIdField = relEntity.Fields.Single(x => x.Name == "id"); List<Guid> fieldIdsToInclude = new List<Guid>(); fieldIdsToInclude.AddRange(tree.NodeObjectProperties); if (!fieldIdsToInclude.Contains(relIdField.Id)) fieldIdsToInclude.Add(relIdField.Id); if (!fieldIdsToInclude.Contains(tree.NodeNameFieldId)) fieldIdsToInclude.Add(tree.NodeNameFieldId); if (!fieldIdsToInclude.Contains(tree.NodeLabelFieldId)) fieldIdsToInclude.Add(tree.NodeLabelFieldId); if (!fieldIdsToInclude.Contains(relField.Id)) fieldIdsToInclude.Add(relField.Id); foreach (var fieldId in fieldIdsToInclude) { var f = relEntity.Fields.SingleOrDefault(x => x.Id == fieldId); if (f != null) { string qFieldName = string.Format("{0}{1},", relName, f.Name); if (!queryFields.Contains(qFieldName)) queryFields += qFieldName; } } //always add target field in query, its value may be required for relative view and list Field field = entity.Fields.FirstOrDefault(f => f.Id == relation.TargetFieldId); queryFields += field.Name + ", "; } else if (column is RecordListRelationFieldItem) { string targetOriginPrefix = ""; if (list.RelationOptions != null) { var options = list.RelationOptions.SingleOrDefault(x => x.RelationId == ((RecordListRelationFieldItem)column).RelationId); if (options != null && options.Direction == "target-origin") targetOriginPrefix = "$"; } EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordListRelationFieldItem)column).RelationId); queryFields += string.Format(targetOriginPrefix + "${0}.{1}, ", relation.Name, ((RecordListRelationFieldItem)column).Meta.Name); //add ID field automatically if not added if (!queryFields.Contains(string.Format(targetOriginPrefix + "${0}.id", relation.Name))) queryFields += string.Format(targetOriginPrefix + "${0}.id,", relation.Name); //always add origin field in query, its value may be required for relative view and list Guid fieldId = entity.Id == relation.OriginEntityId ? relation.OriginFieldId : relation.TargetFieldId; Field field = entity.Fields.FirstOrDefault(f => f.Id == fieldId); queryFields += field.Name + ", "; } else if (column is RecordListListItem || column is RecordListViewItem) { if (export) continue; if (!queryFields.Contains(" id, ") && !queryFields.StartsWith("id,")) queryFields += "id, "; } else if (column is RecordListRelationListItem) { if (export) continue; EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordListRelationListItem)column).RelationId); string targetOriginPrefix = ""; if (list.RelationOptions != null) { var options = list.RelationOptions.SingleOrDefault(x => x.RelationId == ((RecordListRelationListItem)column).RelationId); if (options != null && options.Direction == "target-origin") targetOriginPrefix = "$"; } string relName = relation != null ? string.Format(targetOriginPrefix + "${0}.", relation.Name) : ""; Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Guid relFieldId = entity.Id == relation.OriginEntityId ? relation.TargetFieldId : relation.OriginFieldId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); Field relField = relEntity.Fields.FirstOrDefault(f => f.Id == relFieldId); string queryFieldName = string.Format("{0}{1}, ", relName, relField.Name); if (!queryFields.Contains(queryFieldName)) queryFields += queryFieldName; //always add origin field in query, its value may be required for relative view and list Guid fieldId = entity.Id == relation.OriginEntityId ? relation.OriginFieldId : relation.TargetFieldId; Field field = entity.Fields.FirstOrDefault(f => f.Id == fieldId); queryFields += field.Name + ", "; } else if (column is RecordListRelationViewItem) { if (export) continue; EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordListRelationViewItem)column).RelationId); string targetOriginPrefix = ""; if (list.RelationOptions != null) { var options = list.RelationOptions.SingleOrDefault(x => x.RelationId == ((RecordListRelationViewItem)column).RelationId); if (options != null && options.Direction == "target-origin") targetOriginPrefix = "$"; } string relName = relation != null ? string.Format(targetOriginPrefix + "${0}.", relation.Name) : ""; Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Guid relFieldId = entity.Id == relation.OriginEntityId ? relation.TargetFieldId : relation.OriginFieldId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); Field relField = relEntity.Fields.FirstOrDefault(f => f.Id == relFieldId); string queryFieldName = string.Format("{0}{1}, ", relName, relField.Name); if (!queryFields.Contains(queryFieldName)) queryFields += queryFieldName; //always add origin field in query, its value may be required for relative view and list Guid fieldId = entity.Id == relation.OriginEntityId ? relation.OriginFieldId : relation.TargetFieldId; Field field = entity.Fields.FirstOrDefault(f => f.Id == fieldId); queryFields += field.Name + ", "; } } if (queryFields.EndsWith(", ")) queryFields = queryFields.Remove(queryFields.Length - 2); resultQuery.Fields = queryFields; } if (returnAllRecords) { resultQuery.Skip = null; resultQuery.Limit = null; } else { if (!pageSize.HasValue) pageSize = list.PageSize; if (pageSize.Value > 0) { resultQuery.Limit = pageSize.Value; if (page != null && page > 0) resultQuery.Skip = (page - 1) * resultQuery.Limit; } } } List<EntityRecord> resultDataList = new List<EntityRecord>(); QueryResponse result = Find(resultQuery); if (!result.Success) if (result.Errors.Count > 0) { throw new Exception(result.Message + ". Reason: " + result.Errors[0].Message); } else { throw new Exception(result.Message); } if (list != null) { foreach (var record in result.Object.Data) { EntityRecord dataRecord = new EntityRecord(); //always add id value dataRecord["id"] = record["id"]; foreach (var column in list.Columns) { if (column is RecordListFieldItem) { dataRecord[column.DataName] = record[((RecordListFieldItem)column).FieldName]; } else if (column is RecordListRelationFieldItem) { string propName = string.Format("${0}", ((RecordListRelationFieldItem)column).RelationName); List<EntityRecord> relFieldRecords = (List<EntityRecord>)record[propName]; string idDataName = "$field" + propName + "$id"; if (!dataRecord.Properties.ContainsKey(idDataName)) { List<object> idFieldRecord = new List<object>(); if (relFieldRecords != null) { foreach (var relFieldRecord in relFieldRecords) idFieldRecord.Add(relFieldRecord["id"]); } dataRecord[idDataName] = idFieldRecord; } List<object> resultFieldRecord = new List<object>(); if (relFieldRecords != null) { foreach (var relFieldRecord in relFieldRecords) { resultFieldRecord.Add(relFieldRecord[((RecordListRelationFieldItem)column).FieldName]); } } dataRecord[column.DataName] = resultFieldRecord; } else if (column is RecordListListItem) { if (export) continue; dataRecord[column.DataName] = GetListRecords(entities, entity, ((RecordListListItem)column).ListName); } else if (column is RecordListRelationListItem) { if (export) continue; EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordListRelationListItem)column).RelationId); string relName = string.Format("${0}", relation.Name); Guid fieldId = entity.Id == relation.OriginEntityId ? relation.OriginFieldId : relation.TargetFieldId; Field field = entity.Fields.FirstOrDefault(f => f.Id == fieldId); Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Guid relFieldId = entity.Id == relation.OriginEntityId ? relation.TargetFieldId : relation.OriginFieldId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); Field relField = relEntity.Fields.FirstOrDefault(f => f.Id == relFieldId); var relatedRecords = record["$" + relation.Name] as List<EntityRecord>; List<QueryObject> queries = new List<QueryObject>(); foreach (var relatedRecord in relatedRecords) queries.Add(EntityQuery.QueryEQ(relField.Name, relatedRecord[relField.Name])); if (queries.Count > 0) { QueryObject subListQueryObj = EntityQuery.QueryOR(queries.ToArray()); List<EntityRecord> subListResult = GetListRecords(entities, relEntity, ((RecordListRelationListItem)column).ListName, queryObj: subListQueryObj); dataRecord[((RecordListRelationListItem)column).DataName] = subListResult; } else dataRecord[((RecordListRelationListItem)column).DataName] = new List<object>(); } else if (column is RecordListViewItem) { if (export) continue; dataRecord[column.DataName] = GetViewRecords(entities, entity, ((RecordListViewItem)column).ViewName, "id", record["id"]); } else if (column is RecordListRelationTreeItem) { if (export) continue; EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordListRelationTreeItem)column).RelationId); string relName = string.Format("${0}", relation.Name); Guid fieldId = entity.Id == relation.OriginEntityId ? relation.OriginFieldId : relation.TargetFieldId; Field field = entity.Fields.FirstOrDefault(f => f.Id == fieldId); Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Guid relFieldId = entity.Id == relation.OriginEntityId ? relation.TargetFieldId : relation.OriginFieldId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); Field relField = relEntity.Fields.FirstOrDefault(f => f.Id == relFieldId); var relatedRecords = record["$" + relation.Name] as List<EntityRecord>; dataRecord[((RecordListRelationTreeItem)column).DataName] = relatedRecords; } else if (column is RecordListRelationViewItem) { if (export) continue; EntityRelation relation = relationList.FirstOrDefault(r => r.Id == ((RecordListRelationViewItem)column).RelationId); string relName = string.Format("${0}", relation.Name); Guid fieldId = entity.Id == relation.OriginEntityId ? relation.OriginFieldId : relation.TargetFieldId; Field field = entity.Fields.FirstOrDefault(f => f.Id == fieldId); Guid relEntityId = entity.Id == relation.OriginEntityId ? relation.TargetEntityId : relation.OriginEntityId; Guid relFieldId = entity.Id == relation.OriginEntityId ? relation.TargetFieldId : relation.OriginFieldId; Entity relEntity = entities.FirstOrDefault(e => e.Id == relEntityId); Field relField = relEntity.Fields.FirstOrDefault(f => f.Id == relFieldId); List<EntityRecord> subViewResult = new List<EntityRecord>(); var relatedRecords = record["$" + relation.Name] as List<EntityRecord>; foreach (var relatedRecord in relatedRecords) { subViewResult.AddRange(GetViewRecords(entities, relEntity, ((RecordListRelationViewItem)column).ViewName, relField.Name, relatedRecord[relField.Name])); } dataRecord[((RecordListRelationViewItem)column).DataName] = subViewResult; } } resultDataList.Add(dataRecord); } } else { foreach (var record in result.Object.Data) { EntityRecord dataRecord = new EntityRecord(); foreach (var prop in record.Properties) { //string propName = "$field" + (prop.Key.StartsWith("$") ? prop.Key : "$" + prop.Key); string propName = prop.Key; dataRecord[propName] = record[prop.Key]; } resultDataList.Add(dataRecord); } } return resultDataList; }
public IActionResult UpdateEntityRelationRecordReverse([FromBody]InputEntityRelationRecordReverseUpdateModel model) { var recMan = new RecordManager(); var entMan = new EntityManager(); BaseResponseModel response = new BaseResponseModel { Timestamp = DateTime.UtcNow, Success = true, Errors = new List<ErrorModel>() }; if (model == null) { response.Errors.Add(new ErrorModel { Message = "Invalid model." }); response.Success = false; return DoResponse(response); } EntityRelation relation = null; if (string.IsNullOrWhiteSpace(model.RelationName)) { response.Errors.Add(new ErrorModel { Message = "Invalid relation name.", Key = "relationName" }); response.Success = false; return DoResponse(response); } else { relation = new EntityRelationManager().Read(model.RelationName).Object; if (relation == null) { response.Errors.Add(new ErrorModel { Message = "Invalid relation name. No relation with that name.", Key = "relationName" }); response.Success = false; return DoResponse(response); } } var originEntity = entMan.ReadEntity(relation.OriginEntityId).Object; var targetEntity = entMan.ReadEntity(relation.TargetEntityId).Object; var originField = originEntity.Fields.Single(x => x.Id == relation.OriginFieldId); var targetField = targetEntity.Fields.Single(x => x.Id == relation.TargetFieldId); if (model.DetachOriginFieldRecordIds != null && model.DetachOriginFieldRecordIds.Any() && originField.Required && relation.RelationType != EntityRelationType.ManyToMany) { response.Errors.Add(new ErrorModel { Message = "Cannot detach records, when origin field is required.", Key = "originFieldRecordId" }); response.Success = false; return DoResponse(response); } ////////////////////////////////////////////////////////////////////////////////////// //WEBHOOK FILTER << manage_relation_input_filter >> ////////////////////////////////////////////////////////////////////////////////////// try { //Hook for the origin entity dynamic hookFilterObj = new ExpandoObject(); hookFilterObj.record = model; hookFilterObj.direction = "target-origin"; hookFilterObj.relation = relation; hookFilterObj.originEntity = originEntity; hookFilterObj.targetEntity = targetEntity; hookFilterObj.controller = this; hookFilterObj = hooksService.ProcessFilters(SystemWebHookNames.ManageRelationInput, originEntity.Name, hookFilterObj); model = hookFilterObj.record; //Hook for the target entity hookFilterObj = new ExpandoObject(); hookFilterObj.record = model; hookFilterObj.direction = "target-origin"; hookFilterObj.relation = relation; hookFilterObj.originEntity = originEntity; hookFilterObj.targetEntity = targetEntity; hookFilterObj.controller = this; hookFilterObj = hooksService.ProcessFilters(SystemWebHookNames.ManageRelationInput, targetEntity.Name, hookFilterObj); model = hookFilterObj.record; } catch (Exception ex) { return Json(CreateErrorResponse("Plugin error in web hook manage_relation_input_filter: " + ex.Message)); }// <<< EntityQuery query = new EntityQuery(targetEntity.Name, "id," + targetField.Name, EntityQuery.QueryEQ("id", model.TargetFieldRecordId), null, null, null); QueryResponse result = recMan.Find(query); if (result.Object.Data.Count == 0) { response.Errors.Add(new ErrorModel { Message = "Target record was not found. Id=[" + model.TargetFieldRecordId + "]", Key = "targetFieldRecordId" }); response.Success = false; return DoResponse(response); } var targetRecord = result.Object.Data[0]; object targetValue = targetRecord[targetField.Name]; var attachOriginRecords = new List<EntityRecord>(); var detachOriginRecords = new List<EntityRecord>(); foreach (var originId in model.AttachOriginFieldRecordIds) { query = new EntityQuery(originEntity.Name, "id," + originField.Name, EntityQuery.QueryEQ("id", originId), null, null, null); result = recMan.Find(query); if (result.Object.Data.Count == 0) { response.Errors.Add(new ErrorModel { Message = "Attach origin record was not found. Id=[" + originEntity.Id + "]", Key = "originRecordId" }); response.Success = false; return DoResponse(response); } else if (attachOriginRecords.Any(x => (Guid)x["id"] == originId)) { response.Errors.Add(new ErrorModel { Message = "Attach origin id was duplicated. Id=[" + originEntity.Id + "]", Key = "originRecordId" }); response.Success = false; return DoResponse(response); } attachOriginRecords.Add(result.Object.Data[0]); } foreach (var originId in model.DetachOriginFieldRecordIds) { query = new EntityQuery(originEntity.Name, "id," + originField.Name, EntityQuery.QueryEQ("id", originId), null, null, null); result = recMan.Find(query); if (result.Object.Data.Count == 0) { response.Errors.Add(new ErrorModel { Message = "Detach origin record was not found. Id=[" + originEntity.Id + "]", Key = "originRecordId" }); response.Success = false; return DoResponse(response); } else if (detachOriginRecords.Any(x => (Guid)x["id"] == originId)) { response.Errors.Add(new ErrorModel { Message = "Detach origin id was duplicated. Id=[" + originEntity.Id + "]", Key = "originRecordId" }); response.Success = false; return DoResponse(response); } detachOriginRecords.Add(result.Object.Data[0]); } using (var connection = DbContext.Current.CreateConnection()) { connection.BeginTransaction(); ////////////////////////////////////////////////////////////////////////////////////// //WEBHOOK FILTER << manage_relation_pre_save_filter >> ////////////////////////////////////////////////////////////////////////////////////// try { //Hook for the origin entity dynamic hookFilterObj = new ExpandoObject(); hookFilterObj.direction = "target-origin"; hookFilterObj.attachOriginRecords = attachOriginRecords; hookFilterObj.detachOriginRecords = detachOriginRecords; hookFilterObj.targetRecord = targetRecord; hookFilterObj.originEntity = originEntity; hookFilterObj.targetEntity = targetEntity; hookFilterObj.relation = relation; hookFilterObj.controller = this; hookFilterObj = hooksService.ProcessFilters(SystemWebHookNames.ManageRelationPreSave, originEntity.Name, hookFilterObj); attachOriginRecords = hookFilterObj.attachOriginRecords; detachOriginRecords = hookFilterObj.detachOriginRecords; //Hook for the target entity hookFilterObj = new ExpandoObject(); hookFilterObj.direction = "target-origin"; hookFilterObj.attachOriginRecords = attachOriginRecords; hookFilterObj.detachOriginRecords = detachOriginRecords; hookFilterObj.targetRecord = targetRecord; hookFilterObj.originEntity = originEntity; hookFilterObj.targetEntity = targetEntity; hookFilterObj.relation = relation; hookFilterObj.controller = this; hookFilterObj = hooksService.ProcessFilters(SystemWebHookNames.ManageRelationPreSave, targetEntity.Name, hookFilterObj); attachOriginRecords = hookFilterObj.attachOriginRecords; detachOriginRecords = hookFilterObj.detachOriginRecords; } catch (Exception ex) { return Json(CreateErrorResponse("Plugin error in web hook manage_relation_pre_save_filter: " + ex.Message)); }// <<< try { switch (relation.RelationType) { case EntityRelationType.OneToOne: case EntityRelationType.OneToMany: { foreach (var record in detachOriginRecords) { record[originField.Name] = null; var updResult = recMan.UpdateRecord(originEntity, record); if (!updResult.Success) { connection.RollbackTransaction(); response.Errors = updResult.Errors; response.Message = "Origin record id=[" + record["id"] + "] detach operation failed."; response.Success = false; return DoResponse(response); } } foreach (var record in attachOriginRecords) { var patchObject = new EntityRecord(); patchObject["id"] = (Guid)record["id"]; patchObject[originField.Name] = targetValue; var updResult = recMan.UpdateRecord(originEntity, patchObject); if (!updResult.Success) { connection.RollbackTransaction(); response.Errors = updResult.Errors; response.Message = "Origin record id=[" + record["id"] + "] attach operation failed."; response.Success = false; return DoResponse(response); } } } break; case EntityRelationType.ManyToMany: { foreach (var record in detachOriginRecords) { QueryResponse updResult = recMan.RemoveRelationManyToManyRecord(relation.Id, (Guid)record[originField.Name], (Guid)targetValue ); if (!updResult.Success) { connection.RollbackTransaction(); response.Errors = updResult.Errors; response.Message = "Origin record id=[" + record["id"] + "] detach operation failed."; response.Success = false; return DoResponse(response); } } foreach (var record in attachOriginRecords) { QueryResponse updResult = recMan.CreateRelationManyToManyRecord(relation.Id, (Guid)record[originField.Name], (Guid)targetValue); if (!updResult.Success) { connection.RollbackTransaction(); response.Errors = updResult.Errors; response.Message = "Origin record id=[" + record["id"] + "] attach operation failed."; response.Success = false; return DoResponse(response); } } } break; default: { connection.RollbackTransaction(); throw new Exception("Not supported relation type"); } } connection.CommitTransaction(); } catch (Exception ex) { connection.RollbackTransaction(); response.Success = false; response.Message = ex.Message; return DoResponse(response); } } ////////////////////////////////////////////////////////////////////////////////////// //WEBHOOK ACTION << manage_relation_success_action >> ////////////////////////////////////////////////////////////////////////////////////// try { dynamic hookActionObj = new ExpandoObject(); hookActionObj.record = model; hookActionObj.result = result; hookActionObj.relation = relation; hookActionObj.controller = this; hooksService.ProcessActions(SystemWebHookNames.ManageRelationAction, originEntity.Name, hookActionObj); hookActionObj = new ExpandoObject(); hookActionObj.record = model; hookActionObj.result = result; hookActionObj.relation = relation; hookActionObj.controller = this; hooksService.ProcessActions(SystemWebHookNames.ManageRelationAction, targetEntity.Name, hookActionObj); } catch (Exception ex) { return Json(CreateErrorResponse("Plugin error in web hook create_record_success_action: " + ex.Message)); }// <<< return DoResponse(response); }
public void InitializeSystemEntities() { EntityResponse response = null; FieldResponse fieldResponse = null; EntityManager em = new EntityManager(StorageService); EntityRelationManager rm = new EntityRelationManager(StorageService); RecordManager recMan = new RecordManager(this); var transaction = recMan.CreateTransaction(); try { transaction.Begin(); IStorageSystemSettingsRepository systemSettingsRepository = StorageService.GetSystemSettingsRepository(); IStorageSystemSettings storeSystemSettings = systemSettingsRepository.Read(); Guid systemSettingsId = new Guid("F3223177-B2FF-43F5-9A4B-FF16FC67D186"); SystemSettings systemSettings = new SystemSettings(); systemSettings.Id = systemSettingsId; int currentVersion = 0; if (storeSystemSettings != null) { systemSettings = new SystemSettings(storeSystemSettings); currentVersion = systemSettings.Version; } EntityManager entityManager = new EntityManager(StorageService); //tmp code - during debug only //em.DeleteEntity(SystemIds.UserEntityId); //em.DeleteEntity(SystemIds.RoleEntityId); //rm.Delete(SystemIds.UserRoleRelationId); //currentVersion = 0; if (currentVersion < 150508) { systemSettings.Version = 150508; List<Guid> allowedRoles = new List<Guid>(); allowedRoles.Add(SystemIds.AdministratorRoleId); #region << create role entity >> { InputEntity roleEntity = new InputEntity(); roleEntity.Id = SystemIds.RoleEntityId; roleEntity.Name = "role"; roleEntity.Label = "Role"; roleEntity.LabelPlural = "Roles"; roleEntity.System = true; roleEntity.RecordPermissions = new RecordPermissions(); roleEntity.RecordPermissions.CanRead = allowedRoles; roleEntity.RecordPermissions.CanCreate = allowedRoles; roleEntity.RecordPermissions.CanUpdate = allowedRoles; roleEntity.RecordPermissions.CanDelete = allowedRoles; response = entityManager.CreateEntity(roleEntity); InputTextField nameRoleField = new InputTextField(); nameRoleField.Id = new Guid("36F91EBD-5A02-4032-8498-B7F716F6A349"); nameRoleField.Name = "name"; nameRoleField.Label = "Name"; nameRoleField.PlaceholderText = ""; nameRoleField.Description = "The name of the role"; nameRoleField.HelpText = ""; nameRoleField.Required = true; nameRoleField.Unique = false; nameRoleField.Searchable = false; nameRoleField.Auditable = false; nameRoleField.System = true; nameRoleField.DefaultValue = ""; nameRoleField.MaxLength = 200; fieldResponse = entityManager.CreateField(roleEntity.Id.Value, nameRoleField, false); InputTextField descriptionRoleField = new InputTextField(); descriptionRoleField.Id = new Guid("4A8B9E0A-1C36-40C6-972B-B19E2B5D265B"); descriptionRoleField.Name = "description"; descriptionRoleField.Label = "Description"; descriptionRoleField.PlaceholderText = ""; descriptionRoleField.Description = ""; descriptionRoleField.HelpText = ""; descriptionRoleField.Required = true; descriptionRoleField.Unique = false; descriptionRoleField.Searchable = false; descriptionRoleField.Auditable = false; descriptionRoleField.System = true; descriptionRoleField.DefaultValue = ""; descriptionRoleField.MaxLength = 200; fieldResponse = entityManager.CreateField(roleEntity.Id.Value, descriptionRoleField, false); } #endregion #region << create user entity >> { InputEntity userEntity = new InputEntity(); userEntity.Id = SystemIds.UserEntityId; userEntity.Name = "user"; userEntity.Label = "User"; userEntity.LabelPlural = "Users"; userEntity.System = true; userEntity.RecordPermissions = new RecordPermissions(); userEntity.RecordPermissions.CanRead = allowedRoles; userEntity.RecordPermissions.CanCreate = allowedRoles; userEntity.RecordPermissions.CanUpdate = allowedRoles; userEntity.RecordPermissions.CanDelete = allowedRoles; response = entityManager.CreateEntity(userEntity); InputTextField firstName = new InputTextField(); firstName.Id = new Guid("DF211549-41CC-4D11-BB43-DACA4C164411"); firstName.Name = "first_name"; firstName.Label = "First Name"; firstName.PlaceholderText = ""; firstName.Description = "First name of the user"; firstName.HelpText = ""; firstName.Required = true; firstName.Unique = false; firstName.Searchable = false; firstName.Auditable = false; firstName.System = true; firstName.DefaultValue = ""; firstName.MaxLength = 200; fieldResponse = entityManager.CreateField(userEntity.Id.Value, firstName, false); InputTextField lastName = new InputTextField(); lastName.Id = new Guid("63E685B1-B2C6-4961-B393-2B6723EBD1BF"); lastName.Name = "last_name"; lastName.Label = "Last Name"; lastName.PlaceholderText = ""; lastName.Description = "Last name of the user"; lastName.HelpText = ""; lastName.Required = true; lastName.Unique = false; lastName.Searchable = false; lastName.Auditable = false; lastName.System = true; lastName.DefaultValue = ""; lastName.MaxLength = 200; fieldResponse = entityManager.CreateField(userEntity.Id.Value, lastName, false); InputEmailField email = new InputEmailField(); email.Id = new Guid("9FC75C8F-CE80-4A64-81D7-E2BEFA5E4815"); email.Name = "email"; email.Label = "Email"; email.PlaceholderText = ""; email.Description = "Email address of the user"; email.HelpText = ""; email.Required = true; email.Unique = true; email.Searchable = false; email.Auditable = false; email.System = true; email.DefaultValue = ""; email.MaxLength = 255; fieldResponse = entityManager.CreateField(userEntity.Id.Value, email, false); InputPasswordField password = new InputPasswordField(); password.Id = new Guid("4EDE88D9-217A-4462-9300-EA0D6AFCDCEA"); password.Name = "password"; password.Label = "Password"; password.PlaceholderText = ""; password.Description = "Password for the user account"; password.HelpText = ""; password.Required = true; password.Unique = true; password.Searchable = false; password.Auditable = false; password.System = true; password.MinLength = 6; password.MaxLength = 24; password.Encrypted = true; fieldResponse = entityManager.CreateField(userEntity.Id.Value, password, false); InputDateTimeField lastLoggedIn = new InputDateTimeField(); lastLoggedIn.Id = new Guid("3C85CCEC-D526-4E47-887F-EE169D1F508D"); lastLoggedIn.Name = "last_logged_in"; lastLoggedIn.Label = "Last Logged In"; lastLoggedIn.PlaceholderText = ""; lastLoggedIn.Description = ""; lastLoggedIn.HelpText = ""; lastLoggedIn.Required = false; lastLoggedIn.Unique = true; lastLoggedIn.Searchable = false; lastLoggedIn.Auditable = true; lastLoggedIn.System = true; lastLoggedIn.DefaultValue = null; lastLoggedIn.Format = "dd MMM yyyy HH:mm:ss"; lastLoggedIn.UseCurrentTimeAsDefaultValue = true; fieldResponse = entityManager.CreateField(userEntity.Id.Value, lastLoggedIn, false); InputCheckboxField enabledField = new InputCheckboxField(); enabledField.Id = new Guid("C0C63650-7572-4252-8E4B-4E25C94897A6"); enabledField.Name = "enabled"; enabledField.Label = "Enabled"; enabledField.PlaceholderText = ""; enabledField.Description = "Shows if the user account is enabled"; enabledField.HelpText = ""; enabledField.Required = true; enabledField.Unique = false; enabledField.Searchable = false; enabledField.Auditable = false; enabledField.System = true; enabledField.DefaultValue = false; fieldResponse = entityManager.CreateField(userEntity.Id.Value, enabledField, false); InputCheckboxField verifiedUserField = new InputCheckboxField(); verifiedUserField.Id = new Guid("F1BA5069-8CC9-4E66-BCC3-60E33C79C265"); verifiedUserField.Name = "verified"; verifiedUserField.Label = "Verified"; verifiedUserField.PlaceholderText = ""; verifiedUserField.Description = "Shows if the user email is verified"; verifiedUserField.HelpText = ""; verifiedUserField.Required = true; verifiedUserField.Unique = false; verifiedUserField.Searchable = false; verifiedUserField.Auditable = false; verifiedUserField.System = true; verifiedUserField.DefaultValue = false; fieldResponse = entityManager.CreateField(userEntity.Id.Value, verifiedUserField, false); } #endregion #region << create user - role relation >> { var userEntity = em.ReadEntity(SystemIds.UserEntityId).Object; var roleEntity = em.ReadEntity(SystemIds.RoleEntityId).Object; EntityRelation userRoleRelation = new EntityRelation(); userRoleRelation.Id = SystemIds.UserRoleRelationId; userRoleRelation.Name = "user_role"; userRoleRelation.Label = "User-Role"; userRoleRelation.System = true; userRoleRelation.RelationType = EntityRelationType.ManyToMany; userRoleRelation.TargetEntityId = userEntity.Id; userRoleRelation.TargetFieldId = userEntity.Fields.Single(x => x.Name == "id").Id; userRoleRelation.OriginEntityId = roleEntity.Id; userRoleRelation.OriginFieldId = roleEntity.Fields.Single(x => x.Name == "id").Id; { var result = rm.Create(userRoleRelation); if (!result.Success) throw new Exception("CREATE USER-ROLE RELATION:" + result.Message); } } #endregion #region << create system records >> { EntityRecord user = new EntityRecord(); user["id"] = SystemIds.FirstUserId; user["first_name"] = "WebVella"; user["last_name"] = "Erp"; user["password"] = "******"; user["email"] = "*****@*****.**"; user["created_by"] = SystemIds.FirstUserId; user["last_modified_by"] = SystemIds.FirstUserId; user["created_on"] = DateTime.UtcNow; user["enabled"] = true; QueryResponse result = recMan.CreateRecord("user", user); if (!result.Success) throw new Exception("CREATE FIRST USER RECORD:" + result.Message); } { EntityRecord adminRole = new EntityRecord(); adminRole["id"] = SystemIds.AdministratorRoleId; adminRole["name"] = "Administrator"; adminRole["description"] = ""; adminRole["created_by"] = SystemIds.FirstUserId; adminRole["last_modified_by"] = SystemIds.FirstUserId; adminRole["created_on"] = DateTime.UtcNow; QueryResponse result = recMan.CreateRecord("role", adminRole); if (!result.Success) throw new Exception("CREATE ADMINITRATOR ROLE RECORD:" + result.Message); } { EntityRecord regularRole = new EntityRecord(); regularRole["id"] = SystemIds.RegularRoleId; regularRole["name"] = "Regular"; regularRole["description"] = ""; regularRole["created_by"] = SystemIds.FirstUserId; regularRole["last_modified_by"] = SystemIds.FirstUserId; regularRole["created_on"] = DateTime.UtcNow; QueryResponse result = recMan.CreateRecord("role", regularRole); if (!result.Success) throw new Exception("CREATE REGULAR ROLE RECORD:" + result.Message); } { EntityRecord guestRole = new EntityRecord(); guestRole["id"] = SystemIds.GuestRoleId; guestRole["name"] = "Guest"; guestRole["description"] = ""; guestRole["created_by"] = SystemIds.FirstUserId; guestRole["last_modified_by"] = SystemIds.FirstUserId; guestRole["created_on"] = DateTime.UtcNow; QueryResponse result = recMan.CreateRecord("role", guestRole); if (!result.Success) throw new Exception("CREATE GUEST ROLE RECORD:" + result.Message); } { QueryResponse result = recMan.CreateRelationManyToManyRecord(SystemIds.UserRoleRelationId, SystemIds.AdministratorRoleId, SystemIds.FirstUserId); if (!result.Success) throw new Exception("CREATE FIRST-USER <-> ADMINISTRATOR ROLE RELATION RECORD:" + result.Message); result = recMan.CreateRelationManyToManyRecord(SystemIds.UserRoleRelationId, SystemIds.RegularRoleId, SystemIds.FirstUserId); if (!result.Success) throw new Exception("CREATE FIRST-USER <-> REGULAR ROLE RELATION RECORD:" + result.Message); } #endregion #region << create Area entity >> { InputEntity areaEntity = new InputEntity(); areaEntity.Id = SystemIds.AreaEntityId; areaEntity.Name = "area"; areaEntity.Label = "Area"; areaEntity.LabelPlural = "areas"; areaEntity.System = true; areaEntity.IconName = "folder"; areaEntity.Weight = 10; areaEntity.RecordPermissions = new RecordPermissions(); areaEntity.RecordPermissions.CanRead = allowedRoles; areaEntity.RecordPermissions.CanCreate = allowedRoles; areaEntity.RecordPermissions.CanUpdate = allowedRoles; areaEntity.RecordPermissions.CanDelete = allowedRoles; { var createResponse = entityManager.CreateEntity(areaEntity); if (!createResponse.Success) throw new Exception("System error 10330. Message:" + createResponse.Message); } InputTextField color = new InputTextField(); color.Id = new Guid("2B4AACD9-3C34-4C44-B3A3-8AFF1520CFF6"); color.Name = "color"; color.Label = "Color"; color.PlaceholderText = ""; color.Description = ""; color.HelpText = ""; color.Required = true; color.Unique = false; color.Searchable = false; color.Auditable = false; color.System = true; color.DefaultValue = "teal"; color.MaxLength = null; { var createResponse = entityManager.CreateField(SystemIds.AreaEntityId, color, false); if (!createResponse.Success) throw new Exception("System error 10340. Message:" + createResponse.Message); } InputTextField label = new InputTextField(); label.Id = new Guid("F050E7A1-AFB7-4346-B57B-1F12B2BD5AE5"); label.Name = "label"; label.Label = "Label"; label.PlaceholderText = ""; label.Description = ""; label.HelpText = ""; label.Required = true; label.Unique = false; label.Searchable = false; label.Auditable = false; label.System = true; label.DefaultValue = "Default"; label.MaxLength = null; { var createResponse = entityManager.CreateField(SystemIds.AreaEntityId, label, false); if (!createResponse.Success) throw new Exception("System error 10340. Message:" + createResponse.Message); } InputTextField iconName = new InputTextField(); iconName.Id = new Guid("5EA0C872-D219-4D94-9EFA-C5DA978D316B"); iconName.Name = "icon_name"; iconName.Label = "Icon Name"; iconName.PlaceholderText = ""; iconName.Description = ""; iconName.HelpText = ""; iconName.Required = true; iconName.Unique = false; iconName.Searchable = false; iconName.Auditable = false; iconName.System = true; iconName.DefaultValue = "database"; iconName.MaxLength = null; { var createResponse = entityManager.CreateField(SystemIds.AreaEntityId, iconName, false); if (!createResponse.Success) throw new Exception("System error 10340. Message:" + createResponse.Message); } InputNumberField weight = new InputNumberField(); weight.Id = new Guid("9B169431-6C31-4141-80EB-5844B8333E63"); weight.Name = "weight"; weight.Label = "Weight"; weight.PlaceholderText = ""; weight.Description = ""; weight.HelpText = ""; weight.Required = true; weight.Unique = false; weight.Searchable = false; weight.Auditable = false; weight.System = true; weight.DefaultValue = 10; weight.MinValue = 0; weight.DecimalPlaces = 2; { var createResponse = entityManager.CreateField(SystemIds.AreaEntityId, weight, false); if (!createResponse.Success) throw new Exception("System error 10340. Message:" + createResponse.Message); } InputTextField subscriptions = new InputTextField(); subscriptions.Id = new Guid("288EA657-C12C-4AC1-B701-81D6F9F39363"); subscriptions.Name = "subscriptions"; subscriptions.Label = "Subscriptions JSON String"; subscriptions.PlaceholderText = ""; subscriptions.Description = "Stringified Array of subscription objects"; subscriptions.HelpText = ""; subscriptions.Required = false; subscriptions.Unique = false; subscriptions.Searchable = false; subscriptions.Auditable = false; subscriptions.System = true; subscriptions.DefaultValue = null; subscriptions.MaxLength = null; { var createResponse = entityManager.CreateField(SystemIds.AreaEntityId, subscriptions, false); if (!createResponse.Success) throw new Exception("System error 10340. Message:" + createResponse.Message); } InputTextField name = new InputTextField(); name.Id = new Guid("F297577B-073E-4D18-81F3-675C1AFB466D"); name.Name = "name"; name.Label = "Name"; name.PlaceholderText = ""; name.Description = ""; name.HelpText = ""; name.Required = true; name.Unique = false; name.Searchable = false; name.Auditable = false; name.System = true; name.DefaultValue = "default"; name.MaxLength = null; { var createResponse = entityManager.CreateField(SystemIds.AreaEntityId, name, false); if (!createResponse.Success) throw new Exception("System error 10340. Message:" + createResponse.Message); } InputTextField roles = new InputTextField(); roles.Id = new Guid("8E486F76-D0C1-4D0E-8617-9EF868BF1C55"); roles.Name = "roles"; roles.Label = "Subscriptions JSON String"; roles.PlaceholderText = ""; roles.Description = "Stringified Array of roles that have access to this area"; roles.HelpText = ""; roles.Required = false; roles.Unique = false; roles.Searchable = false; roles.Auditable = false; roles.System = true; roles.DefaultValue = null; roles.MaxLength = null; { var createResponse = entityManager.CreateField(SystemIds.AreaEntityId, roles, false); if (!createResponse.Success) throw new Exception("System error 10340. Message:" + createResponse.Message); } } #endregion } if (currentVersion < 150919) { systemSettings.Version = 150919; List<Guid> allowedRoles = new List<Guid>(); allowedRoles.Add(SystemIds.AdministratorRoleId); Guid filterEntityId = new Guid("2a20e8b1-5713-4257-a860-b964a5cfb317"); #region << create filter >> { InputEntity filterEntity = new InputEntity(); filterEntity.Id = filterEntityId; filterEntity.Name = "filter"; filterEntity.Label = "Filter"; filterEntity.LabelPlural = "Filters"; filterEntity.System = true; filterEntity.IconName = "filter"; filterEntity.Weight = 100; filterEntity.RecordPermissions = new RecordPermissions(); filterEntity.RecordPermissions.CanRead = allowedRoles; filterEntity.RecordPermissions.CanCreate = allowedRoles; filterEntity.RecordPermissions.CanUpdate = allowedRoles; filterEntity.RecordPermissions.CanDelete = allowedRoles; { var createResponse = entityManager.CreateEntity(filterEntity); if (!createResponse.Success) throw new Exception("System error 10330. Message:" + createResponse.Message); } InputTextField filterId = new InputTextField(); filterId.Id = new Guid("597bd9f4-c534-4244-af88-b6970c6abb21"); filterId.Name = "filter_id"; filterId.Label = "Filter id"; filterId.PlaceholderText = ""; filterId.Description = ""; filterId.HelpText = ""; filterId.Required = true; filterId.Unique = false; filterId.Searchable = false; filterId.Auditable = false; filterId.System = true; filterId.DefaultValue = ""; filterId.MaxLength = null; { var createResponse = entityManager.CreateField(filterEntityId, filterId, false); if (!createResponse.Success) throw new Exception("System error 10340. Message:" + createResponse.Message); } InputTextField fieldName = new InputTextField(); fieldName.Id = new Guid("e4094c4d-0fd3-44ef-9cc0-190ea48f7bca"); fieldName.Name = "field_name"; fieldName.Label = "Field name"; fieldName.PlaceholderText = ""; fieldName.Description = ""; fieldName.HelpText = ""; fieldName.Required = true; fieldName.Unique = false; fieldName.Searchable = false; fieldName.Auditable = false; fieldName.System = true; fieldName.DefaultValue = ""; fieldName.MaxLength = null; { var createResponse = entityManager.CreateField(filterEntityId, fieldName, false); if (!createResponse.Success) throw new Exception("System error 10340. Message:" + createResponse.Message); } InputTextField relationName = new InputTextField(); relationName.Id = new Guid("2859082c-5356-4d13-8b7b-e8fe65417279"); relationName.Name = "relation_name"; relationName.Label = "Relation name"; relationName.PlaceholderText = ""; relationName.Description = ""; relationName.HelpText = ""; relationName.Required = true; relationName.Unique = false; relationName.Searchable = false; relationName.Auditable = false; relationName.System = true; relationName.DefaultValue = ""; relationName.MaxLength = null; { var createResponse = entityManager.CreateField(filterEntityId, relationName, false); if (!createResponse.Success) throw new Exception("System error 10340. Message:" + createResponse.Message); } InputTextField values = new InputTextField(); values.Id = new Guid("ff7511ae-0117-41c6-9a03-08e3c6568c39"); values.Name = "values"; values.Label = "Values"; values.PlaceholderText = ""; values.Description = "array of encoded strings"; values.HelpText = ""; values.Required = true; values.Unique = false; values.Searchable = false; values.Auditable = false; values.System = true; values.DefaultValue = ""; values.MaxLength = null; { var createResponse = entityManager.CreateField(filterEntityId, values, false); if (!createResponse.Success) throw new Exception("System error 10340. Message:" + createResponse.Message); } InputTextField helper = new InputTextField(); helper.Id = new Guid("9056b9fb-4a4a-456f-9c64-539eaf70b6b2"); helper.Name = "helper"; helper.Label = "Helper"; helper.PlaceholderText = ""; helper.Description = "stringified object that helps constructing the filter on the interface"; helper.HelpText = ""; helper.Required = true; helper.Unique = false; helper.Searchable = false; helper.Auditable = false; helper.System = true; helper.DefaultValue = ""; helper.MaxLength = null; { var createResponse = entityManager.CreateField(filterEntityId, helper, false); if (!createResponse.Success) throw new Exception("System error 10340. Message:" + createResponse.Message); } InputTextField entityName = new InputTextField(); entityName.Id = new Guid("22f58779-4c91-4278-8412-88e1a55784e1"); entityName.Name = "entity_name"; entityName.Label = "Entity Name"; entityName.PlaceholderText = ""; entityName.Description = ""; entityName.HelpText = ""; entityName.Required = true; entityName.Unique = false; entityName.Searchable = false; entityName.Auditable = false; entityName.System = true; entityName.DefaultValue = ""; entityName.MaxLength = null; { var createResponse = entityManager.CreateField(filterEntityId, entityName, false); if (!createResponse.Success) throw new Exception("System error 10340. Message:" + createResponse.Message); } InputTextField listName = new InputTextField(); listName.Id = new Guid("a2cb0965-fe51-42b0-a07d-765507da8865"); listName.Name = "list_name"; listName.Label = "List Name"; listName.PlaceholderText = ""; listName.Description = ""; listName.HelpText = ""; listName.Required = true; listName.Unique = false; listName.Searchable = false; listName.Auditable = false; listName.System = true; listName.DefaultValue = ""; listName.MaxLength = null; { var createResponse = entityManager.CreateField(filterEntityId, listName, false); if (!createResponse.Success) throw new Exception("System error 10340. Message:" + createResponse.Message); } InputDateTimeField lastUsedOn = new InputDateTimeField(); lastUsedOn.Id = new Guid("207cf27b-3595-41fd-b028-bcd47845ad25"); lastUsedOn.Name = "last_used_on"; lastUsedOn.Label = "Last used on"; lastUsedOn.PlaceholderText = ""; lastUsedOn.Description = ""; lastUsedOn.HelpText = ""; lastUsedOn.Required = true; lastUsedOn.Unique = false; lastUsedOn.Searchable = false; lastUsedOn.Auditable = false; lastUsedOn.System = true; lastUsedOn.DefaultValue = null; lastUsedOn.Format = "dd MMM yyyy HH:mm:ss"; lastUsedOn.UseCurrentTimeAsDefaultValue = true; { var createResponse = entityManager.CreateField(filterEntityId, lastUsedOn, false); if (!createResponse.Success) throw new Exception("System error 10340. Message:" + createResponse.Message); } #region << match_type >> InputSelectField matchType = new InputSelectField(); matchType.Id = new Guid("15416751-e66d-4b85-ae2f-974255f9c987"); matchType.Name = "match_type"; matchType.Label = "Match type"; matchType.PlaceholderText = ""; matchType.Description = ""; matchType.HelpText = ""; matchType.Required = true; matchType.Unique = false; matchType.Searchable = false; matchType.Auditable = false; matchType.System = true; matchType.DefaultValue = "exact"; matchType.Options = null; matchType.Options = new List<SelectFieldOption> { new SelectFieldOption(){ Key = "exact", Value = "Exact match" }, new SelectFieldOption(){ Key = "range", Value = "Range" }, new SelectFieldOption(){ Key = "period", Value = "Period" }, new SelectFieldOption(){ Key = "regex", Value = "Regex" } }; { var createResponse = entityManager.CreateField(filterEntityId, matchType, false); if (!createResponse.Success) throw new Exception("System error 10060. Entity: filter. Field: match_type" + " Message:" + createResponse.Message); } #endregion } #endregion } if (currentVersion < 150924) { systemSettings.Version = 150924; //User #region << image >> { InputImageField imageField = new InputImageField(); imageField.Id = new Guid("bf199b74-4448-4f58-93f5-6b86d888843b"); imageField.Name = "image"; imageField.Label = "Image"; imageField.PlaceholderText = ""; imageField.Description = ""; imageField.HelpText = ""; imageField.Required = false; imageField.Unique = false; imageField.Searchable = false; imageField.Auditable = false; imageField.System = true; imageField.DefaultValue = string.Empty; imageField.EnableSecurity = false; { var createResponse = entityManager.CreateField(SystemIds.UserEntityId, imageField, false); if (!createResponse.Success) throw new Exception("System error 10060. Entity: user. Field: image" + " Message:" + createResponse.Message); } } #endregion } storeSystemSettings = systemSettingsRepository.Convert(systemSettings); systemSettingsRepository.Save(storeSystemSettings); //if (currentVersion == 150508) //update to 150510 //{ // systemSettings.Version = 150510; // storeSystemSettings = systemSettingsRepository.Convert(systemSettings); // systemSettingsRepository.Save(storeSystemSettings); //} transaction.Commit(); } catch (Exception) { transaction.Rollback(); throw; } }
public IActionResult GetEntityLibrary(string entityName) { var result = new EntityLibraryItemsResponse() { Success = true, Timestamp = DateTime.UtcNow }; var relMan = new EntityRelationManager(); var relations = relMan.Read().Object; if (string.IsNullOrWhiteSpace(entityName)) { result.Errors.Add(new ErrorModel { Message = "Invalid entity name." }); result.Success = false; return DoResponse(result); } var entity = entMan.ReadEntity(entityName).Object; if (entity == null) { result.Errors.Add(new ErrorModel { Message = "Entity not found." }); result.Success = false; return DoResponse(result); } entity = Helpers.DeepClone(entMan.ReadEntity(entityName).Object); List<object> itemList = new List<object>(); //itemList.Add(new { type = "html", tag = "HTML string", content = "" }); foreach (var field in entity.Fields) { if (!(field is TreeSelectField)) { itemList.Add(new RecordViewFieldItem { FieldId = field.Id, FieldName = field.Name, Meta = CleanupFieldForLibrary(field), EntityId = entity.Id, EntityName = entity.Name, EntityLabel = entity.Label, EntityLabelPlural = entity.LabelPlural, DataName = field.Name }); } else { TreeSelectField treeField = field as TreeSelectField; var treeRelation = relations.SingleOrDefault(x => x.Id == treeField.RelationId); if (treeRelation == null) //skip if missing relation is used // simple protection continue; Entity relatedEntity = Helpers.DeepClone(entMan.ReadEntity(treeField.RelatedEntityId).Object); if (relatedEntity == null) //skip if missing related entity // simple protection continue; var tree = relatedEntity.RecordTrees.SingleOrDefault(t => t.Id == treeField.SelectedTreeId); if (tree == null) //skip if missing selected tree // simple protection continue; itemList.Add(new RelationTreeItem { RelationId = treeRelation.Id, RelationName = treeRelation.Name, EntityId = relatedEntity.Id, EntityName = relatedEntity.Name, EntityLabel = relatedEntity.Label, EntityLabelPlural = relatedEntity.LabelPlural, TreeId = tree.Id, TreeName = tree.Name, Meta = tree, DataName = string.Format("$tree${0}${1}", treeRelation.Name, tree.Name), FieldLabel = "", FieldPlaceholder = "", FieldHelpText = "", FieldRequired = false, FieldLookupList = "", FieldManageView = "" }); } } foreach (var view in entity.RecordViews) { itemList.Add(new RecordViewViewItem { ViewId = view.Id, ViewName = view.Name, Meta = view, EntityId = entity.Id, EntityName = entity.Name, EntityLabel = entity.Label, EntityLabelPlural = entity.LabelPlural, DataName = string.Format("view{0}", view.Name) }); } foreach (var list in entity.RecordLists) { itemList.Add(new RecordViewListItem { ListId = list.Id, ListName = list.Name, Meta = list, EntityId = entity.Id, EntityName = entity.Name, EntityLabel = entity.Label, EntityLabelPlural = entity.LabelPlural, DataName = string.Format("$list${0}", list.Name) }); } var entityRelations = relations.Where(x => x.OriginEntityId == entity.Id || x.TargetEntityId == entity.Id).ToList(); foreach (var relation in entityRelations) { Guid relatedEntityId = relation.OriginEntityId == entity.Id ? relation.TargetEntityId : relation.OriginEntityId; Entity relatedEntity = Helpers.DeepClone(entMan.ReadEntity(relatedEntityId).Object); itemList.Add(new EntityRelationOptionsItem { RelationId = relation.Id, RelationName = relation.Name, Direction = "origin-target" }); //TODO validation if (relatedEntity == null) throw new Exception(string.Format("Invalid relation '{0}'. Related entity '{1}' do not exist.", relation.Name, relatedEntityId)); foreach (var field in relatedEntity.Fields) { itemList.Add(new RecordViewRelationFieldItem { RelationId = relation.Id, RelationName = relation.Name, EntityId = relatedEntity.Id, EntityName = relatedEntity.Name, EntityLabel = relatedEntity.Label, EntityLabelPlural = relatedEntity.LabelPlural, FieldId = field.Id, FieldName = field.Name, Meta = CleanupFieldForLibrary(field), DataName = string.Format("$field${0}${1}", relation.Name, field.Name), FieldLabel = "", FieldPlaceholder = "", FieldHelpText = "", FieldRequired = false, FieldLookupList = "" }); } foreach (var view in relatedEntity.RecordViews) { itemList.Add(new RecordViewRelationViewItem { RelationId = relation.Id, RelationName = relation.Name, EntityId = relatedEntity.Id, EntityName = relatedEntity.Name, EntityLabel = relatedEntity.Label, EntityLabelPlural = relatedEntity.LabelPlural, ViewId = view.Id, ViewName = view.Name, Meta = view, DataName = string.Format("$view${0}${1}", relation.Name, view.Name), FieldLabel = "", FieldPlaceholder = "", FieldHelpText = "", FieldRequired = false, FieldLookupList = "", FieldManageView = "" }); } foreach (var list in relatedEntity.RecordLists) { itemList.Add(new RecordViewRelationListItem { RelationId = relation.Id, RelationName = relation.Name, EntityId = relatedEntity.Id, EntityName = relatedEntity.Name, EntityLabel = relatedEntity.Label, EntityLabelPlural = relatedEntity.LabelPlural, ListId = list.Id, ListName = list.Name, Meta = list, DataName = string.Format("$list${0}${1}", relation.Name, list.Name), FieldLabel = "", FieldPlaceholder = "", FieldHelpText = "", FieldRequired = false, FieldLookupList = "", FieldManageView = "" }); } } result.Object = itemList; return DoResponse(result); }
private static void Patch160430(EntityManager entMan, EntityRelationManager relMan, RecordManager recMan, bool createSampleRecords = false) { #region << Create Project admin area >> //The areas are the main object for navigation for the user. You can attach entities and URLs later to them { var area = new EntityRecord(); area["id"] = PROJECT_ADMIN_AREA_ID; area["name"] = "project_admin"; area["label"] = "Project Admin"; area["icon_name"] = "wrench"; area["color"] = "pink"; area["folder"] = "Admin"; area["weight"] = 101; var areaRoles = new List<Guid>(); areaRoles.Add(SystemIds.AdministratorRoleId); area["roles"] = JsonConvert.SerializeObject(areaRoles); var createAreaResult = recMan.CreateRecord("area", area); if (!createAreaResult.Success) { throw new Exception("System error 10060. Area create with name : project_admin. Message:" + createAreaResult.Message); } } #endregion #region << Create Project Workplace area >> //The areas are the main object for navigation for the user. You can attach entities and URLs later to them { var area = new EntityRecord(); area["id"] = PROJECT_WORKPLACE_AREA_ID; area["name"] = "projects"; area["label"] = "Projects"; area["icon_name"] = "product-hunt"; area["color"] = "indigo"; area["folder"] = "Projects"; area["weight"] = 5; var areaRoles = new List<Guid>(); areaRoles.Add(SystemIds.AdministratorRoleId); areaRoles.Add(SystemIds.RegularRoleId); area["roles"] = JsonConvert.SerializeObject(areaRoles); var createAreaResult = recMan.CreateRecord("area", area); if (!createAreaResult.Success) { throw new Exception("System error 10060. Area create with name : project_admin. Message:" + createAreaResult.Message); } } #endregion #region << Create Project create task area >> { var area = new EntityRecord(); area["id"] = CREATE_TASK_WORKPLACE_AREA_ID; area["name"] = "create_task"; area["label"] = "Create task"; area["icon_name"] = "tasks"; area["color"] = "teal"; area["folder"] = "Projects"; area["weight"] = 1; var areaRoles = new List<Guid>(); areaRoles.Add(SystemIds.AdministratorRoleId); areaRoles.Add(SystemIds.RegularRoleId); area["roles"] = JsonConvert.SerializeObject(areaRoles); var createAreaResult = recMan.CreateRecord("area", area); if (!createAreaResult.Success) { throw new Exception("System error 10060. Area create with name : project_admin. Message:" + createAreaResult.Message); } } #endregion #region << area add subscription: Create task >> { var updatedAreaId = CREATE_TASK_WORKPLACE_AREA_ID; var updateAreaResult = Helpers.UpsertUrlAsAreaSubscription(entMan, recMan, updatedAreaId, "/#/areas/projects/wv_task/view-create/create?returnUrl=%2Fareas%2Fprojects%2Fwv_task%2Flist-general%2Fmy_tasks", "Create task", 1, "tasks"); if (!updateAreaResult.Success) { throw new Exception("System error 10060. Area update with id : " + updatedAreaId + " Message:" + updateAreaResult.Message); } } #endregion #region << Create Project submit bug area >> { var area = new EntityRecord(); area["id"] = REPORT_BUG_WORKPLACE_AREA_ID; area["name"] = "report_bug"; area["label"] = "Report bug"; area["icon_name"] = "bug"; area["color"] = "deep-orange"; area["folder"] = "Projects"; area["weight"] = 2; var areaRoles = new List<Guid>(); areaRoles.Add(SystemIds.AdministratorRoleId); areaRoles.Add(SystemIds.RegularRoleId); area["roles"] = JsonConvert.SerializeObject(areaRoles); var createAreaResult = recMan.CreateRecord("area", area); if (!createAreaResult.Success) { throw new Exception("System error 10060. Area create with name : project_admin. Message:" + createAreaResult.Message); } } #endregion #region << area add subscription: Create task >> { var updatedAreaId = REPORT_BUG_WORKPLACE_AREA_ID; var updateAreaResult = Helpers.UpsertUrlAsAreaSubscription(entMan, recMan, updatedAreaId, "/#/areas/projects/wv_bug/view-create/create?returnUrl=%2Fareas%2Fprojects%2Fwv_bug%2Flist-general%2Fmy_bugs", "Report bug", 1, "bug"); if (!updateAreaResult.Success) { throw new Exception("System error 10060. Area update with id : " + updatedAreaId + " Message:" + updateAreaResult.Message); } } #endregion #region << wv_project >> { #region << entity >> { InputEntity entity = new InputEntity(); entity.Id = PROJECT_ENTITY_ID; entity.Name = PROJECT_ENTITY_NAME; entity.Label = "Project"; entity.LabelPlural = "Projects"; entity.System = true; entity.IconName = "product-hunt"; entity.Weight = 22; entity.RecordPermissions = new RecordPermissions(); entity.RecordPermissions.CanCreate = new List<Guid>(); entity.RecordPermissions.CanRead = new List<Guid>(); entity.RecordPermissions.CanUpdate = new List<Guid>(); entity.RecordPermissions.CanDelete = new List<Guid>(); //Create entity.RecordPermissions.CanCreate.Add(SystemIds.AdministratorRoleId); //READ entity.RecordPermissions.CanRead.Add(SystemIds.AdministratorRoleId); entity.RecordPermissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE entity.RecordPermissions.CanUpdate.Add(SystemIds.AdministratorRoleId); //System fields and relations Ids should be hardcoded for the compare/change code generation to work later on correctly var systemItemIdDictionary = new Dictionary<string, Guid>(); systemItemIdDictionary["id"] = new Guid("979dc238-c8f2-46c9-90e7-6ab65f9652da"); systemItemIdDictionary["created_on"] = new Guid("64c613a5-354b-4cc3-8ba7-2ece7be562f0"); systemItemIdDictionary["created_by"] = new Guid("5125750c-f82c-4320-905a-804d7c32d3fd"); systemItemIdDictionary["last_modified_on"] = new Guid("58cad35e-39b6-4ce7-9e2b-610cd466141e"); systemItemIdDictionary["last_modified_by"] = new Guid("292cd102-7915-4a3b-85a7-5ffdc5afe4e2"); systemItemIdDictionary["user_wv_project_created_by"] = new Guid("330c72a0-fcce-4c63-979d-8cfad63fa6f5"); systemItemIdDictionary["user_wv_project_modified_by"] = new Guid("d99cfe44-68a8-4e66-9e92-1a484fb73bd8"); { var response = entMan.CreateEntity(entity, false, false, systemItemIdDictionary); if (!response.Success) throw new Exception("System error 10050. Entity: " + PROJECT_ENTITY_NAME + " Field: entity creation" + " Message:" + response.Message); } } #endregion #region << name >> { InputTextField textboxField = new InputTextField(); textboxField.Id = new Guid("d13427b7-e518-4305-b2cc-bc814a299b55"); textboxField.Name = "name"; textboxField.Label = "Name"; textboxField.PlaceholderText = ""; textboxField.Description = ""; textboxField.HelpText = ""; textboxField.Required = true; textboxField.Unique = false; textboxField.Searchable = true; textboxField.Auditable = false; textboxField.System = true; textboxField.DefaultValue = string.Empty; textboxField.MaxLength = null; textboxField.EnableSecurity = true; textboxField.Permissions = new FieldPermissions(); textboxField.Permissions.CanRead = new List<Guid>(); textboxField.Permissions.CanUpdate = new List<Guid>(); //READ textboxField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); textboxField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE textboxField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); { var response = entMan.CreateField(PROJECT_ENTITY_ID, textboxField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + PROJECT_ENTITY_NAME + " Field: name" + " Message:" + response.Message); } } #endregion #region << code >> { InputTextField textboxField = new InputTextField(); textboxField.Id = new Guid("d9c6a939-e2e3-4617-900e-e056f0638fa8"); textboxField.Name = "code"; textboxField.Label = "Code"; textboxField.PlaceholderText = ""; textboxField.Description = ""; textboxField.HelpText = ""; textboxField.Required = true; textboxField.Unique = false; textboxField.Searchable = true; textboxField.Auditable = false; textboxField.System = true; textboxField.DefaultValue = string.Empty; textboxField.MaxLength = null; textboxField.EnableSecurity = true; textboxField.Permissions = new FieldPermissions(); textboxField.Permissions.CanRead = new List<Guid>(); textboxField.Permissions.CanUpdate = new List<Guid>(); //READ textboxField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); textboxField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE textboxField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); { var response = entMan.CreateField(PROJECT_ENTITY_ID, textboxField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + PROJECT_ENTITY_NAME + " Field: code" + " Message:" + response.Message); } } #endregion #region << description >> { InputHtmlField htmlField = new InputHtmlField(); htmlField.Id = new Guid("d5e2c42c-c0b8-4f03-92e0-e91bede1e7b3"); htmlField.Name = "description"; htmlField.Label = "Description"; htmlField.PlaceholderText = ""; htmlField.Description = ""; htmlField.HelpText = ""; htmlField.Required = false; htmlField.Unique = false; htmlField.Searchable = false; htmlField.Auditable = false; htmlField.System = true; htmlField.DefaultValue = string.Empty; htmlField.EnableSecurity = true; htmlField.Permissions = new FieldPermissions(); htmlField.Permissions.CanRead = new List<Guid>(); htmlField.Permissions.CanUpdate = new List<Guid>(); htmlField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); htmlField.Permissions.CanRead.Add(SystemIds.RegularRoleId); htmlField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); { var response = entMan.CreateField(PROJECT_ENTITY_ID, htmlField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + PROJECT_ENTITY_NAME + " Field: description" + " Message:" + response.Message); } } #endregion #region << owner_id >> { InputGuidField guidField = new InputGuidField(); guidField.Id = new Guid("2e8589e0-3966-447d-8d21-6fd9a1250d60"); guidField.Name = "owner_id"; guidField.Label = "Project owner"; guidField.PlaceholderText = ""; guidField.Description = ""; guidField.HelpText = ""; guidField.Required = true; guidField.Unique = false; guidField.Searchable = false; guidField.Auditable = false; guidField.System = true; guidField.DefaultValue = Guid.Empty; guidField.GenerateNewId = false; guidField.EnableSecurity = true; guidField.Permissions = new FieldPermissions(); guidField.Permissions.CanRead = new List<Guid>(); guidField.Permissions.CanUpdate = new List<Guid>(); //READ guidField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE guidField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); { var response = entMan.CreateField(PROJECT_ENTITY_ID, guidField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + PROJECT_ENTITY_NAME + " Field: owner_id" + " Message:" + response.Message); } } #endregion #region << start_date >> { InputDateField dateField = new InputDateField(); dateField.Id = new Guid("417ce7d7-a472-499b-8e70-43a1cb54723d"); dateField.Name = "start_date"; dateField.Label = "Start date"; dateField.PlaceholderText = ""; dateField.Description = ""; dateField.HelpText = ""; dateField.Required = false; dateField.Unique = false; dateField.Searchable = false; dateField.Auditable = false; dateField.System = true; dateField.DefaultValue = null; dateField.Format = "dd MMM yyyy"; dateField.UseCurrentTimeAsDefaultValue = true; dateField.EnableSecurity = true; dateField.Permissions = new FieldPermissions(); dateField.Permissions.CanRead = new List<Guid>(); dateField.Permissions.CanUpdate = new List<Guid>(); //READ dateField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); dateField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE dateField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); { var response = entMan.CreateField(PROJECT_ENTITY_ID, dateField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + PROJECT_ENTITY_NAME + " Field: start_date" + " Message:" + response.Message); } } #endregion #region << end_date >> { InputDateField dateField = new InputDateField(); dateField.Id = new Guid("57198778-636d-47ec-b33e-edfc5705cc05"); dateField.Name = "end_date"; dateField.Label = "End date"; dateField.PlaceholderText = ""; dateField.Description = ""; dateField.HelpText = ""; dateField.Required = false; dateField.Unique = false; dateField.Searchable = false; dateField.Auditable = false; dateField.System = true; dateField.DefaultValue = null; dateField.Format = "dd MMM yyyy"; dateField.UseCurrentTimeAsDefaultValue = true; dateField.EnableSecurity = true; dateField.Permissions = new FieldPermissions(); dateField.Permissions.CanRead = new List<Guid>(); dateField.Permissions.CanUpdate = new List<Guid>(); //READ dateField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); dateField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE dateField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); { var response = entMan.CreateField(PROJECT_ENTITY_ID, dateField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + PROJECT_ENTITY_NAME + " Field: end_date" + " Message:" + response.Message); } } #endregion #region << priority >> { InputSelectField dropdownField = new InputSelectField(); dropdownField.Id = new Guid("277feafe-5727-4a33-9024-153015dd06d0"); dropdownField.Name = "priority"; dropdownField.Label = "Priority"; dropdownField.PlaceholderText = ""; dropdownField.Description = ""; dropdownField.HelpText = ""; dropdownField.Required = true; dropdownField.Unique = false; dropdownField.Searchable = false; dropdownField.Auditable = false; dropdownField.System = true; dropdownField.DefaultValue = "medium"; dropdownField.Options = new List<SelectFieldOption> { new SelectFieldOption(){ Key = "low", Value = "low" }, new SelectFieldOption(){ Key = "medium", Value = "medium" }, new SelectFieldOption(){ Key = "hight", Value = "hight" } }; dropdownField.EnableSecurity = true; dropdownField.Permissions = new FieldPermissions(); dropdownField.Permissions.CanRead = new List<Guid>(); dropdownField.Permissions.CanUpdate = new List<Guid>(); //READ dropdownField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); dropdownField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE dropdownField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); { var response = entMan.CreateField(PROJECT_ENTITY_ID, dropdownField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + PROJECT_ENTITY_NAME + " Field: priority" + " Message:" + response.Message); } } #endregion #region << status >> { InputSelectField dropdownField = new InputSelectField(); dropdownField.Id = new Guid("ba5698ba-fa81-4215-a5e1-17c368f504e2"); dropdownField.Name = "status"; dropdownField.Label = "Status"; dropdownField.PlaceholderText = ""; dropdownField.Description = ""; dropdownField.HelpText = ""; dropdownField.Required = true; dropdownField.Unique = false; dropdownField.Searchable = false; dropdownField.Auditable = false; dropdownField.System = true; dropdownField.DefaultValue = "draft"; dropdownField.Options = new List<SelectFieldOption> { new SelectFieldOption(){ Key = "draft", Value = "draft" }, new SelectFieldOption(){ Key = "in review", Value = "in review" }, new SelectFieldOption(){ Key = "published", Value = "published" }, new SelectFieldOption(){ Key = "archived", Value = "archived" } }; dropdownField.EnableSecurity = true; dropdownField.Permissions = new FieldPermissions(); dropdownField.Permissions.CanRead = new List<Guid>(); dropdownField.Permissions.CanUpdate = new List<Guid>(); //READ dropdownField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); dropdownField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE dropdownField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); { var response = entMan.CreateField(PROJECT_ENTITY_ID, dropdownField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + PROJECT_ENTITY_NAME + " Field: status" + " Message:" + response.Message); } } #endregion #region << billable_hour_price >> { InputCurrencyField currencyField = new InputCurrencyField(); currencyField.Id = new Guid("7179f4ab-0376-4ded-a334-a21ff451538e"); currencyField.Name = "billable_hour_price"; currencyField.Label = "billable_hour_price"; currencyField.PlaceholderText = ""; currencyField.Description = ""; currencyField.HelpText = ""; currencyField.Required = true; currencyField.Unique = false; currencyField.Searchable = false; currencyField.Auditable = false; currencyField.System = true; currencyField.DefaultValue = 0; currencyField.MinValue = 0; currencyField.Currency = Helpers.GetCurrencyTypeObject("USD"); currencyField.EnableSecurity = true; currencyField.Permissions.CanRead = new List<Guid>(); currencyField.Permissions.CanUpdate = new List<Guid>(); //READ currencyField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); //UPDATE currencyField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); { var response = entMan.CreateField(PROJECT_ENTITY_ID, currencyField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + PROJECT_ENTITY_NAME + " Field: billable_hour_price" + " Message:" + response.Message); } } #endregion #region << customer_id >> { InputGuidField guidField = new InputGuidField(); guidField.Id = new Guid("6aec7d63-56f3-4f1d-b2df-5fb62e30ab74"); guidField.Name = "customer_id"; guidField.Label = "Customer"; guidField.PlaceholderText = ""; guidField.Description = ""; guidField.HelpText = ""; guidField.Required = true; guidField.Unique = false; guidField.Searchable = false; guidField.Auditable = false; guidField.System = true; guidField.DefaultValue = Guid.Empty; guidField.GenerateNewId = false; guidField.EnableSecurity = true; guidField.Permissions = new FieldPermissions(); guidField.Permissions.CanRead = new List<Guid>(); guidField.Permissions.CanUpdate = new List<Guid>(); //READ guidField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE guidField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); { var response = entMan.CreateField(PROJECT_ENTITY_ID, guidField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + PROJECT_ENTITY_NAME + " Field: customer_id" + " Message:" + response.Message); } } #endregion #region << x_milestones_opened >> { InputNumberField numberField = new InputNumberField(); numberField.Id = new Guid("83a2c903-454f-480d-9709-9903ad7a4046"); numberField.Name = "x_milestones_opened"; numberField.Label = "x_milestones_opened"; numberField.PlaceholderText = ""; numberField.Description = ""; numberField.HelpText = ""; numberField.Required = true; numberField.Unique = false; numberField.Searchable = false; numberField.Auditable = false; numberField.System = true; numberField.DefaultValue = 0; numberField.MinValue = null; numberField.MaxValue = null; numberField.DecimalPlaces = 0; numberField.EnableSecurity = true; numberField.Permissions = new FieldPermissions(); numberField.Permissions.CanRead = new List<Guid>(); numberField.Permissions.CanUpdate = new List<Guid>(); //READ numberField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE numberField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(PROJECT_ENTITY_ID, numberField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + PROJECT_ENTITY_NAME + " Field: x_milestones_opened" + " Message:" + response.Message); } } #endregion #region << x_milestones_completed >> { InputNumberField numberField = new InputNumberField(); numberField.Id = new Guid("635c2bb3-d141-4eb2-8dce-2d76d9bf0fc3"); numberField.Name = "x_milestones_completed"; numberField.Label = "x_milestones_completed"; numberField.PlaceholderText = ""; numberField.Description = ""; numberField.HelpText = ""; numberField.Required = true; numberField.Unique = false; numberField.Searchable = false; numberField.Auditable = false; numberField.System = true; numberField.DefaultValue = 0; numberField.MinValue = null; numberField.MaxValue = null; numberField.DecimalPlaces = 0; numberField.EnableSecurity = true; numberField.Permissions = new FieldPermissions(); numberField.Permissions.CanRead = new List<Guid>(); numberField.Permissions.CanUpdate = new List<Guid>(); //READ numberField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE numberField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(PROJECT_ENTITY_ID, numberField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + PROJECT_ENTITY_NAME + " Field: x_milestones_completed" + " Message:" + response.Message); } } #endregion #region << x_tasks_not_started >> { InputNumberField numberField = new InputNumberField(); numberField.Id = new Guid("589ad094-3d99-4f85-a35f-6e02c2b2073c"); numberField.Name = "x_tasks_not_started"; numberField.Label = "x_tasks_not_started"; numberField.PlaceholderText = ""; numberField.Description = ""; numberField.HelpText = ""; numberField.Required = true; numberField.Unique = false; numberField.Searchable = false; numberField.Auditable = false; numberField.System = true; numberField.DefaultValue = 0; numberField.MinValue = null; numberField.MaxValue = null; numberField.DecimalPlaces = 0; numberField.EnableSecurity = true; numberField.Permissions = new FieldPermissions(); numberField.Permissions.CanRead = new List<Guid>(); numberField.Permissions.CanUpdate = new List<Guid>(); //READ numberField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE numberField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(PROJECT_ENTITY_ID, numberField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + PROJECT_ENTITY_NAME + " Field: x_tasks_not_started" + " Message:" + response.Message); } } #endregion #region << x_tasks_in_progress >> { InputNumberField numberField = new InputNumberField(); numberField.Id = new Guid("cbc72ef7-b0ac-4952-af75-df65e8a560ea"); numberField.Name = "x_tasks_in_progress"; numberField.Label = "x_tasks_in_progress"; numberField.PlaceholderText = ""; numberField.Description = ""; numberField.HelpText = ""; numberField.Required = true; numberField.Unique = false; numberField.Searchable = false; numberField.Auditable = false; numberField.System = true; numberField.DefaultValue = 0; numberField.MinValue = null; numberField.MaxValue = null; numberField.DecimalPlaces = 0; numberField.EnableSecurity = true; numberField.Permissions = new FieldPermissions(); numberField.Permissions.CanRead = new List<Guid>(); numberField.Permissions.CanUpdate = new List<Guid>(); //READ numberField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE numberField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(PROJECT_ENTITY_ID, numberField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + PROJECT_ENTITY_NAME + " Field: x_tasks_in_progress" + " Message:" + response.Message); } } #endregion #region << x_tasks_completed >> { InputNumberField numberField = new InputNumberField(); numberField.Id = new Guid("abd6b885-d095-4dc4-ad26-d47bd565abcd"); numberField.Name = "x_tasks_completed"; numberField.Label = "x_tasks_completed"; numberField.PlaceholderText = ""; numberField.Description = ""; numberField.HelpText = ""; numberField.Required = true; numberField.Unique = false; numberField.Searchable = false; numberField.Auditable = false; numberField.System = true; numberField.DefaultValue = 0; numberField.MinValue = null; numberField.MaxValue = null; numberField.DecimalPlaces = 0; numberField.EnableSecurity = true; numberField.Permissions = new FieldPermissions(); numberField.Permissions.CanRead = new List<Guid>(); numberField.Permissions.CanUpdate = new List<Guid>(); //READ numberField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE numberField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(PROJECT_ENTITY_ID, numberField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + PROJECT_ENTITY_NAME + " Field: x_tasks_completed" + " Message:" + response.Message); } } #endregion #region << x_bugs_opened >> { InputNumberField numberField = new InputNumberField(); numberField.Id = new Guid("45222a14-313c-450f-8988-f386895753ba"); numberField.Name = "x_bugs_opened"; numberField.Label = "x_bugs_opened"; numberField.PlaceholderText = ""; numberField.Description = ""; numberField.HelpText = ""; numberField.Required = true; numberField.Unique = false; numberField.Searchable = false; numberField.Auditable = false; numberField.System = true; numberField.DefaultValue = 0; numberField.MinValue = null; numberField.MaxValue = null; numberField.DecimalPlaces = 0; numberField.EnableSecurity = true; numberField.Permissions = new FieldPermissions(); numberField.Permissions.CanRead = new List<Guid>(); numberField.Permissions.CanUpdate = new List<Guid>(); //READ numberField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE numberField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(PROJECT_ENTITY_ID, numberField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + PROJECT_ENTITY_NAME + " Field: x_bugs_opened" + " Message:" + response.Message); } } #endregion #region << x_bugs_reopened >> { InputNumberField numberField = new InputNumberField(); numberField.Id = new Guid("9eee5691-1837-4187-8d65-3b6629c51bf7"); numberField.Name = "x_bugs_reopened"; numberField.Label = "x_bugs_reopened"; numberField.PlaceholderText = ""; numberField.Description = ""; numberField.HelpText = ""; numberField.Required = true; numberField.Unique = false; numberField.Searchable = false; numberField.Auditable = false; numberField.System = true; numberField.DefaultValue = 0; numberField.MinValue = null; numberField.MaxValue = null; numberField.DecimalPlaces = 0; numberField.EnableSecurity = true; numberField.Permissions = new FieldPermissions(); numberField.Permissions.CanRead = new List<Guid>(); numberField.Permissions.CanUpdate = new List<Guid>(); //READ numberField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE numberField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(PROJECT_ENTITY_ID, numberField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + PROJECT_ENTITY_NAME + " Field: x_bugs_reopened" + " Message:" + response.Message); } } #endregion #region << x_bugs_closed >> { InputNumberField numberField = new InputNumberField(); numberField.Id = new Guid("41507552-2b75-43d5-98b7-63552e9fa420"); numberField.Name = "x_bugs_closed"; numberField.Label = "x_bugs_closed"; numberField.PlaceholderText = ""; numberField.Description = ""; numberField.HelpText = ""; numberField.Required = true; numberField.Unique = false; numberField.Searchable = false; numberField.Auditable = false; numberField.System = true; numberField.DefaultValue = 0; numberField.MinValue = null; numberField.MaxValue = null; numberField.DecimalPlaces = 0; numberField.EnableSecurity = true; numberField.Permissions = new FieldPermissions(); numberField.Permissions.CanRead = new List<Guid>(); numberField.Permissions.CanUpdate = new List<Guid>(); //READ numberField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE numberField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(PROJECT_ENTITY_ID, numberField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + PROJECT_ENTITY_NAME + " Field: x_bugs_closed" + " Message:" + response.Message); } } #endregion #region << user_1_n_project_owner Relation >> { var originEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; var targetEntity = entMan.ReadEntity(PROJECT_ENTITY_ID).Object; EntityRelation oneToNRelation = new EntityRelation(); oneToNRelation.Id = PROJECT_RELATION_USER_1_N_PROJECT_OWNER_ID; oneToNRelation.Name = "user_1_n_project_owner"; oneToNRelation.Label = "user_1_n_project_owner"; oneToNRelation.System = true; oneToNRelation.RelationType = EntityRelationType.OneToMany; oneToNRelation.OriginEntityId = originEntity.Id; oneToNRelation.OriginFieldId = originEntity.Fields.Single(x => x.Name == "id").Id; oneToNRelation.TargetEntityId = targetEntity.Id; oneToNRelation.TargetFieldId = targetEntity.Fields.Single(x => x.Name == "owner_id").Id; { var result = relMan.Create(oneToNRelation); if (!result.Success) throw new Exception("CREATE user_1_n_project_owner RELATION:" + result.Message); } } #endregion #region << customer_1_n_project Relation >> { var originEntity = entMan.ReadEntity(CUSTOMER_ENTITY_ID).Object; var targetEntity = entMan.ReadEntity(PROJECT_ENTITY_ID).Object; EntityRelation oneToNRelation = new EntityRelation(); oneToNRelation.Id = PROJECT_RELATION_CUSTOMER_1_N_PROJECT_ID; oneToNRelation.Name = "customer_1_n_project"; oneToNRelation.Label = "customer_1_n_project"; oneToNRelation.System = true; oneToNRelation.RelationType = EntityRelationType.OneToMany; oneToNRelation.OriginEntityId = originEntity.Id; oneToNRelation.OriginFieldId = originEntity.Fields.Single(x => x.Name == "id").Id; oneToNRelation.TargetEntityId = targetEntity.Id; oneToNRelation.TargetFieldId = targetEntity.Fields.Single(x => x.Name == "customer_id").Id; { var result = relMan.Create(oneToNRelation); if (!result.Success) throw new Exception("CREATE customer_1_n_project RELATION:" + result.Message); } } #endregion #region << role_n_n_project_team Relation >> //Relation for the team user roles for this projects { var originEntity = entMan.ReadEntity(SystemIds.RoleEntityId).Object; var targetEntity = entMan.ReadEntity(PROJECT_ENTITY_ID).Object; EntityRelation NToNRelation = new EntityRelation(); NToNRelation.Id = PROJECT_RELATION_ROLE_N_N_PROJECT_TEAM_ID; NToNRelation.Name = "role_n_n_project_team"; NToNRelation.Label = "role_n_n_project_team"; NToNRelation.System = true; NToNRelation.RelationType = EntityRelationType.ManyToMany; NToNRelation.OriginEntityId = originEntity.Id; NToNRelation.OriginFieldId = originEntity.Fields.Single(x => x.Name == "id").Id; NToNRelation.TargetEntityId = targetEntity.Id; NToNRelation.TargetFieldId = targetEntity.Fields.Single(x => x.Name == "id").Id; { var result = relMan.Create(NToNRelation); if (!result.Success) throw new Exception("CREATE role_n_n_project_team RELATION:" + result.Message); } } #endregion #region << role_n_n_project_customer Relation >> //Relation for the customer user roles for this projects { var originEntity = entMan.ReadEntity(SystemIds.RoleEntityId).Object; var targetEntity = entMan.ReadEntity(PROJECT_ENTITY_ID).Object; EntityRelation NToNRelation = new EntityRelation(); NToNRelation.Id = new Guid("e6d75feb-3c8f-410b-9ff4-54ef8489dc2f"); NToNRelation.Name = "role_n_n_project_customer"; NToNRelation.Label = "role_n_n_project_customer"; NToNRelation.System = true; NToNRelation.RelationType = EntityRelationType.ManyToMany; NToNRelation.OriginEntityId = originEntity.Id; NToNRelation.OriginFieldId = originEntity.Fields.Single(x => x.Name == "id").Id; NToNRelation.TargetEntityId = targetEntity.Id; NToNRelation.TargetFieldId = targetEntity.Fields.Single(x => x.Name == "id").Id; { var result = relMan.Create(NToNRelation); if (!result.Success) throw new Exception("CREATE role_n_n_project_customer RELATION:" + result.Message); } } #endregion #region << View name: admin_details >> { var createViewEntity = entMan.ReadEntity(PROJECT_ENTITY_ID).Object; var createViewInput = new InputRecordView(); var viewRegion = new InputRecordViewRegion(); var viewSection = new InputRecordViewSection(); var viewRow = new InputRecordViewRow(); var viewColumn = new InputRecordViewColumn(); var viewItem = new InputRecordViewFieldItem(); var viewItemFromRelation = new InputRecordViewRelationFieldItem(); #region << details >> createViewInput.Id = new Guid("120dee5b-f3ed-4256-9346-da01d787a49c"); createViewInput.Type = "hidden"; createViewInput.Name = "admin_details"; createViewInput.Label = "Project details"; createViewInput.Title = ""; createViewInput.Default = false; createViewInput.System = true; createViewInput.Weight = 10; createViewInput.CssClass = ""; createViewInput.IconName = "product-hunt"; createViewInput.DynamicHtmlTemplate = null; createViewInput.DataSourceUrl = null; createViewInput.ServiceCode = null; createViewInput.Regions = new List<InputRecordViewRegion>(); #endregion #region << Header Region >> viewRegion = new InputRecordViewRegion(); viewRegion.Name = "header"; viewRegion.Label = "Header"; viewRegion.Render = true; viewRegion.Weight = 1; viewRegion.CssClass = ""; viewRegion.Sections = new List<InputRecordViewSection>(); #region << Section >> viewSection = new InputRecordViewSection(); viewSection.Id = new Guid("6f8fdcc2-8a8f-4cf6-bf26-47bf1c6f0438"); viewSection.Name = "details"; viewSection.Label = "Details"; viewSection.ShowLabel = false; viewSection.CssClass = ""; viewSection.Collapsed = false; viewSection.TabOrder = "left-right"; viewSection.Weight = 1; viewSection.Rows = new List<InputRecordViewRow>(); #region << Row 1 Column>> viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("5d7ce054-f592-41e7-b8f1-424cfd6d38b7"); viewRow.Weight = 1; viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = 12; viewColumn.Items = new List<InputRecordViewItemBase>(); #region << name >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = PROJECT_ENTITY_ID; viewItem.EntityName = PROJECT_ENTITY_NAME; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "name").Id; viewItem.FieldName = "name"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << description >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = PROJECT_ENTITY_ID; viewItem.EntityName = PROJECT_ENTITY_NAME; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "description").Id; viewItem.FieldName = "description"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); #endregion //Save row viewSection.Rows.Add(viewRow); #endregion #region << Row 2 Columns>> viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("22d11cfc-a763-472b-b509-7ddfe36476bb"); viewRow.Weight = 1; viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column Left >> viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = 6; viewColumn.Items = new List<InputRecordViewItemBase>(); #region << $user_1_n_project_owner > username >> { var targetEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = targetEntity.Id; viewItemFromRelation.EntityName = targetEntity.Name; viewItemFromRelation.Type = "field"; viewItemFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "username").Id; viewItemFromRelation.FieldName = "username"; viewItemFromRelation.FieldLabel = "Owner / Project manager"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = PROJECT_RELATION_USER_1_N_PROJECT_OWNER_ID; viewItemFromRelation.RelationName = "user_1_n_project_owner"; viewColumn.Items.Add(viewItemFromRelation); } #endregion #region << $role_n_n_project_team > name >> { var targetEntity = entMan.ReadEntity(SystemIds.RoleEntityId).Object; viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = targetEntity.Id; viewItemFromRelation.EntityName = targetEntity.Name; viewItemFromRelation.Type = "field"; viewItemFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "name").Id; viewItemFromRelation.FieldName = "name"; viewItemFromRelation.FieldLabel = "Project team roles"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = PROJECT_RELATION_ROLE_N_N_PROJECT_TEAM_ID; viewItemFromRelation.RelationName = "role_n_n_project_team"; viewColumn.Items.Add(viewItemFromRelation); } #endregion #region << start_date >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = PROJECT_ENTITY_ID; viewItem.EntityName = PROJECT_ENTITY_NAME; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "start_date").Id; viewItem.FieldName = "start_date"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << billable_hour_price >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = PROJECT_ENTITY_ID; viewItem.EntityName = PROJECT_ENTITY_NAME; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "billable_hour_price").Id; viewItem.FieldName = "billable_hour_price"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); #endregion #region << Column right >> viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = 6; viewColumn.Items = new List<InputRecordViewItemBase>(); #region << $customer_1_n_project > name >> { var targetEntity = entMan.ReadEntity(CUSTOMER_ENTITY_ID).Object; viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = targetEntity.Id; viewItemFromRelation.EntityName = targetEntity.Name; viewItemFromRelation.Type = "field"; viewItemFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "name").Id; viewItemFromRelation.FieldName = "name"; viewItemFromRelation.FieldLabel = "Customer"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = PROJECT_RELATION_CUSTOMER_1_N_PROJECT_ID; viewItemFromRelation.RelationName = "customer_1_n_project"; viewColumn.Items.Add(viewItemFromRelation); } #endregion #region << $role_n_n_project_customer > name >> { var targetEntity = entMan.ReadEntity(SystemIds.RoleEntityId).Object; viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = targetEntity.Id; viewItemFromRelation.EntityName = targetEntity.Name; viewItemFromRelation.Type = "field"; viewItemFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "name").Id; viewItemFromRelation.FieldName = "name"; viewItemFromRelation.FieldLabel = "Project customer roles"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = PROJECT_RELATION_ROLE_N_N_PROJECT_CUSTOMER_ID; viewItemFromRelation.RelationName = "role_n_n_project_customer"; viewColumn.Items.Add(viewItemFromRelation); } #endregion #region << end_date >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = PROJECT_ENTITY_ID; viewItem.EntityName = PROJECT_ENTITY_NAME; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "end_date").Id; viewItem.FieldName = "end_date"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << code >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = PROJECT_ENTITY_ID; viewItem.EntityName = PROJECT_ENTITY_NAME; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "code").Id; viewItem.FieldName = "code"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); #endregion //Save row viewSection.Rows.Add(viewRow); #endregion //Save section viewRegion.Sections.Add(viewSection); #endregion //Save region createViewInput.Regions.Add(viewRegion); #endregion #region << relation options >> createViewInput.RelationOptions = new List<EntityRelationOptionsItem>(); #endregion #region << Sidebar >> createViewInput.Sidebar = new InputRecordViewSidebar(); createViewInput.Sidebar.CssClass = ""; createViewInput.Sidebar.Render = true; #endregion #region << action items >> createViewInput.ActionItems = new List<ActionItem>(); var actionItem = new ActionItem(); { actionItem = new ActionItem(); actionItem.Name = "wv_record_delete"; actionItem.Menu = "page-title-dropdown"; actionItem.Weight = 1; actionItem.Template = "" + @"<a href=""javascript:void(0)"" confirmed-click=""ngCtrl.deleteRecord(ngCtrl)"" ng-confirm-click=""Are you sure?"" ng-if=""::ngCtrl.userHasRecordPermissions('canDelete')""> <i class=""fa fa-trash go-red""></i> Delete Record </a>"; createViewInput.ActionItems.Add(actionItem); } { actionItem = new ActionItem(); actionItem.Name = "wv_back_button"; actionItem.Menu = "sidebar-top"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""back clearfix"" href=""javascript:void(0)"" ng-click=""sidebarData.goBack()""><i class=""fa fa-fw fa-arrow-left""></i> <span class=""text"">Back</span></a>"; createViewInput.ActionItems.Add(actionItem); } #endregion { var response = entMan.CreateRecordView(PROJECT_ENTITY_ID, createViewInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + PROJECT_ENTITY_NAME + " Updated view: admin_details" + " Message:" + response.Message); } } #endregion #region << View name: admin_create >> { var createViewEntity = entMan.ReadEntity(PROJECT_ENTITY_ID).Object; var createViewInput = new InputRecordView(); var viewRegion = new InputRecordViewRegion(); var viewSection = new InputRecordViewSection(); var viewRow = new InputRecordViewRow(); var viewColumn = new InputRecordViewColumn(); var viewItem = new InputRecordViewFieldItem(); var viewItemFromRelation = new InputRecordViewRelationFieldItem(); #region << details >> createViewInput.Id = new Guid("a6e121f5-0990-4576-9e39-59777e0ecb01"); createViewInput.Type = "hidden"; createViewInput.Title = ""; createViewInput.Name = "admin_create"; createViewInput.Label = "Project create"; createViewInput.Default = false; createViewInput.System = true; createViewInput.Weight = 10; createViewInput.CssClass = null; createViewInput.IconName = "product-hunt"; createViewInput.DynamicHtmlTemplate = null; createViewInput.DataSourceUrl = null; createViewInput.ServiceCode = null; createViewInput.Regions = new List<InputRecordViewRegion>(); #endregion #region << Header Region >> viewRegion = new InputRecordViewRegion(); viewRegion.Name = "header"; viewRegion.Label = "Header"; viewRegion.Render = true; viewRegion.Weight = 1; viewRegion.CssClass = ""; viewRegion.Sections = new List<InputRecordViewSection>(); #region << Section >> viewSection = new InputRecordViewSection(); viewSection.Id = new Guid("88077697-7a36-4a5a-b021-3d2a8638dade"); viewSection.Name = "details"; viewSection.Label = "Details"; viewSection.ShowLabel = false; viewSection.CssClass = ""; viewSection.Collapsed = false; viewSection.TabOrder = "left-right"; viewSection.Weight = 1; viewSection.Rows = new List<InputRecordViewRow>(); #region << Row 1 Column>> viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("cc65d58f-0cfd-4f3d-b9c6-3c8faff6c8b4"); viewRow.Weight = 1; viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = 12; viewColumn.Items = new List<InputRecordViewItemBase>(); #region << name >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = PROJECT_ENTITY_ID; viewItem.EntityName = PROJECT_ENTITY_NAME; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "name").Id; viewItem.FieldName = "name"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << description >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = PROJECT_ENTITY_ID; viewItem.EntityName = PROJECT_ENTITY_NAME; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "description").Id; viewItem.FieldName = "description"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); #endregion //Save row viewSection.Rows.Add(viewRow); #endregion #region << Row 2 Columns>> viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("d88b3da7-d501-48ba-b61d-2eb3485bce21"); viewRow.Weight = 1; viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column Left >> viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = 6; viewColumn.Items = new List<InputRecordViewItemBase>(); #region << $user_1_n_project_owner > username >> { var targetEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = targetEntity.Id; viewItemFromRelation.EntityName = targetEntity.Name; viewItemFromRelation.Type = "field"; viewItemFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "username").Id; viewItemFromRelation.FieldName = "username"; viewItemFromRelation.FieldLabel = "Owner / Project manager"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = PROJECT_RELATION_USER_1_N_PROJECT_OWNER_ID; viewItemFromRelation.RelationName = "user_1_n_project_owner"; viewColumn.Items.Add(viewItemFromRelation); } #endregion #region << $role_n_n_project_team > name >> { var targetEntity = entMan.ReadEntity(SystemIds.RoleEntityId).Object; viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = targetEntity.Id; viewItemFromRelation.EntityName = targetEntity.Name; viewItemFromRelation.Type = "field"; viewItemFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "name").Id; viewItemFromRelation.FieldName = "name"; viewItemFromRelation.FieldLabel = "Project team roles"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = PROJECT_RELATION_ROLE_N_N_PROJECT_TEAM_ID; viewItemFromRelation.RelationName = "role_n_n_project_team"; viewColumn.Items.Add(viewItemFromRelation); } #endregion #region << start_date >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = PROJECT_ENTITY_ID; viewItem.EntityName = PROJECT_ENTITY_NAME; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "start_date").Id; viewItem.FieldName = "start_date"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << billable_hour_price >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = PROJECT_ENTITY_ID; viewItem.EntityName = PROJECT_ENTITY_NAME; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "billable_hour_price").Id; viewItem.FieldName = "billable_hour_price"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); #endregion #region << Column right >> viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = 6; viewColumn.Items = new List<InputRecordViewItemBase>(); #region << $customer_1_n_project > name >> { var targetEntity = entMan.ReadEntity(CUSTOMER_ENTITY_ID).Object; viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = targetEntity.Id; viewItemFromRelation.EntityName = targetEntity.Name; viewItemFromRelation.Type = "field"; viewItemFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "name").Id; viewItemFromRelation.FieldName = "name"; viewItemFromRelation.FieldLabel = "Customer"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = PROJECT_RELATION_CUSTOMER_1_N_PROJECT_ID; viewItemFromRelation.RelationName = "customer_1_n_project"; viewColumn.Items.Add(viewItemFromRelation); } #endregion #region << $role_n_n_project_customer > name >> { var targetEntity = entMan.ReadEntity(SystemIds.RoleEntityId).Object; viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = targetEntity.Id; viewItemFromRelation.EntityName = targetEntity.Name; viewItemFromRelation.Type = "field"; viewItemFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "name").Id; viewItemFromRelation.FieldName = "name"; viewItemFromRelation.FieldLabel = "Project customer roles"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = PROJECT_RELATION_ROLE_N_N_PROJECT_CUSTOMER_ID; viewItemFromRelation.RelationName = "role_n_n_project_customer"; viewColumn.Items.Add(viewItemFromRelation); } #endregion #region << end_date >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = PROJECT_ENTITY_ID; viewItem.EntityName = PROJECT_ENTITY_NAME; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "end_date").Id; viewItem.FieldName = "end_date"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << code >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = PROJECT_ENTITY_ID; viewItem.EntityName = PROJECT_ENTITY_NAME; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "code").Id; viewItem.FieldName = "code"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); #endregion //Save row viewSection.Rows.Add(viewRow); #endregion //Save section viewRegion.Sections.Add(viewSection); #endregion //Save region createViewInput.Regions.Add(viewRegion); #endregion #region << relation options >> createViewInput.RelationOptions = new List<EntityRelationOptionsItem>(); #endregion #region << Sidebar >> createViewInput.Sidebar = new InputRecordViewSidebar(); createViewInput.Sidebar.CssClass = ""; createViewInput.Sidebar.Render = true; #endregion #region << action items >> createViewInput.ActionItems = new List<ActionItem>(); var actionItem = new ActionItem(); { actionItem = new ActionItem(); actionItem.Name = "wv_create_and_list"; actionItem.Menu = "create-bottom"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-primary"" ng-click='ngCtrl.create(""default"")' ng-if=""ngCtrl.createViewRegion != null"">Create</a>"; createViewInput.ActionItems.Add(actionItem); } { actionItem = new ActionItem(); actionItem.Name = "wv_create_and_details"; actionItem.Menu = "create-bottom"; actionItem.Weight = 2; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline"" ng-click='ngCtrl.create(""details"")' ng-if=""ngCtrl.createViewRegion != null"">Create & Details</a>"; createViewInput.ActionItems.Add(actionItem); } { actionItem = new ActionItem(); actionItem.Name = "wv_create_cancel"; actionItem.Menu = "create-bottom"; actionItem.Weight = 3; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline"" ng-click=""ngCtrl.cancel()"">Cancel</a>"; createViewInput.ActionItems.Add(actionItem); } { actionItem = new ActionItem(); actionItem.Name = "wv_back_button"; actionItem.Menu = "sidebar-top"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""back clearfix"" href=""javascript:void(0)"" ng-click=""sidebarData.goBack()""><i class=""fa fa-fw fa-arrow-left""></i> <span class=""text"">Back</span></a>"; createViewInput.ActionItems.Add(actionItem); } #endregion { var response = entMan.CreateRecordView(PROJECT_ENTITY_ID, createViewInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + PROJECT_ENTITY_NAME + " Updated view: admin_create" + " Message:" + response.Message); } } #endregion #region << View name: dashboard >> { var createViewEntity = entMan.ReadEntity(PROJECT_ENTITY_ID).Object; var createViewInput = new InputRecordView(); var viewRegion = new InputRecordViewRegion(); var viewSection = new InputRecordViewSection(); var viewRow = new InputRecordViewRow(); var viewColumn = new InputRecordViewColumn(); var viewItem = new InputRecordViewFieldItem(); var viewItemFromRelation = new InputRecordViewRelationFieldItem(); #region << details >> createViewInput.Id = new Guid("68402d13-d9e7-4fb3-9394-40ba598f3f1a"); createViewInput.Type = "general"; createViewInput.Name = "dashboard"; createViewInput.Label = "[{code}] {name}"; createViewInput.Title = ""; createViewInput.Default = false; createViewInput.System = true; createViewInput.Weight = 10; createViewInput.CssClass = null; createViewInput.IconName = "tachometer"; createViewInput.DynamicHtmlTemplate = null; createViewInput.DataSourceUrl = null; createViewInput.ServiceCode = null; createViewInput.Regions = new List<InputRecordViewRegion>(); #endregion #region << Header Region >> viewRegion = new InputRecordViewRegion(); viewRegion.Name = "header"; viewRegion.Label = "Header"; viewRegion.Render = true; viewRegion.Weight = 1; viewRegion.CssClass = ""; viewRegion.Sections = new List<InputRecordViewSection>(); //Save region createViewInput.Regions.Add(viewRegion); #endregion #region << relation options >> createViewInput.RelationOptions = new List<EntityRelationOptionsItem>(); #endregion #region << Sidebar >> createViewInput.Sidebar = new InputRecordViewSidebar(); createViewInput.Sidebar.CssClass = ""; createViewInput.Sidebar.Render = true; #endregion #region << action items >> createViewInput.ActionItems = new List<ActionItem>(); var actionItem = new ActionItem(); { actionItem = new ActionItem(); actionItem.Name = "wv_record_delete"; actionItem.Menu = "page-title-dropdown"; actionItem.Weight = 1; actionItem.Template = "" + @"<a href=""javascript:void(0)"" confirmed-click=""ngCtrl.deleteRecord(ngCtrl)"" ng-confirm-click=""Are you sure?"" ng-if=""::ngCtrl.userHasRecordPermissions('canDelete')""> <i class=""fa fa-trash go-red""></i> Delete Record </a>"; createViewInput.ActionItems.Add(actionItem); } { actionItem = new ActionItem(); actionItem.Name = "wv_back_button"; actionItem.Menu = "sidebar-top"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""back clearfix"" href=""javascript:void(0)"" ng-click=""sidebarData.goBack()""><i class=""fa fa-fw fa-arrow-left""></i> <span class=""text"">Back</span></a>"; createViewInput.ActionItems.Add(actionItem); } #endregion { var response = entMan.CreateRecordView(PROJECT_ENTITY_ID, createViewInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + PROJECT_ENTITY_NAME + " Updated view: admin_details" + " Message:" + response.Message); } } #endregion #region << List name: admin >> { var createListEntity = entMan.ReadEntity(PROJECT_ENTITY_ID).Object; var createListInput = new InputRecordList(); var listItem = new InputRecordListFieldItem(); var listItemFromRelation = new InputRecordListRelationFieldItem(); var listSort = new InputRecordListSort(); var listQuery = new InputRecordListQuery(); #region << details >> createListInput.Id = new Guid("3eff91d7-152a-496c-913c-152819a42930"); createListInput.Type = "hidden"; createListInput.Name = "admin"; createListInput.Label = "All Projects"; createListInput.Weight = 1; createListInput.Default = false; createListInput.System = true; createListInput.CssClass = null; createListInput.IconName = "product-hunt"; createListInput.VisibleColumnsCount = 7; createListInput.ColumnWidthsCSV = null; createListInput.PageSize = 10; createListInput.DynamicHtmlTemplate = null; createListInput.DataSourceUrl = null; createListInput.ServiceCode = null; #endregion #region << action items >> createListInput.ActionItems = new List<ActionItem>(); var actionItem = new ActionItem(); { actionItem = new ActionItem(); actionItem.Name = "wv_record_details"; actionItem.Menu = "record-row"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline"" ng-href=""{{::ngCtrl.getRecordDetailsUrl(record, ngCtrl)}}""> <i class=""fa fa-fw fa-eye""></i> </a>"; createListInput.ActionItems.Add(actionItem); } { actionItem = new ActionItem(); actionItem.Name = "wv_create_record"; actionItem.Menu = "page-title"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline hidden-xs"" ng-show=""::ngCtrl.userHasRecordPermissions('canCreate')"" ng-href=""{{::ngCtrl.getRecordCreateUrl(ngCtrl)}}"">Add New</a>"; createListInput.ActionItems.Add(actionItem); } #endregion #region << Columns >> createListInput.Columns = new List<InputRecordListItemBase>(); #region << field_name >> { var fieldName = "name"; listItem = new InputRecordListFieldItem(); listItem.EntityId = PROJECT_ENTITY_ID; listItem.EntityName = PROJECT_ENTITY_NAME; listItem.FieldId = createListEntity.Fields.Single(x => x.Name == fieldName).Id; listItem.FieldName = fieldName; listItem.Type = "field"; createListInput.Columns.Add(listItem); } #endregion #endregion #region << relation options >> createListInput.RelationOptions = new List<EntityRelationOptionsItem>(); #endregion #region << query >> listQuery = new InputRecordListQuery(); #endregion #region << Sort >> createListInput.Sorts = new List<InputRecordListSort>(); listSort = new InputRecordListSort(); #endregion { var response = entMan.CreateRecordList(PROJECT_ENTITY_ID, createListInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + PROJECT_ENTITY_NAME + " Updated List: admin" + " Message:" + response.Message); } } #endregion #region << create project my projects list>> { var createListEntity = entMan.ReadEntity(PROJECT_ENTITY_ID).Object; var createListInput = new InputRecordList(); var listItem = new InputRecordListFieldItem(); var listSort = new InputRecordListSort(); var listQuery = new InputRecordListQuery(); //General list details createListInput.Id = new Guid("86f56bb1-9cf4-4168-8e0e-3e8c4d8dd0e6"); createListInput.Name = "my_projects"; createListInput.Label = "My Projects"; createListInput.Default = true; createListInput.System = true; createListInput.Type = "general"; createListInput.IconName = "product-hunt"; createListInput.PageSize = 10; createListInput.Weight = 10; createListInput.VisibleColumnsCount = 5; createListInput.ServiceCode = null; createListInput.DataSourceUrl = "/plugins/webvella-projects/api/project/list/my-projects"; createListInput.DynamicHtmlTemplate = "/plugins/webvella-projects/templates/my-projects.html"; createListInput.ActionItems = new List<ActionItem>(); createListInput.Columns = new List<InputRecordListItemBase>(); //Fields #region << field_name >> listItem = new InputRecordListFieldItem(); listItem.EntityId = PROJECT_ENTITY_ID; listItem.EntityName = PROJECT_ENTITY_NAME; listItem.FieldId = createListEntity.Fields.Single(x => x.Name == "name").Id; listItem.FieldName = "name"; listItem.Type = "field"; createListInput.Columns.Add(listItem); #endregion { var response = entMan.CreateRecordList(PROJECT_ENTITY_ID, createListInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + PROJECT_ENTITY_NAME + " Updated List: general" + " Message:" + response.Message); } } #endregion #region << area add subscription: Project Admin -> Project >> { var updatedAreaId = PROJECT_ADMIN_AREA_ID; var updateAreaResult = Helpers.UpsertEntityAsAreaSubscription(entMan, recMan, updatedAreaId, PROJECT_ENTITY_NAME, "admin_details", "admin_create", "admin"); if (!updateAreaResult.Success) { throw new Exception("System error 10060. Area update with id : " + updatedAreaId + " Message:" + updateAreaResult.Message); } } #endregion #region << create project lookup list >> { var createListEntity = entMan.ReadEntity(PROJECT_ENTITY_ID).Object; var createListInput = new InputRecordList(); var listItem = new InputRecordListFieldItem(); var listSort = new InputRecordListSort(); var listQuery = new InputRecordListQuery(); //General list details createListInput.Id = new Guid("623c9a45-9472-418c-a293-e508d0b91117"); createListInput.Name = "lookup"; createListInput.Label = "Lookup"; createListInput.Default = true; createListInput.System = true; createListInput.Type = "lookup"; createListInput.IconName = "list"; createListInput.PageSize = 10; createListInput.Weight = 10; createListInput.VisibleColumnsCount = 5; createListInput.ServiceCode = null; createListInput.DynamicHtmlTemplate = null; createListInput.DataSourceUrl = "/plugins/webvella-projects/api/project/list/my-projects"; createListInput.ActionItems = new List<ActionItem>(); createListInput.Columns = new List<InputRecordListItemBase>(); //Fields #region << field_name >> listItem = new InputRecordListFieldItem(); listItem.EntityId = PROJECT_ENTITY_ID; listItem.EntityName = PROJECT_ENTITY_NAME; listItem.FieldId = createListEntity.Fields.Single(x => x.Name == "name").Id; listItem.FieldName = "name"; listItem.Type = "field"; createListInput.Columns.Add(listItem); #endregion #region << Queries >> { if (createListInput.Query == null) { createListInput.Query = new InputRecordListQuery(); } createListInput.Query.FieldName = null; createListInput.Query.FieldValue = null; createListInput.Query.QueryType = "AND"; //AND,OR,EQ,NOT,LT,LTE,GT,GTE,CONTAINS,STARTSWITH createListInput.Query.SubQueries = new List<InputRecordListQuery>(); var subQuery = new InputRecordListQuery(); subQuery.FieldName = "name"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""name"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "CONTAINS"; subQuery.SubQueries = new List<InputRecordListQuery>(); createListInput.Query.SubQueries.Add(subQuery); } #endregion { var response = entMan.CreateRecordList(PROJECT_ENTITY_ID, createListInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + PROJECT_ENTITY_NAME + " Updated List: lookup" + " Message:" + response.Message); } } #endregion } #endregion #region << wv_milestone >> { #region << entity >> { InputEntity entity = new InputEntity(); entity.Id = MILESTONE_ENTITY_ID; entity.Name = MILESTONE_ENTITY_NAME; entity.Label = "Milestone"; entity.LabelPlural = "Milestones"; entity.System = true; entity.IconName = "map-signs"; entity.Weight = 2; entity.RecordPermissions = new RecordPermissions(); entity.RecordPermissions.CanCreate = new List<Guid>(); entity.RecordPermissions.CanRead = new List<Guid>(); entity.RecordPermissions.CanUpdate = new List<Guid>(); entity.RecordPermissions.CanDelete = new List<Guid>(); //Create entity.RecordPermissions.CanCreate.Add(SystemIds.AdministratorRoleId); entity.RecordPermissions.CanCreate.Add(SystemIds.RegularRoleId); //READ entity.RecordPermissions.CanRead.Add(SystemIds.AdministratorRoleId); entity.RecordPermissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE entity.RecordPermissions.CanUpdate.Add(SystemIds.AdministratorRoleId); entity.RecordPermissions.CanUpdate.Add(SystemIds.RegularRoleId); //System fields and relations Ids should be hardcoded for the compare/change code generation to work later on correctly var systemItemIdDictionary = new Dictionary<string, Guid>(); systemItemIdDictionary["id"] = new Guid("28c8351b-991d-420f-9a42-57201572571c"); systemItemIdDictionary["created_on"] = new Guid("7aa2003e-92d7-4073-ae59-6b9f02d87516"); systemItemIdDictionary["created_by"] = new Guid("b31ee492-b9ff-47b7-a79d-938935742e40"); systemItemIdDictionary["last_modified_on"] = new Guid("54c925f5-4f2a-4c55-883f-9ac450d807fe"); systemItemIdDictionary["last_modified_by"] = new Guid("f78a6530-7bc7-429d-9c38-27370fce19c0"); systemItemIdDictionary["user_wv_milestone_created_by"] = new Guid("7a6b7dca-ae20-4af5-a888-b3b6e2adf1aa"); systemItemIdDictionary["user_wv_milestone_modified_by"] = new Guid("1f0aa3d9-f50a-496c-bc86-b3e06a7ad8d9"); { var response = entMan.CreateEntity(entity, false, false, systemItemIdDictionary); if (!response.Success) throw new Exception("System error 10050. Entity: " + MILESTONE_ENTITY_NAME + " Field: entity creation" + " Message:" + response.Message); } } #endregion #region << name >> { InputTextField textboxField = new InputTextField(); textboxField.Id = new Guid("94cc3894-110a-4bb7-8c75-3e887cc83217"); textboxField.Name = "name"; textboxField.Label = "Name"; textboxField.PlaceholderText = ""; textboxField.Description = ""; textboxField.HelpText = ""; textboxField.Required = true; textboxField.Unique = false; textboxField.Searchable = true; textboxField.Auditable = false; textboxField.System = true; textboxField.DefaultValue = string.Empty; textboxField.MaxLength = null; textboxField.EnableSecurity = true; textboxField.Permissions = new FieldPermissions(); textboxField.Permissions.CanRead = new List<Guid>(); textboxField.Permissions.CanUpdate = new List<Guid>(); //READ textboxField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); textboxField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE textboxField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); { var response = entMan.CreateField(MILESTONE_ENTITY_ID, textboxField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + MILESTONE_ENTITY_NAME + " Field: name" + " Message:" + response.Message); } } #endregion #region << start_date >> { InputDateField dateField = new InputDateField(); dateField.Id = new Guid("9502a7e4-816c-433c-9f1e-6b1e2dffad62"); dateField.Name = "start_date"; dateField.Label = "Start date"; dateField.PlaceholderText = ""; dateField.Description = ""; dateField.HelpText = ""; dateField.Required = false; dateField.Unique = false; dateField.Searchable = false; dateField.Auditable = false; dateField.System = true; dateField.DefaultValue = null; dateField.Format = "dd MMM yyyy"; dateField.UseCurrentTimeAsDefaultValue = true; dateField.EnableSecurity = true; dateField.Permissions = new FieldPermissions(); dateField.Permissions.CanRead = new List<Guid>(); dateField.Permissions.CanUpdate = new List<Guid>(); //READ dateField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); dateField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE dateField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); { var response = entMan.CreateField(MILESTONE_ENTITY_ID, dateField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + MILESTONE_ENTITY_NAME + " Field: start_date" + " Message:" + response.Message); } } #endregion #region << end_date >> { InputDateField dateField = new InputDateField(); dateField.Id = new Guid("1252a300-c871-4d79-8242-f036705cc86d"); dateField.Name = "end_date"; dateField.Label = "End date"; dateField.PlaceholderText = ""; dateField.Description = ""; dateField.HelpText = ""; dateField.Required = false; dateField.Unique = false; dateField.Searchable = false; dateField.Auditable = false; dateField.System = true; dateField.DefaultValue = null; dateField.Format = "dd MMM yyyy"; dateField.UseCurrentTimeAsDefaultValue = true; dateField.EnableSecurity = true; dateField.Permissions = new FieldPermissions(); dateField.Permissions.CanRead = new List<Guid>(); dateField.Permissions.CanUpdate = new List<Guid>(); //READ dateField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); dateField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE dateField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); { var response = entMan.CreateField(MILESTONE_ENTITY_ID, dateField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + MILESTONE_ENTITY_NAME + " Field: end_date" + " Message:" + response.Message); } } #endregion #region << status >> { InputSelectField dropdownField = new InputSelectField(); dropdownField.Id = new Guid("63eed358-9b33-4d2c-b2cd-b533413df227"); dropdownField.Name = "status"; dropdownField.Label = "Status"; dropdownField.PlaceholderText = ""; dropdownField.Description = ""; dropdownField.HelpText = ""; dropdownField.Required = true; dropdownField.Unique = false; dropdownField.Searchable = false; dropdownField.Auditable = false; dropdownField.System = true; dropdownField.DefaultValue = "opened"; dropdownField.Options = new List<SelectFieldOption> { new SelectFieldOption(){ Key = "opened", Value = "opened" }, new SelectFieldOption(){ Key = "completed", Value = "completed" } }; dropdownField.EnableSecurity = true; dropdownField.Permissions = new FieldPermissions(); dropdownField.Permissions.CanRead = new List<Guid>(); dropdownField.Permissions.CanUpdate = new List<Guid>(); //READ dropdownField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); dropdownField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE dropdownField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); dropdownField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(MILESTONE_ENTITY_ID, dropdownField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + MILESTONE_ENTITY_NAME + " Field: status" + " Message:" + response.Message); } } #endregion #region << project_id >> { InputGuidField guidField = new InputGuidField(); guidField.Id = new Guid("f1540e81-be80-4fed-b0c6-1d538b1dd17a"); guidField.Name = "project_id"; guidField.Label = "Project"; guidField.PlaceholderText = ""; guidField.Description = ""; guidField.HelpText = ""; guidField.Required = true; guidField.Unique = false; guidField.Searchable = false; guidField.Auditable = false; guidField.System = true; guidField.DefaultValue = Guid.Empty; guidField.GenerateNewId = false; guidField.EnableSecurity = true; guidField.Permissions = new FieldPermissions(); guidField.Permissions.CanRead = new List<Guid>(); guidField.Permissions.CanUpdate = new List<Guid>(); //READ guidField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE guidField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); { var response = entMan.CreateField(MILESTONE_ENTITY_ID, guidField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + MILESTONE_ENTITY_NAME + " Field: project_id" + " Message:" + response.Message); } } #endregion #region << x_tasks_not_started >> { InputNumberField numberField = new InputNumberField(); numberField.Id = new Guid("aacfb1b6-8318-4c88-ad9d-7fa0ad799537"); numberField.Name = "x_tasks_not_started"; numberField.Label = "x_tasks_not_started"; numberField.PlaceholderText = ""; numberField.Description = ""; numberField.HelpText = ""; numberField.Required = true; numberField.Unique = false; numberField.Searchable = false; numberField.Auditable = false; numberField.System = true; numberField.DefaultValue = 0; numberField.MinValue = null; numberField.MaxValue = null; numberField.DecimalPlaces = 0; numberField.EnableSecurity = true; numberField.Permissions = new FieldPermissions(); numberField.Permissions.CanRead = new List<Guid>(); numberField.Permissions.CanUpdate = new List<Guid>(); //READ numberField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE numberField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(MILESTONE_ENTITY_ID, numberField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + MILESTONE_ENTITY_NAME + " Field: x_tasks_not_started" + " Message:" + response.Message); } } #endregion #region << x_tasks_in_progress >> { InputNumberField numberField = new InputNumberField(); numberField.Id = new Guid("07fb158a-2b3d-421f-a7f0-c296b5ce76c9"); numberField.Name = "x_tasks_in_progress"; numberField.Label = "x_tasks_in_progress"; numberField.PlaceholderText = ""; numberField.Description = ""; numberField.HelpText = ""; numberField.Required = true; numberField.Unique = false; numberField.Searchable = false; numberField.Auditable = false; numberField.System = true; numberField.DefaultValue = 0; numberField.MinValue = null; numberField.MaxValue = null; numberField.DecimalPlaces = 0; numberField.EnableSecurity = true; numberField.Permissions = new FieldPermissions(); numberField.Permissions.CanRead = new List<Guid>(); numberField.Permissions.CanUpdate = new List<Guid>(); //READ numberField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE numberField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(MILESTONE_ENTITY_ID, numberField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + MILESTONE_ENTITY_NAME + " Field: x_tasks_in_progress" + " Message:" + response.Message); } } #endregion #region << x_tasks_completed >> { InputNumberField numberField = new InputNumberField(); numberField.Id = new Guid("407db47b-23be-4ce1-ad97-e0c63d8e5377"); numberField.Name = "x_tasks_completed"; numberField.Label = "x_tasks_completed"; numberField.PlaceholderText = ""; numberField.Description = ""; numberField.HelpText = ""; numberField.Required = true; numberField.Unique = false; numberField.Searchable = false; numberField.Auditable = false; numberField.System = true; numberField.DefaultValue = 0; numberField.MinValue = null; numberField.MaxValue = null; numberField.DecimalPlaces = 0; numberField.EnableSecurity = true; numberField.Permissions = new FieldPermissions(); numberField.Permissions.CanRead = new List<Guid>(); numberField.Permissions.CanUpdate = new List<Guid>(); //READ numberField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE numberField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(MILESTONE_ENTITY_ID, numberField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + MILESTONE_ENTITY_NAME + " Field: x_tasks_completed" + " Message:" + response.Message); } } #endregion #region << x_bugs_opened >> { InputNumberField numberField = new InputNumberField(); numberField.Id = new Guid("014b2a7c-475d-4c0f-b992-0f6ddf3a5454"); numberField.Name = "x_bugs_opened"; numberField.Label = "x_bugs_opened"; numberField.PlaceholderText = ""; numberField.Description = ""; numberField.HelpText = ""; numberField.Required = true; numberField.Unique = false; numberField.Searchable = false; numberField.Auditable = false; numberField.System = true; numberField.DefaultValue = 0; numberField.MinValue = null; numberField.MaxValue = null; numberField.DecimalPlaces = 0; numberField.EnableSecurity = true; numberField.Permissions = new FieldPermissions(); numberField.Permissions.CanRead = new List<Guid>(); numberField.Permissions.CanUpdate = new List<Guid>(); //READ numberField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE numberField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(MILESTONE_ENTITY_ID, numberField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + MILESTONE_ENTITY_NAME + " Field: x_bugs_opened" + " Message:" + response.Message); } } #endregion #region << x_bugs_reopened >> { InputNumberField numberField = new InputNumberField(); numberField.Id = new Guid("3432d7eb-690a-4076-be24-e583fa1e83c3"); numberField.Name = "x_bugs_reopened"; numberField.Label = "x_bugs_reopened"; numberField.PlaceholderText = ""; numberField.Description = ""; numberField.HelpText = ""; numberField.Required = true; numberField.Unique = false; numberField.Searchable = false; numberField.Auditable = false; numberField.System = true; numberField.DefaultValue = 0; numberField.MinValue = null; numberField.MaxValue = null; numberField.DecimalPlaces = 0; numberField.EnableSecurity = true; numberField.Permissions = new FieldPermissions(); numberField.Permissions.CanRead = new List<Guid>(); numberField.Permissions.CanUpdate = new List<Guid>(); //READ numberField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE numberField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(MILESTONE_ENTITY_ID, numberField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + MILESTONE_ENTITY_NAME + " Field: x_bugs_reopened" + " Message:" + response.Message); } } #endregion #region << x_bugs_closed >> { InputNumberField numberField = new InputNumberField(); numberField.Id = new Guid("09bb35c9-ba7f-455f-8205-11a91fd7a90d"); numberField.Name = "x_bugs_closed"; numberField.Label = "x_bugs_closed"; numberField.PlaceholderText = ""; numberField.Description = ""; numberField.HelpText = ""; numberField.Required = true; numberField.Unique = false; numberField.Searchable = false; numberField.Auditable = false; numberField.System = true; numberField.DefaultValue = 0; numberField.MinValue = null; numberField.MaxValue = null; numberField.DecimalPlaces = 0; numberField.EnableSecurity = true; numberField.Permissions = new FieldPermissions(); numberField.Permissions.CanRead = new List<Guid>(); numberField.Permissions.CanUpdate = new List<Guid>(); //READ numberField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE numberField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(MILESTONE_ENTITY_ID, numberField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + MILESTONE_ENTITY_NAME + " Field: x_bugs_closed" + " Message:" + response.Message); } } #endregion #region << project_1_n_milestone Relation >> { var originEntity = entMan.ReadEntity(PROJECT_ENTITY_ID).Object; var targetEntity = entMan.ReadEntity(MILESTONE_ENTITY_ID).Object; EntityRelation oneToNRelation = new EntityRelation(); oneToNRelation.Id = new Guid("0c446f98-eec2-40c1-9d66-8a3c2a2498e9"); oneToNRelation.Name = "project_1_n_milestone"; oneToNRelation.Label = "project_1_n_milestone"; oneToNRelation.System = true; oneToNRelation.RelationType = EntityRelationType.OneToMany; oneToNRelation.OriginEntityId = originEntity.Id; oneToNRelation.OriginFieldId = originEntity.Fields.Single(x => x.Name == "id").Id; oneToNRelation.TargetEntityId = targetEntity.Id; oneToNRelation.TargetFieldId = targetEntity.Fields.Single(x => x.Name == "project_id").Id; { var result = relMan.Create(oneToNRelation); if (!result.Success) throw new Exception("CREATE project_1_n_milestone RELATION:" + result.Message); } } #endregion #region << create general list >> { var createListEntity = entMan.ReadEntity(MILESTONE_ENTITY_ID).Object; var createListInput = new InputRecordList(); var listItem = new InputRecordListFieldItem(); var listSort = new InputRecordListSort(); var listQuery = new InputRecordListQuery(); //General list details createListInput.Id = new Guid("92b40989-c3a2-4a06-869a-789fba54e733"); createListInput.Name = "project_milestones"; createListInput.Label = "Milestones"; createListInput.Default = true; createListInput.System = true; createListInput.Type = "general"; createListInput.IconName = "map-signs"; createListInput.PageSize = 10; createListInput.Weight = 10; createListInput.VisibleColumnsCount = 5; createListInput.ServiceCode = null; createListInput.DynamicHtmlTemplate = "/plugins/webvella-projects/templates/project-milestones.html"; createListInput.DataSourceUrl = "/plugins/webvella-projects/api/project/milestones-list"; //Action items var newActionItemList = new List<ActionItem>(); { var actionItem = new ActionItem(); actionItem.Name = "wv_create_record"; actionItem.Menu = "page-title"; actionItem.Template = "<a class=\"btn btn-default btn-outline hidden-xs\" ng-show=\"::ngCtrl.userHasRecordPermissions('canCreate')\" \n ng-href=\"{{::ngCtrl.getRecordCreateUrl()}}\">Add New</a>"; actionItem.Weight = 1; newActionItemList.Add(actionItem); } createListInput.ActionItems = newActionItemList; //Fields { var response = entMan.CreateRecordList(MILESTONE_ENTITY_ID, createListInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + MILESTONE_ENTITY_NAME + " Updated List: general" + " Message:" + response.Message); } } #endregion #region << create create view >> { var createViewEntity = entMan.ReadEntity(MILESTONE_ENTITY_ID).Object; var createViewInput = new InputRecordView(); var viewSection = new InputRecordViewSection(); var viewRow = new InputRecordViewRow(); var viewColumn = new InputRecordViewColumn(); var viewItem = new InputRecordViewFieldItem(); var viewItemFromRelation = new InputRecordViewRelationFieldItem(); //General view fields #region << Details >> createViewInput.Id = new Guid("95160359-aa0a-419f-92f4-4102fc692411"); createViewInput.Name = "create"; createViewInput.Label = "Create"; createViewInput.Title = "Create new milestone"; createViewInput.CssClass = ""; createViewInput.Default = true; createViewInput.System = true; createViewInput.Type = "create"; createViewInput.Weight = 10; createViewInput.IconName = "file-text-o"; createViewInput.ServiceCode = null; createViewInput.DynamicHtmlTemplate = null; createViewInput.DataSourceUrl = null; #endregion #region << Get the header Region >> var headerRegion = new InputRecordViewRegion(); headerRegion.Name = "header"; headerRegion.Label = "header"; headerRegion.Sections = new List<InputRecordViewSection>(); #endregion #region << Section >> viewSection = new InputRecordViewSection(); viewSection.Id = new Guid("dd96bfb9-0dbc-4a6b-b7c6-92fb54b1844a"); viewSection.Name = "details"; viewSection.Label = "Details"; viewSection.ShowLabel = false; viewSection.CssClass = ""; viewSection.Collapsed = false; viewSection.TabOrder = "left-right"; viewSection.Weight = 1; viewSection.Rows = new List<InputRecordViewRow>(); #region << Row 1 >> viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("7f59d113-b469-4579-b780-961ead238e46"); viewRow.Weight = 1; viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = 6; viewColumn.Items = new List<InputRecordViewItemBase>(); #region << name >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = createViewEntity.Id; viewItem.EntityName = createViewEntity.Name; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "name").Id; viewItem.FieldName = "name"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << start_date >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = createViewEntity.Id; viewItem.EntityName = createViewEntity.Name; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "start_date").Id; viewItem.FieldName = "start_date"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << project name >> { var targetEntity = entMan.ReadEntity(PROJECT_ENTITY_ID).Object; var targetRelation = relMan.Read("project_1_n_milestone").Object; viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = targetEntity.Id; viewItemFromRelation.EntityName = targetEntity.Name; viewItemFromRelation.Type = "fieldFromRelation"; viewItemFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "name").Id; viewItemFromRelation.FieldName = "name"; viewItemFromRelation.FieldLabel = "Project"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = targetRelation.Id; viewItemFromRelation.RelationName = targetRelation.Name; viewColumn.Items.Add(viewItemFromRelation); } #endregion //Save column viewRow.Columns.Add(viewColumn); #endregion #region << Column 1 >> viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = 6; viewColumn.Items = new List<InputRecordViewItemBase>(); #region << status >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = createViewEntity.Id; viewItem.EntityName = createViewEntity.Name; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "status").Id; viewItem.FieldName = "status"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << end_date >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = createViewEntity.Id; viewItem.EntityName = createViewEntity.Name; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "end_date").Id; viewItem.FieldName = "end_date"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); #endregion //Save row viewSection.Rows.Add(viewRow); #endregion //Save section headerRegion.Sections.Add(viewSection); #endregion createViewInput.Regions = new List<InputRecordViewRegion>(); createViewInput.Regions.Add(headerRegion); #region << Sidebar >> createViewInput.Sidebar = new InputRecordViewSidebar(); createViewInput.Sidebar.CssClass = ""; createViewInput.Sidebar.Render = true; var sidebarItem = new InputRecordViewSidebarItemBase(); #endregion var newActionItemList = new List<ActionItem>(); { var actionItem = new ActionItem(); actionItem.Name = "wv_back_button"; actionItem.Menu = "sidebar-top"; actionItem.Template = "<a class=\"back clearfix\" href=\"javascript:void(0)\" ng-click=\"sidebarData.goBack()\"><i class=\"fa fa-fw fa-arrow-left\"></i> <span class=\"text\">Back</span></a>"; actionItem.Weight = 1; newActionItemList.Add(actionItem); } { var actionItem = new ActionItem(); actionItem.Name = "wv_create_and_list"; actionItem.Menu = "create-bottom"; actionItem.Template = "<a class=\"btn btn-primary\" ng-click='ngCtrl.create(\"default\")' ng-if=\"::ngCtrl.createViewRegion != null\">Create</a>"; actionItem.Weight = 1; newActionItemList.Add(actionItem); } { var actionItem = new ActionItem(); actionItem.Name = "wv_create_and_details"; actionItem.Menu = "create-bottom"; actionItem.Template = "<a class=\"btn btn-default btn-outline\" ng-click='ngCtrl.create(\"details\")' ng-if=\"::ngCtrl.createViewRegion != null\">Create & Details</a>"; actionItem.Weight = 2; newActionItemList.Add(actionItem); } { var actionItem = new ActionItem(); actionItem.Name = "wv_create_cancel"; actionItem.Menu = "create-bottom"; actionItem.Template = "<a class=\"btn btn-default btn-outline\" ng-click=\"ngCtrl.cancel()\">Cancel</a>"; actionItem.Weight = 3; newActionItemList.Add(actionItem); } createViewInput.ActionItems = newActionItemList; { var response = entMan.CreateRecordView(MILESTONE_ENTITY_ID, createViewInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + MILESTONE_ENTITY_NAME + " Updated view: create" + " Message:" + response.Message); } } #endregion } #endregion #region << wv_task >> { #region << entity >> { InputEntity entity = new InputEntity(); entity.Id = TASK_ENTITY_ID; entity.Name = TASK_ENTITY_NAME; entity.Label = "Task"; entity.LabelPlural = "Tasks"; entity.System = true; entity.IconName = "tasks"; entity.Weight = 4; entity.RecordPermissions = new RecordPermissions(); entity.RecordPermissions.CanCreate = new List<Guid>(); entity.RecordPermissions.CanRead = new List<Guid>(); entity.RecordPermissions.CanUpdate = new List<Guid>(); entity.RecordPermissions.CanDelete = new List<Guid>(); //Create entity.RecordPermissions.CanCreate.Add(SystemIds.AdministratorRoleId); entity.RecordPermissions.CanCreate.Add(SystemIds.RegularRoleId); //READ entity.RecordPermissions.CanRead.Add(SystemIds.AdministratorRoleId); entity.RecordPermissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE entity.RecordPermissions.CanUpdate.Add(SystemIds.AdministratorRoleId); entity.RecordPermissions.CanUpdate.Add(SystemIds.RegularRoleId); //System fields and relations Ids should be hardcoded for the compare/change code generation to work later on correctly var systemItemIdDictionary = new Dictionary<string, Guid>(); systemItemIdDictionary["id"] = new Guid("916b8d1e-d6b6-45a9-9060-b0717b2b8b73"); systemItemIdDictionary["created_on"] = new Guid("6a83a91e-7eb8-4fb4-ab5f-5750cb4015d3"); systemItemIdDictionary["created_by"] = new Guid("b6ae3dc9-0c79-478c-89c9-3502f9da319f"); systemItemIdDictionary["last_modified_on"] = new Guid("55dcf9a2-79f7-42cc-8b3f-3cfea8f6dee3"); systemItemIdDictionary["last_modified_by"] = new Guid("39fc45d5-c472-44ed-b3f3-4687fb4a7501"); systemItemIdDictionary["user_wv_task_created_by"] = new Guid("0affc050-2c24-4ae3-bb5e-b08139661d83"); systemItemIdDictionary["user_wv_task_modified_by"] = new Guid("5d4730b0-82b7-401e-8eb3-1e4250aa82a1"); { var response = entMan.CreateEntity(entity, false, false, systemItemIdDictionary); if (!response.Success) throw new Exception("System error 10050. Entity: " + TASK_ENTITY_NAME + " Field: entity creation" + " Message:" + response.Message); } } #endregion #region << number >> { InputAutoNumberField autonumberField = new InputAutoNumberField(); autonumberField.Id = new Guid("1c7e71ce-125d-4afd-aa22-1c0a564bcb7b"); autonumberField.Name = "number"; autonumberField.Label = "Number"; autonumberField.PlaceholderText = ""; autonumberField.Description = ""; autonumberField.HelpText = ""; autonumberField.Required = true; autonumberField.Unique = true; autonumberField.Searchable = true; autonumberField.Auditable = false; autonumberField.System = true; autonumberField.DefaultValue = 0; autonumberField.DisplayFormat = "{0}"; autonumberField.StartingNumber = 1; autonumberField.EnableSecurity = true; autonumberField.Permissions = new FieldPermissions(); autonumberField.Permissions.CanRead = new List<Guid>(); autonumberField.Permissions.CanUpdate = new List<Guid>(); //READ autonumberField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); autonumberField.Permissions.CanRead.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(TASK_ENTITY_ID, autonumberField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + TASK_ENTITY_NAME + " Field: number" + " Message:" + response.Message); } } #endregion #region << code >> { InputTextField textboxField = new InputTextField(); textboxField.Id = new Guid("04f31ad8-4583-4237-8d54-f82c3f44b918"); textboxField.Name = "code"; textboxField.Label = "Code"; textboxField.PlaceholderText = ""; textboxField.Description = ""; textboxField.HelpText = ""; textboxField.Required = false; textboxField.Unique = false; textboxField.Searchable = true; textboxField.Auditable = false; textboxField.System = true; textboxField.DefaultValue = string.Empty; textboxField.MaxLength = null; textboxField.EnableSecurity = true; textboxField.Permissions = new FieldPermissions(); textboxField.Permissions.CanRead = new List<Guid>(); textboxField.Permissions.CanUpdate = new List<Guid>(); //READ textboxField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); textboxField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE textboxField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); textboxField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(TASK_ENTITY_ID, textboxField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + TASK_ENTITY_NAME + " Field: subject" + " Message:" + response.Message); } } #endregion #region << subject >> { InputTextField textboxField = new InputTextField(); textboxField.Id = new Guid("7843bfbd-30c1-4438-af48-ffe56b7f294a"); textboxField.Name = "subject"; textboxField.Label = "Subject"; textboxField.PlaceholderText = ""; textboxField.Description = ""; textboxField.HelpText = ""; textboxField.Required = true; textboxField.Unique = false; textboxField.Searchable = true; textboxField.Auditable = false; textboxField.System = true; textboxField.DefaultValue = string.Empty; textboxField.MaxLength = null; textboxField.EnableSecurity = true; textboxField.Permissions = new FieldPermissions(); textboxField.Permissions.CanRead = new List<Guid>(); textboxField.Permissions.CanUpdate = new List<Guid>(); //READ textboxField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); textboxField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE textboxField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); textboxField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(TASK_ENTITY_ID, textboxField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + TASK_ENTITY_NAME + " Field: subject" + " Message:" + response.Message); } } #endregion #region << owner_id >> { InputGuidField guidField = new InputGuidField(); guidField.Id = new Guid("d9cfe549-5ae2-45ee-b7ee-1a14a84b0166"); guidField.Name = "owner_id"; guidField.Label = "Owned by"; guidField.PlaceholderText = ""; guidField.Description = ""; guidField.HelpText = ""; guidField.Required = true; guidField.Unique = false; guidField.Searchable = false; guidField.Auditable = false; guidField.System = true; guidField.DefaultValue = Guid.Empty; guidField.GenerateNewId = false; guidField.EnableSecurity = true; guidField.Permissions = new FieldPermissions(); guidField.Permissions.CanRead = new List<Guid>(); guidField.Permissions.CanUpdate = new List<Guid>(); //READ guidField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE guidField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(TASK_ENTITY_ID, guidField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + TASK_ENTITY_NAME + " Field: owner_id" + " Message:" + response.Message); } } #endregion #region << milestone_id >> { InputGuidField guidField = new InputGuidField(); guidField.Id = new Guid("6bb67bc2-a09c-4785-b316-c8795696fc17"); guidField.Name = "milestone_id"; guidField.Label = "Release milestone"; guidField.PlaceholderText = ""; guidField.Description = ""; guidField.HelpText = ""; guidField.Required = false; guidField.Unique = false; guidField.Searchable = false; guidField.Auditable = false; guidField.System = true; guidField.DefaultValue = Guid.Empty; guidField.GenerateNewId = false; guidField.EnableSecurity = true; guidField.Permissions = new FieldPermissions(); guidField.Permissions.CanRead = new List<Guid>(); guidField.Permissions.CanUpdate = new List<Guid>(); //READ guidField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE guidField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(TASK_ENTITY_ID, guidField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + TASK_ENTITY_NAME + " Field: milestone_id" + " Message:" + response.Message); } } #endregion #region << description >> { InputHtmlField htmlField = new InputHtmlField(); htmlField.Id = new Guid("a00eb247-918a-46ba-9869-8d1168ea8f45"); htmlField.Name = "description"; htmlField.Label = "Description"; htmlField.PlaceholderText = ""; htmlField.Description = ""; htmlField.HelpText = ""; htmlField.Required = false; htmlField.Unique = false; htmlField.Searchable = false; htmlField.Auditable = false; htmlField.System = true; htmlField.DefaultValue = string.Empty; htmlField.EnableSecurity = true; htmlField.Permissions = new FieldPermissions(); htmlField.Permissions.CanRead = new List<Guid>(); htmlField.Permissions.CanUpdate = new List<Guid>(); htmlField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); htmlField.Permissions.CanRead.Add(SystemIds.RegularRoleId); htmlField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); htmlField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(TASK_ENTITY_ID, htmlField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + TASK_ENTITY_NAME + " Field: description" + " Message:" + response.Message); } } #endregion #region << parent_id >> { InputGuidField guidField = new InputGuidField(); guidField.Id = new Guid("98f6cdf5-634c-494b-9e71-3aa7ee779328"); guidField.Name = "parent_id"; guidField.Label = "Parent task"; guidField.PlaceholderText = ""; guidField.Description = ""; guidField.HelpText = ""; guidField.Required = false; guidField.Unique = false; guidField.Searchable = false; guidField.Auditable = false; guidField.System = true; guidField.DefaultValue = Guid.Empty; guidField.GenerateNewId = false; guidField.EnableSecurity = true; guidField.Permissions = new FieldPermissions(); guidField.Permissions.CanRead = new List<Guid>(); guidField.Permissions.CanUpdate = new List<Guid>(); //READ guidField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE guidField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(TASK_ENTITY_ID, guidField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + TASK_ENTITY_NAME + " Field: parent_id" + " Message:" + response.Message); } } #endregion #region << project_id >> { InputGuidField guidField = new InputGuidField(); guidField.Id = new Guid("68e796c8-cc99-43b1-a285-2c6bc29f52f2"); guidField.Name = "project_id"; guidField.Label = "Project"; guidField.PlaceholderText = ""; guidField.Description = ""; guidField.HelpText = ""; guidField.Required = true; guidField.Unique = false; guidField.Searchable = false; guidField.Auditable = false; guidField.System = true; guidField.DefaultValue = Guid.Empty; guidField.GenerateNewId = false; guidField.EnableSecurity = true; guidField.Permissions = new FieldPermissions(); guidField.Permissions.CanRead = new List<Guid>(); guidField.Permissions.CanUpdate = new List<Guid>(); //READ guidField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE guidField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); { var response = entMan.CreateField(TASK_ENTITY_ID, guidField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + TASK_ENTITY_NAME + " Field: project_id" + " Message:" + response.Message); } } #endregion #region << start_date >> { InputDateField dateField = new InputDateField(); dateField.Id = new Guid("5bf852bf-5e6c-4791-bc8b-f1366440c04b"); dateField.Name = "start_date"; dateField.Label = "Start date"; dateField.PlaceholderText = ""; dateField.Description = ""; dateField.HelpText = ""; dateField.Required = false; dateField.Unique = false; dateField.Searchable = true; dateField.Auditable = false; dateField.System = true; dateField.DefaultValue = null; dateField.Format = "dd MMM yyyy"; dateField.UseCurrentTimeAsDefaultValue = true; dateField.EnableSecurity = true; dateField.Permissions = new FieldPermissions(); dateField.Permissions.CanRead = new List<Guid>(); dateField.Permissions.CanUpdate = new List<Guid>(); //READ dateField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); dateField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE dateField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); dateField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(TASK_ENTITY_ID, dateField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + TASK_ENTITY_NAME + " Field: start_date" + " Message:" + response.Message); } } #endregion #region << end_date >> { InputDateField dateField = new InputDateField(); dateField.Id = new Guid("c6dc9db2-0081-4a91-b0e2-78f9c1c45a51"); dateField.Name = "end_date"; dateField.Label = "End date"; dateField.PlaceholderText = ""; dateField.Description = ""; dateField.HelpText = ""; dateField.Required = false; dateField.Unique = false; dateField.Searchable = true; dateField.Auditable = false; dateField.System = true; dateField.DefaultValue = null; dateField.Format = "dd MMM yyyy"; dateField.UseCurrentTimeAsDefaultValue = true; dateField.EnableSecurity = true; dateField.Permissions = new FieldPermissions(); dateField.Permissions.CanRead = new List<Guid>(); dateField.Permissions.CanUpdate = new List<Guid>(); //READ dateField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); dateField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE dateField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); dateField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(TASK_ENTITY_ID, dateField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + TASK_ENTITY_NAME + " Field: end_date" + " Message:" + response.Message); } } #endregion #region << priority >> { InputSelectField dropdownField = new InputSelectField(); dropdownField.Id = new Guid("04ede478-99ec-4f7f-97af-0df3e89409b1"); dropdownField.Name = "priority"; dropdownField.Label = "Priority"; dropdownField.PlaceholderText = ""; dropdownField.Description = ""; dropdownField.HelpText = ""; dropdownField.Required = true; dropdownField.Unique = false; dropdownField.Searchable = true; dropdownField.Auditable = false; dropdownField.System = true; dropdownField.DefaultValue = "medium"; dropdownField.Options = new List<SelectFieldOption> { new SelectFieldOption(){ Key = "low", Value = "low" }, new SelectFieldOption(){ Key = "medium", Value = "medium" }, new SelectFieldOption(){ Key = "hight", Value = "hight" } }; dropdownField.EnableSecurity = true; dropdownField.Permissions = new FieldPermissions(); dropdownField.Permissions.CanRead = new List<Guid>(); dropdownField.Permissions.CanUpdate = new List<Guid>(); //READ dropdownField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); dropdownField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE dropdownField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); dropdownField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(TASK_ENTITY_ID, dropdownField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + TASK_ENTITY_NAME + " Field: priority" + " Message:" + response.Message); } } #endregion #region << status >> { InputSelectField dropdownField = new InputSelectField(); dropdownField.Id = new Guid("0702e611-6fe5-42e4-9bad-d549cba9cbb1"); dropdownField.Name = "status"; dropdownField.Label = "Status"; dropdownField.PlaceholderText = ""; dropdownField.Description = ""; dropdownField.HelpText = ""; dropdownField.Required = true; dropdownField.Unique = false; dropdownField.Searchable = true; dropdownField.Auditable = false; dropdownField.System = true; dropdownField.DefaultValue = "not started"; dropdownField.Options = new List<SelectFieldOption> { new SelectFieldOption(){ Key = "not started", Value = "not started" }, new SelectFieldOption(){ Key = "in progress", Value = "in progress" }, new SelectFieldOption(){ Key = "completed", Value = "completed" } }; dropdownField.EnableSecurity = true; dropdownField.Permissions = new FieldPermissions(); dropdownField.Permissions.CanRead = new List<Guid>(); dropdownField.Permissions.CanUpdate = new List<Guid>(); //READ dropdownField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); dropdownField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE dropdownField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); dropdownField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(TASK_ENTITY_ID, dropdownField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + TASK_ENTITY_NAME + " Field: status" + " Message:" + response.Message); } } #endregion #region << x_billable_hours >> { InputNumberField numberField = new InputNumberField(); numberField.Id = new Guid("d79a25e4-3eeb-4a5b-84e8-294b0c146c4d"); numberField.Name = "x_billable_hours"; numberField.Label = "Billable hours"; numberField.PlaceholderText = ""; numberField.Description = ""; numberField.HelpText = ""; numberField.Required = false; numberField.Unique = false; numberField.Searchable = false; numberField.Auditable = false; numberField.System = true; numberField.DefaultValue = 0; numberField.MinValue = null; numberField.MaxValue = null; numberField.DecimalPlaces = 0; numberField.EnableSecurity = true; numberField.Permissions = new FieldPermissions(); numberField.Permissions.CanRead = new List<Guid>(); numberField.Permissions.CanUpdate = new List<Guid>(); //READ numberField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE numberField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(TASK_ENTITY_ID, numberField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + TASK_ENTITY_NAME + " Field: x_billable_hours" + " Message:" + response.Message); } } #endregion #region << x_nonbillable_hours >> { InputNumberField numberField = new InputNumberField(); numberField.Id = new Guid("a4196b7b-1de7-4106-b393-79eb3d1b4b79"); numberField.Name = "x_nonbillable_hours"; numberField.Label = "Non-Billable hours"; numberField.PlaceholderText = ""; numberField.Description = ""; numberField.HelpText = ""; numberField.Required = false; numberField.Unique = false; numberField.Searchable = false; numberField.Auditable = false; numberField.System = true; numberField.DefaultValue = 0; numberField.MinValue = null; numberField.MaxValue = null; numberField.DecimalPlaces = 0; numberField.EnableSecurity = true; numberField.Permissions = new FieldPermissions(); numberField.Permissions.CanRead = new List<Guid>(); numberField.Permissions.CanUpdate = new List<Guid>(); //READ numberField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE numberField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(TASK_ENTITY_ID, numberField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + TASK_ENTITY_NAME + " Field: x_nonbillable_hours" + " Message:" + response.Message); } } #endregion #region << user_1_n_task_owner Relation >> { var originEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; var targetEntity = entMan.ReadEntity(TASK_ENTITY_ID).Object; EntityRelation oneToNRelation = new EntityRelation(); oneToNRelation.Id = new Guid("7ce76c81-e604-401e-907f-23de982b930e"); oneToNRelation.Name = "user_1_n_task_owner"; oneToNRelation.Label = "user_1_n_task_owner"; oneToNRelation.System = true; oneToNRelation.RelationType = EntityRelationType.OneToMany; oneToNRelation.OriginEntityId = originEntity.Id; oneToNRelation.OriginFieldId = originEntity.Fields.Single(x => x.Name == "id").Id; oneToNRelation.TargetEntityId = targetEntity.Id; oneToNRelation.TargetFieldId = targetEntity.Fields.Single(x => x.Name == "owner_id").Id; { var result = relMan.Create(oneToNRelation); if (!result.Success) throw new Exception("CREATE user_1_n_task_owner RELATION:" + result.Message); } } #endregion #region << user_n_n_task_watchers Relation >> { var originEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; var targetEntity = entMan.ReadEntity(TASK_ENTITY_ID).Object; EntityRelation NToNRelation = new EntityRelation(); NToNRelation.Id = new Guid("de7e1578-8f8f-4454-a954-0fb62d3bf425"); NToNRelation.Name = "user_n_n_task_watchers"; NToNRelation.Label = "user_n_n_task_watchers"; NToNRelation.System = true; NToNRelation.RelationType = EntityRelationType.ManyToMany; NToNRelation.OriginEntityId = originEntity.Id; NToNRelation.OriginFieldId = originEntity.Fields.Single(x => x.Name == "id").Id; NToNRelation.TargetEntityId = targetEntity.Id; NToNRelation.TargetFieldId = targetEntity.Fields.Single(x => x.Name == "id").Id; { var result = relMan.Create(NToNRelation); if (!result.Success) throw new Exception("CREATE user_n_n_task_watchers RELATION:" + result.Message); } } #endregion #region << task_1_n_task_parent Relation >> { var originEntity = entMan.ReadEntity(TASK_ENTITY_ID).Object; var targetEntity = entMan.ReadEntity(TASK_ENTITY_ID).Object; EntityRelation oneToNRelation = new EntityRelation(); oneToNRelation.Id = new Guid("fd42ca83-9c08-4e7d-ba97-782208f44b18"); oneToNRelation.Name = "task_1_n_task_parent"; oneToNRelation.Label = "task_1_n_task_parent"; oneToNRelation.System = true; oneToNRelation.RelationType = EntityRelationType.OneToMany; oneToNRelation.OriginEntityId = originEntity.Id; oneToNRelation.OriginFieldId = originEntity.Fields.Single(x => x.Name == "id").Id; oneToNRelation.TargetEntityId = targetEntity.Id; oneToNRelation.TargetFieldId = targetEntity.Fields.Single(x => x.Name == "parent_id").Id; { var result = relMan.Create(oneToNRelation); if (!result.Success) throw new Exception("CREATE task_1_n_task_parent RELATION:" + result.Message); } } #endregion #region << project_1_n_task Relation >> { var originEntity = entMan.ReadEntity(PROJECT_ENTITY_ID).Object; var targetEntity = entMan.ReadEntity(TASK_ENTITY_ID).Object; EntityRelation oneToNRelation = new EntityRelation(); oneToNRelation.Id = new Guid("1f860b8c-7fa1-40fa-874f-19c2b5309817"); oneToNRelation.Name = "project_1_n_task"; oneToNRelation.Label = "project_1_n_task"; oneToNRelation.System = true; oneToNRelation.RelationType = EntityRelationType.OneToMany; oneToNRelation.OriginEntityId = originEntity.Id; oneToNRelation.OriginFieldId = originEntity.Fields.Single(x => x.Name == "id").Id; oneToNRelation.TargetEntityId = targetEntity.Id; oneToNRelation.TargetFieldId = targetEntity.Fields.Single(x => x.Name == "project_id").Id; { var result = relMan.Create(oneToNRelation); if (!result.Success) throw new Exception("CREATE project_1_n_task RELATION:" + result.Message); } } #endregion #region << milestone_1_n_task Relation >> { var originEntity = entMan.ReadEntity(MILESTONE_ENTITY_ID).Object; var targetEntity = entMan.ReadEntity(TASK_ENTITY_ID).Object; EntityRelation oneToNRelation = new EntityRelation(); oneToNRelation.Id = new Guid("3b600a1c-066e-42e2-a678-0de4f0f8a9e1"); oneToNRelation.Name = "milestone_1_n_task"; oneToNRelation.Label = "milestone_1_n_task"; oneToNRelation.System = true; oneToNRelation.RelationType = EntityRelationType.OneToMany; oneToNRelation.OriginEntityId = originEntity.Id; oneToNRelation.OriginFieldId = originEntity.Fields.Single(x => x.Name == "id").Id; oneToNRelation.TargetEntityId = targetEntity.Id; oneToNRelation.TargetFieldId = targetEntity.Fields.Single(x => x.Name == "milestone_id").Id; { var result = relMan.Create(oneToNRelation); if (!result.Success) throw new Exception("CREATE milestone_1_n_task RELATION:" + result.Message); } } #endregion #region << create general list >> { var createListEntity = entMan.ReadEntity(TASK_ENTITY_ID).Object; var createListInput = new InputRecordList(); var listField = new InputRecordListFieldItem(); var listFieldFromRelation = new InputRecordListRelationFieldItem(); var listSort = new InputRecordListSort(); var listQuery = new InputRecordListQuery(); //General list details createListInput.Id = new Guid("44f8ed83-b7e8-4223-b02e-b5e35ed4bcc1"); createListInput.Name = "project_tasks"; createListInput.Label = "Project Tasks"; createListInput.Default = true; createListInput.System = true; createListInput.IconName = "tasks"; createListInput.Type = "hidden"; createListInput.PageSize = 10; createListInput.Weight = 10; createListInput.ColumnWidthsCSV = "auto,30px,120px,120px,120px,120px"; createListInput.CssClass = "task-list"; createListInput.VisibleColumnsCount = 6; createListInput.ServiceCode = null; createListInput.DynamicHtmlTemplate = null; createListInput.DataSourceUrl = null; createListInput.Columns = new List<InputRecordListItemBase>(); //Fields #region << subject >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "subject").Id; listField.FieldName = "subject"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << owner - image >> { var targetEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; listFieldFromRelation = new InputRecordListRelationFieldItem(); listFieldFromRelation.EntityId = targetEntity.Id; listFieldFromRelation.EntityName = targetEntity.Name; listFieldFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "image").Id; listFieldFromRelation.FieldName = "image"; listFieldFromRelation.FieldLabel = "Owner"; listFieldFromRelation.RelationId = new Guid("7ce76c81-e604-401e-907f-23de982b930e"); listFieldFromRelation.RelationName = "user_1_n_task_owner"; listFieldFromRelation.Type = "fieldFromRelation"; createListInput.Columns.Add(listFieldFromRelation); } #endregion #region << start_date >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "start_date").Id; listField.FieldName = "start_date"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << end_date >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "end_date").Id; listField.FieldName = "end_date"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << status >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "status").Id; listField.FieldName = "status"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << priority >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "priority").Id; listField.FieldName = "priority"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << query main>> { listQuery = new InputRecordListQuery(); listQuery.FieldName = null; listQuery.FieldValue = null; listQuery.QueryType = "AND"; listQuery.SubQueries = new List<InputRecordListQuery>(); #region << subject >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "subject"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""subject"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "CONTAINS"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion #region << status >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "status"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""status"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "EQ"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion #region << priority >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "priority"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""priority"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "EQ"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion createListInput.Query = listQuery; } #endregion #region << Sort >> createListInput.Sorts = new List<InputRecordListSort>(); { listSort = new InputRecordListSort(); listSort.FieldName = @"{""name"":""url_sort"", ""option"": ""sortBy"", ""default"": ""end_date"", ""settings"":{""order"":""sortOrder""}}"; listSort.SortType = "ascending"; createListInput.Sorts.Add(listSort); } #endregion var newActionItemList = new List<ActionItem>(); { var actionItem = new ActionItem(); actionItem.Name = "wv_create_record"; actionItem.Menu = "page-title"; actionItem.Template = "<a class=\"btn btn-default btn-outline hidden-xs\" ng-show=\"::ngCtrl.userHasRecordPermissions('canCreate')\" \n ng-href=\"{{::ngCtrl.getRecordCreateUrl()}}\">Add New</a>"; actionItem.Weight = 1; newActionItemList.Add(actionItem); } { var actionItem = new ActionItem(); actionItem.Name = "wv_import_records"; actionItem.Menu = "page-title-dropdown"; actionItem.Template = "<a ng-click=\"ngCtrl.openImportModal()\" class=\"ng-hide\" ng-show=\"::ngCtrl.userHasRecordPermissions('canCreate,canUpdate')\">\n\t<i class=\"fa fa-fw fa-upload\"></i> Import CSV\n</a>"; actionItem.Weight = 10; newActionItemList.Add(actionItem); } { var actionItem = new ActionItem(); actionItem.Name = "wv_export_records"; actionItem.Menu = "page-title-dropdown"; actionItem.Template = "<a ng-click=\"ngCtrl.openExportModal()\" class=\"ng-hide\" ng-show=\"::ngCtrl.userHasRecordPermissions('canCreate,canUpdate')\">\n\t<i class=\"fa fa-fw fa-download\"></i> Export CSV\n</a>"; actionItem.Weight = 11; newActionItemList.Add(actionItem); } { var actionItem = new ActionItem(); actionItem.Name = "wv_record_details"; actionItem.Menu = "record-row"; actionItem.Template = "<a class=\"btn btn-default btn-outline\" ng-href=\"{{::ngCtrl.getRecordDetailsUrl(record)}}\">\n <i class=\"fa fa-fw fa-eye\"></i>\n</a>"; actionItem.Weight = 1; newActionItemList.Add(actionItem); } createListInput.ActionItems = newActionItemList; { var response = entMan.CreateRecordList(TASK_ENTITY_ID, createListInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + TASK_ENTITY_NAME + " Updated List: general" + " Message:" + response.Message); } } #endregion #region << List name: my_tasks >> { var createListEntity = entMan.ReadEntity(TASK_ENTITY_ID).Object; var createListInput = new InputRecordList(); var listField = new InputRecordListFieldItem(); var listFieldFromRelation = new InputRecordListRelationFieldItem(); var listSort = new InputRecordListSort(); var listQuery = new InputRecordListQuery(); #region << details >> createListInput.Id = new Guid("42da1595-bf3f-49b1-a784-1218b07d668d"); createListInput.Type = "general"; createListInput.Name = "my_tasks"; createListInput.Label = "My Owned Active Tasks"; createListInput.Weight = 1; createListInput.Default = false; createListInput.System = true; createListInput.CssClass = "task-list"; createListInput.IconName = "tasks"; createListInput.VisibleColumnsCount = 7; createListInput.ColumnWidthsCSV = "100px,auto,30px,120px,120px,120px,120px"; createListInput.PageSize = 10; createListInput.DynamicHtmlTemplate = null; createListInput.DataSourceUrl = null; createListInput.ServiceCode = null; #endregion #region << action items >> createListInput.ActionItems = new List<ActionItem>(); var actionItem = new ActionItem(); { actionItem = new ActionItem(); actionItem.Name = "wv_record_details"; actionItem.Menu = "record-row"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline"" ng-href=""{{::ngCtrl.getRecordDetailsUrl(record, ngCtrl)}}""> <i class=""fa fa-fw fa-eye""></i> </a>"; createListInput.ActionItems.Add(actionItem); } { actionItem = new ActionItem(); actionItem.Name = "wv_create_record"; actionItem.Menu = "page-title"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline hidden-xs"" ng-show=""::ngCtrl.userHasRecordPermissions('canCreate')"" ng-href=""{{::ngCtrl.getRecordCreateUrl(ngCtrl)}}"">Add New</a>"; createListInput.ActionItems.Add(actionItem); } #endregion #region << Columns >> createListInput.Columns = new List<InputRecordListItemBase>(); #region << code >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "code").Id; listField.FieldName = "code"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << subject >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "subject").Id; listField.FieldName = "subject"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << owner - image >> { var targetEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; listFieldFromRelation = new InputRecordListRelationFieldItem(); listFieldFromRelation.EntityId = targetEntity.Id; listFieldFromRelation.EntityName = targetEntity.Name; listFieldFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "image").Id; listFieldFromRelation.FieldName = "image"; listFieldFromRelation.FieldLabel = "Owner"; listFieldFromRelation.RelationId = new Guid("7ce76c81-e604-401e-907f-23de982b930e"); listFieldFromRelation.RelationName = "user_1_n_task_owner"; listFieldFromRelation.Type = "fieldFromRelation"; createListInput.Columns.Add(listFieldFromRelation); } #endregion #region << start_date >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "start_date").Id; listField.FieldName = "start_date"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << end_date >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "end_date").Id; listField.FieldName = "end_date"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << status >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "status").Id; listField.FieldName = "status"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << priority >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "priority").Id; listField.FieldName = "priority"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #endregion #region << relation options >> createListInput.RelationOptions = new List<EntityRelationOptionsItem>(); #endregion #region << query >> createListInput.Query = new InputRecordListQuery(); //Main query rule createListInput.Query.FieldName = null; createListInput.Query.FieldValue = null; createListInput.Query.QueryType = "AND"; createListInput.Query.SubQueries = new List<InputRecordListQuery>(); #region << Section 1 >> listQuery = new InputRecordListQuery(); listQuery.FieldName = null; listQuery.FieldValue = null; listQuery.QueryType = "AND"; listQuery.SubQueries = new List<InputRecordListQuery>(); #region << owner_id >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "owner_id"; subQuery.FieldValue = @"{""name"":""current_user"", ""option"": ""id"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "EQ"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion createListInput.Query.SubQueries.Add(listQuery); #endregion #region << Section 2 >> listQuery = new InputRecordListQuery(); listQuery.FieldName = null; listQuery.FieldValue = null; listQuery.QueryType = "AND"; listQuery.SubQueries = new List<InputRecordListQuery>(); #region << code >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "code"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""code"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "CONTAINS"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion #region << subject >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "subject"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""subject"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "CONTAINS"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion #region << status >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "status"; subQuery.FieldValue = "completed"; subQuery.QueryType = "NOT"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion #region << priority >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "priority"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""priority"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "EQ"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion createListInput.Query.SubQueries.Add(listQuery); #endregion #endregion #region << Sort >> createListInput.Sorts = new List<InputRecordListSort>(); listSort = new InputRecordListSort(); listSort.FieldName = @"{""name"":""url_sort"", ""option"": ""sortBy"", ""default"": ""end_date"", ""settings"":{""order"":""sortOrder""}}"; listSort.SortType = "descending"; createListInput.Sorts.Add(listSort); #endregion { var response = entMan.CreateRecordList(TASK_ENTITY_ID, createListInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + TASK_ENTITY_NAME + " Updated List: my_tickets" + " Message:" + response.Message); } } #endregion #region << List name: created_tasks >> { var createListEntity = entMan.ReadEntity(TASK_ENTITY_ID).Object; var createListInput = new InputRecordList(); var listField = new InputRecordListFieldItem(); var listFieldFromRelation = new InputRecordListRelationFieldItem(); var listSort = new InputRecordListSort(); var listQuery = new InputRecordListQuery(); #region << details >> createListInput.Id = new Guid("dcdc058e-2684-4b80-b011-25ccc3dab184"); createListInput.Type = "general"; createListInput.Name = "created_tasks"; createListInput.Label = "Tasks created by me"; createListInput.Weight = 3; createListInput.Default = false; createListInput.System = true; createListInput.CssClass = "task-list"; createListInput.IconName = "tasks"; createListInput.VisibleColumnsCount = 7; createListInput.ColumnWidthsCSV = "100px,auto,30px,120px,120px,120px,120px"; createListInput.PageSize = 10; createListInput.DynamicHtmlTemplate = null; createListInput.DataSourceUrl = null; createListInput.ServiceCode = null; #endregion #region << action items >> createListInput.ActionItems = new List<ActionItem>(); var actionItem = new ActionItem(); { actionItem = new ActionItem(); actionItem.Name = "wv_record_details"; actionItem.Menu = "record-row"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline"" ng-href=""{{::ngCtrl.getRecordDetailsUrl(record, ngCtrl)}}""> <i class=""fa fa-fw fa-eye""></i> </a>"; createListInput.ActionItems.Add(actionItem); } { actionItem = new ActionItem(); actionItem.Name = "wv_create_record"; actionItem.Menu = "page-title"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline hidden-xs"" ng-show=""::ngCtrl.userHasRecordPermissions('canCreate')"" ng-href=""{{::ngCtrl.getRecordCreateUrl(ngCtrl)}}"">Add New</a>"; createListInput.ActionItems.Add(actionItem); } #endregion #region << Columns >> createListInput.Columns = new List<InputRecordListItemBase>(); #region << code >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "code").Id; listField.FieldName = "code"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << subject >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "subject").Id; listField.FieldName = "subject"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << owner - image >> { var targetEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; listFieldFromRelation = new InputRecordListRelationFieldItem(); listFieldFromRelation.EntityId = targetEntity.Id; listFieldFromRelation.EntityName = targetEntity.Name; listFieldFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "image").Id; listFieldFromRelation.FieldName = "image"; listFieldFromRelation.FieldLabel = "Owner"; listFieldFromRelation.RelationId = new Guid("7ce76c81-e604-401e-907f-23de982b930e"); listFieldFromRelation.RelationName = "user_1_n_task_owner"; listFieldFromRelation.Type = "fieldFromRelation"; createListInput.Columns.Add(listFieldFromRelation); } #endregion #region << start_date >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "start_date").Id; listField.FieldName = "start_date"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << end_date >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "end_date").Id; listField.FieldName = "end_date"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << status >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "status").Id; listField.FieldName = "status"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << priority >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "priority").Id; listField.FieldName = "priority"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #endregion #region << relation options >> createListInput.RelationOptions = new List<EntityRelationOptionsItem>(); #endregion #region << query >> createListInput.Query = new InputRecordListQuery(); //Main query rule createListInput.Query.FieldName = null; createListInput.Query.FieldValue = null; createListInput.Query.QueryType = "AND"; createListInput.Query.SubQueries = new List<InputRecordListQuery>(); #region << Section 1 >> listQuery = new InputRecordListQuery(); listQuery.FieldName = null; listQuery.FieldValue = null; listQuery.QueryType = "AND"; listQuery.SubQueries = new List<InputRecordListQuery>(); #region << created_by >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "created_by"; subQuery.FieldValue = @"{""name"":""current_user"", ""option"": ""id"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "EQ"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion createListInput.Query.SubQueries.Add(listQuery); #endregion #region << Section 2 >> listQuery = new InputRecordListQuery(); listQuery.FieldName = null; listQuery.FieldValue = null; listQuery.QueryType = "AND"; listQuery.SubQueries = new List<InputRecordListQuery>(); #region << code >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "code"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""code"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "CONTAINS"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion #region << subject >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "subject"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""subject"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "CONTAINS"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion #region << status >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "status"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""status"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "EQ"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion #region << priority >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "priority"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""priority"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "EQ"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion createListInput.Query.SubQueries.Add(listQuery); #endregion #endregion #region << Sort >> createListInput.Sorts = new List<InputRecordListSort>(); listSort = new InputRecordListSort(); listSort.FieldName = @"{""name"":""url_sort"", ""option"": ""sortBy"", ""default"": ""end_date"", ""settings"":{""order"":""sortOrder""}}"; listSort.SortType = "descending"; createListInput.Sorts.Add(listSort); #endregion { var response = entMan.CreateRecordList(TASK_ENTITY_ID, createListInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + TASK_ENTITY_NAME + " Updated List: my_tickets" + " Message:" + response.Message); } } #endregion #region << List name: owned_tasks >> { var createListEntity = entMan.ReadEntity(TASK_ENTITY_ID).Object; var createListInput = new InputRecordList(); var listField = new InputRecordListFieldItem(); var listFieldFromRelation = new InputRecordListRelationFieldItem(); var listSort = new InputRecordListSort(); var listQuery = new InputRecordListQuery(); #region << details >> createListInput.Id = new Guid("930b8c52-1cda-4419-9cf4-7a41af95d776"); createListInput.Type = "general"; createListInput.Name = "owned_tasks"; createListInput.Label = "Tasks owned by me"; createListInput.Weight = 2; createListInput.Default = false; createListInput.System = true; createListInput.CssClass = "task-list"; createListInput.IconName = "tasks"; createListInput.VisibleColumnsCount = 7; createListInput.ColumnWidthsCSV = "100px,auto,30px,120px,120px,120px,120px"; createListInput.PageSize = 10; createListInput.DynamicHtmlTemplate = null; createListInput.DataSourceUrl = null; createListInput.ServiceCode = null; #endregion #region << action items >> createListInput.ActionItems = new List<ActionItem>(); var actionItem = new ActionItem(); { actionItem = new ActionItem(); actionItem.Name = "wv_record_details"; actionItem.Menu = "record-row"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline"" ng-href=""{{::ngCtrl.getRecordDetailsUrl(record, ngCtrl)}}""> <i class=""fa fa-fw fa-eye""></i> </a>"; createListInput.ActionItems.Add(actionItem); } { actionItem = new ActionItem(); actionItem.Name = "wv_create_record"; actionItem.Menu = "page-title"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline hidden-xs"" ng-show=""::ngCtrl.userHasRecordPermissions('canCreate')"" ng-href=""{{::ngCtrl.getRecordCreateUrl(ngCtrl)}}"">Add New</a>"; createListInput.ActionItems.Add(actionItem); } #endregion #region << Columns >> createListInput.Columns = new List<InputRecordListItemBase>(); #region << code >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "code").Id; listField.FieldName = "code"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << subject >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "subject").Id; listField.FieldName = "subject"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << owner - image >> { var targetEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; listFieldFromRelation = new InputRecordListRelationFieldItem(); listFieldFromRelation.EntityId = targetEntity.Id; listFieldFromRelation.EntityName = targetEntity.Name; listFieldFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "image").Id; listFieldFromRelation.FieldName = "image"; listFieldFromRelation.FieldLabel = "Owner"; listFieldFromRelation.RelationId = new Guid("7ce76c81-e604-401e-907f-23de982b930e"); listFieldFromRelation.RelationName = "user_1_n_task_owner"; listFieldFromRelation.Type = "fieldFromRelation"; createListInput.Columns.Add(listFieldFromRelation); } #endregion #region << start_date >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "start_date").Id; listField.FieldName = "start_date"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << end_date >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "end_date").Id; listField.FieldName = "end_date"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << status >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "status").Id; listField.FieldName = "status"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << priority >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "priority").Id; listField.FieldName = "priority"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #endregion #region << relation options >> createListInput.RelationOptions = new List<EntityRelationOptionsItem>(); #endregion #region << query >> createListInput.Query = new InputRecordListQuery(); //Main query rule createListInput.Query.FieldName = null; createListInput.Query.FieldValue = null; createListInput.Query.QueryType = "AND"; createListInput.Query.SubQueries = new List<InputRecordListQuery>(); #region << Section 1 >> listQuery = new InputRecordListQuery(); listQuery.FieldName = null; listQuery.FieldValue = null; listQuery.QueryType = "OR"; listQuery.SubQueries = new List<InputRecordListQuery>(); #region << owner_id >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "owner_id"; subQuery.FieldValue = @"{""name"":""current_user"", ""option"": ""id"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "EQ"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion createListInput.Query.SubQueries.Add(listQuery); #endregion #region << Section 2 >> listQuery = new InputRecordListQuery(); listQuery.FieldName = null; listQuery.FieldValue = null; listQuery.QueryType = "AND"; listQuery.SubQueries = new List<InputRecordListQuery>(); #region << number >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "code"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""number"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "CONTAINS"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion #region << subject >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "subject"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""subject"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "CONTAINS"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion #region << status >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "status"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""status"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "EQ"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion #region << priority >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "priority"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""priority"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "EQ"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion createListInput.Query.SubQueries.Add(listQuery); #endregion #endregion #region << Sort >> createListInput.Sorts = new List<InputRecordListSort>(); listSort = new InputRecordListSort(); listSort.FieldName = @"{""name"":""url_sort"", ""option"": ""sortBy"", ""default"": ""end_date"", ""settings"":{""order"":""sortOrder""}}"; listSort.SortType = "descending"; createListInput.Sorts.Add(listSort); #endregion { var response = entMan.CreateRecordList(TASK_ENTITY_ID, createListInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + TASK_ENTITY_NAME + " Updated List: my_tickets" + " Message:" + response.Message); } } #endregion #region << List name: all_tasks >> { var createListEntity = entMan.ReadEntity(TASK_ENTITY_ID).Object; var createListInput = new InputRecordList(); var listField = new InputRecordListFieldItem(); var listFieldFromRelation = new InputRecordListRelationFieldItem(); var listSort = new InputRecordListSort(); var listQuery = new InputRecordListQuery(); #region << details >> createListInput.Id = new Guid("6b6ac308-bb21-46a3-b83c-0559348b2f46"); createListInput.Type = "general"; createListInput.Name = "all_tasks"; createListInput.Label = "All Tasks"; createListInput.Weight = 12; createListInput.Default = false; createListInput.System = true; createListInput.CssClass = "task-list"; createListInput.IconName = "tasks"; createListInput.VisibleColumnsCount = 7; createListInput.ColumnWidthsCSV = "100px,auto,30px,120px,120px,120px,120px"; createListInput.PageSize = 10; createListInput.DynamicHtmlTemplate = null; createListInput.DataSourceUrl = @"/plugins/webvella-projects/api/task/list/all"; createListInput.ServiceCode = null; #endregion #region << action items >> createListInput.ActionItems = new List<ActionItem>(); var actionItem = new ActionItem(); { actionItem = new ActionItem(); actionItem.Name = "wv_record_details"; actionItem.Menu = "record-row"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline"" ng-href=""{{::ngCtrl.getRecordDetailsUrl(record, ngCtrl)}}""> <i class=""fa fa-fw fa-eye""></i> </a>"; createListInput.ActionItems.Add(actionItem); } { actionItem = new ActionItem(); actionItem.Name = "wv_create_record"; actionItem.Menu = "page-title"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline hidden-xs"" ng-show=""::ngCtrl.userHasRecordPermissions('canCreate')"" ng-href=""{{::ngCtrl.getRecordCreateUrl(ngCtrl)}}"">Add New</a>"; createListInput.ActionItems.Add(actionItem); } #endregion #region << Columns >> createListInput.Columns = new List<InputRecordListItemBase>(); #region << code >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "code").Id; listField.FieldName = "code"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << subject >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "subject").Id; listField.FieldName = "subject"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << owner - image >> { var targetEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; listFieldFromRelation = new InputRecordListRelationFieldItem(); listFieldFromRelation.EntityId = targetEntity.Id; listFieldFromRelation.EntityName = targetEntity.Name; listFieldFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "image").Id; listFieldFromRelation.FieldName = "image"; listFieldFromRelation.FieldLabel = "Owner"; listFieldFromRelation.RelationId = new Guid("7ce76c81-e604-401e-907f-23de982b930e"); listFieldFromRelation.RelationName = "user_1_n_task_owner"; listFieldFromRelation.Type = "fieldFromRelation"; createListInput.Columns.Add(listFieldFromRelation); } #endregion #region << start_date >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "start_date").Id; listField.FieldName = "start_date"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << end_date >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "end_date").Id; listField.FieldName = "end_date"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << status >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "status").Id; listField.FieldName = "status"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << priority >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "priority").Id; listField.FieldName = "priority"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #endregion #region << query >> createListInput.Query = new InputRecordListQuery(); //Main query rule createListInput.Query.FieldName = null; createListInput.Query.FieldValue = null; createListInput.Query.QueryType = "AND"; createListInput.Query.SubQueries = new List<InputRecordListQuery>(); #region << code >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "code"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""code"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "CONTAINS"; subQuery.SubQueries = new List<InputRecordListQuery>(); createListInput.Query.SubQueries.Add(subQuery); } #endregion #region << subject >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "subject"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""subject"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "CONTAINS"; subQuery.SubQueries = new List<InputRecordListQuery>(); createListInput.Query.SubQueries.Add(subQuery); } #endregion #region << status >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "status"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""status"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "EQ"; subQuery.SubQueries = new List<InputRecordListQuery>(); createListInput.Query.SubQueries.Add(subQuery); } #endregion #region << priority >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "priority"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""priority"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "EQ"; subQuery.SubQueries = new List<InputRecordListQuery>(); createListInput.Query.SubQueries.Add(subQuery); } #endregion #endregion #region << Sort >> createListInput.Sorts = new List<InputRecordListSort>(); listSort = new InputRecordListSort(); listSort.FieldName = @"{""name"":""url_sort"", ""option"": ""sortBy"", ""default"": ""end_date"", ""settings"":{""order"":""sortOrder""}}"; listSort.SortType = "descending"; createListInput.Sorts.Add(listSort); #endregion { var response = entMan.CreateRecordList(TASK_ENTITY_ID, createListInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + TASK_ENTITY_NAME + " Updated List: all_tickets" + " Message:" + response.Message); } } #endregion #region << List name: admin >> { var createListEntity = entMan.ReadEntity(TASK_ENTITY_ID).Object; var createListInput = new InputRecordList(); var listField = new InputRecordListFieldItem(); var listFieldFromRelation = new InputRecordListRelationFieldItem(); var listSort = new InputRecordListSort(); var listQuery = new InputRecordListQuery(); #region << details >> createListInput.Id = new Guid("10dce98d-843f-48ca-94be-da33a910375e"); createListInput.Type = "hidden"; createListInput.Name = "admin"; createListInput.Label = "All tasks"; createListInput.Weight = 2; createListInput.Default = false; createListInput.System = true; createListInput.CssClass = "task-list"; createListInput.IconName = "tasks"; createListInput.VisibleColumnsCount = 7; createListInput.ColumnWidthsCSV = "80px,auto,30px,120px,120px,120px,120px"; createListInput.PageSize = 10; createListInput.DynamicHtmlTemplate = null; createListInput.DataSourceUrl = null; createListInput.ServiceCode = null; #endregion #region << action items >> createListInput.ActionItems = new List<ActionItem>(); var actionItem = new ActionItem(); { actionItem = new ActionItem(); actionItem.Name = "wv_record_details"; actionItem.Menu = "record-row"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline"" ng-href=""{{::ngCtrl.getRecordDetailsUrl(record, ngCtrl)}}""> <i class=""fa fa-fw fa-eye""></i> </a>"; createListInput.ActionItems.Add(actionItem); } { actionItem = new ActionItem(); actionItem.Name = "wv_create_record"; actionItem.Menu = "page-title"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline hidden-xs"" ng-show=""::ngCtrl.userHasRecordPermissions('canCreate')"" ng-href=""{{::ngCtrl.getRecordCreateUrl(ngCtrl)}}"">Add New</a>"; createListInput.ActionItems.Add(actionItem); } #endregion #region << Columns >> createListInput.Columns = new List<InputRecordListItemBase>(); #region << code >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "code").Id; listField.FieldName = "code"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << subject >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "subject").Id; listField.FieldName = "subject"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << owner - image >> { var targetEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; listFieldFromRelation = new InputRecordListRelationFieldItem(); listFieldFromRelation.EntityId = targetEntity.Id; listFieldFromRelation.EntityName = targetEntity.Name; listFieldFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "image").Id; listFieldFromRelation.FieldName = "image"; listFieldFromRelation.FieldLabel = "Owner"; listFieldFromRelation.RelationId = new Guid("7ce76c81-e604-401e-907f-23de982b930e"); listFieldFromRelation.RelationName = "user_1_n_task_owner"; listFieldFromRelation.Type = "fieldFromRelation"; createListInput.Columns.Add(listFieldFromRelation); } #endregion #region << start_date >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "start_date").Id; listField.FieldName = "start_date"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << end_date >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "end_date").Id; listField.FieldName = "end_date"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << status >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "status").Id; listField.FieldName = "status"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << priority >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "priority").Id; listField.FieldName = "priority"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #endregion #region << relation options >> createListInput.RelationOptions = new List<EntityRelationOptionsItem>(); #endregion #region << query >> createListInput.Query = new InputRecordListQuery(); listQuery = new InputRecordListQuery(); listQuery.FieldName = null; listQuery.FieldValue = null; listQuery.QueryType = "AND"; listQuery.SubQueries = new List<InputRecordListQuery>(); #region << code >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "owner_id"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""code"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "EQ"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion #region << subject >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "subject"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""subject"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "EQ"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion #region << status >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "status"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""status"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "EQ"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion #region << priority >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "priority"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""priority"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "EQ"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion createListInput.Query = listQuery; #endregion #region << Sort >> createListInput.Sorts = new List<InputRecordListSort>(); listSort = new InputRecordListSort(); listSort.FieldName = @"{""name"":""url_sort"", ""option"": ""sortBy"", ""default"": ""end_date"", ""settings"":{""order"":""sortOrder""}}"; listSort.SortType = "descending"; createListInput.Sorts.Add(listSort); #endregion { var response = entMan.CreateRecordList(TASK_ENTITY_ID, createListInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + TASK_ENTITY_NAME + " Updated List: admin" + " Message:" + response.Message); } } #endregion #region << create create >> { var createViewEntity = entMan.ReadEntity(TASK_ENTITY_ID).Object; var createViewInput = new InputRecordView(); var viewSection = new InputRecordViewSection(); var viewRow = new InputRecordViewRow(); var viewColumn = new InputRecordViewColumn(); var viewItem = new InputRecordViewFieldItem(); var viewItemFromRelation = new InputRecordViewRelationFieldItem(); //General view fields #region << Details >> createViewInput.Id = new Guid("b879c8f8-1738-4f33-94aa-89064f227ed9"); createViewInput.Name = "create"; createViewInput.Label = "Create"; createViewInput.Title = ""; createViewInput.Default = true; createViewInput.System = true; createViewInput.Type = "create"; createViewInput.Weight = 10; createViewInput.IconName = "file-text-o"; createViewInput.ServiceCode = null; createViewInput.DynamicHtmlTemplate = null; createViewInput.DataSourceUrl = null; #endregion #region << Get the header Region >> var headerRegion = new InputRecordViewRegion(); headerRegion.Name = "header"; headerRegion.Label = "header"; headerRegion.Sections = new List<InputRecordViewSection>(); #endregion #region << Section >> viewSection = new InputRecordViewSection(); viewSection.Id = new Guid("8b628f5d-16b3-49d0-a433-a910ea208b39"); viewSection.Name = "details"; viewSection.Label = "Details"; viewSection.ShowLabel = false; viewSection.CssClass = ""; viewSection.Collapsed = false; viewSection.TabOrder = "left-right"; viewSection.Weight = 1; viewSection.Rows = new List<InputRecordViewRow>(); #region << Row 1 >> viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("818f516c-f6c2-4073-8574-75c13a72aee4"); viewRow.Weight = 1; viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = 12; viewColumn.Items = new List<InputRecordViewItemBase>(); #region << subject >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = createViewEntity.Id; viewItem.EntityName = createViewEntity.Name; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "subject").Id; viewItem.FieldName = "subject"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << project name >> { var targetEntity = entMan.ReadEntity(PROJECT_ENTITY_ID).Object; viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = targetEntity.Id; viewItemFromRelation.EntityName = targetEntity.Name; viewItemFromRelation.Type = "fieldFromRelation"; viewItemFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "name").Id; viewItemFromRelation.FieldName = "name"; viewItemFromRelation.FieldLabel = "Project"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = new Guid("1f860b8c-7fa1-40fa-874f-19c2b5309817"); viewItemFromRelation.RelationName = "project_1_n_task"; viewColumn.Items.Add(viewItemFromRelation); } #endregion #region << description >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = createViewEntity.Id; viewItem.EntityName = createViewEntity.Name; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "description").Id; viewItem.FieldName = "description"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); #endregion //Save row viewSection.Rows.Add(viewRow); #endregion #region << Row 2 >> viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("2144c60b-4974-44e2-86ef-5ceec72d04f8"); viewRow.Weight = 2; viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = 6; viewColumn.Items = new List<InputRecordViewItemBase>(); #region << status >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = createViewEntity.Id; viewItem.EntityName = createViewEntity.Name; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "status").Id; viewItem.FieldName = "status"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << start_date >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = createViewEntity.Id; viewItem.EntityName = createViewEntity.Name; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "start_date").Id; viewItem.FieldName = "start_date"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); #endregion #region << Column 2 >> viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = 6; viewColumn.Items = new List<InputRecordViewItemBase>(); #region << priority >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = createViewEntity.Id; viewItem.EntityName = createViewEntity.Name; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "priority").Id; viewItem.FieldName = "priority"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << end_date >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = createViewEntity.Id; viewItem.EntityName = createViewEntity.Name; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "end_date").Id; viewItem.FieldName = "end_date"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); #endregion //Save row viewSection.Rows.Add(viewRow); #endregion //Save section headerRegion.Sections.Add(viewSection); #endregion createViewInput.Regions = new List<InputRecordViewRegion>(); createViewInput.Regions.Add(headerRegion); #region << Sidebar >> var sidebarItem = new InputRecordViewSidebarItemBase(); #endregion` var newActionItemList = new List<ActionItem>(); { var actionItem = new ActionItem(); actionItem.Name = "wv_back_button"; actionItem.Menu = "sidebar-top"; actionItem.Template = "<a class=\"back clearfix\" href=\"javascript:void(0)\" ng-click=\"sidebarData.goBack()\"><i class=\"fa fa-fw fa-arrow-left\"></i> <span class=\"text\">Back</span></a>"; actionItem.Weight = 1; newActionItemList.Add(actionItem); } { var actionItem = new ActionItem(); actionItem.Name = "wv_create_and_list"; actionItem.Menu = "create-bottom"; actionItem.Template = "<a class=\"btn btn-primary\" ng-click='ngCtrl.create(\"default\")' ng-if=\"::ngCtrl.createViewRegion != null\">Create</a>"; actionItem.Weight = 1; newActionItemList.Add(actionItem); } { var actionItem = new ActionItem(); actionItem.Name = ""; actionItem.Menu = "create-bottom"; actionItem.Template = "<a class=\"btn btn-default btn-outline\" ng-click='ngCtrl.create(\"details\")' ng-if=\"::ngCtrl.createViewRegion != null\">Create & Details</a>"; actionItem.Weight = 2; newActionItemList.Add(actionItem); } { var actionItem = new ActionItem(); actionItem.Name = ""; actionItem.Menu = "create-bottom"; actionItem.Template = "<a class=\"btn btn-default btn-outline\" ng-click=\"ngCtrl.cancel()\">Cancel</a>"; actionItem.Weight = 3; newActionItemList.Add(actionItem); } createViewInput.ActionItems = newActionItemList; { var response = entMan.CreateRecordView(TASK_ENTITY_ID, createViewInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + TASK_ENTITY_NAME + " Updated view: create" + " Message:" + response.Message); } } #endregion #region << View name: project_milestone >> { var createViewEntity = entMan.ReadEntity(TASK_ENTITY_ID).Object; var createViewInput = new InputRecordView(); var viewRegion = new InputRecordViewRegion(); var viewSection = new InputRecordViewSection(); var viewRow = new InputRecordViewRow(); var viewColumn = new InputRecordViewColumn(); var viewItem = new InputRecordViewFieldItem(); var viewItemFromRelation = new InputRecordViewRelationFieldItem(); #region << details >> createViewInput.Id = new Guid("820b6771-3100-4393-982b-3813d79f4df2"); createViewInput.Type = "hidden"; createViewInput.Name = "project_milestone"; createViewInput.Label = "Project & Milestone"; createViewInput.Title = ""; createViewInput.Default = false; createViewInput.System = true; createViewInput.Weight = 10; createViewInput.CssClass = null; createViewInput.IconName = "code"; createViewInput.DynamicHtmlTemplate = "/plugins/webvella-projects/templates/task-project-milestone-selection.html"; createViewInput.DataSourceUrl = null; createViewInput.ServiceCode = null; createViewInput.Regions = new List<InputRecordViewRegion>(); #endregion #region << Header Region >> viewRegion = new InputRecordViewRegion(); viewRegion.Name = "header"; viewRegion.Label = "Header"; viewRegion.Render = true; viewRegion.Weight = 1; viewRegion.CssClass = ""; viewRegion.Sections = new List<InputRecordViewSection>(); #region << Section >> viewSection = new InputRecordViewSection(); viewSection.Id = new Guid("e886ea83-cb6f-408e-9fa9-a53cd249b714"); viewSection.Name = "details"; viewSection.Label = "Details"; viewSection.ShowLabel = false; viewSection.CssClass = ""; viewSection.Collapsed = false; viewSection.TabOrder = "left-right"; viewSection.Weight = 1; viewSection.Rows = new List<InputRecordViewRow>(); #region << Row Column>> viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("20be17ac-e915-4ac3-87a3-ab1ef534975f"); viewRow.Weight = 1; viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = 12; viewColumn.Items = new List<InputRecordViewItemBase>(); #region << milestone_1_n_task>name from Relation >> { var targetEntity = entMan.ReadEntity(MILESTONE_ENTITY_ID).Object; var targetRelation = relMan.Read("milestone_1_n_task").Object; viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = targetEntity.Id; viewItemFromRelation.EntityName = targetEntity.Name; viewItemFromRelation.Type = "fieldFromRelation"; viewItemFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "name").Id; viewItemFromRelation.FieldName = "name"; viewItemFromRelation.FieldLabel = "Milestone"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = targetRelation.Id; viewItemFromRelation.RelationName = targetRelation.Name; viewColumn.Items.Add(viewItemFromRelation); } #endregion #region << project_1_n_task>name from Relation >> { var targetEntity = entMan.ReadEntity(PROJECT_ENTITY_ID).Object; var targetRelation = relMan.Read("project_1_n_task").Object; viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = targetEntity.Id; viewItemFromRelation.EntityName = targetEntity.Name; viewItemFromRelation.Type = "fieldFromRelation"; viewItemFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "name").Id; viewItemFromRelation.FieldName = "name"; viewItemFromRelation.FieldLabel = "Milestone"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = targetRelation.Id; viewItemFromRelation.RelationName = targetRelation.Name; viewColumn.Items.Add(viewItemFromRelation); } #endregion //Save column viewRow.Columns.Add(viewColumn); #endregion //Save row viewSection.Rows.Add(viewRow); #endregion //Save section viewRegion.Sections.Add(viewSection); #endregion //Save region createViewInput.Regions.Add(viewRegion); #endregion createViewInput.RelationOptions = new List<EntityRelationOptionsItem>(); createViewInput.ActionItems = new List<ActionItem>(); #region << Sidebar >> createViewInput.Sidebar = new InputRecordViewSidebar(); createViewInput.Sidebar.CssClass = ""; createViewInput.Sidebar.Render = true; #endregion { var response = entMan.CreateRecordView(createViewEntity.Id, createViewInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + createViewEntity.Name + " Updated view: project_milestone" + " Message:" + response.Message); } } #endregion #region << create general >> { var createViewEntity = entMan.ReadEntity(TASK_ENTITY_ID).Object; var createViewInput = new InputRecordView(); var viewSection = new InputRecordViewSection(); var viewRow = new InputRecordViewRow(); var viewColumn = new InputRecordViewColumn(); var viewItem = new InputRecordViewFieldItem(); var viewItemFromRelation = new InputRecordViewRelationFieldItem(); var viewItemView = new InputRecordViewViewItem(); //General view fields #region << Details >> createViewInput.Id = new Guid("f3d3a025-ffd5-4eba-86d3-42bde882f597"); createViewInput.Name = "general"; createViewInput.Label = "[{code}] {subject}"; createViewInput.Title = ""; createViewInput.Type = "general"; createViewInput.Default = true; createViewInput.System = true; createViewInput.IconName = "tasks"; createViewInput.ServiceCode = ""; #endregion #region << Get the header Region >> var headerRegion = new InputRecordViewRegion(); headerRegion.Name = "header"; headerRegion.Label = "header"; headerRegion.Sections = new List<InputRecordViewSection>(); #endregion #region << Section >> viewSection = new InputRecordViewSection(); viewSection.Id = new Guid("0289b876-b6be-4d5f-915b-22dc0428bc25"); viewSection.Name = "details"; viewSection.Label = "Details"; viewSection.ShowLabel = false; viewSection.CssClass = ""; viewSection.Collapsed = false; viewSection.TabOrder = "left-right"; viewSection.Weight = 1; viewSection.Rows = new List<InputRecordViewRow>(); #region << Row 1 >> viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("cbf260ae-07e3-4e66-be57-beb7a36779bf"); viewRow.Weight = 1; viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = 8; viewColumn.Items = new List<InputRecordViewItemBase>(); #region << subject >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = createViewEntity.Id; viewItem.EntityName = createViewEntity.Name; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "subject").Id; viewItem.FieldName = "subject"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << project_milestone name >> { var targetEntity = entMan.ReadEntity(TASK_ENTITY_ID).Object; viewItemView = new InputRecordViewViewItem(); viewItemView.EntityId = targetEntity.Id; viewItemView.EntityName = targetEntity.Name; viewItemView.Type = "view"; viewItemView.ViewId = targetEntity.RecordViews.Single(x => x.Name == "project_milestone").Id; viewColumn.Items.Add(viewItemView); } #endregion #region << description >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = createViewEntity.Id; viewItem.EntityName = createViewEntity.Name; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "description").Id; viewItem.FieldName = "description"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); #endregion #region << Column 2 >> viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = 4; viewColumn.Items = new List<InputRecordViewItemBase>(); #region << code >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = createViewEntity.Id; viewItem.EntityName = createViewEntity.Name; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "code").Id; viewItem.FieldName = "code"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << status >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = createViewEntity.Id; viewItem.EntityName = createViewEntity.Name; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "status").Id; viewItem.FieldName = "status"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << priority >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = createViewEntity.Id; viewItem.EntityName = createViewEntity.Name; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "priority").Id; viewItem.FieldName = "priority"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << owner >> { var targetEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = targetEntity.Id; viewItemFromRelation.EntityName = targetEntity.Name; viewItemFromRelation.Type = "fieldFromRelation"; viewItemFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "username").Id; viewItemFromRelation.FieldName = "username"; viewItemFromRelation.FieldLabel = "Owner"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = new Guid("7ce76c81-e604-401e-907f-23de982b930e"); viewItemFromRelation.RelationName = "user_1_n_task_owner"; viewColumn.Items.Add(viewItemFromRelation); } #endregion #region << start_date >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = createViewEntity.Id; viewItem.EntityName = createViewEntity.Name; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "start_date").Id; viewItem.FieldName = "start_date"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << end_date >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = createViewEntity.Id; viewItem.EntityName = createViewEntity.Name; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "end_date").Id; viewItem.FieldName = "end_date"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << watchers >> { var targetEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; var targetRelation = relMan.Read("user_n_n_task_watchers").Object; viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = targetEntity.Id; viewItemFromRelation.EntityName = targetEntity.Name; viewItemFromRelation.Type = "fieldFromRelation"; viewItemFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "username").Id; viewItemFromRelation.FieldName = "username"; viewItemFromRelation.FieldLabel = "Watchers"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = targetRelation.Id; viewItemFromRelation.RelationName = targetRelation.Name; viewColumn.Items.Add(viewItemFromRelation); } #endregion //Save column viewRow.Columns.Add(viewColumn); #endregion //Save row viewSection.Rows.Add(viewRow); #endregion //Save section headerRegion.Sections.Add(viewSection); #endregion createViewInput.Regions = new List<InputRecordViewRegion>(); createViewInput.Regions.Add(headerRegion); #region << Sidebar >> var sidebarItem = new InputRecordViewSidebarItemBase(); createViewInput.Sidebar = new InputRecordViewSidebar(); createViewInput.Sidebar.CssClass = ""; createViewInput.Sidebar.Render = true; #endregion #region << Action items edit >> var newActionItemList = new List<ActionItem>(); { var actionItem = new ActionItem(); actionItem.Name = "wv_record_delete"; actionItem.Menu = "page-title-dropdown"; actionItem.Template = "<a href=\"javascript:void(0)\" confirmed-click=\"::ngCtrl.deleteRecord(ngCtrl)\" ng-confirm-click=\"Are you sure?\"\n\t\tng-if=\"::ngCtrl.userHasRecordPermissions('canDelete')\">\n\t<i class=\"fa fa-trash go-red\"></i> Delete Record\n</a>"; actionItem.Weight = 1; newActionItemList.Add(actionItem); } { var actionItem = new ActionItem(); actionItem.Name = "wv_back_button"; actionItem.Menu = "sidebar-top"; actionItem.Template = "<a class=\"back clearfix\" href=\"javascript:void(0)\" ng-click=\"sidebarData.goBack()\"><i class=\"fa fa-fw fa-arrow-left\"></i> <span class=\"text\">Back</span></a>"; actionItem.Weight = 1; newActionItemList.Add(actionItem); } createViewInput.ActionItems = newActionItemList; #endregion { var response = entMan.CreateRecordView(TASK_ENTITY_ID, createViewInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + TASK_ENTITY_NAME + " Updated view: create" + " Message:" + response.Message); } } #endregion #region << area add subscription: Project Workplace -> My tasks >> { var updatedAreaId = PROJECT_WORKPLACE_AREA_ID; var updateAreaResult = Helpers.UpsertEntityAsAreaSubscription(entMan, recMan, updatedAreaId, TASK_ENTITY_NAME, "general", "create", "my_tasks"); if (!updateAreaResult.Success) { throw new Exception("System error 10060. Area update with id : " + updatedAreaId + " Message:" + updateAreaResult.Message); } } #endregion #region << area add subscription: Project Admin -> Bugs >> { var updatedAreaId = PROJECT_ADMIN_AREA_ID; var updateAreaResult = Helpers.UpsertEntityAsAreaSubscription(entMan, recMan, updatedAreaId, TASK_ENTITY_NAME, "general", "create", "admin"); if (!updateAreaResult.Success) { throw new Exception("System error 10060. Area update with id : " + updatedAreaId + " Message:" + updateAreaResult.Message); } } #endregion } #endregion #region << wv_bug >> { #region << entity >> { InputEntity entity = new InputEntity(); entity.Id = BUG_ENTITY_ID; entity.Name = BUG_ENTITY_NAME; entity.Label = "Bug"; entity.LabelPlural = "Bugs"; entity.System = true; entity.IconName = "bug"; entity.Weight = 5; entity.RecordPermissions = new RecordPermissions(); entity.RecordPermissions.CanCreate = new List<Guid>(); entity.RecordPermissions.CanRead = new List<Guid>(); entity.RecordPermissions.CanUpdate = new List<Guid>(); entity.RecordPermissions.CanDelete = new List<Guid>(); //Create entity.RecordPermissions.CanCreate.Add(SystemIds.AdministratorRoleId); entity.RecordPermissions.CanCreate.Add(SystemIds.RegularRoleId); //READ entity.RecordPermissions.CanRead.Add(SystemIds.AdministratorRoleId); entity.RecordPermissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE entity.RecordPermissions.CanUpdate.Add(SystemIds.AdministratorRoleId); entity.RecordPermissions.CanUpdate.Add(SystemIds.RegularRoleId); //System fields and relations Ids should be hardcoded for the compare/change code generation to work later on correctly var systemItemIdDictionary = new Dictionary<string, Guid>(); systemItemIdDictionary["id"] = new Guid("85e92948-ca90-4983-854d-c1fbad0d7e8c"); systemItemIdDictionary["created_on"] = new Guid("781cee71-1632-4bf9-83b1-ff122d29eb2a"); systemItemIdDictionary["created_by"] = new Guid("72b3a792-7ee8-420c-a48e-86c5beda474b"); systemItemIdDictionary["last_modified_on"] = new Guid("ce3c4668-be18-4217-898e-704d126dc8a2"); systemItemIdDictionary["last_modified_by"] = new Guid("18fdd103-06ee-449b-9140-098ea171670a"); systemItemIdDictionary["user_wv_bug_created_by"] = new Guid("cdc5c5f9-30dc-4e3b-ac0f-4137e54c6c7f"); systemItemIdDictionary["user_wv_bug_modified_by"] = new Guid("a09464e2-0383-435a-a1e7-52c6d2a2743c"); { var response = entMan.CreateEntity(entity, false, false, systemItemIdDictionary); if (!response.Success) throw new Exception("System error 10050. Entity: " + BUG_ENTITY_NAME + " Field: entity creation" + " Message:" + response.Message); } } #endregion #region << number >> { InputAutoNumberField autonumberField = new InputAutoNumberField(); autonumberField.Id = new Guid("01a14364-7e42-42ed-b6aa-92525b7b36fb"); autonumberField.Name = "number"; autonumberField.Label = "Number"; autonumberField.PlaceholderText = ""; autonumberField.Description = ""; autonumberField.HelpText = ""; autonumberField.Required = true; autonumberField.Unique = true; autonumberField.Searchable = true; autonumberField.Auditable = false; autonumberField.System = true; autonumberField.DefaultValue = 0; autonumberField.DisplayFormat = "{0}"; autonumberField.StartingNumber = 1; autonumberField.EnableSecurity = true; autonumberField.Permissions = new FieldPermissions(); autonumberField.Permissions.CanRead = new List<Guid>(); autonumberField.Permissions.CanUpdate = new List<Guid>(); //READ autonumberField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); autonumberField.Permissions.CanRead.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(BUG_ENTITY_ID, autonumberField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + BUG_ENTITY_NAME + " Field: number" + " Message:" + response.Message); } } #endregion #region << code >> { InputTextField textboxField = new InputTextField(); textboxField.Id = new Guid("6f2030e9-edd7-42ac-bb2a-2766b76c3da1"); textboxField.Name = "code"; textboxField.Label = "Code"; textboxField.PlaceholderText = ""; textboxField.Description = ""; textboxField.HelpText = ""; textboxField.Required = false; textboxField.Unique = false; textboxField.Searchable = true; textboxField.Auditable = false; textboxField.System = true; textboxField.DefaultValue = string.Empty; textboxField.MaxLength = null; textboxField.EnableSecurity = true; textboxField.Permissions = new FieldPermissions(); textboxField.Permissions.CanRead = new List<Guid>(); textboxField.Permissions.CanUpdate = new List<Guid>(); //READ textboxField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); textboxField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE textboxField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); textboxField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(BUG_ENTITY_ID, textboxField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + BUG_ENTITY_NAME + " Field: code" + " Message:" + response.Message); } } #endregion #region << subject >> { InputTextField textboxField = new InputTextField(); textboxField.Id = new Guid("335a4500-130e-4739-b774-2f53f33ea22a"); textboxField.Name = "subject"; textboxField.Label = "Subject"; textboxField.PlaceholderText = ""; textboxField.Description = ""; textboxField.HelpText = ""; textboxField.Required = true; textboxField.Unique = false; textboxField.Searchable = true; textboxField.Auditable = false; textboxField.System = true; textboxField.DefaultValue = string.Empty; textboxField.MaxLength = null; textboxField.EnableSecurity = true; textboxField.Permissions = new FieldPermissions(); textboxField.Permissions.CanRead = new List<Guid>(); textboxField.Permissions.CanUpdate = new List<Guid>(); //READ textboxField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); textboxField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE textboxField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); textboxField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(BUG_ENTITY_ID, textboxField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + BUG_ENTITY_NAME + " Field: subject" + " Message:" + response.Message); } } #endregion #region << description >> { InputHtmlField htmlField = new InputHtmlField(); htmlField.Id = new Guid("4afe9621-39ee-40b9-a3ef-cb9b98131a6a"); htmlField.Name = "description"; htmlField.Label = "Description"; htmlField.PlaceholderText = ""; htmlField.Description = ""; htmlField.HelpText = ""; htmlField.Required = false; htmlField.Unique = false; htmlField.Searchable = false; htmlField.Auditable = false; htmlField.System = true; htmlField.DefaultValue = string.Empty; htmlField.EnableSecurity = true; htmlField.Permissions = new FieldPermissions(); htmlField.Permissions.CanRead = new List<Guid>(); htmlField.Permissions.CanUpdate = new List<Guid>(); htmlField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); htmlField.Permissions.CanRead.Add(SystemIds.RegularRoleId); htmlField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); htmlField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(BUG_ENTITY_ID, htmlField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + BUG_ENTITY_NAME + " Field: description" + " Message:" + response.Message); } } #endregion #region << priority >> { InputSelectField dropdownField = new InputSelectField(); dropdownField.Id = new Guid("e506dfc7-6d49-4d00-9f61-8befd56c1a6e"); dropdownField.Name = "priority"; dropdownField.Label = "Priority"; dropdownField.PlaceholderText = ""; dropdownField.Description = ""; dropdownField.HelpText = ""; dropdownField.Required = true; dropdownField.Unique = false; dropdownField.Searchable = true; dropdownField.Auditable = false; dropdownField.System = true; dropdownField.DefaultValue = "medium"; dropdownField.Options = new List<SelectFieldOption> { new SelectFieldOption(){ Key = "low", Value = "low" }, new SelectFieldOption(){ Key = "medium", Value = "medium" }, new SelectFieldOption(){ Key = "hight", Value = "hight" } }; dropdownField.EnableSecurity = true; dropdownField.Permissions = new FieldPermissions(); dropdownField.Permissions.CanRead = new List<Guid>(); dropdownField.Permissions.CanUpdate = new List<Guid>(); //READ dropdownField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); dropdownField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE dropdownField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); dropdownField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(BUG_ENTITY_ID, dropdownField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + BUG_ENTITY_NAME + " Field: priority" + " Message:" + response.Message); } } #endregion #region << owner_id >> { InputGuidField guidField = new InputGuidField(); guidField.Id = new Guid("0ed595db-1abd-4a74-b160-db879c33cba9"); guidField.Name = "owner_id"; guidField.Label = "Owned by"; guidField.PlaceholderText = ""; guidField.Description = ""; guidField.HelpText = ""; guidField.Required = true; guidField.Unique = false; guidField.Searchable = false; guidField.Auditable = false; guidField.System = true; guidField.DefaultValue = Guid.Empty; guidField.GenerateNewId = false; guidField.EnableSecurity = true; guidField.Permissions = new FieldPermissions(); guidField.Permissions.CanRead = new List<Guid>(); guidField.Permissions.CanUpdate = new List<Guid>(); //READ guidField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE guidField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(BUG_ENTITY_ID, guidField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + BUG_ENTITY_NAME + " Field: owner_id" + " Message:" + response.Message); } } #endregion #region << project_id >> { InputGuidField guidField = new InputGuidField(); guidField.Id = new Guid("dd345ce0-476f-4e74-a0b7-5f5c8ee480d6"); guidField.Name = "project_id"; guidField.Label = "Project"; guidField.PlaceholderText = ""; guidField.Description = ""; guidField.HelpText = ""; guidField.Required = true; guidField.Unique = false; guidField.Searchable = false; guidField.Auditable = false; guidField.System = true; guidField.DefaultValue = Guid.Empty; guidField.GenerateNewId = false; guidField.EnableSecurity = true; guidField.Permissions = new FieldPermissions(); guidField.Permissions.CanRead = new List<Guid>(); guidField.Permissions.CanUpdate = new List<Guid>(); //READ guidField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE guidField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(BUG_ENTITY_ID, guidField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + BUG_ENTITY_NAME + " Field: project_id" + " Message:" + response.Message); } } #endregion #region << milestone_id >> { InputGuidField guidField = new InputGuidField(); guidField.Id = new Guid("bd817922-e269-44cf-bc84-64911b5abbdd"); guidField.Name = "milestone_id"; guidField.Label = "Release milestone"; guidField.PlaceholderText = ""; guidField.Description = ""; guidField.HelpText = ""; guidField.Required = false; guidField.Unique = false; guidField.Searchable = false; guidField.Auditable = false; guidField.System = true; guidField.DefaultValue = Guid.Empty; guidField.GenerateNewId = false; guidField.EnableSecurity = true; guidField.Permissions = new FieldPermissions(); guidField.Permissions.CanRead = new List<Guid>(); guidField.Permissions.CanUpdate = new List<Guid>(); //READ guidField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE guidField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(BUG_ENTITY_ID, guidField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + BUG_ENTITY_NAME + " Field: milestone_id" + " Message:" + response.Message); } } #endregion #region << status >> { InputSelectField dropdownField = new InputSelectField(); dropdownField.Id = new Guid("48be1e6e-df47-46f0-b4e1-6e9e1cbaf71c"); dropdownField.Name = "status"; dropdownField.Label = "Status"; dropdownField.PlaceholderText = ""; dropdownField.Description = ""; dropdownField.HelpText = ""; dropdownField.Required = true; dropdownField.Unique = false; dropdownField.Searchable = true; dropdownField.Auditable = false; dropdownField.System = true; dropdownField.DefaultValue = "opened"; dropdownField.Options = new List<SelectFieldOption> { new SelectFieldOption(){ Key = "opened", Value = "opened" }, new SelectFieldOption(){ Key = "closed", Value = "closed" }, new SelectFieldOption(){ Key = "reopened", Value = "reopened" } }; dropdownField.EnableSecurity = true; dropdownField.Permissions = new FieldPermissions(); dropdownField.Permissions.CanRead = new List<Guid>(); dropdownField.Permissions.CanUpdate = new List<Guid>(); //READ dropdownField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); dropdownField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE dropdownField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); dropdownField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(BUG_ENTITY_ID, dropdownField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + BUG_ENTITY_NAME + " Field: status" + " Message:" + response.Message); } } #endregion #region << x_billable_hours >> { InputNumberField numberField = new InputNumberField(); numberField.Id = new Guid("20fa3394-39f8-4ad0-8743-3f75afed8f8f"); numberField.Name = "x_billable_hours"; numberField.Label = "Billable hours"; numberField.PlaceholderText = ""; numberField.Description = ""; numberField.HelpText = ""; numberField.Required = false; numberField.Unique = false; numberField.Searchable = false; numberField.Auditable = false; numberField.System = true; numberField.DefaultValue = 0; numberField.MinValue = null; numberField.MaxValue = null; numberField.DecimalPlaces = 0; numberField.EnableSecurity = true; numberField.Permissions = new FieldPermissions(); numberField.Permissions.CanRead = new List<Guid>(); numberField.Permissions.CanUpdate = new List<Guid>(); //READ numberField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE numberField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(BUG_ENTITY_ID, numberField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + BUG_ENTITY_NAME + " Field: x_billable_hours" + " Message:" + response.Message); } } #endregion #region << x_nonbillable_hours >> { InputNumberField numberField = new InputNumberField(); numberField.Id = new Guid("08c8cea9-79e1-4908-8611-abfa4c087209"); numberField.Name = "x_nonbillable_hours"; numberField.Label = "Non-Billable hours"; numberField.PlaceholderText = ""; numberField.Description = ""; numberField.HelpText = ""; numberField.Required = false; numberField.Unique = false; numberField.Searchable = false; numberField.Auditable = false; numberField.System = true; numberField.DefaultValue = 0; numberField.MinValue = null; numberField.MaxValue = null; numberField.DecimalPlaces = 0; numberField.EnableSecurity = true; numberField.Permissions = new FieldPermissions(); numberField.Permissions.CanRead = new List<Guid>(); numberField.Permissions.CanUpdate = new List<Guid>(); //READ numberField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE numberField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(BUG_ENTITY_ID, numberField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + BUG_ENTITY_NAME + " Field: x_nonbillable_hours" + " Message:" + response.Message); } } #endregion #region << user_1_n_bug_owner Relation >> { var originEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; var targetEntity = entMan.ReadEntity(BUG_ENTITY_ID).Object; EntityRelation oneToNRelation = new EntityRelation(); oneToNRelation.Id = new Guid("cddc10b6-30ff-4a86-96e4-645b3ea59fd9"); oneToNRelation.Name = "user_1_n_bug_owner"; oneToNRelation.Label = "user_1_n_bug_owner"; oneToNRelation.System = true; oneToNRelation.RelationType = EntityRelationType.OneToMany; oneToNRelation.OriginEntityId = originEntity.Id; oneToNRelation.OriginFieldId = originEntity.Fields.Single(x => x.Name == "id").Id; oneToNRelation.TargetEntityId = targetEntity.Id; oneToNRelation.TargetFieldId = targetEntity.Fields.Single(x => x.Name == "owner_id").Id; { var result = relMan.Create(oneToNRelation); if (!result.Success) throw new Exception("CREATE user_1_n_bug_owner RELATION:" + result.Message); } } #endregion #region << user_n_n_bug_watchers Relation >> { var originEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; var targetEntity = entMan.ReadEntity(BUG_ENTITY_ID).Object; EntityRelation NToNRelation = new EntityRelation(); NToNRelation.Id = new Guid("b71d0c52-1626-48da-91bc-e10999ba79b8"); NToNRelation.Name = "user_n_n_bug_watchers"; NToNRelation.Label = "user_n_n_bug_watchers"; NToNRelation.System = true; NToNRelation.RelationType = EntityRelationType.ManyToMany; NToNRelation.OriginEntityId = originEntity.Id; NToNRelation.OriginFieldId = originEntity.Fields.Single(x => x.Name == "id").Id; NToNRelation.TargetEntityId = targetEntity.Id; NToNRelation.TargetFieldId = targetEntity.Fields.Single(x => x.Name == "id").Id; { var result = relMan.Create(NToNRelation); if (!result.Success) throw new Exception("CREATE user_n_n_bug_watchers RELATION:" + result.Message); } } #endregion #region << task_n_n_bug Relation >> { var originEntity = entMan.ReadEntity(TASK_ENTITY_ID).Object; var targetEntity = entMan.ReadEntity(BUG_ENTITY_ID).Object; EntityRelation NToNRelation = new EntityRelation(); NToNRelation.Id = new Guid("7103355b-bf03-40e1-8446-f6aeecfaa74c"); NToNRelation.Name = "task_n_n_bug"; NToNRelation.Label = "task_n_n_bug"; NToNRelation.System = true; NToNRelation.RelationType = EntityRelationType.ManyToMany; NToNRelation.OriginEntityId = originEntity.Id; NToNRelation.OriginFieldId = originEntity.Fields.Single(x => x.Name == "id").Id; NToNRelation.TargetEntityId = targetEntity.Id; NToNRelation.TargetFieldId = targetEntity.Fields.Single(x => x.Name == "id").Id; { var result = relMan.Create(NToNRelation); if (!result.Success) throw new Exception("CREATE task_n_n_bug RELATION:" + result.Message); } } #endregion #region << project_1_n_bug Relation >> { var originEntity = entMan.ReadEntity(PROJECT_ENTITY_ID).Object; var targetEntity = entMan.ReadEntity(BUG_ENTITY_ID).Object; EntityRelation oneToNRelation = new EntityRelation(); oneToNRelation.Id = new Guid("d94f100c-024c-47e7-af32-d67a49be2b6c"); oneToNRelation.Name = "project_1_n_bug"; oneToNRelation.Label = "project_1_n_bug"; oneToNRelation.System = true; oneToNRelation.RelationType = EntityRelationType.OneToMany; oneToNRelation.OriginEntityId = originEntity.Id; oneToNRelation.OriginFieldId = originEntity.Fields.Single(x => x.Name == "id").Id; oneToNRelation.TargetEntityId = targetEntity.Id; oneToNRelation.TargetFieldId = targetEntity.Fields.Single(x => x.Name == "project_id").Id; { var result = relMan.Create(oneToNRelation); if (!result.Success) throw new Exception("CREATE project_1_n_bug RELATION:" + result.Message); } } #endregion #region << create project_bugs list >> { var createListEntity = entMan.ReadEntity(BUG_ENTITY_ID).Object; var createListInput = new InputRecordList(); var listField = new InputRecordListFieldItem(); var listFieldFromRelation = new InputRecordListRelationFieldItem(); var listSort = new InputRecordListSort(); var listQuery = new InputRecordListQuery(); //General list details createListInput.Id = new Guid("3b2ebe34-1d02-448a-9616-5b62538fe2c7"); createListInput.Name = "project_bugs"; createListInput.Label = "Bugs"; createListInput.Weight = 10; createListInput.Default = true; createListInput.VisibleColumnsCount = 5; createListInput.IconName = "bug"; createListInput.ColumnWidthsCSV = "auto,30px,120px,120px,120px"; createListInput.CssClass = "bug-list"; createListInput.Type = "hidden"; //Fields createListInput.Columns = new List<InputRecordListItemBase>(); #region << subject >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "subject").Id; listField.FieldName = "subject"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << owner - image >> { var targetEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; listFieldFromRelation = new InputRecordListRelationFieldItem(); listFieldFromRelation.EntityId = targetEntity.Id; listFieldFromRelation.EntityName = targetEntity.Name; listFieldFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "image").Id; listFieldFromRelation.FieldName = "image"; listFieldFromRelation.FieldLabel = "Owner"; listFieldFromRelation.RelationId = new Guid("cddc10b6-30ff-4a86-96e4-645b3ea59fd9"); listFieldFromRelation.RelationName = "user_1_n_bug_owner"; listFieldFromRelation.Type = "fieldFromRelation"; createListInput.Columns.Add(listFieldFromRelation); } #endregion #region << created_on >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "created_on").Id; listField.FieldName = "created_on"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << status >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "status").Id; listField.FieldName = "status"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << priority >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "priority").Id; listField.FieldName = "priority"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << query main>> { listQuery = new InputRecordListQuery(); listQuery.FieldName = null; listQuery.FieldValue = null; listQuery.QueryType = "AND"; listQuery.SubQueries = new List<InputRecordListQuery>(); #region << subject >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "subject"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""subject"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "CONTAINS"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion #region << subject >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "status"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""status"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "EQ"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion #region << priority >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "priority"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""priority"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "EQ"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion createListInput.Query = listQuery; } #endregion #region << Sort >> createListInput.Sorts = new List<InputRecordListSort>(); { listSort = new InputRecordListSort(); listSort.FieldName = @"{""name"":""url_sort"", ""option"": ""sortBy"", ""default"": ""created_on"", ""settings"":{""order"":""sortOrder""}}"; listSort.SortType = "descending"; createListInput.Sorts.Add(listSort); } #endregion var newActionItemList = new List<ActionItem>(); { var actionItem = new ActionItem(); actionItem.Name = "wv_create_record"; actionItem.Menu = "page-title"; actionItem.Template = "<a class=\"btn btn-default btn-outline hidden-xs\" ng-show=\"::ngCtrl.userHasRecordPermissions('canCreate')\" \n ng-href=\"{{::ngCtrl.getRecordCreateUrl()}}\">Add New</a>"; actionItem.Weight = 1; newActionItemList.Add(actionItem); } { var actionItem = new ActionItem(); actionItem.Name = "wv_import_records"; actionItem.Menu = "page-title-dropdown"; actionItem.Template = "<a ng-click=\"ngCtrl.openImportModal()\" class=\"ng-hide\" ng-show=\"::ngCtrl.userHasRecordPermissions('canCreate,canUpdate')\">\n\t<i class=\"fa fa-fw fa-upload\"></i> Import CSV\n</a>"; actionItem.Weight = 10; newActionItemList.Add(actionItem); } { var actionItem = new ActionItem(); actionItem.Name = "wv_export_records"; actionItem.Menu = "page-title-dropdown"; actionItem.Template = "<a ng-click=\"ngCtrl.openExportModal()\" class=\"ng-hide\" ng-show=\"::ngCtrl.userHasRecordPermissions('canCreate,canUpdate')\">\n\t<i class=\"fa fa-fw fa-download\"></i> Export CSV\n</a>"; actionItem.Weight = 11; newActionItemList.Add(actionItem); } { var actionItem = new ActionItem(); actionItem.Name = "wv_record_details"; actionItem.Menu = "record-row"; actionItem.Template = "<a class=\"btn btn-default btn-outline\" ng-href=\"{{::ngCtrl.getRecordDetailsUrl(record)}}\">\n <i class=\"fa fa-fw fa-eye\"></i>\n</a>"; actionItem.Weight = 1; newActionItemList.Add(actionItem); } createListInput.ActionItems = newActionItemList; { var response = entMan.CreateRecordList(BUG_ENTITY_ID, createListInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + BUG_ENTITY_NAME + " Updated List: general" + " Message:" + response.Message); } } #endregion #region << List name: my_bugs >> { var createListEntity = entMan.ReadEntity(BUG_ENTITY_ID).Object; var createListInput = new InputRecordList(); var listField = new InputRecordListFieldItem(); var listFieldFromRelation = new InputRecordListRelationFieldItem(); var listSort = new InputRecordListSort(); var listQuery = new InputRecordListQuery(); #region << details >> createListInput.Id = new Guid("2ac91f01-0ee5-420e-8981-4f57eaea255e"); createListInput.Type = "general"; createListInput.Name = "my_bugs"; createListInput.Label = "My Owned Open Bugs"; createListInput.Weight = 1; createListInput.Default = false; createListInput.System = true; createListInput.CssClass = "bug-list"; createListInput.IconName = "bug"; createListInput.VisibleColumnsCount = 7; createListInput.ColumnWidthsCSV = "100px,auto,30px,160px,120px,120px,120px"; createListInput.PageSize = 10; createListInput.DynamicHtmlTemplate = null; createListInput.DataSourceUrl = null; createListInput.ServiceCode = null; #endregion #region << action items >> createListInput.ActionItems = new List<ActionItem>(); var actionItem = new ActionItem(); { actionItem = new ActionItem(); actionItem.Name = "wv_record_details"; actionItem.Menu = "record-row"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline"" ng-href=""{{::ngCtrl.getRecordDetailsUrl(record, ngCtrl)}}""> <i class=""fa fa-fw fa-eye""></i> </a>"; createListInput.ActionItems.Add(actionItem); } { actionItem = new ActionItem(); actionItem.Name = "wv_create_record"; actionItem.Menu = "page-title"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline hidden-xs"" ng-show=""::ngCtrl.userHasRecordPermissions('canCreate')"" ng-href=""{{::ngCtrl.getRecordCreateUrl(ngCtrl)}}"">Add New</a>"; createListInput.ActionItems.Add(actionItem); } #endregion #region << Columns >> createListInput.Columns = new List<InputRecordListItemBase>(); #region << code >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "code").Id; listField.FieldName = "code"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << subject >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "subject").Id; listField.FieldName = "subject"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << owner - image >> { var targetEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; var targetRelation = relMan.Read("user_1_n_bug_owner").Object; listFieldFromRelation = new InputRecordListRelationFieldItem(); listFieldFromRelation.EntityId = targetEntity.Id; listFieldFromRelation.EntityName = targetEntity.Name; listFieldFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "image").Id; listFieldFromRelation.FieldName = "image"; listFieldFromRelation.FieldLabel = "Owner"; listFieldFromRelation.RelationId = targetRelation.Id; listFieldFromRelation.RelationName = targetRelation.Name; listFieldFromRelation.Type = "fieldFromRelation"; createListInput.Columns.Add(listFieldFromRelation); } #endregion #region << created_on >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "created_on").Id; listField.FieldName = "created_on"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << status >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "status").Id; listField.FieldName = "status"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << priority >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "priority").Id; listField.FieldName = "priority"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #endregion #region << relation options >> createListInput.RelationOptions = new List<EntityRelationOptionsItem>(); #endregion #region << query >> createListInput.Query = new InputRecordListQuery(); //Main query rule createListInput.Query.FieldName = null; createListInput.Query.FieldValue = null; createListInput.Query.QueryType = "AND"; createListInput.Query.SubQueries = new List<InputRecordListQuery>(); #region << Section 1 >> listQuery = new InputRecordListQuery(); listQuery.FieldName = null; listQuery.FieldValue = null; listQuery.QueryType = "AND"; listQuery.SubQueries = new List<InputRecordListQuery>(); #region << owner_id >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "owner_id"; subQuery.FieldValue = @"{""name"":""current_user"", ""option"": ""id"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "EQ"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion createListInput.Query.SubQueries.Add(listQuery); #endregion #region << Section 2 >> listQuery = new InputRecordListQuery(); listQuery.FieldName = null; listQuery.FieldValue = null; listQuery.QueryType = "AND"; listQuery.SubQueries = new List<InputRecordListQuery>(); #region << code >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "code"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""code"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "CONTAINS"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion #region << subject >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "subject"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""subject"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "CONTAINS"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion #region << status >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "status"; subQuery.FieldValue = "closed"; subQuery.QueryType = "NOT"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion #region << priority >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "priority"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""priority"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "EQ"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion createListInput.Query.SubQueries.Add(listQuery); #endregion #endregion #region << Sort >> createListInput.Sorts = new List<InputRecordListSort>(); listSort = new InputRecordListSort(); listSort.FieldName = @"{""name"":""url_sort"", ""option"": ""sortBy"", ""default"": ""created_on"", ""settings"":{""order"":""sortOrder""}}"; listSort.SortType = "ascending"; createListInput.Sorts.Add(listSort); #endregion { var response = entMan.CreateRecordList(BUG_ENTITY_ID, createListInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + BUG_ENTITY_NAME + " Updated List: my_tickets" + " Message:" + response.Message); } } #endregion #region << List name: created_bugs >> { var createListEntity = entMan.ReadEntity(BUG_ENTITY_ID).Object; var createListInput = new InputRecordList(); var listField = new InputRecordListFieldItem(); var listFieldFromRelation = new InputRecordListRelationFieldItem(); var listSort = new InputRecordListSort(); var listQuery = new InputRecordListQuery(); #region << details >> createListInput.Id = new Guid("42356233-9a6b-4fcb-ae2b-42ca29d84fe8"); createListInput.Type = "general"; createListInput.Name = "created_bugs"; createListInput.Label = "Bugs created by me"; createListInput.Weight = 3; createListInput.Default = false; createListInput.System = true; createListInput.CssClass = "bug-list"; createListInput.IconName = "bug"; createListInput.VisibleColumnsCount = 7; createListInput.ColumnWidthsCSV = "100px,auto,30px,120px,120px,120px,120px"; createListInput.PageSize = 10; createListInput.DynamicHtmlTemplate = null; createListInput.DataSourceUrl = null; createListInput.ServiceCode = null; #endregion #region << action items >> createListInput.ActionItems = new List<ActionItem>(); var actionItem = new ActionItem(); { actionItem = new ActionItem(); actionItem.Name = "wv_record_details"; actionItem.Menu = "record-row"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline"" ng-href=""{{::ngCtrl.getRecordDetailsUrl(record, ngCtrl)}}""> <i class=""fa fa-fw fa-eye""></i> </a>"; createListInput.ActionItems.Add(actionItem); } { actionItem = new ActionItem(); actionItem.Name = "wv_create_record"; actionItem.Menu = "page-title"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline hidden-xs"" ng-show=""::ngCtrl.userHasRecordPermissions('canCreate')"" ng-href=""{{::ngCtrl.getRecordCreateUrl(ngCtrl)}}"">Add New</a>"; createListInput.ActionItems.Add(actionItem); } #endregion #region << Columns >> createListInput.Columns = new List<InputRecordListItemBase>(); #region << code >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "code").Id; listField.FieldName = "code"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << subject >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "subject").Id; listField.FieldName = "subject"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << owner - image >> { var targetEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; var targetRelation = relMan.Read("user_1_n_bug_owner").Object; listFieldFromRelation = new InputRecordListRelationFieldItem(); listFieldFromRelation.EntityId = targetEntity.Id; listFieldFromRelation.EntityName = targetEntity.Name; listFieldFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "image").Id; listFieldFromRelation.FieldName = "image"; listFieldFromRelation.FieldLabel = "Owner"; listFieldFromRelation.RelationId = targetRelation.Id; listFieldFromRelation.RelationName = targetRelation.Name; listFieldFromRelation.Type = "fieldFromRelation"; createListInput.Columns.Add(listFieldFromRelation); } #endregion #region << status >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "status").Id; listField.FieldName = "status"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << priority >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "priority").Id; listField.FieldName = "priority"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #endregion #region << relation options >> createListInput.RelationOptions = new List<EntityRelationOptionsItem>(); #endregion #region << query >> createListInput.Query = new InputRecordListQuery(); //Main query rule createListInput.Query.FieldName = null; createListInput.Query.FieldValue = null; createListInput.Query.QueryType = "AND"; createListInput.Query.SubQueries = new List<InputRecordListQuery>(); #region << Section 1 >> listQuery = new InputRecordListQuery(); listQuery.FieldName = null; listQuery.FieldValue = null; listQuery.QueryType = "AND"; listQuery.SubQueries = new List<InputRecordListQuery>(); #region << created_by >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "created_by"; subQuery.FieldValue = @"{""name"":""current_user"", ""option"": ""id"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "EQ"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion createListInput.Query.SubQueries.Add(listQuery); #endregion #region << Section 2 >> listQuery = new InputRecordListQuery(); listQuery.FieldName = null; listQuery.FieldValue = null; listQuery.QueryType = "AND"; listQuery.SubQueries = new List<InputRecordListQuery>(); #region << code >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "code"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""code"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "CONTAINS"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion #region << subject >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "subject"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""subject"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "CONTAINS"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion #region << status >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "status"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""status"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "EQ"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion #region << priority >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "priority"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""priority"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "EQ"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion createListInput.Query.SubQueries.Add(listQuery); #endregion #endregion #region << Sort >> createListInput.Sorts = new List<InputRecordListSort>(); listSort = new InputRecordListSort(); listSort.FieldName = @"{""name"":""url_sort"", ""option"": ""sortBy"", ""default"": ""created_on"", ""settings"":{""order"":""sortOrder""}}"; listSort.SortType = "ascending"; createListInput.Sorts.Add(listSort); #endregion { var response = entMan.CreateRecordList(BUG_ENTITY_ID, createListInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + BUG_ENTITY_NAME + " Updated List: bug_created" + " Message:" + response.Message); } } #endregion #region << List name: owned_bugs >> { var createListEntity = entMan.ReadEntity(BUG_ENTITY_ID).Object; var createListInput = new InputRecordList(); var listField = new InputRecordListFieldItem(); var listFieldFromRelation = new InputRecordListRelationFieldItem(); var listSort = new InputRecordListSort(); var listQuery = new InputRecordListQuery(); #region << details >> createListInput.Id = new Guid("c3f5b3f5-9d15-4b5a-a2cc-70e0d85efaf7"); createListInput.Type = "general"; createListInput.Name = "owned_bugs"; createListInput.Label = "Bugs owned by me"; createListInput.Weight = 2; createListInput.Default = false; createListInput.System = true; createListInput.CssClass = "bug-list"; createListInput.IconName = "bug"; createListInput.VisibleColumnsCount = 7; createListInput.ColumnWidthsCSV = "100px,auto,30px,120px,120px,120px,120px"; createListInput.PageSize = 10; createListInput.DynamicHtmlTemplate = null; createListInput.DataSourceUrl = null; createListInput.ServiceCode = null; #endregion #region << action items >> createListInput.ActionItems = new List<ActionItem>(); var actionItem = new ActionItem(); { actionItem = new ActionItem(); actionItem.Name = "wv_record_details"; actionItem.Menu = "record-row"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline"" ng-href=""{{::ngCtrl.getRecordDetailsUrl(record, ngCtrl)}}""> <i class=""fa fa-fw fa-eye""></i> </a>"; createListInput.ActionItems.Add(actionItem); } { actionItem = new ActionItem(); actionItem.Name = "wv_create_record"; actionItem.Menu = "page-title"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline hidden-xs"" ng-show=""::ngCtrl.userHasRecordPermissions('canCreate')"" ng-href=""{{::ngCtrl.getRecordCreateUrl(ngCtrl)}}"">Add New</a>"; createListInput.ActionItems.Add(actionItem); } #endregion #region << Columns >> createListInput.Columns = new List<InputRecordListItemBase>(); #region << code >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "code").Id; listField.FieldName = "code"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << subject >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "subject").Id; listField.FieldName = "subject"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << owner - image >> { var targetEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; var targetRelation = relMan.Read("user_1_n_bug_owner").Object; listFieldFromRelation = new InputRecordListRelationFieldItem(); listFieldFromRelation.EntityId = targetEntity.Id; listFieldFromRelation.EntityName = targetEntity.Name; listFieldFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "image").Id; listFieldFromRelation.FieldName = "image"; listFieldFromRelation.FieldLabel = "Owner"; listFieldFromRelation.RelationId = targetRelation.Id; listFieldFromRelation.RelationName = targetRelation.Name; listFieldFromRelation.Type = "fieldFromRelation"; createListInput.Columns.Add(listFieldFromRelation); } #endregion #region << status >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "status").Id; listField.FieldName = "status"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << priority >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "priority").Id; listField.FieldName = "priority"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #endregion #region << relation options >> createListInput.RelationOptions = new List<EntityRelationOptionsItem>(); #endregion #region << query >> createListInput.Query = new InputRecordListQuery(); //Main query rule createListInput.Query.FieldName = null; createListInput.Query.FieldValue = null; createListInput.Query.QueryType = "AND"; createListInput.Query.SubQueries = new List<InputRecordListQuery>(); #region << Section 1 >> listQuery = new InputRecordListQuery(); listQuery.FieldName = null; listQuery.FieldValue = null; listQuery.QueryType = "OR"; listQuery.SubQueries = new List<InputRecordListQuery>(); #region << owner_id >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "owner_id"; subQuery.FieldValue = @"{""name"":""current_user"", ""option"": ""id"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "EQ"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion createListInput.Query.SubQueries.Add(listQuery); #endregion #region << Section 2 >> listQuery = new InputRecordListQuery(); listQuery.FieldName = null; listQuery.FieldValue = null; listQuery.QueryType = "AND"; listQuery.SubQueries = new List<InputRecordListQuery>(); #region << code >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "code"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""code"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "CONTAINS"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion #region << subject >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "subject"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""subject"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "CONTAINS"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion #region << status >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "status"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""status"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "EQ"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion #region << priority >> { var subQuery = new InputRecordListQuery(); subQuery.FieldName = "priority"; subQuery.FieldValue = @"{""name"":""url_query"", ""option"": ""priority"", ""default"": null, ""settings"":{}}"; subQuery.QueryType = "EQ"; subQuery.SubQueries = new List<InputRecordListQuery>(); listQuery.SubQueries.Add(subQuery); } #endregion createListInput.Query.SubQueries.Add(listQuery); #endregion #endregion #region << Sort >> createListInput.Sorts = new List<InputRecordListSort>(); listSort = new InputRecordListSort(); listSort.FieldName = @"{""name"":""url_sort"", ""option"": ""sortBy"", ""default"": ""created_on"", ""settings"":{""order"":""sortOrder""}}"; listSort.SortType = "ascending"; createListInput.Sorts.Add(listSort); #endregion { var response = entMan.CreateRecordList(BUG_ENTITY_ID, createListInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + BUG_ENTITY_NAME + " Updated List: owned_bug" + " Message:" + response.Message); } } #endregion #region << List name: all_bugs >> { var createListEntity = entMan.ReadEntity(BUG_ENTITY_ID).Object; var createListInput = new InputRecordList(); var listField = new InputRecordListFieldItem(); var listFieldFromRelation = new InputRecordListRelationFieldItem(); var listSort = new InputRecordListSort(); var listQuery = new InputRecordListQuery(); #region << details >> createListInput.Id = new Guid("97658e2a-69fb-48f5-b84c-236e1bd0103b"); createListInput.Type = "general"; createListInput.Name = "all_bugs"; createListInput.Label = "All Bugs"; createListInput.Weight = 12; createListInput.Default = false; createListInput.System = true; createListInput.CssClass = "bug-list"; createListInput.IconName = "bug"; createListInput.VisibleColumnsCount = 7; createListInput.ColumnWidthsCSV = "100px,auto,30px,120px,120px,120px,120px"; createListInput.PageSize = 10; createListInput.DynamicHtmlTemplate = null; createListInput.DataSourceUrl = @"/plugins/webvella-projects/api/bug/list/all"; createListInput.ServiceCode = null; #endregion #region << action items >> createListInput.ActionItems = new List<ActionItem>(); var actionItem = new ActionItem(); { actionItem = new ActionItem(); actionItem.Name = "wv_record_details"; actionItem.Menu = "record-row"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline"" ng-href=""{{::ngCtrl.getRecordDetailsUrl(record, ngCtrl)}}""> <i class=""fa fa-fw fa-eye""></i> </a>"; createListInput.ActionItems.Add(actionItem); } { actionItem = new ActionItem(); actionItem.Name = "wv_create_record"; actionItem.Menu = "page-title"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline hidden-xs"" ng-show=""::ngCtrl.userHasRecordPermissions('canCreate')"" ng-href=""{{::ngCtrl.getRecordCreateUrl(ngCtrl)}}"">Add New</a>"; createListInput.ActionItems.Add(actionItem); } #endregion #region << Columns >> createListInput.Columns = new List<InputRecordListItemBase>(); #region << code >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "code").Id; listField.FieldName = "code"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << subject >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "subject").Id; listField.FieldName = "subject"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << owner - image >> { var targetEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; var targetRelation = relMan.Read("user_1_n_bug_owner").Object; listFieldFromRelation = new InputRecordListRelationFieldItem(); listFieldFromRelation.EntityId = targetEntity.Id; listFieldFromRelation.EntityName = targetEntity.Name; listFieldFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "image").Id; listFieldFromRelation.FieldName = "image"; listFieldFromRelation.FieldLabel = "Owner"; listFieldFromRelation.RelationId = targetRelation.Id; listFieldFromRelation.RelationName = targetRelation.Name; listFieldFromRelation.Type = "fieldFromRelation"; createListInput.Columns.Add(listFieldFromRelation); } #endregion #region << status >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "status").Id; listField.FieldName = "status"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << priority >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "priority").Id; listField.FieldName = "priority"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #endregion #region << query >> createListInput.Query = null; #endregion #region << Sort >> createListInput.Sorts = new List<InputRecordListSort>(); #endregion { var response = entMan.CreateRecordList(BUG_ENTITY_ID, createListInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + BUG_ENTITY_NAME + " Updated List: all_bugs" + " Message:" + response.Message); } } #endregion #region << List name: admin >> { var createListEntity = entMan.ReadEntity(BUG_ENTITY_ID).Object; var createListInput = new InputRecordList(); var listField = new InputRecordListFieldItem(); var listFieldFromRelation = new InputRecordListRelationFieldItem(); var listSort = new InputRecordListSort(); var listQuery = new InputRecordListQuery(); #region << details >> createListInput.Id = new Guid("dd4eb5d6-0ada-4151-90af-675e2cc831e5"); createListInput.Type = "hidden"; createListInput.Name = "admin"; createListInput.Label = "All Bugs"; createListInput.Weight = 3; createListInput.Default = false; createListInput.System = true; createListInput.CssClass = "bug-list"; createListInput.IconName = "bug"; createListInput.VisibleColumnsCount = 7; createListInput.ColumnWidthsCSV = "auto,30px,120px,120px,120px,120px"; createListInput.PageSize = 10; createListInput.DynamicHtmlTemplate = null; createListInput.DataSourceUrl = null; createListInput.ServiceCode = null; #endregion #region << action items >> createListInput.ActionItems = new List<ActionItem>(); var actionItem = new ActionItem(); { actionItem = new ActionItem(); actionItem.Name = "wv_record_details"; actionItem.Menu = "record-row"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline"" ng-href=""{{::ngCtrl.getRecordDetailsUrl(record, ngCtrl)}}""> <i class=""fa fa-fw fa-eye""></i> </a>"; createListInput.ActionItems.Add(actionItem); } { actionItem = new ActionItem(); actionItem.Name = "wv_create_record"; actionItem.Menu = "page-title"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline hidden-xs"" ng-show=""::ngCtrl.userHasRecordPermissions('canCreate')"" ng-href=""{{::ngCtrl.getRecordCreateUrl(ngCtrl)}}"">Add New</a>"; createListInput.ActionItems.Add(actionItem); } #endregion #region << Columns >> createListInput.Columns = new List<InputRecordListItemBase>(); #region << subject >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "subject").Id; listField.FieldName = "subject"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << owner - image >> { var targetEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; listFieldFromRelation = new InputRecordListRelationFieldItem(); listFieldFromRelation.EntityId = targetEntity.Id; listFieldFromRelation.EntityName = targetEntity.Name; listFieldFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "image").Id; listFieldFromRelation.FieldName = "image"; listFieldFromRelation.FieldLabel = "Owner"; listFieldFromRelation.RelationId = new Guid("cddc10b6-30ff-4a86-96e4-645b3ea59fd9"); listFieldFromRelation.RelationName = "user_1_n_bug_owner"; listFieldFromRelation.Type = "fieldFromRelation"; createListInput.Columns.Add(listFieldFromRelation); } #endregion #region << created_on >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "created_on").Id; listField.FieldName = "created_on"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << status >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "status").Id; listField.FieldName = "status"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << priority >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "priority").Id; listField.FieldName = "priority"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #endregion #region << relation options >> createListInput.RelationOptions = new List<EntityRelationOptionsItem>(); #endregion #region << Sort >> createListInput.Sorts = new List<InputRecordListSort>(); listSort = new InputRecordListSort(); listSort.FieldName = @"{""name"":""url_sort"", ""option"": ""sortBy"", ""default"": ""created_on"", ""settings"":{""order"":""sortOrder""}}"; listSort.SortType = "descending"; createListInput.Sorts.Add(listSort); #endregion { var response = entMan.CreateRecordList(BUG_ENTITY_ID, createListInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + BUG_ENTITY_NAME + " Updated List: my_tickets" + " Message:" + response.Message); } } #endregion #region << create create >> { var createViewEntity = entMan.ReadEntity(BUG_ENTITY_ID).Object; var createViewInput = new InputRecordView(); var viewSection = new InputRecordViewSection(); var viewRow = new InputRecordViewRow(); var viewColumn = new InputRecordViewColumn(); var viewItem = new InputRecordViewFieldItem(); var viewItemFromRelation = new InputRecordViewRelationFieldItem(); //General view fields #region << Details >> createViewInput.Id = new Guid("b369195d-39b2-4b69-abd3-5182477c7783"); createViewInput.Name = "create"; createViewInput.Label = "Create"; createViewInput.Title = ""; createViewInput.Default = true; createViewInput.System = true; createViewInput.Type = "create"; createViewInput.Weight = 10; createViewInput.IconName = "file-text-o"; createViewInput.ServiceCode = null; createViewInput.DynamicHtmlTemplate = null; createViewInput.DataSourceUrl = null; #endregion #region << Get the header Region >> var headerRegion = new InputRecordViewRegion(); headerRegion.Name = "header"; headerRegion.Label = "header"; headerRegion.Sections = new List<InputRecordViewSection>(); #endregion #region << Section >> viewSection = new InputRecordViewSection(); viewSection.Id = new Guid("6781b136-b982-4934-a98c-5f736bd1a771"); viewSection.Name = "details"; viewSection.Label = "Details"; viewSection.ShowLabel = false; viewSection.CssClass = ""; viewSection.Collapsed = false; viewSection.TabOrder = "left-right"; viewSection.Weight = 1; viewSection.Rows = new List<InputRecordViewRow>(); #region << Row 1 >> viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("c0e3757b-6817-4eda-8cd1-e95b603af049"); viewRow.Weight = 1; viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = 12; viewColumn.Items = new List<InputRecordViewItemBase>(); #region << subject >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = createViewEntity.Id; viewItem.EntityName = createViewEntity.Name; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "subject").Id; viewItem.FieldName = "subject"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << project name >> { var targetEntity = entMan.ReadEntity(PROJECT_ENTITY_ID).Object; var targetRelation = relMan.Read("project_1_n_bug").Object; viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = targetEntity.Id; viewItemFromRelation.EntityName = targetEntity.Name; viewItemFromRelation.Type = "fieldFromRelation"; viewItemFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "name").Id; viewItemFromRelation.FieldName = "name"; viewItemFromRelation.FieldLabel = "Project"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = targetRelation.Id; viewItemFromRelation.RelationName = targetRelation.Name; viewColumn.Items.Add(viewItemFromRelation); } #endregion #region << description >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = createViewEntity.Id; viewItem.EntityName = createViewEntity.Name; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "description").Id; viewItem.FieldName = "description"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); #endregion //Save row viewSection.Rows.Add(viewRow); #endregion #region << Row 2 >> viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("61b3052c-339d-4ad2-8a5f-59f215f07358"); viewRow.Weight = 2; viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = 6; viewColumn.Items = new List<InputRecordViewItemBase>(); #region << status >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = createViewEntity.Id; viewItem.EntityName = createViewEntity.Name; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "status").Id; viewItem.FieldName = "status"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); #endregion #region << Column 2 >> viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = 6; viewColumn.Items = new List<InputRecordViewItemBase>(); #region << priority >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = createViewEntity.Id; viewItem.EntityName = createViewEntity.Name; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "priority").Id; viewItem.FieldName = "priority"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); #endregion //Save row viewSection.Rows.Add(viewRow); #endregion //Save section headerRegion.Sections.Add(viewSection); #endregion createViewInput.Regions = new List<InputRecordViewRegion>(); createViewInput.Regions.Add(headerRegion); #region << Sidebar >> var sidebarItem = new InputRecordViewSidebarItemBase(); createViewInput.Sidebar = new InputRecordViewSidebar(); createViewInput.Sidebar.CssClass = ""; createViewInput.Sidebar.Render = true; #endregion var newActionItemList = new List<ActionItem>(); { var actionItem = new ActionItem(); actionItem.Name = "wv_back_button"; actionItem.Menu = "sidebar-top"; actionItem.Template = "<a class=\"back clearfix\" href=\"javascript:void(0)\" ng-click=\"sidebarData.goBack()\"><i class=\"fa fa-fw fa-arrow-left\"></i> <span class=\"text\">Back</span></a>"; actionItem.Weight = 1; newActionItemList.Add(actionItem); } { var actionItem = new ActionItem(); actionItem.Name = "wv_create_and_list"; actionItem.Menu = "create-bottom"; actionItem.Template = "<a class=\"btn btn-primary\" ng-click='ngCtrl.create(\"default\")' ng-if=\"::ngCtrl.createViewRegion != null\">Create</a>"; actionItem.Weight = 1; newActionItemList.Add(actionItem); } { var actionItem = new ActionItem(); actionItem.Name = "wv_create_and_details"; actionItem.Menu = "create-bottom"; actionItem.Template = "<a class=\"btn btn-default btn-outline\" ng-click='ngCtrl.create(\"details\")' ng-if=\"::ngCtrl.createViewRegion != null\">Create & Details</a>"; actionItem.Weight = 2; newActionItemList.Add(actionItem); } { var actionItem = new ActionItem(); actionItem.Name = "wv_create_cancel"; actionItem.Menu = "create-bottom"; actionItem.Template = "<a class=\"btn btn-default btn-outline\" ng-click=\"ngCtrl.cancel()\">Cancel</a>"; actionItem.Weight = 3; newActionItemList.Add(actionItem); } createViewInput.ActionItems = newActionItemList; { var response = entMan.CreateRecordView(BUG_ENTITY_ID, createViewInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + BUG_ENTITY_NAME + " Updated view: create" + " Message:" + response.Message); } } #endregion #region << create general >> { var createViewEntity = entMan.ReadEntity(BUG_ENTITY_ID).Object; var createViewInput = new InputRecordView(); var viewSection = new InputRecordViewSection(); var viewRow = new InputRecordViewRow(); var viewColumn = new InputRecordViewColumn(); var viewItem = new InputRecordViewFieldItem(); var viewItemFromRelation = new InputRecordViewRelationFieldItem(); //General view fields #region << Details >> createViewInput.Id = new Guid("cc8ca474-29d3-4593-864a-166ad9e9a98e"); createViewInput.Name = "general"; createViewInput.Label = "General"; createViewInput.Title = ""; createViewInput.Default = true; createViewInput.System = true; createViewInput.Type = "general"; createViewInput.Weight = 10; createViewInput.IconName = "file-text-o"; createViewInput.ServiceCode = null; createViewInput.DynamicHtmlTemplate = null; createViewInput.DataSourceUrl = null; #endregion createViewInput.Regions = new List<InputRecordViewRegion>(); #region << Sidebar >> var sidebarItem = new InputRecordViewSidebarItemBase(); createViewInput.Sidebar = new InputRecordViewSidebar(); createViewInput.Sidebar.CssClass = ""; createViewInput.Sidebar.Render = true; #endregion var newActionItemList = new List<ActionItem>(); { var actionItem = new ActionItem(); actionItem.Name = "wv_back_button"; actionItem.Menu = "sidebar-top"; actionItem.Template = "<a class=\"back clearfix\" href=\"javascript:void(0)\" ng-click=\"sidebarData.goBack()\"><i class=\"fa fa-fw fa-arrow-left\"></i> <span class=\"text\">Back</span></a>"; actionItem.Weight = 1; newActionItemList.Add(actionItem); } { var actionItem = new ActionItem(); actionItem.Name = "wv_create_and_list"; actionItem.Menu = "create-bottom"; actionItem.Template = "<a class=\"btn btn-primary\" ng-click='ngCtrl.create(\"default\")' ng-if=\"::ngCtrl.createViewRegion != null\">Create</a>"; actionItem.Weight = 1; newActionItemList.Add(actionItem); } { var actionItem = new ActionItem(); actionItem.Name = "wv_create_and_details"; actionItem.Menu = "create-bottom"; actionItem.Template = "<a class=\"btn btn-default btn-outline\" ng-click='ngCtrl.create(\"details\")' ng-if=\"::ngCtrl.createViewRegion != null\">Create & Details</a>"; actionItem.Weight = 2; newActionItemList.Add(actionItem); } { var actionItem = new ActionItem(); actionItem.Name = "wv_create_cancel"; actionItem.Menu = "create-bottom"; actionItem.Template = "<a class=\"btn btn-default btn-outline\" ng-click=\"ngCtrl.cancel()\">Cancel</a>"; actionItem.Weight = 3; newActionItemList.Add(actionItem); } createViewInput.ActionItems = newActionItemList; { var response = entMan.CreateRecordView(BUG_ENTITY_ID, createViewInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + BUG_ENTITY_NAME + " Updated view: create" + " Message:" + response.Message); } } #endregion #region << area add subscription: Project Admin -> Bugs >> { var updatedAreaId = PROJECT_ADMIN_AREA_ID; var updateAreaResult = Helpers.UpsertEntityAsAreaSubscription(entMan, recMan, updatedAreaId, BUG_ENTITY_NAME, "general", "create", "admin"); if (!updateAreaResult.Success) { throw new Exception("System error 10060. Area update with id : " + updatedAreaId + " Message:" + updateAreaResult.Message); } } #endregion #region << area add subscription: Project Workplace -> My bugs >> { var updatedAreaId = PROJECT_WORKPLACE_AREA_ID; var updateAreaResult = Helpers.UpsertEntityAsAreaSubscription(entMan, recMan, updatedAreaId, BUG_ENTITY_NAME, "general", "create", "my_bugs"); if (!updateAreaResult.Success) { throw new Exception("System error 10060. Area update with id : " + updatedAreaId + " Message:" + updateAreaResult.Message); } } #endregion } #endregion #region << wv_timelog >> { #region << entity >> { InputEntity entity = new InputEntity(); entity.Id = TIMELOG_ENTITY_ID; entity.Name = TIMELOG_ENTITY_NAME; entity.Label = "Time log"; entity.LabelPlural = "Time logs"; entity.System = true; entity.IconName = "clock-o"; entity.Weight = 9; entity.RecordPermissions = new RecordPermissions(); entity.RecordPermissions.CanCreate = new List<Guid>(); entity.RecordPermissions.CanRead = new List<Guid>(); entity.RecordPermissions.CanUpdate = new List<Guid>(); entity.RecordPermissions.CanDelete = new List<Guid>(); //Create entity.RecordPermissions.CanCreate.Add(SystemIds.AdministratorRoleId); entity.RecordPermissions.CanCreate.Add(SystemIds.RegularRoleId); //READ entity.RecordPermissions.CanRead.Add(SystemIds.AdministratorRoleId); entity.RecordPermissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE entity.RecordPermissions.CanUpdate.Add(SystemIds.AdministratorRoleId); entity.RecordPermissions.CanUpdate.Add(SystemIds.RegularRoleId); //System fields and relations Ids should be hardcoded for the compare/change code generation to work later on correctly var systemItemIdDictionary = new Dictionary<string, Guid>(); systemItemIdDictionary["id"] = new Guid("41a9a85b-894d-40d1-956a-dba950a253c7"); systemItemIdDictionary["created_on"] = new Guid("ca1e843f-7f97-49db-bb7f-4b3a2b8f98ef"); systemItemIdDictionary["created_by"] = new Guid("1cc75ad8-dd5b-4cdb-8896-32521e0a7a2e"); systemItemIdDictionary["last_modified_on"] = new Guid("e91995d3-754e-418f-9a2d-aa2a319c568b"); systemItemIdDictionary["last_modified_by"] = new Guid("19b6101a-737e-4dec-96fe-3994b3fb8b65"); systemItemIdDictionary["user_wv_timelog_created_by"] = new Guid("393d1da8-0051-4807-8e89-1de933850888"); systemItemIdDictionary["user_wv_timelog_modified_by"] = new Guid("2c728372-8dc4-4d18-8897-4716fce3d404"); { var response = entMan.CreateEntity(entity, false, false, systemItemIdDictionary); if (!response.Success) throw new Exception("System error 10050. Entity: " + TIMELOG_ENTITY_NAME + " Field: entity creation" + " Message:" + response.Message); } } #endregion #region << billable >> { InputCheckboxField checkboxField = new InputCheckboxField(); checkboxField.Id = new Guid("1f4b0729-4e31-4722-a8ce-3bf90c471dad"); checkboxField.Name = "billable"; checkboxField.Label = "Billable"; checkboxField.PlaceholderText = ""; checkboxField.Description = ""; checkboxField.HelpText = ""; checkboxField.Required = true; checkboxField.Unique = false; checkboxField.Searchable = false; checkboxField.Auditable = false; checkboxField.System = true; checkboxField.DefaultValue = true; checkboxField.EnableSecurity = true; checkboxField.Permissions = new FieldPermissions(); checkboxField.Permissions.CanRead = new List<Guid>(); checkboxField.Permissions.CanUpdate = new List<Guid>(); //READ checkboxField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); checkboxField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE checkboxField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); checkboxField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(TIMELOG_ENTITY_ID, checkboxField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + TIMELOG_ENTITY_NAME + " Field: field_name" + " Message:" + response.Message); } } #endregion #region << hours >> { InputNumberField numberField = new InputNumberField(); numberField.Id = new Guid("41caeb03-7430-4eb8-b830-c9df8bf2dc7f"); numberField.Name = "hours"; numberField.Label = "Hours"; numberField.PlaceholderText = ""; numberField.Description = ""; numberField.HelpText = ""; numberField.Required = true; numberField.Unique = false; numberField.Searchable = false; numberField.Auditable = false; numberField.System = true; numberField.DefaultValue = 0; numberField.MinValue = 0; numberField.MaxValue = null; numberField.DecimalPlaces = 2; numberField.EnableSecurity = true; numberField.Permissions = new FieldPermissions(); numberField.Permissions.CanRead = new List<Guid>(); numberField.Permissions.CanUpdate = new List<Guid>(); //READ numberField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE numberField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); numberField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(TIMELOG_ENTITY_ID, numberField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + TIMELOG_ENTITY_NAME + " Field: hours" + " Message:" + response.Message); } } #endregion #region << description >> { InputMultiLineTextField textareaField = new InputMultiLineTextField(); textareaField.Id = new Guid("1a1b646e-93df-4035-ace0-d844f62bad63"); textareaField.Name = "description"; textareaField.Label = "Description"; textareaField.PlaceholderText = ""; textareaField.Description = ""; textareaField.HelpText = ""; textareaField.Required = false; textareaField.Unique = false; textareaField.Searchable = false; textareaField.Auditable = false; textareaField.System = true; textareaField.DefaultValue = " "; textareaField.VisibleLineNumber = null; textareaField.EnableSecurity = true; textareaField.Permissions = new FieldPermissions(); textareaField.Permissions.CanRead = new List<Guid>(); textareaField.Permissions.CanUpdate = new List<Guid>(); textareaField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); textareaField.Permissions.CanRead.Add(SystemIds.RegularRoleId); textareaField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); textareaField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(TIMELOG_ENTITY_ID, textareaField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + TIMELOG_ENTITY_NAME + " Field: description" + " Message:" + response.Message); } } #endregion #region << log_date >> { InputDateField dateField = new InputDateField(); dateField.Id = new Guid("29a32ad7-7b1c-4ea0-a06b-57b30be9b107"); dateField.Name = "log_date"; dateField.Label = "Log date"; dateField.PlaceholderText = ""; dateField.Description = ""; dateField.HelpText = ""; dateField.Required = true; dateField.Unique = false; dateField.Searchable = false; dateField.Auditable = false; dateField.System = true; dateField.DefaultValue = null; dateField.Format = "dd MMM yyyy"; dateField.UseCurrentTimeAsDefaultValue = true; dateField.EnableSecurity = true; dateField.Permissions = new FieldPermissions(); dateField.Permissions.CanRead = new List<Guid>(); dateField.Permissions.CanUpdate = new List<Guid>(); //READ dateField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); dateField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE dateField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); dateField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(TIMELOG_ENTITY_ID, dateField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + TIMELOG_ENTITY_NAME + " Field: log_date" + " Message:" + response.Message); } } #endregion #region << task_id >> { InputGuidField guidField = new InputGuidField(); guidField.Id = new Guid("d256d5f7-4af7-4d62-b265-e4509319d700"); guidField.Name = "task_id"; guidField.Label = "Parent task"; guidField.PlaceholderText = ""; guidField.Description = ""; guidField.HelpText = ""; guidField.Required = false; guidField.Unique = false; guidField.Searchable = false; guidField.Auditable = false; guidField.System = true; guidField.DefaultValue = Guid.Empty; guidField.GenerateNewId = false; guidField.EnableSecurity = true; guidField.Permissions = new FieldPermissions(); guidField.Permissions.CanRead = new List<Guid>(); guidField.Permissions.CanUpdate = new List<Guid>(); //READ guidField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE guidField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(TIMELOG_ENTITY_ID, guidField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + TIMELOG_ENTITY_NAME + " Field: task_id" + " Message:" + response.Message); } } #endregion #region << bug_id >> { InputGuidField guidField = new InputGuidField(); guidField.Id = new Guid("f1b9a8f3-ab8d-4de0-8503-df3165ad7969"); guidField.Name = "bug_id"; guidField.Label = "Parent bug"; guidField.PlaceholderText = ""; guidField.Description = ""; guidField.HelpText = ""; guidField.Required = false; guidField.Unique = false; guidField.Searchable = false; guidField.Auditable = false; guidField.System = true; guidField.DefaultValue = Guid.Empty; guidField.GenerateNewId = false; guidField.EnableSecurity = true; guidField.Permissions = new FieldPermissions(); guidField.Permissions.CanRead = new List<Guid>(); guidField.Permissions.CanUpdate = new List<Guid>(); //READ guidField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE guidField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(TIMELOG_ENTITY_ID, guidField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + TIMELOG_ENTITY_NAME + " Field: bug_id" + " Message:" + response.Message); } } #endregion #region << task_1_n_time_log Relation >> { var originEntity = entMan.ReadEntity(TASK_ENTITY_ID).Object; var targetEntity = entMan.ReadEntity(TIMELOG_ENTITY_ID).Object; EntityRelation oneToNRelation = new EntityRelation(); oneToNRelation.Id = new Guid("61f1cd54-bcd6-4061-9c96-7934e01f0857"); oneToNRelation.Name = "task_1_n_time_log"; oneToNRelation.Label = "task_1_n_time_log"; oneToNRelation.System = true; oneToNRelation.RelationType = EntityRelationType.OneToMany; oneToNRelation.OriginEntityId = originEntity.Id; oneToNRelation.OriginFieldId = originEntity.Fields.Single(x => x.Name == "id").Id; oneToNRelation.TargetEntityId = targetEntity.Id; oneToNRelation.TargetFieldId = targetEntity.Fields.Single(x => x.Name == "task_id").Id; { var result = relMan.Create(oneToNRelation); if (!result.Success) throw new Exception("CREATE task_1_n_time_log RELATION:" + result.Message); } } #endregion #region << bug_1_n_time_log Relation >> { var originEntity = entMan.ReadEntity(BUG_ENTITY_ID).Object; var targetEntity = entMan.ReadEntity(TIMELOG_ENTITY_ID).Object; EntityRelation oneToNRelation = new EntityRelation(); oneToNRelation.Id = new Guid("97909e49-50d4-4534-aa7b-61c523b55d87"); oneToNRelation.Name = "bug_1_n_time_log"; oneToNRelation.Label = "bug_1_n_time_log"; oneToNRelation.System = true; oneToNRelation.RelationType = EntityRelationType.OneToMany; oneToNRelation.OriginEntityId = originEntity.Id; oneToNRelation.OriginFieldId = originEntity.Fields.Single(x => x.Name == "id").Id; oneToNRelation.TargetEntityId = targetEntity.Id; oneToNRelation.TargetFieldId = targetEntity.Fields.Single(x => x.Name == "bug_id").Id; { var result = relMan.Create(oneToNRelation); if (!result.Success) throw new Exception("CREATE bug_1_n_time_log RELATION:" + result.Message); } } #endregion #region << List name: task_timelogs >> { var createListEntity = entMan.ReadEntity(TIMELOG_ENTITY_ID).Object; var createListInput = new InputRecordList(); var listField = new InputRecordListFieldItem(); var listFieldFromRelation = new InputRecordListRelationFieldItem(); var listSort = new InputRecordListSort(); var listQuery = new InputRecordListQuery(); #region << details >> createListInput.Id = new Guid("c105b3f8-e140-4150-a587-a31cf600d99b"); createListInput.Type = "hidden"; createListInput.Name = "task_timelogs"; createListInput.Label = "Time logs"; createListInput.Weight = 25; createListInput.Default = false; createListInput.System = true; createListInput.CssClass = null; createListInput.IconName = "clock-o"; createListInput.VisibleColumnsCount = 5; createListInput.ColumnWidthsCSV = "160px,160px,80px,auto"; createListInput.PageSize = 10; createListInput.DynamicHtmlTemplate = null; createListInput.DataSourceUrl = null; createListInput.ServiceCode = null; #endregion #region << action items >> createListInput.ActionItems = new List<ActionItem>(); #endregion #region << Columns >> createListInput.Columns = new List<InputRecordListItemBase>(); #region << log_date >> { var fieldName = "log_date"; listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == fieldName).Id; listField.FieldName = fieldName; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << user_wv_timelog_created_by > username >> { var relatedEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; var relation = relMan.Read("user_wv_timelog_created_by").Object; listFieldFromRelation = new InputRecordListRelationFieldItem(); listFieldFromRelation.EntityId = relatedEntity.Id; listFieldFromRelation.EntityName = relatedEntity.Name; listFieldFromRelation.FieldId = relatedEntity.Fields.Single(x => x.Name == "username").Id; listFieldFromRelation.FieldName = "username"; listFieldFromRelation.FieldLabel = "username"; listFieldFromRelation.Type = "field"; listFieldFromRelation.RelationId = relation.Id; listFieldFromRelation.RelationName = relation.Name; createListInput.Columns.Add(listFieldFromRelation); } #endregion #region << hours >> { var fieldName = "hours"; listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == fieldName).Id; listField.FieldName = fieldName; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << description >> { var fieldName = "description"; listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == fieldName).Id; listField.FieldName = fieldName; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #endregion #region << relation options >> createListInput.RelationOptions = new List<EntityRelationOptionsItem>(); #endregion #region << action items >> createListInput.ActionItems = new List<ActionItem>(); var actionItem = new ActionItem(); { actionItem = new ActionItem(); actionItem.Name = "wv_create_record"; actionItem.Menu = "page-title"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline hidden-xs"" ng-show=""::ngCtrl.userHasRecordPermissions('canCreate')"" ng-href=""{{ngCtrl.getRecordCreateUrl(ngCtrl)}}"">Add New</a>"; createListInput.ActionItems.Add(actionItem); } #endregion #region << Sort >> createListInput.Sorts = new List<InputRecordListSort>(); listSort = new InputRecordListSort(); listSort.FieldName = "log_date"; listSort.SortType = "ascending"; createListInput.Sorts.Add(listSort); #endregion { var response = entMan.CreateRecordList(TIMELOG_ENTITY_ID, createListInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + TIMELOG_ENTITY_NAME + " Updated List: task_timelogs" + " Message:" + response.Message); } } #endregion #region << List name: bug_timelogs >> { var createListEntity = entMan.ReadEntity(TIMELOG_ENTITY_ID).Object; var createListInput = new InputRecordList(); var listField = new InputRecordListFieldItem(); var listFieldFromRelation = new InputRecordListRelationFieldItem(); var listSort = new InputRecordListSort(); var listQuery = new InputRecordListQuery(); #region << details >> createListInput.Id = new Guid("f9a12626-08db-4fd2-a443-b521162be2b5"); createListInput.Type = "hidden"; createListInput.Name = "bug_timelogs"; createListInput.Label = "Time logs"; createListInput.Weight = 25; createListInput.Default = false; createListInput.System = true; createListInput.CssClass = null; createListInput.IconName = "clock-o"; createListInput.VisibleColumnsCount = 5; createListInput.ColumnWidthsCSV = "160px,160px,80px,auto"; createListInput.PageSize = 10; createListInput.DynamicHtmlTemplate = null; createListInput.DataSourceUrl = null; createListInput.ServiceCode = null; #endregion #region << action items >> createListInput.ActionItems = new List<ActionItem>(); #endregion #region << Columns >> createListInput.Columns = new List<InputRecordListItemBase>(); #region << created_on >> { var fieldName = "log_date"; listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == fieldName).Id; listField.FieldName = fieldName; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << user_wv_timelog_created_by > username >> { var relatedEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; var relation = relMan.Read("user_wv_timelog_created_by").Object; listFieldFromRelation = new InputRecordListRelationFieldItem(); listFieldFromRelation.EntityId = relatedEntity.Id; listFieldFromRelation.EntityName = relatedEntity.Name; listFieldFromRelation.FieldId = relatedEntity.Fields.Single(x => x.Name == "username").Id; listFieldFromRelation.FieldName = "username"; listFieldFromRelation.FieldLabel = "username"; listFieldFromRelation.Type = "field"; listFieldFromRelation.RelationId = relation.Id; listFieldFromRelation.RelationName = relation.Name; createListInput.Columns.Add(listFieldFromRelation); } #endregion #region << hours >> { var fieldName = "hours"; listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == fieldName).Id; listField.FieldName = fieldName; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << description >> { var fieldName = "description"; listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == fieldName).Id; listField.FieldName = fieldName; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #endregion #region << relation options >> createListInput.RelationOptions = new List<EntityRelationOptionsItem>(); #endregion #region << action items >> createListInput.ActionItems = new List<ActionItem>(); var actionItem = new ActionItem(); { actionItem = new ActionItem(); actionItem.Name = "wv_create_record"; actionItem.Menu = "page-title"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline hidden-xs"" ng-show=""::ngCtrl.userHasRecordPermissions('canCreate')"" ng-href=""{{ngCtrl.getRecordCreateUrl(ngCtrl)}}"">Add New</a>"; createListInput.ActionItems.Add(actionItem); } #endregion #region << Sort >> createListInput.Sorts = new List<InputRecordListSort>(); listSort = new InputRecordListSort(); listSort.FieldName = "log_date"; listSort.SortType = "ascending"; createListInput.Sorts.Add(listSort); #endregion { var response = entMan.CreateRecordList(TIMELOG_ENTITY_ID, createListInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + TIMELOG_ENTITY_NAME + " Updated List: task_timelogs" + " Message:" + response.Message); } } #endregion #region << create create >> { var createViewEntity = entMan.ReadEntity(TIMELOG_ENTITY_ID).Object; var createViewInput = new InputRecordView(); var viewSection = new InputRecordViewSection(); var viewRow = new InputRecordViewRow(); var viewColumn = new InputRecordViewColumn(); var viewItem = new InputRecordViewFieldItem(); var viewItemFromRelation = new InputRecordViewRelationFieldItem(); //General view fields #region << Details >> createViewInput.Id = new Guid("e33d960c-4867-48f2-bfc2-4f532aa2513d"); createViewInput.Name = "create"; createViewInput.Label = "Create"; createViewInput.Title = ""; createViewInput.Default = true; createViewInput.System = true; createViewInput.Type = "create"; createViewInput.Weight = 10; createViewInput.IconName = "file-text-o"; createViewInput.ServiceCode = null; createViewInput.DynamicHtmlTemplate = null; createViewInput.DataSourceUrl = null; #endregion #region << Get the header Region >> var headerRegion = new InputRecordViewRegion(); headerRegion.Name = "header"; headerRegion.Label = "header"; headerRegion.Sections = new List<InputRecordViewSection>(); #endregion #region << Section >> viewSection = new InputRecordViewSection(); viewSection.Id = new Guid("559e8b4a-2ae5-4be7-8a87-805faeafeac4"); viewSection.Name = "details"; viewSection.Label = "Details"; viewSection.ShowLabel = false; viewSection.CssClass = ""; viewSection.Collapsed = false; viewSection.TabOrder = "left-right"; viewSection.Weight = 1; viewSection.Rows = new List<InputRecordViewRow>(); #region << Row 1 >> viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("6c769b09-045b-4826-a791-83812f6ded1b"); viewRow.Weight = 1; viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = 6; viewColumn.Items = new List<InputRecordViewItemBase>(); #region << hours >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = createViewEntity.Id; viewItem.EntityName = createViewEntity.Name; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "hours").Id; viewItem.FieldName = "hours"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << hours >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = createViewEntity.Id; viewItem.EntityName = createViewEntity.Name; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "log_date").Id; viewItem.FieldName = "log_date"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); #endregion #region << Column 2 >> viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = 6; viewColumn.Items = new List<InputRecordViewItemBase>(); #region << subject >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = createViewEntity.Id; viewItem.EntityName = createViewEntity.Name; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "billable").Id; viewItem.FieldName = "billable"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); #endregion //Save row viewSection.Rows.Add(viewRow); #endregion #region << Row 2 >> viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("57e71de9-8cb4-4343-bcec-5a0152f08dbd"); viewRow.Weight = 2; viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = 12; viewColumn.Items = new List<InputRecordViewItemBase>(); #region << description >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = createViewEntity.Id; viewItem.EntityName = createViewEntity.Name; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "description").Id; viewItem.FieldName = "description"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); #endregion //Save row viewSection.Rows.Add(viewRow); #endregion //Save section headerRegion.Sections.Add(viewSection); #endregion createViewInput.Regions = new List<InputRecordViewRegion>(); createViewInput.Regions.Add(headerRegion); #region << Sidebar >> var sidebarItem = new InputRecordViewSidebarItemBase(); createViewInput.Sidebar = new InputRecordViewSidebar(); createViewInput.Sidebar.CssClass = ""; createViewInput.Sidebar.Render = true; #endregion #region << Action items> var newActionItemList = new List<ActionItem>(); { var actionItem = new ActionItem(); actionItem.Name = "wv_create_and_list"; actionItem.Menu = "create-bottom"; actionItem.Template = "<a class=\"btn btn-primary\" ng-click='ngCtrl.create(\"default\")' ng-if=\"::ngCtrl.createViewRegion != null\">Create</a>"; actionItem.Weight = 1; newActionItemList.Add(actionItem); } { var actionItem = new ActionItem(); actionItem.Name = "wv_create_cancel"; actionItem.Menu = "create-bottom"; actionItem.Template = "<a class=\"btn btn-default btn-outline\" ng-click=\"ngCtrl.cancel()\">Cancel</a>"; actionItem.Weight = 2; newActionItemList.Add(actionItem); } { var actionItem = new ActionItem(); actionItem.Name = "wv_back_button"; actionItem.Menu = "sidebar-top"; actionItem.Template = "<a class=\"back clearfix\" href=\"javascript:void(0)\" ng-click=\"sidebarData.goBack()\"><i class=\"fa fa-fw fa-arrow-left\"></i> <span class=\"text\">Back</span></a>"; actionItem.Weight = 1; newActionItemList.Add(actionItem); } createViewInput.ActionItems = newActionItemList; #endregion { var response = entMan.CreateRecordView(TIMELOG_ENTITY_ID, createViewInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + TIMELOG_ENTITY_NAME + " Updated view: create" + " Message:" + response.Message); } } #endregion } #endregion #region << wv_project_attachment >> { #region << entity >> { InputEntity entity = new InputEntity(); entity.Id = ATTACHMENT_ENTITY_ID; entity.Name = ATTACHMENT_ENTITY_NAME; entity.Label = "Attachment"; entity.LabelPlural = "Attachments"; entity.System = true; entity.IconName = "paperclip"; entity.Weight = 10; entity.RecordPermissions = new RecordPermissions(); entity.RecordPermissions.CanCreate = new List<Guid>(); entity.RecordPermissions.CanRead = new List<Guid>(); entity.RecordPermissions.CanUpdate = new List<Guid>(); entity.RecordPermissions.CanDelete = new List<Guid>(); //Create entity.RecordPermissions.CanCreate.Add(SystemIds.AdministratorRoleId); entity.RecordPermissions.CanCreate.Add(SystemIds.RegularRoleId); //READ entity.RecordPermissions.CanRead.Add(SystemIds.AdministratorRoleId); entity.RecordPermissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE entity.RecordPermissions.CanUpdate.Add(SystemIds.AdministratorRoleId); entity.RecordPermissions.CanUpdate.Add(SystemIds.RegularRoleId); //DELETE entity.RecordPermissions.CanDelete.Add(SystemIds.AdministratorRoleId); entity.RecordPermissions.CanDelete.Add(SystemIds.RegularRoleId); //System fields and relations Ids should be hardcoded for the compare/change code generation to work later on correctly var systemItemIdDictionary = new Dictionary<string, Guid>(); systemItemIdDictionary["id"] = new Guid("a965c8b6-83fb-43a0-a156-e8b58e4e51a5"); systemItemIdDictionary["created_on"] = new Guid("381de04c-fad1-46b6-aa11-59bf7822a9a5"); systemItemIdDictionary["created_by"] = new Guid("c8216ce8-5661-4a47-a03f-9cce93e943e1"); systemItemIdDictionary["last_modified_on"] = new Guid("7bb58634-82ce-4b29-9a99-9ec1e8ea03dc"); systemItemIdDictionary["last_modified_by"] = new Guid("c754a57c-4807-4cc8-9c63-6bcef8d09a7f"); systemItemIdDictionary["user_wv_project_attachment_created_by"] = new Guid("97fe4c22-b090-4d8d-b9df-39d3e04a5865"); systemItemIdDictionary["user_wv_project_attachment_modified_by"] = new Guid("b3f1f810-dd2d-4e9a-85d1-8e44746fbbdd"); { var response = entMan.CreateEntity(entity, false, false, systemItemIdDictionary); if (!response.Success) throw new Exception("System error 10050. Entity: " + ATTACHMENT_ENTITY_NAME + " Field: entity creation" + " Message:" + response.Message); } } #endregion #region << file >> { InputFileField fileField = new InputFileField(); fileField.Id = new Guid("6d639a8c-e220-4d9f-86f0-de6ba03030b8"); fileField.Name = "file"; fileField.Label = "File"; fileField.PlaceholderText = ""; fileField.Description = ""; fileField.HelpText = ""; fileField.Required = true; fileField.Unique = false; fileField.Searchable = false; fileField.Auditable = false; fileField.System = true; fileField.DefaultValue = string.Empty; fileField.EnableSecurity = true; fileField.Permissions = new FieldPermissions(); fileField.Permissions.CanRead = new List<Guid>(); fileField.Permissions.CanUpdate = new List<Guid>(); //READ fileField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); fileField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE fileField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); fileField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(ATTACHMENT_ENTITY_ID, fileField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + ATTACHMENT_ENTITY_NAME + " Field: file" + " Message:" + response.Message); } } #endregion #region << task_id >> { InputGuidField guidField = new InputGuidField(); guidField.Id = new Guid("841f6741-a7a6-4f52-9b45-31c4bf2e96ae"); guidField.Name = "task_id"; guidField.Label = "Parent task"; guidField.PlaceholderText = ""; guidField.Description = ""; guidField.HelpText = ""; guidField.Required = false; guidField.Unique = false; guidField.Searchable = false; guidField.Auditable = false; guidField.System = true; guidField.DefaultValue = Guid.Empty; guidField.GenerateNewId = false; guidField.EnableSecurity = true; guidField.Permissions = new FieldPermissions(); guidField.Permissions.CanRead = new List<Guid>(); guidField.Permissions.CanUpdate = new List<Guid>(); //READ guidField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE guidField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(ATTACHMENT_ENTITY_ID, guidField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + ATTACHMENT_ENTITY_NAME + " Field: task_id" + " Message:" + response.Message); } } #endregion #region << bug_id >> { InputGuidField guidField = new InputGuidField(); guidField.Id = new Guid("8a389111-cee3-4da0-986f-bcdc5f179924"); guidField.Name = "bug_id"; guidField.Label = "Parent bug"; guidField.PlaceholderText = ""; guidField.Description = ""; guidField.HelpText = ""; guidField.Required = false; guidField.Unique = false; guidField.Searchable = false; guidField.Auditable = false; guidField.System = true; guidField.DefaultValue = Guid.Empty; guidField.GenerateNewId = false; guidField.EnableSecurity = true; guidField.Permissions = new FieldPermissions(); guidField.Permissions.CanRead = new List<Guid>(); guidField.Permissions.CanUpdate = new List<Guid>(); //READ guidField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE guidField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(ATTACHMENT_ENTITY_ID, guidField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + ATTACHMENT_ENTITY_NAME + " Field: bug_id" + " Message:" + response.Message); } } #endregion #region << project_id >> { InputGuidField guidField = new InputGuidField(); guidField.Id = new Guid("151b03a4-156e-4500-a6ff-4431f67e500f"); guidField.Name = "project_id"; guidField.Label = "Project"; guidField.PlaceholderText = ""; guidField.Description = ""; guidField.HelpText = ""; guidField.Required = false; guidField.Unique = false; guidField.Searchable = false; guidField.Auditable = false; guidField.System = true; guidField.DefaultValue = Guid.Empty; guidField.GenerateNewId = false; guidField.EnableSecurity = true; guidField.Permissions = new FieldPermissions(); guidField.Permissions.CanRead = new List<Guid>(); guidField.Permissions.CanUpdate = new List<Guid>(); //READ guidField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE guidField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(ATTACHMENT_ENTITY_ID, guidField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + ATTACHMENT_ENTITY_NAME + " Field: project_id" + " Message:" + response.Message); } } #endregion #region << task_1_n_attachment Relation >> { var originEntity = entMan.ReadEntity(TASK_ENTITY_ID).Object; var targetEntity = entMan.ReadEntity(ATTACHMENT_ENTITY_ID).Object; EntityRelation oneToNRelation = new EntityRelation(); oneToNRelation.Id = new Guid("f79f76e2-06b1-463a-9675-63845814bf22"); oneToNRelation.Name = "task_1_n_attachment"; oneToNRelation.Label = "task_1_n_attachment"; oneToNRelation.System = true; oneToNRelation.RelationType = EntityRelationType.OneToMany; oneToNRelation.OriginEntityId = originEntity.Id; oneToNRelation.OriginFieldId = originEntity.Fields.Single(x => x.Name == "id").Id; oneToNRelation.TargetEntityId = targetEntity.Id; oneToNRelation.TargetFieldId = targetEntity.Fields.Single(x => x.Name == "task_id").Id; { var result = relMan.Create(oneToNRelation); if (!result.Success) throw new Exception("CREATE task_1_n_attachment RELATION:" + result.Message); } } #endregion #region << bug_1_n_attachment Relation >> { var originEntity = entMan.ReadEntity(BUG_ENTITY_ID).Object; var targetEntity = entMan.ReadEntity(ATTACHMENT_ENTITY_ID).Object; EntityRelation oneToNRelation = new EntityRelation(); oneToNRelation.Id = new Guid("a4f60f87-66a9-4541-a2ef-29e00f2b418b"); oneToNRelation.Name = "bug_1_n_attachment"; oneToNRelation.Label = "bug_1_n_attachment"; oneToNRelation.System = true; oneToNRelation.RelationType = EntityRelationType.OneToMany; oneToNRelation.OriginEntityId = originEntity.Id; oneToNRelation.OriginFieldId = originEntity.Fields.Single(x => x.Name == "id").Id; oneToNRelation.TargetEntityId = targetEntity.Id; oneToNRelation.TargetFieldId = targetEntity.Fields.Single(x => x.Name == "bug_id").Id; { var result = relMan.Create(oneToNRelation); if (!result.Success) throw new Exception("CREATE bug_1_n_attachment RELATION:" + result.Message); } } #endregion #region << project_1_n_attachment Relation >> { var originEntity = entMan.ReadEntity(PROJECT_ENTITY_ID).Object; var targetEntity = entMan.ReadEntity(ATTACHMENT_ENTITY_ID).Object; EntityRelation oneToNRelation = new EntityRelation(); oneToNRelation.Id = new Guid("d20a4341-76d5-4537-91a0-c264824ff76c"); oneToNRelation.Name = "project_1_n_attachment"; oneToNRelation.Label = "project_1_n_attachment"; oneToNRelation.System = true; oneToNRelation.RelationType = EntityRelationType.OneToMany; oneToNRelation.OriginEntityId = originEntity.Id; oneToNRelation.OriginFieldId = originEntity.Fields.Single(x => x.Name == "id").Id; oneToNRelation.TargetEntityId = targetEntity.Id; oneToNRelation.TargetFieldId = targetEntity.Fields.Single(x => x.Name == "project_id").Id; { var result = relMan.Create(oneToNRelation); if (!result.Success) throw new Exception("CREATE project_1_n_attachment RELATION:" + result.Message); } } #endregion #region << general list -> bug_attachments >> { var createListEntity = entMan.ReadEntity(ATTACHMENT_ENTITY_ID).Object; var createListInput = new InputRecordList(); var listField = new InputRecordListFieldItem(); var listFieldFromRelation = new InputRecordListRelationFieldItem(); var listSort = new InputRecordListSort(); var listQuery = new InputRecordListQuery(); //General list details createListInput.Id = new Guid("2b83e4e3-6878-4b5b-9391-6e59429c0b5e"); createListInput.Name = "bug_attachments"; createListInput.Label = "Attachments"; createListInput.IconName = "paperclip"; createListInput.Type = "general"; createListInput.Weight = 10; createListInput.Default = false; createListInput.System = true; createListInput.CssClass = null; createListInput.IconName = "paperclip"; createListInput.VisibleColumnsCount = 5; createListInput.ColumnWidthsCSV = "160px,160px,auto"; createListInput.PageSize = 10; createListInput.DynamicHtmlTemplate = null; createListInput.DataSourceUrl = null; createListInput.ServiceCode = null; createListInput.Columns = new List<InputRecordListItemBase>(); #region << created_on >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "created_on").Id; listField.FieldName = "created_on"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << created_by_username >> { var relatedEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; var relation = relMan.Read("user_wv_project_attachment_created_by").Object; listFieldFromRelation = new InputRecordListRelationFieldItem(); listFieldFromRelation.EntityId = relatedEntity.Id; listFieldFromRelation.EntityName = relatedEntity.Name; listFieldFromRelation.FieldId = relatedEntity.Fields.Single(x => x.Name == "username").Id; listFieldFromRelation.FieldName = "username"; listFieldFromRelation.Type = "field"; listFieldFromRelation.RelationId = relation.Id; listFieldFromRelation.RelationName = relation.Name; createListInput.Columns.Add(listFieldFromRelation); } #endregion #region << file >> { listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == "file").Id; listField.FieldName = "file"; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion //Query #region << query descr >> { } #endregion //Action items var newActionItemList = new List<ActionItem>(); { var actionItem = new ActionItem(); actionItem.Name = "wv_create_record"; actionItem.Menu = "page-title"; actionItem.Template = "<a class=\"btn btn-default btn-outline hidden-xs\" ng-show=\"::ngCtrl.userHasRecordPermissions('canCreate')\" \n ng-href=\"{{::ngCtrl.getRecordCreateUrl()}}\">Add New</a>"; actionItem.Weight = 1; newActionItemList.Add(actionItem); } createListInput.ActionItems = newActionItemList; //Sort #region << Sort >> createListInput.Sorts = new List<InputRecordListSort>(); { listSort = new InputRecordListSort(); listSort.FieldName = "created_on"; listSort.SortType = "ascending"; createListInput.Sorts.Add(listSort); } #endregion { var response = entMan.CreateRecordList(ATTACHMENT_ENTITY_ID, createListInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + ATTACHMENT_ENTITY_NAME + " Updated List: general" + " Message:" + response.Message); } } #endregion #region << List name: task_attachments >> { var createListEntity = entMan.ReadEntity(ATTACHMENT_ENTITY_ID).Object; var createListInput = new InputRecordList(); var listField = new InputRecordListFieldItem(); var listFieldFromRelation = new InputRecordListRelationFieldItem(); var listSort = new InputRecordListSort(); var listQuery = new InputRecordListQuery(); #region << details >> createListInput.Id = new Guid("6fc374ac-ba6b-4009-ade4-988304071f29"); createListInput.Type = "hidden"; createListInput.Name = "task_attachments"; createListInput.Label = "Attachments"; createListInput.Weight = 10; createListInput.Default = false; createListInput.System = true; createListInput.CssClass = null; createListInput.IconName = "paperclip"; createListInput.VisibleColumnsCount = 5; createListInput.ColumnWidthsCSV = "160px,160px,auto"; createListInput.PageSize = 10; createListInput.DynamicHtmlTemplate = null; createListInput.DataSourceUrl = null; createListInput.ServiceCode = null; #endregion #region << action items >> createListInput.ActionItems = new List<ActionItem>(); var actionItem = new ActionItem(); { actionItem = new ActionItem(); actionItem.Name = "wv_create_record"; actionItem.Menu = "page-title"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline hidden-xs"" ng-show=""::ngCtrl.userHasRecordPermissions('canCreate')"" ng-href=""{{ngCtrl.getRecordCreateUrl(ngCtrl)}}"">Add New</a>"; createListInput.ActionItems.Add(actionItem); } #endregion #region << Columns >> createListInput.Columns = new List<InputRecordListItemBase>(); #region << created_on >> { var fieldName = "created_on"; listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == fieldName).Id; listField.FieldName = fieldName; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion //Field from relation #region << user_wv_project_attachment_created_by > username >> { var relatedEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; var relation = relMan.Read("user_wv_project_attachment_created_by").Object; listFieldFromRelation = new InputRecordListRelationFieldItem(); listFieldFromRelation.EntityId = relatedEntity.Id; listFieldFromRelation.EntityName = relatedEntity.Name; listFieldFromRelation.FieldId = relatedEntity.Fields.Single(x => x.Name == "username").Id; listFieldFromRelation.FieldName = "username"; listFieldFromRelation.Type = "field"; listFieldFromRelation.RelationId = relation.Id; listFieldFromRelation.RelationName = relation.Name; createListInput.Columns.Add(listFieldFromRelation); } #endregion #region << file >> { var fieldName = "file"; listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == fieldName).Id; listField.FieldName = fieldName; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #endregion #region << relation options >> createListInput.RelationOptions = new List<EntityRelationOptionsItem>(); #endregion #region << Sort >> createListInput.Sorts = new List<InputRecordListSort>(); listSort = new InputRecordListSort(); listSort.FieldName = "created_on"; listSort.SortType = "ascending"; createListInput.Sorts.Add(listSort); #endregion { var response = entMan.CreateRecordList(ATTACHMENT_ENTITY_ID, createListInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + ATTACHMENT_ENTITY_NAME + " Updated List: task_attachment" + " Message:" + response.Message); } } #endregion #region << create create >> { var createViewEntity = entMan.ReadEntity(ATTACHMENT_ENTITY_ID).Object; var createViewInput = new InputRecordView(); var viewSection = new InputRecordViewSection(); var viewRow = new InputRecordViewRow(); var viewColumn = new InputRecordViewColumn(); var viewItem = new InputRecordViewFieldItem(); var viewItemFromRelation = new InputRecordViewRelationFieldItem(); //General view fields #region << Details >> createViewInput.Id = new Guid("4a049b10-ac21-4402-9984-3b0b8cf015be"); createViewInput.Name = "create"; createViewInput.Label = "Create"; createViewInput.Title = ""; createViewInput.Default = true; createViewInput.System = true; createViewInput.Type = "create"; createViewInput.Weight = 10; createViewInput.IconName = "file-text-o"; createViewInput.ServiceCode = null; createViewInput.DynamicHtmlTemplate = null; createViewInput.DataSourceUrl = null; #endregion #region << Get the header Region >> var headerRegion = new InputRecordViewRegion(); headerRegion.Name = "header"; headerRegion.Label = "header"; headerRegion.Sections = new List<InputRecordViewSection>(); #endregion #region << Section >> viewSection = new InputRecordViewSection(); viewSection.Id = new Guid("8ea140f9-b6fc-4b61-bc50-38b4e92f9eae"); viewSection.Name = "details"; viewSection.Label = "Details"; viewSection.ShowLabel = false; viewSection.CssClass = ""; viewSection.Collapsed = false; viewSection.TabOrder = "left-right"; viewSection.Weight = 1; viewSection.Rows = new List<InputRecordViewRow>(); #region << Row 1 >> viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("84482250-9a74-43d2-ae20-c883ee82a865"); viewRow.Weight = 1; viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = 12; viewColumn.Items = new List<InputRecordViewItemBase>(); #region << subject >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = createViewEntity.Id; viewItem.EntityName = createViewEntity.Name; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "file").Id; viewItem.FieldName = "file"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); #endregion //Save row viewSection.Rows.Add(viewRow); #endregion //Save section headerRegion.Sections.Add(viewSection); #endregion createViewInput.Regions = new List<InputRecordViewRegion>(); createViewInput.Regions.Add(headerRegion); #region << Sidebar >> var sidebarItem = new InputRecordViewSidebarItemBase(); createViewInput.Sidebar = new InputRecordViewSidebar(); createViewInput.Sidebar.CssClass = ""; createViewInput.Sidebar.Render = true; #endregion var newActionItemList = new List<ActionItem>(); { var actionItem = new ActionItem(); actionItem.Name = "wv_back_button"; actionItem.Menu = "sidebar-top"; actionItem.Template = "<a class=\"back clearfix\" href=\"javascript:void(0)\" ng-click=\"sidebarData.goBack()\"><i class=\"fa fa-fw fa-arrow-left\"></i> <span class=\"text\">Back</span></a>"; actionItem.Weight = 1; newActionItemList.Add(actionItem); } { var actionItem = new ActionItem(); actionItem.Name = "wv_create_and_list"; actionItem.Menu = "create-bottom"; actionItem.Template = "<a class=\"btn btn-primary\" ng-click='ngCtrl.create(\"default\")' ng-if=\"::ngCtrl.createViewRegion != null\">Create</a>"; actionItem.Weight = 1; newActionItemList.Add(actionItem); } { var actionItem = new ActionItem(); actionItem.Name = "wv_create_and_details"; actionItem.Menu = "create-bottom"; actionItem.Template = "<a class=\"btn btn-default btn-outline\" ng-click='ngCtrl.create(\"details\")' ng-if=\"::ngCtrl.createViewRegion != null\">Create & Details</a>"; actionItem.Weight = 2; newActionItemList.Add(actionItem); } { var actionItem = new ActionItem(); actionItem.Name = "wv_create_cancel"; actionItem.Menu = "create-bottom"; actionItem.Template = "<a class=\"btn btn-default btn-outline\" ng-click=\"ngCtrl.cancel()\">Cancel</a>"; actionItem.Weight = 3; newActionItemList.Add(actionItem); } createViewInput.ActionItems = newActionItemList; { var response = entMan.CreateRecordView(ATTACHMENT_ENTITY_ID, createViewInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + ATTACHMENT_ENTITY_NAME + " Updated view: create" + " Message:" + response.Message); } } #endregion } #endregion #region << wv_project_activity >> { #region << entity >> { InputEntity entity = new InputEntity(); entity.Id = ACTIVITY_ENTITY_ID; entity.Name = ACTIVITY_ENTITY_NAME; entity.Label = "Activity"; entity.LabelPlural = "Activities"; entity.System = true; entity.IconName = "comments-o"; entity.Weight = 7; entity.RecordPermissions = new RecordPermissions(); entity.RecordPermissions.CanCreate = new List<Guid>(); entity.RecordPermissions.CanRead = new List<Guid>(); entity.RecordPermissions.CanUpdate = new List<Guid>(); entity.RecordPermissions.CanDelete = new List<Guid>(); //Create entity.RecordPermissions.CanCreate.Add(SystemIds.AdministratorRoleId); entity.RecordPermissions.CanCreate.Add(SystemIds.RegularRoleId); //READ entity.RecordPermissions.CanRead.Add(SystemIds.AdministratorRoleId); entity.RecordPermissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE entity.RecordPermissions.CanUpdate.Add(SystemIds.AdministratorRoleId); entity.RecordPermissions.CanUpdate.Add(SystemIds.RegularRoleId); //System fields and relations Ids should be hardcoded for the compare/change code generation to work later on correctly var systemItemIdDictionary = new Dictionary<string, Guid>(); systemItemIdDictionary["id"] = new Guid("0aac0f03-4153-47ed-b3a5-95371f46bb1e"); systemItemIdDictionary["created_on"] = new Guid("f4d890fd-c3ed-4ea6-9b91-4bd55fe688c7"); systemItemIdDictionary["created_by"] = new Guid("1605ec95-ffec-4c66-ba6e-b1e457936306"); systemItemIdDictionary["last_modified_on"] = new Guid("540dfdfb-02aa-47d8-8312-0a887ab092e3"); systemItemIdDictionary["last_modified_by"] = new Guid("80e7f499-cddd-4498-946a-e3972ee98a15"); systemItemIdDictionary["user_wv_project_activity_created_by"] = new Guid("2fd1e3a2-feea-4b2b-a609-d3a5d6694cbb"); systemItemIdDictionary["user_wv_project_activity_modified_by"] = new Guid("bc6314f8-fdf1-4b24-b5f5-574b04f45366"); { var response = entMan.CreateEntity(entity, false, false, systemItemIdDictionary); if (!response.Success) throw new Exception("System error 10050. Entity: " + ACTIVITY_ENTITY_NAME + " Field: entity creation" + " Message:" + response.Message); } } #endregion #region << label >> { InputSelectField dropdownField = new InputSelectField(); dropdownField.Id = new Guid("fe4ee5da-8c32-4ecd-8773-04752b413cb0"); dropdownField.Name = "label"; dropdownField.Label = "Label"; dropdownField.PlaceholderText = ""; dropdownField.Description = ""; dropdownField.HelpText = ""; dropdownField.Required = false; dropdownField.Unique = false; dropdownField.Searchable = false; dropdownField.Auditable = false; dropdownField.System = true; dropdownField.DefaultValue = "added"; dropdownField.Options = new List<SelectFieldOption> { new SelectFieldOption(){ Key = "added", Value = "added" }, new SelectFieldOption(){ Key = "created", Value = "created" }, new SelectFieldOption(){ Key = "updated", Value = "updated" }, new SelectFieldOption(){ Key = "deleted", Value = "deleted" }, new SelectFieldOption(){ Key = "timelog", Value = "timelog" }, new SelectFieldOption(){ Key = "commented", Value = "commented" } }; dropdownField.EnableSecurity = true; dropdownField.Permissions = new FieldPermissions(); dropdownField.Permissions.CanRead = new List<Guid>(); dropdownField.Permissions.CanUpdate = new List<Guid>(); //READ dropdownField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); dropdownField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE dropdownField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); dropdownField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(ACTIVITY_ENTITY_ID, dropdownField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + ACTIVITY_ENTITY_NAME + " Field: label" + " Message:" + response.Message); } } #endregion #region << subject >> { InputTextField textboxField = new InputTextField(); textboxField.Id = new Guid("8f8b4cb9-aaed-4183-b863-b14faa2496ea"); textboxField.Name = "subject"; textboxField.Label = "Subject"; textboxField.PlaceholderText = ""; textboxField.Description = ""; textboxField.HelpText = ""; textboxField.Required = true; textboxField.Unique = false; textboxField.Searchable = false; textboxField.Auditable = false; textboxField.System = true; textboxField.DefaultValue = string.Empty; textboxField.MaxLength = null; textboxField.EnableSecurity = true; textboxField.Permissions = new FieldPermissions(); textboxField.Permissions.CanRead = new List<Guid>(); textboxField.Permissions.CanUpdate = new List<Guid>(); //READ textboxField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); textboxField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE textboxField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); textboxField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(ACTIVITY_ENTITY_ID, textboxField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + ACTIVITY_ENTITY_NAME + " Field: subject" + " Message:" + response.Message); } } #endregion #region << description >> { InputMultiLineTextField textareaField = new InputMultiLineTextField(); textareaField.Id = new Guid("6f29022e-c323-42fa-a4cb-76518787ba07"); textareaField.Name = "description"; textareaField.Label = "Description"; textareaField.PlaceholderText = ""; textareaField.Description = ""; textareaField.HelpText = ""; textareaField.Required = false; textareaField.Unique = false; textareaField.Searchable = false; textareaField.Auditable = false; textareaField.System = true; textareaField.DefaultValue = string.Empty; textareaField.VisibleLineNumber = 4; textareaField.EnableSecurity = true; textareaField.Permissions = new FieldPermissions(); textareaField.Permissions.CanRead = new List<Guid>(); textareaField.Permissions.CanUpdate = new List<Guid>(); textareaField.Permissions.CanRead.Add(SystemIds.RegularRoleId); textareaField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(ACTIVITY_ENTITY_ID, textareaField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + ACTIVITY_ENTITY_NAME + " Field: description" + " Message:" + response.Message); } } #endregion #region << project_id >> { InputGuidField guidField = new InputGuidField(); guidField.Id = new Guid("c67b14eb-e23c-43d1-8fd2-869618390b16"); guidField.Name = "project_id"; guidField.Label = "Parent Project"; guidField.PlaceholderText = ""; guidField.Description = ""; guidField.HelpText = ""; guidField.Required = true; guidField.Unique = false; guidField.Searchable = false; guidField.Auditable = false; guidField.System = true; guidField.DefaultValue = Guid.Empty; guidField.GenerateNewId = false; guidField.EnableSecurity = true; guidField.Permissions = new FieldPermissions(); guidField.Permissions.CanRead = new List<Guid>(); guidField.Permissions.CanUpdate = new List<Guid>(); //READ guidField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE guidField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(ACTIVITY_ENTITY_ID, guidField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + ACTIVITY_ENTITY_NAME + " Field: project_id" + " Message:" + response.Message); } } #endregion #region << task_id >> { InputGuidField guidField = new InputGuidField(); guidField.Id = new Guid("2f919a7c-0167-44bb-a6dc-5a942cc98442"); guidField.Name = "task_id"; guidField.Label = "Parent task"; guidField.PlaceholderText = ""; guidField.Description = ""; guidField.HelpText = ""; guidField.Required = false; guidField.Unique = false; guidField.Searchable = false; guidField.Auditable = false; guidField.System = true; guidField.DefaultValue = Guid.Empty; guidField.GenerateNewId = false; guidField.EnableSecurity = true; guidField.Permissions = new FieldPermissions(); guidField.Permissions.CanRead = new List<Guid>(); guidField.Permissions.CanUpdate = new List<Guid>(); //READ guidField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE guidField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(ACTIVITY_ENTITY_ID, guidField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + ACTIVITY_ENTITY_NAME + " Field: task_id" + " Message:" + response.Message); } } #endregion #region << bug_id >> { InputGuidField guidField = new InputGuidField(); guidField.Id = new Guid("a490f567-a404-4300-be98-e8dde9d3a47e"); guidField.Name = "bug_id"; guidField.Label = "Parent bug"; guidField.PlaceholderText = ""; guidField.Description = ""; guidField.HelpText = ""; guidField.Required = false; guidField.Unique = false; guidField.Searchable = false; guidField.Auditable = false; guidField.System = true; guidField.DefaultValue = Guid.Empty; guidField.GenerateNewId = false; guidField.EnableSecurity = true; guidField.Permissions = new FieldPermissions(); guidField.Permissions.CanRead = new List<Guid>(); guidField.Permissions.CanUpdate = new List<Guid>(); //READ guidField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE guidField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(ACTIVITY_ENTITY_ID, guidField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + ACTIVITY_ENTITY_NAME + " Field: bug_id" + " Message:" + response.Message); } } #endregion #region << project_1_n_activity Relation >> { var originEntity = entMan.ReadEntity(PROJECT_ENTITY_ID).Object; var targetEntity = entMan.ReadEntity(ACTIVITY_ENTITY_ID).Object; EntityRelation oneToNRelation = new EntityRelation(); oneToNRelation.Id = new Guid("f0894d81-1924-48a8-b8ee-213c90a5f524"); oneToNRelation.Name = "project_1_n_activity"; oneToNRelation.Label = "project_1_n_activity"; oneToNRelation.System = true; oneToNRelation.RelationType = EntityRelationType.OneToMany; oneToNRelation.OriginEntityId = originEntity.Id; oneToNRelation.OriginFieldId = originEntity.Fields.Single(x => x.Name == "id").Id; oneToNRelation.TargetEntityId = targetEntity.Id; oneToNRelation.TargetFieldId = targetEntity.Fields.Single(x => x.Name == "project_id").Id; { var result = relMan.Create(oneToNRelation); if (!result.Success) throw new Exception("CREATE project_1_n_activity RELATION:" + result.Message); } } #endregion #region << task_1_n_activity Relation >> { var originEntity = entMan.ReadEntity(TASK_ENTITY_ID).Object; var targetEntity = entMan.ReadEntity(ACTIVITY_ENTITY_ID).Object; EntityRelation oneToNRelation = new EntityRelation(); oneToNRelation.Id = new Guid("8f294277-fd60-496e-bff7-9391fffcda41"); oneToNRelation.Name = "task_1_n_activity"; oneToNRelation.Label = "task_1_n_activity"; oneToNRelation.System = true; oneToNRelation.RelationType = EntityRelationType.OneToMany; oneToNRelation.OriginEntityId = originEntity.Id; oneToNRelation.OriginFieldId = originEntity.Fields.Single(x => x.Name == "id").Id; oneToNRelation.TargetEntityId = targetEntity.Id; oneToNRelation.TargetFieldId = targetEntity.Fields.Single(x => x.Name == "task_id").Id; { var result = relMan.Create(oneToNRelation); if (!result.Success) throw new Exception("CREATE task_1_n_activity RELATION:" + result.Message); } } #endregion #region << bug_1_n_activity Relation >> { var originEntity = entMan.ReadEntity(BUG_ENTITY_ID).Object; var targetEntity = entMan.ReadEntity(ACTIVITY_ENTITY_ID).Object; EntityRelation oneToNRelation = new EntityRelation(); oneToNRelation.Id = new Guid("b96189f7-a880-4da4-b9a9-2274a9745d2d"); oneToNRelation.Name = "bug_1_n_activity"; oneToNRelation.Label = "bug_1_n_activity"; oneToNRelation.System = true; oneToNRelation.RelationType = EntityRelationType.OneToMany; oneToNRelation.OriginEntityId = originEntity.Id; oneToNRelation.OriginFieldId = originEntity.Fields.Single(x => x.Name == "id").Id; oneToNRelation.TargetEntityId = targetEntity.Id; oneToNRelation.TargetFieldId = targetEntity.Fields.Single(x => x.Name == "bug_id").Id; { var result = relMan.Create(oneToNRelation); if (!result.Success) throw new Exception("CREATE bug_1_n_activity RELATION:" + result.Message); } } #endregion #region << List name: task_activities >> { var createListEntity = entMan.ReadEntity(ACTIVITY_ENTITY_ID).Object; var createListInput = new InputRecordList(); var listField = new InputRecordListFieldItem(); var listFieldFromRelation = new InputRecordListRelationFieldItem(); var listSort = new InputRecordListSort(); var listQuery = new InputRecordListQuery(); #region << details >> createListInput.Id = new Guid("121ce540-7838-4459-8357-d0d0ad2b65a4"); createListInput.Type = "hidden"; createListInput.Name = "task_activities"; createListInput.Label = "Activities"; createListInput.Weight = 30; createListInput.Default = false; createListInput.System = true; createListInput.CssClass = null; createListInput.IconName = "history"; createListInput.VisibleColumnsCount = 5; createListInput.ColumnWidthsCSV = null; createListInput.PageSize = 10; createListInput.DynamicHtmlTemplate = null; createListInput.DataSourceUrl = null; createListInput.ServiceCode = null; #endregion #region << action items >> createListInput.ActionItems = new List<ActionItem>(); #endregion #region << Columns >> createListInput.Columns = new List<InputRecordListItemBase>(); #region << created_on >> { var fieldName = "created_on"; listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == fieldName).Id; listField.FieldName = fieldName; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << user_wv_project_activity_created_by > username >> { var relatedEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; var relation = relMan.Read("user_wv_project_activity_created_by").Object; listFieldFromRelation = new InputRecordListRelationFieldItem(); listFieldFromRelation.EntityId = relatedEntity.Id; listFieldFromRelation.EntityName = relatedEntity.Name; listFieldFromRelation.FieldId = relatedEntity.Fields.Single(x => x.Name == "username").Id; listFieldFromRelation.FieldName = "username"; listFieldFromRelation.Type = "field"; listFieldFromRelation.RelationId = relation.Id; listFieldFromRelation.RelationName = relation.Name; createListInput.Columns.Add(listFieldFromRelation); } #endregion #region << subject >> { var fieldName = "subject"; listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == fieldName).Id; listField.FieldName = fieldName; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << label >> { var fieldName = "label"; listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == fieldName).Id; listField.FieldName = fieldName; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << user_wv_project_activity_created_by > image >> { var relatedEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; var relation = relMan.Read("user_wv_project_activity_created_by").Object; listFieldFromRelation = new InputRecordListRelationFieldItem(); listFieldFromRelation.EntityId = relatedEntity.Id; listFieldFromRelation.EntityName = relatedEntity.Name; listFieldFromRelation.FieldId = relatedEntity.Fields.Single(x => x.Name == "image").Id; listFieldFromRelation.FieldName = "image"; listFieldFromRelation.Type = "field"; listFieldFromRelation.RelationId = relation.Id; listFieldFromRelation.RelationName = relation.Name; createListInput.Columns.Add(listFieldFromRelation); } #endregion #region << created_by >> { var fieldName = "created_by"; listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == fieldName).Id; listField.FieldName = fieldName; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #endregion #region << relation options >> createListInput.RelationOptions = new List<EntityRelationOptionsItem>(); #endregion #region << Sort >> createListInput.Sorts = new List<InputRecordListSort>(); listSort = new InputRecordListSort(); listSort.FieldName = "created_on"; listSort.SortType = "ascending"; createListInput.Sorts.Add(listSort); #endregion { var response = entMan.CreateRecordList(ACTIVITY_ENTITY_ID, createListInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + ACTIVITY_ENTITY_NAME + " Updated List: task_activities" + " Message:" + response.Message); } } #endregion #region << List name: bug_activities >> { var createListEntity = entMan.ReadEntity(ACTIVITY_ENTITY_ID).Object; var createListInput = new InputRecordList(); var listField = new InputRecordListFieldItem(); var listFieldFromRelation = new InputRecordListRelationFieldItem(); var listSort = new InputRecordListSort(); var listQuery = new InputRecordListQuery(); #region << details >> createListInput.Id = new Guid("57c3062c-df6e-488a-a432-dd927b0dd013"); createListInput.Type = "hidden"; createListInput.Name = "bug_activities"; createListInput.Label = "Activities"; createListInput.Weight = 30; createListInput.Default = false; createListInput.System = true; createListInput.CssClass = null; createListInput.IconName = "history"; createListInput.VisibleColumnsCount = 5; createListInput.ColumnWidthsCSV = null; createListInput.PageSize = 10; createListInput.DynamicHtmlTemplate = null; createListInput.DataSourceUrl = null; createListInput.ServiceCode = null; #endregion #region << action items >> createListInput.ActionItems = new List<ActionItem>(); #endregion #region << Columns >> createListInput.Columns = new List<InputRecordListItemBase>(); #region << created_on >> { var fieldName = "created_on"; listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == fieldName).Id; listField.FieldName = fieldName; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << user_wv_project_activity_created_by > username >> { var relatedEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; var relation = relMan.Read("user_wv_project_activity_created_by").Object; listFieldFromRelation = new InputRecordListRelationFieldItem(); listFieldFromRelation.EntityId = relatedEntity.Id; listFieldFromRelation.EntityName = relatedEntity.Name; listFieldFromRelation.FieldId = relatedEntity.Fields.Single(x => x.Name == "username").Id; listFieldFromRelation.FieldName = "username"; listFieldFromRelation.Type = "field"; listFieldFromRelation.RelationId = relation.Id; listFieldFromRelation.RelationName = relation.Name; createListInput.Columns.Add(listFieldFromRelation); } #endregion #region << subject >> { var fieldName = "subject"; listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == fieldName).Id; listField.FieldName = fieldName; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << label >> { var fieldName = "label"; listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == fieldName).Id; listField.FieldName = fieldName; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << user_wv_project_activity_created_by > image >> { var relatedEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; var relation = relMan.Read("user_wv_project_activity_created_by").Object; listFieldFromRelation = new InputRecordListRelationFieldItem(); listFieldFromRelation.EntityId = relatedEntity.Id; listFieldFromRelation.EntityName = relatedEntity.Name; listFieldFromRelation.FieldId = relatedEntity.Fields.Single(x => x.Name == "image").Id; listFieldFromRelation.FieldName = "image"; listFieldFromRelation.Type = "field"; listFieldFromRelation.RelationId = relation.Id; listFieldFromRelation.RelationName = relation.Name; createListInput.Columns.Add(listFieldFromRelation); } #endregion #region << created_by >> { var fieldName = "created_by"; listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == fieldName).Id; listField.FieldName = fieldName; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #endregion #region << relation options >> createListInput.RelationOptions = new List<EntityRelationOptionsItem>(); #endregion #region << Sort >> createListInput.Sorts = new List<InputRecordListSort>(); listSort = new InputRecordListSort(); listSort.FieldName = "created_on"; listSort.SortType = "ascending"; createListInput.Sorts.Add(listSort); #endregion { var response = entMan.CreateRecordList(ACTIVITY_ENTITY_ID, createListInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + ACTIVITY_ENTITY_NAME + " Updated List: task_activities" + " Message:" + response.Message); } } #endregion } #endregion #region << wv_project_comment >> { #region << entity >> { InputEntity entity = new InputEntity(); entity.Id = COMMENT_ENTITY_ID; entity.Name = COMMENT_ENTITY_NAME; entity.Label = "Comment"; entity.LabelPlural = "Comments"; entity.System = true; entity.IconName = "comment-o"; entity.Weight = 17; entity.RecordPermissions = new RecordPermissions(); entity.RecordPermissions.CanCreate = new List<Guid>(); entity.RecordPermissions.CanRead = new List<Guid>(); entity.RecordPermissions.CanUpdate = new List<Guid>(); entity.RecordPermissions.CanDelete = new List<Guid>(); //Create entity.RecordPermissions.CanCreate.Add(SystemIds.AdministratorRoleId); entity.RecordPermissions.CanCreate.Add(SystemIds.RegularRoleId); //READ entity.RecordPermissions.CanRead.Add(SystemIds.AdministratorRoleId); entity.RecordPermissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE entity.RecordPermissions.CanUpdate.Add(SystemIds.AdministratorRoleId); entity.RecordPermissions.CanUpdate.Add(SystemIds.RegularRoleId); //System fields and relations Ids should be hardcoded for the compare/change code generation to work later on correctly var systemItemIdDictionary = new Dictionary<string, Guid>(); systemItemIdDictionary["id"] = new Guid("4b10e607-b681-4650-a189-aab7c590aa62"); systemItemIdDictionary["created_on"] = new Guid("c205c60f-598a-4db7-bd41-a7fd2ae3abd0"); systemItemIdDictionary["created_by"] = new Guid("46208807-7bc8-4f54-8618-45134189e763"); systemItemIdDictionary["last_modified_on"] = new Guid("5be05bc8-f6ec-4e6d-82d4-4ea3c48cc60e"); systemItemIdDictionary["last_modified_by"] = new Guid("32e2a310-6613-4571-9fec-e592e1c4f333"); systemItemIdDictionary["user_wv_project_comment_created_by"] = new Guid("2f3635a3-298e-475e-90f4-7d512da6cf95"); systemItemIdDictionary["user_wv_project_comment_modified_by"] = new Guid("98ae433b-8b2e-49c5-b10e-8615d92dfab5"); { var response = entMan.CreateEntity(entity, false, false, systemItemIdDictionary); if (!response.Success) throw new Exception("System error 10050. Entity: " + COMMENT_ENTITY_NAME + " Field: entity creation" + " Message:" + response.Message); } } #endregion #region << content >> { InputHtmlField htmlField = new InputHtmlField(); htmlField.Id = new Guid("23afb07b-438f-4e31-9372-c850a5789cc6"); htmlField.Name = "content"; htmlField.Label = "Content"; htmlField.PlaceholderText = ""; htmlField.Description = ""; htmlField.HelpText = ""; htmlField.Required = true; htmlField.Unique = false; htmlField.Searchable = false; htmlField.Auditable = false; htmlField.System = true; htmlField.DefaultValue = string.Empty; htmlField.EnableSecurity = true; htmlField.Permissions = new FieldPermissions(); htmlField.Permissions.CanRead = new List<Guid>(); htmlField.Permissions.CanUpdate = new List<Guid>(); htmlField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); htmlField.Permissions.CanRead.Add(SystemIds.RegularRoleId); htmlField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); htmlField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(COMMENT_ENTITY_ID, htmlField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + COMMENT_ENTITY_ID + " Field: field_name" + " Message:" + response.Message); } } #endregion #region << task_id >> { InputGuidField guidField = new InputGuidField(); guidField.Id = new Guid("40068814-738f-4725-8aef-4722bc37ee7d"); guidField.Name = "task_id"; guidField.Label = "Parent task"; guidField.PlaceholderText = ""; guidField.Description = ""; guidField.HelpText = ""; guidField.Required = false; guidField.Unique = false; guidField.Searchable = false; guidField.Auditable = false; guidField.System = true; guidField.DefaultValue = Guid.Empty; guidField.GenerateNewId = false; guidField.EnableSecurity = true; guidField.Permissions = new FieldPermissions(); guidField.Permissions.CanRead = new List<Guid>(); guidField.Permissions.CanUpdate = new List<Guid>(); //READ guidField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE guidField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(COMMENT_ENTITY_ID, guidField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + COMMENT_ENTITY_NAME + " Field: task_id" + " Message:" + response.Message); } } #endregion #region << bug_id >> { InputGuidField guidField = new InputGuidField(); guidField.Id = new Guid("6ac276d0-bb0c-4f8f-b30d-ea373cb64b73"); guidField.Name = "bug_id"; guidField.Label = "Parent bug"; guidField.PlaceholderText = ""; guidField.Description = ""; guidField.HelpText = ""; guidField.Required = false; guidField.Unique = false; guidField.Searchable = false; guidField.Auditable = false; guidField.System = true; guidField.DefaultValue = Guid.Empty; guidField.GenerateNewId = false; guidField.EnableSecurity = true; guidField.Permissions = new FieldPermissions(); guidField.Permissions.CanRead = new List<Guid>(); guidField.Permissions.CanUpdate = new List<Guid>(); //READ guidField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE guidField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); guidField.Permissions.CanUpdate.Add(SystemIds.RegularRoleId); { var response = entMan.CreateField(COMMENT_ENTITY_ID, guidField, false); if (!response.Success) throw new Exception("System error 10060. Entity: " + COMMENT_ENTITY_NAME + " Field: bug_id" + " Message:" + response.Message); } } #endregion #region << task_1_n_comment Relation >> { var originEntity = entMan.ReadEntity(TASK_ENTITY_ID).Object; var targetEntity = entMan.ReadEntity(COMMENT_ENTITY_ID).Object; EntityRelation oneToNRelation = new EntityRelation(); oneToNRelation.Id = new Guid("884b9480-dc1c-468a-98f0-2d5f10084622"); oneToNRelation.Name = "task_1_n_comment"; oneToNRelation.Label = "task_1_n_comment"; oneToNRelation.System = true; oneToNRelation.RelationType = EntityRelationType.OneToMany; oneToNRelation.OriginEntityId = originEntity.Id; oneToNRelation.OriginFieldId = originEntity.Fields.Single(x => x.Name == "id").Id; oneToNRelation.TargetEntityId = targetEntity.Id; oneToNRelation.TargetFieldId = targetEntity.Fields.Single(x => x.Name == "task_id").Id; { var result = relMan.Create(oneToNRelation); if (!result.Success) throw new Exception("CREATE task_1_n_comment RELATION:" + result.Message); } } #endregion #region << bug_1_n_comment Relation >> { var originEntity = entMan.ReadEntity(BUG_ENTITY_ID).Object; var targetEntity = entMan.ReadEntity(COMMENT_ENTITY_ID).Object; EntityRelation oneToNRelation = new EntityRelation(); oneToNRelation.Id = new Guid("5af026bd-d046-42ba-b6a0-e9090727348f"); oneToNRelation.Name = "bug_1_n_comment"; oneToNRelation.Label = "bug_1_n_comment"; oneToNRelation.System = true; oneToNRelation.RelationType = EntityRelationType.OneToMany; oneToNRelation.OriginEntityId = originEntity.Id; oneToNRelation.OriginFieldId = originEntity.Fields.Single(x => x.Name == "id").Id; oneToNRelation.TargetEntityId = targetEntity.Id; oneToNRelation.TargetFieldId = targetEntity.Fields.Single(x => x.Name == "bug_id").Id; { var result = relMan.Create(oneToNRelation); if (!result.Success) throw new Exception("CREATE bug_1_n_comment RELATION:" + result.Message); } } #endregion #region << List name: task_comments >> { var createListEntity = entMan.ReadEntity(COMMENT_ENTITY_ID).Object; var createListInput = new InputRecordList(); var listField = new InputRecordListFieldItem(); var listFieldFromRelation = new InputRecordListRelationFieldItem(); var listSort = new InputRecordListSort(); var listQuery = new InputRecordListQuery(); #region << details >> createListInput.Id = new Guid("b8a7a81d-9176-47e6-90c5-3cabc2a4ceff"); createListInput.Type = "hidden"; createListInput.Name = "task_comments"; createListInput.Label = "Comments"; createListInput.Weight = 10; createListInput.Default = false; createListInput.System = true; createListInput.CssClass = null; createListInput.IconName = "comments-o"; createListInput.VisibleColumnsCount = 5; createListInput.ColumnWidthsCSV = null; createListInput.PageSize = 0; createListInput.DynamicHtmlTemplate = @"/plugins/webvella-projects/templates/task-comments.html"; createListInput.DataSourceUrl = null; createListInput.ServiceCode = @"/plugins/webvella-projects/providers/task-comments.service.js"; #endregion #region << action items >> createListInput.ActionItems = new List<ActionItem>(); var actionItem = new ActionItem(); { actionItem = new ActionItem(); actionItem.Name = "wv_create_record"; actionItem.Menu = "page-title"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline hidden-xs"" ng-show=""::ngCtrl.userHasRecordPermissions('canCreate')"" ng-click=""ngCtrl.actionService.manageComment(null,ngCtrl)"">Add Comment</a>"; createListInput.ActionItems.Add(actionItem); } #endregion #region << Columns >> createListInput.Columns = new List<InputRecordListItemBase>(); #region << created_on >> { var fieldName = "created_on"; listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == fieldName).Id; listField.FieldName = fieldName; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << user_wv_project_comment_created_by > username >> { var relatedEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; var relation = relMan.Read("user_wv_project_comment_created_by").Object; listFieldFromRelation = new InputRecordListRelationFieldItem(); listFieldFromRelation.EntityId = relatedEntity.Id; listFieldFromRelation.EntityName = relatedEntity.Name; listFieldFromRelation.FieldId = relatedEntity.Fields.Single(x => x.Name == "username").Id; listFieldFromRelation.FieldName = "username"; listFieldFromRelation.Type = "field"; listFieldFromRelation.RelationId = relation.Id; listFieldFromRelation.RelationName = relation.Name; createListInput.Columns.Add(listFieldFromRelation); } #endregion #region << file >> { var fieldName = "content"; listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == fieldName).Id; listField.FieldName = fieldName; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << user_wv_project_comment_created_by > image >> { var relatedEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; var relation = relMan.Read("user_wv_project_comment_created_by").Object; listFieldFromRelation = new InputRecordListRelationFieldItem(); listFieldFromRelation.EntityId = relatedEntity.Id; listFieldFromRelation.EntityName = relatedEntity.Name; listFieldFromRelation.FieldId = relatedEntity.Fields.Single(x => x.Name == "image").Id; listFieldFromRelation.FieldName = "image"; listFieldFromRelation.Type = "field"; listFieldFromRelation.RelationId = relation.Id; listFieldFromRelation.RelationName = relation.Name; createListInput.Columns.Add(listFieldFromRelation); } #endregion #region << created_by >> { var fieldName = "created_by"; listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == fieldName).Id; listField.FieldName = fieldName; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #endregion #region << relation options >> createListInput.RelationOptions = new List<EntityRelationOptionsItem>(); #endregion #region << Sort >> createListInput.Sorts = new List<InputRecordListSort>(); listSort = new InputRecordListSort(); listSort.FieldName = "created_on"; listSort.SortType = "ascending"; createListInput.Sorts.Add(listSort); #endregion { var response = entMan.CreateRecordList(COMMENT_ENTITY_ID, createListInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + COMMENT_ENTITY_NAME + " Updated List: task_comments" + " Message:" + response.Message); } } #endregion #region << List name: bug_comments >> { var createListEntity = entMan.ReadEntity(COMMENT_ENTITY_ID).Object; var createListInput = new InputRecordList(); var listField = new InputRecordListFieldItem(); var listFieldFromRelation = new InputRecordListRelationFieldItem(); var listSort = new InputRecordListSort(); var listQuery = new InputRecordListQuery(); #region << details >> createListInput.Id = new Guid("b143b82f-b79f-47c1-87e7-ecba6f6f2a32"); createListInput.Type = "hidden"; createListInput.Name = "bug_comments"; createListInput.Label = "Comments"; createListInput.Weight = 10; createListInput.Default = false; createListInput.System = true; createListInput.CssClass = null; createListInput.IconName = "comments-o"; createListInput.VisibleColumnsCount = 5; createListInput.ColumnWidthsCSV = null; createListInput.PageSize = 0; createListInput.DynamicHtmlTemplate = @"/plugins/webvella-projects/templates/bug-comments.html"; createListInput.DataSourceUrl = null; createListInput.ServiceCode = @"/plugins/webvella-projects/providers/bug-comments.service.js"; #endregion #region << action items >> createListInput.ActionItems = new List<ActionItem>(); var actionItem = new ActionItem(); { actionItem = new ActionItem(); actionItem.Name = "wv_create_record"; actionItem.Menu = "page-title"; actionItem.Weight = 1; actionItem.Template = "" + @"<a class=""btn btn-default btn-outline hidden-xs"" ng-show=""::ngCtrl.userHasRecordPermissions('canCreate')"" ng-click=""ngCtrl.actionService.manageComment(null,ngCtrl)"">Add Comment</a>"; createListInput.ActionItems.Add(actionItem); } #endregion #region << Columns >> createListInput.Columns = new List<InputRecordListItemBase>(); #region << created_on >> { var fieldName = "created_on"; listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == fieldName).Id; listField.FieldName = fieldName; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << user_wv_project_comment_created_by > username >> { var relatedEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; var relation = relMan.Read("user_wv_project_comment_created_by").Object; listFieldFromRelation = new InputRecordListRelationFieldItem(); listFieldFromRelation.EntityId = relatedEntity.Id; listFieldFromRelation.EntityName = relatedEntity.Name; listFieldFromRelation.FieldId = relatedEntity.Fields.Single(x => x.Name == "username").Id; listFieldFromRelation.FieldName = "username"; listFieldFromRelation.Type = "field"; listFieldFromRelation.RelationId = relation.Id; listFieldFromRelation.RelationName = relation.Name; createListInput.Columns.Add(listFieldFromRelation); } #endregion #region << file >> { var fieldName = "content"; listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == fieldName).Id; listField.FieldName = fieldName; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #region << user_wv_project_comment_created_by > image >> { var relatedEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; var relation = relMan.Read("user_wv_project_comment_created_by").Object; listFieldFromRelation = new InputRecordListRelationFieldItem(); listFieldFromRelation.EntityId = relatedEntity.Id; listFieldFromRelation.EntityName = relatedEntity.Name; listFieldFromRelation.FieldId = relatedEntity.Fields.Single(x => x.Name == "image").Id; listFieldFromRelation.FieldName = "image"; listFieldFromRelation.Type = "field"; listFieldFromRelation.RelationId = relation.Id; listFieldFromRelation.RelationName = relation.Name; createListInput.Columns.Add(listFieldFromRelation); } #endregion #region << created_by >> { var fieldName = "created_by"; listField = new InputRecordListFieldItem(); listField.EntityId = createListEntity.Id; listField.EntityName = createListEntity.Name; listField.FieldId = createListEntity.Fields.Single(x => x.Name == fieldName).Id; listField.FieldName = fieldName; listField.Type = "field"; createListInput.Columns.Add(listField); } #endregion #endregion #region << relation options >> createListInput.RelationOptions = new List<EntityRelationOptionsItem>(); #endregion #region << Sort >> createListInput.Sorts = new List<InputRecordListSort>(); listSort = new InputRecordListSort(); listSort.FieldName = "created_on"; listSort.SortType = "ascending"; createListInput.Sorts.Add(listSort); #endregion { var response = entMan.CreateRecordList(COMMENT_ENTITY_ID, createListInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + COMMENT_ENTITY_NAME + " Updated List: task_comments" + " Message:" + response.Message); } } #endregion } #endregion #region << create project general view >> { var createViewEntity = entMan.ReadEntity(PROJECT_ENTITY_ID).Object; var createViewInput = new InputRecordView(); var viewSection = new InputRecordViewSection(); var viewRow = new InputRecordViewRow(); var viewColumn = new InputRecordViewColumn(); var viewItem = new InputRecordViewFieldItem(); var viewItemFromRelation = new InputRecordViewRelationFieldItem(); //General view fields #region << Details >> createViewInput.Id = new Guid("211f028b-4e8e-418f-9c0e-78109f0839fc"); createViewInput.Type = "hidden"; createViewInput.Label = "{name}"; createViewInput.Title = ""; createViewInput.Weight = 10; createViewInput.CssClass = ""; createViewInput.IconName = "file-text-o"; createViewInput.Name = "general"; createViewInput.Default = true; createViewInput.System = true; #endregion #region << Get the header Region >> var headerRegion = new InputRecordViewRegion(); headerRegion.Name = "header"; headerRegion.Label = "header"; headerRegion.Sections = new List<InputRecordViewSection>(); #endregion #region << Section >> viewSection = new InputRecordViewSection(); viewSection.Id = new Guid("7848deef-6176-45ec-a12c-bb760793e9ef"); viewSection.Name = "details"; viewSection.Label = "Details"; viewSection.ShowLabel = false; viewSection.CssClass = ""; viewSection.Collapsed = false; viewSection.TabOrder = "left-right"; viewSection.Weight = 1; viewSection.Rows = new List<InputRecordViewRow>(); #region << Row 1 Column>> viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("3a099857-dd26-4723-b0ee-f62ae47d7d93"); viewRow.Weight = 1; viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = 12; viewColumn.Items = new List<InputRecordViewItemBase>(); #region << name >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = PROJECT_ENTITY_ID; viewItem.EntityName = PROJECT_ENTITY_NAME; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "name").Id; viewItem.FieldName = "name"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << description >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = PROJECT_ENTITY_ID; viewItem.EntityName = PROJECT_ENTITY_NAME; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "description").Id; viewItem.FieldName = "description"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); #endregion //Save row viewSection.Rows.Add(viewRow); #endregion #region << Row 2 Columns>> viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("b57588f0-9ca2-40b8-b516-3dd6d9efa0b5"); viewRow.Weight = 1; viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column Left >> viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = 6; viewColumn.Items = new List<InputRecordViewItemBase>(); #region << $user_1_n_project_owner > username >> { var targetEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = targetEntity.Id; viewItemFromRelation.EntityName = targetEntity.Name; viewItemFromRelation.Type = "field"; viewItemFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "username").Id; viewItemFromRelation.FieldName = "username"; viewItemFromRelation.FieldLabel = "Owner / Project manager"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = PROJECT_RELATION_USER_1_N_PROJECT_OWNER_ID; viewItemFromRelation.RelationName = "user_1_n_project_owner"; viewColumn.Items.Add(viewItemFromRelation); } #endregion #region << $role_n_n_project_team > name >> { var targetEntity = entMan.ReadEntity(SystemIds.RoleEntityId).Object; viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = targetEntity.Id; viewItemFromRelation.EntityName = targetEntity.Name; viewItemFromRelation.Type = "field"; viewItemFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "name").Id; viewItemFromRelation.FieldName = "name"; viewItemFromRelation.FieldLabel = "Project team roles"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = PROJECT_RELATION_ROLE_N_N_PROJECT_TEAM_ID; viewItemFromRelation.RelationName = "role_n_n_project_team"; viewColumn.Items.Add(viewItemFromRelation); } #endregion #region << start_date >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = PROJECT_ENTITY_ID; viewItem.EntityName = PROJECT_ENTITY_NAME; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "start_date").Id; viewItem.FieldName = "start_date"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); #endregion #region << Column right >> viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = 6; viewColumn.Items = new List<InputRecordViewItemBase>(); #region << $customer_1_n_project > name >> { var targetEntity = entMan.ReadEntity(CUSTOMER_ENTITY_ID).Object; viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = targetEntity.Id; viewItemFromRelation.EntityName = targetEntity.Name; viewItemFromRelation.Type = "field"; viewItemFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "name").Id; viewItemFromRelation.FieldName = "name"; viewItemFromRelation.FieldLabel = "Customer"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = PROJECT_RELATION_CUSTOMER_1_N_PROJECT_ID; viewItemFromRelation.RelationName = "customer_1_n_project"; viewColumn.Items.Add(viewItemFromRelation); } #endregion #region << $role_n_n_project_customer > name >> { var targetEntity = entMan.ReadEntity(SystemIds.RoleEntityId).Object; viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = targetEntity.Id; viewItemFromRelation.EntityName = targetEntity.Name; viewItemFromRelation.Type = "field"; viewItemFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "name").Id; viewItemFromRelation.FieldName = "name"; viewItemFromRelation.FieldLabel = "Project customer roles"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = PROJECT_RELATION_ROLE_N_N_PROJECT_CUSTOMER_ID; viewItemFromRelation.RelationName = "role_n_n_project_customer"; viewColumn.Items.Add(viewItemFromRelation); } #endregion #region << end_date >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = PROJECT_ENTITY_ID; viewItem.EntityName = PROJECT_ENTITY_NAME; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "end_date").Id; viewItem.FieldName = "end_date"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << code >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = PROJECT_ENTITY_ID; viewItem.EntityName = PROJECT_ENTITY_NAME; viewItem.FieldId = createViewEntity.Fields.Single(x => x.Name == "code").Id; viewItem.FieldName = "code"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); #endregion //Save row viewSection.Rows.Add(viewRow); #endregion //Save section headerRegion.Sections.Add(viewSection); #endregion createViewInput.Regions = new List<InputRecordViewRegion>(); createViewInput.Regions.Add(headerRegion); #region << Sidebar >> var sidebarListFromRelationItem = new InputRecordViewSidebarRelationListItem(); createViewInput.Sidebar = new InputRecordViewSidebar(); createViewInput.Sidebar.CssClass = ""; createViewInput.Sidebar.Render = true; #endregion { var response = entMan.CreateRecordView(PROJECT_ENTITY_ID, createViewInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + PROJECT_ENTITY_NAME + " Updated view: general" + " Message:" + response.Message); } } #endregion #region << create project create view >> { var createViewEntity = entMan.ReadEntity(PROJECT_ENTITY_ID).Object; var createViewInput = new InputRecordView(); var viewSection = new InputRecordViewSection(); var viewRow = new InputRecordViewRow(); var viewColumn = new InputRecordViewColumn(); var viewItem = new InputRecordViewFieldItem(); var viewItemFromRelation = new InputRecordViewRelationFieldItem(); //General view fields #region << Details >> createViewInput.Id = new Guid("43688004-69df-4c2f-9075-a3d4612f4b69"); createViewInput.Type = "create"; createViewInput.Label = "Create"; createViewInput.Weight = 1; createViewInput.CssClass = ""; createViewInput.IconName = "file-text-o"; createViewInput.Title = ""; createViewInput.Name = "create"; createViewInput.Default = true; createViewInput.System = true; #endregion #region << Get the header Region >> var headerRegion = new InputRecordViewRegion(); headerRegion.Name = "header"; headerRegion.Label = "header"; headerRegion.Sections = new List<InputRecordViewSection>(); #endregion createViewInput.Regions = new List<InputRecordViewRegion>(); createViewInput.Regions.Add(headerRegion); #region << Sidebar >> var sidebarListFromRelationItem = new InputRecordViewSidebarRelationListItem(); createViewInput.Sidebar = new InputRecordViewSidebar(); createViewInput.Sidebar.CssClass = ""; createViewInput.Sidebar.Render = true; var newActionItemList = new List<ActionItem>(); { var actionItem = new ActionItem(); actionItem.Name = "wv_back_button"; actionItem.Menu = "sidebar-top"; actionItem.Template = "<a class=\"back clearfix\" href=\"javascript:void(0)\" ng-click=\"sidebarData.goBack()\"><i class=\"fa fa-fw fa-arrow-left\"></i> <span class=\"text\">Back</span></a>"; actionItem.Weight = 1; newActionItemList.Add(actionItem); } { var actionItem = new ActionItem(); actionItem.Name = "wv_create_and_list"; actionItem.Menu = "create-bottom"; actionItem.Template = "<a class=\"btn btn-primary\" ng-click='ngCtrl.create(\"default\")' ng-if=\"::ngCtrl.createViewRegion != null\">Create</a>"; actionItem.Weight = 1; newActionItemList.Add(actionItem); } { var actionItem = new ActionItem(); actionItem.Name = "wv_create_and_details"; actionItem.Menu = "create-bottom"; actionItem.Template = "<a class=\"btn btn-default btn-outline\" ng-click='ngCtrl.create(\"details\")' ng-if=\"::ngCtrl.createViewRegion != null\">Create & Details</a>"; actionItem.Weight = 2; newActionItemList.Add(actionItem); } { var actionItem = new ActionItem(); actionItem.Name = "wv_create_cancel"; actionItem.Menu = "create-bottom"; actionItem.Template = "<a class=\"btn btn-default btn-outline\" ng-click=\"ngCtrl.cancel()\">Cancel</a>"; actionItem.Weight = 3; newActionItemList.Add(actionItem); } createViewInput.ActionItems = newActionItemList; #endregion { var response = entMan.CreateRecordView(PROJECT_ENTITY_ID, createViewInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + PROJECT_ENTITY_NAME + " Updated view: create" + " Message:" + response.Message); } } #endregion #region << update project dashboard view >> { var updateViewEntity = entMan.ReadEntity(PROJECT_ENTITY_ID).Object; var updateView = updateViewEntity.RecordViews.Single(x => x.Name == "dashboard"); var updateViewInput = new InputRecordView(); var viewSection = new InputRecordViewSection(); var viewRow = new InputRecordViewRow(); var viewColumn = new InputRecordViewColumn(); var viewItem = new InputRecordViewFieldItem(); var viewItemFromRelation = new InputRecordViewRelationFieldItem(); //Convert recordList to recordListInput updateViewInput = updateView.DynamicMapTo<InputRecordView>(); updateViewInput.DynamicHtmlTemplate = "/plugins/webvella-projects/templates/project-dashboard.html"; #region << Get the header Region >> var headerRegion = new InputRecordViewRegion(); foreach (var region in updateViewInput.Regions) { if (region.Name == "header") { headerRegion = region; } } headerRegion.Sections = new List<InputRecordViewSection>(); #endregion #region << Sidebar >> var sidebarListFromRelationItem = new InputRecordViewSidebarRelationListItem(); var sidebarViewItem = new InputRecordViewSidebarViewItem(); updateViewInput.Sidebar.CssClass = ""; updateViewInput.Sidebar.Render = true; if(updateViewInput.Sidebar.Items == null) { updateViewInput.Sidebar.Items = new List<InputRecordViewSidebarItemBase>(); } #region << Tasks >> { var targetEntity = entMan.ReadEntity(TASK_ENTITY_ID).Object; var targetGeneralList = targetEntity.RecordLists.Single(x => x.Name == "project_tasks"); var targetRelation = relMan.Read(new Guid("1f860b8c-7fa1-40fa-874f-19c2b5309817")).Object; sidebarListFromRelationItem = new InputRecordViewSidebarRelationListItem(); sidebarListFromRelationItem.EntityId = targetEntity.Id; sidebarListFromRelationItem.EntityName = targetEntity.Name; sidebarListFromRelationItem.FieldHelpText = ""; sidebarListFromRelationItem.FieldLabel = "Tasks"; sidebarListFromRelationItem.FieldLookupList = "lookup"; sidebarListFromRelationItem.FieldManageView = "general"; sidebarListFromRelationItem.FieldPlaceholder = ""; sidebarListFromRelationItem.FieldRequired = false; sidebarListFromRelationItem.ListId = targetGeneralList.Id; sidebarListFromRelationItem.ListName = targetGeneralList.Name; sidebarListFromRelationItem.RelationId = targetRelation.Id; sidebarListFromRelationItem.RelationName = targetRelation.Name; sidebarListFromRelationItem.Type = "listFromRelation"; updateViewInput.Sidebar.Items.Add(sidebarListFromRelationItem); } #endregion #region << Milestone list >> { var milestoneEntity = entMan.ReadEntity(MILESTONE_ENTITY_ID).Object; var milestoneGeneralList = milestoneEntity.RecordLists.Single(x => x.Name == "project_milestones"); var projectMilestoneRelation = relMan.Read(new Guid("0c446f98-eec2-40c1-9d66-8a3c2a2498e9")).Object; sidebarListFromRelationItem = new InputRecordViewSidebarRelationListItem(); sidebarListFromRelationItem.EntityId = MILESTONE_ENTITY_ID; sidebarListFromRelationItem.EntityName = MILESTONE_ENTITY_NAME; sidebarListFromRelationItem.FieldHelpText = ""; sidebarListFromRelationItem.FieldLabel = "Milestones"; sidebarListFromRelationItem.FieldLookupList = "lookup"; sidebarListFromRelationItem.FieldManageView = "general"; sidebarListFromRelationItem.FieldPlaceholder = ""; sidebarListFromRelationItem.FieldRequired = false; sidebarListFromRelationItem.ListId = milestoneGeneralList.Id; sidebarListFromRelationItem.ListName = milestoneGeneralList.Name; sidebarListFromRelationItem.RelationId = projectMilestoneRelation.Id; sidebarListFromRelationItem.RelationName = projectMilestoneRelation.Name; sidebarListFromRelationItem.Type = "listFromRelation"; updateViewInput.Sidebar.Items.Add(sidebarListFromRelationItem); } #endregion #region << Bugs >> { var targetEntity = entMan.ReadEntity(BUG_ENTITY_ID).Object; var targetGeneralList = targetEntity.RecordLists.Single(x => x.Name == "project_bugs"); var targetRelation = relMan.Read(new Guid("d94f100c-024c-47e7-af32-d67a49be2b6c")).Object; sidebarListFromRelationItem = new InputRecordViewSidebarRelationListItem(); sidebarListFromRelationItem.EntityId = targetEntity.Id; sidebarListFromRelationItem.EntityName = targetEntity.Name; sidebarListFromRelationItem.FieldHelpText = ""; sidebarListFromRelationItem.FieldLabel = "Bugs"; sidebarListFromRelationItem.FieldLookupList = "lookup"; sidebarListFromRelationItem.FieldManageView = "general"; sidebarListFromRelationItem.FieldPlaceholder = ""; sidebarListFromRelationItem.FieldRequired = false; sidebarListFromRelationItem.ListId = targetGeneralList.Id; sidebarListFromRelationItem.ListName = targetGeneralList.Name; sidebarListFromRelationItem.RelationId = targetRelation.Id; sidebarListFromRelationItem.RelationName = targetRelation.Name; sidebarListFromRelationItem.Type = "listFromRelation"; updateViewInput.Sidebar.Items.Add(sidebarListFromRelationItem); } #endregion #region << Project details >> { var targetView = updateViewEntity.RecordViews.Single(x => x.Name == "general"); sidebarViewItem = new InputRecordViewSidebarViewItem(); sidebarViewItem.EntityId = updateViewEntity.Id; sidebarViewItem.EntityName = updateViewEntity.Name; sidebarViewItem.Type = "view"; sidebarViewItem.ViewId = targetView.Id; sidebarViewItem.ViewName = targetView.Name; updateViewInput.Sidebar.Items.Add(sidebarViewItem); } #endregion #endregion { var response = entMan.UpdateRecordView(PROJECT_ENTITY_ID, updateViewInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + PROJECT_ENTITY_NAME + " Updated view: dashboard" + " Message:" + response.Message); } } #endregion #region << area add subscription: Project Workplace -> Project >> { var updatedAreaId = PROJECT_WORKPLACE_AREA_ID; var updateAreaResult = Helpers.UpsertEntityAsAreaSubscription(entMan, recMan, updatedAreaId, PROJECT_ENTITY_NAME, "dashboard", "create", "my_projects"); if (!updateAreaResult.Success) { throw new Exception("System error 10060. Area update with id : " + updatedAreaId + " Message:" + updateAreaResult.Message); } } #endregion #region << area add subscription: URL Dashboard -> Project >> { var updatedAreaId = PROJECT_WORKPLACE_AREA_ID; var updateAreaResult = Helpers.UpsertUrlAsAreaSubscription(entMan, recMan, updatedAreaId, "/#/areas/projects/wv_project/dashboard", "My Dashboard", 1, "tachometer"); if (!updateAreaResult.Success) { throw new Exception("System error 10060. Area update with id : " + updatedAreaId + " Message:" + updateAreaResult.Message); } } #endregion #region << update task general view >> { var updateViewEntity = entMan.ReadEntity(TASK_ENTITY_ID).Object; var updateView = updateViewEntity.RecordViews.Single(x => x.Name == "general"); var updateViewInput = new InputRecordView(); var viewSection = new InputRecordViewSection(); var viewRow = new InputRecordViewRow(); var viewColumn = new InputRecordViewColumn(); var viewItem = new InputRecordViewFieldItem(); var viewItemFromRelation = new InputRecordViewRelationFieldItem(); //General view fields //Convert recordList to recordListInput updateViewInput = updateView.DynamicMapTo<InputRecordView>(); #region << Get the header Region >> var headerRegion = new InputRecordViewRegion(); foreach (var region in updateViewInput.Regions) { if (region.Name == "header") { headerRegion = region; } } #endregion #region << Sidebar >> var sidebarListFromRelationItem = new InputRecordViewSidebarRelationListItem(); var sidebarViewItem = new InputRecordViewSidebarViewItem(); updateViewInput.Sidebar.CssClass = ""; updateViewInput.Sidebar.Render = true; if(updateViewInput.Sidebar.Items == null) { updateViewInput.Sidebar.Items = new List<InputRecordViewSidebarItemBase>(); } #region << Attachments >> { var targetEntity = entMan.ReadEntity(ATTACHMENT_ENTITY_ID).Object; var targetGeneralList = targetEntity.RecordLists.Single(x => x.Name == "task_attachments"); var targetRelation = relMan.Read(new Guid("f79f76e2-06b1-463a-9675-63845814bf22")).Object; sidebarListFromRelationItem = new InputRecordViewSidebarRelationListItem(); sidebarListFromRelationItem.EntityId = targetEntity.Id; sidebarListFromRelationItem.EntityName = targetEntity.Name; sidebarListFromRelationItem.FieldHelpText = ""; sidebarListFromRelationItem.FieldLabel = "Attachments"; sidebarListFromRelationItem.FieldLookupList = "lookup"; sidebarListFromRelationItem.FieldManageView = "general"; sidebarListFromRelationItem.FieldPlaceholder = ""; sidebarListFromRelationItem.FieldRequired = false; sidebarListFromRelationItem.ListId = targetGeneralList.Id; sidebarListFromRelationItem.ListName = targetGeneralList.Name; sidebarListFromRelationItem.RelationId = targetRelation.Id; sidebarListFromRelationItem.RelationName = targetRelation.Name; sidebarListFromRelationItem.Type = "listFromRelation"; updateViewInput.Sidebar = new InputRecordViewSidebar(); updateViewInput.Sidebar.Items = new List<InputRecordViewSidebarItemBase>(); updateViewInput.Sidebar.Items.Add(sidebarListFromRelationItem); } #endregion #region << Comments >> { var targetEntity = entMan.ReadEntity(COMMENT_ENTITY_ID).Object; var targetGeneralList = targetEntity.RecordLists.Single(x => x.Name == "task_comments"); var targetRelation = relMan.Read(new Guid("884b9480-dc1c-468a-98f0-2d5f10084622")).Object; sidebarListFromRelationItem = new InputRecordViewSidebarRelationListItem(); sidebarListFromRelationItem.EntityId = targetEntity.Id; sidebarListFromRelationItem.EntityName = targetEntity.Name; sidebarListFromRelationItem.FieldHelpText = ""; sidebarListFromRelationItem.FieldLabel = "Comments"; sidebarListFromRelationItem.FieldLookupList = "lookup"; sidebarListFromRelationItem.FieldManageView = "general"; sidebarListFromRelationItem.FieldPlaceholder = ""; sidebarListFromRelationItem.FieldRequired = false; sidebarListFromRelationItem.ListId = targetGeneralList.Id; sidebarListFromRelationItem.ListName = targetGeneralList.Name; sidebarListFromRelationItem.RelationId = targetRelation.Id; sidebarListFromRelationItem.RelationName = targetRelation.Name; sidebarListFromRelationItem.Type = "listFromRelation"; updateViewInput.Sidebar.Items.Add(sidebarListFromRelationItem); } #endregion #region << Time logs >> { var targetEntity = entMan.ReadEntity(TIMELOG_ENTITY_ID).Object; var targetGeneralList = targetEntity.RecordLists.Single(x => x.Name == "task_timelogs"); var targetRelation = relMan.Read(new Guid("61f1cd54-bcd6-4061-9c96-7934e01f0857")).Object; sidebarListFromRelationItem = new InputRecordViewSidebarRelationListItem(); sidebarListFromRelationItem.EntityId = targetEntity.Id; sidebarListFromRelationItem.EntityName = targetEntity.Name; sidebarListFromRelationItem.FieldHelpText = ""; sidebarListFromRelationItem.FieldLabel = "Time logs"; sidebarListFromRelationItem.FieldLookupList = "lookup"; sidebarListFromRelationItem.FieldManageView = "general"; sidebarListFromRelationItem.FieldPlaceholder = ""; sidebarListFromRelationItem.FieldRequired = false; sidebarListFromRelationItem.ListId = targetGeneralList.Id; sidebarListFromRelationItem.ListName = targetGeneralList.Name; sidebarListFromRelationItem.RelationId = targetRelation.Id; sidebarListFromRelationItem.RelationName = targetRelation.Name; sidebarListFromRelationItem.Type = "listFromRelation"; updateViewInput.Sidebar.Items.Add(sidebarListFromRelationItem); } #endregion #region << Activities >> { var targetEntity = entMan.ReadEntity(ACTIVITY_ENTITY_ID).Object; var targetGeneralList = targetEntity.RecordLists.Single(x => x.Name == "task_activities"); var targetRelation = relMan.Read(new Guid("8f294277-fd60-496e-bff7-9391fffcda41")).Object; sidebarListFromRelationItem = new InputRecordViewSidebarRelationListItem(); sidebarListFromRelationItem.EntityId = targetEntity.Id; sidebarListFromRelationItem.EntityName = targetEntity.Name; sidebarListFromRelationItem.FieldHelpText = ""; sidebarListFromRelationItem.FieldLabel = "Activities"; sidebarListFromRelationItem.FieldLookupList = "lookup"; sidebarListFromRelationItem.FieldManageView = "general"; sidebarListFromRelationItem.FieldPlaceholder = ""; sidebarListFromRelationItem.FieldRequired = false; sidebarListFromRelationItem.ListId = targetGeneralList.Id; sidebarListFromRelationItem.ListName = targetGeneralList.Name; sidebarListFromRelationItem.RelationId = targetRelation.Id; sidebarListFromRelationItem.RelationName = targetRelation.Name; sidebarListFromRelationItem.Type = "listFromRelation"; updateViewInput.Sidebar.Items.Add(sidebarListFromRelationItem); } #endregion #endregion { var response = entMan.UpdateRecordView(TASK_ENTITY_ID, updateViewInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + TASK_ENTITY_NAME + " Updated view: general" + " Message:" + response.Message); } } #endregion #region << update bug general view >> { var updateViewEntity = entMan.ReadEntity(BUG_ENTITY_ID).Object; var updateView = updateViewEntity.RecordViews.Single(x => x.Name == "general"); var updateViewInput = new InputRecordView(); var viewSection = new InputRecordViewSection(); var viewRow = new InputRecordViewRow(); var viewColumn = new InputRecordViewColumn(); var viewItem = new InputRecordViewFieldItem(); var viewItemView = new InputRecordViewViewItem(); var viewItemFromRelation = new InputRecordViewRelationFieldItem(); //General view fields //Convert recordList to recordListInput updateViewInput = updateView.DynamicMapTo<InputRecordView>(); #region << Details >> updateViewInput.Label = "[{code}] {subject}"; updateViewInput.IconName = "bug"; updateViewInput.ServiceCode = ""; #endregion #region << Get the header Region >> var headerRegion = new InputRecordViewRegion(); foreach (var region in updateViewInput.Regions) { if (region.Name == "header") { headerRegion = region; } } headerRegion.Sections = new List<InputRecordViewSection>(); #endregion #region << Section >> viewSection = new InputRecordViewSection(); viewSection.Id = new Guid("b3679dee-d30d-46d7-b5ac-300ed8f1e922"); viewSection.Name = "details"; viewSection.Label = "Details"; viewSection.ShowLabel = false; viewSection.CssClass = ""; viewSection.Collapsed = false; viewSection.TabOrder = "left-right"; viewSection.Weight = 1; viewSection.Rows = new List<InputRecordViewRow>(); #region << Row 1 >> viewRow = new InputRecordViewRow(); viewRow.Id = new Guid("f9099d26-96ad-4fe2-9c81-db7a8f5daa47"); viewRow.Weight = 1; viewRow.Columns = new List<InputRecordViewColumn>(); #region << Column 1 >> viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = 8; viewColumn.Items = new List<InputRecordViewItemBase>(); #region << subject >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = updateViewEntity.Id; viewItem.EntityName = updateViewEntity.Name; viewItem.FieldId = updateViewEntity.Fields.Single(x => x.Name == "subject").Id; viewItem.FieldName = "subject"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << project name from Relation >> { var targetEntity = entMan.ReadEntity(PROJECT_ENTITY_ID).Object; var targetRelation = relMan.Read("project_1_n_bug").Object; viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = targetEntity.Id; viewItemFromRelation.EntityName = targetEntity.Name; viewItemFromRelation.Type = "fieldFromRelation"; viewItemFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "name").Id; viewItemFromRelation.FieldName = "name"; viewItemFromRelation.FieldLabel = "Project"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = targetRelation.Id; viewItemFromRelation.RelationName = targetRelation.Name; viewColumn.Items.Add(viewItemFromRelation); } #endregion #region << description >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = updateViewEntity.Id; viewItem.EntityName = updateViewEntity.Name; viewItem.FieldId = updateViewEntity.Fields.Single(x => x.Name == "description").Id; viewItem.FieldName = "description"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion //Save column viewRow.Columns.Add(viewColumn); #endregion #region << Column 2 >> viewColumn = new InputRecordViewColumn(); viewColumn.GridColCount = 4; viewColumn.Items = new List<InputRecordViewItemBase>(); #region << code >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = updateViewEntity.Id; viewItem.EntityName = updateViewEntity.Name; viewItem.FieldId = updateViewEntity.Fields.Single(x => x.Name == "code").Id; viewItem.FieldName = "code"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << status >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = updateViewEntity.Id; viewItem.EntityName = updateViewEntity.Name; viewItem.FieldId = updateViewEntity.Fields.Single(x => x.Name == "status").Id; viewItem.FieldName = "status"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << priority >> { viewItem = new InputRecordViewFieldItem(); viewItem.EntityId = updateViewEntity.Id; viewItem.EntityName = updateViewEntity.Name; viewItem.FieldId = updateViewEntity.Fields.Single(x => x.Name == "priority").Id; viewItem.FieldName = "priority"; viewItem.Type = "field"; viewColumn.Items.Add(viewItem); } #endregion #region << owner >> { var targetEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; var targetRelation = relMan.Read("user_1_n_bug_owner").Object; viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = targetEntity.Id; viewItemFromRelation.EntityName = targetEntity.Name; viewItemFromRelation.Type = "fieldFromRelation"; viewItemFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "username").Id; viewItemFromRelation.FieldName = "username"; viewItemFromRelation.FieldLabel = "Owner"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = targetRelation.Id; viewItemFromRelation.RelationName = targetRelation.Name; viewColumn.Items.Add(viewItemFromRelation); } #endregion #region << watchers >> { var targetEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; var targetRelation = relMan.Read("user_n_n_bug_watchers").Object; viewItemFromRelation = new InputRecordViewRelationFieldItem(); viewItemFromRelation.EntityId = targetEntity.Id; viewItemFromRelation.EntityName = targetEntity.Name; viewItemFromRelation.Type = "fieldFromRelation"; viewItemFromRelation.FieldId = targetEntity.Fields.Single(x => x.Name == "username").Id; viewItemFromRelation.FieldName = "username"; viewItemFromRelation.FieldLabel = "Watchers"; viewItemFromRelation.FieldPlaceholder = ""; viewItemFromRelation.FieldRequired = true; viewItemFromRelation.FieldLookupList = "lookup"; viewItemFromRelation.RelationId = targetRelation.Id; viewItemFromRelation.RelationName = targetRelation.Name; viewColumn.Items.Add(viewItemFromRelation); } #endregion //Save column viewRow.Columns.Add(viewColumn); #endregion //Save row viewSection.Rows.Add(viewRow); #endregion //Save section headerRegion.Sections.Add(viewSection); #endregion #region << Sidebar >> var sidebarListFromRelationItem = new InputRecordViewSidebarRelationListItem(); var sidebarViewItem = new InputRecordViewSidebarViewItem(); updateViewInput.Sidebar = new InputRecordViewSidebar(); updateViewInput.Sidebar.CssClass = ""; updateViewInput.Sidebar.Render = true; if(updateViewInput.Sidebar.Items == null) { updateViewInput.Sidebar.Items = new List<InputRecordViewSidebarItemBase>(); } #region << Attachments >> { var targetEntity = entMan.ReadEntity(ATTACHMENT_ENTITY_ID).Object; var targetGeneralList = targetEntity.RecordLists.Single(x => x.Name == "bug_attachments"); var targetRelation = relMan.Read("bug_1_n_attachment").Object; sidebarListFromRelationItem = new InputRecordViewSidebarRelationListItem(); sidebarListFromRelationItem.EntityId = targetEntity.Id; sidebarListFromRelationItem.EntityName = targetEntity.Name; sidebarListFromRelationItem.FieldHelpText = ""; sidebarListFromRelationItem.FieldLabel = "Attachments"; sidebarListFromRelationItem.FieldLookupList = "lookup"; sidebarListFromRelationItem.FieldManageView = "general"; sidebarListFromRelationItem.FieldPlaceholder = ""; sidebarListFromRelationItem.FieldRequired = false; sidebarListFromRelationItem.ListId = targetGeneralList.Id; sidebarListFromRelationItem.ListName = targetGeneralList.Name; sidebarListFromRelationItem.RelationId = targetRelation.Id; sidebarListFromRelationItem.RelationName = targetRelation.Name; sidebarListFromRelationItem.Type = "listFromRelation"; updateViewInput.Sidebar.Items.Add(sidebarListFromRelationItem); } #endregion #region << Comments >> { var targetEntity = entMan.ReadEntity(COMMENT_ENTITY_ID).Object; var targetGeneralList = targetEntity.RecordLists.Single(x => x.Name == "bug_comments"); var targetRelation = relMan.Read("bug_1_n_comment").Object; sidebarListFromRelationItem = new InputRecordViewSidebarRelationListItem(); sidebarListFromRelationItem.EntityId = targetEntity.Id; sidebarListFromRelationItem.EntityName = targetEntity.Name; sidebarListFromRelationItem.FieldHelpText = ""; sidebarListFromRelationItem.FieldLabel = "Comments"; sidebarListFromRelationItem.FieldLookupList = "lookup"; sidebarListFromRelationItem.FieldManageView = "general"; sidebarListFromRelationItem.FieldPlaceholder = ""; sidebarListFromRelationItem.FieldRequired = false; sidebarListFromRelationItem.ListId = targetGeneralList.Id; sidebarListFromRelationItem.ListName = targetGeneralList.Name; sidebarListFromRelationItem.RelationId = targetRelation.Id; sidebarListFromRelationItem.RelationName = targetRelation.Name; sidebarListFromRelationItem.Type = "listFromRelation"; updateViewInput.Sidebar.Items.Add(sidebarListFromRelationItem); } #endregion #region << Time logs >> { var targetEntity = entMan.ReadEntity(TIMELOG_ENTITY_ID).Object; var targetGeneralList = targetEntity.RecordLists.Single(x => x.Name == "bug_timelogs"); var targetRelation = relMan.Read("bug_1_n_time_log").Object; sidebarListFromRelationItem = new InputRecordViewSidebarRelationListItem(); sidebarListFromRelationItem.EntityId = targetEntity.Id; sidebarListFromRelationItem.EntityName = targetEntity.Name; sidebarListFromRelationItem.FieldHelpText = ""; sidebarListFromRelationItem.FieldLabel = "Time logs"; sidebarListFromRelationItem.FieldLookupList = "lookup"; sidebarListFromRelationItem.FieldManageView = "general"; sidebarListFromRelationItem.FieldPlaceholder = ""; sidebarListFromRelationItem.FieldRequired = false; sidebarListFromRelationItem.ListId = targetGeneralList.Id; sidebarListFromRelationItem.ListName = targetGeneralList.Name; sidebarListFromRelationItem.RelationId = targetRelation.Id; sidebarListFromRelationItem.RelationName = targetRelation.Name; sidebarListFromRelationItem.Type = "listFromRelation"; updateViewInput.Sidebar.Items.Add(sidebarListFromRelationItem); } #endregion #region << Activities >> { var targetEntity = entMan.ReadEntity(ACTIVITY_ENTITY_ID).Object; var targetGeneralList = targetEntity.RecordLists.Single(x => x.Name == "bug_activities"); var targetRelation = relMan.Read("bug_1_n_activity").Object; sidebarListFromRelationItem = new InputRecordViewSidebarRelationListItem(); sidebarListFromRelationItem.EntityId = targetEntity.Id; sidebarListFromRelationItem.EntityName = targetEntity.Name; sidebarListFromRelationItem.FieldHelpText = ""; sidebarListFromRelationItem.FieldLabel = "Activities"; sidebarListFromRelationItem.FieldLookupList = "lookup"; sidebarListFromRelationItem.FieldManageView = "general"; sidebarListFromRelationItem.FieldPlaceholder = ""; sidebarListFromRelationItem.FieldRequired = false; sidebarListFromRelationItem.ListId = targetGeneralList.Id; sidebarListFromRelationItem.ListName = targetGeneralList.Name; sidebarListFromRelationItem.RelationId = targetRelation.Id; sidebarListFromRelationItem.RelationName = targetRelation.Name; sidebarListFromRelationItem.Type = "listFromRelation"; updateViewInput.Sidebar.Items.Add(sidebarListFromRelationItem); } #endregion #endregion { var response = entMan.UpdateRecordView(BUG_ENTITY_ID, updateViewInput); if (!response.Success) throw new Exception("System error 10060. Entity: " + BUG_ENTITY_NAME + " Updated view: general" + " Message:" + response.Message); } } #endregion if (createSampleRecords) { #region << Create Project Team Role >> { var sampleRecord = new EntityRecord(); sampleRecord["id"] = new Guid("083a5c46-7dbe-4ff9-b19f-44603671ccb2"); sampleRecord["name"] = "project_team"; sampleRecord["description"] = "Project team role for the Project application"; var createSampleRecordResult = recMan.CreateRecord(SystemIds.RoleEntityId, sampleRecord); if (!createSampleRecordResult.Success) { throw new Exception("System error 10060. Create sample role record. Message:" + createSampleRecordResult.Message); } } #endregion #region << Create Sample Project Manager User >> { var sampleRecord = new EntityRecord(); sampleRecord["id"] = new Guid("b646c5d4-acc8-4404-af77-6786b81bee05"); sampleRecord["first_name"] = "Project"; sampleRecord["last_name"] = "Manager"; sampleRecord["username"] = "******"; sampleRecord["email"] = "*****@*****.**"; sampleRecord["password"] = "******"; sampleRecord["enabled"] = true; sampleRecord["verified"] = true; sampleRecord["image"] = "/plugins/webvella-core/assets/avatar-red.png"; var createSampleRecordResult = recMan.CreateRecord(SystemIds.UserEntityId, sampleRecord); if (!createSampleRecordResult.Success) { throw new Exception("System error 10060. Create sample customer record. Message:" + createSampleRecordResult.Message); } } #endregion #region << Create Sample Project Team User >> { var sampleRecord = new EntityRecord(); sampleRecord["id"] = new Guid("6c820f13-f7d0-429e-a04a-c0ec3ba6ade0"); sampleRecord["first_name"] = "Project"; sampleRecord["last_name"] = "Team"; sampleRecord["username"] = "******"; sampleRecord["email"] = "*****@*****.**"; sampleRecord["password"] = "******"; sampleRecord["enabled"] = true; sampleRecord["verified"] = true; sampleRecord["image"] = "/plugins/webvella-core/assets/avatar-green.png"; var createSampleRecordResult = recMan.CreateRecord(SystemIds.UserEntityId, sampleRecord); if (!createSampleRecordResult.Success) { throw new Exception("System error 10060. Create sample customer record. Message:" + createSampleRecordResult.Message); } } #endregion #region << Create relation between project manager user and role >> { var createRelationNtoNResponse = recMan.CreateRelationManyToManyRecord(new Guid("0c4b119e-1d7b-4b40-8d2c-9e447cc656ab"), new Guid("083a5c46-7dbe-4ff9-b19f-44603671ccb2"), new Guid("b646c5d4-acc8-4404-af77-6786b81bee05")); if (!createRelationNtoNResponse.Success) { throw new Exception("Could not create item image relation" + createRelationNtoNResponse.Message); } } #endregion #region << Create relation between project manager user and regular role >> { var createRelationNtoNResponse = recMan.CreateRelationManyToManyRecord(new Guid("0c4b119e-1d7b-4b40-8d2c-9e447cc656ab"), new Guid("f16ec6db-626d-4c27-8de0-3e7ce542c55f"), new Guid("b646c5d4-acc8-4404-af77-6786b81bee05")); if (!createRelationNtoNResponse.Success) { throw new Exception("Could not create item image relation" + createRelationNtoNResponse.Message); } } #endregion #region << Create relation between project team user and role >> { var createRelationNtoNResponse = recMan.CreateRelationManyToManyRecord(new Guid("0c4b119e-1d7b-4b40-8d2c-9e447cc656ab"), new Guid("083a5c46-7dbe-4ff9-b19f-44603671ccb2"), new Guid("6c820f13-f7d0-429e-a04a-c0ec3ba6ade0")); if (!createRelationNtoNResponse.Success) { throw new Exception("Could not create item image relation" + createRelationNtoNResponse.Message); } } #endregion #region << Create relation between project manager user and regular role >> { var createRelationNtoNResponse = recMan.CreateRelationManyToManyRecord(new Guid("0c4b119e-1d7b-4b40-8d2c-9e447cc656ab"), new Guid("f16ec6db-626d-4c27-8de0-3e7ce542c55f"), new Guid("6c820f13-f7d0-429e-a04a-c0ec3ba6ade0")); if (!createRelationNtoNResponse.Success) { throw new Exception("Could not create item image relation" + createRelationNtoNResponse.Message); } } #endregion #region << Create relation between the system admin and project team role, so he can see the first project >> { var createRelationNtoNResponse = recMan.CreateRelationManyToManyRecord(new Guid("0c4b119e-1d7b-4b40-8d2c-9e447cc656ab"), new Guid("083a5c46-7dbe-4ff9-b19f-44603671ccb2"), SystemIds.FirstUserId); if (!createRelationNtoNResponse.Success) { throw new Exception("Could not create item image relation" + createRelationNtoNResponse.Message); } } #endregion #region << Create Sample Project >> { var sampleRecord = new EntityRecord(); sampleRecord["id"] = new Guid("a0141850-b13c-44b4-bb1b-4e0dde4850f4"); sampleRecord["name"] = "Corporate website development"; sampleRecord["description"] = "All activities for developing a sample application"; sampleRecord["code"] = "SMPL"; sampleRecord["billable_hour_price"] = 100; sampleRecord["owner_id"] = new Guid("b646c5d4-acc8-4404-af77-6786b81bee05"); sampleRecord["customer_id"] = CUSTOMER_RECORD_ID; var customerRoles = new List<Guid>(); customerRoles.Add(CUSTOMER_ROLE_ID); sampleRecord["$$role_n_n_project_customer.id"] = customerRoles; var projectTeamRoles = new List<Guid>(); projectTeamRoles.Add(new Guid("083a5c46-7dbe-4ff9-b19f-44603671ccb2")); sampleRecord["$$role_n_n_project_team.id"] = projectTeamRoles; sampleRecord["priority"] = "medium"; sampleRecord["status"] = "in review"; sampleRecord["start_date"] = DateTime.UtcNow.AddDays(3); sampleRecord["end_date"] = DateTime.UtcNow.AddDays(90); var createSampleRecordResult = recMan.CreateRecord(PROJECT_ENTITY_NAME, sampleRecord); if (!createSampleRecordResult.Success) { throw new Exception("System error 10060. Create sample project. Message:" + createSampleRecordResult.Message); } } #endregion #region << Create Sample Milestone >> { var sampleRecord = new EntityRecord(); sampleRecord["id"] = new Guid("42b881fc-d93f-46cf-b39d-391cd42fd2f6"); sampleRecord["name"] = "Specification documents development"; sampleRecord["start_date"] = DateTime.UtcNow.AddDays(3); sampleRecord["status"] = "opened"; sampleRecord["end_date"] = DateTime.UtcNow.AddDays(90); sampleRecord["project_id"] = new Guid("a0141850-b13c-44b4-bb1b-4e0dde4850f4"); var createSampleRecordResult = recMan.CreateRecord(MILESTONE_ENTITY_ID, sampleRecord); if (!createSampleRecordResult.Success) { throw new Exception("System error 10060. Create sample milestone. Message:" + createSampleRecordResult.Message); } } #endregion #region << Create Sample Task >> { var sampleRecord = new EntityRecord(); sampleRecord["id"] = new Guid("70515386-7612-480d-99e6-76b97ca4190a"); sampleRecord["subject"] = "Corporate identity specification"; sampleRecord["owner_id"] = new Guid("b646c5d4-acc8-4404-af77-6786b81bee05"); sampleRecord["milestone_id"] = new Guid("42b881fc-d93f-46cf-b39d-391cd42fd2f6"); sampleRecord["description"] = "This is a sample task describing how to generate a corporate identity document"; sampleRecord["parent_id"] = null; sampleRecord["code"] = "SMPL-T1"; sampleRecord["start_date"] = DateTime.UtcNow.AddDays(3); sampleRecord["end_date"] = DateTime.UtcNow.AddDays(90); sampleRecord["priority"] = "medium"; sampleRecord["status"] = "not started"; sampleRecord["x_billable_hours"] = 0; sampleRecord["x_nonbillable_hours"] = 0; sampleRecord["project_id"] = new Guid("a0141850-b13c-44b4-bb1b-4e0dde4850f4"); var createSampleRecordResult = recMan.CreateRecord(TASK_ENTITY_ID, sampleRecord); if (!createSampleRecordResult.Success) { throw new Exception("System error 10060. Create sample task. Message:" + createSampleRecordResult.Message); } } #endregion #region << Add watchers to the task >> //Creator { var targetRelation = relMan.Read("user_n_n_task_watchers").Object; var createRelationNtoNResponse = recMan.CreateRelationManyToManyRecord(targetRelation.Id, SystemIds.FirstUserId, new Guid("70515386-7612-480d-99e6-76b97ca4190a")); if (!createRelationNtoNResponse.Success) { throw new Exception("Could not create watch relation" + createRelationNtoNResponse.Message); } } // Project manager { var targetRelation = relMan.Read("user_n_n_task_watchers").Object; var createRelationNtoNResponse = recMan.CreateRelationManyToManyRecord(targetRelation.Id, new Guid("b646c5d4-acc8-4404-af77-6786b81bee05"), new Guid("70515386-7612-480d-99e6-76b97ca4190a")); if (!createRelationNtoNResponse.Success) { throw new Exception("Could not create watch relation" + createRelationNtoNResponse.Message); } } #endregion #region << Create Sample BUG >> { var sampleRecord = new EntityRecord(); sampleRecord["id"] = new Guid("18934091-b4e4-4db4-8beb-678cd29b6916"); sampleRecord["subject"] = "Sample bug subject"; sampleRecord["owner_id"] = new Guid("b646c5d4-acc8-4404-af77-6786b81bee05"); sampleRecord["milestone_id"] = new Guid("42b881fc-d93f-46cf-b39d-391cd42fd2f6"); sampleRecord["description"] = "This is a sample bug about the project"; sampleRecord["priority"] = "medium"; sampleRecord["code"] = "SMPL-B1"; sampleRecord["status"] = "opened"; sampleRecord["x_billable_hours"] = 0; sampleRecord["x_nonbillable_hours"] = 0; sampleRecord["project_id"] = new Guid("a0141850-b13c-44b4-bb1b-4e0dde4850f4"); var createSampleRecordResult = recMan.CreateRecord(BUG_ENTITY_ID, sampleRecord); if (!createSampleRecordResult.Success) { throw new Exception("System error 10060. Create sample bug. Message:" + createSampleRecordResult.Message); } } #endregion #region << Add watchers to the bug >> //Creator { var targetRelation = relMan.Read("user_n_n_bug_watchers").Object; var createRelationNtoNResponse = recMan.CreateRelationManyToManyRecord(targetRelation.Id, SystemIds.FirstUserId, new Guid("18934091-b4e4-4db4-8beb-678cd29b6916")); if (!createRelationNtoNResponse.Success) { throw new Exception("Could not create watch relation" + createRelationNtoNResponse.Message); } } // Project manager { var targetRelation = relMan.Read("user_n_n_bug_watchers").Object; var createRelationNtoNResponse = recMan.CreateRelationManyToManyRecord(targetRelation.Id, new Guid("b646c5d4-acc8-4404-af77-6786b81bee05"), new Guid("18934091-b4e4-4db4-8beb-678cd29b6916")); if (!createRelationNtoNResponse.Success) { throw new Exception("Could not create watch relation" + createRelationNtoNResponse.Message); } } #endregion #region << Update the project >> { var filterObj = EntityQuery.QueryEQ("id", new Guid("a0141850-b13c-44b4-bb1b-4e0dde4850f4")); var resultQuery = new EntityQuery(PROJECT_ENTITY_NAME, "*", filterObj, null, null, null, null); var updateResult = recMan.Find(resultQuery); if (!updateResult.Success) { throw new Exception("Failed to update the project"); } var updateRecord = updateResult.Object.Data[0]; updateRecord["x_milestones_opened"] = (decimal)updateRecord["x_milestones_opened"] + 1; updateRecord["x_tasks_not_started"] = (decimal)updateRecord["x_tasks_not_started"] + 1; updateRecord["x_bugs_opened"] = (decimal)updateRecord["x_bugs_opened"] + 1; var createSampleRecordResult = recMan.UpdateRecord(PROJECT_ENTITY_ID, updateRecord); if (!createSampleRecordResult.Success) { throw new Exception("System error 10060.Update sample project. Message:" + createSampleRecordResult.Message); } } #endregion #region << Update the milestone >> { var filterObj = EntityQuery.QueryEQ("id", new Guid("42b881fc-d93f-46cf-b39d-391cd42fd2f6")); var resultQuery = new EntityQuery(MILESTONE_ENTITY_NAME, "*", filterObj, null, null, null, null); var updateResult = recMan.Find(resultQuery); if (!updateResult.Success) { throw new Exception("Failed to update the project"); } var updateRecord = updateResult.Object.Data[0]; updateRecord["x_tasks_not_started"] = (decimal)updateRecord["x_tasks_not_started"] + 1; updateRecord["x_bugs_opened"] = (decimal)updateRecord["x_bugs_opened"] + 1; var createSampleRecordResult = recMan.UpdateRecord(MILESTONE_ENTITY_NAME, updateRecord); if (!createSampleRecordResult.Success) { throw new Exception("System error 10060. Update sample milestone. Message:" + createSampleRecordResult.Message); } } #endregion } }
public void InitializeSystemEntities() { EntityResponse response = null; FieldResponse fieldResponse = null; EntityManager entMan = new EntityManager(); EntityRelationManager rm = new EntityRelationManager(); RecordManager recMan = new RecordManager(true); using (var connection = DbContext.Current.CreateConnection()) { //setup necessary extensions DbRepository.CreatePostgresqlExtensions(); try { connection.BeginTransaction(); CheckCreateSystemTables(); DbSystemSettings storeSystemSettings = DbContext.Current.SettingsRepository.Read(); Guid systemSettingsId = new Guid("F3223177-B2FF-43F5-9A4B-FF16FC67D186"); SystemSettings systemSettings = new SystemSettings(); systemSettings.Id = systemSettingsId; int currentVersion = 0; if (storeSystemSettings != null) { systemSettings = new SystemSettings(storeSystemSettings); currentVersion = systemSettings.Version; } //tmp code - during debug only //entityManager.DeleteEntity(SystemIds.UserEntityId); //entityManager.DeleteEntity(SystemIds.RoleEntityId); //rm.Delete(SystemIds.UserRoleRelationId); //currentVersion = 0; if (currentVersion < 150508) { systemSettings.Version = 150508; List<Guid> allowedRoles = new List<Guid>(); allowedRoles.Add(SystemIds.AdministratorRoleId); #region << create user entity >> { InputEntity userEntity = new InputEntity(); userEntity.Id = SystemIds.UserEntityId; userEntity.Name = "user"; userEntity.Label = "User"; userEntity.LabelPlural = "Users"; userEntity.System = true; userEntity.RecordPermissions = new RecordPermissions(); userEntity.RecordPermissions.CanCreate = new List<Guid>(); userEntity.RecordPermissions.CanRead = new List<Guid>(); userEntity.RecordPermissions.CanUpdate = new List<Guid>(); userEntity.RecordPermissions.CanDelete = new List<Guid>(); userEntity.RecordPermissions.CanCreate.Add(SystemIds.GuestRoleId); userEntity.RecordPermissions.CanCreate.Add(SystemIds.AdministratorRoleId); userEntity.RecordPermissions.CanRead.Add(SystemIds.GuestRoleId); userEntity.RecordPermissions.CanRead.Add(SystemIds.RegularRoleId); userEntity.RecordPermissions.CanRead.Add(SystemIds.AdministratorRoleId); userEntity.RecordPermissions.CanUpdate.Add(SystemIds.AdministratorRoleId); userEntity.RecordPermissions.CanDelete.Add(SystemIds.AdministratorRoleId); var systemItemIdDictionary = new Dictionary<string, Guid>(); systemItemIdDictionary["id"] = new Guid("8e438549-fd30-4766-95a9-061008cee48e"); systemItemIdDictionary["created_on"] = new Guid("6fda5e6b-80e6-4d8a-9e2a-d983c3694e96"); systemItemIdDictionary["created_by"] = new Guid("825e8367-3be1-4022-ba66-6494859d70d9"); systemItemIdDictionary["last_modified_on"] = new Guid("5a975d33-47c6-4ba6-83c8-c24034206879"); systemItemIdDictionary["last_modified_by"] = new Guid("cafc8cda-1a1d-43e4-9406-6acf8ba8fa8d"); response = entMan.CreateEntity(userEntity, false, false, systemItemIdDictionary); InputTextField firstName = new InputTextField(); firstName.Id = new Guid("DF211549-41CC-4D11-BB43-DACA4C164411"); firstName.Name = "first_name"; firstName.Label = "First Name"; firstName.PlaceholderText = ""; firstName.Description = "First name of the user"; firstName.HelpText = ""; firstName.Required = false; firstName.Unique = false; firstName.Searchable = false; firstName.Auditable = false; firstName.System = true; firstName.DefaultValue = ""; firstName.MaxLength = 200; fieldResponse = entMan.CreateField(userEntity.Id.Value, firstName, false); InputTextField lastName = new InputTextField(); lastName.Id = new Guid("63E685B1-B2C6-4961-B393-2B6723EBD1BF"); lastName.Name = "last_name"; lastName.Label = "Last Name"; lastName.PlaceholderText = ""; lastName.Description = "Last name of the user"; lastName.HelpText = ""; lastName.Required = false; lastName.Unique = false; lastName.Searchable = false; lastName.Auditable = false; lastName.System = true; lastName.DefaultValue = ""; lastName.MaxLength = 200; fieldResponse = entMan.CreateField(userEntity.Id.Value, lastName, false); InputTextField userName = new InputTextField(); userName.Id = new Guid("263c0b21-88c1-4c2b-80b4-db7402b0d2e2"); userName.Name = "username"; userName.Label = "User Name"; userName.PlaceholderText = ""; userName.Description = "screen name for the user"; userName.HelpText = ""; userName.Required = true; userName.Unique = true; userName.Searchable = true; userName.Auditable = false; userName.System = true; userName.DefaultValue = string.Empty; userName.MaxLength = 200; fieldResponse = entMan.CreateField(userEntity.Id.Value, userName, false); InputEmailField email = new InputEmailField(); email.Id = new Guid("9FC75C8F-CE80-4A64-81D7-E2BEFA5E4815"); email.Name = "email"; email.Label = "Email"; email.PlaceholderText = ""; email.Description = "Email address of the user"; email.HelpText = ""; email.Required = true; email.Unique = true; email.Searchable = true; email.Auditable = false; email.System = true; email.DefaultValue = string.Empty; email.MaxLength = 255; fieldResponse = entMan.CreateField(userEntity.Id.Value, email, false); InputPasswordField password = new InputPasswordField(); password.Id = new Guid("4EDE88D9-217A-4462-9300-EA0D6AFCDCEA"); password.Name = "password"; password.Label = "Password"; password.PlaceholderText = ""; password.Description = "Password for the user account"; password.HelpText = ""; password.Required = true; password.Unique = false; password.Searchable = false; password.Auditable = false; password.System = true; password.MinLength = 6; password.MaxLength = 24; password.Encrypted = true; fieldResponse = entMan.CreateField(userEntity.Id.Value, password, false); InputDateTimeField lastLoggedIn = new InputDateTimeField(); lastLoggedIn.Id = new Guid("3C85CCEC-D526-4E47-887F-EE169D1F508D"); lastLoggedIn.Name = "last_logged_in"; lastLoggedIn.Label = "Last Logged In"; lastLoggedIn.PlaceholderText = ""; lastLoggedIn.Description = ""; lastLoggedIn.HelpText = ""; lastLoggedIn.Required = false; lastLoggedIn.Unique = false; lastLoggedIn.Searchable = false; lastLoggedIn.Auditable = true; lastLoggedIn.System = true; lastLoggedIn.DefaultValue = null; lastLoggedIn.Format = "dd MMM yyyy HH:mm:ss"; lastLoggedIn.UseCurrentTimeAsDefaultValue = true; fieldResponse = entMan.CreateField(userEntity.Id.Value, lastLoggedIn, false); InputCheckboxField enabledField = new InputCheckboxField(); enabledField.Id = new Guid("C0C63650-7572-4252-8E4B-4E25C94897A6"); enabledField.Name = "enabled"; enabledField.Label = "Enabled"; enabledField.PlaceholderText = ""; enabledField.Description = "Shows if the user account is enabled"; enabledField.HelpText = ""; enabledField.Required = true; enabledField.Unique = false; enabledField.Searchable = false; enabledField.Auditable = false; enabledField.System = true; enabledField.DefaultValue = false; fieldResponse = entMan.CreateField(userEntity.Id.Value, enabledField, false); InputCheckboxField verifiedUserField = new InputCheckboxField(); verifiedUserField.Id = new Guid("F1BA5069-8CC9-4E66-BCC3-60E33C79C265"); verifiedUserField.Name = "verified"; verifiedUserField.Label = "Verified"; verifiedUserField.PlaceholderText = ""; verifiedUserField.Description = "Shows if the user email is verified"; verifiedUserField.HelpText = ""; verifiedUserField.Required = true; verifiedUserField.Unique = false; verifiedUserField.Searchable = false; verifiedUserField.Auditable = false; verifiedUserField.System = true; verifiedUserField.DefaultValue = false; fieldResponse = entMan.CreateField(userEntity.Id.Value, verifiedUserField, false); #region << image >> { InputImageField imageField = new InputImageField(); imageField.Id = new Guid("bf199b74-4448-4f58-93f5-6b86d888843b"); imageField.Name = "image"; imageField.Label = "Image"; imageField.PlaceholderText = ""; imageField.Description = ""; imageField.HelpText = ""; imageField.Required = false; imageField.Unique = false; imageField.Searchable = false; imageField.Auditable = false; imageField.System = true; imageField.DefaultValue = string.Empty; imageField.EnableSecurity = false; { var createResponse = entMan.CreateField(SystemIds.UserEntityId, imageField, false); if (!createResponse.Success) throw new Exception("System error 10060. Entity: user. Field: image" + " Message:" + createResponse.Message); } } #endregion } #endregion #region << create role entity >> { InputEntity roleEntity = new InputEntity(); roleEntity.Id = SystemIds.RoleEntityId; roleEntity.Name = "role"; roleEntity.Label = "Role"; roleEntity.LabelPlural = "Roles"; roleEntity.System = true; roleEntity.RecordPermissions = new RecordPermissions(); roleEntity.RecordPermissions.CanCreate = new List<Guid>(); roleEntity.RecordPermissions.CanRead = new List<Guid>(); roleEntity.RecordPermissions.CanUpdate = new List<Guid>(); roleEntity.RecordPermissions.CanDelete = new List<Guid>(); roleEntity.RecordPermissions.CanCreate.Add(SystemIds.GuestRoleId); roleEntity.RecordPermissions.CanCreate.Add(SystemIds.AdministratorRoleId); roleEntity.RecordPermissions.CanRead.Add(SystemIds.RegularRoleId); roleEntity.RecordPermissions.CanRead.Add(SystemIds.GuestRoleId); roleEntity.RecordPermissions.CanRead.Add(SystemIds.AdministratorRoleId); roleEntity.RecordPermissions.CanUpdate.Add(SystemIds.AdministratorRoleId); roleEntity.RecordPermissions.CanDelete.Add(SystemIds.AdministratorRoleId); var systemItemIdDictionary = new Dictionary<string, Guid>(); systemItemIdDictionary["id"] = new Guid("37fd9c4f-5413-4f3a-aa2f-d831cc106d03"); systemItemIdDictionary["created_on"] = new Guid("64047bab-dc73-4175-a744-e5d565e8adbb"); systemItemIdDictionary["created_by"] = new Guid("0ccd806b-715c-42d4-a580-f3f11f55d937"); systemItemIdDictionary["last_modified_on"] = new Guid("c4522433-1c67-44f9-b461-e85d4d363b70"); systemItemIdDictionary["last_modified_by"] = new Guid("a4489db4-9d76-4d5a-8940-6ef2da562c25"); systemItemIdDictionary["user_role_created_by"] = new Guid("c6151e80-9dce-4c0b-ae5f-4798e14cff4c"); systemItemIdDictionary["user_role_modified_by"] = new Guid("f3efaefe-32d2-4840-ac06-bc5723e323d0"); response = entMan.CreateEntity(roleEntity, false, false, systemItemIdDictionary); InputTextField nameRoleField = new InputTextField(); nameRoleField.Id = new Guid("36F91EBD-5A02-4032-8498-B7F716F6A349"); nameRoleField.Name = "name"; nameRoleField.Label = "Name"; nameRoleField.PlaceholderText = ""; nameRoleField.Description = "The name of the role"; nameRoleField.HelpText = ""; nameRoleField.Required = true; nameRoleField.Unique = false; nameRoleField.Searchable = false; nameRoleField.Auditable = false; nameRoleField.System = true; nameRoleField.DefaultValue = ""; nameRoleField.MaxLength = 200; nameRoleField.EnableSecurity = true; nameRoleField.Permissions = new FieldPermissions(); nameRoleField.Permissions.CanRead = new List<Guid>(); nameRoleField.Permissions.CanUpdate = new List<Guid>(); //READ nameRoleField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); nameRoleField.Permissions.CanRead.Add(SystemIds.RegularRoleId); //UPDATE nameRoleField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); fieldResponse = entMan.CreateField(roleEntity.Id.Value, nameRoleField, false); InputTextField descriptionRoleField = new InputTextField(); descriptionRoleField.Id = new Guid("4A8B9E0A-1C36-40C6-972B-B19E2B5D265B"); descriptionRoleField.Name = "description"; descriptionRoleField.Label = "Description"; descriptionRoleField.PlaceholderText = ""; descriptionRoleField.Description = ""; descriptionRoleField.HelpText = ""; descriptionRoleField.Required = true; descriptionRoleField.Unique = false; descriptionRoleField.Searchable = false; descriptionRoleField.Auditable = false; descriptionRoleField.System = true; descriptionRoleField.DefaultValue = ""; descriptionRoleField.MaxLength = 200; fieldResponse = entMan.CreateField(roleEntity.Id.Value, descriptionRoleField, false); } #endregion #region << create user - role relation >> { var userEntity = entMan.ReadEntity(SystemIds.UserEntityId).Object; var roleEntity = entMan.ReadEntity(SystemIds.RoleEntityId).Object; EntityRelation userRoleRelation = new EntityRelation(); userRoleRelation.Id = SystemIds.UserRoleRelationId; userRoleRelation.Name = "user_role"; userRoleRelation.Label = "User-Role"; userRoleRelation.System = true; userRoleRelation.RelationType = EntityRelationType.ManyToMany; userRoleRelation.TargetEntityId = userEntity.Id; userRoleRelation.TargetFieldId = userEntity.Fields.Single(x => x.Name == "id").Id; userRoleRelation.OriginEntityId = roleEntity.Id; userRoleRelation.OriginFieldId = roleEntity.Fields.Single(x => x.Name == "id").Id; { var result = rm.Create(userRoleRelation); if (!result.Success) throw new Exception("CREATE USER-ROLE RELATION:" + result.Message); } } #endregion #region << create system records >> { EntityRecord user = new EntityRecord(); user["id"] = SystemIds.SystemUserId; user["first_name"] = "Local"; user["last_name"] = "System"; user["password"] = Guid.NewGuid().ToString(); user["email"] = "*****@*****.**"; user["username"] = "******"; user["created_by"] = SystemIds.SystemUserId; user["last_modified_by"] = SystemIds.SystemUserId; user["created_on"] = DateTime.UtcNow; user["enabled"] = true; QueryResponse result = recMan.CreateRecord("user", user); if (!result.Success) throw new Exception("CREATE SYSTEM USER RECORD:" + result.Message); } { EntityRecord user = new EntityRecord(); user["id"] = SystemIds.FirstUserId; user["first_name"] = "WebVella"; user["last_name"] = "Erp"; user["password"] = "******"; user["email"] = "*****@*****.**"; user["username"] = "******"; user["created_by"] = SystemIds.SystemUserId; user["last_modified_by"] = SystemIds.SystemUserId; user["created_on"] = DateTime.UtcNow; user["enabled"] = true; QueryResponse result = recMan.CreateRecord("user", user); if (!result.Success) throw new Exception("CREATE FIRST USER RECORD:" + result.Message); } { EntityRecord adminRole = new EntityRecord(); adminRole["id"] = SystemIds.AdministratorRoleId; adminRole["name"] = "administrator"; adminRole["description"] = ""; adminRole["created_by"] = SystemIds.SystemUserId; adminRole["last_modified_by"] = SystemIds.SystemUserId; adminRole["created_on"] = DateTime.UtcNow; QueryResponse result = recMan.CreateRecord("role", adminRole); if (!result.Success) throw new Exception("CREATE ADMINITRATOR ROLE RECORD:" + result.Message); } { EntityRecord regularRole = new EntityRecord(); regularRole["id"] = SystemIds.RegularRoleId; regularRole["name"] = "regular"; regularRole["description"] = ""; regularRole["created_by"] = SystemIds.SystemUserId; regularRole["last_modified_by"] = SystemIds.SystemUserId; regularRole["created_on"] = DateTime.UtcNow; QueryResponse result = recMan.CreateRecord("role", regularRole); if (!result.Success) throw new Exception("CREATE REGULAR ROLE RECORD:" + result.Message); } { EntityRecord guestRole = new EntityRecord(); guestRole["id"] = SystemIds.GuestRoleId; guestRole["name"] = "guest"; guestRole["description"] = ""; guestRole["created_by"] = SystemIds.SystemUserId; guestRole["last_modified_by"] = SystemIds.SystemUserId; guestRole["created_on"] = DateTime.UtcNow; QueryResponse result = recMan.CreateRecord("role", guestRole); if (!result.Success) throw new Exception("CREATE GUEST ROLE RECORD:" + result.Message); } { QueryResponse result = recMan.CreateRelationManyToManyRecord(SystemIds.UserRoleRelationId, SystemIds.AdministratorRoleId, SystemIds.SystemUserId); if (!result.Success) throw new Exception("CREATE SYSTEM-USER <-> ADMINISTRATOR ROLE RELATION RECORD:" + result.Message); } { QueryResponse result = recMan.CreateRelationManyToManyRecord(SystemIds.UserRoleRelationId, SystemIds.AdministratorRoleId, SystemIds.FirstUserId); if (!result.Success) throw new Exception("CREATE FIRST-USER <-> ADMINISTRATOR ROLE RELATION RECORD:" + result.Message); result = recMan.CreateRelationManyToManyRecord(SystemIds.UserRoleRelationId, SystemIds.RegularRoleId, SystemIds.FirstUserId); if (!result.Success) throw new Exception("CREATE FIRST-USER <-> REGULAR ROLE RELATION RECORD:" + result.Message); } #endregion #region << create Area entity >> { InputEntity areaEntity = new InputEntity(); areaEntity.Id = SystemIds.AreaEntityId; areaEntity.Name = "area"; areaEntity.Label = "Area"; areaEntity.LabelPlural = "areas"; areaEntity.System = true; areaEntity.IconName = "folder"; areaEntity.Weight = 10; areaEntity.RecordPermissions = new RecordPermissions(); areaEntity.RecordPermissions.CanCreate = new List<Guid>(); areaEntity.RecordPermissions.CanRead = new List<Guid>(); areaEntity.RecordPermissions.CanUpdate = new List<Guid>(); areaEntity.RecordPermissions.CanDelete = new List<Guid>(); areaEntity.RecordPermissions.CanCreate.Add(SystemIds.AdministratorRoleId); areaEntity.RecordPermissions.CanRead.Add(SystemIds.RegularRoleId); areaEntity.RecordPermissions.CanRead.Add(SystemIds.AdministratorRoleId); areaEntity.RecordPermissions.CanUpdate.Add(SystemIds.AdministratorRoleId); areaEntity.RecordPermissions.CanDelete.Add(SystemIds.AdministratorRoleId); var systemItemIdDictionary = new Dictionary<string, Guid>(); systemItemIdDictionary["id"] = new Guid("19f16bdb-56e6-46bf-8310-2b42fd78be2a"); systemItemIdDictionary["created_on"] = new Guid("3e6be69e-8f25-40e4-9f21-86b0d1404230"); systemItemIdDictionary["created_by"] = new Guid("16fbba6c-6282-4828-9873-86b8fef745d4"); systemItemIdDictionary["last_modified_on"] = new Guid("5f076d8b-e587-4201-9481-67e19789ff6c"); systemItemIdDictionary["last_modified_by"] = new Guid("721b27b3-741d-4414-8783-a0245a4eec58"); systemItemIdDictionary["user_area_created_by"] = new Guid("5fe5fdc4-ee10-4661-93e7-25ea2a61e710"); systemItemIdDictionary["user_area_modified_by"] = new Guid("bb52122c-a354-4668-9423-71dfdc3d9f36"); { var createResponse = entMan.CreateEntity(areaEntity, false, false, systemItemIdDictionary); if (!createResponse.Success) throw new Exception("System error 10330. Message:" + createResponse.Message); } InputTextField color = new InputTextField(); color.Id = new Guid("2B4AACD9-3C34-4C44-B3A3-8AFF1520CFF6"); color.Name = "color"; color.Label = "Color"; color.PlaceholderText = ""; color.Description = ""; color.HelpText = ""; color.Required = true; color.Unique = false; color.Searchable = false; color.Auditable = false; color.System = true; color.DefaultValue = "teal"; color.MaxLength = null; { var createResponse = entMan.CreateField(SystemIds.AreaEntityId, color, false); if (!createResponse.Success) throw new Exception("System error 10340. Message:" + createResponse.Message); } InputTextField label = new InputTextField(); label.Id = new Guid("F050E7A1-AFB7-4346-B57B-1F12B2BD5AE5"); label.Name = "label"; label.Label = "Label"; label.PlaceholderText = ""; label.Description = ""; label.HelpText = ""; label.Required = true; label.Unique = false; label.Searchable = false; label.Auditable = false; label.System = true; label.DefaultValue = "Default"; label.MaxLength = null; { var createResponse = entMan.CreateField(SystemIds.AreaEntityId, label, false); if (!createResponse.Success) throw new Exception("System error 10340. Message:" + createResponse.Message); } InputTextField iconName = new InputTextField(); iconName.Id = new Guid("5EA0C872-D219-4D94-9EFA-C5DA978D316B"); iconName.Name = "icon_name"; iconName.Label = "Icon Name"; iconName.PlaceholderText = ""; iconName.Description = ""; iconName.HelpText = ""; iconName.Required = true; iconName.Unique = false; iconName.Searchable = false; iconName.Auditable = false; iconName.System = true; iconName.DefaultValue = "database"; iconName.MaxLength = null; { var createResponse = entMan.CreateField(SystemIds.AreaEntityId, iconName, false); if (!createResponse.Success) throw new Exception("System error 10340. Message:" + createResponse.Message); } InputNumberField weight = new InputNumberField(); weight.Id = new Guid("9B169431-6C31-4141-80EB-5844B8333E63"); weight.Name = "weight"; weight.Label = "Weight"; weight.PlaceholderText = ""; weight.Description = ""; weight.HelpText = ""; weight.Required = true; weight.Unique = false; weight.Searchable = false; weight.Auditable = false; weight.System = true; weight.DefaultValue = 10; weight.MinValue = 0; weight.DecimalPlaces = 2; { var createResponse = entMan.CreateField(SystemIds.AreaEntityId, weight, false); if (!createResponse.Success) throw new Exception("System error 10340. Message:" + createResponse.Message); } InputTextField attachments = new InputTextField(); attachments.Id = new Guid("288EA657-C12C-4AC1-B701-81D6F9F39363"); attachments.Name = "attachments"; attachments.Label = "Attachments JSON String"; attachments.PlaceholderText = ""; attachments.Description = "Stringified Array of attached objects"; attachments.HelpText = ""; attachments.Required = false; attachments.Unique = false; attachments.Searchable = false; attachments.Auditable = false; attachments.System = true; attachments.DefaultValue = null; attachments.MaxLength = null; { var createResponse = entMan.CreateField(SystemIds.AreaEntityId, attachments, false); if (!createResponse.Success) throw new Exception("System error 10340. Message:" + createResponse.Message); } InputTextField name = new InputTextField(); name.Id = new Guid("F297577B-073E-4D18-81F3-675C1AFB466D"); name.Name = "name"; name.Label = "Name"; name.PlaceholderText = ""; name.Description = ""; name.HelpText = ""; name.Required = true; name.Unique = false; name.Searchable = false; name.Auditable = false; name.System = true; name.DefaultValue = "default"; name.MaxLength = null; { var createResponse = entMan.CreateField(SystemIds.AreaEntityId, name, false); if (!createResponse.Success) throw new Exception("System error 10340. Message:" + createResponse.Message); } InputTextField roles = new InputTextField(); roles.Id = new Guid("8E486F76-D0C1-4D0E-8617-9EF868BF1C55"); roles.Name = "roles"; roles.Label = "Roles JSON String"; roles.PlaceholderText = ""; roles.Description = "Stringified Array of roles that have access to this area"; roles.HelpText = ""; roles.Required = false; roles.Unique = false; roles.Searchable = false; roles.Auditable = false; roles.System = true; roles.DefaultValue = null; roles.MaxLength = null; { var createResponse = entMan.CreateField(SystemIds.AreaEntityId, roles, false); if (!createResponse.Success) throw new Exception("System error 10340. Message:" + createResponse.Message); } #region << folder >> { InputTextField textboxField = new InputTextField(); textboxField.Id = new Guid("6a0fdf14-2d2b-4c6c-b2f1-4d846c7d5ab8"); textboxField.Name = "folder"; textboxField.Label = "folder"; textboxField.PlaceholderText = ""; textboxField.Description = ""; textboxField.HelpText = ""; textboxField.Required = false; textboxField.Unique = false; textboxField.Searchable = false; textboxField.Auditable = false; textboxField.System = true; textboxField.DefaultValue = string.Empty; textboxField.MaxLength = null; textboxField.EnableSecurity = true; textboxField.Permissions = new FieldPermissions(); textboxField.Permissions.CanRead = new List<Guid>(); textboxField.Permissions.CanUpdate = new List<Guid>(); //READ textboxField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); //UPDATE textboxField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); { var createResponse = entMan.CreateField(SystemIds.AreaEntityId, textboxField, false); if (!createResponse.Success) throw new Exception("System error 10060. Entity: area Field: folder" + " Message:" + response.Message); } } #endregion } #endregion } if (currentVersion < 20160430) { systemSettings.Version = 20160430; #region << plugin_data >> var PLUGIN_DATA_ID = new Guid("d928d031-c8b1-4359-be3e-39bceb58f268"); var PLUGIN_DATA_NAME = "plugin_data"; { #region << entity >> { InputEntity entity = new InputEntity(); entity.Id = PLUGIN_DATA_ID; entity.Name = PLUGIN_DATA_NAME; entity.Label = "Plugin Data"; entity.LabelPlural = "Plugin Data"; entity.System = true; entity.IconName = "database"; entity.Weight = 99; entity.RecordPermissions = new RecordPermissions(); entity.RecordPermissions.CanCreate = new List<Guid>(); entity.RecordPermissions.CanRead = new List<Guid>(); entity.RecordPermissions.CanUpdate = new List<Guid>(); entity.RecordPermissions.CanDelete = new List<Guid>(); //Create entity.RecordPermissions.CanCreate.Add(SystemIds.AdministratorRoleId); //READ entity.RecordPermissions.CanRead.Add(SystemIds.AdministratorRoleId); //UPDATE entity.RecordPermissions.CanUpdate.Add(SystemIds.AdministratorRoleId); //DELETE entity.RecordPermissions.CanDelete.Add(SystemIds.AdministratorRoleId); var systemItemIdDictionary = new Dictionary<string, Guid>(); systemItemIdDictionary["id"] = new Guid("bdb47d11-b8ee-42e9-8cd1-56e43246656b"); systemItemIdDictionary["created_on"] = new Guid("00f172b1-393b-4674-b6cd-32669dfb0924"); systemItemIdDictionary["created_by"] = new Guid("89379dbe-98ea-40b0-a794-a7cbf36201af"); systemItemIdDictionary["last_modified_on"] = new Guid("aaee0db8-d131-4273-b06a-a788757e24c3"); systemItemIdDictionary["last_modified_by"] = new Guid("eb0d2a71-4172-4293-87d7-d238a2153abf"); systemItemIdDictionary["user_plugin_data_created_by"] = new Guid("00e3f673-9dbc-4b57-b6d8-38d75e7d165a"); systemItemIdDictionary["user_plugin_data_modified_by"] = new Guid("c228125d-066c-415b-8c2a-a43ba2774411"); { var createResponse = entMan.CreateEntity(entity, false, false, systemItemIdDictionary); if (!createResponse.Success) throw new Exception("System error 10050. Entity: " + PLUGIN_DATA_NAME + " Field: entity creation" + " Message:" + response.Message); } } #endregion #region << name >> { InputTextField textboxField = new InputTextField(); textboxField.Id = new Guid("ab81aec7-da90-4ba8-8ac7-378faa01763f"); textboxField.Name = "name"; textboxField.Label = "Name"; textboxField.PlaceholderText = ""; textboxField.Description = ""; textboxField.HelpText = ""; textboxField.Required = true; textboxField.Unique = true; textboxField.Searchable = false; textboxField.Auditable = false; textboxField.System = true; textboxField.DefaultValue = string.Empty; textboxField.MaxLength = null; textboxField.EnableSecurity = true; textboxField.Permissions = new FieldPermissions(); textboxField.Permissions.CanRead = new List<Guid>(); textboxField.Permissions.CanUpdate = new List<Guid>(); //READ textboxField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); //UPDATE textboxField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); { var createResponse = entMan.CreateField(PLUGIN_DATA_ID, textboxField, false); if (!createResponse.Success) throw new Exception("System error 10060. Entity: " + PLUGIN_DATA_NAME + " Field: field_name" + " Message:" + response.Message); } } #endregion #region << data >> { InputTextField textboxField = new InputTextField(); textboxField.Id = new Guid("52a799ad-80a3-404b-99b5-1f58ce437982"); textboxField.Name = "data"; textboxField.Label = "Data"; textboxField.PlaceholderText = ""; textboxField.Description = ""; textboxField.HelpText = ""; textboxField.Required = false; textboxField.Unique = false; textboxField.Searchable = false; textboxField.Auditable = false; textboxField.System = true; textboxField.DefaultValue = string.Empty; textboxField.MaxLength = null; textboxField.EnableSecurity = true; textboxField.Permissions = new FieldPermissions(); textboxField.Permissions.CanRead = new List<Guid>(); textboxField.Permissions.CanUpdate = new List<Guid>(); //READ textboxField.Permissions.CanRead.Add(SystemIds.AdministratorRoleId); //UPDATE textboxField.Permissions.CanUpdate.Add(SystemIds.AdministratorRoleId); { var createResponse = entMan.CreateField(PLUGIN_DATA_ID, textboxField, false); if (!createResponse.Success) throw new Exception("System error 10060. Entity: " + PLUGIN_DATA_NAME + " Field: field_name" + " Message:" + response.Message); } } #endregion } #endregion } new DbSystemSettingsRepository().Save(new DbSystemSettings { Id = systemSettings.Id, Version = systemSettings.Version }); connection.CommitTransaction(); } catch (Exception ex) { var exception = ex; connection.RollbackTransaction(); throw; } } //recMan.ConvertNtoNRelations(); }
public EntityListResponse ReadEntities() { EntityListResponse response = new EntityListResponse { Success = true, Message = "The entity was successfully returned!", }; try { List<IStorageEntity> storageEntityList = EntityRepository.Read(); List<Entity> entities = storageEntityList.MapTo<Entity>(); EntityRelationManager relationManager = new EntityRelationManager(Storage); EntityRelationListResponse relationListResponse = relationManager.Read(); List<EntityRelation> relationList = new List<EntityRelation>(); if (relationListResponse.Object != null) relationList = relationListResponse.Object; List<RecordList> recordLists = new List<RecordList>(); List<RecordView> recordViews = new List<RecordView>(); List<Field> fields = new List<Field>(); foreach (var entity in entities) { recordLists.AddRange(entity.RecordLists); recordViews.AddRange(entity.RecordViews); fields.AddRange(entity.Fields); } foreach (var entity in entities) { #region Process Lists if (entity.RecordLists != null) { foreach (var recordList in entity.RecordLists) { if (recordList.Columns != null) { foreach (var column in recordList.Columns) { if (column is RecordListFieldItem) { Field field = fields.FirstOrDefault(f => f.Id == ((RecordListFieldItem)column).FieldId); if (field != null) { //((RecordListFieldItem)column).DataName = string.Format("$field${0}", field.Name); ((RecordListFieldItem)column).DataName = field.Name; ((RecordListFieldItem)column).FieldName = field.Name; ((RecordListFieldItem)column).Meta = field; ((RecordListFieldItem)column).EntityName = entity.Name; ((RecordListFieldItem)column).EntityLabel = entity.Label; ((RecordListFieldItem)column).EntityLabelPlural = entity.LabelPlural; } } if (column is RecordListRelationFieldItem) { Entity relEntity = GetEntityByFieldId(((RecordListRelationFieldItem)column).FieldId, entities); if (relEntity != null) { ((RecordListRelationFieldItem)column).EntityName = relEntity.Name; ((RecordListRelationFieldItem)column).EntityLabel = relEntity.Label; ((RecordListRelationFieldItem)column).EntityLabelPlural = entity.LabelPlural; } var relation = relationList.FirstOrDefault(r => r.Id == ((RecordListRelationFieldItem)column).RelationId); ((RecordListRelationFieldItem)column).RelationName = relation != null ? relation.Name : string.Empty; if (relation != null) { var relationOptions = recordList.RelationOptions.SingleOrDefault(x => x.RelationId == ((RecordListRelationFieldItem)column).RelationId); if (relationOptions != null) ((RecordListRelationFieldItem)column).RelationDirection = relationOptions.Direction; else ((RecordListRelationFieldItem)column).RelationDirection = "origin-target"; } Field field = fields.FirstOrDefault(f => f.Id == ((RecordListRelationFieldItem)column).FieldId); if (field != null) { ((RecordListRelationFieldItem)column).DataName = string.Format("$field${0}${1}", ((RecordListRelationFieldItem)column).RelationName, field.Name); ((RecordListRelationFieldItem)column).FieldName = field.Name; ((RecordListRelationFieldItem)column).Meta = field; } } if (column is RecordListViewItem) { RecordView view = recordViews.FirstOrDefault(v => v.Id == ((RecordListViewItem)column).ViewId); if (view != null) { ((RecordListViewItem)column).DataName = string.Format("$view${0}", view.Name); ((RecordListViewItem)column).ViewName = view.Name; ((RecordListViewItem)column).Meta = view; ((RecordListViewItem)column).EntityName = entity.Name; ((RecordListViewItem)column).EntityLabel = entity.Label; ((RecordListViewItem)column).EntityLabelPlural = entity.LabelPlural; } } if (column is RecordListRelationViewItem) { Entity relEntity = GetEntityByViewId(((RecordListRelationViewItem)column).ViewId, entities); if (relEntity != null) { ((RecordListRelationViewItem)column).EntityName = relEntity.Name; ((RecordListRelationViewItem)column).EntityLabel = relEntity.Label; ((RecordListRelationViewItem)column).EntityLabelPlural = entity.LabelPlural; } var relation = relationList.FirstOrDefault(r => r.Id == ((RecordListRelationViewItem)column).RelationId); ((RecordListRelationViewItem)column).RelationName = relation != null ? relation.Name : string.Empty; if (relation != null) { var relationOptions = recordList.RelationOptions.SingleOrDefault(x => x.RelationId == ((RecordListRelationViewItem)column).RelationId); if (relationOptions != null) ((RecordListRelationViewItem)column).RelationDirection = relationOptions.Direction; else ((RecordListRelationViewItem)column).RelationDirection = "origin-target"; } RecordView view = recordViews.FirstOrDefault(v => v.Id == ((RecordListRelationViewItem)column).ViewId); if (view != null) { ((RecordListRelationViewItem)column).DataName = string.Format("$view${0}${1}", ((RecordListRelationViewItem)column).RelationName, view.Name); ((RecordListRelationViewItem)column).ViewName = view.Name; ((RecordListRelationViewItem)column).Meta = view; } } if (column is RecordListListItem) { RecordList list = recordLists.FirstOrDefault(l => l.Id == ((RecordListListItem)column).ListId); if (list != null) { ((RecordListListItem)column).DataName = string.Format("list${0}", list.Name); ((RecordListListItem)column).ListName = list.Name; ((RecordListListItem)column).Meta = list; ((RecordListListItem)column).EntityName = entity.Name; ((RecordListListItem)column).EntityLabel = entity.Label; ((RecordListListItem)column).EntityLabelPlural = entity.LabelPlural; } } if (column is RecordListRelationListItem) { Entity relEntity = GetEntityByListId(((RecordListRelationListItem)column).ListId, entities); if (relEntity != null) { ((RecordListRelationListItem)column).EntityName = relEntity.Name; ((RecordListRelationListItem)column).EntityLabel = relEntity.Label; ((RecordListRelationListItem)column).EntityLabelPlural = entity.LabelPlural; } var relation = relationList.FirstOrDefault(r => r.Id == ((RecordListRelationListItem)column).RelationId); ((RecordListRelationListItem)column).RelationName = relation != null ? relation.Name : string.Empty; if (relation != null) { var relationOptions = recordList.RelationOptions.SingleOrDefault(x => x.RelationId == ((RecordListRelationListItem)column).RelationId); if (relationOptions != null) ((RecordListRelationListItem)column).RelationDirection = relationOptions.Direction; else ((RecordListRelationListItem)column).RelationDirection = "origin-target"; } RecordList list = recordLists.FirstOrDefault(l => l.Id == ((RecordListRelationListItem)column).ListId); if (list != null) { ((RecordListRelationListItem)column).DataName = string.Format("$list${0}${1}", ((RecordListRelationListItem)column).RelationName, list.Name); ((RecordListRelationListItem)column).ListName = list.Name; ((RecordListRelationListItem)column).Meta = list; } } if (column is RecordListRelationTreeItem) { Entity relEntity = GetEntityByTreeId(((RecordListRelationTreeItem)column).TreeId, entities); if (relEntity != null) { ((RecordListRelationTreeItem)column).EntityName = relEntity.Name; ((RecordListRelationTreeItem)column).EntityLabel = relEntity.Label; ((RecordListRelationTreeItem)column).EntityLabelPlural = entity.LabelPlural; } var relation = relationList.FirstOrDefault(r => r.Id == ((RecordListRelationTreeItem)column).RelationId); ((RecordListRelationTreeItem)column).RelationName = relation != null ? relation.Name : string.Empty; RecordTree tree = relEntity.RecordTrees.FirstOrDefault(l => l.Id == ((RecordListRelationTreeItem)column).TreeId); if (tree != null) { ((RecordListRelationTreeItem)column).DataName = string.Format("$tree${0}${1}", ((RecordListRelationTreeItem)column).RelationName, tree.Name); ((RecordListRelationTreeItem)column).TreeName = tree.Name; ((RecordListRelationTreeItem)column).Meta = tree; } } } } } } #endregion #region Process Views if (entity.RecordViews != null) { foreach (var recordView in entity.RecordViews) { if (recordView.Regions == null) continue; foreach (var region in recordView.Regions) { if (region.Sections == null) continue; foreach (var section in region.Sections) { if (section.Rows == null) continue; foreach (var row in section.Rows) { if (row.Columns == null) continue; foreach (var column in row.Columns) { if (column.Items == null) continue; foreach (var item in column.Items) { if (item is RecordViewFieldItem) { Field field = fields.FirstOrDefault(f => f.Id == ((RecordViewFieldItem)item).FieldId); if (field != null) { //((RecordViewFieldItem)item).DataName = string.Format("$field${0}", field.Name); ((RecordViewFieldItem)item).DataName = field.Name; ((RecordViewFieldItem)item).FieldName = field.Name; ((RecordViewFieldItem)item).Meta = field; ((RecordViewFieldItem)item).EntityId = entity.Id; ((RecordViewFieldItem)item).EntityName = entity.Name; ((RecordViewFieldItem)item).EntityLabel = entity.Label; ((RecordViewFieldItem)item).EntityLabelPlural = entity.LabelPlural; } } if (item is RecordViewListItem) { RecordList list = entity.RecordLists.FirstOrDefault(l => l.Id == ((RecordViewListItem)item).ListId); if (list != null) { ((RecordViewListItem)item).DataName = string.Format("$list${0}", list.Name); ((RecordViewListItem)item).Meta = list; ((RecordViewListItem)item).ListName = list.Name; ((RecordViewListItem)item).EntityId = entity.Id; ((RecordViewListItem)item).EntityName = entity.Name; ((RecordViewListItem)item).EntityLabel = entity.Label; ((RecordViewListItem)item).EntityLabelPlural = entity.LabelPlural; } } if (item is RecordViewViewItem) { RecordView recView = entity.RecordViews.FirstOrDefault(v => v.Id == ((RecordViewViewItem)item).ViewId); if (recView != null) { ((RecordViewViewItem)item).DataName = string.Format("$view${0}", recView.Name); ((RecordViewViewItem)item).Meta = recView; ((RecordViewViewItem)item).ViewName = recView.Name; ((RecordViewViewItem)item).EntityId = entity.Id; ((RecordViewViewItem)item).EntityName = entity.Name; ((RecordViewViewItem)item).EntityLabel = entity.Label; ((RecordViewViewItem)item).EntityLabelPlural = entity.LabelPlural; } } if (item is RecordViewRelationFieldItem) { Entity relEntity = GetEntityByFieldId(((RecordViewRelationFieldItem)item).FieldId, entities); if (relEntity != null) { ((RecordViewRelationFieldItem)item).EntityId = relEntity.Id; ((RecordViewRelationFieldItem)item).EntityName = relEntity.Name; ((RecordViewRelationFieldItem)item).EntityLabel = relEntity.Label; } var relation = relationList.FirstOrDefault(r => r.Id == ((RecordViewRelationFieldItem)item).RelationId); ((RecordViewRelationFieldItem)item).RelationName = relation != null ? relation.Name : string.Empty; if (relation != null) { var relationOptions = recordView.RelationOptions.SingleOrDefault(x => x.RelationId == ((RecordViewRelationFieldItem)item).RelationId); if (relationOptions != null) ((RecordViewRelationFieldItem)item).RelationDirection = relationOptions.Direction; else ((RecordViewRelationFieldItem)item).RelationDirection = "origin-target"; } Field field = fields.FirstOrDefault(f => f.Id == ((RecordViewRelationFieldItem)item).FieldId); if (field != null) { ((RecordViewRelationFieldItem)item).DataName = string.Format("$field${0}${1}", ((RecordViewRelationFieldItem)item).RelationName, field.Name); ((RecordViewRelationFieldItem)item).Meta = field; ((RecordViewRelationFieldItem)item).FieldName = field.Name; } } if (item is RecordViewRelationViewItem) { var relation = relationList.FirstOrDefault(r => r.Id == ((RecordViewRelationViewItem)item).RelationId); ((RecordViewRelationViewItem)item).RelationName = relation != null ? relation.Name : string.Empty; if (relation != null) { var relationOptions = recordView.RelationOptions.SingleOrDefault(x => x.RelationId == ((RecordViewRelationViewItem)item).RelationId); if (relationOptions != null) ((RecordViewRelationViewItem)item).RelationDirection = relationOptions.Direction; else ((RecordViewRelationViewItem)item).RelationDirection = "origin-target"; } Entity relEntity = GetEntityByViewId(((RecordViewRelationViewItem)item).ViewId, entities); if (relEntity != null) { ((RecordViewRelationViewItem)item).EntityId = relEntity.Id; ((RecordViewRelationViewItem)item).EntityName = relEntity.Name; ((RecordViewRelationViewItem)item).EntityLabel = relEntity.Label; RecordView view = relEntity.RecordViews.FirstOrDefault(f => f.Id == ((RecordViewRelationViewItem)item).ViewId); if (view != null) { ((RecordViewRelationViewItem)item).DataName = string.Format("$view${0}${1}", ((RecordViewRelationViewItem)item).RelationName, view.Name); ((RecordViewRelationViewItem)item).Meta = view; ((RecordViewRelationViewItem)item).ViewName = view.Name; } } } if (item is RecordViewRelationListItem) { var relation = relationList.FirstOrDefault(r => r.Id == ((RecordViewRelationListItem)item).RelationId); ((RecordViewRelationListItem)item).RelationName = relation != null ? relation.Name : string.Empty; if (relation != null) { var relationOptions = recordView.RelationOptions.SingleOrDefault(x => x.RelationId == ((RecordViewRelationListItem)item).RelationId); if (relationOptions != null) ((RecordViewRelationListItem)item).RelationDirection = relationOptions.Direction; else ((RecordViewRelationListItem)item).RelationDirection = "origin-target"; } Entity relEntity = GetEntityByListId(((RecordViewRelationListItem)item).ListId, entities); if (relEntity != null) { ((RecordViewRelationListItem)item).EntityId = relEntity.Id; ((RecordViewRelationListItem)item).EntityName = relEntity.Name; ((RecordViewRelationListItem)item).EntityLabel = relEntity.Label; ((RecordViewRelationListItem)item).EntityLabelPlural = relEntity.LabelPlural; RecordList list = relEntity.RecordLists.FirstOrDefault(f => f.Id == ((RecordViewRelationListItem)item).ListId); if (list != null) { ((RecordViewRelationListItem)item).DataName = string.Format("$list${0}${1}", ((RecordViewRelationListItem)item).RelationName, list.Name); ((RecordViewRelationListItem)item).Meta = list; ((RecordViewRelationListItem)item).ListName = list.Name; } } } if (item is RecordViewRelationTreeItem) { Entity relEntity = GetEntityByTreeId(((RecordViewRelationTreeItem)item).TreeId, entities); if (relEntity != null) { ((RecordViewRelationTreeItem)item).EntityId = relEntity.Id; ((RecordViewRelationTreeItem)item).EntityName = relEntity.Name; ((RecordViewRelationTreeItem)item).EntityLabel = relEntity.Label; ((RecordViewRelationTreeItem)item).EntityLabelPlural = entity.LabelPlural; } var relation = relationList.FirstOrDefault(r => r.Id == ((RecordViewRelationTreeItem)item).RelationId); ((RecordViewRelationTreeItem)item).RelationName = relation != null ? relation.Name : string.Empty; RecordTree tree = relEntity.RecordTrees.FirstOrDefault(l => l.Id == ((RecordViewRelationTreeItem)item).TreeId); if (tree != null) { ((RecordViewRelationTreeItem)item).DataName = string.Format("$tree${0}${1}", ((RecordViewRelationTreeItem)item).RelationName, tree.Name); ((RecordViewRelationTreeItem)item).TreeName = tree.Name; ((RecordViewRelationTreeItem)item).Meta = tree; } } } } } } } if (recordView.Sidebar != null) { foreach (var item in recordView.Sidebar.Items) { if (item is RecordViewSidebarListItem) { RecordList list = entity.RecordLists.FirstOrDefault(l => l.Id == ((RecordViewSidebarListItem)item).ListId); if (list != null) { ((RecordViewSidebarListItem)item).DataName = string.Format("$list${0}", list.Name); ((RecordViewSidebarListItem)item).Meta = list; ((RecordViewSidebarListItem)item).ListName = list.Name; ((RecordViewSidebarListItem)item).EntityId = entity.Id; ((RecordViewSidebarListItem)item).EntityName = entity.Name; ((RecordViewSidebarListItem)item).EntityLabel = entity.Label; ((RecordViewSidebarListItem)item).EntityLabelPlural = entity.LabelPlural; } } if (item is RecordViewSidebarViewItem) { RecordView recView = entity.RecordViews.FirstOrDefault(v => v.Id == ((RecordViewSidebarViewItem)item).ViewId); if (recView != null) { ((RecordViewSidebarViewItem)item).DataName = string.Format("$view${0}", recView.Name); ((RecordViewSidebarViewItem)item).Meta = recView; ((RecordViewSidebarViewItem)item).ViewName = recView.Name; ((RecordViewSidebarViewItem)item).EntityId = entity.Id; ((RecordViewSidebarViewItem)item).EntityName = entity.Name; ((RecordViewSidebarViewItem)item).EntityLabel = entity.Label; ((RecordViewSidebarViewItem)item).EntityLabelPlural = entity.LabelPlural; } } if (item is RecordViewSidebarRelationViewItem) { var relation = relationList.FirstOrDefault(r => r.Id == ((RecordViewSidebarRelationViewItem)item).RelationId); ((RecordViewSidebarRelationViewItem)item).RelationName = relation != null ? relation.Name : string.Empty; if (relation != null) { var relationOptions = recordView.RelationOptions.SingleOrDefault(x => x.RelationId == ((RecordViewSidebarRelationViewItem)item).RelationId); if (relationOptions != null) ((RecordViewSidebarRelationViewItem)item).RelationDirection = relationOptions.Direction; else ((RecordViewSidebarRelationViewItem)item).RelationDirection = "origin-target"; } Entity relEntity = GetEntityByViewId(((RecordViewSidebarRelationViewItem)item).ViewId, entities); if (relEntity != null) { ((RecordViewSidebarRelationViewItem)item).EntityId = relEntity.Id; ((RecordViewSidebarRelationViewItem)item).EntityName = relEntity.Name; ((RecordViewSidebarRelationViewItem)item).EntityLabel = relEntity.Label; RecordView view = relEntity.RecordViews.FirstOrDefault(f => f.Id == ((RecordViewSidebarRelationViewItem)item).ViewId); if (view != null) { ((RecordViewSidebarRelationViewItem)item).DataName = string.Format("$view${0}${1}", ((RecordViewSidebarRelationViewItem)item).RelationName, view.Name); ((RecordViewSidebarRelationViewItem)item).Meta = view; ((RecordViewSidebarRelationViewItem)item).ViewName = view.Name; } } } if (item is RecordViewSidebarRelationListItem) { var relation = relationList.FirstOrDefault(r => r.Id == ((RecordViewSidebarRelationListItem)item).RelationId); ((RecordViewSidebarRelationListItem)item).RelationName = relation != null ? relation.Name : string.Empty; if (relation != null) { var relationOptions = recordView.RelationOptions.SingleOrDefault(x => x.RelationId == ((RecordViewSidebarRelationListItem)item).RelationId); if (relationOptions != null) ((RecordViewSidebarRelationListItem)item).RelationDirection = relationOptions.Direction; else ((RecordViewSidebarRelationListItem)item).RelationDirection = "origin-target"; } Entity relEntity = GetEntityByListId(((RecordViewSidebarRelationListItem)item).ListId, entities); if (relEntity != null) { ((RecordViewSidebarRelationListItem)item).EntityId = relEntity.Id; ((RecordViewSidebarRelationListItem)item).EntityName = relEntity.Name; ((RecordViewSidebarRelationListItem)item).EntityLabel = relEntity.Label; ((RecordViewSidebarRelationListItem)item).EntityLabelPlural = relEntity.LabelPlural; RecordList list = relEntity.RecordLists.FirstOrDefault(f => f.Id == ((RecordViewSidebarRelationListItem)item).ListId); if (list != null) { ((RecordViewSidebarRelationListItem)item).DataName = string.Format("$list${0}${1}", ((RecordViewSidebarRelationListItem)item).RelationName, list.Name); ((RecordViewSidebarRelationListItem)item).Meta = list; ((RecordViewSidebarRelationListItem)item).ListName = list.Name; } } } if (item is RecordViewSidebarRelationTreeItem) { Entity relEntity = GetEntityByTreeId(((RecordViewSidebarRelationTreeItem)item).TreeId, entities); if (relEntity != null) { ((RecordViewSidebarRelationTreeItem)item).EntityName = relEntity.Name; ((RecordViewSidebarRelationTreeItem)item).EntityLabel = relEntity.Label; ((RecordViewSidebarRelationTreeItem)item).EntityLabelPlural = entity.LabelPlural; } var relation = relationList.FirstOrDefault(r => r.Id == ((RecordViewSidebarRelationTreeItem)item).RelationId); ((RecordViewSidebarRelationTreeItem)item).RelationName = relation != null ? relation.Name : string.Empty; RecordTree tree = relEntity.RecordTrees.FirstOrDefault(l => l.Id == ((RecordViewSidebarRelationTreeItem)item).TreeId); if (tree != null) { ((RecordViewSidebarRelationTreeItem)item).DataName = string.Format("$tree${0}${1}", ((RecordViewSidebarRelationTreeItem)item).RelationName, tree.Name); ((RecordViewSidebarRelationTreeItem)item).TreeName = tree.Name; ((RecordViewSidebarRelationTreeItem)item).Meta = tree; } } } } } } #endregion #region Process Trees if (entity.RecordTrees != null) { foreach (var recordTree in entity.RecordTrees) { foreach (RecordTreeNode node in recordTree.RootNodes) { IStorageRecordRepository recRep = Storage.GetRecordRepository(); var recData = recRep.Find(entity.Name, node.RecordId); if (recData != null) { var idField = entity.Fields.SingleOrDefault(x => x.Id == recordTree.NodeIdFieldId); if (idField == null) throw new Exception("Cannot initialize tree '" + recordTree.Name + "'. Node id field is missing in entity meta."); var parentIdField = entity.Fields.SingleOrDefault(x => x.Id == recordTree.NodeParentIdFieldId); if (parentIdField == null) throw new Exception("Cannot initialize tree '" + recordTree.Name + "'. Parent id field is missing in entity meta."); var nameField = entity.Fields.SingleOrDefault(x => x.Id == recordTree.NodeNameFieldId); if (nameField == null) throw new Exception("Cannot initialize tree '" + recordTree.Name + "'. Node name field is missing in entity meta."); var labelField = entity.Fields.SingleOrDefault(x => x.Id == recordTree.NodeLabelFieldId); if (labelField == null) throw new Exception("Cannot initialize tree '" + recordTree.Name + "'. Node label field is missing in entity meta."); var valuePair = recData.SingleOrDefault(x => x.Key == idField.Name); node.Id = (valuePair.Value as Guid?) ?? Guid.Empty; valuePair = recData.SingleOrDefault(x => x.Key == parentIdField.Name); node.ParentId = valuePair.Value as Guid?; valuePair = recData.SingleOrDefault(x => x.Key == nameField.Name); node.Name = (valuePair.Value ?? string.Empty).ToString(); valuePair = recData.SingleOrDefault(x => x.Key == labelField.Name); node.Label = (valuePair.Value ?? string.Empty).ToString(); } } } } #endregion } EntityList entityList = new EntityList(); entityList.Entities = entities; response.Object = entityList; } catch (Exception e) { response.Timestamp = DateTime.UtcNow; response.Success = false; #if DEBUG response.Message = e.Message + e.StackTrace; #else response.Message = "An internal error occurred!"; #endif return response; } response.Timestamp = DateTime.Now; return response; }