カスタム分類法のタグクラウドを表示するようにデフォルトウィジェットを変更する方法
何も知らないが、あなたは簡単にあなた自身のものを作ることができる:
<?php
add_action("widgets_init", array('Widget_Custom_tax_tag_cloud', 'register'));
class Widget_Custom_tax_tag_cloud {
function control(){
echo 'No control panel';
}
function widget($args){
echo $args['before_widget'];
echo $args['before_title'] . 'Your widget title' . $args['after_title'];
$cloud_args = array('taxonomy' => 'Your taxonomy here');
wp_tag_cloud( $cloud_args );
echo $args['after_widget'];
}
function register(){
register_sidebar_widget('Widget name', array('Widget_Custom_tax_tag_cloud', 'widget'));
register_widget_control('Widget name', array('Widget_Custom_tax_tag_cloud', 'control'));
}
}
?>
ちょっと変更してください:あなたのタイトルとあなたの分類名であなたの 'ここでの分類'で 'あなたのウィジェットのタイトル'。
codex の大きなリストから$ cloud_argsにさらに引数を渡すことで、ルックアンドフィールを変更できます。
お役に立てれば。
ここでの既存の答えは素晴らしいです、しかし残念なことに答えの年齢のためにそれはWordPressのより新しいバージョンのために働かない。
以下のコードは2つの点で改善されています。
1 - version 2.8 以降、WordPressの新しいバージョンに推奨される/ベストプラクティスの方法です。
2 - ダッシュボード・ウィジェット・インターフェースを使用して、ハードコーディングするのではなく分類法を選択できます。
add_action( 'widgets_init', 'custom_register_plugin_widget' );
function custom_register_plugin_widget() {
register_widget( 'Widget_Custom_Tax_Tag_Cloud' );
}
/**
* New "best practice" is to extend the built-in WP_Widget class
*
* Class Widget_Custom_tax_tag_cloud
*/
class Widget_Custom_Tax_Tag_Cloud extends WP_Widget {
function __construct() {
parent::__construct( 'custom_tax_tag_cloud', 'Custom Taxonomy Tag Cloud', array( 'description' => 'Display a tag cloud for a custom taxonomy.' ) );
}
/**
* Allows for manipulation, calculation, etc. when saving the widget instance in the dashboard.
*
* @param array $new_instance
* @param array $old_instance
*
* @return array
*/
function update( $new_instance, $old_instance ) {
return $new_instance;
}
/**
* Echos the widget contents in a sidebar
*
* @param array $args - the general widget arguments
* @param array $instance - the settings for this specific widget
*/
function widget( $args, $instance ) {
echo $args['before_widget'];
echo $args['before_title'] . 'Your widget title' . $args['after_title'];
$cloud_args = array( 'taxonomy' => 'catalogtag' );
wp_tag_cloud( $cloud_args );
echo $args['after_widget'];
}
/**
* Render the "Controls" in the dashboard menu under Appearance => Widgets
*
* @param array $instance - the settings for this instance of the widget
*
* @return null
*/
function form( $instance ) {
$instance = wp_parse_args( (array) $instance, array( 'title' => '', 'taxonomy' => 'post_tag' ) );
// Load the list of taxonomies available
$taxonomies = get_taxonomies( array( 'public' => TRUE , 'show_tagcloud' => TRUE), 'objects' );
echo '<p><label>Title</label><input name="' . $this->get_field_name( 'title' ) . '" id="' . $this->get_field_id( 'title' ) . '" value="' . esc_attr( $instance['title'] ) . '" /></p>';
echo '<p><label>Taxonomy</label><select name="' . $this->get_field_name('taxonomy') . ' id="' . $this->get_field_id('taxonomy') . '">';
echo '<option value="">Select Taxonomy...</option>';
foreach($taxonomies AS $tax) {
echo '<option value="' . $tax->name . '"';
echo ($tax->name == $instance['taxonomy']) ? ' selected' : '';
echo '>';
echo ( ! empty($tax->labels->singular_name)) ? $tax->labels->singular_name : $tax->label;
echo '</option>';
}
echo '</select></p>';
}
}
技術的にはこれをテーマの関数ファイルに追加するだけでも構いませんが、私はそれを別のテーマファイル(widgets.php
など)に入れて、そのファイルを関数ファイルに含めることを好む傾向があります。