X-Git-Url: https://scripts.mit.edu/gitweb/autoinstalls/wordpress.git/blobdiff_plain/9c40b4d36daed9e28e48a5fe9205c32557195a4b..ebf9bbbbf2dbd59c653bbec4ed90d2947a95b9e7:/wp-admin/js/inline-edit-post.dev.js diff --git a/wp-admin/js/inline-edit-post.dev.js b/wp-admin/js/inline-edit-post.dev.js index ecc93b6b..96b36fed 100644 --- a/wp-admin/js/inline-edit-post.dev.js +++ b/wp-admin/js/inline-edit-post.dev.js @@ -1,25 +1,36 @@ - (function($) { inlineEditPost = { - init : function() { + init : function(){ var t = this, qeRow = $('#inline-edit'), bulkRow = $('#bulk-edit'); - t.type = $('table.widefat').hasClass('page') ? 'page' : 'post'; - t.what = '#'+t.type+'-'; - - // get all editable rows - t.rows = $('tr.iedit'); + t.type = $('table.widefat').hasClass('pages') ? 'page' : 'post'; + t.what = '#post-'; // prepare the edit rows - qeRow.keyup(function(e) { if(e.which == 27) return inlineEditPost.revert(); }); - bulkRow.keyup(function(e) { if (e.which == 27) return inlineEditPost.revert(); }); + qeRow.keyup(function(e){ + if (e.which == 27) + return inlineEditPost.revert(); + }); + bulkRow.keyup(function(e){ + if (e.which == 27) + return inlineEditPost.revert(); + }); - $('a.cancel', qeRow).click(function() { return inlineEditPost.revert(); }); - $('a.save', qeRow).click(function() { return inlineEditPost.save(this); }); - $('td', qeRow).keydown(function(e) { if ( e.which == 13 ) return inlineEditPost.save(this); }); + $('a.cancel', qeRow).click(function(){ + return inlineEditPost.revert(); + }); + $('a.save', qeRow).click(function(){ + return inlineEditPost.save(this); + }); + $('td', qeRow).keydown(function(e){ + if ( e.which == 13 ) + return inlineEditPost.save(this); + }); - $('a.cancel', bulkRow).click(function() { return inlineEditPost.revert(); }); + $('a.cancel', bulkRow).click(function(){ + return inlineEditPost.revert(); + }); $('#inline-edit .inline-edit-private input[value=private]').click( function(){ var pw = $('input.inline-edit-password-input'); @@ -31,7 +42,10 @@ inlineEditPost = { }); // add events - t.addEvents(t.rows); + $('a.editinline').live('click', function(){ + inlineEditPost.edit(this); + return false; + }); $('#bulk-title-div').parents('fieldset').after( $('#inline-edit fieldset.inline-edit-categories').clone() @@ -39,17 +53,13 @@ inlineEditPost = { $('#inline-edit label.inline-edit-tags').clone() ); - // categories expandable? - $('span.catshow').click(function() { - $('.inline-editor ul.cat-checklist').addClass("cat-hover"); - $('.inline-editor span.cathide').show(); - $(this).hide(); + // hiearchical taxonomies expandable? + $('span.catshow').click(function(){ + $(this).hide().next().show().parent().next().addClass("cat-hover"); }); - $('span.cathide').click(function() { - $('.inline-editor ul.cat-checklist').removeClass("cat-hover"); - $('.inline-editor span.catshow').show(); - $(this).hide(); + $('span.cathide').click(function(){ + $(this).hide().prev().show().parent().next().removeClass("cat-hover"); }); $('select[name="_status"] option[value="future"]', bulkRow).remove(); @@ -68,23 +78,15 @@ inlineEditPost = { if ( $('form#posts-filter tr.inline-editor').length > 0 ) t.revert(); }); - }, - toggle : function(el) { + toggle : function(el){ var t = this; $(t.what+t.getId(el)).css('display') == 'none' ? t.revert() : t.edit(el); }, - addEvents : function(r) { - r.each(function() { - var row = $(this); - $('a.editinline', row).click(function() { inlineEditPost.edit(this); return false; }); - }); - }, - - setBulk : function() { - var te = '', type = this.type, tax; + setBulk : function(){ + var te = '', type = this.type, tax, c = true; this.revert(); $('#bulk-edit td').attr('colspan', $('.widefat:first thead th:visible').length); @@ -93,14 +95,18 @@ inlineEditPost = { $('tbody th.check-column input[type="checkbox"]').each(function(i){ if ( $(this).attr('checked') ) { + c = false; var id = $(this).val(), theTitle; theTitle = $('#inline_'+id+' .post_title').text() || inlineEditL10n.notitle; te += '
X'+theTitle+'
'; } }); + if ( c ) + return this.revert(); + $('#bulk-titles').html(te); - $('#bulk-titles a').click(function() { + $('#bulk-titles a').click(function(){ var id = $(this).attr('id').substr(1); $('table.widefat input[value="'+id+'"]').attr('checked', ''); @@ -108,7 +114,7 @@ inlineEditPost = { }); // enable autocomplete for tags - if ( type == 'post' ) { + if ( 'post' == type ) { // support multi taxonomies? tax = 'post_tag'; $('tr.inline-editor textarea[name="tags_input"]').suggest( 'admin-ajax.php?action=ajax-tag-search&tax='+tax, { delay: 500, minchars: 2, multiple: true, multipleSep: ", " } ); @@ -116,15 +122,15 @@ inlineEditPost = { }, edit : function(id) { - var t = this, fields, editRow, rowData, cats, status, pageOpt, f, pageLevel, nextPage, pageLoop = true, nextLevel, tax; + var t = this, fields, editRow, rowData, cats, status, pageOpt, pageLevel, nextPage, pageLoop = true, nextLevel, tax; t.revert(); if ( typeof(id) == 'object' ) id = t.getId(id); fields = ['post_title', 'post_name', 'post_author', '_status', 'jj', 'mm', 'aa', 'hh', 'mn', 'ss', 'post_password']; - if ( t.type == 'page' ) fields.push('post_parent', 'menu_order', 'page_template'); - if ( t.type == 'post' ) fields.push('tags_input'); + if ( t.type == 'page' ) + fields.push('post_parent', 'menu_order', 'page_template'); // add the new blank row editRow = $('#inline-edit').clone(true); @@ -136,7 +142,15 @@ inlineEditPost = { // populate the data rowData = $('#inline_'+id); - for ( f = 0; f < fields.length; f++ ) { + if ( !$(':input[name="post_author"] option[value=' + $('.post_author', rowData).text() + ']', editRow).val() ) { + // author no longer has edit caps, so we need to add them to the list of authors + $(':input[name="post_author"]', editRow).prepend(''); + } + if ( $(':input[name="post_author"] option', editRow).length == 1 ) { + $('label.inline-edit-author', editRow).hide(); + } + + for ( var f = 0; f < fields.length; f++ ) { $(':input[name="'+fields[f]+'"]', editRow).val( $('.'+fields[f], rowData).text() ); } @@ -147,14 +161,33 @@ inlineEditPost = { if ( $('.sticky', rowData).text() == 'sticky' ) $('input[name="sticky"]', editRow).attr("checked", "checked"); - // categories - if ( cats = $('.post_category', rowData).text() ) - $('ul.cat-checklist :checkbox', editRow).val(cats.split(',')); + // hierarchical taxonomies + $('.post_category', rowData).each(function(){ + var term_ids = $(this).text(); + + if ( term_ids ) { + taxname = $(this).attr('id').replace('_'+id, ''); + $('ul.'+taxname+'-checklist :checkbox', editRow).val(term_ids.split(',')); + } + }); + //flat taxonomies + $('.tags_input', rowData).each(function(){ + var terms = $(this).text(); + + if ( terms ) { + taxname = $(this).attr('id').replace('_'+id, ''); + $('textarea.tax_input_'+taxname, editRow).val(terms); + $('textarea.tax_input_'+taxname, editRow).suggest( 'admin-ajax.php?action=ajax-tag-search&tax='+taxname, { delay: 500, minchars: 2, multiple: true, multipleSep: ", " } ); + } + }); + // handle the post status status = $('._status', rowData).text(); - if ( status != 'future' ) $('select[name="_status"] option[value="future"]', editRow).remove(); - if ( status == 'private' ) { + if ( 'future' != status ) + $('select[name="_status"] option[value="future"]', editRow).remove(); + + if ( 'private' == status ) { $('input[name="keep_private"]', editRow).attr("checked", "checked"); $('input.inline-edit-password-input').val('').attr('disabled', 'disabled'); } @@ -181,31 +214,26 @@ inlineEditPost = { $(editRow).attr('id', 'edit-'+id).addClass('inline-editor').show(); $('.ptitle', editRow).focus(); - // enable autocomplete for tags - if ( t.type == 'post' ) { - tax = 'post_tag'; - $('tr.inline-editor textarea[name="tags_input"]').suggest( 'admin-ajax.php?action=ajax-tag-search&tax='+tax, { delay: 500, minchars: 2, multiple: true, multipleSep: ", " } ); - } - return false; }, save : function(id) { - var params, fields; + var params, fields, page = $('.post_status_page').val() || ''; - if( typeof(id) == 'object' ) + if ( typeof(id) == 'object' ) id = this.getId(id); $('table.widefat .inline-edit-save .waiting').show(); params = { action: 'inline-save', - post_type: this.type, + post_type: typenow, post_ID: id, - edit_date: 'true' + edit_date: 'true', + post_status: page }; - fields = $('#edit-'+id+' :input').fieldSerialize(); + fields = $('#edit-'+id+' :input').serialize(); params = fields + '&' + $.param(params); // make ajax request @@ -217,15 +245,7 @@ inlineEditPost = { if ( -1 != r.indexOf(']*?>/g, '' ); $('#edit-'+id+' .inline-edit-save').append(''+r+''); @@ -238,17 +258,17 @@ inlineEditPost = { return false; }, - revert : function() { - var id; + revert : function(){ + var id = $('table.widefat tr.inline-editor').attr('id'); - if ( id = $('table.widefat tr.inline-editor').attr('id') ) { + if ( id ) { $('table.widefat .inline-edit-save .waiting').hide(); if ( 'bulk-edit' == id ) { $('table.widefat #bulk-edit').removeClass('inline-editor').hide(); $('#bulk-titles').html(''); $('#inlineedit').append( $('#bulk-edit') ); - } else { + } else { $('#'+id).remove(); id = id.substr( id.lastIndexOf('-') + 1 ); $(this.what+id).show(); @@ -259,7 +279,8 @@ inlineEditPost = { }, getId : function(o) { - var id = o.tagName == 'TR' ? o.id : $(o).parents('tr').attr('id'), parts = id.split('-'); + var id = $(o).closest('tr').attr('id'), + parts = id.split('-'); return parts[parts.length - 1]; } };