ダッシュボードに表示されるプラグイン情報を非表示にする

Filed under: functions.php,wordpressプラグイン — kdcs @ 24年9月12日 木曜日

Smash Balloon Social Photo Feedを6.5.0にしたらダッシュボードにプラグインの情報が表示されるようになった。
編集者権限や投稿者権限でも表示されてしまい、管理者以外プラグインの操作ができないようにしているので、プラグインへのリンクをクリックしても「アクセスする権限がありません」となる。

この表示は邪魔なので管理者以外は非表示にする方法
functions.php

//ダッシュボードウィジェット「Smash Balloon Social Photo Feed」非表示 --------------------
function sb_remove_dashboard_widgets() {
  if (!current_user_can('administrator')) {
     remove_meta_box('sb_dashboard_widget', 'dashboard', 'normal');
    }
}
add_action('wp_dashboard_setup', 'sb_remove_dashboard_widgets');

この記述でダッシュボードの表示オプションにも「Smash Balloon」は出なくなる

投稿者が作成する記事内にjavascriptが使用できるようにする

Filed under: functions.php,wordpress — kdcs @ 23年9月4日 月曜日

WordPressのデフォルトでは管理者と編集者以外、記事内にjavascriptを使うことができない。
※入力しても強制削除される

権限のカスタマイズでjavascriptが入力できるようにする
※投稿者のユーザー情報が漏れるとセキュリティーリスクが伴う

functions.phpに記述

function add_theme_caps(){
    $role = get_role( 'author' );
    $role->add_cap( 'unfiltered_html' );
}
add_action( 'admin_init', 'add_theme_caps' );

get_roleで指定できる権限グループは以下になります。

管理者 : administrator
編集者 : editor
投稿者 : author
寄稿者 : contributor
購読者 : subscriber

WordPress 自動ログアウト

Filed under: functions.php,wordpress — kdcs @ 23年5月29日 月曜日

ログイン時から一定の時間が経過すると自動でログアウトさせる。
時間設定どおり、操作中でもログアウトする。

functions.phpに以下記述

// 一定期間経過で自動ログアウト
add_filter( 'auth_cookie_expiration', 'stay_logged_in' );
function stay_logged_in( $expire ) {
 return 86400; // 60秒 * 60分 * 24時間=1日
}

ログインの後、一定時間操作が無い場合に自動でログアウトさせる。

//一定時間操作がない場合に自動ログアウト
add_action( ‘admin_init’, ‘mytheme_admin_init’ );
function mytheme_admin_init() {
add_filter( ‘auth_cookie_expiration’, ‘mytheme_auth_cookie_expiration’, 10, 3 );
$user = wp_get_current_user();
wp_set_auth_cookie( $user->ID, true );
}
function mytheme_auth_cookie_expiration( $expiration, $user_id, $remember ) {
if ( $remember ) $expiration = 3600; // 60秒 * 60分 =1時間
return $expiration;
}

WordPress 投稿一覧に最終更新日を追加する

Filed under: functions.php,wordpress — kdcs @ 23年4月21日 金曜日

WordPress 投稿一覧に最終更新日を追加する
functions.php

// 投稿一覧に最終更新日を表示する並び替えも可 ------------------------------------------------------
add_filter( 'manage_edit-post_columns', 'aco_last_modified_admin_column' );
 
// 最終更新日の列を作成
function aco_last_modified_admin_column( $columns ) {
  $columns['modified-last'] =__( '最終更新日', 'aco' );
  return $columns;
}
add_filter( 'manage_edit-post_sortable_columns', 'aco_sortable_last_modified_column' );
 
// 最終更新した時間で記事を並べ替える
function aco_sortable_last_modified_column( $columns ) {
  $columns['modified-last'] = 'modified';
  return $columns;
}
add_action( 'manage_posts_custom_column', 'aco_last_modified_admin_column_content', 10, 2 );
 
// 出力をフォーマット
function aco_last_modified_admin_column_content( $column_name, $post_id ) {

  if ( 'modified-last' != $column_name )
    return;

  $modified_date   = the_modified_date( 'Y年Md日' );
 
  echo $modified_date;
}

最終更新日時(時間付き)

function last_modified_admin_column( $columns ) {
 $columns['modified-last'] =__( '最終更新日', 'aco' );
 return $columns;
}
add_filter( 'manage_edit-post_columns', 'last_modified_admin_column' );
 
function sortable_last_modified_column( $columns ) {
 $columns['modified-last'] = 'modified';
 return $columns;
}
add_filter( 'manage_edit-post_sortable_columns', 'sortable_last_modified_column' );
 
