WordPress 自動ログアウト

Filed under: functions.php,wordpress — kdcs @ 2023年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 @ 2023年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 @ 2023年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);

フォーム入力例「placeholder 属性」へのスタイルシート適用

Filed under: contactform7,css — kdcs @ 2023年4月8日 土曜日

Contact Form 7で入力例としてplaceholder属性を付ける場合のコード
例として氏名を必須にし、入力例を「田中 太郎」にする

[text* your-name autocomplete:name placeholder "田中 太郎"]

これで出力されるhtml

<div id="entryForm">
<input size="40" class="wpcf7-form-control wpcf7-text wpcf7-validates-as-required" autocomplete="name" aria-required="true" aria-invalid="false" placeholder="田中 太郎" value="" type="text" name="your-name" />
</div><!--/#entryForm-->

このinputタグ内のplaceholder属性にcssを適用する

#entryForm input::-webkit-input-placeholder {
    color: #aaa;
    font-size: 77%;
}
#entryForm input::-moz-placeholder {
    color: #aaa;
    font-size: 77%;
}
#entryForm input:-ms-input-placeholder {
    color: #aaa;
    font-size: 77%;
}

【注意】
このプレフィックスのついたcssをまとめて一括指定すると何故か適用されない

Contact Form 7 autop(自動挿入タグの無効化)

Filed under: contactform7,functions.php — kdcs @ 2023年4月8日 土曜日

Contact Form 7のバージョン5.7からpタグとbrタグが自動で挿入される
これを無効化する方法

wp-config.phpに記述する方法

define ('WPCF7_AUTOP', false);

functions.phpに記述する方法

add_filter('wpcf7_autop_or_not', 'wpcf7_autop_return_false');
function wpcf7_autop_return_false() {
  return false;
} 

サイト内検索

カテゴリー

最近の投稿

↑上に戻る