2008-05-08 19:25:07 +02:00
< ? php
2008-08-16 09:27:34 +02:00
/**
* Post advanced form for inclusion in the administration panels .
*
* @ package WordPress
* @ subpackage Administration
*/
2008-05-08 19:25:07 +02:00
2009-08-03 02:04:45 +02:00
// don't load directly
if ( ! defined ( 'ABSPATH' ) )
die ( '-1' );
2008-08-16 09:27:34 +02:00
/**
* Post ID global
* @ name $post_ID
* @ var int
*/
2009-02-02 04:41:19 +01:00
$post_ID = isset ( $post_ID ) ? ( int ) $post_ID : 0 ;
2008-08-08 19:05:10 +02:00
2008-05-08 19:25:07 +02:00
$action = isset ( $action ) ? $action : '' ;
2007-05-25 11:41:04 +02:00
if ( isset ( $_GET [ 'message' ]) )
2008-03-21 04:31:12 +01:00
$_GET [ 'message' ] = absint ( $_GET [ 'message' ] );
2009-05-02 23:44:09 +02:00
$messages [ 1 ] = sprintf ( __ ( 'Post updated. <a href="%s">View post</a>' ), get_permalink ( $post_ID ));
2008-03-21 04:31:12 +01:00
$messages [ 2 ] = __ ( 'Custom field updated.' );
2004-04-28 06:49:16 +02:00
$messages [ 3 ] = __ ( 'Custom field deleted.' );
2008-03-26 19:55:24 +01:00
$messages [ 4 ] = __ ( 'Post updated.' );
2008-11-06 22:26:11 +01:00
$messages [ 6 ] = sprintf ( __ ( 'Post published. <a href="%s">View post</a>' ), get_permalink ( $post_ID ));
2008-08-20 23:42:31 +02:00
$messages [ 7 ] = __ ( 'Post saved.' );
2008-12-07 04:39:00 +01:00
$messages [ 8 ] = sprintf ( __ ( 'Post submitted. <a href="%s">Preview post</a>' ), add_query_arg ( 'preview' , 'true' , get_permalink ( $post_ID ) ) );
2008-07-30 14:32:04 +02:00
if ( isset ( $_GET [ 'revision' ]) )
$messages [ 5 ] = sprintf ( __ ( 'Post restored to revision from %s' ), wp_post_revision_title ( ( int ) $_GET [ 'revision' ], false ) );
2008-05-08 19:25:07 +02:00
$notice = false ;
$notices [ 1 ] = __ ( 'There is an autosave of this post that is more recent than the version below. <a href="%s">View the autosave</a>.' );
2008-08-08 19:05:10 +02:00
if ( 0 == $post_ID ) {
2008-05-08 19:25:07 +02:00
$form_action = 'post' ;
$temp_ID = - 1 * time (); // don't change this formula without looking at wp_write_post()
2009-05-05 21:43:53 +02:00
$form_extra = " <input type='hidden' id='post_ID' name='temp_ID' value=' " . esc_attr ( $temp_ID ) . " ' /> " ;
2008-05-08 19:25:07 +02:00
$autosave = false ;
} else {
$form_action = 'editpost' ;
2009-05-05 21:43:53 +02:00
$form_extra = " <input type='hidden' id='post_ID' name='post_ID' value=' " . esc_attr ( $post_ID ) . " ' /> " ;
2008-08-25 23:50:11 +02:00
$autosave = wp_get_post_autosave ( $post_ID );
2008-06-24 00:25:27 +02:00
// Detect if there exists an autosave newer than the post and if that autosave is different than the post
2009-05-14 04:00:32 +02:00
if ( $autosave && mysql2date ( 'U' , $autosave -> post_modified_gmt , false ) > mysql2date ( 'U' , $post -> post_modified_gmt , false ) ) {
2008-06-24 00:25:27 +02:00
foreach ( _wp_post_revision_fields () as $autosave_field => $_autosave_field ) {
2008-10-23 22:03:16 +02:00
if ( normalize_whitespace ( $autosave -> $autosave_field ) != normalize_whitespace ( $post -> $autosave_field ) ) {
2008-06-24 00:25:27 +02:00
$notice = sprintf ( $notices [ 1 ], get_edit_post_link ( $autosave -> ID ) );
break ;
}
}
unset ( $autosave_field , $_autosave_field );
}
2008-05-08 19:25:07 +02:00
}
2008-08-20 23:42:31 +02:00
// All meta boxes should be defined and added before the first do_meta_boxes() call (or potentially during the do_meta_boxes action).
2009-08-14 19:37:40 +02:00
require_once ( 'includes/meta-boxes.php' );
2008-10-10 20:21:16 +02:00
2008-08-20 23:42:31 +02:00
add_meta_box ( 'submitdiv' , __ ( 'Publish' ), 'post_submit_meta_box' , 'post' , 'side' , 'core' );
2008-02-22 04:45:19 +01:00
2009-03-18 03:43:45 +01:00
// all tag-style post taxonomies
foreach ( get_object_taxonomies ( 'post' ) as $tax_name ) {
if ( ! is_taxonomy_hierarchical ( $tax_name ) ) {
2008-12-18 20:12:26 +01:00
$taxonomy = get_taxonomy ( $tax_name );
2009-05-05 21:43:53 +02:00
$label = isset ( $taxonomy -> label ) ? esc_attr ( $taxonomy -> label ) : $tax_name ;
2008-12-18 20:12:26 +01:00
2009-03-18 03:43:45 +01:00
add_meta_box ( 'tagsdiv-' . $tax_name , $label , 'post_tags_meta_box' , 'post' , 'side' , 'core' );
}
}
2008-01-14 02:14:57 +01:00
2008-08-20 23:42:31 +02:00
add_meta_box ( 'categorydiv' , __ ( 'Categories' ), 'post_categories_meta_box' , 'post' , 'side' , 'core' );
2008-11-12 19:36:48 +01:00
// add_meta_box('passworddiv', __('Privacy Options'), 'post_password_meta_box', 'post', 'side', 'core');
2008-08-20 23:42:31 +02:00
add_meta_box ( 'postexcerpt' , __ ( 'Excerpt' ), 'post_excerpt_meta_box' , 'post' , 'normal' , 'core' );
2008-11-11 20:25:30 +01:00
add_meta_box ( 'trackbacksdiv' , __ ( 'Send Trackbacks' ), 'post_trackback_meta_box' , 'post' , 'normal' , 'core' );
2008-08-20 23:42:31 +02:00
add_meta_box ( 'postcustom' , __ ( 'Custom Fields' ), 'post_custom_meta_box' , 'post' , 'normal' , 'core' );
2008-05-14 10:22:01 +02:00
do_action ( 'dbx_post_advanced' );
2009-02-02 04:41:19 +01:00
add_meta_box ( 'commentstatusdiv' , __ ( 'Discussion' ), 'post_comment_status_meta_box' , 'post' , 'normal' , 'core' );
if ( 'publish' == $post -> post_status || 'private' == $post -> post_status )
add_meta_box ( 'commentsdiv' , __ ( 'Comments' ), 'post_comment_meta_box' , 'post' , 'normal' , 'core' );
2008-01-03 09:03:29 +01:00
2008-10-02 06:10:54 +02:00
if ( ! ( 'pending' == $post -> post_status && ! current_user_can ( 'publish_posts' ) ) )
add_meta_box ( 'slugdiv' , __ ( 'Post Slug' ), 'post_slug_meta_box' , 'post' , 'normal' , 'core' );
2008-05-14 10:22:01 +02:00
2008-01-03 09:03:29 +01:00
$authors = get_editable_user_ids ( $current_user -> id ); // TODO: ROLE SYSTEM
if ( $post -> post_author && ! in_array ( $post -> post_author , $authors ) )
$authors [] = $post -> post_author ;
2009-08-14 19:37:40 +02:00
if ( $authors && count ( $authors ) > 1 )
add_meta_box ( 'authordiv' , __ ( 'Post Author' ), 'post_author_meta_box' , 'post' , 'normal' , 'core' );
2008-01-03 09:03:29 +01:00
2009-08-14 19:37:40 +02:00
if ( 0 < $post_ID && wp_get_post_revisions ( $post_ID ) )
add_meta_box ( 'revisionsdiv' , __ ( 'Post Revisions' ), 'post_revisions_meta_box' , 'post' , 'normal' , 'core' );
2008-04-19 01:38:21 +02:00
2008-11-11 23:40:16 +01:00
do_action ( 'do_meta_boxes' , 'post' , 'normal' , $post );
do_action ( 'do_meta_boxes' , 'post' , 'advanced' , $post );
do_action ( 'do_meta_boxes' , 'post' , 'side' , $post );
require_once ( 'admin-header.php' );
2008-08-20 23:42:31 +02:00
?>
2008-09-28 06:11:27 +02:00
2008-08-20 23:42:31 +02:00
< ? php if ( ( isset ( $mode ) && 'bookmarklet' == $mode ) || isset ( $_GET [ 'popupurl' ]) ) : ?>
< input type = " hidden " name = " mode " value = " bookmarklet " />
< ? php endif ; ?>
< div class = " wrap " >
2008-11-26 14:51:25 +01:00
< ? php screen_icon (); ?>
2009-05-18 17:11:07 +02:00
< h2 >< ? php echo esc_html ( $title ); ?> </h2>
2008-11-05 20:17:22 +01:00
< ? php if ( $notice ) : ?>
< div id = " notice " class = " error " >< p >< ? php echo $notice ?> </p></div>
< ? php endif ; ?>
< ? php if ( isset ( $_GET [ 'message' ])) : ?>
< div id = " message " class = " updated fade " >< p >< ? php echo $messages [ $_GET [ 'message' ]]; ?> </p></div>
< ? php endif ; ?>
2008-09-28 06:11:27 +02:00
< form name = " post " action = " post.php " method = " post " id = " post " >
2008-08-20 23:42:31 +02:00
< ? php
if ( 0 == $post_ID )
wp_nonce_field ( 'add-post' );
else
wp_nonce_field ( 'update-post_' . $post_ID );
?>
< input type = " hidden " id = " user-id " name = " user_ID " value = " <?php echo (int) $user_ID ?> " />
2009-05-05 21:43:53 +02:00
< input type = " hidden " id = " hiddenaction " name = " action " value = " <?php echo esc_attr( $form_action ) ?> " />
< input type = " hidden " id = " originalaction " name = " originalaction " value = " <?php echo esc_attr( $form_action ) ?> " />
< input type = " hidden " id = " post_author " name = " post_author " value = " <?php echo esc_attr( $post->post_author ); ?> " />
< input type = " hidden " id = " post_type " name = " post_type " value = " <?php echo esc_attr( $post->post_type ) ?> " />
< input type = " hidden " id = " original_post_status " name = " original_post_status " value = " <?php echo esc_attr( $post->post_status ) ?> " />
2009-05-18 18:00:33 +02:00
< input name = " referredby " type = " hidden " id = " referredby " value = " <?php echo esc_url(stripslashes(wp_get_referer())); ?> " />
2009-05-05 04:14:25 +02:00
< ? php
if ( 'draft' != $post -> post_status )
wp_original_referer_field ( true , 'previous' );
2008-08-20 23:42:31 +02:00
2009-05-05 04:14:25 +02:00
echo $form_extra ?>
2008-08-20 23:42:31 +02:00
2009-03-25 15:29:22 +01:00
< div id = " poststuff " class = " metabox-holder<?php echo 2 == $screen_layout_columns ? ' has-right-sidebar' : ''; ?> " >
2008-08-20 23:42:31 +02:00
< div id = " side-info-column " class = " inner-sidebar " >
< ? php do_action ( 'submitpost_box' ); ?>
< ? php $side_meta_boxes = do_meta_boxes ( 'post' , 'side' , $post ); ?>
</ div >
2009-04-01 02:14:38 +02:00
< div id = " post-body " >
2009-04-04 12:21:43 +02:00
< div id = " post-body-content " >
2008-08-20 23:42:31 +02:00
< div id = " titlediv " >
< div id = " titlewrap " >
2009-05-13 00:40:56 +02:00
< label class = " screen-reader-text " for = " title " >< ? php _e ( 'Title' ) ?> </label>
2009-05-05 21:43:53 +02:00
< input type = " text " name = " post_title " size = " 30 " tabindex = " 1 " value = " <?php echo esc_attr( htmlspecialchars( $post->post_title ) ); ?> " id = " title " autocomplete = " off " />
2008-08-20 23:42:31 +02:00
</ div >
< div class = " inside " >
2009-05-05 04:14:25 +02:00
< ? php
$sample_permalink_html = get_sample_permalink_html ( $post -> ID );
if ( ! ( 'pending' == $post -> post_status && ! current_user_can ( 'publish_posts' ) ) ) { ?>
2008-08-20 23:42:31 +02:00
< div id = " edit-slug-box " >
2009-05-05 04:14:25 +02:00
< ? php
if ( ! empty ( $post -> ID ) && ! empty ( $sample_permalink_html ) ) :
echo $sample_permalink_html ;
2008-08-20 23:42:31 +02:00
endif ; ?>
</ div >
2009-05-05 04:14:25 +02:00
< ? php
} ?>
2008-08-20 23:42:31 +02:00
</ div >
</ div >
< div id = " <?php echo user_can_richedit() ? 'postdivrich' : 'postdiv'; ?> " class = " postarea " >
< ? php the_editor ( $post -> post_content ); ?>
2009-04-16 06:41:05 +02:00
< table id = " post-status-info " cellspacing = " 0 " >< tbody >< tr >
2009-03-25 15:29:22 +01:00
< td id = " wp-word-count " ></ td >
< td class = " autosave-info " >
2008-08-20 23:42:31 +02:00
< span id = " autosave " >& nbsp ; </ span >
< ? php
if ( $post_ID ) {
echo '<span id="last-edit">' ;
if ( $last_id = get_post_meta ( $post_ID , '_edit_last' , true ) ) {
$last_user = get_userdata ( $last_id );
2009-05-18 17:11:07 +02:00
printf ( __ ( 'Last edited by %1$s on %2$s at %3$s' ), esc_html ( $last_user -> display_name ), mysql2date ( get_option ( 'date_format' ), $post -> post_modified ), mysql2date ( get_option ( 'time_format' ), $post -> post_modified ));
2008-08-20 23:42:31 +02:00
} else {
printf ( __ ( 'Last edited on %1$s at %2$s' ), mysql2date ( get_option ( 'date_format' ), $post -> post_modified ), mysql2date ( get_option ( 'time_format' ), $post -> post_modified ));
}
echo '</span>' ;
2009-05-05 04:14:25 +02:00
} ?>
2009-03-25 15:29:22 +01:00
</ td >
</ tr ></ tbody ></ table >
2008-08-20 23:42:31 +02:00
2009-05-05 04:14:25 +02:00
< ? php
wp_nonce_field ( 'autosave' , 'autosavenonce' , false );
wp_nonce_field ( 'closedpostboxes' , 'closedpostboxesnonce' , false );
wp_nonce_field ( 'getpermalink' , 'getpermalinknonce' , false );
wp_nonce_field ( 'samplepermalink' , 'samplepermalinknonce' , false );
wp_nonce_field ( 'meta-box-order' , 'meta-box-order-nonce' , false ); ?>
2008-08-20 23:42:31 +02:00
</ div >
< ? php
do_meta_boxes ( 'post' , 'normal' , $post );
do_action ( 'edit_form_advanced' );
2008-05-14 10:22:01 +02:00
do_meta_boxes ( 'post' , 'advanced' , $post );
2008-02-08 19:51:37 +01:00
2009-05-05 04:14:25 +02:00
do_action ( 'dbx_post_sidebar' ); ?>
2008-08-20 23:42:31 +02:00
2009-04-04 12:21:43 +02:00
</ div >
2005-06-14 09:31:36 +02:00
</ div >
2008-10-23 00:08:58 +02:00
< br class = " clear " />
2008-08-20 23:42:31 +02:00
</ div ><!-- / poststuff -->
2005-09-27 01:55:36 +02:00
</ form >
2008-09-28 06:11:27 +02:00
</ div >
2008-03-15 23:57:47 +01:00
2008-08-24 08:56:22 +02:00
< ? php wp_comment_reply (); ?>
2008-03-15 23:57:47 +01:00
< ? php if (( isset ( $post -> post_title ) && '' == $post -> post_title ) || ( isset ( $_GET [ 'message' ]) && 2 > $_GET [ 'message' ])) : ?>
< script type = " text/javascript " >
try { document . post . title . focus ();} catch ( e ){}
</ script >
< ? php endif ; ?>