Nicer behaviour for the loading of the notice input form.

This commit is contained in:
Mikael Nordfeldth 2015-02-01 21:35:36 +01:00
parent f05f701764
commit 20e1257e70

View File

@ -1382,7 +1382,7 @@ var SN = { // StatusNet
* *
* @param {String} tag * @param {String} tag
*/ */
switchInputFormTab: function (tag) { switchInputFormTab: function (tag, setFocus=true) {
// The one that's current isn't current anymore // The one that's current isn't current anymore
$('.input_form_nav_tab.current').removeClass('current'); $('.input_form_nav_tab.current').removeClass('current');
if (tag != null) { if (tag != null) {
@ -1403,13 +1403,15 @@ var SN = { // StatusNet
return false; return false;
} }
$('#input_form_' + tag) var noticeForm = $('#input_form_' + tag)
.addClass('current') .addClass('current')
.find('.ajax-notice').each(function () { .find('.ajax-notice').each(function () {
var form = $(this); var form = $(this);
SN.Init.NoticeFormSetup(form); SN.Init.NoticeFormSetup(form);
}) });
.find('.notice_data-text').focus(); if (setFocus) {
noticeForm.find('.notice_data-text').focus();
}
return false; return false;
}, },
@ -1437,16 +1439,11 @@ var SN = { // StatusNet
// SN.Init.NoticeFormSetup() will get run // SN.Init.NoticeFormSetup() will get run
// when forms get displayed for the first time... // when forms get displayed for the first time...
// Initially hide all tabs on the top of the page // Initialize the input form field
// if there's no data in there yet. $('#input_form_nav .input_form_nav_tab.current').each(function () {
var fields = $('#content .input_forms .input_form.current').find('textarea, input[type=text], input[type=""]'); current_tab_id = $(this).attr('id').substring('input_form_nav_'.length);
var anything = false; SN.U.switchInputFormTab(current_tab_id, false);
fields.each(function () {
anything = anything || $(this).val();
}); });
if (!anything) {
SN.U.switchInputFormTab(null);
}
// Make inline reply forms self-close when clicking out. // Make inline reply forms self-close when clicking out.
$('body').on('click', function (e) { $('body').on('click', function (e) {