我有一个要求,当编辑器点击Unpublish菜单命令时,我需要显示警告/弹出窗口。我将使用是/否按钮显示弹出窗口,如果选择是,我们继续并显示现有的UnPub屏幕。如果选择否则不会发生任何活动,用户返回到屏幕。
如何实现这一目标?
我们可以扩展/覆盖现有的CME命令,而无需为自己创建新的命令吗?
答案 0 :(得分:8)
我昨天刚刚学会了如何做到这一点(感谢Nuno Linhares) - 你需要熟悉为GUI创建一个新的编辑器。
下一步是找到要覆盖的命令的名称(在您的情况下可能是“UnPublish”)。最简单的方法是在GUI中使用Chrome或FieFox的“inspect element”,并在要扩展的按钮上查找类似c:command="UnPublish"
的内容。
设置完基本编辑器后,需要添加新命令来覆盖现有的命令:
<extensions>
<ext:dataextenders />
<ext:editorextensions>
<ext:editorextension target="CME">
<ext:editurls />
<ext:listdefinitions />
<ext:taskbars />
<ext:commands />
<ext:commandextensions>
<ext:commands>
<ext:command name="UnPublish" extendingcommand="CustomUnPublishCommand"/>
</ext:commands>
<ext:dependencies>
<cfg:dependency>CustomUnPublish.CommandSet</cfg:dependency>
</ext:dependencies>
</ext:commandextensions>
<ext:contextmenus />
<ext:lists />
<ext:tabpages />
<ext:toolbars />
<ext:ribbontoolbars />
</ext:editorextension>
</ext:editorextensions>
</extensions>
以正常方式添加所有依赖项(JS和CSS等)和命令引用。
然后像编写任何其他GUI命令一样编写JS执行函数,并在处理弹出窗口后调用现有命令,如下所示:
CustomUnPublish.prototype._execute = function CustomUnPublish$_execute(selection, pipeline) {
//Insert some logic to make a popup and confirm
blnOkToProceed = true;
//
if (blnOkToProceed) {
//EDIT: Original code
$cme.getCommand("UnPublish")._execute(selection, pipeline);
//EDIT: Or using the suggestion from @Peter below
$commands.executeCommand("UnPublish", selection, pipeline);
//End Edit
}
return;
};