mirror of
https://github.com/WordPress/WordPress.git
synced 2025-01-24 17:21:34 +01:00
Post format UI refresh.
* Post format switcher does not go away after clicking * Refresh of format switcher style * Highlighting of active post format * Prompt text goes under the switcher * Better animations see #24046. props wonderboymusic, johnjamesjacoby, aaroncampbell, PeteMall. Also, because I forgot it on [24006]: props saracannon. git-svn-id: http://core.svn.wordpress.org/trunk@24098 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
57cb2a36bb
commit
1b554db95a
@ -164,6 +164,7 @@ textarea.disabled {
|
|||||||
color: #fff;
|
color: #fff;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.post-format-options,
|
||||||
.widget .widget-top,
|
.widget .widget-top,
|
||||||
.postbox h3,
|
.postbox h3,
|
||||||
.stuffbox h3,
|
.stuffbox h3,
|
||||||
@ -688,6 +689,7 @@ table.widefat span.spam a,
|
|||||||
background-image: linear-gradient(to top, #eff8ff, #f7fcfe);
|
background-image: linear-gradient(to top, #eff8ff, #f7fcfe);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.post-format-options,
|
||||||
.postbox h3 {
|
.postbox h3 {
|
||||||
color: #174f69;
|
color: #174f69;
|
||||||
}
|
}
|
||||||
|
@ -164,6 +164,7 @@ textarea.disabled {
|
|||||||
color: #fff;
|
color: #fff;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.post-format-options,
|
||||||
.widget .widget-top,
|
.widget .widget-top,
|
||||||
.postbox h3,
|
.postbox h3,
|
||||||
.stuffbox h3,
|
.stuffbox h3,
|
||||||
@ -690,6 +691,7 @@ table.widefat span.spam a,
|
|||||||
background-image: linear-gradient(to top, #f5f5f5, #f9f9f9);
|
background-image: linear-gradient(to top, #f5f5f5, #f9f9f9);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.post-format-options,
|
||||||
.postbox h3 {
|
.postbox h3 {
|
||||||
color: #464646;
|
color: #464646;
|
||||||
}
|
}
|
||||||
|
@ -4000,6 +4000,9 @@ body .ui-tooltip {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.wp-format-status #titlewrap,
|
.wp-format-status #titlewrap,
|
||||||
|
.wp-format-image .wp-media-buttons .insert-media,
|
||||||
|
.wp-format-audio .wp-media-buttons .insert-media,
|
||||||
|
.wp-format-video .wp-media-buttons .insert-media,
|
||||||
.wp-format-aside .wp-media-buttons .insert-media,
|
.wp-format-aside .wp-media-buttons .insert-media,
|
||||||
.wp-format-status .wp-media-buttons .insert-media {
|
.wp-format-status .wp-media-buttons .insert-media {
|
||||||
display: none;
|
display: none;
|
||||||
@ -4101,18 +4104,36 @@ body .ui-tooltip {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.post-format-options {
|
.post-format-options {
|
||||||
height: 50px;
|
border-width: 1px;
|
||||||
|
border-style: solid;
|
||||||
|
-webkit-border-radius: 3px;
|
||||||
|
border-radius: 3px;
|
||||||
|
border-color: #CCC;
|
||||||
margin: 13px 0 10px;
|
margin: 13px 0 10px;
|
||||||
padding: 0;
|
padding: 5px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.post-format-options a {
|
.post-format-options a {
|
||||||
display: inline-block;
|
display: inline-block;
|
||||||
height: 34px;
|
min-width: 62px;
|
||||||
margin-right: 33px;
|
padding:5px;
|
||||||
|
border:1px solid transparent;
|
||||||
|
margin-right: 10px;
|
||||||
position: relative;
|
position: relative;
|
||||||
text-decoration: none;
|
text-decoration: none;
|
||||||
text-align: center;
|
text-align: center;
|
||||||
|
transition: opacity 0.1s linear;
|
||||||
|
opacity: 0.6;
|
||||||
|
}
|
||||||
|
|
||||||
|
.post-format-options:hover a {
|
||||||
|
opacity: 1.0;
|
||||||
|
}
|
||||||
|
.post-format-options a:hover,
|
||||||
|
.post-format-options a.active {
|
||||||
|
opacity: 1.0;
|
||||||
|
background-color: #fff;
|
||||||
|
border-color: #ccc;
|
||||||
}
|
}
|
||||||
|
|
||||||
.post-format-options a div {
|
.post-format-options a div {
|
||||||
@ -4127,7 +4148,7 @@ body .ui-tooltip {
|
|||||||
margin-top: 4px;
|
margin-top: 4px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.post-format-change, .post-format-set .post-format-options {
|
.post-format-set .post-format-options {
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4136,7 +4157,7 @@ body .ui-tooltip {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#poststuff .post-format-change {
|
#poststuff .post-format-change {
|
||||||
margin: 11px 0 13px;
|
margin: -7px 0 13px 2px;
|
||||||
padding: 0;
|
padding: 0;
|
||||||
font-size: 1.5em;
|
font-size: 1.5em;
|
||||||
line-height: 18px;
|
line-height: 18px;
|
||||||
@ -4150,43 +4171,43 @@ body .ui-tooltip {
|
|||||||
width: 16px;
|
width: 16px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.post-format-change span.icon.standard {
|
.post-format-change span.icon.wp-format-standard {
|
||||||
background: url(../images/post-formats.png) no-repeat -8px -8px;
|
background: url(../images/post-formats.png) no-repeat -8px -8px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.post-format-change span.icon.image {
|
.post-format-change span.icon.wp-format-image {
|
||||||
background: url(../images/post-formats.png) no-repeat -40px -8px;
|
background: url(../images/post-formats.png) no-repeat -40px -8px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.post-format-change span.icon.gallery {
|
.post-format-change span.icon.wp-format-gallery {
|
||||||
background: url(../images/post-formats.png) no-repeat -72px -8px;
|
background: url(../images/post-formats.png) no-repeat -72px -8px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.post-format-change span.icon.audio {
|
.post-format-change span.icon.wp-format-audio {
|
||||||
background: url(../images/post-formats.png) no-repeat -104px -8px;
|
background: url(../images/post-formats.png) no-repeat -104px -8px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.post-format-change span.icon.video {
|
.post-format-change span.icon.wp-format-video {
|
||||||
background: url(../images/post-formats.png) no-repeat -136px -8px;
|
background: url(../images/post-formats.png) no-repeat -136px -8px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.post-format-change span.icon.chat {
|
.post-format-change span.icon.wp-format-chat {
|
||||||
background: url(../images/post-formats.png) no-repeat -168px -8px;
|
background: url(../images/post-formats.png) no-repeat -168px -8px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.post-format-change span.icon.status {
|
.post-format-change span.icon.wp-format-status {
|
||||||
background: url(../images/post-formats.png) no-repeat -200px -8px;
|
background: url(../images/post-formats.png) no-repeat -200px -8px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.post-format-change span.icon.aside {
|
.post-format-change span.icon.wp-format-aside {
|
||||||
background: url(../images/post-formats.png) no-repeat -232px -8px;
|
background: url(../images/post-formats.png) no-repeat -232px -8px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.post-format-change span.icon.quote {
|
.post-format-change span.icon.wp-format-quote {
|
||||||
background: url(../images/post-formats.png) no-repeat -264px -8px;
|
background: url(../images/post-formats.png) no-repeat -264px -8px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.post-format-change span.icon.link {
|
.post-format-change span.icon.wp-format-link {
|
||||||
background: url(../images/post-formats.png) no-repeat -296px -8px;
|
background: url(../images/post-formats.png) no-repeat -296px -8px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -136,15 +136,12 @@ if ( post_type_supports( $post_type, 'post-formats' ) && apply_filters( 'enable_
|
|||||||
wp_enqueue_script( 'wp-mediaelement' );
|
wp_enqueue_script( 'wp-mediaelement' );
|
||||||
wp_enqueue_style( 'wp-mediaelement' );
|
wp_enqueue_style( 'wp-mediaelement' );
|
||||||
$post_format = get_post_format();
|
$post_format = get_post_format();
|
||||||
$post_format_set_class = 'post-format-set';
|
|
||||||
|
|
||||||
if ( ! $post_format ) {
|
if ( ! $post_format ) {
|
||||||
$post_format = 'standard';
|
$post_format = 'standard';
|
||||||
|
|
||||||
if ( ! empty( $_REQUEST['format'] ) && in_array( $_REQUEST['format'], get_post_format_slugs() ) )
|
if ( ! empty( $_REQUEST['format'] ) && in_array( $_REQUEST['format'], get_post_format_slugs() ) )
|
||||||
$post_format = $_REQUEST['format'];
|
$post_format = $_REQUEST['format'];
|
||||||
elseif ( 'auto-draft' == $post->post_status )
|
|
||||||
$post_format_set_class = '';
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$user_wants = get_user_option( 'post_formats_' . $post_type );
|
$user_wants = get_user_option( 'post_formats_' . $post_type );
|
||||||
@ -425,6 +422,9 @@ wp_nonce_field( 'closedpostboxes', 'closedpostboxesnonce', false );
|
|||||||
<div id="poststuff">
|
<div id="poststuff">
|
||||||
<div id="post-body" class="metabox-holder columns-<?php echo 1 == get_current_screen()->get_columns() ? '1' : '2'; ?>">
|
<div id="post-body" class="metabox-holder columns-<?php echo 1 == get_current_screen()->get_columns() ? '1' : '2'; ?>">
|
||||||
<div id="post-body-content"<?php echo $format_class; ?>>
|
<div id="post-body-content"<?php echo $format_class; ?>>
|
||||||
|
<div class="wp-post-format-ui<?php if ( ! $show_post_format_ui ) echo ' no-ui' ?>">
|
||||||
|
<div class="post-format-change"><span class="icon <?php echo esc_attr( 'wp-format-' . $post_format ); ?>"></span> <span class="post-format-description"><?php echo $all_post_formats[$post_format]['description']; ?></span></div>
|
||||||
|
</div>
|
||||||
<?php if ( post_type_supports($post_type, 'title') ) { ?>
|
<?php if ( post_type_supports($post_type, 'title') ) { ?>
|
||||||
<div id="titlediv">
|
<div id="titlediv">
|
||||||
<div id="titlewrap">
|
<div id="titlewrap">
|
||||||
|
@ -10,7 +10,6 @@ wp_nonce_field( 'show-post-format-ui_' . $post_type, 'show_post_format_ui_nonce'
|
|||||||
|
|
||||||
?>
|
?>
|
||||||
<div class="wp-post-format-ui<?php if ( ! $show_post_format_ui ) echo ' no-ui' ?>">
|
<div class="wp-post-format-ui<?php if ( ! $show_post_format_ui ) echo ' no-ui' ?>">
|
||||||
<div class="post-format-change"><span class="icon <?php echo esc_attr( $post_format ); ?>"></span> <span class="post-format-description"><?php echo $all_post_formats[$post_format]['description']; ?></span> <a href="#"><?php _e('Change format'); ?></a></div>
|
|
||||||
<div class="post-formats-fields">
|
<div class="post-formats-fields">
|
||||||
|
|
||||||
<input type="hidden" name="post_format" id="post_format" value="<?php echo esc_attr( $post_format ); ?>" />
|
<input type="hidden" name="post_format" id="post_format" value="<?php echo esc_attr( $post_format ); ?>" />
|
||||||
|
@ -1,89 +1,132 @@
|
|||||||
|
/*globals window, $, jQuery, document, _, postFormats, tinymce, ajaxurl, wp, getUserSetting */
|
||||||
|
|
||||||
window.wp = window.wp || {};
|
window.wp = window.wp || {};
|
||||||
|
|
||||||
(function($) {
|
(function ($) {
|
||||||
var container, $container, mediaFrame, lastMimeType, mediaPreview, lastHeight = 360, content, insertMediaButton,
|
"use strict";
|
||||||
|
|
||||||
|
var mediaFrame, insertMediaButton, container, icon, formatField,
|
||||||
|
lastMimeType,
|
||||||
|
classRegex = /\s?\bwp-format-[^ ]+/g,
|
||||||
|
shortHeight = 120,
|
||||||
|
lastHeight = 360,
|
||||||
initialFormat = 'standard',
|
initialFormat = 'standard',
|
||||||
shortClass = 'short-format',
|
shortClass = 'short-format',
|
||||||
|
noTitleFormats = ['status'],
|
||||||
|
noMediaFormats = ['status', 'aside', 'image', 'audio', 'video'],
|
||||||
shortContentFormats = ['status', 'aside'],
|
shortContentFormats = ['status', 'aside'],
|
||||||
noUIFormats = ['standard', 'chat', 'status', 'aside', 'gallery'],
|
noUIFormats = ['standard', 'chat', 'status', 'aside', 'gallery'];
|
||||||
$screenIcon = $( '.icon32' );
|
|
||||||
|
|
||||||
|
|
||||||
function switchFormatClass( format ) {
|
function switchFormatClass( format ) {
|
||||||
container.get(0).className = container.get(0).className.replace( /\s?\bwp-format-[^ ]+/g, '' );
|
formatField.val( format );
|
||||||
container.addClass('wp-format-' + format);
|
|
||||||
$screenIcon.get(0).className = $screenIcon.get(0).className.replace( /\s?\bwp-format-[^ ]+/g, '' );
|
container
|
||||||
$screenIcon.addClass('wp-format-' + format);
|
.prop( 'className', container.prop( 'className' ).replace( classRegex, '' ) )
|
||||||
|
.addClass( 'wp-format-' + format );
|
||||||
|
|
||||||
|
icon
|
||||||
|
.prop( 'className', icon.prop( 'className' ).replace( classRegex, '' ) )
|
||||||
|
.addClass( 'wp-format-' + format );
|
||||||
}
|
}
|
||||||
|
|
||||||
function resizeContent( format, noAnimate ) {
|
function resizeContent( format, noAnimate ) {
|
||||||
var height;
|
var height, content = $( '#content, #content_ifr' );
|
||||||
|
|
||||||
content = $('#content, #content_ifr');
|
height = content.outerHeight();
|
||||||
|
if ( shortHeight < height ) {
|
||||||
height = content.height();
|
|
||||||
if ( 120 < height ) {
|
|
||||||
lastHeight = height;
|
lastHeight = height;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( -1 < $.inArray( format, shortContentFormats ) ) {
|
if ( -1 < $.inArray( format, shortContentFormats ) ) {
|
||||||
if ( ! content.hasClass(shortClass) ) {
|
if ( ! content.hasClass( shortClass ) ) {
|
||||||
content.addClass(shortClass);
|
content.addClass( shortClass );
|
||||||
if ( noAnimate ) {
|
_(content).each(function (elem) {
|
||||||
content.each(function () {
|
$(elem)[noAnimate ? 'css' : 'animate']( { height : shortHeight } );
|
||||||
$(this).css({ height : 120 });
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
content.each(function () {
|
|
||||||
$(this).animate({ height : 120 });
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
content.removeClass(shortClass).animate({ height : lastHeight });
|
content.removeClass( shortClass ).animate( { height : lastHeight } );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function switchFormat($this) {
|
function switchFormat(elem) {
|
||||||
var editor, body,
|
var editor, body, formatTo, formatFrom,
|
||||||
parent = $this.parent(),
|
format = elem.data( 'wp-format' ),
|
||||||
format = $this.data('wp-format'),
|
titlePrompt = $( '#title-prompt-text' ),
|
||||||
description = $('.post-format-description'),
|
description = $( '.post-format-description' ),
|
||||||
postTitle = $('#title');
|
postTitle = $( '#title'),
|
||||||
|
fields = $( '.post-formats-fields' ),
|
||||||
|
tinyIcon = $( '.post-format-change span.icon' );
|
||||||
|
|
||||||
if ( typeof container === 'undefined' )
|
if ( format === postFormats.currentPostFormat ) {
|
||||||
container = $('#post-body-content');
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
parent.slideUp().find('a.active').removeClass('active');
|
elem.addClass( 'active' ).siblings().removeClass( 'active' );
|
||||||
$this.addClass('active');
|
|
||||||
$('#post_format').val(format);
|
|
||||||
$('.post-format-change').show().find('span.icon').removeClass(postFormats.currentPostFormat).addClass(format);
|
|
||||||
|
|
||||||
if ( -1 < $.inArray( format, noUIFormats ) ) {
|
// Animate the media button going away or coming back
|
||||||
switchFormatClass( format ); // No slide
|
formatTo = -1 < $.inArray( format, noMediaFormats );
|
||||||
$container.hide();
|
formatFrom = -1 < $.inArray( postFormats.currentPostFormat, noMediaFormats );
|
||||||
} else {
|
if ( formatFrom ? !formatTo : formatTo ) { // XOR
|
||||||
$container.slideUp( 200, function(){
|
insertMediaButton.fadeToggle( 200 ).css( 'display', 'inline-block' );
|
||||||
|
}
|
||||||
|
// Animate the title going away or coming back
|
||||||
|
formatTo = -1 < $.inArray( format, noTitleFormats );
|
||||||
|
formatFrom = -1 < $.inArray( postFormats.currentPostFormat, noTitleFormats );
|
||||||
|
if ( formatFrom ? !formatTo : formatTo ) { // XOR
|
||||||
|
$( '#titlewrap' ).fadeToggle( 200 );
|
||||||
|
}
|
||||||
|
|
||||||
|
// Animate the fields moving going away or coming in
|
||||||
|
formatTo = -1 < $.inArray( format, noUIFormats );
|
||||||
|
formatFrom = -1 < $.inArray( postFormats.currentPostFormat, noUIFormats );
|
||||||
|
if ( formatTo && formatFrom ) { // To/from have no UI. No slide.
|
||||||
|
console.log( 'both no UI' );
|
||||||
switchFormatClass( format );
|
switchFormatClass( format );
|
||||||
$container.slideDown( 400 );
|
fields.hide();
|
||||||
|
} else if ( formatFrom ) { // Only destination has UI. Slide down.
|
||||||
|
console.log( 'destination only' );
|
||||||
|
fields.hide();
|
||||||
|
switchFormatClass( format );
|
||||||
|
fields.slideDown( 400 );
|
||||||
|
} else if ( formatTo ) { // Only source has UI. Slide up.
|
||||||
|
console.log( 'source only' );
|
||||||
|
fields.slideUp( 200, function(){
|
||||||
|
switchFormatClass( format );
|
||||||
|
});
|
||||||
|
} else { // Both have UI. Slide both ways.
|
||||||
|
console.log( 'both' );
|
||||||
|
fields.slideUp( 200, function(){
|
||||||
|
switchFormatClass( format );
|
||||||
|
fields.slideDown( 400 );
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
resizeContent( format );
|
resizeContent( format );
|
||||||
|
|
||||||
postTitle.focus();
|
postTitle.focus();
|
||||||
|
|
||||||
if ( '' === postTitle.val() )
|
if ( '' === postTitle.val() ) {
|
||||||
$('#title-prompt-text').removeClass('screen-reader-text');
|
titlePrompt.removeClass( 'screen-reader-text' );
|
||||||
|
|
||||||
|
postTitle.keydown( function (e) {
|
||||||
|
titlePrompt.addClass( 'screen-reader-text' );
|
||||||
|
$( e.currentTarget ).unbind( e );
|
||||||
|
} );
|
||||||
|
}
|
||||||
|
|
||||||
// Update description line
|
// Update description line
|
||||||
description.html($this.data('description'));
|
description.html( elem.data( 'description' ) );
|
||||||
|
tinyIcon
|
||||||
|
.show()
|
||||||
|
.prop( 'className', tinyIcon.prop( 'className' ).replace( classRegex, '' ) )
|
||||||
|
.addClass( 'wp-format-' + format );
|
||||||
|
|
||||||
if (description.not(':visible'))
|
if ( description.not( ':visible' ) ) {
|
||||||
description.slideDown('fast');
|
description.slideDown( 'fast' );
|
||||||
|
}
|
||||||
|
|
||||||
if ( typeof tinymce != 'undefined' ) {
|
if ( tinymce ) {
|
||||||
editor = tinymce.get('content');
|
editor = tinymce.get( 'content' );
|
||||||
|
|
||||||
if ( editor ) {
|
if ( editor ) {
|
||||||
body = editor.getBody();
|
body = editor.getBody();
|
||||||
@ -94,51 +137,45 @@ window.wp = window.wp || {};
|
|||||||
|
|
||||||
// If gallery, force it to open to gallery state
|
// If gallery, force it to open to gallery state
|
||||||
insertMediaButton.toggleClass( 'gallery', 'gallery' === format );
|
insertMediaButton.toggleClass( 'gallery', 'gallery' === format );
|
||||||
|
|
||||||
postFormats.currentPostFormat = format;
|
postFormats.currentPostFormat = format;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$(function () {
|
||||||
|
container = $( '#post-body-content' );
|
||||||
$(function() {
|
icon = $( '.icon32' );
|
||||||
|
formatField = $( '#post_format' );
|
||||||
insertMediaButton = $( '#insert-media-button' ).toggleClass( 'gallery', 'gallery' === postFormats.currentPostFormat );
|
insertMediaButton = $( '#insert-media-button' ).toggleClass( 'gallery', 'gallery' === postFormats.currentPostFormat );
|
||||||
$container = $( '.post-formats-fields' );
|
|
||||||
|
|
||||||
initialFormat = $( '.post-format-options .active' ).data( 'wp-format' );
|
initialFormat = $( '.post-format-options .active' ).data( 'wp-format' );
|
||||||
|
|
||||||
if ( -1 < $.inArray( initialFormat, shortContentFormats ) ) {
|
if ( -1 < $.inArray( initialFormat, shortContentFormats ) ) {
|
||||||
resizeContent( initialFormat, true );
|
resizeContent( initialFormat, true );
|
||||||
}
|
}
|
||||||
|
|
||||||
$('#show_post_format_ui').on('change', function() {
|
$( '#show_post_format_ui' ).on( 'change', function () {
|
||||||
$('.wp-post-format-ui').toggleClass('no-ui', ! this.checked );
|
$( '.wp-post-format-ui' ).toggleClass( 'no-ui', ! this.checked );
|
||||||
$.post( ajaxurl, {
|
$.post( ajaxurl, {
|
||||||
action: 'show-post-format-ui',
|
action: 'show-post-format-ui',
|
||||||
post_type: $('#post_type').val(),
|
post_type: $( '#post_type' ).val(),
|
||||||
show: this.checked ? 1 : 0,
|
show: this.checked ? 1 : 0,
|
||||||
nonce: $('#show_post_format_ui_nonce').val()
|
nonce: $( '#show_post_format_ui_nonce' ).val()
|
||||||
});
|
} );
|
||||||
});
|
} );
|
||||||
|
|
||||||
$('.post-format-change a').click(function() {
|
|
||||||
$('.post-formats-fields, .post-format-change').slideUp();
|
|
||||||
$('.post-format-options').slideDown();
|
|
||||||
return false;
|
|
||||||
});
|
|
||||||
|
|
||||||
// Post formats selection
|
// Post formats selection
|
||||||
$('.post-format-options').on( 'click', 'a', function (e) {
|
$( '.post-format-options' ).on( 'click', 'a', function (e) {
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
switchFormat($(this));
|
switchFormat( $( e.currentTarget ) );
|
||||||
});
|
} );
|
||||||
|
|
||||||
// Media selection
|
// Media selection
|
||||||
$('.wp-format-media-select').click(function(event) {
|
$( '.wp-format-media-select' ).click( function (e) {
|
||||||
event.preventDefault();
|
e.preventDefault();
|
||||||
var $el = $(this), mime = 'image',
|
|
||||||
$holder = $el.closest('.wp-format-media-holder'),
|
|
||||||
$field = $( '#wp_format_' + $holder.data('format') );
|
|
||||||
|
|
||||||
mime = $holder.data('format');
|
var $el = $(e.currentTarget), mediaPreview, mime = 'image', $holder, $field;
|
||||||
|
|
||||||
|
$holder = $el.closest( '.wp-format-media-holder' );
|
||||||
|
$field = $( '#wp_format_' + $holder.data( 'format' ) );
|
||||||
|
mime = $holder.data( 'format' );
|
||||||
|
|
||||||
// If the media frame already exists, reopen it.
|
// If the media frame already exists, reopen it.
|
||||||
if ( mediaFrame && lastMimeType === mime ) {
|
if ( mediaFrame && lastMimeType === mime ) {
|
||||||
@ -150,86 +187,97 @@ window.wp = window.wp || {};
|
|||||||
|
|
||||||
mediaFrame = wp.media.frames.formatMedia = wp.media( {
|
mediaFrame = wp.media.frames.formatMedia = wp.media( {
|
||||||
button: {
|
button: {
|
||||||
text: $el.data('update')
|
text: $el.data( 'update' )
|
||||||
},
|
},
|
||||||
states: [
|
states: [
|
||||||
new wp.media.controller.Library({
|
new wp.media.controller.Library({
|
||||||
library: wp.media.query( { type: mime } ),
|
library: wp.media.query( { type: mime } ),
|
||||||
title: $el.data('choose'),
|
title: $el.data( 'choose' ),
|
||||||
displaySettings: 'image' === mime
|
displaySettings: 'image' === mime
|
||||||
})
|
})
|
||||||
]
|
]
|
||||||
} );
|
} );
|
||||||
|
|
||||||
mediaPreview = function(attachment) {
|
mediaPreview = function (attachment) {
|
||||||
var w, h, dimensions = '', url = attachment.url, mime = attachment.mime, format = attachment.type;
|
var w, h, dimensions = '', url = attachment.url, mime = attachment.mime, format = attachment.type;
|
||||||
|
|
||||||
if ( 'video' === format ) {
|
if ( 'video' === format ) {
|
||||||
if ( attachment.width ) {
|
if ( attachment.width ) {
|
||||||
w = attachment.width;
|
w = attachment.width;
|
||||||
if ( w > 600 )
|
if ( w > 600 ) {
|
||||||
w = 600;
|
w = 600;
|
||||||
|
}
|
||||||
dimensions += ' width="' + w + '"';
|
dimensions += ' width="' + w + '"';
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( attachment.height ) {
|
if ( attachment.height ) {
|
||||||
h = attachment.height;
|
h = attachment.height;
|
||||||
if ( attachment.width && w < attachment.width )
|
if ( attachment.width && w < attachment.width ) {
|
||||||
h = Math.round( ( h * w ) / attachment.width );
|
h = Math.round( ( h * w ) / attachment.width );
|
||||||
|
}
|
||||||
dimensions += ' height="' + h + '"';
|
dimensions += ' height="' + h + '"';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$('#' + format + '-preview').remove();
|
$( '#' + format + '-preview' ).remove();
|
||||||
$holder.parent().prepend( '<div id="' + format + '-preview" class="wp-format-media-preview">' +
|
$holder.parent().prepend( '<div id="' + format + '-preview" class="wp-format-media-preview">' +
|
||||||
'<' + format + dimensions + ' class="wp-' + format + '-shortcode" controls="controls" preload="none">' +
|
'<' + format + dimensions + ' class="wp-' + format + '-shortcode" controls="controls" preload="none">' +
|
||||||
'<source type="' + mime + '" src="' + url + '" />' +
|
'<source type="' + mime + '" src="' + url + '" />' +
|
||||||
'</' + format + '></div>' );
|
'</' + format + '></div>' );
|
||||||
$('.wp-' + format + '-shortcode').mediaelementplayer();
|
$( '.wp-' + format + '-shortcode' ).mediaelementplayer();
|
||||||
};
|
};
|
||||||
|
|
||||||
// When an image is selected, run a callback.
|
// When an image is selected, run a callback.
|
||||||
mediaFrame.on( 'select', function() {
|
mediaFrame.on( 'select', function () {
|
||||||
// Grab the selected attachment.
|
// Grab the selected attachment.
|
||||||
var w = 0, h = 0, html, attachment = mediaFrame.state().get('selection').first().toJSON();
|
var w = 0, h = 0, html, attachment = mediaFrame.state().get( 'selection' ).first().toJSON();
|
||||||
|
|
||||||
if ( 0 === attachment.mime.indexOf('audio') ) {
|
if ( 0 === attachment.mime.indexOf( 'audio' ) ) {
|
||||||
$field.val(attachment.url);
|
$field.val( attachment.url );
|
||||||
// show one preview at a time
|
// show one preview at a time
|
||||||
mediaPreview(attachment);
|
mediaPreview( attachment );
|
||||||
} else if ( 0 === attachment.mime.indexOf('video') ) {
|
} else if ( 0 === attachment.mime.indexOf( 'video' ) ) {
|
||||||
attachment.src = attachment.url;
|
attachment.src = attachment.url;
|
||||||
$field.val(wp.shortcode.string({
|
$field.val( wp.shortcode.string( {
|
||||||
tag: 'video',
|
tag: 'video',
|
||||||
attrs: _.pick( attachment, 'src', 'width', 'height' )
|
attrs: _.pick( attachment, 'src', 'width', 'height' )
|
||||||
}));
|
} ) );
|
||||||
// show one preview at a time
|
// show one preview at a time
|
||||||
mediaPreview(attachment);
|
mediaPreview( attachment );
|
||||||
} else {
|
} else {
|
||||||
html = wp.media.string.image({
|
html = wp.media.string.image({
|
||||||
align : getUserSetting('align'),
|
align : getUserSetting( 'align' ),
|
||||||
size : getUserSetting('imgsize'),
|
size : getUserSetting( 'imgsize' ),
|
||||||
link : getUserSetting('urlbutton')
|
link : getUserSetting( 'urlbutton' )
|
||||||
}, attachment);
|
}, attachment);
|
||||||
|
|
||||||
// set the hidden input's value
|
// set the hidden input's value
|
||||||
$field.val(html);
|
$field.val( html );
|
||||||
$('#image-preview').remove();
|
|
||||||
if ( attachment.width )
|
$( '#image-preview' ).remove();
|
||||||
|
|
||||||
|
if ( attachment.width ) {
|
||||||
w = attachment.width > 600 ? 600 : attachment.width;
|
w = attachment.width > 600 ? 600 : attachment.width;
|
||||||
if ( attachment.height )
|
}
|
||||||
|
|
||||||
|
if ( attachment.height ) {
|
||||||
h = attachment.height;
|
h = attachment.height;
|
||||||
if ( w < attachment.width )
|
}
|
||||||
|
|
||||||
|
if ( w < attachment.width ) {
|
||||||
h = Math.round( ( h * w ) / attachment.width );
|
h = Math.round( ( h * w ) / attachment.width );
|
||||||
|
}
|
||||||
|
|
||||||
$holder.parent().prepend( ['<div id="image-preview" class="wp-format-media-preview">',
|
$holder.parent().prepend( ['<div id="image-preview" class="wp-format-media-preview">',
|
||||||
'<img src="', attachment.url, '"',
|
'<img src="', attachment.url, '"',
|
||||||
w ? ' width="' + w + '"' : '',
|
w ? ' width="' + w + '"' : '',
|
||||||
h ? ' height="' + h + '"' : '',
|
h ? ' height="' + h + '"' : '',
|
||||||
' />',
|
' />',
|
||||||
'</div>'].join('') );
|
'</div>'].join( '' ) );
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
mediaFrame.open();
|
mediaFrame.open();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
})(jQuery);
|
}( jQuery ) );
|
||||||
|
Loading…
Reference in New Issue
Block a user