Orchard CMS を学習中で、カスタム タイプを作成しようとしました。さまざまなチュートリアルに従い、モデル クラスと Migration.cs を作成したところ、Orchard のリストされたコンテンツ パーツの下に自分のパーツが表示されるのを確認できました。
次に、ドライバー、ハンドラー、ビュー、placement.info を追加しました。しかし、パーツを含むアイテムを作成または表示するときに、新しいパーツのフィールドを表示できません。パーツのフィールドがあるはずのアイテムが空です。
これが私の Views/Parts/Event.cshtml です:
@using Orchard.ContentManagement.ViewModels
@using Orchard.ContentManagement
@using Orchard.Core.Common.Models
<div class="event-container">
<div class="event-text">
<p>Event Name: @Model.EventName</p>
</div>
<div>
<p>Event ID: @Model.EventID</p>
</div>
<div>
<p>Description: @Model.Description</p>
</div>
</div>
ここに私の Views/EditorTemplates/Event.cshtml があります:
@using System.Web.Mvc.Html
@using Orchard.Event.Models
@model Orchard.Event.Models.EventPart
<fieldset>
<legend>@T("Event Fields")</legend>
<div class="editor-field">
@Html.LabelFor(x => x.EventName, T("Event Name"))
@Html.EditorFor(x => x.EventName)
@Html.ValidationMessageFor(x => x.EventName)
</div>
<div class="hint">@T("Enter the Event Name")</div>
<div class="editor-field">
@Html.LabelFor(x => x.EventID, T("Event ID"))
@Html.EditorFor(x => x.EventID)
@Html.ValidationMessageFor(x => x.EventID)
</div>
<div class="hint">@T("Enter the Event ID")</div>
<div class="editor-field">
@Html.LabelFor(x => x.Description, T("Description"))
@Html.EditorFor(x => x.Description)
@Html.ValidationMessageFor(x => x.Description)
</div>
<div class="hint">@T("Enter the Description")</div>
</fieldset>
運転者:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Orchard.ContentManagement;
using Orchard.ContentManagement.Drivers;
using Orchard.ContentManagement.Handlers;
using Orchard.Event.Models;
namespace Orchard.Event.Drivers
{
public class EventPartDriver : ContentPartDriver<EventPart>
{
protected override string Prefix
{
get
{ return "Event"; }
}
protected override DriverResult Editor(EventPart part, dynamic shapeHelper)
{
return ContentShape("Parts_Event_Edit", () => shapeHelper
.EditorTemplate(TemplateName: "Parts/Event", Model: part, Prefix: Prefix));
}
protected override DriverResult Editor(EventPart part, IUpdateModel updater, dynamic shapeHelper)
{
updater.TryUpdateModel(part, Prefix, null, null);
return Editor(part, shapeHelper);
}
protected override DriverResult Display(EventPart part, string displayType, dynamic shapeHelper)
{
return ContentShape("Parts_Event",
() => shapeHelper.Parts_Event(
EventName: part.EventName,
EventID: part.EventID,
Description: part.Description
));
}
}
}
Placement.info:
<Placement>
<place Parts_Event="Content:10"/>
<place Parts_Event_Edit="Content:7.5"/>
</Placement>
どんなアイデアでも大歓迎です。これらをチュートリアルと比較しましたが、紙の上ではすべてが正しいようです。