mirror of
https://github.com/WordPress/WordPress.git
synced 2024-12-31 13:37:51 +01:00
cc5ed3a485
The exceptions to this are update_post_meta() and add_post_meta() which are often used by plugins in POST handlers and will continue accepting slashed data for now. Introduce wp_upate_post_meta() and wp_add_post_meta() as unslashed alternatives to update_post_meta() and add_post_meta(). These functions could become methods in WP_Post so don't use them too heavily yet. Remove all escape() calls from wp_xmlrpc_server. Now that core expects unslashed data this is no longer needed. Remove addslashes(), addslashes_gpc(), add_magic_quotes() calls on data being prepared for handoff to core functions that until now expected slashed data. Adding slashes in no longer necessary. Introduce wp_unslash() and use to it remove slashes from GPCS data before using it in core API. Almost every instance of stripslashes() in core should now be wp_unslash(). In the future (a release or three) when GPCS is no longer slashed, wp_unslash() will stop stripping slashes and simply return what is passed. At this point wp_unslash() calls can be removed from core. Introduce wp_slash() for slashing GPCS data. This will also turn into a noop once GPCS is no longer slashed. wp_slash() should almost never be used. It is mainly of use in unit tests. Plugins should use wp_unslash() on data being passed to core API. Plugins should no longer slash data being passed to core. So when you get_post() and then wp_insert_post() the post data from get_post() no longer needs addslashes(). Most plugins were not bothering with this. They will magically start doing the right thing. Unfortunately, those few souls who did it properly will now have to avoid calling addslashes() for 3.6 and newer. Use wp_kses_post() and wp_kses_data(), which expect unslashed data, instead of wp_filter_post_kses() and wp_filter_kses(), which expect slashed data. Filters are no longer passed slashed data. Remove many no longer necessary calls to $wpdb->escape() and esc_sql(). In wp_get_referer() and wp_get_original_referer(), return unslashed data. Remove old stripslashes() calls from WP_Widget::update() handlers. These haven't been necessary since WP_Widget. Switch several queries over to prepare(). Expect something to break. Props alexkingorg see #21767 git-svn-id: http://core.svn.wordpress.org/trunk@23416 1a063a9b-81f0-0310-95a4-ce76da25c4cd
655 lines
25 KiB
PHP
655 lines
25 KiB
PHP
<?php
|
|
/**
|
|
* Press This Display and Handler.
|
|
*
|
|
* @package WordPress
|
|
* @subpackage Press_This
|
|
*/
|
|
|
|
define('IFRAME_REQUEST' , true);
|
|
|
|
/** WordPress Administration Bootstrap */
|
|
require_once('./admin.php');
|
|
|
|
header('Content-Type: ' . get_option('html_type') . '; charset=' . get_option('blog_charset'));
|
|
|
|
if ( ! current_user_can( 'edit_posts' ) || ! current_user_can( get_post_type_object( 'post' )->cap->create_posts ) )
|
|
wp_die( __( 'Cheatin’ uh?' ) );
|
|
|
|
/**
|
|
* Press It form handler.
|
|
*
|
|
* @package WordPress
|
|
* @subpackage Press_This
|
|
* @since 2.6.0
|
|
*
|
|
* @return int Post ID
|
|
*/
|
|
function press_it() {
|
|
|
|
$post = get_default_post_to_edit();
|
|
$post = get_object_vars($post);
|
|
$post_ID = $post['ID'] = (int) $_POST['post_id'];
|
|
|
|
if ( !current_user_can('edit_post', $post_ID) )
|
|
wp_die(__('You are not allowed to edit this post.'));
|
|
|
|
$post['post_category'] = isset($_POST['post_category']) ? $_POST['post_category'] : '';
|
|
$post['tax_input'] = isset($_POST['tax_input']) ? $_POST['tax_input'] : '';
|
|
$post['post_title'] = isset($_POST['title']) ? $_POST['title'] : '';
|
|
$content = isset($_POST['content']) ? $_POST['content'] : '';
|
|
|
|
$upload = false;
|
|
if ( !empty($_POST['photo_src']) && current_user_can('upload_files') ) {
|
|
foreach( (array) $_POST['photo_src'] as $key => $image) {
|
|
// see if files exist in content - we don't want to upload non-used selected files.
|
|
if ( strpos($_POST['content'], htmlspecialchars($image)) !== false ) {
|
|
$desc = isset($_POST['photo_description'][$key]) ? $_POST['photo_description'][$key] : '';
|
|
$upload = media_sideload_image($image, $post_ID, $desc);
|
|
|
|
// Replace the POSTED content <img> with correct uploaded ones. Regex contains fix for Magic Quotes
|
|
if ( !is_wp_error($upload) )
|
|
$content = preg_replace('/<img ([^>]*)src=\\\?(\"|\')'.preg_quote(htmlspecialchars($image), '/').'\\\?(\2)([^>\/]*)\/*>/is', $upload, $content);
|
|
}
|
|
}
|
|
}
|
|
// set the post_content and status
|
|
$post['post_content'] = $content;
|
|
if ( isset( $_POST['publish'] ) && current_user_can( 'publish_posts' ) )
|
|
$post['post_status'] = 'publish';
|
|
elseif ( isset( $_POST['review'] ) )
|
|
$post['post_status'] = 'pending';
|
|
else
|
|
$post['post_status'] = 'draft';
|
|
|
|
// error handling for media_sideload
|
|
if ( is_wp_error($upload) ) {
|
|
wp_delete_post($post_ID);
|
|
wp_die($upload);
|
|
} else {
|
|
// Post formats
|
|
if ( isset( $_POST['post_format'] ) ) {
|
|
if ( current_theme_supports( 'post-formats', $_POST['post_format'] ) )
|
|
set_post_format( $post_ID, $_POST['post_format'] );
|
|
elseif ( '0' == $_POST['post_format'] )
|
|
set_post_format( $post_ID, false );
|
|
}
|
|
|
|
$post_ID = wp_update_post($post);
|
|
}
|
|
|
|
return $post_ID;
|
|
}
|
|
|
|
// For submitted posts.
|
|
if ( isset($_REQUEST['action']) && 'post' == $_REQUEST['action'] ) {
|
|
check_admin_referer('press-this');
|
|
$posted = $post_ID = press_it();
|
|
} else {
|
|
$post = get_default_post_to_edit('post', true);
|
|
$post_ID = $post->ID;
|
|
}
|
|
|
|
// Set Variables
|
|
$title = isset( $_GET['t'] ) ? trim( strip_tags( html_entity_decode( wp_unslash( $_GET['t'] ) , ENT_QUOTES) ) ) : '';
|
|
|
|
$selection = '';
|
|
if ( !empty($_GET['s']) ) {
|
|
$selection = str_replace(''', "'", wp_unslash($_GET['s']));
|
|
$selection = trim( htmlspecialchars( html_entity_decode($selection, ENT_QUOTES) ) );
|
|
}
|
|
|
|
if ( ! empty($selection) ) {
|
|
$selection = preg_replace('/(\r?\n|\r)/', '</p><p>', $selection);
|
|
$selection = '<p>' . str_replace('<p></p>', '', $selection) . '</p>';
|
|
}
|
|
|
|
$url = isset($_GET['u']) ? esc_url($_GET['u']) : '';
|
|
$image = isset($_GET['i']) ? $_GET['i'] : '';
|
|
|
|
if ( !empty($_REQUEST['ajax']) ) {
|
|
switch ($_REQUEST['ajax']) {
|
|
case 'video': ?>
|
|
<script type="text/javascript">
|
|
/* <![CDATA[ */
|
|
jQuery('.select').click(function() {
|
|
append_editor(jQuery('#embed-code').val());
|
|
jQuery('#extra-fields').hide();
|
|
jQuery('#extra-fields').html('');
|
|
});
|
|
jQuery('.close').click(function() {
|
|
jQuery('#extra-fields').hide();
|
|
jQuery('#extra-fields').html('');
|
|
});
|
|
/* ]]> */
|
|
</script>
|
|
<div class="postbox">
|
|
<h2><label for="embed-code"><?php _e('Embed Code') ?></label></h2>
|
|
<div class="inside">
|
|
<textarea name="embed-code" id="embed-code" rows="8" cols="40"><?php echo esc_textarea( $selection ); ?></textarea>
|
|
<p id="options"><a href="#" class="select button"><?php _e('Insert Video'); ?></a> <a href="#" class="close button"><?php _e('Cancel'); ?></a></p>
|
|
</div>
|
|
</div>
|
|
<?php break;
|
|
|
|
case 'photo_thickbox': ?>
|
|
<script type="text/javascript">
|
|
/* <![CDATA[ */
|
|
jQuery('.cancel').click(function() {
|
|
tb_remove();
|
|
});
|
|
jQuery('.select').click(function() {
|
|
image_selector(this);
|
|
});
|
|
/* ]]> */
|
|
</script>
|
|
<h3 class="tb"><label for="tb_this_photo_description"><?php _e('Description') ?></label></h3>
|
|
<div class="titlediv">
|
|
<div class="titlewrap">
|
|
<input id="tb_this_photo_description" name="photo_description" class="tb_this_photo_description tbtitle text" onkeypress="if(event.keyCode==13) image_selector(this);" value="<?php echo esc_attr($title);?>"/>
|
|
</div>
|
|
</div>
|
|
|
|
<p class="centered">
|
|
<input type="hidden" name="this_photo" value="<?php echo esc_attr($image); ?>" id="tb_this_photo" class="tb_this_photo" />
|
|
<a href="#" class="select">
|
|
<img src="<?php echo esc_url($image); ?>" alt="<?php echo esc_attr(__('Click to insert.')); ?>" title="<?php echo esc_attr(__('Click to insert.')); ?>" />
|
|
</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;
|
|
case 'photo_images':
|
|
/**
|
|
* Retrieve all image URLs from given URI.
|
|
*
|
|
* @package WordPress
|
|
* @subpackage Press_This
|
|
* @since 2.6.0
|
|
*
|
|
* @param string $uri
|
|
* @return string
|
|
*/
|
|
function get_images_from_uri($uri) {
|
|
$uri = preg_replace('/\/#.+?$/','', $uri);
|
|
if ( preg_match( '/\.(jpe?g|jpe|gif|png)\b/i', $uri ) && !strpos( $uri, 'blogger.com' ) )
|
|
return "'" . esc_attr( html_entity_decode($uri) ) . "'";
|
|
$content = wp_remote_fopen($uri);
|
|
if ( false === $content )
|
|
return '';
|
|
$host = parse_url($uri);
|
|
$pattern = '/<img ([^>]*)src=(\"|\')([^<>\'\"]+)(\2)([^>]*)\/*>/i';
|
|
$content = str_replace(array("\n","\t","\r"), '', $content);
|
|
preg_match_all($pattern, $content, $matches);
|
|
if ( empty($matches[0]) )
|
|
return '';
|
|
$sources = array();
|
|
foreach ($matches[3] as $src) {
|
|
// if no http in url
|
|
if (strpos($src, 'http') === false)
|
|
// if it doesn't have a relative uri
|
|
if ( strpos($src, '../') === false && strpos($src, './') === false && strpos($src, '/') === 0)
|
|
$src = 'http://'.str_replace('//','/', $host['host'].'/'.$src);
|
|
else
|
|
$src = 'http://'.str_replace('//','/', $host['host'].'/'.dirname($host['path']).'/'.$src);
|
|
$sources[] = esc_url($src);
|
|
}
|
|
return "'" . implode("','", $sources) . "'";
|
|
}
|
|
$url = wp_kses(urldecode($url), null);
|
|
echo 'new Array('.get_images_from_uri($url).')';
|
|
break;
|
|
|
|
case 'photo_js': ?>
|
|
// gather images and load some default JS
|
|
var last = null
|
|
var img, img_tag, aspect, w, h, skip, i, strtoappend = "";
|
|
if(photostorage == false) {
|
|
var my_src = eval(
|
|
jQuery.ajax({
|
|
type: "GET",
|
|
url: "<?php echo esc_url($_SERVER['PHP_SELF']); ?>",
|
|
cache : false,
|
|
async : false,
|
|
data: "ajax=photo_images&u=<?php echo urlencode($url); ?>",
|
|
dataType : "script"
|
|
}).responseText
|
|
);
|
|
if(my_src.length == 0) {
|
|
var my_src = eval(
|
|
jQuery.ajax({
|
|
type: "GET",
|
|
url: "<?php echo esc_url($_SERVER['PHP_SELF']); ?>",
|
|
cache : false,
|
|
async : false,
|
|
data: "ajax=photo_images&u=<?php echo urlencode($url); ?>",
|
|
dataType : "script"
|
|
}).responseText
|
|
);
|
|
if(my_src.length == 0) {
|
|
strtoappend = '<?php _e('Unable to retrieve images or no images on page.'); ?>';
|
|
}
|
|
}
|
|
}
|
|
for (i = 0; i < my_src.length; i++) {
|
|
img = new Image();
|
|
img.src = my_src[i];
|
|
img_attr = 'id="img' + i + '"';
|
|
skip = false;
|
|
|
|
maybeappend = '<a href="?ajax=photo_thickbox&i=' + encodeURIComponent(img.src) + '&u=<?php echo urlencode($url); ?>&height=400&width=500" title="" class="thickbox"><img src="' + img.src + '" ' + img_attr + '/></a>';
|
|
|
|
if (img.width && img.height) {
|
|
if (img.width >= 30 && img.height >= 30) {
|
|
aspect = img.width / img.height;
|
|
scale = (aspect > 1) ? (71 / img.width) : (71 / img.height);
|
|
|
|
w = img.width;
|
|
h = img.height;
|
|
|
|
if (scale < 1) {
|
|
w = parseInt(img.width * scale);
|
|
h = parseInt(img.height * scale);
|
|
}
|
|
img_attr += ' style="width: ' + w + 'px; height: ' + h + 'px;"';
|
|
strtoappend += maybeappend;
|
|
}
|
|
} else {
|
|
strtoappend += maybeappend;
|
|
}
|
|
}
|
|
|
|
function pick(img, desc) {
|
|
if (img) {
|
|
if('object' == typeof jQuery('.photolist input') && jQuery('.photolist input').length != 0) length = jQuery('.photolist input').length;
|
|
if(length == 0) length = 1;
|
|
jQuery('.photolist').append('<input name="photo_src[' + length + ']" value="' + img +'" type="hidden"/>');
|
|
jQuery('.photolist').append('<input name="photo_description[' + length + ']" value="' + desc +'" type="hidden"/>');
|
|
insert_editor( "\n\n" + encodeURI('<p style="text-align: center;"><a href="<?php echo $url; ?>"><img src="' + img +'" alt="' + desc + '" /></a></p>'));
|
|
}
|
|
return false;
|
|
}
|
|
|
|
function image_selector(el) {
|
|
var desc, src, parent = jQuery(el).closest('#photo-add-url-div');
|
|
|
|
if ( parent.length ) {
|
|
desc = parent.find('input.tb_this_photo_description').val() || '';
|
|
src = parent.find('input.tb_this_photo').val() || ''
|
|
} else {
|
|
desc = jQuery('#tb_this_photo_description').val() || '';
|
|
src = jQuery('#tb_this_photo').val() || ''
|
|
}
|
|
|
|
tb_remove();
|
|
pick(src, desc);
|
|
jQuery('#extra-fields').hide();
|
|
jQuery('#extra-fields').html('');
|
|
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="button button-small"><?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);
|
|
<?php break;
|
|
}
|
|
die;
|
|
}
|
|
|
|
wp_enqueue_style( 'colors' );
|
|
wp_enqueue_script( 'post' );
|
|
_wp_admin_html_begin();
|
|
?>
|
|
<title><?php _e('Press This') ?></title>
|
|
<script type="text/javascript">
|
|
//<![CDATA[
|
|
addLoadEvent = function(func){if(typeof jQuery!="undefined")jQuery(document).ready(func);else if(typeof wpOnload!='function'){wpOnload=func;}else{var oldonload=wpOnload;wpOnload=function(){oldonload();func();}}};
|
|
var userSettings = {'url':'<?php echo SITECOOKIEPATH; ?>','uid':'<?php if ( ! isset($current_user) ) $current_user = wp_get_current_user(); echo $current_user->ID; ?>','time':'<?php echo time() ?>'};
|
|
var ajaxurl = '<?php echo admin_url( 'admin-ajax.php', 'relative' ); ?>', pagenow = 'press-this', isRtl = <?php echo (int) is_rtl(); ?>;
|
|
var photostorage = false;
|
|
//]]>
|
|
</script>
|
|
|
|
<?php
|
|
do_action('admin_print_styles');
|
|
do_action('admin_print_scripts');
|
|
do_action('admin_head');
|
|
?>
|
|
<script type="text/javascript">
|
|
var wpActiveEditor = 'content';
|
|
|
|
function insert_plain_editor(text) {
|
|
if ( typeof(QTags) != 'undefined' )
|
|
QTags.insertContent(text);
|
|
}
|
|
function set_editor(text) {
|
|
if ( '' == text || '<p></p>' == text )
|
|
text = '<p><br /></p>';
|
|
|
|
if ( tinyMCE.activeEditor )
|
|
tinyMCE.execCommand('mceSetContent', false, text);
|
|
}
|
|
function insert_editor(text) {
|
|
if ( '' != text && tinyMCE.activeEditor && ! tinyMCE.activeEditor.isHidden()) {
|
|
tinyMCE.execCommand('mceInsertContent', false, '<p>' + decodeURI(tinymce.DOM.decode(text)) + '</p>', {format : 'raw'});
|
|
} else {
|
|
insert_plain_editor(decodeURI(text));
|
|
}
|
|
}
|
|
function append_editor(text) {
|
|
if ( '' != text && tinyMCE.activeEditor && ! tinyMCE.activeEditor.isHidden()) {
|
|
tinyMCE.execCommand('mceSetContent', false, tinyMCE.activeEditor.getContent({format : 'raw'}) + '<p>' + text + '</p>');
|
|
} else {
|
|
insert_plain_editor(text);
|
|
}
|
|
}
|
|
|
|
function show(tab_name) {
|
|
jQuery('#extra-fields').html('');
|
|
switch(tab_name) {
|
|
case 'video' :
|
|
jQuery('#extra-fields').load('<?php echo esc_url($_SERVER['PHP_SELF']); ?>', { ajax: 'video', s: '<?php echo esc_attr($selection); ?>'}, function() {
|
|
<?php
|
|
$content = '';
|
|
if ( preg_match("/youtube\.com\/watch/i", $url) ) {
|
|
list($domain, $video_id) = explode("v=", $url);
|
|
$video_id = esc_attr($video_id);
|
|
$content = '<object width="425" height="350"><param name="movie" value="http://www.youtube.com/v/' . $video_id . '"></param><param name="wmode" value="transparent"></param><embed src="http://www.youtube.com/v/' . $video_id . '" type="application/x-shockwave-flash" wmode="transparent" width="425" height="350"></embed></object>';
|
|
|
|
} elseif ( preg_match("/vimeo\.com\/[0-9]+/i", $url) ) {
|
|
list($domain, $video_id) = explode(".com/", $url);
|
|
$video_id = esc_attr($video_id);
|
|
$content = '<object width="400" height="225"><param name="allowfullscreen" value="true" /><param name="allowscriptaccess" value="always" /><param name="movie" value="http://www.vimeo.com/moogaloop.swf?clip_id=' . $video_id . '&server=www.vimeo.com&show_title=1&show_byline=1&show_portrait=0&color=&fullscreen=1" /> <embed src="http://www.vimeo.com/moogaloop.swf?clip_id=' . $video_id . '&server=www.vimeo.com&show_title=1&show_byline=1&show_portrait=0&color=&fullscreen=1" type="application/x-shockwave-flash" allowfullscreen="true" allowscriptaccess="always" width="400" height="225"></embed></object>';
|
|
|
|
if ( trim($selection) == '' )
|
|
$selection = '<p><a href="http://www.vimeo.com/' . $video_id . '?pg=embed&sec=' . $video_id . '">' . $title . '</a> on <a href="http://vimeo.com?pg=embed&sec=' . $video_id . '">Vimeo</a></p>';
|
|
|
|
} elseif ( strpos( $selection, '<object' ) !== false ) {
|
|
$content = $selection;
|
|
}
|
|
?>
|
|
jQuery('#embed-code').prepend('<?php echo htmlentities($content); ?>');
|
|
});
|
|
jQuery('#extra-fields').show();
|
|
return false;
|
|
break;
|
|
case 'photo' :
|
|
function setup_photo_actions() {
|
|
jQuery('.close').click(function() {
|
|
jQuery('#extra-fields').hide();
|
|
jQuery('#extra-fields').html('');
|
|
});
|
|
jQuery('.refresh').click(function() {
|
|
photostorage = false;
|
|
show('photo');
|
|
});
|
|
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('#extra-fields').show();
|
|
}
|
|
|
|
jQuery('#waiting').show();
|
|
if(photostorage == false) {
|
|
jQuery.ajax({
|
|
type: "GET",
|
|
cache : false,
|
|
url: "<?php echo esc_url($_SERVER['PHP_SELF']); ?>",
|
|
data: "ajax=photo_js&u=<?php echo urlencode($url)?>",
|
|
dataType : "script",
|
|
success : function(data) {
|
|
eval(data);
|
|
photostorage = jQuery('#extra-fields').html();
|
|
setup_photo_actions();
|
|
}
|
|
});
|
|
} else {
|
|
jQuery('#extra-fields').html(photostorage);
|
|
setup_photo_actions();
|
|
}
|
|
return false;
|
|
break;
|
|
}
|
|
}
|
|
jQuery(document).ready(function($) {
|
|
//resize screen
|
|
window.resizeTo(740,580);
|
|
// set button actions
|
|
jQuery('#photo_button').click(function() { show('photo'); return false; });
|
|
jQuery('#video_button').click(function() { show('video'); return false; });
|
|
// auto select
|
|
<?php if ( preg_match("/youtube\.com\/watch/i", $url) ) { ?>
|
|
show('video');
|
|
<?php } elseif ( preg_match("/vimeo\.com\/[0-9]+/i", $url) ) { ?>
|
|
show('video');
|
|
<?php } elseif ( preg_match("/flickr\.com/i", $url) ) { ?>
|
|
show('photo');
|
|
<?php } ?>
|
|
jQuery('#title').unbind();
|
|
jQuery('#publish, #save').click(function() { jQuery('.press-this #publishing-actions .spinner').css('display', 'inline-block'); });
|
|
|
|
$('#tagsdiv-post_tag, #categorydiv').children('h3, .handlediv').click(function(){
|
|
$(this).siblings('.inside').toggle();
|
|
});
|
|
});
|
|
</script>
|
|
</head>
|
|
<?php
|
|
$admin_body_class = ( is_rtl() ) ? 'rtl' : '';
|
|
$admin_body_class .= ' locale-' . sanitize_html_class( strtolower( str_replace( '_', '-', get_locale() ) ) );
|
|
?>
|
|
<body class="press-this wp-admin wp-core-ui <?php echo $admin_body_class; ?>">
|
|
<form action="press-this.php?action=post" method="post">
|
|
<div id="poststuff" class="metabox-holder">
|
|
<div id="side-sortables" class="press-this-sidebar">
|
|
<div class="sleeve">
|
|
<?php wp_nonce_field('press-this') ?>
|
|
<input type="hidden" name="post_type" id="post_type" value="text"/>
|
|
<input type="hidden" name="autosave" id="autosave" />
|
|
<input type="hidden" id="original_post_status" name="original_post_status" value="draft" />
|
|
<input type="hidden" id="prev_status" name="prev_status" value="draft" />
|
|
<input type="hidden" id="post_id" name="post_id" value="<?php echo (int) $post_ID; ?>" />
|
|
|
|
<!-- This div holds the photo metadata -->
|
|
<div class="photolist"></div>
|
|
|
|
<div id="submitdiv" class="postbox">
|
|
<div class="handlediv" title="<?php esc_attr_e( 'Click to toggle' ); ?>"><br /></div>
|
|
<h3 class="hndle"><?php _e('Press This') ?></h3>
|
|
<div class="inside">
|
|
<p id="publishing-actions">
|
|
<?php
|
|
submit_button( __( 'Save Draft' ), 'button', 'draft', false, array( 'id' => 'save' ) );
|
|
if ( current_user_can('publish_posts') ) {
|
|
submit_button( __( 'Publish' ), 'primary', 'publish', false );
|
|
} else {
|
|
echo '<br /><br />';
|
|
submit_button( __( 'Submit for Review' ), 'primary', 'review', false );
|
|
} ?>
|
|
<span class="spinner" style="display: none;"></span>
|
|
</p>
|
|
<?php if ( current_theme_supports( 'post-formats' ) && post_type_supports( 'post', 'post-formats' ) ) :
|
|
$post_formats = get_theme_support( 'post-formats' );
|
|
if ( is_array( $post_formats[0] ) ) :
|
|
$default_format = get_option( 'default_post_format', '0' );
|
|
?>
|
|
<p>
|
|
<label for="post_format"><?php _e( 'Post Format:' ); ?>
|
|
<select name="post_format" id="post_format">
|
|
<option value="0"><?php _ex( 'Standard', 'Post format' ); ?></option>
|
|
<?php foreach ( $post_formats[0] as $format ): ?>
|
|
<option<?php selected( $default_format, $format ); ?> value="<?php echo esc_attr( $format ); ?>"> <?php echo esc_html( get_post_format_string( $format ) ); ?></option>
|
|
<?php endforeach; ?>
|
|
</select></label>
|
|
</p>
|
|
<?php endif; endif; ?>
|
|
</div>
|
|
</div>
|
|
|
|
<?php $tax = get_taxonomy( 'category' ); ?>
|
|
<div id="categorydiv" class="postbox">
|
|
<div class="handlediv" title="<?php esc_attr_e( 'Click to toggle' ); ?>"><br /></div>
|
|
<h3 class="hndle"><?php _e('Categories') ?></h3>
|
|
<div class="inside">
|
|
<div id="taxonomy-category" class="categorydiv">
|
|
|
|
<ul id="category-tabs" class="category-tabs">
|
|
<li class="tabs"><a href="#category-all"><?php echo $tax->labels->all_items; ?></a></li>
|
|
<li class="hide-if-no-js"><a href="#category-pop"><?php _e( 'Most Used' ); ?></a></li>
|
|
</ul>
|
|
|
|
<div id="category-pop" class="tabs-panel" style="display: none;">
|
|
<ul id="categorychecklist-pop" class="categorychecklist form-no-clear" >
|
|
<?php $popular_ids = wp_popular_terms_checklist( 'category' ); ?>
|
|
</ul>
|
|
</div>
|
|
|
|
<div id="category-all" class="tabs-panel">
|
|
<ul id="categorychecklist" data-wp-lists="list:category" class="categorychecklist form-no-clear">
|
|
<?php wp_terms_checklist($post_ID, array( 'taxonomy' => 'category', 'popular_cats' => $popular_ids ) ) ?>
|
|
</ul>
|
|
</div>
|
|
|
|
<?php if ( !current_user_can($tax->cap->assign_terms) ) : ?>
|
|
<p><em><?php _e('You cannot modify this Taxonomy.'); ?></em></p>
|
|
<?php endif; ?>
|
|
<?php if ( current_user_can($tax->cap->edit_terms) ) : ?>
|
|
<div id="category-adder" class="wp-hidden-children">
|
|
<h4>
|
|
<a id="category-add-toggle" href="#category-add" class="hide-if-no-js">
|
|
<?php printf( __( '+ %s' ), $tax->labels->add_new_item ); ?>
|
|
</a>
|
|
</h4>
|
|
<p id="category-add" class="category-add wp-hidden-child">
|
|
<label class="screen-reader-text" for="newcategory"><?php echo $tax->labels->add_new_item; ?></label>
|
|
<input type="text" name="newcategory" id="newcategory" class="form-required form-input-tip" value="<?php echo esc_attr( $tax->labels->new_item_name ); ?>" aria-required="true"/>
|
|
<label class="screen-reader-text" for="newcategory_parent">
|
|
<?php echo $tax->labels->parent_item_colon; ?>
|
|
</label>
|
|
<?php wp_dropdown_categories( array( 'taxonomy' => 'category', 'hide_empty' => 0, 'name' => 'newcategory_parent', 'orderby' => 'name', 'hierarchical' => 1, 'show_option_none' => '— ' . $tax->labels->parent_item . ' —' ) ); ?>
|
|
<input type="button" id="category-add-submit" data-wp-lists="add:categorychecklist:category-add" class="button category-add-submit" value="<?php echo esc_attr( $tax->labels->add_new_item ); ?>" />
|
|
<?php wp_nonce_field( 'add-category', '_ajax_nonce-add-category', false ); ?>
|
|
<span id="category-ajax-response"></span>
|
|
</p>
|
|
</div>
|
|
<?php endif; ?>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div id="tagsdiv-post_tag" class="postbox">
|
|
<div class="handlediv" title="<?php esc_attr_e( 'Click to toggle' ); ?>"><br /></div>
|
|
<h3><span><?php _e('Tags'); ?></span></h3>
|
|
<div class="inside">
|
|
<div class="tagsdiv" id="post_tag">
|
|
<div class="jaxtag">
|
|
<label class="screen-reader-text" for="newtag"><?php _e('Tags'); ?></label>
|
|
<input type="hidden" name="tax_input[post_tag]" class="the-tags" id="tax-input[post_tag]" value="" />
|
|
<div class="ajaxtag">
|
|
<input type="text" name="newtag[post_tag]" class="newtag form-input-tip" size="16" autocomplete="off" value="" />
|
|
<input type="button" class="button tagadd" value="<?php esc_attr_e('Add'); ?>" />
|
|
</div>
|
|
</div>
|
|
<div class="tagchecklist"></div>
|
|
</div>
|
|
<p class="tagcloud-link"><a href="#titlediv" class="tagcloud-link" id="link-post_tag"><?php _e('Choose from the most used tags'); ?></a></p>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="posting">
|
|
|
|
<div id="wphead">
|
|
<img id="header-logo" src="<?php echo esc_url( includes_url( 'images/blank.gif' ) ); ?>" alt="" width="16" height="16" />
|
|
<h1 id="site-heading">
|
|
<a href="<?php echo get_option('home'); ?>/" target="_blank">
|
|
<span id="site-title"><?php bloginfo('name'); ?></span>
|
|
</a>
|
|
</h1>
|
|
</div>
|
|
|
|
<?php
|
|
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 } ?>
|
|
|
|
<div id="titlediv">
|
|
<div class="titlewrap">
|
|
<input name="title" id="title" class="text" value="<?php echo esc_attr($title);?>"/>
|
|
</div>
|
|
</div>
|
|
|
|
<div id="waiting" style="display: none"><span class="spinner"></span> <span><?php esc_html_e( 'Loading...' ); ?></span></div>
|
|
|
|
<div id="extra-fields" style="display: none"></div>
|
|
|
|
<div class="postdivrich">
|
|
<?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:' );
|
|
|
|
if ( current_user_can('upload_files') ) {
|
|
?>
|
|
<a id="photo_button" title="<?php esc_attr_e('Insert an Image'); ?>" href="#">
|
|
<img alt="<?php esc_attr_e('Insert an Image'); ?>" src="<?php echo esc_url( admin_url( 'images/media-button-image.gif?ver=20100531' ) ); ?>"/></a>
|
|
<?php
|
|
}
|
|
?>
|
|
<a id="video_button" title="<?php esc_attr_e('Embed a Video'); ?>" href="#"><img alt="<?php esc_attr_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>
|
|
</form>
|
|
<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="tb_this_photo text" onkeypress="if(event.keyCode==13) image_selector(this);" /></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="tb_this_photo_description text" onkeypress="if(event.keyCode==13) image_selector(this);" value="<?php echo esc_attr($title);?>"/></td>
|
|
</tr><tr>
|
|
<td><input type="button" class="button" onclick="image_selector(this)" value="<?php esc_attr_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>
|
|
</body>
|
|
</html>
|