Как настроить редактор WordPress по умолчанию? - PullRequest
6 голосов
/ 11 января 2012

Приятно слышать, что Sony (wordpress3.3) имеет новый редактор api wp_editor () , который дает нам возможность использовать несколько экземпляров редактора в наших настраиваемых полях с легкость.

Но мне нужно было настроить редактор по умолчанию (для основного контента) и не мог понять, как это сделать с помощью этой функции. Мне нужно было настроить редактор для моего нового пользовательского типа записи под названием baner , для которого мне нужно было изменить размер редактора с меньшим количеством кнопок. Я знаю, что мог бы сделать это, просто используя вместо этого настраиваемое поле, но по какой-то причине я хочу использовать контент для описания баннера.

Заранее спасибо.

Ответы [ 3 ]

9 голосов
/ 18 мая 2012

Я искал решение для размещения настраиваемого метабокса над редактором по умолчанию, и я нашел решение моего старого вопроса (как настроить редактор по умолчанию с помощью wp_editor)!

Решение былосначала удалите редактор по умолчанию.Затем создайте другой метабокс, чтобы разместить контент, затем используйте wp_editor, чтобы создать новый его экземпляр, не так ли?

add_action( 'add_meta_boxes', 'page_meta_boxes' );
public function page_meta_boxes()
{

    global $_wp_post_type_features;
            //ive defined my other metaboxes first with higher priority
    add_meta_box(
        $id     =   'page_heading_meta_box',
        $title  =   __('Heading'),
        $callback   = array(&$this,'render_page_heading_metabox'),
        $post_type  =   'page',
        $context    =   'normal',
        $priority   =   'core'
        );
    add_meta_box(
        $id     =   'page_description_meta_box',
        $title  =   __('Description'),
        $callback   = array(&$this,'render_page_description_metabox'),
        $post_type  =   'page',
        $context    =   'normal',
        $priority   =   'core'
        );
    //check for the required post type page or post or <custom post type(here article)  
    if (isset($_wp_post_type_features['article']['editor']) && $_wp_post_type_features['post']['editor']) {
        unset($_wp_post_type_features['article']['editor']);
        add_meta_box(
            'wsp_content',
            __('Content'),
            array(&$this,'content_editor_meta_box'),
            'article', 'normal', 'core'
        );
    }
    if (isset($_wp_post_type_features['page']['editor']) && $_wp_post_type_features['page']['editor']) {
        unset($_wp_post_type_features['page']['editor']);
        add_meta_box(
            'wsp_content',
            __('Content'),
            array(&$this,'content_editor_meta_box'),
            'page', 'normal', 'low'
        );
    }
    }

Таким образом, мы зарегистрировали новый метабокс с именем content.Теперь время разместить редактор

        function content_editor_meta_box($post)
    {
        $settings = array(
            #media_buttons
            #(boolean) (optional) Whether to display media insert/upload buttons
            #Default: true
            'media_buttons' => true,

            #textarea_name
            #(string) (optional) The name assigned to the generated textarea and passed parameter when the form is submitted. (may include [] to pass data as array)
            #Default: $editor_id
            'textarea_name'=>'content',

            #textarea_rows
            #(integer) (optional) The number of rows to display for the textarea
            #Default: get_option('default_post_edit_rows', 10)

            #tabindex
            #(integer) (optional) The tabindex value used for the form field
            #Default: None
            'tabindex' => '4'

            #editor_css
            #(string) (optional) Additional CSS styling applied for both visual and HTML editors buttons, needs to #include <style> tags, can use "scoped"
            #Default: None

            #editor_class
            #(string) (optional) Any extra CSS Classes to append to the Editor textarea
            #Default:

            #teeny
            #(boolean) (optional) Whether to output the minimal editor configuration used in PressThis
            #Default: false

            #dfw
            #(boolean) (optional) Whether to replace the default fullscreen editor with DFW (needs specific DOM elements #and css)
            #Default: false

            #tinymce
            #(array) (optional) Load TinyMCE, can be used to pass settings directly to TinyMCE using an array()
            #Default: true

            #quicktags
            #(array) (optional) Load Quicktags, can be used to pass settings directly to Quicktags using an array()
            #Default: true
        );
        wp_editor($post->post_content,'content');

    }

Теперь вы можете полностью настроить свой редактор!Вот так это выглядит сейчас.Надеюсь, это будет полезно и вам!enter image description here

1 голос
/ 11 января 2012

Вы можете настроить редактор (TinyMCE) с помощью фильтра, как показано здесь .Прикрепленный фрагмент кода:

function myformatTinyMCE($in)
{
 $in['plugins']='inlinepopups,tabfocus,paste,media,fullscreen,wordpress,wpeditimage,wpgallery,wplink,wpdialogs,wpfullscreen';
 $in['wpautop']=true;
 $in['apply_source_formatting']=false;
 $in['theme_advanced_buttons1']='formatselect,forecolor,|,bold,italic,underline,|,bullist,numlist,blockquote,|,justifyleft,justifycenter,justifyright,justifyfull,|,link,unlink,|,wp_fullscreen,wp_adv';
 $in['theme_advanced_buttons2']='pastetext,pasteword,removeformat,|,charmap,|,outdent,indent,|,undo,redo';
 $in['theme_advanced_buttons3']='';
 $in['theme_advanced_buttons4']='';
 return $in;
}
add_filter('tiny_mce_before_init', 'myformatTinyMCE' );

Этот код должен быть помещен в файл functions.php вашей темы.Вы можете print_r( $in ) просмотреть все переданные ключи (некоторые из них здесь опущены, потому что я не верю, что страница, на которую я ссылался выше, актуальна).Вы можете просмотреть последний источник здесь .Вы найдете нужные фильтры в функции public static function editor_settings($editor_id, $set)

Кроме того, вы можете также убедиться, что это происходит только для вашего baner post_type, поскольку это повлияет на все экземплярыредактор, который создан.

0 голосов
/ 11 января 2012

Вы можете попробовать этот редактор , в который вы можете добавить дополнительные поля, также он прост в использовании и установке

...