Як додати кнопку короткого коду до редактора TinyMCE?


34

Як зробити будь-яку піктограму плагіна в публікації Wordpress? Код, який я хочу вставити у код плагіна, і з’явиться на панелі повідомлень [wp-admin / post.php].

Подобається це зображення:

введіть тут опис зображення

Вихід: Якщо я натискаю на піктограму, вона автоматично записується [plugin]на вміст публікації, як це:

введіть тут опис зображення


Додайте знімок екрана результату, який потрібно отримати. Не ясно, що ви хочете.
фуксія

Я думаю, ви хочете створити плагін, який додає кнопку редактора TinyMCE до редактора, який вставляє короткий код WordPress, правда?
developmentdaly

Відповіді:


65

Щоб додати нашу кнопку до редактора TinyMCE, нам потрібно зробити кілька речей:

  1. Додайте нашу кнопку на панель інструментів
  2. Зареєструйте плагін TinyMCE
  3. Створіть той плагін TinyMCE, який підкаже TinyMCE, що робити, коли натискаємо нашу кнопку.

Кроки №1 та №2

У цьому кроці ми реєструємо наш плагін TinyMCE, який буде жити у файлі javascript за адресою 'path/to/shortcode.js'(див. wpse72394_register_tinymce_plugin()Нижче)

 // init process for registering our button
 add_action('init', 'wpse72394_shortcode_button_init');
 function wpse72394_shortcode_button_init() {

      //Abort early if the user will never see TinyMCE
      if ( ! current_user_can('edit_posts') && ! current_user_can('edit_pages') && get_user_option('rich_editing') == 'true')
           return;

      //Add a callback to regiser our tinymce plugin   
      add_filter("mce_external_plugins", "wpse72394_register_tinymce_plugin"); 

      // Add a callback to add our button to the TinyMCE toolbar
      add_filter('mce_buttons', 'wpse72394_add_tinymce_button');
}


//This callback registers our plug-in
function wpse72394_register_tinymce_plugin($plugin_array) {
    $plugin_array['wpse72394_button'] = 'path/to/shortcode.js';
    return $plugin_array;
}

//This callback adds our button to the toolbar
function wpse72394_add_tinymce_button($buttons) {
            //Add the button ID to the $button array
    $buttons[] = "wpse72394_button";
    return $buttons;
}

Крок №3

Тепер нам потрібно створити наш плагін TinyMCE. Це відбудеться у файлі 'path/to/shortcode.js'(як зазначено на перших етапах).

jQuery(document).ready(function($) {

    tinymce.create('tinymce.plugins.wpse72394_plugin', {
        init : function(ed, url) {
                // Register command for when button is clicked
                ed.addCommand('wpse72394_insert_shortcode', function() {
                    selected = tinyMCE.activeEditor.selection.getContent();

                    if( selected ){
                        //If text is selected when button is clicked
                        //Wrap shortcode around it.
                        content =  '[shortcode]'+selected+'[/shortcode]';
                    }else{
                        content =  '[shortcode]';
                    }

                    tinymce.execCommand('mceInsertContent', false, content);
                });

            // Register buttons - trigger above command when clicked
            ed.addButton('wpse72394_button', {title : 'Insert shortcode', cmd : 'wpse72394_insert_shortcode', image: url + '/path/to/image.png' });
        },   
    });

    // Register our TinyMCE plugin
    // first parameter is the button ID1
    // second parameter must match the first parameter of the tinymce.create() function above
    tinymce.PluginManager.add('wpse72394_button', tinymce.plugins.wpse72394_plugin);
});

1
На кроці 1 зміна initгака на admin_initгачок також може заощадити невелику додаткову обробку на передній частині.
Тім Малоун

Це залежить, ви можете мати TinyMCE і на передній частині. Але так, якщо це стосується лише адміністратора, admin_initбуло б краще.
Стівен Харріс

5

Тут занадто багато, щоб викласти всю відповідь, тому перегляньте цей посібник: http://wp.smashingmagazine.com/2012/05/01/wordpress-shortcodes-complete-guide/

Ви повинні створити файл Javascript, який виконує дії за допомогою кнопки, яку ви зареєструєте через WordPress, яка вставляє кнопку TinyMCE в редактор.


3
Використовує query_posts, тому, можливо, не найкращий приклад для посилання.
Бред Далтон
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.