Add media library uploader tab. Props andy. see #5911
git-svn-id: http://svn.automattic.com/wordpress/trunk@7062 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
e1bb43b66b
commit
cc39b5fbce
|
@ -1,42 +1,34 @@
|
||||||
div#media-upload-header {
|
div#media-upload-header {
|
||||||
background-color: #eaf3fa;
|
background-color: #e4f2fd;
|
||||||
margin: 0;
|
margin: 0;
|
||||||
padding: 1em 0.5em 0.5em 0.5em;
|
padding: 1em 0.5em 0 0.5em;
|
||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
|
position: relative;
|
||||||
|
border-bottom: 1px solid #c6d9e9;
|
||||||
}
|
}
|
||||||
|
|
||||||
ul#media-upload-tabs {
|
ul#sidemenu {
|
||||||
display:inline;
|
font-weight: normal;
|
||||||
|
margin: 0 15px;
|
||||||
position: absolute;
|
position: absolute;
|
||||||
right: 1em;
|
right: 1em;
|
||||||
top: 1em;
|
bottom: -1px;
|
||||||
font-size: 0.9em;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ul#media-upload-tabs li {
|
|
||||||
display:inline;
|
|
||||||
}
|
|
||||||
|
|
||||||
ul#media-upload-tabs li:after {
|
|
||||||
content: " | ";
|
|
||||||
}
|
|
||||||
|
|
||||||
ul#media-upload-tabs li.last:after {
|
|
||||||
content: "";
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
div#media-upload-error {
|
div#media-upload-error {
|
||||||
margin: 1em;
|
margin: 1em;
|
||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
color: #f00;
|
color: #f00;
|
||||||
}
|
}
|
||||||
|
|
||||||
form.media-upload-form {
|
form {
|
||||||
margin: 1em;
|
margin: 1em;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#search-filter {
|
||||||
|
text-align: right;
|
||||||
|
}
|
||||||
|
|
||||||
.media-upload-form label, .media-upload-form legend {
|
.media-upload-form label, .media-upload-form legend {
|
||||||
display:block;
|
display:block;
|
||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
|
|
|
@ -29,20 +29,18 @@ function the_media_upload_tabs() {
|
||||||
$tabs = media_upload_tabs();
|
$tabs = media_upload_tabs();
|
||||||
|
|
||||||
if ( !empty($tabs) ) {
|
if ( !empty($tabs) ) {
|
||||||
echo "<ul id='media-upload-tabs'>\n";
|
echo "<ul id='sidemenu'>\n";
|
||||||
if ( isset($_GET['tab']) && array_key_exists($_GET['tab'], $tabs) )
|
if ( isset($_GET['tab']) && array_key_exists($_GET['tab'], $tabs) )
|
||||||
$current = $_GET['tab'];
|
$current = $_GET['tab'];
|
||||||
else
|
else
|
||||||
$current = array_shift(array_keys($tabs));
|
$current = array_shift(array_keys($tabs));
|
||||||
foreach ( $tabs as $callback => $text ) {
|
foreach ( $tabs as $callback => $text ) {
|
||||||
if ( ++$i == count($tabs) )
|
$class = '';
|
||||||
$class = ' class="last"';
|
if ( $current == $callback )
|
||||||
$href = add_query_arg('tab', $callback);
|
$class = " class='current'";
|
||||||
if ( $callback == $current )
|
$href = add_query_arg(array('tab'=>$callback, 's'=>false, 'paged'=>false, 'post_mime_type'=>false, 'm'=>false));
|
||||||
$link = $text;
|
$link = "<a href='$href'$class>$text</a>";
|
||||||
else
|
echo "\t<li id='tab-$callback'>$link</li>\n";
|
||||||
$link = "<a href='$href'>$text</a>";
|
|
||||||
echo "\t<li id='tab-$callback'$class>$link</li>\n";
|
|
||||||
}
|
}
|
||||||
echo "</ul>\n";
|
echo "</ul>\n";
|
||||||
}
|
}
|
||||||
|
@ -261,15 +259,26 @@ function media_upload_attachments() {
|
||||||
}
|
}
|
||||||
|
|
||||||
function media_upload_library() {
|
function media_upload_library() {
|
||||||
if ( empty($_POST) )
|
if ( !empty($_POST) ) {
|
||||||
wp_iframe( 'media_upload_library_form', $errors );
|
$return = media_upload_form_handler();
|
||||||
|
|
||||||
|
if ( is_string($return) )
|
||||||
|
return $return;
|
||||||
|
if ( is_array($return) )
|
||||||
|
$errors = $return;
|
||||||
|
}
|
||||||
|
|
||||||
|
return wp_iframe( 'media_upload_library_form', $errors );
|
||||||
}
|
}
|
||||||
|
|
||||||
function get_media_items( $post_id, $errors ) {
|
function get_media_items( $post_id, $errors ) {
|
||||||
if ( $post_id )
|
if ( $post_id ) {
|
||||||
$attachments = get_children("post_parent=$post_id&post_type=attachment&orderby=menu_order ASC, ID&order=DESC");
|
$attachments = get_children("post_parent=$post_id&post_type=attachment&orderby=menu_order ASC, ID&order=DESC");
|
||||||
else
|
} else {
|
||||||
$attachments = get_paged_attachments();
|
if ( is_array($GLOBALS['wp_the_query']->posts) )
|
||||||
|
foreach ( $GLOBALS['wp_the_query']->posts as $attachment )
|
||||||
|
$attachments[$attachment->ID] = $attachment;
|
||||||
|
}
|
||||||
|
|
||||||
if ( empty($attachments) )
|
if ( empty($attachments) )
|
||||||
return '';
|
return '';
|
||||||
|
@ -707,7 +716,141 @@ jQuery(function($){
|
||||||
}
|
}
|
||||||
|
|
||||||
function media_upload_library_form($errors) {
|
function media_upload_library_form($errors) {
|
||||||
|
global $wpdb, $wp_query, $wp_locale;
|
||||||
|
|
||||||
media_upload_header();
|
media_upload_header();
|
||||||
|
|
||||||
|
$post_id = intval($_REQUEST['post_id']);
|
||||||
|
|
||||||
|
$form_action_url = get_option('siteurl') . "/wp-admin/media-upload.php?type=media&tab=library&post_id=$post_id";
|
||||||
|
|
||||||
|
$_GET['paged'] = intval($_GET['paged']);
|
||||||
|
if ( $_GET['paged'] < 1 )
|
||||||
|
$_GET['paged'] = 1;
|
||||||
|
$start = ( $_GET['paged'] - 1 ) * 10;
|
||||||
|
if ( $start < 1 )
|
||||||
|
$start = 0;
|
||||||
|
add_filter( 'post_limits', $limit_filter = create_function( '$a', "return 'LIMIT $start, 10';" ) );
|
||||||
|
|
||||||
|
list($post_mime_types, $avail_post_mime_types) = wp_edit_attachments_query();
|
||||||
|
|
||||||
|
?>
|
||||||
|
|
||||||
|
<form id="filter" action="" method="get">
|
||||||
|
<input type="hidden" name="type" value="media" />
|
||||||
|
<input type="hidden" name="tab" value="library" />
|
||||||
|
<input type="hidden" name="post_id" value="<?php echo $post_id; ?>" />
|
||||||
|
<input type="hidden" name="post_mime_type" value="<?php echo $_GET['post_mime_type']; ?>" />
|
||||||
|
|
||||||
|
<div id="search-filter">
|
||||||
|
<input type="text" id="post-search-input" name="s" value="<?php the_search_query(); ?>" />
|
||||||
|
<input type="submit" value="<?php _e( 'Search Media' ); ?>" class="button" />
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<p>
|
||||||
|
<ul class="subsubsub">
|
||||||
|
<?php
|
||||||
|
$type_links = array();
|
||||||
|
$_num_posts = (array) wp_count_attachments();
|
||||||
|
$matches = wp_match_mime_types(array_keys($post_mime_types), array_keys($_num_posts));
|
||||||
|
foreach ( $matches as $type => $reals )
|
||||||
|
foreach ( $reals as $real )
|
||||||
|
$num_posts[$type] += $_num_posts[$real];
|
||||||
|
foreach ( $post_mime_types as $mime_type => $label ) {
|
||||||
|
$class = '';
|
||||||
|
|
||||||
|
if ( !wp_match_mime_types($mime_type, $avail_post_mime_types) )
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if ( wp_match_mime_types($mime_type, $_GET['post_mime_type']) )
|
||||||
|
$class = ' class="current"';
|
||||||
|
|
||||||
|
$type_links[] = "<li><a href='" . add_query_arg(array('post_mime_type'=>$mime_type, 'paged'=>false)) . "'$class>" . sprintf($label[2], $num_posts[$mime_type]) . '</a>';
|
||||||
|
}
|
||||||
|
$class = empty($_GET['post_mime_type']) ? ' class="current"' : '';
|
||||||
|
$type_links[] = "<li><a href='" . remove_query_arg(array('post_mime_type', 'paged', 'm')) . "'$class>".__('All Types')."</a>";
|
||||||
|
echo implode(' | </li>', $type_links) . '</li>';
|
||||||
|
unset($type_links);
|
||||||
|
?>
|
||||||
|
</ul>
|
||||||
|
</p>
|
||||||
|
|
||||||
|
<div class="tablenav">
|
||||||
|
|
||||||
|
<?php
|
||||||
|
$page_links = paginate_links( array(
|
||||||
|
'base' => add_query_arg( 'paged', '%#%' ),
|
||||||
|
'format' => '',
|
||||||
|
'total' => ceil($wp_query->found_posts / 10),
|
||||||
|
'current' => $_GET['paged']
|
||||||
|
));
|
||||||
|
|
||||||
|
if ( $page_links )
|
||||||
|
echo "<div class='tablenav-pages'>$page_links</div>";
|
||||||
|
?>
|
||||||
|
|
||||||
|
<div style="float: left">
|
||||||
|
<?php
|
||||||
|
|
||||||
|
$arc_query = "SELECT DISTINCT YEAR(post_date) AS yyear, MONTH(post_date) AS mmonth FROM $wpdb->posts WHERE post_type = 'attachment' ORDER BY post_date DESC";
|
||||||
|
|
||||||
|
$arc_result = $wpdb->get_results( $arc_query );
|
||||||
|
|
||||||
|
$month_count = count($arc_result);
|
||||||
|
|
||||||
|
if ( $month_count && !( 1 == $month_count && 0 == $arc_result[0]->mmonth ) ) { ?>
|
||||||
|
<select name='m'>
|
||||||
|
<option<?php selected( @$_GET['m'], 0 ); ?> value='0'><?php _e('Show all dates'); ?></option>
|
||||||
|
<?php
|
||||||
|
foreach ($arc_result as $arc_row) {
|
||||||
|
if ( $arc_row->yyear == 0 )
|
||||||
|
continue;
|
||||||
|
$arc_row->mmonth = zeroise( $arc_row->mmonth, 2 );
|
||||||
|
|
||||||
|
if ( $arc_row->yyear . $arc_row->mmonth == $_GET['m'] )
|
||||||
|
$default = ' selected="selected"';
|
||||||
|
else
|
||||||
|
$default = '';
|
||||||
|
|
||||||
|
echo "<option$default value='$arc_row->yyear$arc_row->mmonth'>";
|
||||||
|
echo $wp_locale->get_month($arc_row->mmonth) . " $arc_row->yyear";
|
||||||
|
echo "</option>\n";
|
||||||
|
}
|
||||||
|
?>
|
||||||
|
</select>
|
||||||
|
<?php } ?>
|
||||||
|
|
||||||
|
<input type="submit" id="post-query-submit" value="<?php _e('Filter »'); ?>" class="button-secondary" />
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<br style="clear:both;" />
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
|
||||||
|
<form enctype="multipart/form-data" method="post" action="<?php echo attribute_escape($form_action_url); ?>" class="media-upload-form" id="attachments-form">
|
||||||
|
|
||||||
|
<script type="text/javascript">
|
||||||
|
<!--
|
||||||
|
jQuery(function($){
|
||||||
|
var preloaded = $(".media-item.preloaded");
|
||||||
|
if ( preloaded.length > 0 ) {
|
||||||
|
preloaded.each(function(){prepareMediaItem({id:this.id.replace(/[^0-9]/g, '')},'');});
|
||||||
|
updateMediaForm();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
-->
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<?php wp_nonce_field('media-form'); ?>
|
||||||
|
<?php //media_upload_form( $errors ); ?>
|
||||||
|
|
||||||
|
<div id="media-items">
|
||||||
|
<?php echo get_media_items(null, $errors); ?>
|
||||||
|
</div>
|
||||||
|
<input type="hidden" name="post_id" id="post_id" value="<?php echo $post_id; ?>" />
|
||||||
|
</form>
|
||||||
|
<?php
|
||||||
}
|
}
|
||||||
|
|
||||||
add_filter('async_upload_media', 'get_media_item', 10, 2);
|
add_filter('async_upload_media', 'get_media_item', 10, 2);
|
||||||
|
|
|
@ -37,7 +37,8 @@ if ( 1 == $_GET['c'] )
|
||||||
|
|
||||||
require_once('admin-header.php');
|
require_once('admin-header.php');
|
||||||
|
|
||||||
add_filter( 'post_limits', $limit_filter = create_function( '$a', 'if ( empty($_GET["paged"]) ) $_GET["paged"] = 1; $start = ( intval($_GET["paged"]) - 1 ) * 15; return "LIMIT $start, 20";' ) );
|
if ( isset($_GET['paged']) && $start = ( intval($_GET['paged']) - 1 ) * 15 )
|
||||||
|
add_filter( 'post_limits', $limit_filter = create_function( '$a', "return 'LIMIT $start, 15';" ) );
|
||||||
list($post_mime_types, $avail_post_mime_types) = wp_edit_attachments_query();
|
list($post_mime_types, $avail_post_mime_types) = wp_edit_attachments_query();
|
||||||
$wp_query->max_num_pages = ceil( $wp_query->found_posts / 15 ); // We grab 20 but only show 15 ( 5 more for ajax extra )
|
$wp_query->max_num_pages = ceil( $wp_query->found_posts / 15 ); // We grab 20 but only show 15 ( 5 more for ajax extra )
|
||||||
|
|
||||||
|
@ -81,7 +82,7 @@ if ( is_single() ) {
|
||||||
|
|
||||||
<ul class="subsubsub">
|
<ul class="subsubsub">
|
||||||
<?php
|
<?php
|
||||||
$status_links = array();
|
$type_links = array();
|
||||||
$_num_posts = (array) wp_count_attachments();
|
$_num_posts = (array) wp_count_attachments();
|
||||||
$matches = wp_match_mime_types(array_keys($post_mime_types), array_keys($_num_posts));
|
$matches = wp_match_mime_types(array_keys($post_mime_types), array_keys($_num_posts));
|
||||||
foreach ( $matches as $type => $reals )
|
foreach ( $matches as $type => $reals )
|
||||||
|
@ -96,13 +97,13 @@ foreach ( $post_mime_types as $mime_type => $label ) {
|
||||||
if ( wp_match_mime_types($mime_type, $_GET['post_mime_type']) )
|
if ( wp_match_mime_types($mime_type, $_GET['post_mime_type']) )
|
||||||
$class = ' class="current"';
|
$class = ' class="current"';
|
||||||
|
|
||||||
$status_links[] = "<li><a href=\"upload.php?post_mime_type=$mime_type\"$class>" .
|
$type_links[] = "<li><a href=\"upload.php?post_mime_type=$mime_type\"$class>" .
|
||||||
sprintf($label[2], $num_posts[$mime_type]) . '</a>';
|
sprintf($label[2], $num_posts[$mime_type]) . '</a>';
|
||||||
}
|
}
|
||||||
$class = empty($_GET['post_mime_type']) ? ' class="current"' : '';
|
$class = empty($_GET['post_mime_type']) ? ' class="current"' : '';
|
||||||
$status_links[] = "<li><a href=\"upload.php\"$class>".__('All Types')."</a>";
|
$type_links[] = "<li><a href=\"upload.php\"$class>".__('All Types')."</a>";
|
||||||
echo implode(' |</li>', $status_links) . '</li>';
|
echo implode(' | </li>', $type_links) . '</li>';
|
||||||
unset($status_links);
|
unset($type_links);
|
||||||
?>
|
?>
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue