You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
761 lines
17 KiB
761 lines
17 KiB
13 years ago
|
/*
|
||
|
*
|
||
12 years ago
|
* Weather extension for GNOME Shell preferences
|
||
|
* - Creates a widget to set the preferences of the weather extension
|
||
13 years ago
|
*
|
||
|
* Copyright (C) 2012
|
||
12 years ago
|
* Canek Peláez <canek@ciencias.unam.mx>,
|
||
|
* Christian METZLER <neroth@xeked.com>,
|
||
13 years ago
|
*
|
||
|
* This file is part of gnome-shell-extension-weather.
|
||
|
*
|
||
12 years ago
|
* gnome-shell-extension-weather is free software: you can
|
||
|
* redistribute it and/or modify it under the terms of the GNU
|
||
|
* General Public License as published by the Free Software
|
||
|
* Foundation, either version 3 of the License, or (at your option)
|
||
|
* any later version.
|
||
13 years ago
|
*
|
||
12 years ago
|
* gnome-shell-extension-weather is distributed in the hope that it
|
||
|
* will be useful, but WITHOUT ANY WARRANTY; without even the
|
||
|
* implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
|
||
|
* PURPOSE. See the GNU General Public License for more details.
|
||
13 years ago
|
*
|
||
|
* You should have received a copy of the GNU General Public License
|
||
12 years ago
|
* along with gnome-shell-extension-weather. If not, see
|
||
|
* <http://www.gnu.org/licenses/>.
|
||
13 years ago
|
*
|
||
|
*/
|
||
|
|
||
|
const Gtk = imports.gi.Gtk;
|
||
|
const GObject = imports.gi.GObject;
|
||
12 years ago
|
const GtkBuilder = Gtk.Builder;
|
||
13 years ago
|
const Gio = imports.gi.Gio;
|
||
12 years ago
|
const Gettext = imports.gettext.domain('gnome-shell-extension-weather');
|
||
13 years ago
|
const _ = Gettext.gettext;
|
||
13 years ago
|
const Soup = imports.gi.Soup;
|
||
13 years ago
|
|
||
12 years ago
|
const Lang = imports.lang;
|
||
|
const ExtensionUtils = imports.misc.extensionUtils;
|
||
|
const Me = ExtensionUtils.getCurrentExtension();
|
||
|
const Convenience = Me.imports.convenience;
|
||
|
|
||
|
const EXTENSIONDIR = Me.dir.get_path();
|
||
|
|
||
13 years ago
|
const WEATHER_SETTINGS_SCHEMA = 'org.gnome.shell.extensions.weather';
|
||
|
const WEATHER_UNIT_KEY = 'unit';
|
||
13 years ago
|
const WEATHER_PRESSURE_UNIT_KEY = 'pressure-unit';
|
||
13 years ago
|
const WEATHER_WIND_SPEED_UNIT_KEY = 'wind-speed-unit';
|
||
13 years ago
|
const WEATHER_WIND_DIRECTION_KEY = 'wind-direction';
|
||
13 years ago
|
const WEATHER_CITY_KEY = 'city';
|
||
|
const WEATHER_ACTUAL_CITY_KEY = 'actual-city';
|
||
|
const WEATHER_TRANSLATE_CONDITION_KEY = 'translate-condition';
|
||
|
const WEATHER_USE_SYMBOLIC_ICONS_KEY = 'use-symbolic-icons';
|
||
|
const WEATHER_SHOW_TEXT_IN_PANEL_KEY = 'show-text-in-panel';
|
||
|
const WEATHER_POSITION_IN_PANEL_KEY = 'position-in-panel';
|
||
|
const WEATHER_SHOW_COMMENT_IN_PANEL_KEY = 'show-comment-in-panel';
|
||
|
const WEATHER_REFRESH_INTERVAL = 'refresh-interval';
|
||
|
|
||
13 years ago
|
// Soup session (see https://bugzilla.gnome.org/show_bug.cgi?id=661323#c64) (Simon Legner)
|
||
|
const _httpSession = new Soup.SessionAsync();
|
||
|
Soup.Session.prototype.add_feature.call(_httpSession, new Soup.ProxyResolverDefault());
|
||
|
|
||
12 years ago
|
const Window = new Gtk.Builder();
|
||
|
Window.add_from_file(EXTENSIONDIR+"/weather-settings.ui");
|
||
|
const MainWidget = Window.get_object("main-widget");
|
||
|
const treeview = Window.get_object("tree-treeview");
|
||
|
const liststore = Window.get_object("liststore");
|
||
|
const Iter = liststore.get_iter_first();
|
||
|
let mCities = null;
|
||
|
|
||
|
const PrefsWidget = new GObject.Class(
|
||
13 years ago
|
{
|
||
12 years ago
|
Name: 'WeatherExtension.Prefs.Widget',
|
||
|
GTypeName: 'WeatherExtensionPrefsWidget',
|
||
|
Extends: Gtk.Box,
|
||
13 years ago
|
|
||
12 years ago
|
_init: function(params)
|
||
|
{
|
||
|
this.parent(params);
|
||
13 years ago
|
|
||
12 years ago
|
this.initWindow();
|
||
13 years ago
|
|
||
12 years ago
|
this.refreshUI();
|
||
13 years ago
|
|
||
12 years ago
|
this.add(MainWidget);
|
||
|
},
|
||
13 years ago
|
|
||
12 years ago
|
initWindow : function()
|
||
|
{
|
||
|
let that = this;
|
||
|
|
||
|
Window.get_object("tree-toolbutton-add").connect("clicked",function()
|
||
|
{
|
||
|
that.addCity();
|
||
|
});
|
||
|
|
||
|
Window.get_object("tree-toolbutton-remove").connect("clicked",function()
|
||
|
{
|
||
|
that.removeCity();
|
||
|
});
|
||
|
|
||
|
Window.get_object("treeview-selection").connect("changed",function(selection)
|
||
|
{
|
||
|
that.selectionChanged(selection);
|
||
|
});
|
||
|
|
||
|
treeview.set_model(liststore);
|
||
|
|
||
|
let column = new Gtk.TreeViewColumn()
|
||
|
treeview.append_column(column);
|
||
|
|
||
|
let renderer = new Gtk.CellRendererText();
|
||
|
column.pack_start(renderer,null);
|
||
|
|
||
|
column.set_cell_data_func(renderer,function()
|
||
|
{
|
||
|
arguments[1].markup = arguments[2].get_value(arguments[3],0);
|
||
|
});
|
||
|
|
||
|
this.initConfigWidget();
|
||
|
this.addLabel(_("Temperature Unit"));
|
||
|
this.addComboBox(["\u00b0C","\u00b0F","K","\u00b0Ra","\u00b0R\u00E9","\u00b0R\u00F8","\u00b0De","\u00b0N"],"units");
|
||
|
this.addLabel(_("Wind Speed Unit"));
|
||
|
this.addComboBox(["km/h","mph","m/s","kn","ft/s","Beaufort"],"wind_speed_unit");
|
||
|
this.addLabel(_("Pressure Unit"));
|
||
|
this.addComboBox(["hPa","inHg","bar","Pa","kPa","atm","at","Torr","psi"],"pressure_unit");
|
||
|
this.addLabel(_("Position in Panel"));
|
||
|
this.addComboBox([_("Center"),_("Right"),_("Left")],"position_in_panel");
|
||
|
this.addLabel(_("Wind Direction by Arrows"));
|
||
|
this.addSwitch("wind_direction");
|
||
|
this.addLabel(_("Translate Conditions"));
|
||
|
this.addSwitch("translate_condition");
|
||
|
this.addLabel(_("Symbolic Icons"));
|
||
|
this.addSwitch("icon_type");
|
||
|
this.addLabel(_("Temperature in Panel"));
|
||
|
this.addSwitch("text_in_panel");
|
||
|
this.addLabel(_("Conditions in Panel"));
|
||
|
this.addSwitch("comment_in_panel");
|
||
|
},
|
||
|
|
||
|
refreshUI : function()
|
||
|
{
|
||
|
Window.get_object("tree-toolbutton-remove").sensitive = Boolean(this.city.length);
|
||
|
|
||
|
if(mCities != this.city)
|
||
|
{
|
||
|
if(typeof liststore != "undefined")
|
||
|
liststore.clear();
|
||
|
|
||
|
if(this.city.length > 0)
|
||
|
{
|
||
|
let city = String(this.city).split(" && ");
|
||
|
|
||
|
if(city && typeof city == "string")
|
||
|
city = [city];
|
||
|
|
||
|
let current = liststore.get_iter_first();
|
||
|
|
||
|
for(let i in city)
|
||
|
{
|
||
|
current = liststore.append();
|
||
|
liststore.set_value(current, 0, this.extractLocation(city[i]));
|
||
|
}
|
||
|
}
|
||
|
|
||
|
mCities = this.city;
|
||
|
}
|
||
|
|
||
|
this.changeSelection();
|
||
|
|
||
|
let config = this.configWidgets;
|
||
|
for(let i in config)
|
||
|
if(config[i][0].active != this[config[i][1]])
|
||
|
config[i][0].active = this[config[i][1]];
|
||
|
},
|
||
|
|
||
|
initConfigWidget : function()
|
||
|
{
|
||
|
let a = Window.get_object("right-widget-table");
|
||
|
a.visible = 1;
|
||
|
a.can_focus = 0;
|
||
|
this.widget = a;
|
||
|
},
|
||
|
|
||
|
x : [0,1],
|
||
|
|
||
|
y : [0,1],
|
||
|
|
||
|
configWidgets : [],
|
||
|
|
||
|
inc : function()
|
||
|
{
|
||
|
if(this.x[0] == 1)
|
||
|
{
|
||
|
this.x[0] = 0;
|
||
|
this.x[1] = 1;
|
||
|
this.y[0] += 1;
|
||
|
this.y[1] += 1;
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
this.x[0] += 1;
|
||
|
this.x[1] += 1;
|
||
|
}
|
||
|
},
|
||
|
|
||
|
addLabel : function(text)
|
||
|
{
|
||
|
let l = new Gtk.Label({label:text,xalign:0});
|
||
|
l.visible = 1;
|
||
|
l.can_focus = 0;
|
||
|
this.widget.attach(l, this.x[0],this.x[1], this.y[0],this.y[1],0,0,0,0);
|
||
|
this.inc();
|
||
|
},
|
||
|
|
||
|
addComboBox : function(a,b)
|
||
|
{
|
||
|
let that = this;
|
||
|
let cf = new Gtk.ComboBoxText();
|
||
|
this.configWidgets.push([cf,b]);
|
||
|
cf.visible = 1;
|
||
|
cf.can_focus = 0;
|
||
|
cf.width_request = 100;
|
||
|
for(let i in a)
|
||
|
cf.append_text(a[i]);
|
||
|
cf.active = this[b];
|
||
|
cf.connect("changed",function(){that[b] = arguments[0].active;});
|
||
|
this.widget.attach(cf, this.x[0],this.x[1], this.y[0],this.y[1],0,0,0,0);
|
||
|
this.inc();
|
||
|
},
|
||
|
|
||
|
addSwitch : function(a)
|
||
|
{
|
||
|
let that = this;
|
||
|
let sw = new Gtk.Switch();
|
||
|
this.configWidgets.push([sw,a]);
|
||
|
sw.visible = 1;
|
||
|
sw.can_focus = 0;
|
||
|
sw.active = this[a];
|
||
|
sw.connect("notify::active",function(){that[a] = arguments[0].active;});
|
||
|
this.widget.attach(sw, this.x[0],this.x[1], this.y[0],this.y[1],0,0,0,0);
|
||
|
this.inc();
|
||
|
},
|
||
|
|
||
|
selectionChanged : function(select)
|
||
|
{
|
||
|
let a = select.get_selected_rows(liststore)[0][0];
|
||
|
|
||
|
if(typeof a != "undefined")
|
||
|
if(this.actual_city != parseInt(a.to_string()))
|
||
|
this.actual_city = parseInt(a.to_string());
|
||
|
},
|
||
13 years ago
|
|
||
|
addCity : function()
|
||
|
{
|
||
12 years ago
|
let that = this;
|
||
|
let textDialog = _("Name of the city");
|
||
|
let dialog = new Gtk.Dialog({title : ""});
|
||
|
let entry = new Gtk.Entry();
|
||
|
let completion = new Gtk.EntryCompletion();
|
||
13 years ago
|
entry.set_completion(completion);
|
||
12 years ago
|
let completionModel = new Gtk.ListStore.new([GObject.TYPE_STRING]);
|
||
13 years ago
|
completion.set_model(completionModel);
|
||
|
completion.set_text_column(0);
|
||
12 years ago
|
completion.set_popup_single_match(true);
|
||
|
completion.set_minimum_key_length(1);
|
||
12 years ago
|
completion.set_match_func(function(completion,key,iter)
|
||
|
{
|
||
|
if(iter)
|
||
|
{
|
||
|
if(completionModel.get_value(iter,0))
|
||
|
return true;
|
||
|
}
|
||
|
return false;
|
||
|
});
|
||
13 years ago
|
entry.margin_top = 12;
|
||
|
entry.margin_bottom = 12;
|
||
12 years ago
|
let label = new Gtk.Label({label : textDialog});
|
||
13 years ago
|
|
||
|
dialog.set_border_width(12);
|
||
|
dialog.set_modal(1);
|
||
|
dialog.set_resizable(0);
|
||
12 years ago
|
//dialog.set_transient_for(***** Need parent Window *****);
|
||
13 years ago
|
|
||
|
dialog.add_button(Gtk.STOCK_CANCEL, 0);
|
||
12 years ago
|
let d = dialog.add_button(Gtk.STOCK_OK, 1);
|
||
13 years ago
|
|
||
|
d.set_can_default(true);
|
||
13 years ago
|
d.sensitive = 0;
|
||
|
|
||
13 years ago
|
dialog.set_default(d);
|
||
|
entry.activates_default = true;
|
||
|
|
||
12 years ago
|
let testLocation = function(location)
|
||
13 years ago
|
{
|
||
12 years ago
|
if(location.search(/\[/) == -1 || location.search(/\]/) == -1)
|
||
|
return 0;
|
||
|
|
||
12 years ago
|
let woeid = location.split(/\[/)[1].split(/\]/)[0];
|
||
12 years ago
|
if(!woeid)
|
||
|
return 0;
|
||
|
|
||
12 years ago
|
that.loadJsonAsync(encodeURI('http://query.yahooapis.com/v1/public/yql?q=select woeid from geo.places where woeid = "'+woeid+'" limit 1&format=json'),function()
|
||
13 years ago
|
{
|
||
|
d.sensitive = 0;
|
||
13 years ago
|
if(typeof arguments[0].query == "undefined")
|
||
|
return 0;
|
||
12 years ago
|
|
||
12 years ago
|
let city = arguments[0].query;
|
||
13 years ago
|
if(Number(city.count) == 0)
|
||
13 years ago
|
return 0;
|
||
12 years ago
|
|
||
13 years ago
|
d.sensitive = 1;
|
||
12 years ago
|
return 0;
|
||
|
},"testLocation");
|
||
|
return 0;
|
||
13 years ago
|
};
|
||
|
|
||
12 years ago
|
let searchLocation = function()
|
||
13 years ago
|
{
|
||
12 years ago
|
let location = entry.get_text();
|
||
12 years ago
|
if(testLocation(location) == 0)
|
||
|
that.loadJsonAsync(encodeURI('http://query.yahooapis.com/v1/public/yql?q=select woeid,name,admin1,country from geo.places where text = "*'+location+'*" or text = "'+location+'"&format=json'),function()
|
||
13 years ago
|
{
|
||
13 years ago
|
if(!arguments[0])
|
||
|
return 0;
|
||
12 years ago
|
let city = arguments[0].query;
|
||
|
let n = Number(city.count);
|
||
13 years ago
|
if(n > 0)
|
||
13 years ago
|
city = city.results.place;
|
||
|
else
|
||
|
return 0;
|
||
|
completionModel.clear();
|
||
13 years ago
|
|
||
12 years ago
|
let current = liststore.get_iter_first();
|
||
|
|
||
13 years ago
|
if(n > 1)
|
||
13 years ago
|
{
|
||
|
for(var i in city)
|
||
|
{
|
||
|
if(typeof m == "undefined")
|
||
|
var m = {};
|
||
12 years ago
|
|
||
|
current = completionModel.append();
|
||
|
let cityText = city[i].name;
|
||
13 years ago
|
if(city[i].admin1)
|
||
|
cityText += ", "+city[i].admin1.content;
|
||
|
|
||
|
if(city[i].country)
|
||
12 years ago
|
cityText += " ("+city[i].country.code+")";
|
||
|
|
||
|
cityText += " ["+city[i].woeid+"]";
|
||
13 years ago
|
|
||
13 years ago
|
if(m[cityText])
|
||
|
continue;
|
||
|
else
|
||
|
m[cityText] = 1;
|
||
12 years ago
|
|
||
13 years ago
|
completionModel.set_value(current,0,cityText);
|
||
|
}
|
||
|
}
|
||
|
else
|
||
|
{
|
||
12 years ago
|
current = completionModel.append();
|
||
|
let cityText = city.name;
|
||
13 years ago
|
if(city.admin1)
|
||
|
cityText += ", "+city.admin1.content;
|
||
|
|
||
|
if(city.country)
|
||
12 years ago
|
cityText += " ("+city.country.code+")";
|
||
|
|
||
|
cityText += " ["+city.woeid+"]";
|
||
13 years ago
|
completionModel.set_value(current,0,cityText);
|
||
|
}
|
||
12 years ago
|
completion.complete();
|
||
|
return 0;
|
||
13 years ago
|
},"getInfo");
|
||
13 years ago
|
return 0;
|
||
12 years ago
|
};
|
||
13 years ago
|
|
||
12 years ago
|
entry.connect("changed",searchLocation);
|
||
|
|
||
|
let dialog_area = dialog.get_content_area();
|
||
|
dialog_area.pack_start(label,0,0,0);
|
||
|
dialog_area.pack_start(entry,0,0,0);
|
||
|
dialog.connect("response",function(w, response_id) {
|
||
13 years ago
|
if(response_id)
|
||
13 years ago
|
{
|
||
12 years ago
|
if(entry.get_text().search(/\[/) == -1 || entry.get_text().search(/\]/) == -1)
|
||
|
return 0;
|
||
|
|
||
12 years ago
|
let woeid = entry.get_text().split(/\[/)[1].split(/\]/)[0];
|
||
12 years ago
|
if(!woeid)
|
||
|
return 0;
|
||
|
|
||
|
that.loadJsonAsync(encodeURI('http://query.yahooapis.com/v1/public/yql?format=json&q=select woeid,name,admin1,country from geo.places where woeid = "'+woeid+'" limit 1'),function()
|
||
13 years ago
|
{
|
||
12 years ago
|
let city = arguments[0].query;
|
||
13 years ago
|
if(Number(city.count) > 0)
|
||
13 years ago
|
city = city.results.place;
|
||
|
else
|
||
|
return 0;
|
||
|
|
||
12 years ago
|
let cityText = city.name;
|
||
13 years ago
|
if(city.admin1)
|
||
|
cityText += ", "+city.admin1.content;
|
||
|
|
||
|
if(city.country)
|
||
12 years ago
|
cityText += " ("+city.country.code+")";
|
||
13 years ago
|
|
||
13 years ago
|
if(that.city)
|
||
13 years ago
|
that.city = that.city+" && "+city.woeid+">"+cityText;
|
||
13 years ago
|
else
|
||
13 years ago
|
that.city = city.woeid+">"+cityText;
|
||
12 years ago
|
return 0;
|
||
13 years ago
|
},"lastTest");
|
||
13 years ago
|
}
|
||
13 years ago
|
dialog.hide();
|
||
12 years ago
|
return 0;
|
||
13 years ago
|
});
|
||
|
|
||
|
dialog.show_all();
|
||
|
},
|
||
|
|
||
|
removeCity : function()
|
||
|
{
|
||
12 years ago
|
let that = this;
|
||
|
let city = this.city.split(" && ");
|
||
13 years ago
|
if(!city.length)
|
||
|
return 0;
|
||
12 years ago
|
let ac = this.actual_city;
|
||
|
let textDialog = _("Remove %s ?").replace("%s",this.extractLocation(city[ac]));
|
||
|
let dialog = new Gtk.Dialog({title : ""});
|
||
|
let label = new Gtk.Label({label : textDialog});
|
||
13 years ago
|
label.margin_bottom = 12;
|
||
13 years ago
|
|
||
|
dialog.set_border_width(12);
|
||
|
dialog.set_modal(1);
|
||
|
dialog.set_resizable(0);
|
||
12 years ago
|
//dialog.set_transient_for(***** Need parent Window *****);
|
||
13 years ago
|
|
||
|
dialog.add_button(Gtk.STOCK_NO, 0);
|
||
12 years ago
|
let d = dialog.add_button(Gtk.STOCK_YES, 1);
|
||
13 years ago
|
|
||
|
d.set_can_default(true);
|
||
|
dialog.set_default(d);
|
||
|
|
||
12 years ago
|
let dialog_area = dialog.get_content_area();
|
||
|
dialog_area.pack_start(label,0,0,0);
|
||
|
dialog.connect("response",function(w, response_id)
|
||
13 years ago
|
{
|
||
|
if(response_id)
|
||
|
{
|
||
|
if(city.length == 0)
|
||
|
city = [];
|
||
|
|
||
|
if(city.length > 0 && typeof city != "object")
|
||
|
city = [city];
|
||
|
|
||
|
if(city.length > 0)
|
||
|
city.splice(ac,1);
|
||
|
|
||
|
if(city.length > 1)
|
||
|
that.city = city.join(" && ");
|
||
|
else if(city[0])
|
||
|
that.city = city[0];
|
||
|
else
|
||
|
that.city = "";
|
||
|
}
|
||
|
dialog.hide();
|
||
12 years ago
|
return 0;
|
||
13 years ago
|
});
|
||
|
|
||
|
dialog.show_all();
|
||
12 years ago
|
return 0;
|
||
13 years ago
|
},
|
||
|
|
||
|
changeSelection : function()
|
||
|
{
|
||
12 years ago
|
let path = this.actual_city;
|
||
13 years ago
|
if(arguments[0])
|
||
|
path = arguments[0];
|
||
12 years ago
|
path = new Gtk.TreePath.new_from_string(String(path));
|
||
|
treeview.get_selection().select_path(path);
|
||
13 years ago
|
},
|
||
|
|
||
13 years ago
|
loadJsonAsync : function(url, fun, id)
|
||
13 years ago
|
{
|
||
12 years ago
|
let here = this;
|
||
|
let message = new Soup.Message.new('GET', url);
|
||
13 years ago
|
|
||
|
if(typeof this.asyncSession == "undefined")
|
||
|
this.asyncSession = {};
|
||
|
|
||
12 years ago
|
if(typeof this.asyncSession[id] != "undefined" && this.asyncSession[id])
|
||
13 years ago
|
{
|
||
|
_httpSession.abort();
|
||
|
this.asyncSession[id] = 0;
|
||
|
}
|
||
|
|
||
|
this.asyncSession[id] = 1;
|
||
|
_httpSession.queue_message(message, function(_httpSession, message)
|
||
|
{
|
||
12 years ago
|
here.asyncSession[id] = 0;
|
||
13 years ago
|
if(!message.response_body.data)
|
||
|
{
|
||
|
fun.call(here,0);
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
try
|
||
|
{
|
||
12 years ago
|
let jp = JSON.parse(message.response_body.data);
|
||
13 years ago
|
fun.call(here, jp);
|
||
|
}
|
||
|
catch(e)
|
||
|
{
|
||
|
fun.call(here,0);
|
||
|
return 0;
|
||
|
}
|
||
12 years ago
|
return 0;
|
||
13 years ago
|
});
|
||
|
},
|
||
|
|
||
13 years ago
|
loadConfig : function()
|
||
|
{
|
||
12 years ago
|
let that = this;
|
||
|
let schema = WEATHER_SETTINGS_SCHEMA;
|
||
13 years ago
|
if (Gio.Settings.list_schemas().indexOf(schema) == -1)
|
||
|
throw _("Schema \"%s\" not found.").format(schema);
|
||
12 years ago
|
this.Settings = Convenience.getSettings(schema);
|
||
|
this.Settings.connect("changed",function(){that.refreshUI();});
|
||
13 years ago
|
},
|
||
|
|
||
|
get units()
|
||
|
{
|
||
|
if(!this.Settings)
|
||
|
this.loadConfig();
|
||
|
return this.Settings.get_enum(WEATHER_UNIT_KEY);
|
||
|
},
|
||
|
|
||
12 years ago
|
set units(v)
|
||
13 years ago
|
{
|
||
|
if(!this.Settings)
|
||
|
this.loadConfig();
|
||
12 years ago
|
this.Settings.set_enum(WEATHER_UNIT_KEY,v);
|
||
13 years ago
|
},
|
||
|
|
||
13 years ago
|
get pressure_unit()
|
||
|
{
|
||
|
if(!this.Settings)
|
||
|
this.loadConfig();
|
||
|
return this.Settings.get_enum(WEATHER_PRESSURE_UNIT_KEY);
|
||
|
},
|
||
|
|
||
12 years ago
|
set pressure_unit(v)
|
||
13 years ago
|
{
|
||
|
if(!this.Settings)
|
||
|
this.loadConfig();
|
||
12 years ago
|
this.Settings.set_enum(WEATHER_PRESSURE_UNIT_KEY,v);
|
||
13 years ago
|
},
|
||
|
|
||
13 years ago
|
get wind_speed_unit()
|
||
|
{
|
||
|
if(!this.Settings)
|
||
|
this.loadConfig();
|
||
|
return this.Settings.get_enum(WEATHER_WIND_SPEED_UNIT_KEY);
|
||
|
},
|
||
|
|
||
12 years ago
|
set wind_speed_unit(v)
|
||
13 years ago
|
{
|
||
|
if(!this.Settings)
|
||
|
this.loadConfig();
|
||
12 years ago
|
this.Settings.set_enum(WEATHER_WIND_SPEED_UNIT_KEY,v);
|
||
13 years ago
|
},
|
||
|
|
||
|
get wind_direction()
|
||
|
{
|
||
|
if(!this.Settings)
|
||
|
this.loadConfig();
|
||
|
return this.Settings.get_boolean(WEATHER_WIND_DIRECTION_KEY);
|
||
|
},
|
||
|
|
||
12 years ago
|
set wind_direction(v)
|
||
13 years ago
|
{
|
||
|
if(!this.Settings)
|
||
|
this.loadConfig();
|
||
12 years ago
|
return this.Settings.set_boolean(WEATHER_WIND_DIRECTION_KEY,v);
|
||
13 years ago
|
},
|
||
|
|
||
13 years ago
|
get city()
|
||
|
{
|
||
|
if(!this.Settings)
|
||
|
this.loadConfig();
|
||
|
return this.Settings.get_string(WEATHER_CITY_KEY);
|
||
|
},
|
||
|
|
||
12 years ago
|
set city(v)
|
||
13 years ago
|
{
|
||
|
if(!this.Settings)
|
||
|
this.loadConfig();
|
||
12 years ago
|
this.Settings.set_string(WEATHER_CITY_KEY,v);
|
||
13 years ago
|
},
|
||
|
|
||
|
get actual_city()
|
||
|
{
|
||
|
if(!this.Settings)
|
||
|
this.loadConfig();
|
||
12 years ago
|
let a = this.Settings.get_int(WEATHER_ACTUAL_CITY_KEY);
|
||
|
let citys = this.city.split(" && ");
|
||
13 years ago
|
|
||
|
if(citys && typeof citys == "string")
|
||
|
citys = [citys];
|
||
|
|
||
12 years ago
|
let l = citys.length-1;
|
||
13 years ago
|
|
||
|
if(a < 0)
|
||
|
a = 0;
|
||
|
|
||
|
if(l < 0)
|
||
|
l = 0;
|
||
|
|
||
|
if(a > l)
|
||
|
a = l;
|
||
|
|
||
|
return a;
|
||
|
},
|
||
|
|
||
12 years ago
|
set actual_city(a)
|
||
13 years ago
|
{
|
||
|
if(!this.Settings)
|
||
|
this.loadConfig();
|
||
12 years ago
|
let citys = this.city.split(" && ");
|
||
13 years ago
|
|
||
|
if(citys && typeof citys == "string")
|
||
|
citys = [citys];
|
||
|
|
||
12 years ago
|
let l = citys.length-1;
|
||
13 years ago
|
|
||
|
if(a < 0)
|
||
|
a = 0;
|
||
|
|
||
|
if(l < 0)
|
||
|
l = 0;
|
||
|
|
||
|
if(a > l)
|
||
|
a = l;
|
||
|
|
||
|
this.Settings.set_int(WEATHER_ACTUAL_CITY_KEY,a);
|
||
|
},
|
||
|
|
||
|
get translate_condition()
|
||
|
{
|
||
|
if(!this.Settings)
|
||
|
this.loadConfig();
|
||
|
return this.Settings.get_boolean(WEATHER_TRANSLATE_CONDITION_KEY);
|
||
|
},
|
||
|
|
||
12 years ago
|
set translate_condition(v)
|
||
13 years ago
|
{
|
||
|
if(!this.Settings)
|
||
|
this.loadConfig();
|
||
12 years ago
|
this.Settings.set_boolean(WEATHER_TRANSLATE_CONDITION_KEY,v);
|
||
13 years ago
|
},
|
||
|
|
||
|
get icon_type()
|
||
|
{
|
||
|
if(!this.Settings)
|
||
|
this.loadConfig();
|
||
|
return this.Settings.get_boolean(WEATHER_USE_SYMBOLIC_ICONS_KEY);
|
||
|
},
|
||
|
|
||
12 years ago
|
set icon_type(v)
|
||
13 years ago
|
{
|
||
|
if(!this.Settings)
|
||
|
this.loadConfig();
|
||
12 years ago
|
this.Settings.set_boolean(WEATHER_USE_SYMBOLIC_ICONS_KEY,v);
|
||
13 years ago
|
},
|
||
|
|
||
|
get text_in_panel()
|
||
|
{
|
||
|
if(!this.Settings)
|
||
|
this.loadConfig();
|
||
|
return this.Settings.get_boolean(WEATHER_SHOW_TEXT_IN_PANEL_KEY);
|
||
|
},
|
||
|
|
||
12 years ago
|
set text_in_panel(v)
|
||
13 years ago
|
{
|
||
|
if(!this.Settings)
|
||
|
this.loadConfig();
|
||
12 years ago
|
this.Settings.set_boolean(WEATHER_SHOW_TEXT_IN_PANEL_KEY,v);
|
||
13 years ago
|
},
|
||
|
|
||
|
get position_in_panel()
|
||
|
{
|
||
|
if(!this.Settings)
|
||
|
this.loadConfig();
|
||
|
return this.Settings.get_enum(WEATHER_POSITION_IN_PANEL_KEY);
|
||
|
},
|
||
|
|
||
12 years ago
|
set position_in_panel(v)
|
||
13 years ago
|
{
|
||
|
if(!this.Settings)
|
||
|
this.loadConfig();
|
||
12 years ago
|
this.Settings.set_enum(WEATHER_POSITION_IN_PANEL_KEY,v);
|
||
13 years ago
|
},
|
||
|
|
||
|
get comment_in_panel()
|
||
|
{
|
||
|
if(!this.Settings)
|
||
|
this.loadConfig();
|
||
|
return this.Settings.get_boolean(WEATHER_SHOW_COMMENT_IN_PANEL_KEY);
|
||
|
},
|
||
|
|
||
12 years ago
|
set comment_in_panel(v)
|
||
13 years ago
|
{
|
||
|
if(!this.Settings)
|
||
|
this.loadConfig();
|
||
12 years ago
|
this.Settings.set_boolean(WEATHER_SHOW_COMMENT_IN_PANEL_KEY,v);
|
||
13 years ago
|
},
|
||
|
|
||
|
get refresh_interval()
|
||
|
{
|
||
|
if(!this.Settings)
|
||
|
this.loadConfig();
|
||
|
return this.Settings.get_int(WEATHER_REFRESH_INTERVAL);
|
||
|
},
|
||
|
|
||
12 years ago
|
set refresh_interval(v)
|
||
13 years ago
|
{
|
||
|
if(!this.Settings)
|
||
|
this.loadConfig();
|
||
12 years ago
|
this.Settings.set_int(WEATHER_REFRESH_INTERVAL,v);
|
||
13 years ago
|
},
|
||
|
|
||
12 years ago
|
extractLocation : function(a)
|
||
13 years ago
|
{
|
||
12 years ago
|
if(a.search(">") == -1)
|
||
13 years ago
|
return _("Invalid city");
|
||
12 years ago
|
return a.split(">")[1];
|
||
13 years ago
|
},
|
||
|
|
||
12 years ago
|
extractWoeid : function(a)
|
||
13 years ago
|
{
|
||
12 years ago
|
if(a.search(">") == -1)
|
||
13 years ago
|
return 0;
|
||
12 years ago
|
return a.split(">")[0];
|
||
13 years ago
|
}
|
||
12 years ago
|
});
|
||
|
|
||
|
function init()
|
||
|
{
|
||
|
Convenience.initTranslations('gnome-shell-extension-weather');
|
||
|
}
|
||
13 years ago
|
|
||
12 years ago
|
function buildPrefsWidget()
|
||
|
{
|
||
|
let prefs = new PrefsWidget();
|
||
|
prefs.show_all();
|
||
|
return prefs;
|
||
|
}
|