Processing: 'processing',
CommandResult: 'command_result',
FormNotice: 'form_notice',
- NoticeInReplyTo: 'notice_in-reply-to',
- NoticeActionSubmit: 'notice_action-submit',
- NoticeLat: 'notice_data-lat',
- NoticeLon: 'notice_data-lon',
- NoticeLocationId: 'notice_data-location_id',
- NoticeLocationNs: 'notice_data-location_ns',
- NoticeGeoName: 'notice_data-geo_name',
NoticeDataGeo: 'notice_data-geo',
NoticeDataGeoCookie: 'NoticeDataGeo',
NoticeDataGeoSelected: 'notice_data-geo_selected',
}
form
.addClass(SN.C.S.Processing)
- .find('#'+SN.C.S.NoticeActionSubmit)
+ .find('.submit')
.addClass(SN.C.S.Disabled)
.attr(SN.C.S.Disabled, SN.C.S.Disabled);
error: function (xhr, textStatus, errorThrown) {
form
.removeClass(SN.C.S.Processing)
- .find('#'+SN.C.S.NoticeActionSubmit)
+ .find('.submit')
.removeClass(SN.C.S.Disabled)
.removeAttr(SN.C.S.Disabled, SN.C.S.Disabled);
removeFeedback();
var notices = $('#notices_primary .notices:first');
if (notices.length > 0 && SN.U.belongsOnTimeline(notice)) {
if ($('#'+notice.id).length === 0) {
- var notice_irt_value = $('#'+SN.C.S.NoticeInReplyTo).val();
+ var notice_irt_value = form.find('[name=inreplyto]').val();
var notice_irt = '#notices_primary #notice-'+notice_irt_value;
if($('body')[0].id == 'conversation') {
if(notice_irt_value.length > 0 && $(notice_irt+' .notices').length < 1) {
complete: function(xhr, textStatus) {
form
.removeClass(SN.C.S.Processing)
- .find('#'+SN.C.S.NoticeActionSubmit)
+ .find('.submit')
.removeAttr(SN.C.S.Disabled)
.removeClass(SN.C.S.Disabled);
form.find('[name=lon]').val(SN.C.I.NoticeDataGeo.NLon);
form.find('[name=location_ns]').val(SN.C.I.NoticeDataGeo.NLNS);
form.find('[name=location_id]').val(SN.C.I.NoticeDataGeo.NLID);
- $('#'+SN.C.S.NoticeDataGeo).attr('checked', SN.C.I.NoticeDataGeo.NDG);
+ form.find('[name=notice_data-geo]').attr('checked', SN.C.I.NoticeDataGeo.NDG);
}
});
},
SN.C.I.NoticeDataGeo.NLon = form.find('[name=lon]').val();
SN.C.I.NoticeDataGeo.NLNS = form.find('[name=location_ns]').val();
SN.C.I.NoticeDataGeo.NLID = form.find('[name=location_id]').val();
- SN.C.I.NoticeDataGeo.NDG = $('#'+SN.C.S.NoticeDataGeo).attr('checked'); // @fixme
+ SN.C.I.NoticeDataGeo.NDG = form.find('[name=notice_data-geo]').attr('checked'); // @fixme
var cookieValue = $.cookie(SN.C.S.NoticeDataGeoCookie);
}
}
if (cookieValue == 'disabled') {
- SN.C.I.NoticeDataGeo.NDG = $('#'+SN.C.S.NoticeDataGeo).attr('checked', false).attr('checked');
+ SN.C.I.NoticeDataGeo.NDG = form.find('[name=notice_data-geo]').attr('checked', false).attr('checked');
}
else {
- SN.C.I.NoticeDataGeo.NDG = $('#'+SN.C.S.NoticeDataGeo).attr('checked', true).attr('checked');
+ SN.C.I.NoticeDataGeo.NDG = form.find('[name=notice_data-geo]').attr('checked', true).attr('checked');
}
},
// See if the form's already open...
var replyForm = $('.notice-reply-form', list);
- if (replyForm.length == 0) {
+
+ var nextStep = function() {
+ // Override...?
+ replyForm.find('input[name=inreplyto]').val(id);
+
+ // Set focus...
+ var text = replyForm.find('textarea');
+ if (text.length == 0) {
+ throw "No textarea";
+ }
+ var replyto = '';
+ if (initialText) {
+ replyto = initialText + ' ';
+ }
+ text.val(replyto + text.val().replace(RegExp(replyto, 'i'), ''));
+ text.data('initialText', $.trim(initialText + ''));
+ text.focus();
+ if (text[0].setSelectionRange) {
+ var len = text.val().length;
+ text[0].setSelectionRange(len,len);
+ }
+ };
+ if (replyForm.length > 0) {
+ // Update the existing form...
+ nextStep();
+ } else {
// Remove placeholder if any
$('li.notice-reply-placeholder').remove();
// Create the reply form entry at the end
var replyItem = $('li.notice-reply', list);
if (replyItem.length == 0) {
+ var url = $('#form_notice').attr('action');
+ replyItem = $('<li class="notice-reply"></li>');
+ $.get(url, {ajax: 1}, function(data, textStatus, xhr) {
+ var formEl = document._importNode($('form', data)[0], true);
+ replyItem.append(formEl);
+ list.append(replyItem);
+
+ var form = replyForm = $(formEl);
+ SN.U.NoticeLocationAttach(form);
+ SN.U.FormNoticeXHR(form);
+ SN.U.FormNoticeEnhancements(form);
+ SN.U.NoticeDataAttach(form);
+
+ nextStep();
+ });
+ /*
replyItem = $('<li class="notice-reply">' +
'<form class="notice-reply-form" method="post">' +
'<textarea name="status_textarea"></textarea>' +
'</div>' +
'</form>' +
'</li>');
-
var baseForm = $('#form_notice');
replyForm = replyItem.find('form');
replyForm.attr('action', baseForm.attr('action'));
event.preventDefault();
return false;
});
+ */
}
}
-
- // Override...?
- replyForm.find('input[name=inreplyto]').val(id);
-
- // Set focus...
- var text = replyForm.find('textarea');
- if (text.length == 0) {
- throw "No textarea";
- }
- var replyto = '';
- if (initialText) {
- replyto = initialText + ' ';
- }
- text.val(replyto + text.val().replace(RegExp(replyto, 'i'), ''));
- text.data('initialText', $.trim(initialText + ''));
- text.focus();
- if (text[0].setSelectionRange) {
- var len = text.val().length;
- text[0].setSelectionRange(len,len);
- }
},
/**
* new-notice form. Seems to set up some event handlers for
* triggering lookups and using the new values.
*
+ * @param {jQuery} form
+ *
* @fixme tl;dr
* @fixme there's not good visual state update here, so users have a
* hard time figuring out if it's working or fixing if it's wrong.
*
*/
- NoticeLocationAttach: function() {
+ NoticeLocationAttach: function(form) {
// @fixme this should not be tied to the main notice form, as there may be multiple notice forms...
- var NLat = $('#'+SN.C.S.NoticeLat).val();
- var NLon = $('#'+SN.C.S.NoticeLon).val();
- var NLNS = $('#'+SN.C.S.NoticeLocationNs).val();
- var NLID = $('#'+SN.C.S.NoticeLocationId).val();
- var NLN = $('#'+SN.C.S.NoticeGeoName).text();
- var NDGe = $('#'+SN.C.S.NoticeDataGeo);
+ var NLat = form.find('[name=lat]')
+ var NLon = form.find('[name=lon]')
+ var NLNS = form.find('[name=location_ns]').val();
+ var NLID = form.find('[name=location_id]').val();
+ var NLN = ''; // @fixme
+ var NDGe = form.find('[name=notice_data-geo]');
+ var check = form.find('[name=notice_data-geo]');
+ var label = form.find('label.notice_data-geo');
function removeNoticeDataGeo(error) {
- $('label[for='+SN.C.S.NoticeDataGeo+']')
- .attr('title', jQuery.trim($('label[for='+SN.C.S.NoticeDataGeo+']').text()))
+ label
+ .attr('title', jQuery.trim(label.text()))
.removeClass('checked');
- $('.form_notice [name=lat]').val('');
- $('.form_notice [name=lon]').val('');
- $('.form_notice [name=location_ns]').val('');
- $('.form_notice [name=location_id]').val('');
- $('#'+SN.C.S.NoticeDataGeo).attr('checked', false);
+ form.find('[name=lat]').val('');
+ form.find('[name=lon]').val('');
+ form.find('[name=location_ns]').val('');
+ form.find('[name=location_id]').val('');
+ form.find('[name=notice_data-geo]').attr('checked', false);
$.cookie(SN.C.S.NoticeDataGeoCookie, 'disabled', { path: '/' });
if (error) {
- $('.geo_status_wrapper').removeClass('success').addClass('error');
- $('.geo_status_wrapper .geo_status').text(error);
+ form.find('.geo_status_wrapper').removeClass('success').addClass('error');
+ form.find('.geo_status_wrapper .geo_status').text(error);
} else {
- $('.geo_status_wrapper').remove();
+ form.find('.geo_status_wrapper').remove();
}
}
function getJSONgeocodeURL(geocodeURL, data) {
- SN.U.NoticeGeoStatus('Looking up place name...');
+ SN.U.NoticeGeoStatus(form, 'Looking up place name...');
$.getJSON(geocodeURL, data, function(location) {
var lns, lid;
if (typeof(location.location_ns) != 'undefined') {
- $('#'+SN.C.S.NoticeLocationNs).val(location.location_ns);
+ form.find('[name=location_ns]').val(location.location_ns);
lns = location.location_ns;
}
if (typeof(location.location_id) != 'undefined') {
- $('#'+SN.C.S.NoticeLocationId).val(location.location_id);
+ form.find('[name=location_id]').val(location.location_id);
lid = location.location_id;
}
NLN_text = location.name;
}
- SN.U.NoticeGeoStatus(NLN_text, data.lat, data.lon, location.url);
- $('label[for='+SN.C.S.NoticeDataGeo+']')
+ SN.U.NoticeGeoStatus(form, NLN_text, data.lat, data.lon, location.url);
+ label
.attr('title', NoticeDataGeo_text.ShareDisable + ' (' + NLN_text + ')');
- $('.form_notice [name=lat]').val(data.lat);
- $('.form_notice [name=lon]').val(data.lon);
- $('.form_notice [name=location_ns]').val(lns);
- $('.form_notice [name=location_id]').val(lid);
- $('#'+SN.C.S.NoticeDataGeo).attr('checked', true);
+ form.find('[name=lat]').val(data.lat);
+ form.find('[name=lon]').val(data.lon);
+ form.find('[name=location_ns]').val(lns);
+ form.find('[name=location_id]').val(lid);
+ form.find('[name=notice_data-geo]').attr('checked', true);
var cookieValue = {
NLat: data.lat,
});
}
- if (NDGe.length > 0) {
+ if (check.length > 0) {
if ($.cookie(SN.C.S.NoticeDataGeoCookie) == 'disabled') {
- NDGe.attr('checked', false);
+ check.attr('checked', false);
}
else {
- NDGe.attr('checked', true);
+ check.attr('checked', true);
}
- var NGW = $('#notice_data-geo_wrap');
+ var NGW = form.find('.notice_data-geo_wrap');
var geocodeURL = NGW.attr('title');
NGW.removeAttr('title');
- $('label[for='+SN.C.S.NoticeDataGeo+']')
- .attr('title', jQuery.trim($('label[for='+SN.C.S.NoticeDataGeo+']').text()));
+ label
+ .attr('title', label.text());
- NDGe.change(function() {
- if ($('#'+SN.C.S.NoticeDataGeo).attr('checked') === true || $.cookie(SN.C.S.NoticeDataGeoCookie) === null) {
- $('label[for='+SN.C.S.NoticeDataGeo+']')
+ check.change(function() {
+ if (check.attr('checked') === true || $.cookie(SN.C.S.NoticeDataGeoCookie) === null) {
+ label
.attr('title', NoticeDataGeo_text.ShareDisable)
.addClass('checked');
if ($.cookie(SN.C.S.NoticeDataGeoCookie) === null || $.cookie(SN.C.S.NoticeDataGeoCookie) == 'disabled') {
if (navigator.geolocation) {
- SN.U.NoticeGeoStatus('Requesting location from browser...');
+ SN.U.NoticeGeoStatus(form, 'Requesting location from browser...');
navigator.geolocation.getCurrentPosition(
function(position) {
- $('.form_notice [name=lat]').val(position.coords.latitude);
- $('.form_notice [name=lon]').val(position.coords.longitude);
+ form.find('[name=lat]').val(position.coords.latitude);
+ form.find('[name=lon]').val(position.coords.longitude);
var data = {
lat: position.coords.latitude,
}
else {
removeNoticeDataGeo();
- $('#'+SN.C.S.NoticeDataGeo).remove();
- $('label[for='+SN.C.S.NoticeDataGeo+']').remove();
+ check.remove();
+ label.remove();
}
}
}
else {
var cookieValue = JSON.parse($.cookie(SN.C.S.NoticeDataGeoCookie));
- $('.form_notice [name=lat]').val(cookieValue.NLat);
- $('.form_notice [name=lon]').val(cookieValue.NLon);
- $('.form_notice [name=location_ns]').val(cookieValue.NLNS);
- $('.form_notice [name=location_id]').val(cookieValue.NLID);
- $('#'+SN.C.S.NoticeDataGeo).attr('checked', cookieValue.NDG);
+ form.find('[name=lat]').val(cookieValue.NLat);
+ form.find('[name=lon]').val(cookieValue.NLon);
+ form.find('[name=location_ns]').val(cookieValue.NLNS);
+ form.find('[name=location_id]').val(cookieValue.NLID);
+ form.find('[name=notice_data-geo]').attr('checked', cookieValue.NDG);
- SN.U.NoticeGeoStatus(cookieValue.NLN, cookieValue.NLat, cookieValue.NLon, cookieValue.NLNU);
- $('label[for='+SN.C.S.NoticeDataGeo+']')
+ SN.U.NoticeGeoStatus(form, cookieValue.NLN, cookieValue.NLat, cookieValue.NLon, cookieValue.NLNU);
+ label
.attr('title', NoticeDataGeo_text.ShareDisable + ' (' + cookieValue.NLN + ')')
.addClass('checked');
}
/**
* Create or update a geolocation status widget in this notice posting form.
*
+ * @param {jQuery} form
* @param {String} status
* @param {String} lat (optional)
* @param {String} lon (optional)
* @param {String} url (optional)
*/
- NoticeGeoStatus: function(status, lat, lon, url)
+ NoticeGeoStatus: function(form, status, lat, lon, url)
{
- var form = $('#form_notice');
var wrapper = form.find('.geo_status_wrapper');
if (wrapper.length == 0) {
wrapper = $('<div class="'+SN.C.S.Success+' geo_status_wrapper"><button class="close" style="float:right">×</button><div class="geo_status"></div></div>');
wrapper.find('button.close').click(function() {
- $('#'+SN.C.S.NoticeDataGeo).removeAttr('checked').change();
+ form.find('[name=notice_data-geo]').removeAttr('checked').change();
});
form.append(wrapper);
}
*/
NoticeForm: function() {
if ($('body.user_in').length > 0) {
- SN.U.NoticeLocationAttach();
-
$('.'+SN.C.S.FormNotice).each(function() {
- SN.U.FormNoticeXHR($(this));
- SN.U.FormNoticeEnhancements($(this));
- SN.U.NoticeDataAttach($(this));
+ var form = $(this);
+ SN.U.NoticeLocationAttach(form);
+ SN.U.FormNoticeXHR(form);
+ SN.U.FormNoticeEnhancements(form);
+ SN.U.NoticeDataAttach(form);
});
}
},