gpt4 book ai didi

css - Sitecore 多种 RTE 类样式

转载 作者:行者123 更新时间:2023-11-28 09:17:47 27 4
gpt4 key购买 nike

我可以为 RichTextEditor(RTE) 添加 CSS 样式路径,如下所示,我可以在 RTE 中选择定义的样式。

<configuration xmlns:patch="http://www.sitecore.net/xmlconfig/">
<sitecore>
<settings>
<setting name="WebStylesheet">
<patch:attribute name="value">/resources/customCSS.css</patch:attribute>
</setting>
</settings>
</sitecore>
</configuration>

但是,应该有两种或两种以上的CSS。例如, Angular 色 A 中的用户将只能看到 RTE 类列表中的“Role-A.css”,而 Angular 色 B 中的用户将只能看到 RTE 类列表中的“Role-B.css” .

我该如何实现?
有没有办法过滤类列表中显示的 CSS 路径??

最佳答案

开箱即用是不可能的,但实现起来相当容易。创建一个继承自 Sitecore.Shell.Controls.RichTextEditor.EditorConfiguration 的新类并覆盖 SetupStylesheets() 方法:

public class EditorConfiguration : Sitecore.Shell.Controls.RichTextEditor.EditorConfiguration
{
public EditorConfiguration(Item profile) : base(profile)
{
}

protected override void SetupStylesheets()
{
// if (user = X)
this.Editor.CssFiles.Add("/path/to/custom.css");

base.SetupStylesheets();
}
}

然后将富文本配置文件设置为使用这种新的配置类型。切换到核心数据库,然后转到元素 /sitecore/system/Settings/Html Editor Profiles/Rich Text Default/Configuration Type 并将 Type 字段设置为您的新类。如果您的特定配置文件不包含 Configuration Type 项,则复制或创建一个新项,或者在配置中设置“HtmlEditor.DefaultConfigurationType”。

与其对样式表进行硬编码,我建议您在内容树某处的设置中定义一组“样式表”,然后使用不同 Angular 色的安全性和权限来限制对它们的读取访问。然后您可以简单地读回元素列表,迭代并添加它们,例如

Stylesheets

然后在您的 SetupStylesheets() 方法中迭代元素。

protected override void SetupStylesheets()
{
var stylesheets = Sitecore.Context.ContentDatabase.GetItem("/sitecore/content/RTE-Stylesheets").Children.ToList();

foreach (var item in stylesheets)
{
this.Editor.CssFiles.Add(item["Stylesheet"]);
}

base.SetupStylesheets();
}

由于您限制了权限,因此只会返回并添加用户有权访问的样式表。

关于css - Sitecore 多种 RTE 类样式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28972564/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com