diff --git a/src/Umbraco.Web/Models/Mapping/ContentTypeModelMapper.cs b/src/Umbraco.Web/Models/Mapping/ContentTypeModelMapper.cs index 07f5340822..ac88f6b111 100644 --- a/src/Umbraco.Web/Models/Mapping/ContentTypeModelMapper.cs +++ b/src/Umbraco.Web/Models/Mapping/ContentTypeModelMapper.cs @@ -36,7 +36,6 @@ namespace Umbraco.Web.Models.Mapping config.CreateMap(); config.CreateMap(); - config.CreateMap() .ConstructUsing((ContentTypeDisplay source) => new ContentType(source.ParentId)) @@ -56,7 +55,8 @@ namespace Umbraco.Web.Models.Mapping .ForMember(dto => dto.PropertyGroups, expression => expression.Ignore()) .AfterMap((source, dest) => { - foreach (var groupDisplay in source.Groups.Where(x => x.Name.IsNullOrWhiteSpace() == false ) ) + //get all properties from groups that are not generic properties (-666 id) + foreach (var groupDisplay in source.Groups.Where(x => x.Id != -666)) { //use underlying logic to add the property group which should wire most things up for us dest.AddPropertyGroup(groupDisplay.Name); @@ -70,6 +70,15 @@ namespace Umbraco.Web.Models.Mapping //dest.PropertyGroups.Add(Mapper.Map(groupDisplay)); } + //add generic properties + var genericProperties = source.Groups.FirstOrDefault(x => x.Id == -666); + if(genericProperties != null){ + foreach (var propertyTypeDisplay in genericProperties.Properties) + { + dest.AddPropertyType(Mapper.Map(propertyTypeDisplay)); + } + } + //Sync allowed child types var allowedTypes = source.AllowedContentTypes.Select((t, i) => new ContentTypeSort(t, i));