在果园建立1-1关系

时间:2014-01-20 14:08:13

标签: orchardcms orchardcms-1.7

在果园中创建1-1关系时出现问题,无法保存下拉列表中所选项目的值。如果有人指出我如何解决这个问题的正确方向,那么会很高兴。

联系部件驱动程序

 public class ContactPartDriver : ContentPartDriver<ContactPart>
    {
        private readonly IContactService _contactService;
        public ContactPartDriver(IContactService contactService)
        {
            _contactService = contactService;
        }
        protected override string Prefix
        {
            get
            {
                    return "Contact";
            }
        }
        protected override DriverResult Display(ContactPart part, 
                         string displayType, dynamic shapeHelper)
        {
            return ContentShape("Parts_Contactindex1",
                        () => shapeHelper.Parts_Contactindex1(
                            ContentPart: part,
                            Address: part.Address,
                             Name : part.Name,
                            EmailId: part.EmailId,
                            StateCode: part.Source.Id
                           ));
        }
        //Get
        protected override DriverResult Editor(ContactPart part, dynamic shapeHelper)
        {
               return ContentShape("Parts_Contact_Edit", () =>
          shapeHelper.EditorTemplate(TemplateName: "Parts/Contactindex1", 
        Model:BuildEditorViewModel(part), Prefix: Prefix));
        }
        //Post
        protected override DriverResult Editor(ContactPart part,
               IUpdateModel updater, dynamic shapeHelper)
        {
            var model = new EditContactViewModel();
             updater.TryUpdateModel(part, Prefix, null, null);
             //if (part.ContentItem.Id != 0)
             //{
             //   _contactService.UpdateContactForContentItem(part.ContentItem, model);

             //}
             return Editor(part, shapeHelper);
        }

        private EditContactViewModel BuildEditorViewModel(ContactPart part)
        {
            var model = new EditContactViewModel {
                Name = part.Name,
                Address = part.Address,
                EmailId = part.EmailId,

                Sources = _contactService.GetSource()

            };
            return model;
            }
        }

 }

联系处理程序

 public class ContactHandler :ContentHandler
    {
       public ContactHandler (IRepository<ContactPartRecord> respository)
        {

            Filters.Add(StorageFilter.For(respository));

        }
    }

模型ContactPart

{
    public class ContactPart : ContentPart<ContactPartRecord>
    {

        public string Name
        {
            get { return Retrieve(x => x.Name); }
            set { Store(x => x.Name, value); }
        }
        public string Address
        {
            get { return Retrieve(x => x.Address); }
            set { Store(x => x.Address, value); }
        }
        public string EmailId
        {
            get { return Retrieve(x => x.EmailId); }
            set { Store(x => x.EmailId, value); }
        }

       public SourceRecord Source
        {
            get { return Retrieve(x => x.SourceRecord); }
           set {Store(x => x.SourceRecord,value);}

        }

    }
}

ContactPartRecord

{
    public class ContactPartRecord : ContentPartRecord
    {

        public virtual string Name { get; set; }
        public virtual string Address { get; set; }
        public virtual string EmailId { get; set; }
        public virtual SourceRecord SourceRecord { get; set; }

    }
}

记录部分

{
    public class SourceRecord
    {
        public virtual int Id { get; set; }
        public virtual string Type { get; set; }

    }

}

联系服务

 {
    public interface IContactService : IDependency {
        void UpdateContactForContentItem(ContentItem item, EditContactViewModel model);
        IEnumerable<SourceRecord> GetSource();
    }

    public class ContactService : IContactService
    {
        private readonly IRepository<SourceRecord> _sourceRepository;

        public ContactService(IRepository<SourceRecord> sourceRepository)
        {
            _sourceRepository = sourceRepository;
        }

        public void UpdateContactForContentItem(ContentItem item, EditContactViewModel model)
        {
            var contactPart = item.As<ContactPart>();
            contactPart.Address = model.Address;
            contactPart.Name = model.Name;
            contactPart.EmailId = model.EmailId;
            contactPart.Source = _sourceRepository.Get(s => s.Id == model.SourceId);
        }

        public IEnumerable<SourceRecord> GetSource()
        {
            return _sourceRepository.Table.ToList();
        }
    }
}

EditContactViewModel

{
    public class EditContactViewModel
    {
        public string Name { get; set; }
        public  string Address{ get; set; }
        public string  EmailId { get; set; }
        public int SourceId { get; set; }
        public IEnumerable<SourceRecord>  Sources{ get; set; }
    }
}

联络视图

@using Cess.Contacts.ViewModel;
@model  EditContactViewModel

<fieldset>
    <legend>New Contact</legend>
    @Html.LabelFor(m =>m.Name)
    @Html.EditorFor(m => m.Name)
    @Html.LabelFor(m => m.Address)
    @Html.TextAreaFor(m => m.Address)
    @Html.LabelFor(m => m.EmailId)
    @Html.EditorFor(m => m.EmailId)
    <p>
    @Html.DropDownListFor(model => model.Sources,
                      Model.Sources.Select(s => new SelectListItem
                      {
                          Selected = s.Id == Model.SourceId,
                          Text = s.Type ,
                          Value = s.Id.ToString()
                      }),
                      "Choose a Source...")
    </p>
</fieldset>

2 个答案:

答案 0 :(得分:2)

http://docs.orchardproject.net/Documentation/Creating-1-n-and-n-n-relations 然而,在你的View中,下拉列表并没有真正保留SourceId,不是吗? 改为:

@Html.DropDownListFor(model => model.SourceId,
                      Model.Sources.Select(s => new SelectListItem
                      {
                          Selected = s.Id == Model.SourceId,
                          Text = s.Type ,
                          Value = s.Id.ToString()
                      }),
                      "Choose a Source...")

将允许再次检查表格。

答案 1 :(得分:2)

ErMasca正确地指出了一个错误。

同样在您的ContentPart中,您需要使用Record.SourceRecord来访问导航属性。

public SourceRecord Source()
{
  get { return Record.SourceRecord; }
  set { Record.SourceRecord = value; }
}