投稿を保存するときに、デフォルトのメッセージではなくカスタムメッセージを作成しようとしています。
http://codex.wordpress.org/Function_Reference/register_post_type example:
//add filter to ensure the text Book, or book, is displayed when user updates a book
add_filter('post_updated_messages', 'codex_book_updated_messages');
function codex_book_updated_messages( $messages ) {
global $post, $post_ID;
$messages['book'] = array(
0 => '', // Unused. Messages start at index 1.
1 => sprintf( __('Book updated. <a href="%s">View book</a>'), esc_url( get_permalink($post_ID) ) ),
2 => __('Custom field updated.'),
3 => __('Custom field deleted.'),
4 => __('Book updated.'),
/* translators: %s: date and time of the revision */
5 => isset($_GET['revision']) ? sprintf( __('Book restored to revision from %s'), wp_post_revision_title( (int) $_GET['revision'], false ) ) : false,
6 => sprintf( __('Book published. <a href="%s">View book</a>'), esc_url( get_permalink($post_ID) ) ),
7 => __('Book saved.'),
8 => sprintf( __('Book submitted. <a target="_blank" href="%s">Preview book</a>'), esc_url( add_query_arg( 'preview', 'true', get_permalink($post_ID) ) ) ),
9 => sprintf( __('Book scheduled for: <strong>%1$s</strong>. <a target="_blank" href="%2$s">Preview book</a>'),
// translators: Publish box date format, see http://php.net/date
date_i18n( __( 'M j, Y @ G:i' ), strtotime( $post->post_date ) ), esc_url( get_permalink($post_ID) ) ),
10 => sprintf( __('Book draft updated. <a target="_blank" href="%s">Preview book</a>'), esc_url( add_query_arg( 'preview', 'true', get_permalink($post_ID) ) ) ),
);
return $messages;
}
'message'
配列の$_GET
部分は、実際のメッセージ値をinteger
として保持する役割を果たします。つまり、そこに渡されたものはすべて実際のメッセージとして設定されます。メッセージ自体は、管理UIテンプレートのグローバル配列内に格納されています。 $messages
という名前で、デフォルトごとに3つのキーがあります。
page
post
attachment
メッセージはメインの$messages
配列のサブ配列として保存されます。
留意すべき点がいくつかあります(WPコアv4.0.1)。
0
は使用されていません。attachment
メッセージは現在ハックであり、すべてのキーに'Media attachment updated.'
という文字列が含まれています。post_updated_messages
フィルタを使用してください。
add_filter( 'post_updated_messages', function( $messages )
{
$messages['post'][2] = 'My awesome custom field just updated. Congratulations!';
return $messages;
} );
何のメッセージが何のために使われているかについての~/wp-admin/edit-form-advanced.php
を見てください。
ポストタイプが使用されていない場合の代替は、
post
ポストタイプのmessages配列です。
あなたは安全にbespokenフィルタのコールバックを通してあなた自身のメッセージのセットを追加することができます。カスタムの投稿タイプの名前をmessages配列のキーとして使用するようにしてください。
add_filter( 'post_updated_messages', function( $messages )
{
$messages['my_custom_post_type'][2] = 'Go, buy some milk!';
return $messages;
} );
コールバック自体はおそらく最もうまくフックされるでしょう
do_action( "load-{$pagenow}" )
これはいくらか助けになるかもしれないと思った。
さまざまなサイトの長さと幅を調べた後、これを利用してカスタムメッセージを表示することしかできませんでした。
https://onextrapixel.com/10-tips-for-a-deeply-customised-wordpress-admin-area/
function frl_on_save_post($post_id, $post) {/* add warning filter when saving post */
if($post->post_type == 'post') //test for something real here
add_filter('redirect_post_location', 'frl_custom_warning_filter');
}
add_action('save_post', 'frl_on_save_post', 2, 2);
function frl_custom_warning_filter($location) { /* filter redirect location to add warning parameter*/
$location = add_query_arg(array('warning'=>'my_warning'), $location);
return $location;
}
function frl_warning_in_notice() { /* print warning message */
if(!isset($_REQUEST['warning']) || empty($_REQUEST['warning']))
return;
$warnum = trim($_REQUEST['warning']);
/* possible warnings codes and messages */
$warnings = array(
'my_warning' => __('This is my truly custom warning!', 'frl')
);
if(!isset($warnings[$warnum]))
return;
echo '<div class="error message"><p><strong>';
echo $warnings[$warnum];
echo '</strong></p></div>';
}
add_action('admin_notices', 'frl_warning_in_notice');