Customize: Improve interactions between the Themes panel and Publish Settings section.

* Deactivate the Themes panel immediately after changing selected status to non-publish.
* Animate publish settings button into view with publish button when collapsing Themes panel.
* Deactivate publish settings section and hide publish settings button entirely when customizer state is clean.
* Harden access of Themes panel in case it was removed by plugin.
* Fix throttling of `renderScreenshots` calls in `ThemesSection`.

Amends [41648], [41626].
See #37661, #39896, #34843.


git-svn-id: https://develop.svn.wordpress.org/trunk@41649 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Weston Ruter 2017-09-29 21:51:42 +00:00
parent c35fe07703
commit d2540cfa06
2 changed files with 45 additions and 31 deletions

View File

@ -1659,6 +1659,7 @@ p.customize-section-description {
/* Animations for opening the themes panel */ /* Animations for opening the themes panel */
#customize-header-actions .save, #customize-header-actions .save,
#customize-header-actions #publish-settings,
#customize-header-actions .spinner, #customize-header-actions .spinner,
#customize-header-actions .customize-controls-preview-toggle { #customize-header-actions .customize-controls-preview-toggle {
position: relative; position: relative;
@ -1686,6 +1687,7 @@ p.customize-section-description {
} }
.in-themes-panel #customize-header-actions .save, .in-themes-panel #customize-header-actions .save,
.in-themes-panel #customize-header-actions #publish-settings,
.in-themes-panel #customize-header-actions .spinner, .in-themes-panel #customize-header-actions .spinner,
.in-themes-panel #customize-header-actions .customize-controls-preview-toggle { .in-themes-panel #customize-header-actions .customize-controls-preview-toggle {
top: -45px; top: -45px;

View File

@ -1510,7 +1510,9 @@
} }
}); });
_.bindAll( this, 'renderScreenshots', 'loadMore', 'checkTerm', 'filtersChecked' ); section.renderScreenshots = _.throttle( section.renderScreenshots, 100 );
_.bindAll( section, 'renderScreenshots', 'loadMore', 'checkTerm', 'filtersChecked' );
}, },
/** /**
@ -1929,9 +1931,7 @@
section.container.find( noFilter ).hide(); section.container.find( noFilter ).hide();
} }
renderScreenshots = _.throttle( _.bind( section.renderScreenshots, this ), 100 ); section.renderScreenshots();
renderScreenshots();
// Update theme count. // Update theme count.
section.updateCount( count ); section.updateCount( count );
@ -6283,7 +6283,7 @@
saveBtn.show(); saveBtn.show();
api.section( 'publish_settings', function( section ) { api.section( 'publish_settings', function( section ) {
var updateButtonsState, previewLinkControl, previewLinkControlId = 'changeset_preview_link'; var updateButtonsState, previewLinkControl, previewLinkControlId = 'changeset_preview_link', updateSectionActive, isSectionActive;
previewLinkControl = new api.PreviewLinkControl( previewLinkControlId, { previewLinkControl = new api.PreviewLinkControl( previewLinkControlId, {
params: { params: {
@ -6296,11 +6296,30 @@
api.control.add( previewLinkControlId, previewLinkControl ); api.control.add( previewLinkControlId, previewLinkControl );
// Make sure publish settings are not available until the theme has been activated. /**
if ( ! api.settings.theme.active ) { * Return whether the pubish settings section should be active.
section.active.set( false ); *
section.active.link( api.state( 'activated' ) ); * @return {boolean} Is section active.
*/
isSectionActive = function() {
if ( ! api.state( 'activated' ) ) {
return false;
} }
if ( '' === api.state( 'changesetStatus' ).get() && api.state( 'saved' ).get() ) {
return false;
}
return true;
};
// Make sure publish settings are not available while the theme is not active and the customizer is in a published state.
section.active.validate = isSectionActive;
updateSectionActive = function() {
section.active.set( isSectionActive() );
};
api.state( 'activated' ).bind( updateSectionActive );
api.state( 'saved' ).bind( updateSectionActive );
api.state( 'changesetStatus' ).bind( updateSectionActive );
updateSectionActive();
// Bind visibility of the publish settings button to whether the section is active. // Bind visibility of the publish settings button to whether the section is active.
updateButtonsState = function() { updateButtonsState = function() {
@ -6323,12 +6342,6 @@
publishSettingsBtn.attr( 'aria-expanded', String( isExpanded ) ); publishSettingsBtn.attr( 'aria-expanded', String( isExpanded ) );
publishSettingsBtn.toggleClass( 'active', isExpanded ); publishSettingsBtn.toggleClass( 'active', isExpanded );
} ); } );
api.state( 'changesetStatus' ).bind( function( status ) {
if ( 'publish' === status ) {
section.collapse();
}
} );
} ); } );
// Prevent the form from saving when enter is pressed on an input or select element. // Prevent the form from saving when enter is pressed on an input or select element.
@ -6996,18 +7009,21 @@
}; };
// Deactivate themes panel if changeset status is not auto-draft. // Deactivate themes panel if changeset status is not auto-draft.
api.panel( 'themes', function( panel ) { api.panel( 'themes', function( themesPanel ) {
var canActivate; var isPanelActive, updatePanelActive;
canActivate = function() { isPanelActive = function() {
return ! changesetStatus() || 'auto-draft' === changesetStatus(); return 'publish' === selectedChangesetStatus.get() && ( ! changesetStatus() || 'auto-draft' === changesetStatus() );
};
themesPanel.active.validate = isPanelActive;
updatePanelActive = function() {
themesPanel.active.set( isPanelActive() );
}; };
panel.active.validate = canActivate; updatePanelActive();
panel.active.set( canActivate() ); changesetStatus.bind( updatePanelActive );
changesetStatus.bind( function() { selectedChangesetStatus.bind( updatePanelActive );
panel.active.set( canActivate() );
} );
} ); } );
// Show changeset UUID in URL when in branching mode and there is a saved changeset. // Show changeset UUID in URL when in branching mode and there is a saved changeset.
@ -7215,10 +7231,10 @@
// Themes panel or section. // Themes panel or section.
if ( body.hasClass( 'modal-open' ) ) { if ( body.hasClass( 'modal-open' ) ) {
collapsedObject.closeDetails(); collapsedObject.closeDetails();
} else { } else if ( api.panel.has( 'themes' ) ) {
// If we're collapsing a section, collapse the panel also. // If we're collapsing a section, collapse the panel also.
wp.customize.panel( 'themes' ).collapse(); api.panel( 'themes' ).collapse();
} }
return; return;
} }
@ -7842,10 +7858,6 @@
var publishSettingsSection; var publishSettingsSection;
api.state( 'selectedChangesetStatus' ).set( 'publish' ); api.state( 'selectedChangesetStatus' ).set( 'publish' );
publishSettingsSection = api.section( 'publish_settings' );
if ( publishSettingsSection ) {
publishSettingsSection.collapse();
}
api.previewer.save(); api.previewer.save();
}; };