function last_modified_admin_column_content( $column_name, $post_id ) {
 if ( 'modified-last' != $column_name )
 return;
  
 $modified_date = the_modified_date( 'Y年Md日Ag時i分' );
 echo $modified_date;
}
add_action( 'manage_posts_custom_column', 'last_modified_admin_column_content', 10, 2 );

カスタム投稿タイプの一覧に最終更新日時を追加(時間付き)

function my_manage_edit_columns( $columns ) {
	$columns['modified'] = '更新日';
	return $columns;
}
add_filter( 'manage_edit-{カスタム投稿タイプ}_columns', 'my_manage_edit_columns' );

function my_manage_edit_sortable_columns( $columns ) {
	$columns['modified'] = 'modified';
	return $columns;
}
add_filter( 'manage_edit-{カスタム投稿タイプ}_sortable_columns', 'my_manage_edit_sortable_columns' );

function my_manage_posts_custom_column( $column_name ) {
	if ( 'modified' == $column_name ) {
		the_modified_date('Y年Md日Ag時i分');
	}
}
add_action( 'manage_{カスタム投稿タイプ}_posts_custom_column', 'my_manage_posts_custom_column' );

WordPress カスタム投稿タイプで「プレビュー」ボタンを無効にする

Filed under: functions.php,wordpress — kdcs @ 23年4月21日 金曜日

WordPressでカスタム投稿タイプとアドバンスドカスタムフィールドを利用して、例えば広告バナー表示や特定のページに埋め込んだ内容などのコンテンツの更新を行う場合、管理者以外はメニューの「新規追加」や「編集・クイック編集・ゴミ箱へ移動」ほか「プレビュー」などを非表示にしておく方が都合がよいことがある。

以下はその方法。(カスタム投稿タイプはhogehoge)

ダッシュボード左側のメニューから管理者以外hogehogeの新規追加を無効にする

function remove_admin_menus() {
 
    // level10以外のユーザーの場合
    if (!current_user_can('level_10')) {
 
        global $menu;
        global $submenu;
 
        // unsetで非表示にするメニューを指定
        unset($menu[2]);  // ダッシュボード
//      unset($menu[5]);  // 投稿
        unset($menu[10]); // メディア
        unset($menu[20]); // 固定ページ
        unset($submenu['edit.php?post_type=page'][10]); //固定ページのサブメニュー
        unset($menu[25]); // コメント
        unset($menu[60]); // 外観
        unset($menu[65]); // プラグイン
        unset($menu[70]); // ユーザー
        unset($menu[75]); // ツール
        unset($menu[80]); // 設定
 remove_menu_page('wpcf7'); //コンタクトフォーム7
 remove_submenu_page( 'edit.php?post_type=hogehoge', 'post-new.php?post_type=hogehoge' ); //hogehogeの新規追加非表示
    }
}

編集画面側に表示される「新規追加」を非表示にする

function custom_edit_newpost_delete($hook) {
	if($hook == 'edit.php' || $hook == 'post.php'){

    $postType = get_post_type();
if ( !current_user_can( 'administrator' ) ) {
    if ( $postType == 'hogehoge' ) { //カスタム投稿スラッグがhogehogeなら非表示
        echo '<style>.wrap .wp-heading-inline + .page-title-action{display: none;}</style>';
	  }

	}
  }
}
add_action('admin_enqueue_scripts', 'custom_edit_newpost_delete');

編集画面の公開エリアにある「プレビュー」または「変更をプレビュー」を無効にするには、カスタム投稿タイプ作成時の設定で「publicly_queryable」をfalseにする。
以下参考

register_post_type( 'support', array(
'labels' => $labels,
'public' => true,
'publicly_queryable' => true,
'show_ui' => true,
'show_in_menu' => true,
'query_var' => true,
'rewrite' => array( 'slug' => 'support' ),
'capability_type' => 'post',
'has_archive' => true,
'hierarchical' => false,
'menu_position' => null,
'supports' => array( 'title', 'editor', 'author', 'thumbnail', 'excerpt', 'comments' )
) );

一覧の「編集・クイック編集・ゴミ箱へ移動・プレビュー」を非表示にする

function custom_action_row($actions, $post){
    
    $postType = get_post_type();
    if ( $postType == "recruit" ){ //カスタム投稿スラッグがrecruitなら非表示
       unset($actions['edit']); //編集
       unset($actions['inline hide-if-no-js']); //クイック編集
       unset($actions['trash']); //ゴミ箱
       unset($actions['view']); //プレビュー
    }

    return $actions;
}
add_filter('post_row_actions','custom_action_row', 10, 2);

サイト内検索

カテゴリー

最近の投稿

↑上に戻る