最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

custom field - How to change what the post creation page looks like?

programmeradmin0浏览0评论

Is there a way (plugin, or something else) to set it where there is a drop down on the "New Post" page that allows you to choose a post type and the fields change allowing you to filter what content you are putting into a post without confusing a user by having 20 different custom fields on the "New Post" page.

Also, is there a plugin or other that can make custom fields with different value types (textarea, list, file upload, etc)?

Is there a way (plugin, or something else) to set it where there is a drop down on the "New Post" page that allows you to choose a post type and the fields change allowing you to filter what content you are putting into a post without confusing a user by having 20 different custom fields on the "New Post" page.

Also, is there a plugin or other that can make custom fields with different value types (textarea, list, file upload, etc)?

Share Improve this question asked Feb 4, 2011 at 5:54 Jo AlbrightJo Albright 1431 silver badge7 bronze badges 2
  • Welcome to WordPress Answers on StackExchange. Glad to have you here. Since you are new and likely unfamiliar with how things are designed to work here I'd like to let you know that you should only ask one question per question so please answer another question about the custom fields with different value types. – MikeSchinkel Commented Feb 4, 2011 at 12:12
  • I apologize, is there an easy way to do that without creating two questions? And is there a way to mark two answers correct on one question? – Jo Albright Commented Feb 4, 2011 at 14:07
Add a comment  | 

2 Answers 2

Reset to default 1

This was asked over and over:

  • Add custom field automatically to custom page types
  • Redesigning Custom Post Type “Add New” page

and if you are not into coding the you can use plugins like

  • Simple fields
  • More Fields
  • Verve Meta Boxes

hope this helps

I understand your concern; if you get a lot of post types WordPress' admin menu quickly grows unwieldy. What I've done for you is to implement something like what you asked for. It creates a post edit page metabox for the new post page with a drop down list of custom post types like this:

And here's what it looks like with a bunch of custom post types in the drop down mode:

What it does is use jQuery and Javascript to modify window.location.href in the browser's DOM upon selection using one of the following URL patterns, using the post types in my list of screenshots as an example:

http://example/wp-admin/post-new.php // This is for post_type=post
http://example/wp-admin/post-new.php?post_type=page 
http://example/wp-admin/post-new.php?post_type=actor
http://example/wp-admin/post-new.php?post_type=movie
http://example/wp-admin/post-new.php?post_type=car 
http://example/wp-admin/post-new.php?post_type=event
http://example/wp-admin/post-new.php?post_type=performer

One thing I worry about is the usability of this, however, so I wrote it to disable the drop down after the user modifies the value of any input field. That way the user can't accidently loose everything they were working on.

The code follows and you can place this in your theme's functions.php file or in a .php file for a plugin that you might be writing:

add_action('add_meta_boxes', 'add_meta_boxes_post_type_switcher',10,2);
function add_meta_boxes_post_type_switcher($post_type,$post) {
  global $pagenow;
  if ($pagenow=='post-new.php') {
    require_once(ABSPATH . 'wp-admin/includes/template.php');
    add_meta_box('post_type_switcher','Change Post Type',
                 'post_type_switcher',$post_type,'side','high');
  }
}
function post_type_switcher($post,$metabox) {
  $post_types = get_post_types();
  $new_post_url = admin_url('post-new.php');
  $js =<<<JS
<script type="text/javascript">
jQuery(document).ready(function ($) {
  $("#post-type-switcher-selector").change(function() {
    var post_type = $(this).find(":selected").val();
    var new_post_type_url = "{$new_post_url}?post_type=" + post_type;
    if (post_type=="post" && "{$new_post_url}"!=window.location.href) {
      window.location.href = "{$new_post_url}";
    } else if (new_post_type_url!=window.location.href) {
      window.location.href = new_post_type_url;
    }
  });
  $(".wp-admin #wpbody-content :input").change(function() {
    $("#post-type-switcher-selector").attr("disabled","disabled");
  });
});
</script>
JS;
  echo $js;
  echo '<select id="post-type-switcher-selector">';
  foreach ( $post_types as $post_type ) {
    $post_type_object = get_post_type_object($post_type);
    if ($post_type_object->publicly_queryable && $post_type!='attachment') {
      echo "\n\t<option ";
      if ( $post_type == $post->post_type ) // Make default first in list
        echo "selected='selected' ";
      echo "value='{$post_type}'>";
      echo $post_type_object->labels->singular_name;
      echo "</option>";
    }
  }
  echo '</select>';
}

So there's the code and it should work for you. If you have any questions about specifics in the code, just ask. However I would recommend you instead consider a consolidated menu like this one instead since I think it creates a more consistent mental model for the user, but the choice is yours!

发布评论

评论列表(0)

  1. 暂无评论