WordPress4.8よりテキストウィジェットの仕様が変わりました。
仕様変更により、ビジュアルエディターが利用できるようになり便利になった反面、テキスト入力すると勝手に段落が付加されてしまうといった不便な面もでできました。
詳しい問題点は以下を参照してください。
この問題に対処するため、「デフォルトがだめなら旧式のテキストウィジェットを作ってしまえばいいじゃない」ということで、「テーマをカスタマイズして旧タイプのテキストウィジェットを作成する方法」の紹介です。
目次
主な手順
今回のカスタマイズで行う主な手順はこれだけです。
- functions.phpにコードを貼り付ける
単にコピペ一発でカスタマイズすることができます。新たな機能を追加したりする場合は、その後、コードを編集してください。
functions.phpにコードを貼り付ける
クラシックタイプのテキストウィジェットをテーマ側で実装するには、以下のコードをfunctions.phpに追記してください。
/////////////////////////////////////////////////// //クラシックテキストウィジェットの追加 /////////////////////////////////////////////////// class DemoClassicTextWidget extends WP_Widget { public function __construct() { $widget_ops = array( 'classname' => 'classic-textwidget', 'description' => 'テキストエディターのみの旧タイプのテキストウィジェット(Wordpress4.8以前のビジュアルエディターのないテキストウィジェット)。' ); $control_ops = array( 'width' => 400, 'height' => 350 ); parent::__construct( 'DemoClassicTextWidget', 'クラシックテキストウィジェット', $widget_ops, $control_ops ); } public function widget( $args, $instance ) { $title = apply_filters( 'widget_title', empty( $instance['title'] ) ? '' : $instance['title'], $instance, $this->id_base ); $widget_text = ! empty( $instance['text'] ) ? $instance['text'] : ''; $text = apply_filters( 'classic_widget_text', $widget_text, $instance, $this ); echo $args['before_widget']; if ( ! empty( $title ) ) : echo $args['before_title'] . $title . $args['after_title']; endif; ?> <div class="classic-text-widget"><?php echo !empty( $instance['filter'] ) ? wpautop( $text ) : $text; ?></div> <?php echo $args['after_widget']; } //アップデート処理 public function update( $new_instance, $old_instance ) { $instance = $old_instance; $instance['title'] = sanitize_text_field( $new_instance['title'] ); if ( current_user_can( 'unfiltered_html' ) ){ $instance['text'] = $new_instance['text']; } else { $instance['text'] = wp_kses_post( $new_instance['text'] ); } $instance['filter'] = ! empty( $new_instance['filter'] ); return $instance; } //ウィジェット画面の入力フォーム public function form( $instance ) { $instance = wp_parse_args( (array) $instance, array( 'title' => '', 'text' => '' ) ); $filter = isset( $instance['filter'] ) ? $instance['filter'] : 0; $title = sanitize_text_field( $instance['title'] ); ?> <p><label for="<?php echo $this->get_field_id('title'); ?>">タイトル:</label> <input class="widefat" id="<?php echo $this->get_field_id('title'); ?>" name="<?php echo $this->get_field_name('title'); ?>" type="text" value="<?php echo esc_attr($title); ?>" /></p> <p><label for="<?php echo $this->get_field_id( 'text' ); ?>">内容:</label> <textarea class="widefat" rows="16" cols="20" id="<?php echo $this->get_field_id('text'); ?>" name="<?php echo $this->get_field_name('text'); ?>"><?php echo esc_textarea( $instance['text'] ); ?></textarea></p> <p><input id="<?php echo $this->get_field_id('filter'); ?>" name="<?php echo $this->get_field_name('filter'); ?>" type="checkbox"<?php checked( $filter ); ?> /> <label for="<?php echo $this->get_field_id('filter'); ?>">自動的に段落を追加する</label></p> <?php } } add_action('widgets_init', create_function('', 'return register_widget("DemoClassicTextWidget");'));
上記コードは、以下のClassic Text Widgetプラグインのコードを参考にさせていただきました。
参考 Classic Text Widget — WordPress Plugins
動作確認
functions.phpの編集を終えると、管理画面の「ウィジェット」設定に移動してください。
するとウィジェット設定画面に、以下のようなウィジェットが表示されます。
上記ウィジェットを、ウィジェットエリアに起動すると以下のように、ほぼ旧式のテキストウィジェットが表示されます。
あとは、旧テキストウィジェットのように利用するだけです。
やっぱ、「自動的に段落を追加する」機能が選択できるのは便利です。
まとめ
今回、Wordpress4.8で仕様変更されたテキストウィジェットが、少し使いづらかったため、旧式のテキストウィジェットの実装方法を調べてみました。
個人的には、長年使い親しんだ「旧テキストウィジェット」の方が使いやすく感じます。ただこれも、新式に慣れてしまえば、気にならなくなるのかもしれませんが。
とりあえず、今後のWordpressのアップデートで、テキストウィジェットの問題点が改善し、より使いやすいものになるかもしれません。ですので、カスタマイズする場合は、それを踏まえて行ってみてください。