2017-04-27 14 views

答えて

0

これは、いくつかのサイトコアのXMLコントロールをオーバーライドし、次のコードを使用して適用されます。

private void RenderRenderings(DeviceDefinition deviceDefinition, int selectedIndex, int index) 
    { 
     Assert.ArgumentNotNull(deviceDefinition, "deviceDefinition"); 
     ArrayList renderings = deviceDefinition.Renderings; 
     if (renderings == null) 
     { 
      return; 
     } 
     foreach (RenderingDefinition renderingDefinition in renderings) 
     { 
      if (renderingDefinition.ItemID != null) 
      { 
       Item item = Client.ContentDatabase.GetItem(renderingDefinition.ItemID); 
       XmlControl xmlControl = Resource.GetWebControl("DeviceRendering") as XmlControl; 
       Assert.IsNotNull(xmlControl, typeof(XmlControl)); 
       System.Web.UI.HtmlControls.HtmlGenericControl htmlGenericControl = new System.Web.UI.HtmlControls.HtmlGenericControl("div"); 
       htmlGenericControl.Style.Add("padding", "0"); 
       htmlGenericControl.Style.Add("margin", "0"); 
       htmlGenericControl.Style.Add("border", "0"); 
       htmlGenericControl.Style.Add("position", "relative"); 
       htmlGenericControl.Controls.Add(xmlControl); 
       string uniqueID = Control.GetUniqueID("R"); 
       this.Renderings.Controls.Add(htmlGenericControl); 
       htmlGenericControl.ID = Control.GetUniqueID("C"); 
       xmlControl["Click"] = "OnRenderingClick(\"" + index + "\")"; 
       xmlControl["DblClick"] = "device:edit"; 
       if (index == selectedIndex) 
       { 
        xmlControl["Background"] = "#D0EBF6"; 
       } 
       this.Controls.Add(uniqueID); 

       //Get DataSource item path 
       var datasource = string.Empty; 
       Sitecore.Data.Database master = Sitecore.Configuration.Factory.GetDatabase("master"); 
       if (!string.IsNullOrEmpty(renderingDefinition.Datasource)) 
       { 
        var dsItem = master.GetItem(renderingDefinition.Datasource); 
        if (dsItem != null) 
         datasource = dsItem.Paths.Path; 
       } 

       if (item != null) 
       { 
        xmlControl["ID"] = uniqueID; 
        xmlControl["Icon"] = item.Appearance.Icon; 
        xmlControl["Header"] = item.DisplayName; 
        xmlControl["Placeholder"] = WebUtil.SafeEncode(renderingDefinition.Placeholder); 
        xmlControl["DataSource"] = datasource; 
       } 
       else 
       { 
        xmlControl["ID"] = uniqueID; 
        xmlControl["Icon"] = "Applications/24x24/forbidden.png"; 
        xmlControl["Header"] = "Unknown rendering"; 
        xmlControl["Placeholder"] = string.Empty; 
        xmlControl["DataSource"] = string.Empty; 
       } 
       if (renderingDefinition.Rules != null && !renderingDefinition.Rules.IsEmpty) 
       { 
        int num = renderingDefinition.Rules.Elements("rule").Count<XElement>(); 
        if (num > 1) 
        { 
         System.Web.UI.HtmlControls.HtmlGenericControl htmlGenericControl2 = new System.Web.UI.HtmlControls.HtmlGenericControl("span"); 
         if (num > 9) 
         { 
          htmlGenericControl2.Attributes["class"] = "scConditionContainer scLongConditionContainer"; 
         } 
         else 
         { 
          htmlGenericControl2.Attributes["class"] = "scConditionContainer"; 
         } 
         htmlGenericControl2.InnerText = num.ToString(); 
         htmlGenericControl.Controls.Add(htmlGenericControl2); 
        } 
       } 
       RenderDeviceEditorRenderingPipeline.Run(renderingDefinition, xmlControl, htmlGenericControl); 
       index++; 
      } 
     } 
    } 

次のステップ更新し、次のファイルにある: \ Webサイト\のサイトコアの\シェル\オーバーライド\アプリケーション\レイアウト\ DeviceEditor.xml \ Webサイト\のサイトコアの\シェル\オーバーライド\アプリケーション\レイアウト\ DeviceRendering.xml

あなたは、次のブログ記事でソースコードを見つけることができます。

http://baraamasri.blogspot.com/2017/03/custom-device-editor_21.html

また、あなたがこれを行い、市場モジュールダウンロードすることができます。 https://marketplace.sitecore.net/Modules/C/Custom_Device_Editor.aspx

+0

確実なことを、行います。 –

+0

@Adriaan私は答えを更新しました、これがより良いことを願っています。 –

+0

@モハマドデバイスエディタダイアログの前に開くレイアウトの詳細ダイアログで、同じ機能を実装するために変更する必要があるクラスとXMLファイルを教えてください。それは私のために非常に役立つでしょう –

関連する問題