diff --git a/wp-admin/includes/post.php b/wp-admin/includes/post.php
index 6e719ef67..e47df7ac8 100644
--- a/wp-admin/includes/post.php
+++ b/wp-admin/includes/post.php
@@ -943,16 +943,13 @@ function get_sample_permalink($id, $title=null, $name = null) {
* @param unknown_type $new_slug
* @return unknown
*/
-function get_sample_permalink_html($id, $new_title=null, $new_slug=null) {
+function get_sample_permalink_html( $id, $new_title = null, $new_slug = null ) {
$post = &get_post($id);
list($permalink, $post_name) = get_sample_permalink($post->ID, $new_title, $new_slug);
if ( 'publish' == $post->post_status )
$view_post = 'post' == $post->post_type ? __('View Post') : __('View Page');
if ( false === strpos($permalink, '%postname%') && false === strpos($permalink, '%pagename%') ) {
- if ( 'page' == $post->post_type )
- return '';
-
$return = '' . __('Permalink:') . "\n" . '' . $permalink . "\n";
$return .= '' . __('Change Permalinks') . "\n";
if ( isset($view_post) )
diff --git a/wp-admin/js/slug.dev.js b/wp-admin/js/slug.dev.js
index f15cf97d0..fa9860b2d 100644
--- a/wp-admin/js/slug.dev.js
+++ b/wp-admin/js/slug.dev.js
@@ -1,7 +1,8 @@
function edit_permalink(post_id) {
var i, c = 0, e = jQuery('#editable-post-name'), revert_e = e.html(), real_slug = jQuery('#post_name'), revert_slug = real_slug.html(), b = jQuery('#edit-slug-buttons'), revert_b = b.html(), full = jQuery('#editable-post-name-full').html();
- b.html(''+slugL10n.save+' '+slugL10n.cancel+'');
+ jQuery('#view-post-btn').hide();
+ b.html(''+slugL10n.save+' '+slugL10n.cancel+'');
b.children('.save').click(function() {
var new_slug = e.children('input').val();
jQuery.post(slugL10n.requestFile, {
@@ -14,10 +15,12 @@ function edit_permalink(post_id) {
b.html(revert_b);
real_slug.attr('value', new_slug);
make_slugedit_clickable();
+ jQuery('#view-post-btn').show();
});
return false;
});
jQuery('#edit-slug-buttons .cancel').click(function() {
+ jQuery('#view-post-btn').show();
e.html(revert_e);
b.html(revert_b);
real_slug.attr('value', revert_slug);
diff --git a/wp-admin/js/slug.js b/wp-admin/js/slug.js
index 2fed33ac9..a17946fea 100644
--- a/wp-admin/js/slug.js
+++ b/wp-admin/js/slug.js
@@ -1 +1 @@
-function edit_permalink(a){var d,h=0,g=jQuery("#editable-post-name"),j=g.html(),m=jQuery("#post_name"),n=m.html(),k=jQuery("#edit-slug-buttons"),l=k.html(),f=jQuery("#editable-post-name-full").html();k.html(''+slugL10n.save+' '+slugL10n.cancel+"");k.children(".save").click(function(){var b=g.children("input").val();jQuery.post(slugL10n.requestFile,{action:"sample-permalink",post_id:a,new_slug:b,new_title:jQuery("#title").val(),samplepermalinknonce:jQuery("#samplepermalinknonce").val()},function(c){jQuery("#edit-slug-box").html(c);k.html(l);m.attr("value",b);make_slugedit_clickable()});return false});jQuery("#edit-slug-buttons .cancel").click(function(){g.html(j);k.html(l);m.attr("value",n);return false});for(d=0;df.length/4)?"":f;g.html('').children("input").keypress(function(c){var b=c.charCode?c.charCode:c.keyCode?c.keyCode:0;if(13==b){k.children(".save").click();return false}if(27==b){k.children(".cancel").click();return false}m.attr("value",this.value)}).focus()}function make_slugedit_clickable(){jQuery("#editable-post-name").click(function(){jQuery("#edit-slug-buttons").children(".edit-slug").click()})};
\ No newline at end of file
+function edit_permalink(a){var d,h=0,g=jQuery("#editable-post-name"),j=g.html(),m=jQuery("#post_name"),n=m.html(),k=jQuery("#edit-slug-buttons"),l=k.html(),f=jQuery("#editable-post-name-full").html();jQuery("#view-post-btn").hide();k.html(''+slugL10n.save+' '+slugL10n.cancel+"");k.children(".save").click(function(){var b=g.children("input").val();jQuery.post(slugL10n.requestFile,{action:"sample-permalink",post_id:a,new_slug:b,new_title:jQuery("#title").val(),samplepermalinknonce:jQuery("#samplepermalinknonce").val()},function(c){jQuery("#edit-slug-box").html(c);k.html(l);m.attr("value",b);make_slugedit_clickable();jQuery("#view-post-btn").show()});return false});jQuery("#edit-slug-buttons .cancel").click(function(){jQuery("#view-post-btn").show();g.html(j);k.html(l);m.attr("value",n);return false});for(d=0;df.length/4)?"":f;g.html('').children("input").keypress(function(c){var b=c.charCode?c.charCode:c.keyCode?c.keyCode:0;if(13==b){k.children(".save").click();return false}if(27==b){k.children(".cancel").click();return false}m.attr("value",this.value)}).focus()}function make_slugedit_clickable(){jQuery("#editable-post-name").click(function(){jQuery("#edit-slug-buttons").children(".edit-slug").click()})};
\ No newline at end of file
diff --git a/wp-includes/link-template.php b/wp-includes/link-template.php
index 47ef1a7cd..05e7c0f8c 100644
--- a/wp-includes/link-template.php
+++ b/wp-includes/link-template.php
@@ -92,15 +92,18 @@ function get_permalink($id = 0, $leavename = false) {
$leavename? '' : '%pagename%',
);
- if ( is_object($id) && isset($id->filter) && 'sample' == $id->filter )
+ if ( is_object($id) && isset($id->filter) && 'sample' == $id->filter ) {
$post = $id;
- else
+ $sample = true;
+ } else {
$post = &get_post($id);
+ $sample = false;
+ }
if ( empty($post->ID) ) return false;
if ( $post->post_type == 'page' )
- return get_page_link($post->ID, $leavename);
+ return get_page_link($post->ID, $leavename, $sample);
elseif ($post->post_type == 'attachment')
return get_attachment_link($post->ID);
@@ -177,10 +180,11 @@ function post_permalink($post_id = 0, $deprecated = '') {
* @since 1.5.0
*
* @param int $id Optional. Post ID.
- * @param bool $leavename Optional, defaults to false. Whether to keep post name or page name.
+ * @param bool $leavename Optional, defaults to false. Whether to keep page name.
+ * @param bool $sample Optional, defaults to false. Is it a sample permalink.
* @return string
*/
-function get_page_link($id = false, $leavename = false) {
+function get_page_link( $id = false, $leavename = false, $sample = false ) {
global $post;
$id = (int) $id;
@@ -190,7 +194,7 @@ function get_page_link($id = false, $leavename = false) {
if ( 'page' == get_option('show_on_front') && $id == get_option('page_on_front') )
$link = get_option('home');
else
- $link = _get_page_link( $id , $leavename );
+ $link = _get_page_link( $id , $leavename, $sample );
return apply_filters('page_link', $link, $id);
}
@@ -205,9 +209,10 @@ function get_page_link($id = false, $leavename = false) {
*
* @param int $id Optional. Post ID.
* @param bool $leavename Optional. Leave name.
+ * @param bool $sample Optional. Sample permalink.
* @return string
*/
-function _get_page_link( $id = false, $leavename = false ) {
+function _get_page_link( $id = false, $leavename = false, $sample = false ) {
global $post, $wp_rewrite;
if ( !$id )
@@ -217,7 +222,7 @@ function _get_page_link( $id = false, $leavename = false ) {
$pagestruct = $wp_rewrite->get_page_permastruct();
- if ( '' != $pagestruct && isset($post->post_status) && 'draft' != $post->post_status ) {
+ if ( '' != $pagestruct && ( ( isset($post->post_status) && 'draft' != $post->post_status ) || $sample ) ) {
$link = get_page_uri($id);
$link = ( $leavename ) ? $pagestruct : str_replace('%pagename%', $link, $pagestruct);
$link = get_option('home') . "/$link";
diff --git a/wp-includes/script-loader.php b/wp-includes/script-loader.php
index 3b3cc0c71..298752117 100644
--- a/wp-includes/script-loader.php
+++ b/wp-includes/script-loader.php
@@ -240,7 +240,7 @@ function wp_default_scripts( &$scripts ) {
'requestFile' => admin_url('admin-ajax.php')
) );
- $scripts->add( 'slug', "/wp-admin/js/slug$suffix.js", array('jquery'), '20090102' );
+ $scripts->add( 'slug', "/wp-admin/js/slug$suffix.js", array('jquery'), '20090207' );
$scripts->add_data( 'slug', 'group', 1 );
$scripts->localize( 'slug', 'slugL10n', array(
'requestFile' => admin_url('admin-ajax.php'),