기본 관리자 화면 옵션 및 메타 박스 순서 설정


28

functions.php 파일을 통해 기본 "화면 옵션"과 메타 박스 순서를 설정하는 방법 (필요한 방법)을 필사적으로 찾고 있습니다. 누구든지 그들이 여기에서 제공 할 수있는 도움이 있습니까?


2014 업데이트 : 메타 박스를 재정렬 해야하는 사람들은 아래 Nabil의 답변을 참조하십시오 .
rinogo

답변:


23

편집 후 페이지에서 메타 박스 순서 설정

메타 상자를 제거하고 원하는 순서대로 다시 추가해야합니다.

메타 박스를 비활성화하려면 : (필요에 따라 사용자 정의하고 html 코드에서 메타 박스 ID를보고 함수의 첫 번째 매개 변수로 사용해야하는 이름을 확인하십시오)

function my_remove_meta_boxes() {

    remove_meta_box('postcustom', 'post', 'core');

    remove_meta_box('commentsdiv', 'post', 'core');

    ...
}

add_action( 'admin_menu', 'my_remove_meta_boxes' );

: 그들을 제거 후 새 위치에 추가 할 수 add_meta_box 기능을 사용할 수 있습니다 http://codex.wordpress.org/Function_Reference/add_meta_box . 메타 박스의 순서는 add_meta_box 함수를 호출하는 순서에 따라 다릅니다. 예 : 다음 코드 스 니펫을 사용하면 주석 메타 상자가 사용자 정의 필드 메타 상자 앞에 있습니다.

function my_add_meta_boxes( $post_type, $post ) {
    if ( ('publish' == $post->post_status || 'private' == $post->post_status) && post_type_supports($post_type, 'comments') )
        add_meta_box('commentsdiv', __('Comments'), 'post_comment_meta_box', $post_type, 'normal', 'core');

    if ( post_type_supports($post_type, 'custom-fields') )
        add_meta_box('postcustom', __('Custom Fields'), 'post_custom_meta_box', $post_type, 'normal', 'core');

    ...
}

add_action( 'add_meta_boxes', 'my_add_meta_boxes' );

wp-admin / edit-form-advanced.php 파일을 볼 수 있습니다

게시물 목록 페이지에 표시 할 열 제목 설정

필터 manage _ {$ post_type} _posts_columns를 사용해야합니다. 예 : 다음 스 니펫은 댓글 열을 제거합니다.

function my_remove_columns( $posts_columns ) {
    unset( $posts_columns['comments'] );

    return $posts_columns;
}

add_filter( 'manage_post_posts_columns', 'my_remove_columns' );

게시물 목록 페이지에 표시 될 기본 결과 설정

'edit _ {$ post_type} _per_page'및 'edit_posts_per_page'필터를 사용하십시오.

function my_edit_post_per_page( $per_page, $post_type ) {

    $edit_per_page = 'edit_' . $post_type . '_per_page';
    $per_page = (int) get_user_option( $edit_per_page );
    if ( empty( $per_page ) || $per_page < 1 )
        $per_page = 1;

    return $per_page;
}

add_filter( 'edit_posts_per_page', 'my_edit_post_per_page' );

특정 게시물 유형을 타겟팅하려면 다음 단계를 따르십시오.

  • 사용 add_filter( 'edit_{post type}_per_page', 'my_edit_post_per_page' );예를 들어 add_filter( 'edit_post_per_page', 'my_edit_post_per_page' );, 게시물 add_filter( 'edit_page_per_page', 'my_edit_post_per_page' );페이지를.

  • 또는 함수 내에서 조건을 사용하십시오. 예 :

    함수 my_edit_post_per_page ($ per_page, $ post_type) {

    if( $post_type == 'post' ) {
        $edit_per_page = 'edit_' . $post_type . '_per_page';
        $per_page = (int) get_user_option( $edit_per_page );
        if ( empty( $per_page ) || $per_page < 1 )
            $per_page = 1;
    }
    
    
    return $per_page;
    

미안, 어쩌면 내가 제대로 설명하지 못했습니다. 관리자 영역의 게시물 편집 페이지에서 메타 상자를 참조하고 관리자 게시물 목록 페이지에 표시 할 기본 게시물 수를 설정했습니다.
NetConstructor.com

1
기술적으로 이것은 질문이 아닙니다. 실제로 2 개의 질문입니까?
Tom J Nowell

나는 대답을 수정했다. 자세한 내용이 필요하면 알려주십시오.
sorich87

@ sorich87 귀하의 답변에 감사드립니다. 그러나 각 메타 박스의 정확한 순서를 구체적으로 지정할 방법이 없었거나 거기에 있었음을 기억하십시오. 어쩌면 좀 더 구체적이어야합니다. 기본적으로 각 코드에 로그인 할 필요없이 모든 사용자에게 다양한 옵션을 미리 설정할 수있는 다양한 코드 스 니펫을 찾고 있습니다. 예 : 게시물 편집 페이지에서 메타 상자의 정확한 순서 설정, 게시물 목록 페이지에 표시 할 열 제목 설정, 게시물 목록 페이지에 표시되는 기본 결과 설정 ... 미리 감사드립니다.
NetConstructor.com

나는 대답을 수정했다.
sorich87

9

다음 예에서 교체 {CPT}후 유형 이름과 같은 post, page, book, event, imaginary, foobar...라는 이름의 포스트 유형이 그렇다면 event, 당신은에 대한 필터를 추가해야합니다 get_user_option_meta-box-order_event.

add_filter( 'get_user_option_meta-box-order_{CPT}', 'metabox_order' );
function metabox_order( $order ) {
    return array(
        'normal' => join( 
            ",", 
            array(       // vvv  Arrange here as you desire
                'customdiv-{CPT}',
                'authordiv',
                'slugdiv',
            )
        ),
    );
}

노트:

  • 와 함께 normal할 수도 side있고advanced
  • 값은 쉼표로 구분 된 div id입니다. 페이지 소스 코드를 보거나 추측 할 수 있습니다.
  • 존재하는 메타 박스는 사용자 정의 순서에 포함되지 않습니다. 목록 끝에 자동으로 추가됩니다.

1
나는 그 {CPT}명칭 에 다소 혼란 스러웠다 . 명확히하기 위해 이름이라는 게시물 유형 인 event경우에 대한 필터를 추가해야합니다 get_user_option_meta-box-order_event.
rinogo
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.