BUG ShowUnpublished checkbox with initial state not working

If ShowUnpublished checkbox initial state is checked, the history
doesn't show the unpublished versions up front. The user would need to
uncheck the box then check again, as only the change event would handle
the toggling of showing unpublished versions.

Moved the ShowUnpublished handler into a separate entwine class, and
run the same toggle code onmatch, as well as onchange.
This commit is contained in:
Sean Harvey 2013-05-13 16:24:00 +12:00
parent f0e7990ca3
commit 4f88dcbbfc

View File

@ -8,6 +8,7 @@
*/ */
$.entwine('ss', function($){ $.entwine('ss', function($){
/** /**
* Class: #Form_VersionsForm * Class: #Form_VersionsForm
* *
@ -19,24 +20,6 @@
* Constructor * Constructor
*/ */
onmatch: function() { onmatch: function() {
var self = this;
/**
* Event: :input[name=ShowUnpublished] change
*
* Changing the show unpublished checkbox toggles whether to show
* or hide the unpublished versions. Because those rows may be being
* compared this also ensures those rows are unselected.
*/
this.find(':input[name=ShowUnpublished]').bind('change', function(e) {
if($(this).attr("checked")) {
self.find("tr[data-published=false]").show();
}
else {
self.find("tr[data-published=false]").hide()._unselect();
}
});
this._super(); this._super();
}, },
onunmatch: function() { onunmatch: function() {
@ -83,6 +66,41 @@
} }
}); });
/**
* Class: :input[name=ShowUnpublished]
*
* Used for toggling whether to show or hide unpublished versions.
*/
$('#Form_VersionsForm input[name=ShowUnpublished]').entwine({
onmatch: function() {
this.toggle();
this._super();
},
onunmatch: function() {
this._super();
},
/**
* Event: :input[name=ShowUnpublished] change
*
* Changing the show unpublished checkbox toggles whether to show
* or hide the unpublished versions. Because those rows may be being
* compared this also ensures those rows are unselected.
*/
onchange: function() {
this.toggle();
},
toggle: function() {
var self = $(this);
var form = self.parents('form');
if(self.attr('checked')) {
form.find('tr[data-published=false]').show();
} else {
form.find("tr[data-published=false]").hide()._unselect();
}
}
});
/** /**
* Class: #Form_VersionsForm tr * Class: #Form_VersionsForm tr
* *