在sitecore中,如果我将新项目添加到主数据库(未发布),则不会显示有关已发布状态的任何指示.
例如,如果用户添加了10个项目,他可能会混淆以找出他正在等待发布的项目.
有没有办法将新添加的项目标识为未发布或新建,并在"快速操作栏"中显示验证?
Ruu*_*ier 18
从来没有想过这个,但它实际上很容易修复.
我创建了一个GutterRenderer表示项目已发布到至少一个,全部或没有发布目标的项目.
编辑:添加了点击行为.单击装订线图标时,将显示该项目的"发布"对话框.
首先,我将向您展示我为此编写的代码,然后我将向您展示设置和结果的屏幕截图.
这是代码:
using System.Collections.Generic;
using System.Linq;
using Sitecore;
using Sitecore.Data;
using Sitecore.Data.Items;
using Sitecore.Globalization;
using Sitecore.Shell.Applications.ContentEditor.Gutters;
namespace ParTech.Library.Gutters
{
public class PublicationStatus : GutterRenderer
{
private readonly ID publishingTargetsFolderId = new ID("{D9E44555-02A6-407A-B4FC-96B9026CAADD}");
private readonly ID targetDatabaseFieldId = new ID("{39ECFD90-55D2-49D8-B513-99D15573DE41}");
protected override GutterIconDescriptor GetIconDescriptor(Item item)
{
bool existsInAll = true;
bool existsInOne = false;
// Find the publishing targets item folder
Item publishingTargetsFolder = Context.ContentDatabase.GetItem(publishingTargetsFolderId);
if (publishingTargetsFolder == null)
{
return null;
}
// Retrieve the publishing targets database names
List<string> publishingTargetsDatabases = publishingTargetsFolder.GetChildren()
.Select(x => x[targetDatabaseFieldId])
.ToList();
// Check for item existance in publishing targets
publishingTargetsDatabases.ForEach(delegate(string databaseName)
{
if (Database.GetDatabase(databaseName).GetItem(item.ID) != null)
{
existsInOne = true;
}
else
{
existsInAll = false;
}
});
// Return descriptor with tooltip and icon
string tooltip = Translate.Text("This item has not yet been published");
string icon = "People/16x16/flag_red.png";
if (existsInAll)
{
tooltip = Translate.Text("This item has been published to all targets");
icon = "People/16x16/flag_green.png";
}
else if (existsInOne)
{
tooltip = Translate.Text("This item has been published to at least one target");
icon = "People/16x16/flag_yellow.png";
}
return new GutterIconDescriptor()
{
Icon = icon,
Tooltip = tooltip,
Click = string.Format("item:publish(id={0})", item.ID)
};
}
}
}
Run Code Online (Sandbox Code Playgroud)
这就是如何设置以及它在运行后的外观:
图1:在Core数据库中创建一个新的Gutter项:

图2:Master通过右键单击装订线区域,切换回数据库并激活装订线.

图3:Gutter现在指示您的项目的发布状态

| 归档时间: |
|
| 查看次数: |
2551 次 |
| 最近记录: |