12

我正在尝试在 Joomla 的文章编辑器中插入一个额外的按钮。它在扩展模式下使用默认的 TinyMCE 插件。如您所知,编辑器下方有 4 个按钮(文章、图像、分页符和阅读更多)。我想做的是插入第 5 个按钮。(我确实附上了一个图片按钮,所以说我不能发布至少需要 10 个代表点。)

我尝试复制分页按钮插件并重命名它等,然后将其重新安装为新插件,但所有这些都会导致 TinyMCE 出现错误并且没有按钮出现。

问题:如何插入按钮?

4

2 回答 2

9

我继续进行了广泛的搜索,并找到了有关在 Joomla 1.5 的文章编辑器中添加附加按钮的指南。

该教程位于:http: //tushev.org/articles/programming/18-how-to-create-an-editor-button-editors-xtd-plugin-for-joomla

开箱即用,这不适用于 Joomla 2.5 和 Joomla 3.0,因为 XML 清单标准已经发生了微小的变化。为了与本教程保持一致,请改用此 XML 清单。

<?xml version="1.0" encoding="utf-8"?>
<extension version="2.5" type="plugin" method="upgrade" group="editors-xtd">
        <name>test</name>
        <author>Name</author>
        <creationDate>Month 2013</creationDate>
        <copyright>Month Name. All rights reserved.</copyright>
        <license>GPL</license>
        <authorEmail>Email</authorEmail>
        <authorUrl>Your URL</authorUrl>
        <version>1.0.0</version>
        <description>
            "adds the button 'test' to the editor"
        </description>
        <files>
            <filename plugin="test">test.php</filename>
        </files>
</extension>

教程PHP是正确的,如下:

<?php

 // no direct access
defined( '_JEXEC' ) or die( 'Restricted access' );

jimport( 'joomla.plugin.plugin' );

class plgButtonTest extends JPlugin {

    function plgButtonTest(& $subject, $config)
    {
        parent::__construct($subject, $config);
    }
    function onDisplay($name)
    {
        $js =  "                      
         function buttonTestClick(editor) {
                             txt = prompt('Please enter something','123');
                             if(!txt) return;
                               jInsertEditorText('{test '+txt+'}', editor);
        }";
        $css = ".button2-left .testButton {
                    background: transparent url(/plugins/editors-xtd/test.png) no-repeat 100% 0px;
                }";
        $doc = & JFactory::getDocument();
        $doc->addScriptDeclaration($js);
        $doc->addStyleDeclaration($css);
        $button = new JObject();
        $button->set('modal', false);
        $button->set('onclick', 'buttonTestClick(\''.$name.'\');return false;');
        $button->set('text', JText::_('Test'));
        $button->set('name', 'testButton');
        $button->set('link', '#');
        return $button;
    }
}
?>

感谢大家的帮助。如果您有任何其他更好的方法,我将不胜感激。

于 2012-12-07T09:10:14.750 回答
4

如果您的插件安装成功,那么您必须将您的插件名称放入插件 Custom pluginCustom button的高级参数设置中。tinymce并确保您安装的插件已发布。例如,请参见下图。

这是我设置为启用的自定义插件。请参阅此图像: 在此处输入图像描述

然后在tinymce插件中转到高级参数并在最后看到自定义字段选项。请参阅此图像:

在此处输入图像描述

输入插件名称和按钮名称。然后在文章管理器编辑器中找到您的按钮。

于 2012-12-06T14:10:22.570 回答