Customize: Draw attention to save button after collapsing the publish settings section when the changeset status or date had been changed.
Props bpayton, westonruter. See #42114, #39896. Fixes #42211. git-svn-id: https://develop.svn.wordpress.org/trunk@41932 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
3ce1938687
commit
285be53824
@ -6889,7 +6889,7 @@
|
|||||||
|
|
||||||
// Set up publish settings section and its controls.
|
// Set up publish settings section and its controls.
|
||||||
api.section( 'publish_settings', function( section ) {
|
api.section( 'publish_settings', function( section ) {
|
||||||
var updateButtonsState, trashControl, updateSectionActive, isSectionActive, statusControl, dateControl, toggleDateControl, publishWhenTime, pollInterval, updateTimeArrivedPoller, timeArrivedPollingInterval = 1000;
|
var updateButtonsState, trashControl, updateSectionActive, isSectionActive, statusControl, dateControl, toggleDateControl, publishWhenTime, pollInterval, updateTimeArrivedPoller, cancelScheduleButtonReminder, timeArrivedPollingInterval = 1000;
|
||||||
|
|
||||||
trashControl = new api.Control( 'trash_changeset', {
|
trashControl = new api.Control( 'trash_changeset', {
|
||||||
type: 'button',
|
type: 'button',
|
||||||
@ -6951,6 +6951,26 @@
|
|||||||
updateButtonsState();
|
updateButtonsState();
|
||||||
section.active.bind( updateButtonsState );
|
section.active.bind( updateButtonsState );
|
||||||
|
|
||||||
|
function highlightScheduleButton() {
|
||||||
|
if ( ! cancelScheduleButtonReminder ) {
|
||||||
|
cancelScheduleButtonReminder = api.utils.highlightButton( btnWrapper, {
|
||||||
|
delay: 1000,
|
||||||
|
|
||||||
|
// Only abort the reminder when the save button is focused.
|
||||||
|
// If the user clicks the settings button to toggle the
|
||||||
|
// settings closed, we'll still remind them.
|
||||||
|
focusTarget: saveBtn
|
||||||
|
} );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
function cancelHighlightScheduleButton() {
|
||||||
|
if ( cancelScheduleButtonReminder ) {
|
||||||
|
cancelScheduleButtonReminder();
|
||||||
|
cancelScheduleButtonReminder = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
api.state( 'selectedChangesetStatus' ).bind( cancelHighlightScheduleButton );
|
||||||
|
|
||||||
section.contentContainer.find( '.customize-action' ).text( api.l10n.updating );
|
section.contentContainer.find( '.customize-action' ).text( api.l10n.updating );
|
||||||
section.contentContainer.find( '.customize-section-back' ).removeAttr( 'tabindex' );
|
section.contentContainer.find( '.customize-section-back' ).removeAttr( 'tabindex' );
|
||||||
publishSettingsBtn.prop( 'disabled', false );
|
publishSettingsBtn.prop( 'disabled', false );
|
||||||
@ -6963,6 +6983,14 @@
|
|||||||
section.expanded.bind( function( isExpanded ) {
|
section.expanded.bind( function( isExpanded ) {
|
||||||
publishSettingsBtn.attr( 'aria-expanded', String( isExpanded ) );
|
publishSettingsBtn.attr( 'aria-expanded', String( isExpanded ) );
|
||||||
publishSettingsBtn.toggleClass( 'active', isExpanded );
|
publishSettingsBtn.toggleClass( 'active', isExpanded );
|
||||||
|
|
||||||
|
if ( isExpanded ) {
|
||||||
|
cancelHighlightScheduleButton();
|
||||||
|
} else if ( api.state( 'selectedChangesetStatus' ).get() !== api.state( 'changesetStatus' ).get() ) {
|
||||||
|
highlightScheduleButton();
|
||||||
|
} else if ( 'future' === api.state( 'selectedChangesetStatus' ).get() && api.state( 'selectedChangesetDate' ).get() !== api.state( 'changesetDate' ).get() ) {
|
||||||
|
highlightScheduleButton();
|
||||||
|
}
|
||||||
} );
|
} );
|
||||||
|
|
||||||
statusControl = new api.Control( 'changeset_status', {
|
statusControl = new api.Control( 'changeset_status', {
|
||||||
@ -7620,8 +7648,6 @@
|
|||||||
state.bind( 'change', function() {
|
state.bind( 'change', function() {
|
||||||
var canSave;
|
var canSave;
|
||||||
|
|
||||||
btnWrapper.removeClass( 'button-see-me' );
|
|
||||||
|
|
||||||
if ( ! activated() ) {
|
if ( ! activated() ) {
|
||||||
saveBtn.val( api.l10n.activate );
|
saveBtn.val( api.l10n.activate );
|
||||||
closeBtn.find( '.screen-reader-text' ).text( api.l10n.cancel );
|
closeBtn.find( '.screen-reader-text' ).text( api.l10n.cancel );
|
||||||
@ -7645,12 +7671,10 @@
|
|||||||
if ( saved() && selectedChangesetStatus() === changesetStatus() ) {
|
if ( saved() && selectedChangesetStatus() === changesetStatus() ) {
|
||||||
if ( changesetDate.get() !== selectedChangesetDate.get() ) {
|
if ( changesetDate.get() !== selectedChangesetDate.get() ) {
|
||||||
saveBtn.val( api.l10n.schedule );
|
saveBtn.val( api.l10n.schedule );
|
||||||
btnWrapper.addClass( 'button-see-me' );
|
|
||||||
} else {
|
} else {
|
||||||
saveBtn.val( api.l10n.scheduled );
|
saveBtn.val( api.l10n.scheduled );
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
btnWrapper.addClass( 'button-see-me' );
|
|
||||||
saveBtn.val( api.l10n.schedule );
|
saveBtn.val( api.l10n.schedule );
|
||||||
}
|
}
|
||||||
} else if ( ! api.settings.changeset.currentUserCanPublish ) {
|
} else if ( ! api.settings.changeset.currentUserCanPublish ) {
|
||||||
|
Loading…
Reference in New Issue
Block a user