Fix Press This editors, see #17144

git-svn-id: http://svn.automattic.com/wordpress/trunk@18570 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
azaozz 2011-08-19 01:14:56 +00:00
parent 0fe8ea2f72
commit 97ff3b4c7a
6 changed files with 192 additions and 206 deletions

File diff suppressed because one or more lines are too long

View File

@ -505,18 +505,13 @@ ul.category-tabs li {
margin: 5px 0; margin: 5px 0;
padding: 0 5px; padding: 0 5px;
border: 0 none; border: 0 none;
height: 365px; height: 357px;
width: 97% !important;
font-family: Consolas, Monaco, monospace; font-family: Consolas, Monaco, monospace;
font-size: 13px; font-size: 13px;
line-height: 19px; line-height: 19px;
background: transparent; background: transparent;
} }
* html .postdivrich {
zoom: 1;
}
/* Submit */ /* Submit */
#saving { #saving {
display: inline; display: inline;
@ -676,3 +671,8 @@ input.newtag:focus ~ div.taghint {
#mce_fullscreen_container { #mce_fullscreen_container {
background: #fff; background: #fff;
} }
#photo-add-url-div input[type="text"] {
width: 300px;
}

View File

@ -266,7 +266,7 @@ wp_nonce_field( 'samplepermalink', 'samplepermalinknonce', false );
<?php if ( post_type_supports($post_type, 'editor') ) { ?> <?php if ( post_type_supports($post_type, 'editor') ) { ?>
<div id="postdivrich" class="postarea"> <div id="postdivrich" class="postarea">
<?php wp_editor($post->post_content, 'content'); ?> <?php wp_editor($post->post_content, 'content', array('dfw' => true) ); ?>
<table id="post-status-info" cellspacing="0"><tbody><tr> <table id="post-status-info" cellspacing="0"><tbody><tr>
<td id="wp-word-count"><?php printf( __( 'Word count: %s' ), '<span class="word-count">0</span>' ); ?></td> <td id="wp-word-count"><?php printf( __( 'Word count: %s' ), '<span class="word-count">0</span>' ); ?></td>

View File

@ -26,20 +26,13 @@ if ( ! current_user_can('edit_posts') )
* @return int Post ID * @return int Post ID
*/ */
function press_it() { function press_it() {
// define some basic variables
$quick = array();
$quick['post_status'] = 'draft'; // set as draft first
$quick['post_category'] = isset($_POST['post_category']) ? $_POST['post_category'] : null;
$quick['tax_input'] = isset($_POST['tax_input']) ? $_POST['tax_input'] : null;
$quick['post_title'] = ( trim($_POST['title']) != '' ) ? $_POST['title'] : ' ';
$quick['post_content'] = isset($_POST['post_content']) ? $_POST['post_content'] : '';
// insert the post with nothing in it, to get an ID $post = get_default_post_to_edit('post', true);
$post_ID = wp_insert_post($quick, true); $post_ID = $post['ID'];
if ( is_wp_error($post_ID) ) $post['post_category'] = isset($_POST['post_category']) ? $_POST['post_category'] : null;
wp_die($post_ID); $post['tax_input'] = isset($_POST['tax_input']) ? $_POST['tax_input'] : null;
$post['post_title'] = isset($_POST['title']) ? $_POST['title'] : '';
$content = isset($_POST['content']) ? $_POST['content'] : ''; $post['post_content'] = isset($_POST['post_content']) ? $_POST['post_content'] : '';
$upload = false; $upload = false;
if ( !empty($_POST['photo_src']) && current_user_can('upload_files') ) { if ( !empty($_POST['photo_src']) && current_user_can('upload_files') ) {
@ -57,12 +50,12 @@ function press_it() {
} }
// set the post_content and status // set the post_content and status
if ( isset( $_POST['publish'] ) && current_user_can( 'publish_posts' ) ) if ( isset( $_POST['publish'] ) && current_user_can( 'publish_posts' ) )
$quick['post_status'] = 'publish'; $post['post_status'] = 'publish';
elseif ( isset( $_POST['review'] ) ) elseif ( isset( $_POST['review'] ) )
$quick['post_status'] = 'pending'; $post['post_status'] = 'pending';
else else
$quick['post_status'] = 'draft'; $post['post_status'] = 'draft';
$quick['post_content'] = $content;
// error handling for media_sideload // error handling for media_sideload
if ( is_wp_error($upload) ) { if ( is_wp_error($upload) ) {
wp_delete_post($post_ID); wp_delete_post($post_ID);
@ -80,17 +73,16 @@ function press_it() {
} }
} }
$quick['ID'] = $post_ID; wp_update_post($post);
wp_update_post($quick);
} }
return $post_ID; return $post_ID;
} }
// For submitted posts. // For submitted posts.
if ( isset($_REQUEST['action']) && 'post' == $_REQUEST['action'] ) { if ( isset($_REQUEST['action']) && 'post' == $_REQUEST['action'] ) {
check_admin_referer('press-this'); check_admin_referer('press-this');
$post_ID = press_it(); $posted = $post_ID = press_it();
$posted = $post_ID;
} else { } else {
$post_ID = 0; $post_ID = 0;
} }
@ -164,34 +156,6 @@ if ( !empty($_REQUEST['ajax']) ) {
<p id="options"><a href="#" class="select button"><?php _e('Insert Image'); ?></a> <a href="#" class="cancel button"><?php _e('Cancel'); ?></a></p> <p id="options"><a href="#" class="select button"><?php _e('Insert Image'); ?></a> <a href="#" class="cancel button"><?php _e('Cancel'); ?></a></p>
<?php break; <?php break;
case 'photo_thickbox_url': ?>
<script type="text/javascript" charset="utf-8">
/* <![CDATA[ */
jQuery('.cancel').click(function() {
tb_remove();
});
jQuery('.select').click(function() {
image_selector();
});
/* ]]> */
</script>
<h3 class="tb"><label for="this_photo"><?php _e('URL') ?></label></h3>
<div class="titlediv">
<div class="titlewrap">
<input id="this_photo" name="this_photo" class="tbtitle text" onkeypress="if(event.keyCode==13) image_selector();" />
</div>
</div>
<h3 class="tb"><label for="photo_description"><?php _e('Description') ?></label></h3>
<div id="titlediv">
<div class="titlewrap">
<input id="this_photo_description" name="photo_description" class="tbtitle text" onkeypress="if(event.keyCode==13) image_selector();" value="<?php echo esc_attr($title);?>"/>
</div>
</div>
<p id="options"><a href="#" class="select"><?php _e('Insert Image'); ?></a> | <a href="#" class="cancel"><?php _e('Cancel'); ?></a></p>
<?php break;
case 'photo_images': case 'photo_images':
/** /**
* Retrieve all image URLs from given URI. * Retrieve all image URLs from given URI.
@ -312,7 +276,7 @@ if ( !empty($_REQUEST['ajax']) ) {
jQuery('#extra-fields').html(''); jQuery('#extra-fields').html('');
return false; return false;
} }
jQuery('#extra-fields').html('<div class="postbox"><h2><?php _e( 'Add Photos' ); ?> <small id="photo_directions">(<?php _e("click images to select") ?>)</small></h2><ul class="actions"><li><a href="#" id="photo-add-url" class="thickbox button"><?php _e("Add from URL") ?> +</a></li></ul><div class="inside"><div class="titlewrap"><div id="img_container"></div></div><p id="options"><a href="#" class="close button"><?php _e('Cancel'); ?></a><a href="#" class="refresh button"><?php _e('Refresh'); ?></a></p></div>'); jQuery('#extra-fields').html('<div class="postbox"><h2><?php _e( 'Add Photos' ); ?> <small id="photo_directions">(<?php _e("click images to select") ?>)</small></h2><ul class="actions"><li><a href="#" id="photo-add-url" class="button"><?php _e("Add from URL") ?> +</a></li></ul><div class="inside"><div class="titlewrap"><div id="img_container"></div></div><p id="options"><a href="#" class="close button"><?php _e('Cancel'); ?></a><a href="#" class="refresh button"><?php _e('Refresh'); ?></a></p></div>');
jQuery('#img_container').html(strtoappend); jQuery('#img_container').html(strtoappend);
<?php break; <?php break;
} }
@ -327,7 +291,6 @@ die;
<title><?php _e('Press This') ?></title> <title><?php _e('Press This') ?></title>
<?php <?php
add_thickbox();
wp_enqueue_style( 'press-this' ); wp_enqueue_style( 'press-this' );
wp_enqueue_style( 'press-this-ie'); wp_enqueue_style( 'press-this-ie');
wp_enqueue_style( 'colors' ); wp_enqueue_style( 'colors' );
@ -349,8 +312,7 @@ var photostorage = false;
?> ?>
<script type="text/javascript"> <script type="text/javascript">
function insert_plain_editor(text) { function insert_plain_editor(text) {
edCanvas = document.getElementById('content'); edInsertContent(text);
edInsertContent(edCanvas, text);
} }
function set_editor(text) { function set_editor(text) {
if ( '' == text || '<p></p>' == text ) text = '<p><br /></p>'; if ( '' == text || '<p></p>' == text ) text = '<p><br /></p>';
@ -410,7 +372,10 @@ var photostorage = false;
photostorage = false; photostorage = false;
show('photo'); show('photo');
}); });
jQuery('#photo-add-url').attr('href', '?ajax=photo_thickbox_url&height=200&width=500'); jQuery('#photo-add-url').click(function(){
var form = jQuery('#photo-add-url-div').clone();
jQuery('#img_container').empty().append( form.show() );
});
jQuery('#waiting').hide(); jQuery('#waiting').hide();
jQuery('#extra-fields').show(); jQuery('#extra-fields').show();
} }
@ -439,7 +404,7 @@ var photostorage = false;
} }
jQuery(document).ready(function($) { jQuery(document).ready(function($) {
//resize screen //resize screen
window.resizeTo(720,540); window.resizeTo(720,580);
// set button actions // set button actions
jQuery('#photo_button').click(function() { show('photo'); return false; }); jQuery('#photo_button').click(function() { show('photo'); return false; });
jQuery('#video_button').click(function() { show('video'); return false; }); jQuery('#video_button').click(function() { show('video'); return false; });
@ -461,11 +426,6 @@ var photostorage = false;
</script> </script>
</head> </head>
<body class="press-this wp-admin"> <body class="press-this wp-admin">
<?php
if ( user_can_richedit() ) {
wp_tiny_mce( true, array( 'height' => '370' ) );
}
?>
<form action="press-this.php?action=post" method="post"> <form action="press-this.php?action=post" method="post">
<div id="poststuff" class="metabox-holder"> <div id="poststuff" class="metabox-holder">
<div id="side-info-column"> <div id="side-info-column">
@ -564,9 +524,7 @@ if ( user_can_richedit() ) {
</div> </div>
<div id="tagsdiv-post_tag" class="postbox"> <div id="tagsdiv-post_tag" class="postbox">
<div class="handlediv" title="<?php _e( 'Click to toggle' ); ?>"> <div class="handlediv" title="<?php _e( 'Click to toggle' ); ?>"><br /></div>
<br/>
</div>
<h3><span><?php _e('Post Tags'); ?></span></h3> <h3><span><?php _e('Post Tags'); ?></span></h3>
<div class="inside"> <div class="inside">
<div class="tagsdiv" id="post_tag"> <div class="tagsdiv" id="post_tag">
@ -596,8 +554,15 @@ if ( user_can_richedit() ) {
</h1> </h1>
</div> </div>
<?php if ( isset($posted) && intval($posted) ) { $post_ID = intval($posted); ?> <?php
<div id="message" class="updated"><p><strong><?php _e('Your post has been saved.'); ?></strong> <a onclick="window.opener.location.replace(this.href); window.close();" href="<?php echo get_permalink( $post_ID); ?>"><?php _e('View post'); ?></a> | <a href="<?php echo get_edit_post_link( $post_ID ); ?>" onclick="window.opener.location.replace(this.href); window.close();"><?php _e('Edit Post'); ?></a> | <a href="#" onclick="window.close();"><?php _e('Close Window'); ?></a></p></div> if ( isset($posted) && intval($posted) ) {
$post_ID = intval($posted); ?>
<div id="message" class="updated">
<p><strong><?php _e('Your post has been saved.'); ?></strong>
<a onclick="window.opener.location.replace(this.href); window.close();" href="<?php echo get_permalink($post_ID); ?>"><?php _e('View post'); ?></a>
| <a href="<?php echo get_edit_post_link( $post_ID ); ?>" onclick="window.opener.location.replace(this.href); window.close();"><?php _e('Edit Post'); ?></a>
| <a href="#" onclick="window.close();"><?php _e('Close Window'); ?></a></p>
</div>
<?php } ?> <?php } ?>
<div id="titlediv"> <div id="titlediv">
@ -609,44 +574,64 @@ if ( user_can_richedit() ) {
<div id="extra-fields" style="display: none"></div> <div id="extra-fields" style="display: none"></div>
<div class="postdivrich"> <div class="postdivrich">
<div id="editor-toolbar">
<?php if ( user_can_richedit() ) :
wp_print_scripts( 'quicktags' );
add_filter('the_editor_content', 'wp_richedit_pre'); ?>
<a id="edButtonHTML" onclick="switchEditors.go('content', 'html');"><?php _e('HTML'); ?></a>
<a id="edButtonPreview" class="active" onclick="switchEditors.go('content', 'tinymce');"><?php _e('Visual'); ?></a>
<div class="zerosize"><input accesskey="e" type="button" onclick="switchEditors.go('content')" /></div>
<?php endif; ?>
<div id="media-buttons">
<?php <?php
$editor_settings = array(
'teeny' => true,
'textarea_rows' => '15'
);
$content = '';
if ( $selection )
$content .= $selection;
if ( $url ) {
$content .= '<p>';
if ( $selection )
$content .= __('via ');
$content .= sprintf( "<a href='%s'>%s</a>.</p>", esc_url( $url ), esc_html( $title ) );
}
remove_action( 'media_buttons', 'media_buttons' );
add_action( 'media_buttons', 'press_this_media_buttons' );
function press_this_media_buttons() {
_e( 'Add:' ); _e( 'Add:' );
if ( current_user_can('upload_files') ) : ?> if ( current_user_can('upload_files') ) {
?>
<a id="photo_button" title="<?php _e('Insert an Image'); ?>" href="#"> <a id="photo_button" title="<?php _e('Insert an Image'); ?>" href="#">
<img alt="<?php _e('Insert an Image'); ?>" src="<?php echo esc_url( admin_url( 'images/media-button-image.gif?ver=20100531' ) ); ?>"/></a><?php <img alt="<?php _e('Insert an Image'); ?>" src="<?php echo esc_url( admin_url( 'images/media-button-image.gif?ver=20100531' ) ); ?>"/></a>
endif; <?php
?><a id="video_button" title="<?php _e('Embed a Video'); ?>" href="#"><img alt="<?php _e('Embed a Video'); ?>" src="<?php echo esc_url( admin_url( 'images/media-button-video.gif?ver=20100531' ) ); ?>"/></a>
</div>
</div>
<div id="quicktags"></div>
<div class="editor-container">
<textarea name="content" id="content" style="width:100%;" class="theEditor" rows="15"><?php
if ( $selection )
echo wp_richedit_pre($selection);
if ( $url ) {
echo '<p>';
if ( $selection )
_e('via ');
printf( "<a href='%s'>%s</a>.</p>", esc_url( $url ), esc_html( $title ) );
} }
?></textarea> ?>
</div> <a id="video_button" title="<?php _e('Embed a Video'); ?>" href="#"><img alt="<?php _e('Embed a Video'); ?>" src="<?php echo esc_url( admin_url( 'images/media-button-video.gif?ver=20100531' ) ); ?>"/></a>
<?php
}
wp_editor( $content, 'content', $editor_settings );
?>
</div> </div>
</div> </div>
</div> </div>
</form> </form>
<?php do_action('admin_print_footer_scripts'); ?> <div id="photo-add-url-div" style="display:none;">
<table><tr>
<td><label for="this_photo"><?php _e('URL') ?></label></td>
<td><input type="text" id="this_photo" name="this_photo" class="tbtitle text" onkeypress="if(event.keyCode==13) image_selector();" /></td>
</tr><tr>
<td><label for="this_photo_description"><?php _e('Description') ?></label></td>
<td><input type="text" id="this_photo_description" name="photo_description" class="tbtitle text" onkeypress="if(event.keyCode==13) image_selector();" value="<?php echo esc_attr($title);?>"/></td>
</tr><tr>
<td><input type="button" class="button" onclick="image_selector()" value="<?php _e('Insert Image'); ?>" /></td>
</tr></table>
</div>
<?php
do_action('admin_footer');
do_action('admin_print_footer_scripts');
?>
<script type="text/javascript">if(typeof wpOnload=='function')wpOnload();</script> <script type="text/javascript">if(typeof wpOnload=='function')wpOnload();</script>
</body> </body>
</html> </html>

View File

@ -48,6 +48,7 @@ class WP_Editor {
'editor_css' => '', // intended for extra styles for both visual and HTML editors buttons, needs to include the <style> tags, can use "scoped". 'editor_css' => '', // intended for extra styles for both visual and HTML editors buttons, needs to include the <style> tags, can use "scoped".
'editor_class' => '', // add extra class(es) to the editor textarea 'editor_class' => '', // add extra class(es) to the editor textarea
'teeny' => false, // output the minimal editor config used in Press This 'teeny' => false, // output the minimal editor config used in Press This
'dfw' => false, // replace the default fullscreen with DFW (needs specific css)
'tinymce' => true, // load TinyMCE, can be used to pass settings directly to TinyMCE using an array() 'tinymce' => true, // load TinyMCE, can be used to pass settings directly to TinyMCE using an array()
'quicktags' => true // load Quicktags, can be used to pass settings directly to Quicktags using an array() 'quicktags' => true // load Quicktags, can be used to pass settings directly to Quicktags using an array()
) ); ) );
@ -227,8 +228,9 @@ class WP_Editor {
} }
$plugins = array_unique( apply_filters('tiny_mce_plugins', $plugins) ); $plugins = array_unique( apply_filters('tiny_mce_plugins', $plugins) );
}
if ( 'content' == $editor_id ) // enable DFW only on Add/Edit Post screens for now if ( $settings['dfw'] )
$plugins[] = 'wpfullscreen'; $plugins[] = 'wpfullscreen';
$this->plugins = $plugins; $this->plugins = $plugins;
@ -317,29 +319,28 @@ class WP_Editor {
if ( ! empty($mce_css) ) if ( ! empty($mce_css) )
$this->first_init['content_css'] = $mce_css; $this->first_init['content_css'] = $mce_css;
} }
}
if ( $settings['teeny'] ) { if ( $settings['teeny'] ) {
$mce_buttons = apply_filters( 'teeny_mce_buttons', array('bold, italic, underline, blockquote, separator, strikethrough, bullist, numlist,justifyleft, justifycenter, justifyright, undo, redo, link, unlink, fullscreen'), $editor_id ); $mce_buttons = apply_filters( 'teeny_mce_buttons', array('bold', 'italic', 'underline', 'blockquote', 'separator', 'strikethrough', 'bullist', 'numlist', 'justifyleft', 'justifycenter', 'justifyright', 'undo', 'redo', 'link', 'unlink', 'fullscreen'), $editor_id );
$mce_buttons_2 = $mce_buttons_3 = $mce_buttons_4 = array(); $mce_buttons_2 = $mce_buttons_3 = $mce_buttons_4 = array();
} else { } else {
$mce_buttons = apply_filters('mce_buttons', array('bold', 'italic', 'strikethrough', '|', 'bullist', 'numlist', 'blockquote', '|', 'justifyleft', 'justifycenter', 'justifyright', '|', 'link', 'unlink', 'wp_more', '|', 'spellchecker', 'fullscreen', 'wp_fullscreen', 'wp_adv' ), $editor_id); $mce_buttons = apply_filters('mce_buttons', array('bold', 'italic', 'strikethrough', '|', 'bullist', 'numlist', 'blockquote', '|', 'justifyleft', 'justifycenter', 'justifyright', '|', 'link', 'unlink', 'wp_more', '|', 'spellchecker', 'fullscreen', 'wp_adv' ), $editor_id);
$mce_buttons_2 = apply_filters('mce_buttons_2', array( 'formatselect', 'underline', 'justifyfull', 'forecolor', '|', 'pastetext', 'pasteword', 'removeformat', '|', 'charmap', '|', 'outdent', 'indent', '|', 'undo', 'redo', 'wp_help' ), $editor_id); $mce_buttons_2 = apply_filters('mce_buttons_2', array( 'formatselect', 'underline', 'justifyfull', 'forecolor', '|', 'pastetext', 'pasteword', 'removeformat', '|', 'charmap', '|', 'outdent', 'indent', '|', 'undo', 'redo', 'wp_help' ), $editor_id);
$mce_buttons_3 = apply_filters('mce_buttons_3', array(), $editor_id); $mce_buttons_3 = apply_filters('mce_buttons_3', array(), $editor_id);
$mce_buttons_4 = apply_filters('mce_buttons_4', array(), $editor_id); $mce_buttons_4 = apply_filters('mce_buttons_4', array(), $editor_id);
} }
if ( 'content' == $editor_id ) if ( $settings['dfw'] ) {
$arg = array('fullscreen'); function replace_fullscreen(&$val) {
else if ( $val == 'fullscreen' )
$arg = array('wp_fullscreen'); $val = 'wp_fullscreen';
$_buttons = compact('mce_buttons', 'mce_buttons_2', 'mce_buttons_3', 'mce_buttons_4');
foreach ( $_buttons as $key => $val ) {
$_buttons[$key] = array_diff( $val, $arg );
} }
extract($_buttons, EXTR_OVERWRITE); array_walk($mce_buttons, 'replace_fullscreen');
array_walk($mce_buttons_2, 'replace_fullscreen');
array_walk($mce_buttons_3, 'replace_fullscreen');
array_walk($mce_buttons_4, 'replace_fullscreen');
}
$mceInit = array ( $mceInit = array (
'elements' => $editor_id, 'elements' => $editor_id,

View File

@ -424,7 +424,7 @@ function wp_default_styles( &$styles ) {
$styles->add( 'dashboard', "/wp-admin/css/dashboard$suffix.css", array(), '20110815' ); $styles->add( 'dashboard', "/wp-admin/css/dashboard$suffix.css", array(), '20110815' );
$styles->add( 'install', "/wp-admin/css/install$suffix.css", array(), '20110707' ); // Readme as well $styles->add( 'install', "/wp-admin/css/install$suffix.css", array(), '20110707' ); // Readme as well
$styles->add( 'theme-editor', "/wp-admin/css/theme-editor$suffix.css", array(), '20110602' ); $styles->add( 'theme-editor', "/wp-admin/css/theme-editor$suffix.css", array(), '20110602' );
$styles->add( 'press-this', "/wp-admin/css/press-this$suffix.css", array(), '20110707' ); $styles->add( 'press-this', "/wp-admin/css/press-this$suffix.css", array(), '20110818' );
$styles->add( 'thickbox', '/wp-includes/js/thickbox/thickbox.css', array(), '20090514' ); $styles->add( 'thickbox', '/wp-includes/js/thickbox/thickbox.css', array(), '20090514' );
$styles->add( 'login', "/wp-admin/css/login$suffix.css", array(), '20110610' ); $styles->add( 'login', "/wp-admin/css/login$suffix.css", array(), '20110610' );
$styles->add( 'plugin-install', "/wp-admin/css/plugin-install$suffix.css", array(), '20110810' ); $styles->add( 'plugin-install', "/wp-admin/css/plugin-install$suffix.css", array(), '20110810' );