各著者ページ(カスタム著者ページテンプレート)のオンラインステータス(オンライン/オフライン)を表示する必要があります。
is_user_logged_in()は現在のユーザーにのみ適用され、現在の著者を対象とする関連するアプローチが見つかりません。例:is_author_logged_in()
何か案は?
回答
あるTrick Ponyは、以前は使用したことがなかった、トランジェントを使用して2〜3つの関数のコーディングを準備するのに十分なほど親切でした。
http://codex.wordpress.org/Transients_API
これをfunctions.phpに追加します。
add_action('wp', 'update_online_users_status');
function update_online_users_status(){
if(is_user_logged_in()){
// get the online users list
if(($logged_in_users = get_transient('users_online')) === false) $logged_in_users = array();
$current_user = wp_get_current_user();
$current_user = $current_user->ID;
$current_time = current_time('timestamp');
if(!isset($logged_in_users[$current_user]) || ($logged_in_users[$current_user] < ($current_time - (15 * 60)))){
$logged_in_users[$current_user] = $current_time;
set_transient('users_online', $logged_in_users, 30 * 60);
}
}
}
これをauthor.php(または別のページテンプレート)に追加します。
function is_user_online($user_id) {
// get the online users list
$logged_in_users = get_transient('users_online');
// online, if (s)he is in the list and last activity was less than 15 minutes ago
return isset($logged_in_users[$user_id]) && ($logged_in_users[$user_id] > (current_time('timestamp') - (15 * 60)));
}
$passthis_id = $curauth->ID;
if(is_user_online($passthis_id)){
echo 'User is online.';}
else {
echo'User is not online.';}
2番目の回答(使用しないでください)
この回答は参照用に含まれています。One Trick Ponyが指摘したように、ページの読み込みごとにデータベースが更新されるため、これは望ましくないアプローチです。さらに詳しく調べたところ、コードは現在のユーザーのログイン状態を検出しているだけで、現在の作成者に追加で一致しているように見えました。
1)このプラグインをインストールします:http : //wordpress.org/extend/plugins/who-is-online/
2)以下をページテンプレートに追加します。
//Set the $curauth variable
if(isset($_GET['author_name'])) :
$curauth = get_userdatabylogin($author_name);
else :
$curauth = get_userdata(intval($author));
endif;
// Define the ID of whatever authors page is being viewed.
$authortemplate_id = $curauth->ID;
// Connect to database.
global $wpdb;
// Define table as variable.
$who_is_online_table = $wpdb->prefix . 'who_is_online';
// Query: Count the number of user_id's (plugin) that match the author id (author template page).
$onlinestatus_check = $wpdb->get_var( $wpdb->prepare( "SELECT COUNT(*) FROM ".$who_is_online_table." WHERE user_id = '".$authortemplate_id."';" ) );
// If a match is found...
if ($onlinestatus_check == "1"){
echo "<p>User is <strong>online</strong> now!</p>";
}
else{
echo "<p>User is currently <strong>offline</strong>.</p>";
}