1

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>

どんなアイデアでも大歓迎です。これらをチュートリアルと比較しましたが、紙の上ではすべてが正しいようです。

4

1 に答える 1