Moved JavaScript dependant stuff out of noticeform.
This commit is contained in:
parent
e84bf0aa98
commit
dde6415a6a
29
js/util.js
29
js/util.js
|
@ -440,8 +440,20 @@ var SN = { // StatusNet
|
|||
NoticeLocationAttach: function() {
|
||||
if ($('#notice_data-location_enabled').length > 0) {
|
||||
if (navigator.geolocation) {
|
||||
$('#notice_data-location_enabled').change(function() {
|
||||
var NLE = $('#notice_data-location_wrap');
|
||||
var geocodeURL = NLE.attr('title');
|
||||
|
||||
NLE.change(function() {
|
||||
NLE.removeAttr('title');
|
||||
|
||||
$.cookie(SN.C.S.NoticeLocationCookieName, $('#notice_data-location_enabled').attr('checked'));
|
||||
|
||||
var NLN = $('#'+SN.C.S.NoticeLocationName);
|
||||
if (NLN.length > 0) {
|
||||
NLN.remove();
|
||||
}
|
||||
|
||||
NLE.append('<span id="'+SN.C.S.NoticeLocationName+'">Geo</span>');
|
||||
NLN = $('#'+SN.C.S.NoticeLocationName);
|
||||
|
||||
if ($('#notice_data-location_enabled').attr('checked') === true) {
|
||||
|
@ -458,8 +470,9 @@ var SN = { // StatusNet
|
|||
'token': $('#token').val()
|
||||
};
|
||||
|
||||
$.getJSON($('#notice_data-location_enabled_container').attr('data-geocode-url'), data, function(location) {
|
||||
NLN.removeClass('processing');
|
||||
$.getJSON(geocodeURL, data, function(location) {
|
||||
NLN.replaceWith('<a id="notice_data-location_name"/>');
|
||||
NLN = $('#'+SN.C.S.NoticeLocationName);
|
||||
|
||||
if (typeof(location.location_ns) != 'undefined') {
|
||||
$('#'+SN.C.S.NoticeLocationNs).val(location.location_ns);
|
||||
|
@ -470,12 +483,14 @@ var SN = { // StatusNet
|
|||
}
|
||||
|
||||
if (typeof(location.name) == 'undefined') {
|
||||
NLN.text(position.coords.latitude + ';' + position.coords.longitude);
|
||||
NLN_text = position.coords.latitude + ';' + position.coords.longitude;
|
||||
}
|
||||
else {
|
||||
NLN.text(location.name);
|
||||
NLN.attr('href',location.url);
|
||||
NLN_text = location.name;
|
||||
}
|
||||
|
||||
NLN.attr('href', location.url);
|
||||
NLN.text(NLN_text);
|
||||
});
|
||||
});
|
||||
}
|
||||
|
@ -490,7 +505,7 @@ var SN = { // StatusNet
|
|||
|
||||
var cookieVal = $.cookie(SN.C.S.NoticeLocationCookieName);
|
||||
$('#notice_data-location_enabled').attr('checked',(cookieVal == null || cookieVal == 'true'));
|
||||
$('#notice_data-location_enabled').change();
|
||||
NLE.change();
|
||||
}
|
||||
}
|
||||
},
|
||||
|
|
|
@ -207,9 +207,9 @@ class NoticeForm extends Form
|
|||
$this->out->hidden('notice_data-location_id', empty($this->location_id) ? (empty($this->profile->location_id) ? null : $this->profile->location_id) : $this->location_id, 'location_id');
|
||||
$this->out->hidden('notice_data-location_ns', empty($this->location_ns) ? (empty($this->profile->location_ns) ? null : $this->profile->location_ns) : $this->location_ns, 'location_ns');
|
||||
|
||||
$this->out->elementStart('div',array('id' => 'notice_data-location_enabled_container', 'data-geocode-url' => common_local_url('geocode')));
|
||||
$this->out->elementStart('div', array('id' => 'notice_data-location_wrap',
|
||||
'title' => common_local_url('geocode')));
|
||||
$this->out->checkbox('notice_data-location_enabled', _('Share your location'), true);
|
||||
$this->out->element('a', array('id' => 'notice_data-location_name'), _('Finding your location...'));
|
||||
$this->out->elementEnd('div');
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue
Block a user