Media library updates from andy. see #5911

git-svn-id: http://svn.automattic.com/wordpress/trunk@7092 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
ryan 2008-02-28 21:29:51 +00:00
parent cf7e0adf8b
commit 282ed12fa4
5 changed files with 431 additions and 140 deletions

View File

@ -46,10 +46,6 @@ form {
margin: 0 1em 1em 0; margin: 0 1em 1em 0;
} }
.media-upload-form input[type="text"], .media-upload-form input[type="file"] {
width: 100%;
}
.media-upload-form fieldset { .media-upload-form fieldset {
width: 100%; width: 100%;
border: none; border: none;
@ -57,7 +53,7 @@ form {
margin: 0 0 1em 0; margin: 0 0 1em 0;
padding: 0; padding: 0;
} }
/*
.media-upload-form button.button-ok { .media-upload-form button.button-ok {
float: right; float: right;
background-color: #ebebeb; background-color: #ebebeb;
@ -74,7 +70,7 @@ form {
text-decoration: underline; text-decoration: underline;
margin: 0.5em 1em; margin: 0.5em 1em;
} }
*/
/* specific to the image upload form */ /* specific to the image upload form */
.align .field label { .align .field label {
display: inline; display: inline;
@ -156,13 +152,12 @@ span.filename {
max-width: 40px; max-width: 40px;
} }
.describe { .describe {
display: none;
border-top: 1px solid #d0d0d0; border-top: 1px solid #d0d0d0;
padding: 5px; padding: 5px;
width: 100%; width: 100%;
} }
.startopen .describe { .describe.startopen, .describe.startclosed {
display: block; display: none;
} }
.required abbr { .required abbr {
color: red; color: red;
@ -179,18 +174,9 @@ span.filename {
.describe td.A1 { .describe td.A1 {
width: 132px; width: 132px;
} }
.describe td.savesend {
text-align: right;
}
.describe input[type="text"], .describe textarea { .describe input[type="text"], .describe textarea {
width: 460px; width: 460px;
} }
a.delete {
display: block;
text-align: center;
width: 100%;
color: #246;
}
.describe-toggle-on, .describe-toggle-off { .describe-toggle-on, .describe-toggle-off {
display: block; display: block;
line-height: 36px; line-height: 36px;
@ -211,13 +197,12 @@ a.delete {
border: none; border: none;
z-index: 10; z-index: 10;
} }
tr.submit input {
width: 128px;
}
tr.align td.field { tr.align td.field {
text-align: center; text-align: center;
} }
a.delete {
color: #666;
}
.hidden { .hidden {
height: 0px; height: 0px;
width: 0px; width: 0px;

View File

@ -2,28 +2,28 @@
function media_upload_tabs() { function media_upload_tabs() {
$_default_tabs = array( $_default_tabs = array(
'computer' => __('From Computer'), // handler action suffix => tab text 'type' => __('Choose File'), // handler action suffix => tab text
'attachments' => __('Attachments'), 'gallery' => __('Gallery'),
'library' => __('Media Library'), 'library' => __('Media Library'),
); );
return apply_filters('media_upload_tabs', $_default_tabs); return apply_filters('media_upload_tabs', $_default_tabs);
} }
function update_attachments_tab($tabs) { function update_gallery_tab($tabs) {
global $wpdb; global $wpdb;
if ( !isset($_REQUEST['post_id']) ) { if ( !isset($_REQUEST['post_id']) ) {
unset($tabs['attachments']); unset($tabs['gallery']);
return $tabs; return $tabs;
} }
if ( intval($_REQUEST['post_id']) ) if ( intval($_REQUEST['post_id']) )
$attachments = $wpdb->get_var($wpdb->prepare("SELECT count(*) FROM $wpdb->posts WHERE post_type = 'attachment' AND post_parent = %d", $_REQUEST['post_id'])); $attachments = intval($wpdb->get_var($wpdb->prepare("SELECT count(*) FROM $wpdb->posts WHERE post_type = 'attachment' AND post_parent = %d", $_REQUEST['post_id'])));
$tabs['attachments'] = sprintf(__('Attachments (%s)'), "<span id='attachments-count'>$attachments</span>"); $tabs['gallery'] = sprintf(__('Gallery (%s)'), "<span id='attachments-count'>$attachments</span>");
return $tabs; return $tabs;
} }
add_filter('media_upload_tabs', 'update_attachments_tab'); add_filter('media_upload_tabs', 'update_gallery_tab');
function the_media_upload_tabs() { function the_media_upload_tabs() {
$tabs = media_upload_tabs(); $tabs = media_upload_tabs();
@ -55,7 +55,7 @@ function get_image_send_to_editor($id, $alt, $title, $align, $url='', $rel = fal
$html = "<a href='".attribute_escape($url)."'$rel>$html</a>"; $html = "<a href='".attribute_escape($url)."'$rel>$html</a>";
elseif ( $size == 'thumb' || $size == 'medium' ) elseif ( $size == 'thumb' || $size == 'medium' )
$html = '<a href="'.get_attachment_link($id).'"'.$rel.'>'.$html.'</a>'; $html = '<a href="'.get_attachment_link($id).'"'.$rel.'>'.$html.'</a>';
$html = apply_filters( 'image_send_to_editor', $html, $id, $alt, $title, $align, $url ); $html = apply_filters( 'image_send_to_editor', $html, $id, $alt, $title, $align, $url );
return $html; return $html;
@ -154,9 +154,23 @@ if ( is_string($content_func) )
function media_buttons() { function media_buttons() {
global $post_ID, $temp_ID; global $post_ID, $temp_ID;
$uploading_iframe_ID = (int) (0 == $post_ID ? $temp_ID : $post_ID); $uploading_iframe_ID = (int) (0 == $post_ID ? $temp_ID : $post_ID);
$media_upload_iframe_src = "media-upload.php?type=media&amp;post_id=$uploading_iframe_ID"; $media_upload_iframe_src = "media-upload.php?post_id=$uploading_iframe_ID";
$media_upload_iframe_src = apply_filters('media_upload_iframe_src', $media_upload_iframe_src); $media_title = __('Add Media');
echo "<a href='$media_upload_iframe_src&amp;TB_iframe=true&amp;height=500&amp;width=640' class='button-secondary thickbox'>" . __('Add media'). '</a>'; $image_upload_iframe_src = apply_filters('image_upload_iframe_src', "$media_upload_iframe_src&amp;type=image");
$image_title = __('Add an Image');
$video_upload_iframe_src = apply_filters('video_upload_iframe_src', "$media_upload_iframe_src&amp;type=video");
$video_title = __('Add Video');
$audio_upload_iframe_src = apply_filters('audio_upload_iframe_src', "$media_upload_iframe_src&amp;type=audio");
$audio_title = __('Add Audio');
$out = <<<EOF
<a href="{$image_upload_iframe_src}&TB_iframe=true&height=500&width=640" class="thickbox" title='$image_title'><img src='images/media-button-image.gif' alt='$image_title' /></a>
<a href="{$video_upload_iframe_src}&TB_iframe=true&height=500&width=640" class="thickbox" title='$video_title'><img src='images/media-button-video.gif' alt='$video_title' /></a>
<a href="{$audio_upload_iframe_src}&TB_iframe=true&height=500&width=640" class="thickbox" title='$audio_title'><img src='images/media-button-music.gif' alt='$audio_title' /></a>
<a href="{$media_upload_iframe_src}&TB_iframe=true&height=500&width=640" class="thickbox" title='$media_title'><img src='images/media-button-other.gif' alt='$media_title' /></a>
EOF;
echo $out;
} }
add_action( 'media_buttons', 'media_buttons' ); add_action( 'media_buttons', 'media_buttons' );
@ -191,8 +205,10 @@ function media_upload_form_handler() {
$id = media_handle_upload('async-upload', $_REQUEST['post_id']); $id = media_handle_upload('async-upload', $_REQUEST['post_id']);
if ( is_wp_error($id) ) if ( is_wp_error($id) ) {
$errors['upload_error'] = $id; $errors['upload_error'] = $id;
$id = false;
}
} }
if ( !empty($_POST['attachments']) ) foreach ( $_POST['attachments'] as $attachment_id => $attachment ) { if ( !empty($_POST['attachments']) ) foreach ( $_POST['attachments'] as $attachment_id => $attachment ) {
@ -232,20 +248,139 @@ function media_upload_form_handler() {
return $errors; return $errors;
} }
function media_upload_computer() { function media_upload_image() {
if ( !empty($_FILES) ) {
// Upload File button was clicked
$id = media_handle_upload('async-upload', $_REQUEST['post_id']);
unset($_FILES);
if ( is_wp_error($id) ) {
$errors['upload_error'] = $id;
$id = false;
}
}
if ( !empty($_POST['insertonlybutton']) ) {
$src = $_POST['insertonly']['src'];
if ( !strpos($src, '://') )
$src = "http://$src";
$alt = attribute_escape($_POST['insertonly']['alt']);
if ( isset($_POST['insertonly']['align']) ) {
$align = attribute_escape($_POST['insertonly']['align']);
$class = " class='align-$align'";
}
$html = "<img src='$src' alt='$alt'$class />";
return media_send_to_editor($html);
}
if ( !empty($_POST) ) { if ( !empty($_POST) ) {
$return = media_upload_form_handler(); $return = media_upload_form_handler();
if ( is_string($return) ) if ( is_string($return) )
return $return; return $return;
if ( is_array($return) ) if ( is_array($return) )
$errors = $return; $errors = $return;
} }
return wp_iframe( 'media_upload_computer_form', $errors ); return wp_iframe( 'media_upload_type_form', 'image', $errors, $id );
} }
function media_upload_attachments() { function media_upload_audio() {
if ( !empty($_FILES) ) {
// Upload File button was clicked
$id = media_handle_upload('async-upload', $_REQUEST['post_id']);
unset($_FILES);
if ( is_wp_error($id) ) {
$errors['upload_error'] = $id;
$id = false;
}
}
if ( !empty($_POST['insertonlybutton']) ) {
$href = $_POST['insertonly']['href'];
if ( !strpos($href, '://') )
$href = "http://$href";
$title = attribute_escape($_POST['insertonly']['title']);
$html = "<a href='$href' >$title</a>";
return media_send_to_editor($html);
}
if ( !empty($_POST) ) {
$return = media_upload_form_handler();
if ( is_string($return) )
return $return;
if ( is_array($return) )
$errors = $return;
}
return wp_iframe( 'media_upload_type_form', 'audio', $errors, $id );
}
function media_upload_video() {
if ( !empty($_FILES) ) {
// Upload File button was clicked
$id = media_handle_upload('async-upload', $_REQUEST['post_id']);
unset($_FILES);
if ( is_wp_error($id) ) {
$errors['upload_error'] = $id;
$id = false;
}
}
if ( !empty($_POST['insertonlybutton']) ) {
$href = $_POST['insertonly']['href'];
if ( !strpos($href, '://') )
$href = "http://$href";
$title = attribute_escape($_POST['insertonly']['title']);
$html = "<a href='$href' >$title</a>";
return media_send_to_editor($html);
}
if ( !empty($_POST) ) {
$return = media_upload_form_handler();
if ( is_string($return) )
return $return;
if ( is_array($return) )
$errors = $return;
}
return wp_iframe( 'media_upload_type_form', 'video', $errors, $id );
}
function media_upload_file() {
if ( !empty($_FILES) ) {
// Upload File button was clicked
$id = media_handle_upload('async-upload', $_REQUEST['post_id']);
unset($_FILES);
if ( is_wp_error($id) ) {
$errors['upload_error'] = $id;
$id = false;
}
}
if ( !empty($_POST['insertonlybutton']) ) {
$href = $_POST['insertonly']['href'];
if ( !strpos($href, '://') )
$href = "http://$href";
$title = attribute_escape($_POST['insertonly']['title']);
$html = "<a href='$href' >$title</a>";
return media_send_to_editor($html);
}
if ( !empty($_POST) ) {
$return = media_upload_form_handler();
if ( is_string($return) )
return $return;
if ( is_array($return) )
$errors = $return;
}
return wp_iframe( 'media_upload_type_form', 'file', $errors, $id );
}
function media_upload_gallery() {
if ( !empty($_POST) ) { if ( !empty($_POST) ) {
$return = media_upload_form_handler(); $return = media_upload_form_handler();
@ -255,7 +390,7 @@ function media_upload_attachments() {
$errors = $return; $errors = $return;
} }
return wp_iframe( 'media_upload_attachments_form', $errors ); return wp_iframe( 'media_upload_gallery_form', $errors );
} }
function media_upload_library() { function media_upload_library() {
@ -271,25 +406,6 @@ function media_upload_library() {
return wp_iframe( 'media_upload_library_form', $errors ); return wp_iframe( 'media_upload_library_form', $errors );
} }
function get_media_items( $post_id, $errors ) {
if ( $post_id ) {
$attachments = get_children("post_parent=$post_id&post_type=attachment&orderby=menu_order ASC, ID&order=DESC");
} else {
if ( is_array($GLOBALS['wp_the_query']->posts) )
foreach ( $GLOBALS['wp_the_query']->posts as $attachment )
$attachments[$attachment->ID] = $attachment;
}
if ( empty($attachments) )
return '';
foreach ( $attachments as $id => $attachment )
if ( $item = get_media_item($id, isset($errors[$id]) ? $errors[$id] : null) )
$output .= "\n<div id='media-item-$id' class='media-item preloaded'><div id='media-upload-error-$id'></div><span class='filename'></span><div class='progress'><div class='bar'></div></div>$item<div class='progress clickmask'></div>\n</div>";
return $output;
}
function get_attachment_taxonomies($attachment) { function get_attachment_taxonomies($attachment) {
if ( is_int( $attachment ) ) if ( is_int( $attachment ) )
$attachment = get_post($attachment); $attachment = get_post($attachment);
@ -331,13 +447,7 @@ function image_attachment_fields_to_edit($form_fields, $post) {
$thumb = wp_get_attachment_thumb_url(); $thumb = wp_get_attachment_thumb_url();
$form_fields['_send']['url'] = array( $form_fields['align'] = array(
'label' => __('Link URL'),
'input' => 'html',
'html' => '',
'helps' => __('If filled, this will override the default link URL.'),
);
$form_fields['_send']['align'] = array(
'label' => __('Alignment'), 'label' => __('Alignment'),
'input' => 'html', 'input' => 'html',
'html' => " 'html' => "
@ -350,7 +460,7 @@ function image_attachment_fields_to_edit($form_fields, $post) {
<input type='radio' name='attachments[$post->ID][align]' id='image-align-right-$post->ID' value='right' /> <input type='radio' name='attachments[$post->ID][align]' id='image-align-right-$post->ID' value='right' />
<label for='image-align-right-$post->ID' class='align image-align-right-label'>" . __('Right') . "</label>\n", <label for='image-align-right-$post->ID' class='align image-align-right-label'>" . __('Right') . "</label>\n",
); );
$form_fields['_send']['image-size'] = array( $form_fields['image-size'] = array(
'label' => __('Size'), 'label' => __('Size'),
'input' => 'html', 'input' => 'html',
'html' => " 'html' => "
@ -383,12 +493,7 @@ add_filter('attachment_fields_to_save', 'image_attachment_fields_to_save', 10, 2
function image_media_send_to_editor($html, $attachment_id, $attachment) { function image_media_send_to_editor($html, $attachment_id, $attachment) {
$post =& get_post($attachment_id); $post =& get_post($attachment_id);
if ( substr($post->post_mime_type, 0, 5) == 'image' ) { if ( substr($post->post_mime_type, 0, 5) == 'image' ) {
if ( !empty($attachment['url']) ) $url = $attachment['url'];
$url = $attachment['url'];
elseif ( $rel = strlen(trim($post->post_content)) )
$url = get_attachment_link($attachment_id);
else
$url = wp_get_attachment_url($attachment_id);
if ( isset($attachment['align']) ) if ( isset($attachment['align']) )
$align = $attachment['align']; $align = $attachment['align'];
@ -415,11 +520,14 @@ function get_attachment_fields_to_edit($post, $errors = null) {
$post = (object) $post; $post = (object) $post;
$edit_post = sanitize_post($post, 'edit'); $edit_post = sanitize_post($post, 'edit');
$file = wp_get_attachment_url($post->ID);
$link = get_attachment_link($post->ID);
$form_fields = array( $form_fields = array(
'post_title' => array( 'post_title' => array(
'label' => __('Title'), 'label' => __('Title'),
'value' => $edit_post->post_title, 'value' => $edit_post->post_title,
'helps' => __(''),
), ),
'post_excerpt' => array( 'post_excerpt' => array(
'label' => __('Description'), 'label' => __('Description'),
@ -429,7 +537,19 @@ function get_attachment_fields_to_edit($post, $errors = null) {
'label' => __('Long description'), 'label' => __('Long description'),
'value' => $edit_post->post_content, 'value' => $edit_post->post_content,
'input' => 'textarea', 'input' => 'textarea',
'helps' => array(__('If filled, the default link URL will be the attachment permalink.')), ),
'url' => array(
'label' => __('Link URL'),
'input' => 'html',
'html' => "
<input type='text' name='attachments[$post->ID][url]' value='" . attribute_escape($file) . "' />
<button type='button' class='button url-$post->ID' value=''>" . __('None') . "</button>
<button type='button' class='button url-$post->ID' value='" . attribute_escape($file) . "'>" . __('File URL') . "</button>
<button type='button' class='button url-$post->ID' value='" . attribute_escape($link) . "'>" . __('Post URL') . "</button>
<script type='text/javascript'>
jQuery('button.url-$post->ID').bind('click', function(){jQuery(this).siblings('input').val(this.value);});
</script>\n",
'helps' => __('Enter a link URL or click above for presets.'),
), ),
); );
@ -462,7 +582,30 @@ function get_attachment_fields_to_edit($post, $errors = null) {
return $form_fields; return $form_fields;
} }
function get_media_item( $attachment_id, $errors = null, $send = true ) { function get_media_items( $post_id, $errors ) {
if ( $post_id && $post = get_post($post_id) ) {
if ( $post->post_type == 'attachment' )
$attachments = array($post->ID => $post);
else
$attachments = get_children("post_parent=$post_id&post_type=attachment&orderby=menu_order ASC, ID&order=DESC");
} else {
if ( is_array($GLOBALS['wp_the_query']->posts) )
foreach ( $GLOBALS['wp_the_query']->posts as $attachment )
$attachments[$attachment->ID] = $attachment;
}
if ( empty($attachments) )
return '';
foreach ( $attachments as $id => $attachment )
if ( $item = get_media_item($id, isset($errors[$id]) ? $errors[$id] : null) )
$output .= "\n<div id='media-item-$id' class='media-item child-of-$attachment->post_parent preloaded'><div id='media-upload-error-$id'></div><span class='filename'></span><div class='progress'><div class='bar'></div></div>$item<div class='progress clickmask'></div>\n</div>";
return $output;
}
function get_media_item( $attachment_id, $errors = null, $send = true, $delete = true ) {
global $post_mime_types;
if ( ( $attachment_id = intval($attachment_id) ) && $thumb_url = get_attachment_icon_src( $attachment_id ) ) if ( ( $attachment_id = intval($attachment_id) ) && $thumb_url = get_attachment_icon_src( $attachment_id ) )
$thumb_url = $thumb_url[0]; $thumb_url = $thumb_url[0];
else else
@ -486,10 +629,16 @@ function get_media_item( $attachment_id, $errors = null, $send = true ) {
$tags = attribute_escape(join(', ', $tags)); $tags = attribute_escape(join(', ', $tags));
} }
if ( isset($post_mime_types) ) {
$type = array_shift(array_keys(wp_match_mime_types(array_keys($post_mime_types), $post->post_mime_type)));
$type = "<input type='hidden' id='type-of-$attachment_id' value='$type' />";
}
$form_fields = get_attachment_fields_to_edit($post, $errors); $form_fields = get_attachment_fields_to_edit($post, $errors);
$class = empty($errors) ? 'startclosed' : 'startopen'; $class = empty($errors) ? 'startclosed' : 'startopen';
$item = " $item = "
$type
<a class='toggle describe-toggle-on' href='#'>$toggle_on</a> <a class='toggle describe-toggle-on' href='#'>$toggle_on</a>
<a class='toggle describe-toggle-off' href='#'>$toggle_off</a> <a class='toggle describe-toggle-off' href='#'>$toggle_off</a>
<span class='filename new'>$filename</span> <span class='filename new'>$filename</span>
@ -510,18 +659,12 @@ function get_media_item( $attachment_id, $errors = null, $send = true ) {
); );
$delete_href = wp_nonce_url("post.php?action=delete-post&amp;post=$attachment_id", 'delete-post_' . $attachment_id); $delete_href = wp_nonce_url("post.php?action=delete-post&amp;post=$attachment_id", 'delete-post_' . $attachment_id);
$delete = __('Delete'); if ( $send )
$save = "<input type='submit' value='" . wp_specialchars(__('Save'), 1) . "' />"; $send = "<button type='submit' class='button' value='1' name='send[$attachment_id]'>" . __('Insert into Post') . '</button>';
$send = "<input type='submit' value='" . wp_specialchars(__('Send to Editor'), 1) . "' id='send[$attachment_id]' name='send[$attachment_id]' />"; if ( $delete )
$delete = "<a href='$delete_href' id='del[$attachment_id]' disabled='disabled' class='delete'>" . __('Delete') . "</button>";
if ( empty($form_fields['save']) && empty($form_fields['_send']) ) { if ( ( $send || $delete ) && !isset($form_fields['buttons']) )
$form_fields['save'] = array('tr' => "\t\t<tr class='submit'><td colspan='2' class='del'><a id='del[$attachment_id]' class='delete button' href='$delete_href'>$delete</a></td><td class='savesend'>$save$send</td></tr>\n"); $form_fields['buttons'] = array('tr' => "\t\t<tr class='submit'><td colspan='2'></td><td class='savesend'>$send $delete</td></tr>\n");
} elseif ( empty($form_fields['save']) ) {
$form_fields['save'] = array('tr' => "\t\t<tr class='submit'><td></td><td></td><td class='savesend'>$save</td></tr>\n");
foreach ( $form_fields['_send'] as $id => $field )
$form_fields[$id] = $field;
$form_fields['send'] = array('tr' => "\t\t<tr class='submit'><td colspan='2' class='del'><a id='del[$attachment_id]' class='delete button' href='$delete_href'>$delete</a></td><td class='savesend'>$send</td>");
}
$hidden_fields = array(); $hidden_fields = array();
@ -583,21 +726,27 @@ function get_media_item( $attachment_id, $errors = null, $send = true ) {
return $item; return $item;
} }
function media_upload_header() { function media_upload_header($title = false) {
if ( empty($title) )
$title = __('Choose a File');
?> ?>
<script type="text/javascript">post_id = <?php echo intval($_REQUEST['post_id']); ?>;</script>
<div id="media-upload-header"> <div id="media-upload-header">
<h3><?php _e('Add Media'); ?></h3> <h3><?php echo $title ?></h3>
<?php the_media_upload_tabs(); ?> <?php the_media_upload_tabs(); ?>
</div> </div>
<?php <?php
} }
function media_upload_form( $errors = null ) { function media_upload_form( $errors = null ) {
$flash_action_url = get_option('siteurl') . '/wp-admin/async-upload.php?type=media'; global $type, $tab;
$flash_action_url = get_option('siteurl') . "/wp-admin/async-upload.php";
$post_id = intval($_REQUEST['post_id']); $post_id = intval($_REQUEST['post_id']);
?> ?>
<input type='hidden' name='post_id' value='<?php echo $post_id; ?>' />
<div id="media-upload-error"> <div id="media-upload-error">
<?php if (isset($errors['upload_error']) && is_wp_error($errors['upload_error'])) { ?> <?php if (isset($errors['upload_error']) && is_wp_error($errors['upload_error'])) { ?>
<?php echo $errors['upload_error']->get_error_message(); ?> <?php echo $errors['upload_error']->get_error_message(); ?>
@ -614,7 +763,8 @@ jQuery(function($){
post_params : { post_params : {
"post_id" : "<?php echo $post_id; ?>", "post_id" : "<?php echo $post_id; ?>",
"auth_cookie" : "<?php echo $_COOKIE[AUTH_COOKIE]; ?>", "auth_cookie" : "<?php echo $_COOKIE[AUTH_COOKIE]; ?>",
"type" : "media" "type" : "<?php echo $type; ?>",
"tab" : "<?php echo $tab; ?>"
}, },
file_size_limit : "<?php echo wp_max_upload_size(); ?>b", file_size_limit : "<?php echo wp_max_upload_size(); ?>b",
swfupload_element_id : "flash-upload-ui", // id of the element displayed when swfupload is available swfupload_element_id : "flash-upload-ui", // id of the element displayed when swfupload is available
@ -640,17 +790,12 @@ jQuery(function($){
<div id="flash-upload-ui"> <div id="flash-upload-ui">
<p><input id="flash-browse-button" type="button" value="<?php _e('Choose files to upload'); ?>" class="button" /></p> <p><input id="flash-browse-button" type="button" value="<?php _e('Choose files to upload'); ?>" class="button" /></p>
<p><?php _e('After a file has been uploaded, you can add titles and descriptions below.'); ?></p> <p><?php _e('After a file has been uploaded, you can add titles and descriptions.'); ?></p>
</div> </div>
<div id="html-upload-ui"> <div id="html-upload-ui">
<p><label for="async-upload"><?php _e('Choose image'); ?></label>
<input type="file" name="async-upload" id="async-upload" />
<label for="image-file" class="form-help"><?php _e('Only PNG, JPG, GIF'); ?></label>
</p>
<p> <p>
<button id="upload-button" name="upload-button" value="1" class="button-ok"><?php _e('Add Image'); ?></button> <input type="file" name="async-upload" id="async-upload" /> <input type="submit" class="button" value="<?php echo attribute_escape(__('Upload')); ?>" /> <a href="#" onClick="return top.tb_remove();"><?php _e('Cancel'); ?></a>
<a href="#" onClick="return top.tb_remove();" id="image-cancel" class="button-cancel"><?php _e('Cancel'); ?></a>
</p> </p>
<input type="hidden" name="post_id" id="post_id" value="<?php echo $post_id; ?>" /> <input type="hidden" name="post_id" id="post_id" value="<?php echo $post_id; ?>" />
<br style="clear:both" /> <br style="clear:both" />
@ -658,34 +803,60 @@ jQuery(function($){
<?php <?php
} }
function media_upload_computer_form( $errors = null ) { function media_upload_type_form($type = 'file', $errors = null, $id = null) {
media_upload_header(); media_upload_header();
$post_id = intval($_REQUEST['post_id']); $post_id = intval($_REQUEST['post_id']);
$form_action_url = get_option('siteurl') . "/wp-admin/media-upload.php?type=media&tab=computer&post_id=$post_id"; $form_action_url = get_option('siteurl') . "/wp-admin/media-upload.php?type=$type&tab=type&post_id=$post_id";
$callback = "type_form_$type";
?> ?>
<form enctype="multipart/form-data" method="post" action="<?php echo attribute_escape($form_action_url); ?>" class="media-upload-form" id="computer-form"> <form enctype="multipart/form-data" method="post" action="<?php echo attribute_escape($form_action_url); ?>" class="media-upload-form type-form" id="<?php echo $type; ?>-form">
<input type="hidden" name="post_id" id="post_id" value="<?php echo $post_id; ?>" />
<?php wp_nonce_field('media-form'); ?> <?php wp_nonce_field('media-form'); ?>
<h3><?php _e('From Computer'); ?></h3>
<?php media_upload_form( $errors ); ?> <?php media_upload_form( $errors ); ?>
<div id="media-items"></div> <?php if ( $id && !is_wp_error($id) ) : ?>
<p class="submit"> <script type="text/javascript">
<input type="submit" class="submit insert-gallery" name="insert-media" value="<?php _e('Insert gallery into post'); ?>" /> <!--
</p> jQuery(function($){
</form> var preloaded = $(".media-item.preloaded");
if ( preloaded.length > 0 ) {
preloaded.each(function(){prepareMediaItem({id:this.id.replace(/[^0-9]/g, '')},'');});
updateMediaForm();
}
});
-->
</script>
<div id="media-items">
<?php echo get_media_items( $id, $errors ); ?>
</div>
<?php elseif ( is_callable($callback) ) : ?>
<div class="media-blank">
<p style="text-align:center"><?php _e('&mdash; OR &mdash;'); ?></p>
<h3><?php _e('From URL'); ?></h3>
</div>
<div id="media-items">
<div class="media-item media-blank">
<?php echo call_user_func($callback); ?>
</div>
</div>
<?php <?php
endif;
} }
function media_upload_attachments_form($errors) { function media_upload_gallery_form($errors) {
media_upload_header(); media_upload_header(__('Browse attached files'));
$post_id = intval($_REQUEST['post_id']); $post_id = intval($_REQUEST['post_id']);
$form_action_url = get_option('siteurl') . "/wp-admin/media-upload.php?type=media&tab=attachments&post_id=$post_id"; $form_action_url = get_option('siteurl') . "/wp-admin/media-upload.php?type=media&tab=gallery&post_id=$post_id";
?> ?>
@ -701,7 +872,7 @@ jQuery(function($){
--> -->
</script> </script>
<form enctype="multipart/form-data" method="post" action="<?php echo attribute_escape($form_action_url); ?>" class="media-upload-form" id="attachments-form"> <form enctype="multipart/form-data" method="post" action="<?php echo attribute_escape($form_action_url); ?>" class="media-upload-form" id="gallery-form">
<?php wp_nonce_field('media-form'); ?> <?php wp_nonce_field('media-form'); ?>
<?php //media_upload_form( $errors ); ?> <?php //media_upload_form( $errors ); ?>
@ -717,13 +888,13 @@ jQuery(function($){
} }
function media_upload_library_form($errors) { function media_upload_library_form($errors) {
global $wpdb, $wp_query, $wp_locale; global $wpdb, $wp_query, $wp_locale, $type, $tab, $post_mime_types;
media_upload_header(); media_upload_header(__('Browse Media Library'));
$post_id = intval($_REQUEST['post_id']); $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"; $form_action_url = get_option('siteurl') . "/wp-admin/media-upload.php";
$_GET['paged'] = intval($_GET['paged']); $_GET['paged'] = intval($_GET['paged']);
if ( $_GET['paged'] < 1 ) if ( $_GET['paged'] < 1 )
@ -738,10 +909,10 @@ function media_upload_library_form($errors) {
?> ?>
<form id="filter" action="" method="get"> <form id="filter" action="" method="get">
<input type="hidden" name="type" value="media" /> <input type="hidden" name="type" value="<?php echo $type; ?>" />
<input type="hidden" name="tab" value="library" /> <input type="hidden" name="tab" value="<?php echo $tab; ?>" />
<input type="hidden" name="post_id" value="<?php echo $post_id; ?>" /> <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']; ?>" /> <input type="hidden" name="post_mime_type" value="<?php echo wp_specialchars($_GET['post_mime_type'], true); ?>" />
<div id="search-filter"> <div id="search-filter">
<input type="text" id="post-search-input" name="s" value="<?php the_search_query(); ?>" /> <input type="text" id="post-search-input" name="s" value="<?php the_search_query(); ?>" />
@ -766,7 +937,7 @@ 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"';
$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>'; $type_links[] = "<li><a href='" . add_query_arg(array('post_mime_type'=>$mime_type, 'paged'=>false)) . "'$class>" . sprintf($label[2], "<span id='$mime_type-counter'>{$num_posts[$mime_type]}</span>") . '</a>';
} }
$class = empty($_GET['post_mime_type']) ? ' class="current"' : ''; $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>"; $type_links[] = "<li><a href='" . remove_query_arg(array('post_mime_type', 'paged', 'm')) . "'$class>".__('All Types')."</a>";
@ -807,12 +978,12 @@ foreach ($arc_result as $arc_row) {
if ( $arc_row->yyear == 0 ) if ( $arc_row->yyear == 0 )
continue; continue;
$arc_row->mmonth = zeroise( $arc_row->mmonth, 2 ); $arc_row->mmonth = zeroise( $arc_row->mmonth, 2 );
if ( $arc_row->yyear . $arc_row->mmonth == $_GET['m'] ) if ( $arc_row->yyear . $arc_row->mmonth == $_GET['m'] )
$default = ' selected="selected"'; $default = ' selected="selected"';
else else
$default = ''; $default = '';
echo "<option$default value='$arc_row->yyear$arc_row->mmonth'>"; echo "<option$default value='$arc_row->yyear$arc_row->mmonth'>";
echo $wp_locale->get_month($arc_row->mmonth) . " $arc_row->yyear"; echo $wp_locale->get_month($arc_row->mmonth) . " $arc_row->yyear";
echo "</option>\n"; echo "</option>\n";
@ -829,7 +1000,10 @@ foreach ($arc_result as $arc_row) {
</div> </div>
</form> </form>
<form enctype="multipart/form-data" method="post" action="<?php echo attribute_escape($form_action_url); ?>" class="media-upload-form" id="attachments-form"> <form enctype="multipart/form-data" method="post" action="<?php echo attribute_escape($form_action_url); ?>" class="media-upload-form" id="library-form">
<?php wp_nonce_field('media-form'); ?>
<?php //media_upload_form( $errors ); ?>
<script type="text/javascript"> <script type="text/javascript">
<!-- <!--
@ -843,9 +1017,6 @@ jQuery(function($){
--> -->
</script> </script>
<?php wp_nonce_field('media-form'); ?>
<?php //media_upload_form( $errors ); ?>
<div id="media-items"> <div id="media-items">
<?php echo get_media_items(null, $errors); ?> <?php echo get_media_items(null, $errors); ?>
</div> </div>
@ -854,13 +1025,129 @@ jQuery(function($){
<?php <?php
} }
add_filter('async_upload_media', 'get_media_item', 10, 2); function type_form_image() {
return '
<table class="describe"><tbody>
<tr>
<td class="label"><label for="insertonly[src]">' . __('Image URL') . '</label></td>
<td class="required"><abbr title="required">*</abbr></td>
<td class="field"><input id="insertonly[src]" name="insertonly[src]" value="" type="text"></td>
</tr>
<tr>
<td class="label"><label for="insertonly[alt]">' . __('Description') . '</label></td>
<td class="required"><abbr title="required">*</abbr></td>
<td class="field"><input id="insertonly[alt]" name="insertonly[alt]" value="" type="text"></td>
</tr>
<tr><td colspan="2"></td><td class="help">' . __('Alternate text, e.g. "The Mona Lisa"') . '</td></tr>
<tr class="align">
<td class="label"><label for="insertonly[align]">' . __('Alignment') . '</label></td>
<td class="required"></td>
<td class="field">
<input name="insertonly[align]" id="image-align-none-0" value="none" type="radio">
<label for="image-align-none-0" class="align image-align-none-label">' . __('None') . '</label>
<input name="insertonly[align]" id="image-align-left-0" value="left" type="radio">
<label for="image-align-left-0" class="align image-align-left-label">' . __('Left') . '</label>
<input name="insertonly[align]" id="image-align-center-0" value="center" type="radio">
<label for="image-align-center-0" class="align image-align-center-label">' . __('Center') . '</label>
<input name="insertonly[align]" id="image-align-right-0" value="right" type="radio">
<label for="image-align-right-0" class="align image-align-right-label">' . __('Right') . '</label>
</td>
</tr>
<tr>
<td colspan="2"></td>
<td>
<input type="submit" class="button" name="insertonlybutton" value="' . attribute_escape(__('Insert into Post')) . '" />
</td>
</tr>
</tbody></table>
';
}
add_filter('media_upload_computer', 'media_upload_computer'); function type_form_audio() {
add_action('admin_head_media_upload_computer_form', 'media_admin_css'); return '
<table class="describe"><tbody>
<tr>
<td class="label"><label for="insertonly[href]">' . __('Audio File URL') . '</label></td>
<td class="required"><abbr title="required">*</abbr></td>
<td class="field"><input id="insertonly[href]" name="insertonly[href]" value="" type="text"></td>
</tr>
<tr>
<td class="label"><label for="insertonly[title]">' . __('Title') . '</label></td>
<td class="required"><abbr title="required">*</abbr></td>
<td class="field"><input id="insertonly[title]" name="insertonly[title]" value="" type="text"></td>
</tr>
<tr><td colspan="2"></td><td class="help">' . __('Link text, e.g. "Still Alive by Jonathan Coulton"') . '</td></tr>
<tr>
<td colspan="2"></td>
<td>
<input type="submit" class="button" name="insertonlybutton" value="' . attribute_escape(__('Insert into Post')) . '" />
</td>
</tr>
</tbody></table>
';
}
add_filter('media_upload_attachments', 'media_upload_attachments'); function type_form_video() {
add_action('admin_head_media_upload_attachments_form', 'media_admin_css'); return '
<table class="describe"><tbody>
<tr>
<td class="label"><label for="insertonly[href]">' . __('Video URL') . '</label></td>
<td class="required"><abbr title="required">*</abbr></td>
<td class="field"><input id="insertonly[href]" name="insertonly[href]" value="" type="text"></td>
</tr>
<tr>
<td class="label"><label for="insertonly[title]">' . __('Title') . '</label></td>
<td class="required"><abbr title="required">*</abbr></td>
<td class="field"><input id="insertonly[title]" name="insertonly[title]" value="" type="text"></td>
</tr>
<tr><td colspan="2"></td><td class="help">' . __('Link text, e.g. "Lucy on YouTube"') . '</td></tr>
<tr>
<td colspan="2"></td>
<td>
<input type="submit" class="button" name="insertonlybutton" value="' . attribute_escape(__('Insert into Post')) . '" />
</td>
</tr>
</tbody></table>
';
}
function type_form_file() {
return '
<table class="describe"><tbody>
<tr>
<td class="label"><label for="insertonly[href]">' . __('URL') . '</label></td>
<td class="required"><abbr title="required">*</abbr></td>
<td class="field"><input id="insertonly[href]" name="insertonly[href]" value="" type="text"></td>
</tr>
<tr>
<td class="label"><label for="insertonly[title]">' . __('Title') . '</label></td>
<td class="required"><abbr title="required">*</abbr></td>
<td class="field"><input id="insertonly[title]" name="insertonly[title]" value="" type="text"></td>
</tr>
<tr><td colspan="2"></td><td class="help">' . __('Link text, e.g. "Ransom Demands (PDF)"') . '</td></tr>
<tr>
<td colspan="2"></td>
<td>
<input type="submit" class="button" name="insertonlybutton" value="' . attribute_escape(__('Insert into Post')) . '" />
</td>
</tr>
</tbody></table>
';
}
add_filter('async_upload_image', 'get_media_item', 10, 2);
add_filter('async_upload_audio', 'get_media_item', 10, 2);
add_filter('async_upload_video', 'get_media_item', 10, 2);
add_filter('async_upload_file', 'get_media_item', 10, 2);
add_action('media_upload_image', 'media_upload_image');
add_action('media_upload_audio', 'media_upload_audio');
add_action('media_upload_video', 'media_upload_video');
add_action('media_upload_file', 'media_upload_file');
add_action('admin_head_media_upload_type_form', 'media_admin_css');
add_filter('media_upload_gallery', 'media_upload_gallery');
add_action('admin_head_media_upload_gallery_form', 'media_admin_css');
add_filter('media_upload_library', 'media_upload_library'); add_filter('media_upload_library', 'media_upload_library');
add_action('admin_head_media_upload_library_form', 'media_admin_css'); add_action('admin_head_media_upload_library_form', 'media_admin_css');

View File

@ -19,12 +19,21 @@ if ( isset($action) && $action == 'edit' && !$ID )
wp_die(__("You are not allowed to be here")); wp_die(__("You are not allowed to be here"));
// upload type: image, video, file, ..? // upload type: image, video, file, ..?
if ( isset($_GET['type']) )
$type = strval($_GET['type']);
else
$type = apply_filters('media_upload_default_type', 'file');
// tab: gallery, library, or type-specific
if ( isset($_GET['tab']) ) if ( isset($_GET['tab']) )
$tab = strval($_GET['tab']); $tab = strval($_GET['tab']);
else else
$tab = apply_filters('media_upload_default_tab', 'computer'); $tab = apply_filters('media_upload_default_tab', 'type');
// let the action code decide how to handle the request // let the action code decide how to handle the request
do_action("media_upload_$tab"); if ( $tab == 'type' )
do_action("media_upload_$type");
else
do_action("media_upload_$tab");
?> ?>

View File

@ -9,8 +9,10 @@ function fileDialogStart() {
// progress and success handlers for media multi uploads // progress and success handlers for media multi uploads
function fileQueued(fileObj) { function fileQueued(fileObj) {
// Get rid of unused form
jQuery('.media-blank').remove();
// Create a progress bar containing the filename // Create a progress bar containing the filename
jQuery('#media-items').prepend('<div id="media-item-' + fileObj.id + '" class="media-item"><span class="filename original">' + fileObj.name + '</span><div class="progress"><div class="bar"></div></div></div>'); jQuery('#media-items').prepend('<div id="media-item-' + fileObj.id + '" class="media-item child-of-' + post_id + '"><span class="filename original">' + fileObj.name + '</span><div class="progress"><div class="bar"></div></div></div>');
// Disable the submit button // Disable the submit button
jQuery('#insert-media').attr('disabled', 'disabled'); jQuery('#insert-media').attr('disabled', 'disabled');
@ -50,8 +52,13 @@ function prepareMediaItem(fileObj, serverData) {
action : 'delete-post', action : 'delete-post',
_ajax_nonce : this.href.replace(/^.*wpnonce=/,'')} _ajax_nonce : this.href.replace(/^.*wpnonce=/,'')}
}); });
// Decrement the counter.
jQuery('#attachments-count').text(jQuery('#attachments-count').text()-1); // Decrement the counters.
if ( type = jQuery('#type-of-' + this.id.replace(/[^0-9]/g,'')).val() )
jQuery('#' + type + '-counter').text(jQuery('#' + type + '-counter').text()-1);
if ( jQuery(this).parents('.media-item').eq(0).hasClass('child-of-'+post_id) )
jQuery('#attachments-count').text(jQuery('#attachments-count').text()-1);
// Vanish it. // Vanish it.
jQuery(this).parents(".media-item").eq(0).slideToggle(300,function(){jQuery(this).remove();if(jQuery('.media-item').length==0)jQuery('.insert-gallery').hide();updateMediaForm();}); jQuery(this).parents(".media-item").eq(0).slideToggle(300,function(){jQuery(this).remove();if(jQuery('.media-item').length==0)jQuery('.insert-gallery').hide();updateMediaForm();});
return false; return false;
@ -66,11 +73,11 @@ function prepareMediaItem(fileObj, serverData) {
function updateMediaForm() { function updateMediaForm() {
// Just one file, no need for collapsible part // Just one file, no need for collapsible part
if ( jQuery('#computer-form #media-items>*').length == 1 ) { if ( jQuery('.type-form #media-items>*').length == 1 ) {
jQuery('#media-items .slidetoggle').slideDown(500).parent().eq(0).children('.toggle').toggle(); jQuery('#media-items .slidetoggle').slideDown(500).parent().eq(0).children('.toggle').toggle();
jQuery('#computer-form .slidetoggle').siblings().addClass('hidden'); jQuery('.type-form .slidetoggle').siblings().addClass('hidden');
} else { } else {
jQuery('#computer-form .slidetoggle').siblings().removeClass('hidden'); jQuery('.type-form .slidetoggle').siblings().removeClass('hidden');
} }
// Only show Gallery button when there are at least two files. // Only show Gallery button when there are at least two files.
@ -88,7 +95,10 @@ function uploadSuccess(fileObj, serverData) {
} }
prepareMediaItem(fileObj, serverData); prepareMediaItem(fileObj, serverData);
updateMediaForm(); updateMediaForm();
jQuery('#attachments-count').text(1 * jQuery('#attachments-count').text() + 1);
// Increment the counter.
if ( jQuery('#media-item-' + fileObj.id).hasClass('child-of-' + post_id) )
jQuery('#attachments-count').text(1 * jQuery('#attachments-count').text() + 1);
} }
function uploadComplete(fileObj) { function uploadComplete(fileObj) {
@ -116,13 +126,13 @@ function fileQueueError(fileObj, error_code, message) {
wpQueueError(swfuploadL10n.queue_limit_exceeded); wpQueueError(swfuploadL10n.queue_limit_exceeded);
} }
else if ( error_code == SWFUpload.QUEUE_ERROR.FILE_EXCEEDS_SIZE_LIMIT ) { else if ( error_code == SWFUpload.QUEUE_ERROR.FILE_EXCEEDS_SIZE_LIMIT ) {
wpQueueError(swfuploadL10n.file_exceeds_size_limit); wpFileError(fileObj, swfuploadL10n.file_exceeds_size_limit);
} }
else if ( error_code == SWFUpload.QUEUE_ERROR.ZERO_BYTE_FILE ) { else if ( error_code == SWFUpload.QUEUE_ERROR.ZERO_BYTE_FILE ) {
wpQueueError(swfuploadL10n.zero_byte_file); wpFileError(fileObj, swfuploadL10n.zero_byte_file);
} }
else if ( error_code == SWFUpload.QUEUE_ERROR.INVALID_FILETYPE ) { else if ( error_code == SWFUpload.QUEUE_ERROR.INVALID_FILETYPE ) {
wpQueueError(swfuploadL10n.invalid_filetype); wpFileError(fileObj, swfuploadL10n.invalid_filetype);
} }
else { else {
wpQueueError(swfuploadL10n.default_error); wpQueueError(swfuploadL10n.default_error);

View File

@ -88,7 +88,7 @@ class WP_Scripts {
$this->add( 'swfupload', '/wp-includes/js/swfupload/swfupload.js', false, '2.0.2'); $this->add( 'swfupload', '/wp-includes/js/swfupload/swfupload.js', false, '2.0.2');
$this->add( 'swfupload-degrade', '/wp-includes/js/swfupload/plugins/swfupload.graceful_degradation.js', array('swfupload'), '2.0.2'); $this->add( 'swfupload-degrade', '/wp-includes/js/swfupload/plugins/swfupload.graceful_degradation.js', array('swfupload'), '2.0.2');
$this->add( 'swfupload-queue', '/wp-includes/js/swfupload/plugins/swfupload.queue.js', array('swfupload'), '2.0.2'); $this->add( 'swfupload-queue', '/wp-includes/js/swfupload/plugins/swfupload.queue.js', array('swfupload'), '2.0.2');
$this->add( 'swfupload-handlers', '/wp-includes/js/swfupload/handlers.js', array('swfupload'), '2.0.2-20080225'); $this->add( 'swfupload-handlers', '/wp-includes/js/swfupload/handlers.js', array('swfupload'), '2.0.2-20080227');
// these error messages came from the sample swfupload js, they might need changing. // these error messages came from the sample swfupload js, they might need changing.
$this->localize( 'swfupload-handlers', 'swfuploadL10n', array( $this->localize( 'swfupload-handlers', 'swfuploadL10n', array(
'queue_limit_exceeded' => 'You have attempted to queue too many files.', 'queue_limit_exceeded' => 'You have attempted to queue too many files.',