Compare commits
2 Commits
3.19.3
...
wip/csoria
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
6865dbdd1b | ||
|
|
741c84bc41 |
6
.gitignore
vendored
6
.gitignore
vendored
@@ -17,8 +17,10 @@ config.status
|
|||||||
config
|
config
|
||||||
configure
|
configure
|
||||||
data/50-gnome-shell-*.xml
|
data/50-gnome-shell-*.xml
|
||||||
data/org.gnome.Shell.desktop
|
data/gnome-shell.desktop
|
||||||
data/org.gnome.Shell.desktop.in
|
data/gnome-shell.desktop.in
|
||||||
|
data/gnome-shell-wayland.desktop
|
||||||
|
data/gnome-shell-wayland.desktop.in
|
||||||
data/gnome-shell-extension-prefs.desktop
|
data/gnome-shell-extension-prefs.desktop
|
||||||
data/gnome-shell-extension-prefs.desktop.in
|
data/gnome-shell-extension-prefs.desktop.in
|
||||||
data/gnome-shell-theme.gresource
|
data/gnome-shell-theme.gresource
|
||||||
|
|||||||
128
NEWS
128
NEWS
@@ -1,131 +1,3 @@
|
|||||||
3.19.3
|
|
||||||
======
|
|
||||||
* Fix thumbnail scaling in window switcher on HiDPI [Florian; #758676]
|
|
||||||
* Update animated backgrounds on timezone changes [Florian; #758939]
|
|
||||||
* loginDialog: Update user list on user changes [Michael; #758568]
|
|
||||||
* Fix touch interaction on wayland [Carlos; #756748]
|
|
||||||
|
|
||||||
Contributors:
|
|
||||||
Michael Catanzaro, Carlos Garnacho, Kalev Lember, Florian Müllner
|
|
||||||
|
|
||||||
Translations:
|
|
||||||
Daniel Korostil [uk], Muhammet Kara [tr], Dušan Kazik [sk],
|
|
||||||
Baurzhan Muftakhidinov [kk], Marek Černocký [cs]
|
|
||||||
|
|
||||||
3.19.2
|
|
||||||
======
|
|
||||||
* Make gnome-shell DBus activatable [Ray; #741666]
|
|
||||||
* Fix browser plugin crash in Firefox [Carlos; #737932, #757940]
|
|
||||||
* Optionally show battery percentage in system status area [Bastien; #735771]
|
|
||||||
* Misc. bug fixes [Kalev, Florian, Bastien; #757418, #757668, #757779, #757816,
|
|
||||||
#745626, #758220]
|
|
||||||
|
|
||||||
Contributors:
|
|
||||||
Michael Biebl, Michael Catanzaro, Piotr Drąg, Carlos Garcia Campos,
|
|
||||||
Kalev Lember, Florian Müllner, Bastien Nocera, Ray Strode
|
|
||||||
|
|
||||||
Translations:
|
|
||||||
Pedro Albuquerque [pt], liushuyu [zh_CN], Yosef Or Boczko [he],
|
|
||||||
Jiri Grönroos [fi], Kjartan Maraas [nb], GNOME Translation Robot [gd],
|
|
||||||
Daniel Mustieles [es], Marek Černocký [cs], Kristjan SCHMIDT [eo],
|
|
||||||
Stas Solovey [ru]
|
|
||||||
|
|
||||||
3.19.1
|
|
||||||
======
|
|
||||||
* Respect text-scaling factor under wayland [Owen; #756447]
|
|
||||||
* Show the Bluetooth submenu when there were setup devices [Bastien; #723848]
|
|
||||||
* Misc. bug fixes [Florian, Cosimo, Rui, Ray, Owen, Jakub, Bastien;
|
|
||||||
#756697, #756714, #756605, #754814, #738942, #756983, #756925,
|
|
||||||
#757011, #673235, #757150]
|
|
||||||
|
|
||||||
Contributors:
|
|
||||||
Cosimo Cecchi, Rui Matos, Florian Müllner, Bastien Nocera, Jakub Steiner,
|
|
||||||
Ray Strode, Owen W. Taylor
|
|
||||||
|
|
||||||
Translations:
|
|
||||||
Kjartan Maraas [nb], Khaled Hosny [ar], Balázs Meskó [hu],
|
|
||||||
Daniel Șerbănescu [ro], Marek Černocký [cs]
|
|
||||||
|
|
||||||
3.18.1
|
|
||||||
======
|
|
||||||
* Fix screen freezes when a notification is pushed [Carlos; #755425]
|
|
||||||
* Fix overzealous ellipsization in system status menu [Adel, Florian; #708472]
|
|
||||||
* Hide app menu when disabled by setting [Florian; #745919]
|
|
||||||
* Fix lightbox effect when animations are disabled [Rui; #755827]
|
|
||||||
* Do not mark hotplug notifications as critical [Florian; #657923]
|
|
||||||
* Fix icons getting cut off in dash [Florian; #745649]
|
|
||||||
* Animate fullscreen/unfullscreen operations [Cosimo; #707248]
|
|
||||||
* Misc. bug fixes [Florian, Owen; #748919, #674799, #754581]
|
|
||||||
|
|
||||||
Contributors:
|
|
||||||
Emmanuele Bassi, Michael Catanzaro, Cosimo Cecchi, Matthias Clasen,
|
|
||||||
Adel Gadllah, Carlos Garnacho, Ekaterina Gerasimova, Rui Matos,
|
|
||||||
Florian Müllner, Owen W. Taylor
|
|
||||||
|
|
||||||
Translations:
|
|
||||||
Марко Костић [sr], Милош Поповић [sr@latin], Khaled Hosny [ar],
|
|
||||||
Trần Ngọc Quân [vi], Petr Kovar [cs], Alexandre Franke [fr],
|
|
||||||
Fran Dieguez [gl], Anders Jonsson [sv], Piotr Drąg [pl], Dušan Kazik [sk],
|
|
||||||
Milo Casagrande [it], Changwoo Ryu [ko], Stas Solovey [ru],
|
|
||||||
Rafael Fontenelle [pt_BR], Tom Tryfonidis [el], Aurimas Černius [lt],
|
|
||||||
Seán de Búrca [ga], Christian Kirbach [de], Jiri Grönroos [fi],
|
|
||||||
Pedro Albuquerque [pt], Baurzhan Muftakhidinov [kk], Daniel Mustieles [es],
|
|
||||||
Marek Černocký [cs], Ask Hjorth Larsen [da], Inaki Larranaga Murgoitio [eu]
|
|
||||||
|
|
||||||
3.18.0
|
|
||||||
======
|
|
||||||
|
|
||||||
Translations:
|
|
||||||
Sendy Aditya Suryana [id], Kris Thomsen [da], Seán de Búrca [ga],
|
|
||||||
Andika Triwidada [id], Enrico Nicoletto [pt_BR], Anders Jonsson [sv],
|
|
||||||
Rūdolfs Mazurs [lv]
|
|
||||||
|
|
||||||
3.17.92
|
|
||||||
=======
|
|
||||||
* Fix race when loading multiple background animations [Josselin; #741453]
|
|
||||||
|
|
||||||
Contributors:
|
|
||||||
Michael Biebl, Josselin Mouette, Florian Müllner
|
|
||||||
|
|
||||||
Translations:
|
|
||||||
Baurzhan Muftakhidinov [kk], Changwoo Ryu [ko], Christian Kirbach [de],
|
|
||||||
Kjartan Maraas [nb], Jiri Grönroos [fi], Arash Mousavi [fa],
|
|
||||||
Jiro Matsuzawa [ja], Marek Černocký [cs], Milo Casagrande [it]
|
|
||||||
|
|
||||||
3.17.91
|
|
||||||
=======
|
|
||||||
* Fix login screen spinner causing wakeups while VT-switched away
|
|
||||||
[Ray, Rui; #753891]
|
|
||||||
* Fix scrolling of user list on login screen [Florian; #754525]
|
|
||||||
|
|
||||||
Contributors:
|
|
||||||
Piotr Drąg, Rui Matos, Florian Müllner, Ray Strode
|
|
||||||
|
|
||||||
Translations:
|
|
||||||
Dušan Kazik [sk], Jordi Mas [ca], Aurimas Černius [lt], Stas Solovey [ru],
|
|
||||||
Piotr Drąg [pl], Pedro Albuquerque [pt], Daniel Mustieles [es],
|
|
||||||
Chao-Hsiung Liao [zh_TW], Muhammet Kara [tr], Fran Dieguez [gl],
|
|
||||||
Hannie Dumoleyn [nl], Yosef Or Boczko [he], Tom Tryfonidis [el],
|
|
||||||
A S Alam [pa], Balázs Úr [hu], Alexandre Franke [fr], Frédéric Péters [fr]
|
|
||||||
|
|
||||||
3.17.90
|
|
||||||
=======
|
|
||||||
* Avoid caret/focus viewport changes during pointer movement [Rui; #752138]
|
|
||||||
* Match GTK+'s modal dialogs for system modal dialogs [Carlos; #746108]
|
|
||||||
* Refine message list style [Florian; #749958]
|
|
||||||
* Fix type-ahead behavior for backspace and compose key [Rui; #753319, #753320]
|
|
||||||
* Refine the system status menu [Florian; #751377]
|
|
||||||
* Misc. bug fixes and cleanups [Bastien, Ray, Florian, Jakub; #752779, #752739,
|
|
||||||
#741366, #651503, #753064, #753181, #752881]
|
|
||||||
|
|
||||||
Contributors:
|
|
||||||
Rui Matos, Florian Müllner, Bastien Nocera, Carlos Soriano, Jakub Steiner,
|
|
||||||
Ray Strode, Rico Tzschichholz
|
|
||||||
|
|
||||||
Translations:
|
|
||||||
Marek Černocký [cs], Kjartan Maraas [nb], Jordi Mas [ca], Muhammet Kara [tr],
|
|
||||||
Enrico Nicoletto [pt_BR]
|
|
||||||
|
|
||||||
3.17.4
|
3.17.4
|
||||||
======
|
======
|
||||||
* Fix fuzziness of app menu icon [Jakub; #747932]
|
* Fix fuzziness of app menu icon [Jakub; #747932]
|
||||||
|
|||||||
@@ -3,10 +3,7 @@ mozillalibdir = $(BROWSER_PLUGIN_DIR)
|
|||||||
|
|
||||||
mozillalib_LTLIBRARIES = libgnome-shell-browser-plugin.la
|
mozillalib_LTLIBRARIES = libgnome-shell-browser-plugin.la
|
||||||
|
|
||||||
# Browsers can unload and reload the module while browsing, which is not supported by GObject.
|
libgnome_shell_browser_plugin_la_LDFLAGS = -module -avoid-version -no-undefined
|
||||||
# We pass -Wl,-z,nodelete to the linker to ensure the module is never unloaded.
|
|
||||||
# https://bugzilla.gnome.org/show_bug.cgi?id=737932
|
|
||||||
libgnome_shell_browser_plugin_la_LDFLAGS = -module -avoid-version -no-undefined -Wl,-z,nodelete
|
|
||||||
|
|
||||||
libgnome_shell_browser_plugin_la_LIBADD = \
|
libgnome_shell_browser_plugin_la_LIBADD = \
|
||||||
$(BROWSER_PLUGIN_LIBS)
|
$(BROWSER_PLUGIN_LIBS)
|
||||||
|
|||||||
@@ -33,16 +33,20 @@
|
|||||||
#include <json-glib/json-glib.h>
|
#include <json-glib/json-glib.h>
|
||||||
|
|
||||||
#define ORIGIN "extensions.gnome.org"
|
#define ORIGIN "extensions.gnome.org"
|
||||||
#define PLUGIN_NAME "GNOME Shell Integration"
|
#define PLUGIN_NAME "Gnome Shell Integration"
|
||||||
#define PLUGIN_DESCRIPTION "This plugin provides integration with GNOME Shell " \
|
#define PLUGIN_DESCRIPTION "This plugin provides integration with Gnome Shell " \
|
||||||
"for live extension enabling and disabling. " \
|
"for live extension enabling and disabling. " \
|
||||||
"It can be used only by extensions.gnome.org"
|
"It can be used only by extensions.gnome.org"
|
||||||
#define PLUGIN_MIME_STRING "application/x-gnome-shell-integration::GNOME Shell Integration Dummy Content-Type";
|
#define PLUGIN_MIME_STRING "application/x-gnome-shell-integration::Gnome Shell Integration Dummy Content-Type";
|
||||||
|
|
||||||
#define PLUGIN_API_VERSION 5
|
#define PLUGIN_API_VERSION 5
|
||||||
|
|
||||||
#define EXTENSION_DISABLE_VERSION_CHECK_KEY "disable-extension-version-validation"
|
#define EXTENSION_DISABLE_VERSION_CHECK_KEY "disable-extension-version-validation"
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
GDBusProxy *proxy;
|
||||||
|
} PluginData;
|
||||||
|
|
||||||
static NPNetscapeFuncs funcs;
|
static NPNetscapeFuncs funcs;
|
||||||
|
|
||||||
static inline gchar *
|
static inline gchar *
|
||||||
@@ -141,6 +145,121 @@ check_origin_and_protocol (NPP instance)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* =============== public entry points =================== */
|
||||||
|
|
||||||
|
NPError
|
||||||
|
NP_Initialize(NPNetscapeFuncs *pfuncs, NPPluginFuncs *plugin)
|
||||||
|
{
|
||||||
|
/* global initialization routine, called once when plugin
|
||||||
|
is loaded */
|
||||||
|
|
||||||
|
g_debug ("plugin loaded");
|
||||||
|
|
||||||
|
memcpy (&funcs, pfuncs, sizeof (funcs));
|
||||||
|
|
||||||
|
plugin->size = sizeof(NPPluginFuncs);
|
||||||
|
plugin->newp = NPP_New;
|
||||||
|
plugin->destroy = NPP_Destroy;
|
||||||
|
plugin->getvalue = NPP_GetValue;
|
||||||
|
plugin->setwindow = NPP_SetWindow;
|
||||||
|
|
||||||
|
return NPERR_NO_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
NPError
|
||||||
|
NP_Shutdown(void)
|
||||||
|
{
|
||||||
|
return NPERR_NO_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
const char*
|
||||||
|
NP_GetMIMEDescription(void)
|
||||||
|
{
|
||||||
|
return PLUGIN_MIME_STRING;
|
||||||
|
}
|
||||||
|
|
||||||
|
NPError
|
||||||
|
NP_GetValue(void *instance,
|
||||||
|
NPPVariable variable,
|
||||||
|
void *value)
|
||||||
|
{
|
||||||
|
switch (variable) {
|
||||||
|
case NPPVpluginNameString:
|
||||||
|
*(char**)value = PLUGIN_NAME;
|
||||||
|
break;
|
||||||
|
case NPPVpluginDescriptionString:
|
||||||
|
*(char**)value = PLUGIN_DESCRIPTION;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
;
|
||||||
|
}
|
||||||
|
|
||||||
|
return NPERR_NO_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
NPError
|
||||||
|
NPP_New(NPMIMEType mimetype,
|
||||||
|
NPP instance,
|
||||||
|
uint16_t mode,
|
||||||
|
int16_t argc,
|
||||||
|
char **argn,
|
||||||
|
char **argv,
|
||||||
|
NPSavedData *saved)
|
||||||
|
{
|
||||||
|
/* instance initialization function */
|
||||||
|
PluginData *data;
|
||||||
|
GError *error = NULL;
|
||||||
|
|
||||||
|
g_debug ("plugin created");
|
||||||
|
|
||||||
|
if (!check_origin_and_protocol (instance))
|
||||||
|
return NPERR_GENERIC_ERROR;
|
||||||
|
|
||||||
|
data = g_slice_new (PluginData);
|
||||||
|
instance->pdata = data;
|
||||||
|
|
||||||
|
data->proxy = g_dbus_proxy_new_for_bus_sync (G_BUS_TYPE_SESSION,
|
||||||
|
G_DBUS_PROXY_FLAGS_NONE,
|
||||||
|
NULL, /* interface info */
|
||||||
|
"org.gnome.Shell",
|
||||||
|
"/org/gnome/Shell",
|
||||||
|
"org.gnome.Shell.Extensions",
|
||||||
|
NULL, /* GCancellable */
|
||||||
|
&error);
|
||||||
|
if (!data->proxy)
|
||||||
|
{
|
||||||
|
/* ignore error if the shell is not running, otherwise warn */
|
||||||
|
if (error->domain != G_DBUS_ERROR ||
|
||||||
|
error->code != G_DBUS_ERROR_NAME_HAS_NO_OWNER)
|
||||||
|
{
|
||||||
|
g_warning ("Failed to set up Shell proxy: %s", error->message);
|
||||||
|
}
|
||||||
|
g_clear_error (&error);
|
||||||
|
return NPERR_GENERIC_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
g_debug ("plugin created successfully");
|
||||||
|
|
||||||
|
return NPERR_NO_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
NPError
|
||||||
|
NPP_Destroy(NPP instance,
|
||||||
|
NPSavedData **saved)
|
||||||
|
{
|
||||||
|
/* instance finalization function */
|
||||||
|
|
||||||
|
PluginData *data = instance->pdata;
|
||||||
|
|
||||||
|
g_debug ("plugin destroyed");
|
||||||
|
|
||||||
|
g_object_unref (data->proxy);
|
||||||
|
|
||||||
|
g_slice_free (PluginData, data);
|
||||||
|
|
||||||
|
return NPERR_NO_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
/* =================== scripting interface =================== */
|
/* =================== scripting interface =================== */
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
@@ -211,18 +330,45 @@ static NPObject *
|
|||||||
plugin_object_allocate (NPP instance,
|
plugin_object_allocate (NPP instance,
|
||||||
NPClass *klass)
|
NPClass *klass)
|
||||||
{
|
{
|
||||||
PluginObject *obj = (PluginObject *) funcs.memalloc (sizeof (PluginObject));
|
PluginData *data = instance->pdata;
|
||||||
|
PluginObject *obj = g_slice_new0 (PluginObject);
|
||||||
|
|
||||||
memset (obj, 0, sizeof (PluginObject));
|
|
||||||
obj->instance = instance;
|
obj->instance = instance;
|
||||||
|
obj->proxy = g_object_ref (data->proxy);
|
||||||
|
obj->settings = g_settings_new (SHELL_SCHEMA);
|
||||||
|
obj->signal_id = g_signal_connect (obj->proxy, "g-signal",
|
||||||
|
G_CALLBACK (on_shell_signal), obj);
|
||||||
|
|
||||||
return (NPObject*) obj;
|
obj->watch_name_id = g_bus_watch_name (G_BUS_TYPE_SESSION,
|
||||||
|
"org.gnome.Shell",
|
||||||
|
G_BUS_NAME_WATCHER_FLAGS_NONE,
|
||||||
|
on_shell_appeared,
|
||||||
|
NULL,
|
||||||
|
obj,
|
||||||
|
NULL);
|
||||||
|
|
||||||
|
g_debug ("plugin object created");
|
||||||
|
|
||||||
|
return (NPObject*)obj;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
plugin_object_deallocate (NPObject *npobj)
|
plugin_object_deallocate (NPObject *npobj)
|
||||||
{
|
{
|
||||||
funcs.memfree (npobj);
|
PluginObject *obj = (PluginObject*)npobj;
|
||||||
|
|
||||||
|
g_signal_handler_disconnect (obj->proxy, obj->signal_id);
|
||||||
|
g_object_unref (obj->proxy);
|
||||||
|
|
||||||
|
if (obj->listener)
|
||||||
|
funcs.releaseobject (obj->listener);
|
||||||
|
|
||||||
|
if (obj->watch_name_id)
|
||||||
|
g_bus_unwatch_name (obj->watch_name_id);
|
||||||
|
|
||||||
|
g_debug ("plugin object destroyed");
|
||||||
|
|
||||||
|
g_slice_free (PluginObject, obj);
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline gboolean
|
static inline gboolean
|
||||||
@@ -873,149 +1019,6 @@ init_methods_and_properties (void)
|
|||||||
onextension_changed_id = funcs.getstringidentifier ("onchange");
|
onextension_changed_id = funcs.getstringidentifier ("onchange");
|
||||||
}
|
}
|
||||||
|
|
||||||
/* =============== public entry points =================== */
|
|
||||||
|
|
||||||
NPError
|
|
||||||
NP_Initialize(NPNetscapeFuncs *pfuncs, NPPluginFuncs *plugin)
|
|
||||||
{
|
|
||||||
/* global initialization routine, called once when plugin
|
|
||||||
is loaded */
|
|
||||||
|
|
||||||
g_debug ("plugin loaded");
|
|
||||||
|
|
||||||
memcpy (&funcs, pfuncs, sizeof (funcs));
|
|
||||||
|
|
||||||
plugin->size = sizeof(NPPluginFuncs);
|
|
||||||
plugin->newp = NPP_New;
|
|
||||||
plugin->destroy = NPP_Destroy;
|
|
||||||
plugin->getvalue = NPP_GetValue;
|
|
||||||
plugin->setwindow = NPP_SetWindow;
|
|
||||||
plugin->event = NPP_HandleEvent;
|
|
||||||
|
|
||||||
return NPERR_NO_ERROR;
|
|
||||||
}
|
|
||||||
|
|
||||||
NPError
|
|
||||||
NP_Shutdown(void)
|
|
||||||
{
|
|
||||||
return NPERR_NO_ERROR;
|
|
||||||
}
|
|
||||||
|
|
||||||
const char*
|
|
||||||
NP_GetMIMEDescription(void)
|
|
||||||
{
|
|
||||||
return PLUGIN_MIME_STRING;
|
|
||||||
}
|
|
||||||
|
|
||||||
NPError
|
|
||||||
NP_GetValue(void *instance,
|
|
||||||
NPPVariable variable,
|
|
||||||
void *value)
|
|
||||||
{
|
|
||||||
switch (variable) {
|
|
||||||
case NPPVpluginNameString:
|
|
||||||
*(char**)value = PLUGIN_NAME;
|
|
||||||
break;
|
|
||||||
case NPPVpluginDescriptionString:
|
|
||||||
*(char**)value = PLUGIN_DESCRIPTION;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
;
|
|
||||||
}
|
|
||||||
|
|
||||||
return NPERR_NO_ERROR;
|
|
||||||
}
|
|
||||||
|
|
||||||
NPError
|
|
||||||
NPP_New(NPMIMEType mimetype,
|
|
||||||
NPP instance,
|
|
||||||
uint16_t mode,
|
|
||||||
int16_t argc,
|
|
||||||
char **argn,
|
|
||||||
char **argv,
|
|
||||||
NPSavedData *saved)
|
|
||||||
{
|
|
||||||
/* instance initialization function */
|
|
||||||
PluginObject *obj;
|
|
||||||
GError *error = NULL;
|
|
||||||
|
|
||||||
g_debug ("plugin created");
|
|
||||||
|
|
||||||
if (!check_origin_and_protocol (instance))
|
|
||||||
return NPERR_GENERIC_ERROR;
|
|
||||||
|
|
||||||
/* set windowless mode */
|
|
||||||
funcs.setvalue(instance, NPPVpluginWindowBool, NULL);
|
|
||||||
|
|
||||||
g_debug ("creating scriptable object");
|
|
||||||
init_methods_and_properties ();
|
|
||||||
obj = (PluginObject *) funcs.createobject (instance, &plugin_class);
|
|
||||||
instance->pdata = obj;
|
|
||||||
|
|
||||||
obj->proxy = g_dbus_proxy_new_for_bus_sync (G_BUS_TYPE_SESSION,
|
|
||||||
G_DBUS_PROXY_FLAGS_NONE,
|
|
||||||
NULL, /* interface info */
|
|
||||||
"org.gnome.Shell",
|
|
||||||
"/org/gnome/Shell",
|
|
||||||
"org.gnome.Shell.Extensions",
|
|
||||||
NULL, /* GCancellable */
|
|
||||||
&error);
|
|
||||||
if (!obj->proxy)
|
|
||||||
{
|
|
||||||
/* ignore error if the shell is not running, otherwise warn */
|
|
||||||
if (!g_error_matches (error, G_DBUS_ERROR, G_DBUS_ERROR_NAME_HAS_NO_OWNER))
|
|
||||||
{
|
|
||||||
g_warning ("Failed to set up Shell proxy: %s", error->message);
|
|
||||||
}
|
|
||||||
g_clear_error (&error);
|
|
||||||
return NPERR_GENERIC_ERROR;
|
|
||||||
}
|
|
||||||
|
|
||||||
obj->settings = g_settings_new (SHELL_SCHEMA);
|
|
||||||
obj->signal_id = g_signal_connect (obj->proxy, "g-signal",
|
|
||||||
G_CALLBACK (on_shell_signal), obj);
|
|
||||||
obj->watch_name_id = g_bus_watch_name (G_BUS_TYPE_SESSION,
|
|
||||||
"org.gnome.Shell",
|
|
||||||
G_BUS_NAME_WATCHER_FLAGS_NONE,
|
|
||||||
on_shell_appeared,
|
|
||||||
NULL,
|
|
||||||
obj,
|
|
||||||
NULL);
|
|
||||||
|
|
||||||
g_debug ("plugin created successfully");
|
|
||||||
|
|
||||||
return NPERR_NO_ERROR;
|
|
||||||
}
|
|
||||||
|
|
||||||
NPError
|
|
||||||
NPP_Destroy(NPP instance,
|
|
||||||
NPSavedData **saved)
|
|
||||||
{
|
|
||||||
/* instance finalization function */
|
|
||||||
PluginObject *obj = (PluginObject *) instance->pdata;
|
|
||||||
|
|
||||||
if (!obj)
|
|
||||||
return NPERR_INVALID_INSTANCE_ERROR;
|
|
||||||
|
|
||||||
g_debug ("plugin destroyed");
|
|
||||||
|
|
||||||
g_signal_handler_disconnect (obj->proxy, obj->signal_id);
|
|
||||||
g_object_unref (obj->proxy);
|
|
||||||
|
|
||||||
if (obj->listener)
|
|
||||||
funcs.releaseobject (obj->listener);
|
|
||||||
|
|
||||||
if (obj->restart_listener)
|
|
||||||
funcs.releaseobject (obj->restart_listener);
|
|
||||||
|
|
||||||
if (obj->watch_name_id)
|
|
||||||
g_bus_unwatch_name (obj->watch_name_id);
|
|
||||||
|
|
||||||
funcs.releaseobject((NPObject *)obj);
|
|
||||||
|
|
||||||
return NPERR_NO_ERROR;
|
|
||||||
}
|
|
||||||
|
|
||||||
NPError
|
NPError
|
||||||
NPP_GetValue(NPP instance,
|
NPP_GetValue(NPP instance,
|
||||||
NPPVariable variable,
|
NPPVariable variable,
|
||||||
@@ -1026,10 +1029,13 @@ NPP_GetValue(NPP instance,
|
|||||||
switch (variable) {
|
switch (variable) {
|
||||||
case NPPVpluginScriptableNPObject:
|
case NPPVpluginScriptableNPObject:
|
||||||
g_debug ("creating scriptable object");
|
g_debug ("creating scriptable object");
|
||||||
if (!instance->pdata)
|
init_methods_and_properties ();
|
||||||
return NPERR_INVALID_INSTANCE_ERROR;
|
|
||||||
|
|
||||||
*(NPObject**)value = instance->pdata;
|
*(NPObject**)value = funcs.createobject (instance, &plugin_class);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case NPPVpluginNeedsXEmbed:
|
||||||
|
*(bool *)value = TRUE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
@@ -1047,11 +1053,3 @@ NPP_SetWindow(NPP instance,
|
|||||||
{
|
{
|
||||||
return NPERR_NO_ERROR;
|
return NPERR_NO_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
int16_t
|
|
||||||
NPP_HandleEvent(NPP instance,
|
|
||||||
void *event)
|
|
||||||
{
|
|
||||||
/* Ignore the event */
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
|
|||||||
17
configure.ac
17
configure.ac
@@ -1,6 +1,5 @@
|
|||||||
AC_PREREQ(2.63)
|
AC_PREREQ(2.63)
|
||||||
AC_INIT([gnome-shell],[3.19.3],[https://bugzilla.gnome.org/enter_bug.cgi?product=gnome-shell],[gnome-shell])
|
AC_INIT([gnome-shell],[3.17.4],[https://bugzilla.gnome.org/enter_bug.cgi?product=gnome-shell],[gnome-shell])
|
||||||
AX_IS_RELEASE([git-directory])
|
|
||||||
|
|
||||||
AC_CONFIG_HEADERS([config.h])
|
AC_CONFIG_HEADERS([config.h])
|
||||||
AC_CONFIG_SRCDIR([src/shell-global.c])
|
AC_CONFIG_SRCDIR([src/shell-global.c])
|
||||||
@@ -75,13 +74,13 @@ AS_IF([test x$enable_systemd != xno], [
|
|||||||
AC_MSG_RESULT($enable_systemd)
|
AC_MSG_RESULT($enable_systemd)
|
||||||
|
|
||||||
CLUTTER_MIN_VERSION=1.21.5
|
CLUTTER_MIN_VERSION=1.21.5
|
||||||
GOBJECT_INTROSPECTION_MIN_VERSION=1.45.4
|
GOBJECT_INTROSPECTION_MIN_VERSION=0.10.1
|
||||||
GJS_MIN_VERSION=1.39.0
|
GJS_MIN_VERSION=1.39.0
|
||||||
MUTTER_MIN_VERSION=3.19.3
|
MUTTER_MIN_VERSION=3.17.4
|
||||||
GTK_MIN_VERSION=3.15.0
|
GTK_MIN_VERSION=3.15.0
|
||||||
GIO_MIN_VERSION=2.45.3
|
GIO_MIN_VERSION=2.45.3
|
||||||
LIBECAL_MIN_VERSION=3.5.3
|
LIBECAL_MIN_VERSION=3.5.3
|
||||||
LIBEDATASERVER_MIN_VERSION=3.17.2
|
LIBEDATASERVER_MIN_VERSION=3.13.90
|
||||||
TELEPATHY_GLIB_MIN_VERSION=0.17.5
|
TELEPATHY_GLIB_MIN_VERSION=0.17.5
|
||||||
POLKIT_MIN_VERSION=0.100
|
POLKIT_MIN_VERSION=0.100
|
||||||
STARTUP_NOTIFICATION_MIN_VERSION=0.11
|
STARTUP_NOTIFICATION_MIN_VERSION=0.11
|
||||||
@@ -117,9 +116,9 @@ PKG_CHECK_MODULES(GNOME_SHELL_JS, gio-2.0 gjs-internals-1.0 >= $GJS_MIN_VERSION)
|
|||||||
PKG_CHECK_MODULES(ST, clutter-1.0 gtk+-3.0 libcroco-0.6 >= 0.6.8 x11)
|
PKG_CHECK_MODULES(ST, clutter-1.0 gtk+-3.0 libcroco-0.6 >= 0.6.8 x11)
|
||||||
PKG_CHECK_MODULES(SHELL_PERF_HELPER, gtk+-3.0 gio-2.0)
|
PKG_CHECK_MODULES(SHELL_PERF_HELPER, gtk+-3.0 gio-2.0)
|
||||||
PKG_CHECK_MODULES(SHELL_HOTPLUG_SNIFFER, gio-2.0 gdk-pixbuf-2.0)
|
PKG_CHECK_MODULES(SHELL_HOTPLUG_SNIFFER, gio-2.0 gdk-pixbuf-2.0)
|
||||||
PKG_CHECK_MODULES(TRAY, clutter-1.0 gtk+-3.0)
|
PKG_CHECK_MODULES(TRAY, gtk+-3.0)
|
||||||
PKG_CHECK_MODULES(GVC, libpulse >= $PULSE_MIN_VERS libpulse-mainloop-glib gobject-2.0)
|
PKG_CHECK_MODULES(GVC, libpulse >= $PULSE_MIN_VERS libpulse-mainloop-glib gobject-2.0)
|
||||||
PKG_CHECK_MODULES(DESKTOP_SCHEMAS, gsettings-desktop-schemas >= 3.19.2)
|
PKG_CHECK_MODULES(DESKTOP_SCHEMAS, gsettings-desktop-schemas >= 3.13.1)
|
||||||
|
|
||||||
AC_ARG_ENABLE(browser-plugin,
|
AC_ARG_ENABLE(browser-plugin,
|
||||||
[AS_HELP_STRING([--enable-browser-plugin],
|
[AS_HELP_STRING([--enable-browser-plugin],
|
||||||
@@ -221,7 +220,7 @@ if test "$enable_man" != no; then
|
|||||||
fi
|
fi
|
||||||
AM_CONDITIONAL(ENABLE_MAN, test "$enable_man" != no)
|
AM_CONDITIONAL(ENABLE_MAN, test "$enable_man" != no)
|
||||||
|
|
||||||
AX_COMPILER_FLAGS()
|
GNOME_COMPILE_WARNINGS([error])
|
||||||
case "$WARN_CFLAGS" in
|
case "$WARN_CFLAGS" in
|
||||||
*-Werror*)
|
*-Werror*)
|
||||||
WARN_CFLAGS="$WARN_CFLAGS -Wno-error=deprecated-declarations"
|
WARN_CFLAGS="$WARN_CFLAGS -Wno-error=deprecated-declarations"
|
||||||
@@ -270,7 +269,7 @@ Build configuration:
|
|||||||
Prefix: ${prefix}
|
Prefix: ${prefix}
|
||||||
Source code location: ${srcdir}
|
Source code location: ${srcdir}
|
||||||
Compiler: ${CC}
|
Compiler: ${CC}
|
||||||
Compiler Warnings: $ax_enable_compile_warnings
|
Compiler Warnings: $enable_compile_warnings
|
||||||
|
|
||||||
Support for NetworkManager: $have_networkmanager
|
Support for NetworkManager: $have_networkmanager
|
||||||
Support for GStreamer recording: $build_recorder
|
Support for GStreamer recording: $build_recorder
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ CLEANFILES =
|
|||||||
NULL =
|
NULL =
|
||||||
|
|
||||||
desktopdir=$(datadir)/applications
|
desktopdir=$(datadir)/applications
|
||||||
desktop_DATA = org.gnome.Shell.desktop gnome-shell-extension-prefs.desktop
|
desktop_DATA = gnome-shell.desktop gnome-shell-wayland.desktop gnome-shell-extension-prefs.desktop
|
||||||
|
|
||||||
if HAVE_NETWORKMANAGER
|
if HAVE_NETWORKMANAGER
|
||||||
desktop_DATA += org.gnome.Shell.PortalHelper.desktop
|
desktop_DATA += org.gnome.Shell.PortalHelper.desktop
|
||||||
@@ -104,7 +104,8 @@ convertdir = $(datadir)/GConf/gsettings
|
|||||||
convert_DATA = gnome-shell-overrides.convert
|
convert_DATA = gnome-shell-overrides.convert
|
||||||
|
|
||||||
EXTRA_DIST = \
|
EXTRA_DIST = \
|
||||||
org.gnome.Shell.desktop.in.in \
|
gnome-shell.desktop.in.in \
|
||||||
|
gnome-shell-wayland.desktop.in.in \
|
||||||
gnome-shell-extension-prefs.desktop.in.in \
|
gnome-shell-extension-prefs.desktop.in.in \
|
||||||
$(introspection_DATA) \
|
$(introspection_DATA) \
|
||||||
$(menu_DATA) \
|
$(menu_DATA) \
|
||||||
@@ -120,7 +121,8 @@ EXTRA_DIST = \
|
|||||||
$(NULL)
|
$(NULL)
|
||||||
|
|
||||||
CLEANFILES += \
|
CLEANFILES += \
|
||||||
org.gnome.Shell.desktop.in \
|
gnome-shell.desktop.in \
|
||||||
|
gnome-shell-wayland.desktop.in \
|
||||||
gnome-shell-extension-prefs.in \
|
gnome-shell-extension-prefs.in \
|
||||||
$(desktop_DATA) \
|
$(desktop_DATA) \
|
||||||
$(keys_DATA) \
|
$(keys_DATA) \
|
||||||
|
|||||||
15
data/gnome-shell-wayland.desktop.in.in
Normal file
15
data/gnome-shell-wayland.desktop.in.in
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
[Desktop Entry]
|
||||||
|
Type=Application
|
||||||
|
_Name=GNOME Shell (wayland compositor)
|
||||||
|
_Comment=Window management and application launching
|
||||||
|
Exec=@bindir@/gnome-shell --wayland --display-server
|
||||||
|
X-GNOME-Bugzilla-Bugzilla=GNOME
|
||||||
|
X-GNOME-Bugzilla-Product=gnome-shell
|
||||||
|
X-GNOME-Bugzilla-Component=general
|
||||||
|
X-GNOME-Bugzilla-Version=@VERSION@
|
||||||
|
Categories=GNOME;GTK;Core;
|
||||||
|
OnlyShowIn=GNOME;
|
||||||
|
NoDisplay=true
|
||||||
|
X-GNOME-Autostart-Phase=DisplayServer
|
||||||
|
X-GNOME-Autostart-Notify=true
|
||||||
|
X-GNOME-AutoRestart=false
|
||||||
@@ -10,7 +10,7 @@ X-GNOME-Bugzilla-Version=@VERSION@
|
|||||||
Categories=GNOME;GTK;Core;
|
Categories=GNOME;GTK;Core;
|
||||||
OnlyShowIn=GNOME;
|
OnlyShowIn=GNOME;
|
||||||
NoDisplay=true
|
NoDisplay=true
|
||||||
X-GNOME-Autostart-Phase=DisplayServer
|
X-GNOME-Autostart-Phase=WindowManager
|
||||||
X-GNOME-Provides=panel;windowmanager;
|
X-GNOME-Provides=panel;windowmanager;
|
||||||
X-GNOME-Autostart-Notify=true
|
X-GNOME-Autostart-Notify=true
|
||||||
X-GNOME-AutoRestart=false
|
X-GNOME-AutoRestart=false
|
||||||
@@ -72,16 +72,6 @@
|
|||||||
This key sets the default state of the checkbox.
|
This key sets the default state of the checkbox.
|
||||||
</_description>
|
</_description>
|
||||||
</key>
|
</key>
|
||||||
<key name="had-bluetooth-devices-setup" type="b">
|
|
||||||
<default>false</default>
|
|
||||||
<_summary>Whether the default Bluetooth adapter had set up devices associated to it</_summary>
|
|
||||||
<_description>
|
|
||||||
The shell will only show a Bluetooth menu item if a Bluetooth
|
|
||||||
adapter is powered, or if there were devices set up associated
|
|
||||||
with the default adapter. This will be reset if the default
|
|
||||||
adapter is ever seen not to have devices associated to it.
|
|
||||||
</_description>
|
|
||||||
</key>
|
|
||||||
<child name="calendar" schema="org.gnome.shell.calendar"/>
|
<child name="calendar" schema="org.gnome.shell.calendar"/>
|
||||||
<child name="keybindings" schema="org.gnome.shell.keybindings"/>
|
<child name="keybindings" schema="org.gnome.shell.keybindings"/>
|
||||||
<child name="keyboard" schema="org.gnome.shell.keyboard"/>
|
<child name="keyboard" schema="org.gnome.shell.keyboard"/>
|
||||||
|
|||||||
@@ -408,9 +408,9 @@ StScrollBar {
|
|||||||
spacing-rows: 15px;
|
spacing-rows: 15px;
|
||||||
spacing-columns: 1em; }
|
spacing-columns: 1em; }
|
||||||
|
|
||||||
/* Popovers/Menus */
|
/* Popvers/Menus */
|
||||||
.popup-menu {
|
.popup-menu {
|
||||||
min-width: 15em; }
|
min-width: 200px; }
|
||||||
.popup-menu .popup-sub-menu {
|
.popup-menu .popup-sub-menu {
|
||||||
background-color: black;
|
background-color: black;
|
||||||
box-shadow: inset 0 -1px 0px #0d0d0d; }
|
box-shadow: inset 0 -1px 0px #0d0d0d; }
|
||||||
@@ -625,8 +625,6 @@ StScrollBar {
|
|||||||
#panel .panel-status-indicators-box,
|
#panel .panel-status-indicators-box,
|
||||||
#panel .panel-status-menu-box {
|
#panel .panel-status-menu-box {
|
||||||
spacing: 2px; }
|
spacing: 2px; }
|
||||||
#panel .power-status.panel-status-indicators-box {
|
|
||||||
spacing: 0; }
|
|
||||||
#panel .screencast-indicator {
|
#panel .screencast-indicator {
|
||||||
color: #f57900; }
|
color: #f57900; }
|
||||||
|
|
||||||
@@ -754,7 +752,7 @@ StScrollBar {
|
|||||||
|
|
||||||
/* Message list */
|
/* Message list */
|
||||||
.message-list {
|
.message-list {
|
||||||
width: 31.5em; }
|
width: 420px; }
|
||||||
|
|
||||||
.message-list-sections {
|
.message-list-sections {
|
||||||
spacing: 1.5em; }
|
spacing: 1.5em; }
|
||||||
@@ -789,12 +787,7 @@ StScrollBar {
|
|||||||
padding: 8px 8px 8px 0px; }
|
padding: 8px 8px 8px 0px; }
|
||||||
|
|
||||||
.message-icon-bin > StIcon {
|
.message-icon-bin > StIcon {
|
||||||
icon-size: 32px; }
|
icon-size: 48px; }
|
||||||
|
|
||||||
.message-secondary-bin:ltr {
|
|
||||||
padding-left: 8px; }
|
|
||||||
.message-secondary-bin:rtl {
|
|
||||||
padding-right: 8px; }
|
|
||||||
|
|
||||||
.message-secondary-bin {
|
.message-secondary-bin {
|
||||||
color: #999999; }
|
color: #999999; }
|
||||||
@@ -803,20 +796,14 @@ StScrollBar {
|
|||||||
icon-size: 16px; }
|
icon-size: 16px; }
|
||||||
|
|
||||||
.message-title {
|
.message-title {
|
||||||
font-weight: bold;
|
font-weight: bold; }
|
||||||
font-size: 1.1em; }
|
|
||||||
|
|
||||||
.message-content {
|
.message-content {
|
||||||
padding: 8px;
|
padding: 8px; }
|
||||||
font-size: .9em; }
|
|
||||||
|
|
||||||
.system-switch-user-submenu-icon.user-icon {
|
.system-switch-user-submenu-icon {
|
||||||
icon-size: 20px;
|
icon-size: 24px;
|
||||||
padding: 0 2px; }
|
border: 1px solid rgba(255, 255, 255, 0.4); }
|
||||||
|
|
||||||
.system-switch-user-submenu-icon.default-icon {
|
|
||||||
icon-size: 16px;
|
|
||||||
padding: 0 4px; }
|
|
||||||
|
|
||||||
#appMenu {
|
#appMenu {
|
||||||
spinner-image: url("resource:///org/gnome/shell/theme/process-working.svg");
|
spinner-image: url("resource:///org/gnome/shell/theme/process-working.svg");
|
||||||
@@ -825,7 +812,7 @@ StScrollBar {
|
|||||||
color: transparent; }
|
color: transparent; }
|
||||||
|
|
||||||
.aggregate-menu {
|
.aggregate-menu {
|
||||||
min-width: 21em; }
|
width: 360px; }
|
||||||
.aggregate-menu .popup-menu-icon {
|
.aggregate-menu .popup-menu-icon {
|
||||||
padding: 0 4px; }
|
padding: 0 4px; }
|
||||||
|
|
||||||
@@ -962,14 +949,10 @@ StScrollBar {
|
|||||||
.search-entry {
|
.search-entry {
|
||||||
width: 320px;
|
width: 320px;
|
||||||
padding: 7px 9px;
|
padding: 7px 9px;
|
||||||
border-radius: 6px;
|
border-radius: 6px; }
|
||||||
border-color: #747467;
|
|
||||||
color: #eeeeec;
|
|
||||||
background-color: #2e3436; }
|
|
||||||
.search-entry:focus {
|
.search-entry:focus {
|
||||||
padding: 6px 8px;
|
padding: 6px 8px;
|
||||||
border-width: 2px;
|
border-width: 2px; }
|
||||||
border-color: #215d9c; }
|
|
||||||
.search-entry .search-entry-icon {
|
.search-entry .search-entry-icon {
|
||||||
icon-size: 1em;
|
icon-size: 1em;
|
||||||
padding: 0 4px;
|
padding: 0 4px;
|
||||||
|
|||||||
Submodule data/theme/gnome-shell-sass updated: 63e059c923...e0e74382f1
@@ -408,9 +408,9 @@ StScrollBar {
|
|||||||
spacing-rows: 15px;
|
spacing-rows: 15px;
|
||||||
spacing-columns: 1em; }
|
spacing-columns: 1em; }
|
||||||
|
|
||||||
/* Popovers/Menus */
|
/* Popvers/Menus */
|
||||||
.popup-menu {
|
.popup-menu {
|
||||||
min-width: 15em; }
|
min-width: 200px; }
|
||||||
.popup-menu .popup-sub-menu {
|
.popup-menu .popup-sub-menu {
|
||||||
background-color: #343a3a;
|
background-color: #343a3a;
|
||||||
box-shadow: inset 0 -1px 0px #282c2c; }
|
box-shadow: inset 0 -1px 0px #282c2c; }
|
||||||
@@ -625,8 +625,6 @@ StScrollBar {
|
|||||||
#panel .panel-status-indicators-box,
|
#panel .panel-status-indicators-box,
|
||||||
#panel .panel-status-menu-box {
|
#panel .panel-status-menu-box {
|
||||||
spacing: 2px; }
|
spacing: 2px; }
|
||||||
#panel .power-status.panel-status-indicators-box {
|
|
||||||
spacing: 0; }
|
|
||||||
#panel .screencast-indicator {
|
#panel .screencast-indicator {
|
||||||
color: #f57900; }
|
color: #f57900; }
|
||||||
|
|
||||||
@@ -754,7 +752,7 @@ StScrollBar {
|
|||||||
|
|
||||||
/* Message list */
|
/* Message list */
|
||||||
.message-list {
|
.message-list {
|
||||||
width: 31.5em; }
|
width: 420px; }
|
||||||
|
|
||||||
.message-list-sections {
|
.message-list-sections {
|
||||||
spacing: 1.5em; }
|
spacing: 1.5em; }
|
||||||
@@ -789,12 +787,7 @@ StScrollBar {
|
|||||||
padding: 8px 8px 8px 0px; }
|
padding: 8px 8px 8px 0px; }
|
||||||
|
|
||||||
.message-icon-bin > StIcon {
|
.message-icon-bin > StIcon {
|
||||||
icon-size: 32px; }
|
icon-size: 48px; }
|
||||||
|
|
||||||
.message-secondary-bin:ltr {
|
|
||||||
padding-left: 8px; }
|
|
||||||
.message-secondary-bin:rtl {
|
|
||||||
padding-right: 8px; }
|
|
||||||
|
|
||||||
.message-secondary-bin {
|
.message-secondary-bin {
|
||||||
color: #8e8e80; }
|
color: #8e8e80; }
|
||||||
@@ -803,20 +796,14 @@ StScrollBar {
|
|||||||
icon-size: 16px; }
|
icon-size: 16px; }
|
||||||
|
|
||||||
.message-title {
|
.message-title {
|
||||||
font-weight: bold;
|
font-weight: bold; }
|
||||||
font-size: 1.1em; }
|
|
||||||
|
|
||||||
.message-content {
|
.message-content {
|
||||||
padding: 8px;
|
padding: 8px; }
|
||||||
font-size: .9em; }
|
|
||||||
|
|
||||||
.system-switch-user-submenu-icon.user-icon {
|
.system-switch-user-submenu-icon {
|
||||||
icon-size: 20px;
|
icon-size: 24px;
|
||||||
padding: 0 2px; }
|
border: 1px solid rgba(238, 238, 236, 0.4); }
|
||||||
|
|
||||||
.system-switch-user-submenu-icon.default-icon {
|
|
||||||
icon-size: 16px;
|
|
||||||
padding: 0 4px; }
|
|
||||||
|
|
||||||
#appMenu {
|
#appMenu {
|
||||||
spinner-image: url("resource:///org/gnome/shell/theme/process-working.svg");
|
spinner-image: url("resource:///org/gnome/shell/theme/process-working.svg");
|
||||||
@@ -825,7 +812,7 @@ StScrollBar {
|
|||||||
color: transparent; }
|
color: transparent; }
|
||||||
|
|
||||||
.aggregate-menu {
|
.aggregate-menu {
|
||||||
min-width: 21em; }
|
width: 360px; }
|
||||||
.aggregate-menu .popup-menu-icon {
|
.aggregate-menu .popup-menu-icon {
|
||||||
padding: 0 4px; }
|
padding: 0 4px; }
|
||||||
|
|
||||||
@@ -962,14 +949,10 @@ StScrollBar {
|
|||||||
.search-entry {
|
.search-entry {
|
||||||
width: 320px;
|
width: 320px;
|
||||||
padding: 7px 9px;
|
padding: 7px 9px;
|
||||||
border-radius: 6px;
|
border-radius: 6px; }
|
||||||
border-color: #747467;
|
|
||||||
color: #eeeeec;
|
|
||||||
background-color: #2e3436; }
|
|
||||||
.search-entry:focus {
|
.search-entry:focus {
|
||||||
padding: 6px 8px;
|
padding: 6px 8px;
|
||||||
border-width: 2px;
|
border-width: 2px; }
|
||||||
border-color: #215d9c; }
|
|
||||||
.search-entry .search-entry-icon {
|
.search-entry .search-entry-icon {
|
||||||
icon-size: 1em;
|
icon-size: 1em;
|
||||||
padding: 0 4px;
|
padding: 0 4px;
|
||||||
|
|||||||
@@ -258,7 +258,6 @@ const AuthPrompt = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_onVerificationComplete: function() {
|
_onVerificationComplete: function() {
|
||||||
this.setActorInDefaultButtonWell(null);
|
|
||||||
this.verificationStatus = AuthPromptStatus.VERIFICATION_SUCCEEDED;
|
this.verificationStatus = AuthPromptStatus.VERIFICATION_SUCCEEDED;
|
||||||
this.cancelButton.reactive = false;
|
this.cancelButton.reactive = false;
|
||||||
},
|
},
|
||||||
@@ -282,12 +281,6 @@ const AuthPrompt = new Lang.Class({
|
|||||||
if (oldActor)
|
if (oldActor)
|
||||||
Tweener.removeTweens(oldActor);
|
Tweener.removeTweens(oldActor);
|
||||||
|
|
||||||
let wasSpinner;
|
|
||||||
if (oldActor == this._spinner.actor)
|
|
||||||
wasSpinner = true;
|
|
||||||
else
|
|
||||||
wasSpinner = false;
|
|
||||||
|
|
||||||
let isSpinner;
|
let isSpinner;
|
||||||
if (actor == this._spinner.actor)
|
if (actor == this._spinner.actor)
|
||||||
isSpinner = true;
|
isSpinner = true;
|
||||||
@@ -297,11 +290,6 @@ const AuthPrompt = new Lang.Class({
|
|||||||
if (this._defaultButtonWellActor != actor && oldActor) {
|
if (this._defaultButtonWellActor != actor && oldActor) {
|
||||||
if (!animate) {
|
if (!animate) {
|
||||||
oldActor.opacity = 0;
|
oldActor.opacity = 0;
|
||||||
|
|
||||||
if (wasSpinner) {
|
|
||||||
if (this._spinner)
|
|
||||||
this._spinner.stop();
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
Tweener.addTween(oldActor,
|
Tweener.addTween(oldActor,
|
||||||
{ opacity: 0,
|
{ opacity: 0,
|
||||||
@@ -310,7 +298,7 @@ const AuthPrompt = new Lang.Class({
|
|||||||
transition: 'linear',
|
transition: 'linear',
|
||||||
onCompleteScope: this,
|
onCompleteScope: this,
|
||||||
onComplete: function() {
|
onComplete: function() {
|
||||||
if (wasSpinner) {
|
if (isSpinner) {
|
||||||
if (this._spinner)
|
if (this._spinner)
|
||||||
this._spinner.stop();
|
this._spinner.stop();
|
||||||
}
|
}
|
||||||
@@ -501,7 +489,6 @@ const AuthPrompt = new Lang.Class({
|
|||||||
|
|
||||||
finish: function(onComplete) {
|
finish: function(onComplete) {
|
||||||
if (!this._userVerifier.hasPendingMessages) {
|
if (!this._userVerifier.hasPendingMessages) {
|
||||||
this._userVerifier.clear();
|
|
||||||
onComplete();
|
onComplete();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -509,7 +496,6 @@ const AuthPrompt = new Lang.Class({
|
|||||||
let signalId = this._userVerifier.connect('no-more-messages',
|
let signalId = this._userVerifier.connect('no-more-messages',
|
||||||
Lang.bind(this, function() {
|
Lang.bind(this, function() {
|
||||||
this._userVerifier.disconnect(signalId);
|
this._userVerifier.disconnect(signalId);
|
||||||
this._userVerifier.clear();
|
|
||||||
onComplete();
|
onComplete();
|
||||||
}));
|
}));
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -16,34 +16,6 @@
|
|||||||
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
|
||||||
* In order for transformation animations to look good, they need to be
|
|
||||||
* incremental and have some order to them (e.g., fade out hidden items,
|
|
||||||
* then shrink to close the void left over). Chaining animations in this way can
|
|
||||||
* be error-prone and wordy using just Tweener callbacks.
|
|
||||||
*
|
|
||||||
* The classes in this file help with this:
|
|
||||||
*
|
|
||||||
* - Task. encapsulates schedulable work to be run in a specific scope.
|
|
||||||
*
|
|
||||||
* - ConsecutiveBatch. runs a series of tasks in order and completes
|
|
||||||
* when the last in the series finishes.
|
|
||||||
*
|
|
||||||
* - ConcurrentBatch. runs a set of tasks at the same time and completes
|
|
||||||
* when the last to finish completes.
|
|
||||||
*
|
|
||||||
* - Hold. prevents a batch from completing the pending task until
|
|
||||||
* the hold is released.
|
|
||||||
*
|
|
||||||
* The tasks associated with a batch are specified in a list at batch
|
|
||||||
* construction time as either task objects or plain functions.
|
|
||||||
* Batches are task objects, themselves, so they can be nested.
|
|
||||||
*
|
|
||||||
* These classes aren't specific to GDM, but were found to be unintuitive and so
|
|
||||||
* are not used elsewhere. These APIs may ultimately get dropped entirely and
|
|
||||||
* replaced by something else.
|
|
||||||
*/
|
|
||||||
|
|
||||||
const Lang = imports.lang;
|
const Lang = imports.lang;
|
||||||
const Signals = imports.signals;
|
const Signals = imports.signals;
|
||||||
|
|
||||||
|
|||||||
@@ -96,7 +96,7 @@ const UserListItem = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_onDestroy: function() {
|
_onDestroy: function() {
|
||||||
this.user.disconnect(this._userChangedId);
|
this._user.disconnect(this._userChangedId);
|
||||||
},
|
},
|
||||||
|
|
||||||
_onClicked: function() {
|
_onClicked: function() {
|
||||||
@@ -212,10 +212,6 @@ const UserList = new Lang.Class({
|
|||||||
return item;
|
return item;
|
||||||
},
|
},
|
||||||
|
|
||||||
containsUser: function(user) {
|
|
||||||
return this._items[user.get_user_name()] != null;
|
|
||||||
},
|
|
||||||
|
|
||||||
addUser: function(user) {
|
addUser: function(user) {
|
||||||
if (!user.is_loaded)
|
if (!user.is_loaded)
|
||||||
return;
|
return;
|
||||||
@@ -539,9 +535,6 @@ const LoginDialog = new Lang.Class({
|
|||||||
let centerX = dialogBox.x1 + (dialogBox.x2 - dialogBox.x1) / 2;
|
let centerX = dialogBox.x1 + (dialogBox.x2 - dialogBox.x1) / 2;
|
||||||
let centerY = dialogBox.y1 + (dialogBox.y2 - dialogBox.y1) / 2;
|
let centerY = dialogBox.y1 + (dialogBox.y2 - dialogBox.y1) / 2;
|
||||||
|
|
||||||
natWidth = Math.min(natWidth, dialogBox.x2 - dialogBox.x1);
|
|
||||||
natHeight = Math.min(natHeight, dialogBox.y2 - dialogBox.y1);
|
|
||||||
|
|
||||||
actorBox.x1 = Math.floor(centerX - natWidth / 2);
|
actorBox.x1 = Math.floor(centerX - natWidth / 2);
|
||||||
actorBox.y1 = Math.floor(centerY - natHeight / 2);
|
actorBox.y1 = Math.floor(centerY - natHeight / 2);
|
||||||
actorBox.x2 = actorBox.x1 + natWidth;
|
actorBox.x2 = actorBox.x1 + natWidth;
|
||||||
@@ -881,7 +874,7 @@ const LoginDialog = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_loginScreenSessionActivated: function() {
|
_loginScreenSessionActivated: function() {
|
||||||
if (this.actor.opacity == 255 && this._authPrompt.verificationStatus == AuthPrompt.AuthPromptStatus.NOT_VERIFYING)
|
if (this._authPrompt.verificationStatus != AuthPrompt.AuthPromptStatus.VERIFICATION_SUCCEEDED)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
Tweener.addTween(this.actor,
|
Tweener.addTween(this.actor,
|
||||||
@@ -898,8 +891,7 @@ const LoginDialog = new Lang.Class({
|
|||||||
},
|
},
|
||||||
onUpdateScope: this,
|
onUpdateScope: this,
|
||||||
onComplete: function() {
|
onComplete: function() {
|
||||||
if (this._authPrompt.verificationStatus != AuthPrompt.AuthPromptStatus.NOT_VERIFYING)
|
this._authPrompt.reset();
|
||||||
this._authPrompt.reset();
|
|
||||||
},
|
},
|
||||||
onCompleteScope: this });
|
onCompleteScope: this });
|
||||||
},
|
},
|
||||||
@@ -928,7 +920,11 @@ const LoginDialog = new Lang.Class({
|
|||||||
},
|
},
|
||||||
onUpdateScope: this,
|
onUpdateScope: this,
|
||||||
onComplete: function() {
|
onComplete: function() {
|
||||||
this._greeter.call_start_session_when_ready_sync(serviceName, true, null);
|
let id = Mainloop.idle_add(Lang.bind(this, function() {
|
||||||
|
this._greeter.call_start_session_when_ready_sync(serviceName, true, null);
|
||||||
|
return GLib.SOURCE_REMOVE;
|
||||||
|
}));
|
||||||
|
GLib.Source.set_name_by_id(id, '[gnome-shell] this._greeter.call_start_session_when_ready_sync');
|
||||||
},
|
},
|
||||||
onCompleteScope: this });
|
onCompleteScope: this });
|
||||||
},
|
},
|
||||||
@@ -1130,10 +1126,6 @@ const LoginDialog = new Lang.Class({
|
|||||||
this._userManager.disconnect(this._userRemovedId);
|
this._userManager.disconnect(this._userRemovedId);
|
||||||
this._userRemovedId = 0;
|
this._userRemovedId = 0;
|
||||||
}
|
}
|
||||||
if (this._userChangedId) {
|
|
||||||
this._userManager.disconnect(this._userChangedId);
|
|
||||||
this._userChangedId = 0;
|
|
||||||
}
|
|
||||||
this._textureCache.disconnect(this._updateLogoTextureId);
|
this._textureCache.disconnect(this._updateLogoTextureId);
|
||||||
Main.layoutManager.disconnect(this._startupCompleteId);
|
Main.layoutManager.disconnect(this._startupCompleteId);
|
||||||
if (this._settings) {
|
if (this._settings) {
|
||||||
@@ -1180,14 +1172,6 @@ const LoginDialog = new Lang.Class({
|
|||||||
this._userList.removeUser(user);
|
this._userList.removeUser(user);
|
||||||
}));
|
}));
|
||||||
|
|
||||||
this._userChangedId = this._userManager.connect('user-changed',
|
|
||||||
Lang.bind(this, function(userManager, user) {
|
|
||||||
if (this._userList.containsUser(user) && user.locked)
|
|
||||||
this._userList.removeUser(user);
|
|
||||||
else if (!this._userList.containsUser(user) && !user.locked)
|
|
||||||
this._userList.addUser(user);
|
|
||||||
}));
|
|
||||||
|
|
||||||
return GLib.SOURCE_REMOVE;
|
return GLib.SOURCE_REMOVE;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|||||||
@@ -448,6 +448,8 @@ const AppSwitcher = new Lang.Class({
|
|||||||
});
|
});
|
||||||
if (appIcon.cachedWindows.length > 0)
|
if (appIcon.cachedWindows.length > 0)
|
||||||
this._addIcon(appIcon);
|
this._addIcon(appIcon);
|
||||||
|
else if (workspace == null)
|
||||||
|
throw new Error('%s appears to be running, but doesn\'t have any windows'.format(appIcon.app.get_name()));
|
||||||
}
|
}
|
||||||
|
|
||||||
this._curApp = -1;
|
this._curApp = -1;
|
||||||
@@ -685,17 +687,15 @@ const WindowIcon = new Lang.Class({
|
|||||||
|
|
||||||
this._icon.destroy_all_children();
|
this._icon.destroy_all_children();
|
||||||
|
|
||||||
let scaleFactor = St.ThemeContext.get_for_stage(global.stage).scale_factor;
|
|
||||||
|
|
||||||
switch (mode) {
|
switch (mode) {
|
||||||
case AppIconMode.THUMBNAIL_ONLY:
|
case AppIconMode.THUMBNAIL_ONLY:
|
||||||
size = WINDOW_PREVIEW_SIZE;
|
size = WINDOW_PREVIEW_SIZE;
|
||||||
this._icon.add_actor(_createWindowClone(mutterWindow, size * scaleFactor));
|
this._icon.add_actor(_createWindowClone(mutterWindow, WINDOW_PREVIEW_SIZE));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case AppIconMode.BOTH:
|
case AppIconMode.BOTH:
|
||||||
size = WINDOW_PREVIEW_SIZE;
|
size = WINDOW_PREVIEW_SIZE;
|
||||||
this._icon.add_actor(_createWindowClone(mutterWindow, size * scaleFactor));
|
this._icon.add_actor(_createWindowClone(mutterWindow, WINDOW_PREVIEW_SIZE));
|
||||||
|
|
||||||
if (this.app)
|
if (this.app)
|
||||||
this._icon.add_actor(this._createAppIcon(this.app,
|
this._icon.add_actor(this._createAppIcon(this.app,
|
||||||
@@ -707,7 +707,7 @@ const WindowIcon = new Lang.Class({
|
|||||||
this._icon.add_actor(this._createAppIcon(this.app, size));
|
this._icon.add_actor(this._createAppIcon(this.app, size));
|
||||||
}
|
}
|
||||||
|
|
||||||
this._icon.set_size(size * scaleFactor, size * scaleFactor);
|
this._icon.set_size(size, size);
|
||||||
},
|
},
|
||||||
|
|
||||||
_createAppIcon: function(app, size) {
|
_createAppIcon: function(app, size) {
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ const St = imports.gi.St;
|
|||||||
const Signals = imports.signals;
|
const Signals = imports.signals;
|
||||||
const Atk = imports.gi.Atk;
|
const Atk = imports.gi.Atk;
|
||||||
|
|
||||||
const ANIMATED_ICON_UPDATE_TIMEOUT = 16;
|
const ANIMATED_ICON_UPDATE_TIMEOUT = 14;
|
||||||
|
|
||||||
const Animation = new Lang.Class({
|
const Animation = new Lang.Class({
|
||||||
Name: 'Animation',
|
Name: 'Animation',
|
||||||
@@ -33,7 +33,7 @@ const Animation = new Lang.Class({
|
|||||||
if (this._frame == 0)
|
if (this._frame == 0)
|
||||||
this._showFrame(0);
|
this._showFrame(0);
|
||||||
|
|
||||||
this._timeoutId = GLib.timeout_add(GLib.PRIORITY_LOW, this._speed, Lang.bind(this, this._update));
|
this._timeoutId = Mainloop.timeout_add(this._speed, Lang.bind(this, this._update));
|
||||||
GLib.Source.set_name_by_id(this._timeoutId, '[gnome-shell] this._update');
|
GLib.Source.set_name_by_id(this._timeoutId, '[gnome-shell] this._update');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -26,7 +26,6 @@ const RENAMED_DESKTOP_IDS = {
|
|||||||
'gnome-photos.desktop': 'org.gnome.Photos.desktop',
|
'gnome-photos.desktop': 'org.gnome.Photos.desktop',
|
||||||
'gnome-screenshot.desktop': 'org.gnome.Screenshot.desktop',
|
'gnome-screenshot.desktop': 'org.gnome.Screenshot.desktop',
|
||||||
'gnome-software.desktop': 'org.gnome.Software.desktop',
|
'gnome-software.desktop': 'org.gnome.Software.desktop',
|
||||||
'gnome-terminal.desktop': 'org.gnome.Terminal.desktop',
|
|
||||||
'gnome-weather.desktop': 'org.gnome.Weather.Application.desktop',
|
'gnome-weather.desktop': 'org.gnome.Weather.Application.desktop',
|
||||||
'gnomine.desktop': 'gnome-mines.desktop',
|
'gnomine.desktop': 'gnome-mines.desktop',
|
||||||
'gnotravex.desktop': 'gnome-tetravex.desktop',
|
'gnotravex.desktop': 'gnome-tetravex.desktop',
|
||||||
|
|||||||
@@ -144,7 +144,6 @@ const BackgroundCache = new Lang.Class({
|
|||||||
this._pendingFileLoads = [];
|
this._pendingFileLoads = [];
|
||||||
this._fileMonitors = {};
|
this._fileMonitors = {};
|
||||||
this._backgroundSources = {};
|
this._backgroundSources = {};
|
||||||
this._animations = {};
|
|
||||||
},
|
},
|
||||||
|
|
||||||
monitorFile: function(file) {
|
monitorFile: function(file) {
|
||||||
@@ -163,13 +162,12 @@ const BackgroundCache = new Lang.Class({
|
|||||||
|
|
||||||
getAnimation: function(params) {
|
getAnimation: function(params) {
|
||||||
params = Params.parse(params, { file: null,
|
params = Params.parse(params, { file: null,
|
||||||
settingsSchema: null,
|
|
||||||
onLoaded: null });
|
onLoaded: null });
|
||||||
|
|
||||||
if (this._animations[params.settingsSchema] && _fileEqual0(this._animationFile, params.file)) {
|
if (_fileEqual0(this._animationFile, params.file)) {
|
||||||
if (params.onLoaded) {
|
if (params.onLoaded) {
|
||||||
let id = GLib.idle_add(GLib.PRIORITY_DEFAULT, Lang.bind(this, function() {
|
let id = GLib.idle_add(GLib.PRIORITY_DEFAULT, Lang.bind(this, function() {
|
||||||
params.onLoaded(this._animations[params.settingsSchema]);
|
params.onLoaded(this._animation);
|
||||||
return GLib.SOURCE_REMOVE;
|
return GLib.SOURCE_REMOVE;
|
||||||
}));
|
}));
|
||||||
GLib.Source.set_name_by_id(id, '[gnome-shell] params.onLoaded');
|
GLib.Source.set_name_by_id(id, '[gnome-shell] params.onLoaded');
|
||||||
@@ -180,11 +178,12 @@ const BackgroundCache = new Lang.Class({
|
|||||||
let animation = new Animation({ file: params.file });
|
let animation = new Animation({ file: params.file });
|
||||||
|
|
||||||
animation.load(Lang.bind(this, function() {
|
animation.load(Lang.bind(this, function() {
|
||||||
this._animations[params.settingsSchema] = animation;
|
this._animationFile = params.file;
|
||||||
|
this._animation = animation;
|
||||||
|
|
||||||
if (params.onLoaded) {
|
if (params.onLoaded) {
|
||||||
let id = GLib.idle_add(GLib.PRIORITY_DEFAULT, Lang.bind(this, function() {
|
let id = GLib.idle_add(GLib.PRIORITY_DEFAULT, Lang.bind(this, function() {
|
||||||
params.onLoaded(this._animations[params.settingsSchema]);
|
params.onLoaded(this._animation);
|
||||||
return GLib.SOURCE_REMOVE;
|
return GLib.SOURCE_REMOVE;
|
||||||
}));
|
}));
|
||||||
GLib.Source.set_name_by_id(id, '[gnome-shell] params.onLoaded');
|
GLib.Source.set_name_by_id(id, '[gnome-shell] params.onLoaded');
|
||||||
@@ -247,13 +246,6 @@ const Background = new Lang.Class({
|
|||||||
this._cancellable = new Gio.Cancellable();
|
this._cancellable = new Gio.Cancellable();
|
||||||
this.isLoaded = false;
|
this.isLoaded = false;
|
||||||
|
|
||||||
this._clock = new GnomeDesktop.WallClock();
|
|
||||||
this._timezoneChangedId = this._clock.connect('notify::timezone',
|
|
||||||
Lang.bind(this, function() {
|
|
||||||
if (this._animation)
|
|
||||||
this._loadAnimation(this._animation.file);
|
|
||||||
}));
|
|
||||||
|
|
||||||
this._settingsChangedSignalId = this._settings.connect('changed', Lang.bind(this, function() {
|
this._settingsChangedSignalId = this._settings.connect('changed', Lang.bind(this, function() {
|
||||||
this.emit('changed');
|
this.emit('changed');
|
||||||
}));
|
}));
|
||||||
@@ -272,10 +264,6 @@ const Background = new Lang.Class({
|
|||||||
}
|
}
|
||||||
this._fileWatches = null;
|
this._fileWatches = null;
|
||||||
|
|
||||||
if (this._timezoneChangedId != 0)
|
|
||||||
this._clock.disconnect(this._timezoneChangedId);
|
|
||||||
this._timezoneChangedId = 0;
|
|
||||||
|
|
||||||
if (this._settingsChangedSignalId != 0)
|
if (this._settingsChangedSignalId != 0)
|
||||||
this._settings.disconnect(this._settingsChangedSignalId);
|
this._settings.disconnect(this._settingsChangedSignalId);
|
||||||
this._settingsChangedSignalId = 0;
|
this._settingsChangedSignalId = 0;
|
||||||
@@ -415,18 +403,17 @@ const Background = new Lang.Class({
|
|||||||
|
|
||||||
_loadAnimation: function(file) {
|
_loadAnimation: function(file) {
|
||||||
this._cache.getAnimation({ file: file,
|
this._cache.getAnimation({ file: file,
|
||||||
settingsSchema: this._settings.schema_id,
|
onLoaded: Lang.bind(this, function(animation) {
|
||||||
onLoaded: Lang.bind(this, function(animation) {
|
this._animation = animation;
|
||||||
this._animation = animation;
|
|
||||||
|
|
||||||
if (!this._animation || this._cancellable.is_cancelled()) {
|
if (!this._animation || this._cancellable.is_cancelled()) {
|
||||||
this._setLoaded();
|
this._setLoaded();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
this._updateAnimation();
|
this._updateAnimation();
|
||||||
this._watchFile(file);
|
this._watchFile(file);
|
||||||
})
|
})
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|||||||
@@ -24,8 +24,6 @@ const MSECS_IN_DAY = 24 * 60 * 60 * 1000;
|
|||||||
const SHOW_WEEKDATE_KEY = 'show-weekdate';
|
const SHOW_WEEKDATE_KEY = 'show-weekdate';
|
||||||
const ELLIPSIS_CHAR = '\u2026';
|
const ELLIPSIS_CHAR = '\u2026';
|
||||||
|
|
||||||
const MESSAGE_ICON_SIZE = 32;
|
|
||||||
|
|
||||||
const MESSAGE_ANIMATION_TIME = 0.1;
|
const MESSAGE_ANIMATION_TIME = 0.1;
|
||||||
|
|
||||||
const DEFAULT_EXPAND_LINES = 6;
|
const DEFAULT_EXPAND_LINES = 6;
|
||||||
@@ -725,7 +723,7 @@ const Calendar = new Lang.Class({
|
|||||||
// nRows here means 6 weeks + one header + one navbar
|
// nRows here means 6 weeks + one header + one navbar
|
||||||
let nRows = 8;
|
let nRows = 8;
|
||||||
while (row < 8) {
|
while (row < 8) {
|
||||||
let button = new St.Button({ label: iter.toLocaleFormat(C_("date day number format", "%d")),
|
let button = new St.Button({ label: iter.getDate().toString(),
|
||||||
can_focus: true });
|
can_focus: true });
|
||||||
let rtl = button.get_text_direction() == Clutter.TextDirection.RTL;
|
let rtl = button.get_text_direction() == Clutter.TextDirection.RTL;
|
||||||
|
|
||||||
@@ -978,6 +976,7 @@ const Message = new Lang.Class({
|
|||||||
this._iconBin = new St.Bin({ style_class: 'message-icon-bin',
|
this._iconBin = new St.Bin({ style_class: 'message-icon-bin',
|
||||||
y_expand: true,
|
y_expand: true,
|
||||||
visible: false });
|
visible: false });
|
||||||
|
this._iconBin.set_y_align(Clutter.ActorAlign.START);
|
||||||
hbox.add_actor(this._iconBin);
|
hbox.add_actor(this._iconBin);
|
||||||
|
|
||||||
let contentBox = new St.BoxLayout({ style_class: 'message-content',
|
let contentBox = new St.BoxLayout({ style_class: 'message-content',
|
||||||
@@ -1230,7 +1229,7 @@ const NotificationMessage = new Lang.Class({
|
|||||||
this._closed = true;
|
this._closed = true;
|
||||||
this.notification.destroy(MessageTray.NotificationDestroyedReason.DISMISSED);
|
this.notification.destroy(MessageTray.NotificationDestroyedReason.DISMISSED);
|
||||||
}));
|
}));
|
||||||
this._destroyId = notification.connect('destroy', Lang.bind(this,
|
notification.connect('destroy', Lang.bind(this,
|
||||||
function() {
|
function() {
|
||||||
if (!this._closed)
|
if (!this._closed)
|
||||||
this.close();
|
this.close();
|
||||||
@@ -1241,10 +1240,9 @@ const NotificationMessage = new Lang.Class({
|
|||||||
|
|
||||||
_getIcon: function() {
|
_getIcon: function() {
|
||||||
if (this.notification.gicon)
|
if (this.notification.gicon)
|
||||||
return new St.Icon({ gicon: this.notification.gicon,
|
return new St.Icon({ gicon: this.notification.gicon, icon_size: 48 });
|
||||||
icon_size: MESSAGE_ICON_SIZE });
|
|
||||||
else
|
else
|
||||||
return this.notification.source.createIcon(MESSAGE_ICON_SIZE);
|
return this.notification.source.createIcon(48);
|
||||||
},
|
},
|
||||||
|
|
||||||
_onUpdated: function(n, clear) {
|
_onUpdated: function(n, clear) {
|
||||||
@@ -1262,10 +1260,6 @@ const NotificationMessage = new Lang.Class({
|
|||||||
if (this._updatedId)
|
if (this._updatedId)
|
||||||
this.notification.disconnect(this._updatedId);
|
this.notification.disconnect(this._updatedId);
|
||||||
this._updatedId = 0;
|
this._updatedId = 0;
|
||||||
|
|
||||||
if (this._destroyId)
|
|
||||||
this.notification.disconnect(this._destroyId);
|
|
||||||
this._destroyId = 0;
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
@@ -313,10 +313,6 @@ const AutorunSource = new Lang.Class({
|
|||||||
|
|
||||||
getIcon: function() {
|
getIcon: function() {
|
||||||
return this.mount.get_icon();
|
return this.mount.get_icon();
|
||||||
},
|
|
||||||
|
|
||||||
_createPolicy: function() {
|
|
||||||
return new MessageTray.NotificationApplicationPolicy('org.gnome.Nautilus');
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -329,6 +325,9 @@ const AutorunNotification = new Lang.Class({
|
|||||||
|
|
||||||
this._manager = manager;
|
this._manager = manager;
|
||||||
this._mount = source.mount;
|
this._mount = source.mount;
|
||||||
|
|
||||||
|
// set the notification to urgent, so that it expands out
|
||||||
|
this.setUrgency(MessageTray.Urgency.CRITICAL);
|
||||||
},
|
},
|
||||||
|
|
||||||
createBanner: function() {
|
createBanner: function() {
|
||||||
|
|||||||
@@ -15,7 +15,7 @@ const ShellEntry = imports.ui.shellEntry;
|
|||||||
const CheckBox = imports.ui.checkBox;
|
const CheckBox = imports.ui.checkBox;
|
||||||
const Tweener = imports.ui.tweener;
|
const Tweener = imports.ui.tweener;
|
||||||
|
|
||||||
const WORK_SPINNER_ICON_SIZE = 16;
|
const WORK_SPINNER_ICON_SIZE = 24;
|
||||||
const WORK_SPINNER_ANIMATION_DELAY = 1.0;
|
const WORK_SPINNER_ANIMATION_DELAY = 1.0;
|
||||||
const WORK_SPINNER_ANIMATION_TIME = 0.3;
|
const WORK_SPINNER_ANIMATION_TIME = 0.3;
|
||||||
|
|
||||||
@@ -78,6 +78,13 @@ const KeyringDialog = new Lang.Class({
|
|||||||
this.prompt.bind_property('continue-label', this._continueButton, 'label', GObject.BindingFlags.SYNC_CREATE);
|
this.prompt.bind_property('continue-label', this._continueButton, 'label', GObject.BindingFlags.SYNC_CREATE);
|
||||||
},
|
},
|
||||||
|
|
||||||
|
_createSpinner: function() {
|
||||||
|
let spinnerIcon = Gio.File.new_for_uri('resource:///org/gnome/shell/theme/process-working.svg');
|
||||||
|
this._workSpinner = new Animation.AnimatedIcon(spinnerIcon, WORK_SPINNER_ICON_SIZE);
|
||||||
|
this._workSpinner.actor.opacity = 0;
|
||||||
|
this._workSpinner.actor.show();
|
||||||
|
},
|
||||||
|
|
||||||
_setWorking: function(working) {
|
_setWorking: function(working) {
|
||||||
if (!this._workSpinner)
|
if (!this._workSpinner)
|
||||||
return;
|
return;
|
||||||
@@ -127,10 +134,7 @@ const KeyringDialog = new Lang.Class({
|
|||||||
ShellEntry.addContextMenu(this._passwordEntry, { isPassword: true });
|
ShellEntry.addContextMenu(this._passwordEntry, { isPassword: true });
|
||||||
this._passwordEntry.clutter_text.connect('activate', Lang.bind(this, this._onPasswordActivate));
|
this._passwordEntry.clutter_text.connect('activate', Lang.bind(this, this._onPasswordActivate));
|
||||||
|
|
||||||
let spinnerIcon = Gio.File.new_for_uri('resource:///org/gnome/shell/theme/process-working.svg');
|
this._createSpinner();
|
||||||
this._workSpinner = new Animation.AnimatedIcon(spinnerIcon, WORK_SPINNER_ICON_SIZE);
|
|
||||||
this._workSpinner.actor.opacity = 0;
|
|
||||||
|
|
||||||
if (rtl) {
|
if (rtl) {
|
||||||
layout.attach(this._workSpinner.actor, 0, row, 1, 1);
|
layout.attach(this._workSpinner.actor, 0, row, 1, 1);
|
||||||
layout.attach(this._passwordEntry, 1, row, 1, 1);
|
layout.attach(this._passwordEntry, 1, row, 1, 1);
|
||||||
|
|||||||
@@ -22,7 +22,7 @@ const Tweener = imports.ui.tweener;
|
|||||||
|
|
||||||
const DIALOG_ICON_SIZE = 48;
|
const DIALOG_ICON_SIZE = 48;
|
||||||
|
|
||||||
const WORK_SPINNER_ICON_SIZE = 16;
|
const WORK_SPINNER_ICON_SIZE = 24;
|
||||||
const WORK_SPINNER_ANIMATION_DELAY = 1.0;
|
const WORK_SPINNER_ANIMATION_DELAY = 1.0;
|
||||||
const WORK_SPINNER_ANIMATION_TIME = 0.3;
|
const WORK_SPINNER_ANIMATION_TIME = 0.3;
|
||||||
|
|
||||||
@@ -142,13 +142,7 @@ const AuthenticationDialog = new Lang.Class({
|
|||||||
this._passwordEntry.clutter_text.connect('activate', Lang.bind(this, this._onEntryActivate));
|
this._passwordEntry.clutter_text.connect('activate', Lang.bind(this, this._onEntryActivate));
|
||||||
this._passwordBox.add(this._passwordEntry,
|
this._passwordBox.add(this._passwordEntry,
|
||||||
{ expand: true });
|
{ expand: true });
|
||||||
|
this._addSpinner();
|
||||||
let spinnerIcon = Gio.File.new_for_uri('resource:///org/gnome/shell/theme/process-working.svg');
|
|
||||||
this._workSpinner = new Animation.AnimatedIcon(spinnerIcon, WORK_SPINNER_ICON_SIZE);
|
|
||||||
this._workSpinner.actor.opacity = 0;
|
|
||||||
|
|
||||||
this._passwordBox.add(this._workSpinner.actor);
|
|
||||||
|
|
||||||
this.setInitialKeyFocus(this._passwordEntry);
|
this.setInitialKeyFocus(this._passwordEntry);
|
||||||
this._passwordBox.hide();
|
this._passwordBox.hide();
|
||||||
|
|
||||||
@@ -189,6 +183,15 @@ const AuthenticationDialog = new Lang.Class({
|
|||||||
this._cookie = cookie;
|
this._cookie = cookie;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
_addSpinner: function() {
|
||||||
|
let spinnerIcon = Gio.File.new_for_uri('resource:///org/gnome/shell/theme/process-working.svg');
|
||||||
|
this._workSpinner = new Animation.AnimatedIcon(spinnerIcon, WORK_SPINNER_ICON_SIZE);
|
||||||
|
this._workSpinner.actor.opacity = 0;
|
||||||
|
this._workSpinner.actor.show();
|
||||||
|
|
||||||
|
this._passwordBox.add(this._workSpinner.actor);
|
||||||
|
},
|
||||||
|
|
||||||
_setWorking: function(working) {
|
_setWorking: function(working) {
|
||||||
Tweener.removeTweens(this._workSpinner.actor);
|
Tweener.removeTweens(this._workSpinner.actor);
|
||||||
if (working) {
|
if (working) {
|
||||||
|
|||||||
@@ -303,8 +303,6 @@ const ChatSource = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_createPolicy: function() {
|
_createPolicy: function() {
|
||||||
if (this._account.protocol_name == 'irc')
|
|
||||||
return new MessageTray.NotificationApplicationPolicy('org.gnome.Polari');
|
|
||||||
return new MessageTray.NotificationApplicationPolicy('empathy');
|
return new MessageTray.NotificationApplicationPolicy('empathy');
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|||||||
@@ -644,14 +644,15 @@ const Dash = new Lang.Class({
|
|||||||
let firstIcon = firstButton._delegate.icon;
|
let firstIcon = firstButton._delegate.icon;
|
||||||
|
|
||||||
let minHeight, natHeight;
|
let minHeight, natHeight;
|
||||||
let scaleFactor = St.ThemeContext.get_for_stage(global.stage).scale_factor;
|
|
||||||
|
|
||||||
// Enforce the current icon size during the size request
|
// Enforce the current icon size during the size request
|
||||||
firstIcon.icon.ensure_style();
|
firstIcon.setIconSize(this.iconSize);
|
||||||
let [currentWidth, currentHeight] = firstIcon.icon.get_size();
|
|
||||||
firstIcon.icon.set_size(this.iconSize * scaleFactor, this.iconSize * scaleFactor);
|
|
||||||
[minHeight, natHeight] = firstButton.get_preferred_height(-1);
|
[minHeight, natHeight] = firstButton.get_preferred_height(-1);
|
||||||
firstIcon.icon.set_size(currentWidth, currentHeight);
|
|
||||||
|
let scaleFactor = St.ThemeContext.get_for_stage(global.stage).scale_factor;
|
||||||
|
let iconSizes = baseIconSizes.map(function(s) {
|
||||||
|
return s * scaleFactor;
|
||||||
|
});
|
||||||
|
|
||||||
// Subtract icon padding and box spacing from the available height
|
// Subtract icon padding and box spacing from the available height
|
||||||
availHeight -= iconChildren.length * (natHeight - this.iconSize * scaleFactor) +
|
availHeight -= iconChildren.length * (natHeight - this.iconSize * scaleFactor) +
|
||||||
@@ -659,10 +660,6 @@ const Dash = new Lang.Class({
|
|||||||
|
|
||||||
let availSize = availHeight / iconChildren.length;
|
let availSize = availHeight / iconChildren.length;
|
||||||
|
|
||||||
let iconSizes = baseIconSizes.map(function(s) {
|
|
||||||
return s * scaleFactor;
|
|
||||||
});
|
|
||||||
|
|
||||||
let newIconSize = baseIconSizes[0];
|
let newIconSize = baseIconSizes[0];
|
||||||
for (let i = 0; i < iconSizes.length; i++) {
|
for (let i = 0; i < iconSizes.length; i++) {
|
||||||
if (iconSizes[i] < availSize)
|
if (iconSizes[i] < availSize)
|
||||||
|
|||||||
71
js/ui/dnd.js
71
js/ui/dnd.js
@@ -79,12 +79,9 @@ const _Draggable = new Lang.Class({
|
|||||||
dragActorOpacity: undefined });
|
dragActorOpacity: undefined });
|
||||||
|
|
||||||
this.actor = actor;
|
this.actor = actor;
|
||||||
if (!params.manualMode) {
|
if (!params.manualMode)
|
||||||
this.actor.connect('button-press-event',
|
this.actor.connect('button-press-event',
|
||||||
Lang.bind(this, this._onButtonPress));
|
Lang.bind(this, this._onButtonPress));
|
||||||
this.actor.connect('touch-event',
|
|
||||||
Lang.bind(this, this._onTouchEvent));
|
|
||||||
}
|
|
||||||
|
|
||||||
this.actor.connect('destroy', Lang.bind(this, function() {
|
this.actor.connect('destroy', Lang.bind(this, function() {
|
||||||
this._actorDestroyed = true;
|
this._actorDestroyed = true;
|
||||||
@@ -124,50 +121,8 @@ const _Draggable = new Lang.Class({
|
|||||||
return Clutter.EVENT_PROPAGATE;
|
return Clutter.EVENT_PROPAGATE;
|
||||||
},
|
},
|
||||||
|
|
||||||
_onTouchEvent: function (actor, event) {
|
|
||||||
if (event.type() != Clutter.EventType.TOUCH_BEGIN ||
|
|
||||||
!global.display.is_pointer_emulating_sequence(event.get_event_sequence()))
|
|
||||||
return Clutter.EVENT_PROPAGATE;
|
|
||||||
|
|
||||||
if (Tweener.getTweenCount(actor))
|
|
||||||
return Clutter.EVENT_PROPAGATE;
|
|
||||||
|
|
||||||
this._touchSequence = event.get_event_sequence();
|
|
||||||
|
|
||||||
this._buttonDown = true;
|
|
||||||
this._grabActor();
|
|
||||||
|
|
||||||
let [stageX, stageY] = event.get_coords();
|
|
||||||
this._dragStartX = stageX;
|
|
||||||
this._dragStartY = stageY;
|
|
||||||
|
|
||||||
return Clutter.EVENT_PROPAGATE;
|
|
||||||
},
|
|
||||||
|
|
||||||
_grabDevice: function(actor) {
|
|
||||||
let manager = Clutter.DeviceManager.get_default();
|
|
||||||
let pointer = manager.get_core_device(Clutter.InputDeviceType.POINTER_DEVICE);
|
|
||||||
|
|
||||||
if (pointer && this._touchSequence)
|
|
||||||
pointer.sequence_grab(this._touchSequence, actor);
|
|
||||||
else if (pointer)
|
|
||||||
pointer.grab (actor);
|
|
||||||
|
|
||||||
this._grabbedDevice = pointer;
|
|
||||||
},
|
|
||||||
|
|
||||||
_ungrabDevice: function() {
|
|
||||||
if (this._touchSequence)
|
|
||||||
this._grabbedDevice.sequence_ungrab (this._touchSequence);
|
|
||||||
else
|
|
||||||
this._grabbedDevice.ungrab();
|
|
||||||
|
|
||||||
this._touchSequence = null;
|
|
||||||
this._grabbedDevice = null;
|
|
||||||
},
|
|
||||||
|
|
||||||
_grabActor: function() {
|
_grabActor: function() {
|
||||||
this._grabDevice(this.actor);
|
Clutter.grab_pointer(this.actor);
|
||||||
this._onEventId = this.actor.connect('event',
|
this._onEventId = this.actor.connect('event',
|
||||||
Lang.bind(this, this._onEvent));
|
Lang.bind(this, this._onEvent));
|
||||||
},
|
},
|
||||||
@@ -176,7 +131,7 @@ const _Draggable = new Lang.Class({
|
|||||||
if (!this._onEventId)
|
if (!this._onEventId)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
this._ungrabDevice();
|
Clutter.ungrab_pointer();
|
||||||
this.actor.disconnect(this._onEventId);
|
this.actor.disconnect(this._onEventId);
|
||||||
this._onEventId = null;
|
this._onEventId = null;
|
||||||
},
|
},
|
||||||
@@ -185,13 +140,13 @@ const _Draggable = new Lang.Class({
|
|||||||
if (!this._eventsGrabbed) {
|
if (!this._eventsGrabbed) {
|
||||||
this._eventsGrabbed = Main.pushModal(_getEventHandlerActor());
|
this._eventsGrabbed = Main.pushModal(_getEventHandlerActor());
|
||||||
if (this._eventsGrabbed)
|
if (this._eventsGrabbed)
|
||||||
this._grabDevice(_getEventHandlerActor());
|
Clutter.grab_pointer(_getEventHandlerActor());
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
_ungrabEvents: function() {
|
_ungrabEvents: function() {
|
||||||
if (this._eventsGrabbed) {
|
if (this._eventsGrabbed) {
|
||||||
this._ungrabDevice();
|
Clutter.ungrab_pointer();
|
||||||
Main.popModal(_getEventHandlerActor());
|
Main.popModal(_getEventHandlerActor());
|
||||||
this._eventsGrabbed = false;
|
this._eventsGrabbed = false;
|
||||||
}
|
}
|
||||||
@@ -202,9 +157,7 @@ const _Draggable = new Lang.Class({
|
|||||||
// didn't start the drag, to drop the draggable in case the drag was in progress, and
|
// didn't start the drag, to drop the draggable in case the drag was in progress, and
|
||||||
// to complete the drag and ensure that whatever happens to be under the pointer does
|
// to complete the drag and ensure that whatever happens to be under the pointer does
|
||||||
// not get triggered if the drag was cancelled with Esc.
|
// not get triggered if the drag was cancelled with Esc.
|
||||||
if (event.type() == Clutter.EventType.BUTTON_RELEASE ||
|
if (event.type() == Clutter.EventType.BUTTON_RELEASE) {
|
||||||
(event.type() == Clutter.EventType.TOUCH_END &&
|
|
||||||
global.display.is_pointer_emulating_sequence(event.get_event_sequence()))) {
|
|
||||||
this._buttonDown = false;
|
this._buttonDown = false;
|
||||||
if (this._dragInProgress) {
|
if (this._dragInProgress) {
|
||||||
return this._dragActorDropped(event);
|
return this._dragActorDropped(event);
|
||||||
@@ -219,9 +172,7 @@ const _Draggable = new Lang.Class({
|
|||||||
}
|
}
|
||||||
// We intercept MOTION event to figure out if the drag has started and to draw
|
// We intercept MOTION event to figure out if the drag has started and to draw
|
||||||
// this._dragActor under the pointer when dragging is in progress
|
// this._dragActor under the pointer when dragging is in progress
|
||||||
} else if (event.type() == Clutter.EventType.MOTION ||
|
} else if (event.type() == Clutter.EventType.MOTION) {
|
||||||
(event.type() == Clutter.EventType.TOUCH_UPDATE &&
|
|
||||||
global.display.is_pointer_emulating_sequence(event.get_event_sequence()))) {
|
|
||||||
if (this._dragInProgress) {
|
if (this._dragInProgress) {
|
||||||
return this._updateDragPosition(event);
|
return this._updateDragPosition(event);
|
||||||
} else if (this._dragActor == null) {
|
} else if (this._dragActor == null) {
|
||||||
@@ -263,7 +214,7 @@ const _Draggable = new Lang.Class({
|
|||||||
* This function is useful to call if you've specified manualMode
|
* This function is useful to call if you've specified manualMode
|
||||||
* for the draggable.
|
* for the draggable.
|
||||||
*/
|
*/
|
||||||
startDrag: function (stageX, stageY, time, sequence) {
|
startDrag: function (stageX, stageY, time) {
|
||||||
currentDraggable = this;
|
currentDraggable = this;
|
||||||
this._dragInProgress = true;
|
this._dragInProgress = true;
|
||||||
|
|
||||||
@@ -277,8 +228,6 @@ const _Draggable = new Lang.Class({
|
|||||||
this.emit('drag-begin', time);
|
this.emit('drag-begin', time);
|
||||||
if (this._onEventId)
|
if (this._onEventId)
|
||||||
this._ungrabActor();
|
this._ungrabActor();
|
||||||
|
|
||||||
this._touchSequence = sequence;
|
|
||||||
this._grabEvents();
|
this._grabEvents();
|
||||||
global.screen.set_cursor(Meta.Cursor.DND_IN_DRAG);
|
global.screen.set_cursor(Meta.Cursor.DND_IN_DRAG);
|
||||||
|
|
||||||
@@ -389,8 +338,8 @@ const _Draggable = new Lang.Class({
|
|||||||
let threshold = Gtk.Settings.get_default().gtk_dnd_drag_threshold;
|
let threshold = Gtk.Settings.get_default().gtk_dnd_drag_threshold;
|
||||||
if ((Math.abs(stageX - this._dragStartX) > threshold ||
|
if ((Math.abs(stageX - this._dragStartX) > threshold ||
|
||||||
Math.abs(stageY - this._dragStartY) > threshold)) {
|
Math.abs(stageY - this._dragStartY) > threshold)) {
|
||||||
this.startDrag(stageX, stageY, event.get_time(), this._touchSequence);
|
this.startDrag(stageX, stageY, event.get_time());
|
||||||
this._updateDragPosition(event);
|
this._updateDragPosition(event);
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
|||||||
@@ -334,7 +334,7 @@ function _sessionUpdated() {
|
|||||||
// from allowExtensions in the future
|
// from allowExtensions in the future
|
||||||
if (Main.sessionMode.allowExtensions) {
|
if (Main.sessionMode.allowExtensions) {
|
||||||
if (initted)
|
if (initted)
|
||||||
enabledExtensions = getEnabledExtensions();
|
onEnabledExtensionsChanged();
|
||||||
enableAllExtensions();
|
enableAllExtensions();
|
||||||
} else {
|
} else {
|
||||||
disableAllExtensions();
|
disableAllExtensions();
|
||||||
|
|||||||
@@ -78,7 +78,6 @@ let _startDate;
|
|||||||
let _defaultCssStylesheet = null;
|
let _defaultCssStylesheet = null;
|
||||||
let _cssStylesheet = null;
|
let _cssStylesheet = null;
|
||||||
let _a11ySettings = null;
|
let _a11ySettings = null;
|
||||||
let _themeResource = null;
|
|
||||||
|
|
||||||
function _sessionUpdated() {
|
function _sessionUpdated() {
|
||||||
if (sessionMode.isPrimary)
|
if (sessionMode.isPrimary)
|
||||||
@@ -138,7 +137,9 @@ function _initializeUI() {
|
|||||||
Shell.WindowTracker.get_default();
|
Shell.WindowTracker.get_default();
|
||||||
Shell.AppUsage.get_default();
|
Shell.AppUsage.get_default();
|
||||||
|
|
||||||
reloadThemeResource();
|
let resource = Gio.Resource.load(global.datadir + '/gnome-shell-theme.gresource');
|
||||||
|
resource._register();
|
||||||
|
|
||||||
_loadDefaultStylesheet();
|
_loadDefaultStylesheet();
|
||||||
|
|
||||||
// Setup the stage hierarchy early
|
// Setup the stage hierarchy early
|
||||||
@@ -289,14 +290,6 @@ function setThemeStylesheet(cssStylesheet) {
|
|||||||
_cssStylesheet = cssStylesheet ? Gio.File.new_for_path(cssStylesheet) : null;
|
_cssStylesheet = cssStylesheet ? Gio.File.new_for_path(cssStylesheet) : null;
|
||||||
}
|
}
|
||||||
|
|
||||||
function reloadThemeResource() {
|
|
||||||
if (_themeResource)
|
|
||||||
_themeResource._unregister();
|
|
||||||
|
|
||||||
_themeResource = Gio.Resource.load(global.datadir + '/gnome-shell-theme.gresource');
|
|
||||||
_themeResource._register();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* loadTheme:
|
* loadTheme:
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -14,6 +14,7 @@ const Atk = imports.gi.Atk;
|
|||||||
|
|
||||||
const Params = imports.misc.params;
|
const Params = imports.misc.params;
|
||||||
|
|
||||||
|
const Animation = imports.ui.animation;
|
||||||
const Layout = imports.ui.layout;
|
const Layout = imports.ui.layout;
|
||||||
const Lightbox = imports.ui.lightbox;
|
const Lightbox = imports.ui.lightbox;
|
||||||
const Main = imports.ui.main;
|
const Main = imports.ui.main;
|
||||||
@@ -22,6 +23,10 @@ const Tweener = imports.ui.tweener;
|
|||||||
const OPEN_AND_CLOSE_TIME = 0.1;
|
const OPEN_AND_CLOSE_TIME = 0.1;
|
||||||
const FADE_OUT_DIALOG_TIME = 1.0;
|
const FADE_OUT_DIALOG_TIME = 1.0;
|
||||||
|
|
||||||
|
const WORK_SPINNER_ICON_SIZE = 16;
|
||||||
|
const WORK_SPINNER_ANIMATION_DELAY = 1.0;
|
||||||
|
const WORK_SPINNER_ANIMATION_TIME = 0.3;
|
||||||
|
|
||||||
const State = {
|
const State = {
|
||||||
OPENED: 0,
|
OPENED: 0,
|
||||||
CLOSED: 1,
|
CLOSED: 1,
|
||||||
@@ -74,9 +79,7 @@ const ModalDialog = new Lang.Class({
|
|||||||
this._group.add_actor(this._backgroundBin);
|
this._group.add_actor(this._backgroundBin);
|
||||||
|
|
||||||
this.dialogLayout = new St.BoxLayout({ style_class: 'modal-dialog',
|
this.dialogLayout = new St.BoxLayout({ style_class: 'modal-dialog',
|
||||||
x_align: Clutter.ActorAlign.CENTER,
|
vertical: true });
|
||||||
y_align: Clutter.ActorAlign.CENTER,
|
|
||||||
vertical: true });
|
|
||||||
// modal dialogs are fixed width and grow vertically; set the request
|
// modal dialogs are fixed width and grow vertically; set the request
|
||||||
// mode accordingly so wrapped labels are handled correctly during
|
// mode accordingly so wrapped labels are handled correctly during
|
||||||
// size requests.
|
// size requests.
|
||||||
@@ -97,8 +100,7 @@ const ModalDialog = new Lang.Class({
|
|||||||
this.backgroundStack.add_actor(this.dialogLayout);
|
this.backgroundStack.add_actor(this.dialogLayout);
|
||||||
|
|
||||||
|
|
||||||
this.contentLayout = new St.BoxLayout({ vertical: true,
|
this.contentLayout = new St.BoxLayout({ vertical: true });
|
||||||
style_class: "modal-dialog-content-box" });
|
|
||||||
this.dialogLayout.add(this.contentLayout,
|
this.dialogLayout.add(this.contentLayout,
|
||||||
{ expand: true,
|
{ expand: true,
|
||||||
x_fill: true,
|
x_fill: true,
|
||||||
@@ -106,7 +108,8 @@ const ModalDialog = new Lang.Class({
|
|||||||
x_align: St.Align.MIDDLE,
|
x_align: St.Align.MIDDLE,
|
||||||
y_align: St.Align.START });
|
y_align: St.Align.START });
|
||||||
|
|
||||||
this.buttonLayout = new St.Widget ({ layout_manager: new Clutter.BoxLayout ({ homogeneous:true }) });
|
this.buttonLayout = new St.BoxLayout({ style_class: 'modal-dialog-button-box',
|
||||||
|
vertical: false });
|
||||||
this.dialogLayout.add(this.buttonLayout,
|
this.dialogLayout.add(this.buttonLayout,
|
||||||
{ x_align: St.Align.MIDDLE,
|
{ x_align: St.Align.MIDDLE,
|
||||||
y_align: St.Align.END });
|
y_align: St.Align.END });
|
||||||
@@ -115,6 +118,8 @@ const ModalDialog = new Lang.Class({
|
|||||||
this._initialKeyFocus = this.dialogLayout;
|
this._initialKeyFocus = this.dialogLayout;
|
||||||
this._initialKeyFocusDestroyId = 0;
|
this._initialKeyFocusDestroyId = 0;
|
||||||
this._savedKeyFocus = null;
|
this._savedKeyFocus = null;
|
||||||
|
|
||||||
|
this._workSpinner = null;
|
||||||
},
|
},
|
||||||
|
|
||||||
destroy: function() {
|
destroy: function() {
|
||||||
@@ -142,12 +147,16 @@ const ModalDialog = new Lang.Class({
|
|||||||
else
|
else
|
||||||
x_alignment = St.Align.MIDDLE;
|
x_alignment = St.Align.MIDDLE;
|
||||||
|
|
||||||
this.addButton(buttonInfo);
|
this.addButton(buttonInfo, { expand: true,
|
||||||
|
x_fill: false,
|
||||||
|
y_fill: false,
|
||||||
|
x_align: x_alignment,
|
||||||
|
y_align: St.Align.MIDDLE });
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
addButton: function(buttonInfo) {
|
addButton: function(buttonInfo, layoutInfo) {
|
||||||
let label = buttonInfo['label']
|
let label = buttonInfo['label'];
|
||||||
let action = buttonInfo['action'];
|
let action = buttonInfo['action'];
|
||||||
let key = buttonInfo['key'];
|
let key = buttonInfo['key'];
|
||||||
let isDefault = buttonInfo['default'];
|
let isDefault = buttonInfo['default'];
|
||||||
@@ -161,12 +170,10 @@ const ModalDialog = new Lang.Class({
|
|||||||
else
|
else
|
||||||
keys = [];
|
keys = [];
|
||||||
|
|
||||||
let button = new St.Button({ style_class: 'modal-dialog-linked-button',
|
let button = new St.Button({ style_class: 'modal-dialog-button button',
|
||||||
button_mask: St.ButtonMask.ONE | St.ButtonMask.THREE,
|
button_mask: St.ButtonMask.ONE | St.ButtonMask.THREE,
|
||||||
reactive: true,
|
reactive: true,
|
||||||
can_focus: true,
|
can_focus: true,
|
||||||
x_expand: true,
|
|
||||||
y_expand: true,
|
|
||||||
label: label });
|
label: label });
|
||||||
button.connect('clicked', action);
|
button.connect('clicked', action);
|
||||||
|
|
||||||
@@ -181,11 +188,47 @@ const ModalDialog = new Lang.Class({
|
|||||||
for (let i in keys)
|
for (let i in keys)
|
||||||
this._buttonKeys[keys[i]] = buttonInfo;
|
this._buttonKeys[keys[i]] = buttonInfo;
|
||||||
|
|
||||||
this.buttonLayout.add_actor(button);
|
this.buttonLayout.add(button, layoutInfo);
|
||||||
|
|
||||||
return button;
|
return button;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
placeSpinner: function(layoutInfo) {
|
||||||
|
let spinnerIcon = Gio.File.new_for_uri('resource:///org/gnome/shell/theme/process-working.svg');
|
||||||
|
this._workSpinner = new Animation.AnimatedIcon(spinnerIcon, WORK_SPINNER_ICON_SIZE);
|
||||||
|
this._workSpinner.actor.opacity = 0;
|
||||||
|
this._workSpinner.actor.show();
|
||||||
|
|
||||||
|
this.buttonLayout.add(this._workSpinner.actor, layoutInfo);
|
||||||
|
},
|
||||||
|
|
||||||
|
setWorking: function(working) {
|
||||||
|
if (!this._workSpinner)
|
||||||
|
return;
|
||||||
|
|
||||||
|
Tweener.removeTweens(this._workSpinner.actor);
|
||||||
|
if (working) {
|
||||||
|
this._workSpinner.play();
|
||||||
|
Tweener.addTween(this._workSpinner.actor,
|
||||||
|
{ opacity: 255,
|
||||||
|
delay: WORK_SPINNER_ANIMATION_DELAY,
|
||||||
|
time: WORK_SPINNER_ANIMATION_TIME,
|
||||||
|
transition: 'linear'
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
Tweener.addTween(this._workSpinner.actor,
|
||||||
|
{ opacity: 0,
|
||||||
|
time: WORK_SPINNER_ANIMATION_TIME,
|
||||||
|
transition: 'linear',
|
||||||
|
onCompleteScope: this,
|
||||||
|
onComplete: function() {
|
||||||
|
if (this._workSpinner)
|
||||||
|
this._workSpinner.stop();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
_onKeyPressEvent: function(object, event) {
|
_onKeyPressEvent: function(object, event) {
|
||||||
this._pressedKey = event.get_key_symbol();
|
this._pressedKey = event.get_key_symbol();
|
||||||
return Clutter.EVENT_PROPAGATE;
|
return Clutter.EVENT_PROPAGATE;
|
||||||
|
|||||||
@@ -95,7 +95,6 @@ const AppMenuButton = new Lang.Class({
|
|||||||
this._startingApps = [];
|
this._startingApps = [];
|
||||||
|
|
||||||
this._menuManager = panel.menuManager;
|
this._menuManager = panel.menuManager;
|
||||||
this._gtkSettings = Gtk.Settings.get_default();
|
|
||||||
this._targetApp = null;
|
this._targetApp = null;
|
||||||
this._appMenuNotifyId = 0;
|
this._appMenuNotifyId = 0;
|
||||||
this._actionGroupNotifyId = 0;
|
this._actionGroupNotifyId = 0;
|
||||||
@@ -124,14 +123,11 @@ const AppMenuButton = new Lang.Class({
|
|||||||
this._arrow = PopupMenu.arrowIcon(St.Side.BOTTOM);
|
this._arrow = PopupMenu.arrowIcon(St.Side.BOTTOM);
|
||||||
this._container.add_actor(this._arrow);
|
this._container.add_actor(this._arrow);
|
||||||
|
|
||||||
this._visible = this._gtkSettings.gtk_shell_shows_app_menu &&
|
this._visible = !Main.overview.visible;
|
||||||
!Main.overview.visible;
|
|
||||||
if (!this._visible)
|
if (!this._visible)
|
||||||
this.actor.hide();
|
this.actor.hide();
|
||||||
this._overviewHidingId = Main.overview.connect('hiding', Lang.bind(this, this._sync));
|
this._overviewHidingId = Main.overview.connect('hiding', Lang.bind(this, this._sync));
|
||||||
this._overviewShowingId = Main.overview.connect('showing', Lang.bind(this, this._sync));
|
this._overviewShowingId = Main.overview.connect('showing', Lang.bind(this, this._sync));
|
||||||
this._showsAppMenuId = this._gtkSettings.connect('notify::gtk-shell-shows-app-menu',
|
|
||||||
Lang.bind(this, this._sync));
|
|
||||||
|
|
||||||
this._stop = true;
|
this._stop = true;
|
||||||
|
|
||||||
@@ -309,9 +305,7 @@ const AppMenuButton = new Lang.Class({
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
let visible = (this._targetApp != null &&
|
let visible = (this._targetApp != null && !Main.overview.visibleTarget);
|
||||||
this._gtkSettings.gtk_shell_shows_app_menu &&
|
|
||||||
!Main.overview.visibleTarget);
|
|
||||||
if (visible)
|
if (visible)
|
||||||
this.show();
|
this.show();
|
||||||
else
|
else
|
||||||
@@ -384,10 +378,6 @@ const AppMenuButton = new Lang.Class({
|
|||||||
Main.overview.disconnect(this._overviewShowingId);
|
Main.overview.disconnect(this._overviewShowingId);
|
||||||
this._overviewShowingId = 0;
|
this._overviewShowingId = 0;
|
||||||
}
|
}
|
||||||
if (this._showsAppMenuId > 0) {
|
|
||||||
this._gtkSettings.disconnect(this._showsAppMenuId);
|
|
||||||
this._showsAppMenuId = 0;
|
|
||||||
}
|
|
||||||
if (this._switchWorkspaceNotifyId > 0) {
|
if (this._switchWorkspaceNotifyId > 0) {
|
||||||
global.window_manager.disconnect(this._switchWorkspaceNotifyId);
|
global.window_manager.disconnect(this._switchWorkspaceNotifyId);
|
||||||
this._switchWorkspaceNotifyId = 0;
|
this._switchWorkspaceNotifyId = 0;
|
||||||
@@ -459,8 +449,7 @@ const ActivitiesButton = new Lang.Class({
|
|||||||
|
|
||||||
if (event.type() == Clutter.EventType.TOUCH_END ||
|
if (event.type() == Clutter.EventType.TOUCH_END ||
|
||||||
event.type() == Clutter.EventType.BUTTON_RELEASE)
|
event.type() == Clutter.EventType.BUTTON_RELEASE)
|
||||||
if (Main.overview.shouldToggleByCornerOrButton())
|
Main.overview.toggle();
|
||||||
Main.overview.toggle();
|
|
||||||
|
|
||||||
return Clutter.EVENT_PROPAGATE;
|
return Clutter.EVENT_PROPAGATE;
|
||||||
},
|
},
|
||||||
@@ -468,8 +457,7 @@ const ActivitiesButton = new Lang.Class({
|
|||||||
_onKeyRelease: function(actor, event) {
|
_onKeyRelease: function(actor, event) {
|
||||||
let symbol = event.get_key_symbol();
|
let symbol = event.get_key_symbol();
|
||||||
if (symbol == Clutter.KEY_Return || symbol == Clutter.KEY_space) {
|
if (symbol == Clutter.KEY_Return || symbol == Clutter.KEY_space) {
|
||||||
if (Main.overview.shouldToggleByCornerOrButton())
|
Main.overview.toggle();
|
||||||
Main.overview.toggle();
|
|
||||||
}
|
}
|
||||||
return Clutter.EVENT_PROPAGATE;
|
return Clutter.EVENT_PROPAGATE;
|
||||||
},
|
},
|
||||||
@@ -654,50 +642,14 @@ const PanelCorner = new Lang.Class({
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
const AggregateLayout = new Lang.Class({
|
|
||||||
Name: 'AggregateLayout',
|
|
||||||
Extends: Clutter.BoxLayout,
|
|
||||||
|
|
||||||
_init: function(params) {
|
|
||||||
if (!params)
|
|
||||||
params = {};
|
|
||||||
params['orientation'] = Clutter.Orientation.VERTICAL;
|
|
||||||
this.parent(params);
|
|
||||||
|
|
||||||
this._sizeChildren = [];
|
|
||||||
},
|
|
||||||
|
|
||||||
addSizeChild: function(actor) {
|
|
||||||
this._sizeChildren.push(actor);
|
|
||||||
this.layout_changed();
|
|
||||||
},
|
|
||||||
|
|
||||||
vfunc_get_preferred_width: function(container, forHeight) {
|
|
||||||
let themeNode = container.get_theme_node();
|
|
||||||
let minWidth = themeNode.get_min_width();
|
|
||||||
let natWidth = minWidth;
|
|
||||||
|
|
||||||
for (let i = 0; i < this._sizeChildren.length; i++) {
|
|
||||||
let child = this._sizeChildren[i];
|
|
||||||
let [childMin, childNat] = child.get_preferred_width(forHeight);
|
|
||||||
minWidth = Math.max(minWidth, childMin);
|
|
||||||
natWidth = Math.max(minWidth, childNat);
|
|
||||||
}
|
|
||||||
return [minWidth, natWidth];
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
const AggregateMenu = new Lang.Class({
|
const AggregateMenu = new Lang.Class({
|
||||||
Name: 'AggregateMenu',
|
Name: 'AggregateMenu',
|
||||||
Extends: PanelMenu.Button,
|
Extends: PanelMenu.Button,
|
||||||
|
|
||||||
_init: function() {
|
_init: function() {
|
||||||
this.parent(0.0, C_("System menu in the top bar", "System"), false);
|
this.parent(0.0, _("Settings"), false);
|
||||||
this.menu.actor.add_style_class_name('aggregate-menu');
|
this.menu.actor.add_style_class_name('aggregate-menu');
|
||||||
|
|
||||||
let menuLayout = new AggregateLayout();
|
|
||||||
this.menu.box.set_layout_manager(menuLayout);
|
|
||||||
|
|
||||||
this._indicators = new St.BoxLayout({ style_class: 'panel-status-indicators-box' });
|
this._indicators = new St.BoxLayout({ style_class: 'panel-status-indicators-box' });
|
||||||
this.actor.add_child(this._indicators);
|
this.actor.add_child(this._indicators);
|
||||||
|
|
||||||
@@ -745,12 +697,8 @@ const AggregateMenu = new Lang.Class({
|
|||||||
this.menu.addMenuItem(this._location.menu);
|
this.menu.addMenuItem(this._location.menu);
|
||||||
this.menu.addMenuItem(this._rfkill.menu);
|
this.menu.addMenuItem(this._rfkill.menu);
|
||||||
this.menu.addMenuItem(this._power.menu);
|
this.menu.addMenuItem(this._power.menu);
|
||||||
|
this.menu.addMenuItem(new PopupMenu.PopupSeparatorMenuItem());
|
||||||
this.menu.addMenuItem(this._system.menu);
|
this.menu.addMenuItem(this._system.menu);
|
||||||
|
|
||||||
menuLayout.addSizeChild(this._location.menu.actor);
|
|
||||||
menuLayout.addSizeChild(this._rfkill.menu.actor);
|
|
||||||
menuLayout.addSizeChild(this._power.menu.actor);
|
|
||||||
menuLayout.addSizeChild(this._system.menu.actor);
|
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
@@ -396,7 +396,6 @@ const PopupImageMenuItem = new Lang.Class({
|
|||||||
this.actor.add_child(this.label);
|
this.actor.add_child(this.label);
|
||||||
this._icon = new St.Icon({ style_class: 'popup-menu-icon' });
|
this._icon = new St.Icon({ style_class: 'popup-menu-icon' });
|
||||||
this.actor.add_child(this._icon, { align: St.Align.END });
|
this.actor.add_child(this._icon, { align: St.Align.END });
|
||||||
this.actor.label_actor = this.label;
|
|
||||||
|
|
||||||
this.setIcon(iconName);
|
this.setIcon(iconName);
|
||||||
},
|
},
|
||||||
@@ -1060,6 +1059,11 @@ const PopupSubMenuMenuItem = new Lang.Class({
|
|||||||
let expander = new St.Bin({ style_class: 'popup-menu-item-expander' });
|
let expander = new St.Bin({ style_class: 'popup-menu-item-expander' });
|
||||||
this.actor.add(expander, { expand: true });
|
this.actor.add(expander, { expand: true });
|
||||||
|
|
||||||
|
this.status = new St.Label({ style_class: 'popup-status-menu-item',
|
||||||
|
y_expand: true,
|
||||||
|
y_align: Clutter.ActorAlign.CENTER });
|
||||||
|
this.actor.add_child(this.status);
|
||||||
|
|
||||||
this._triangle = arrowIcon(St.Side.RIGHT);
|
this._triangle = arrowIcon(St.Side.RIGHT);
|
||||||
this._triangle.pivot_point = new Clutter.Point({ x: 0.5, y: 0.6 });
|
this._triangle.pivot_point = new Clutter.Point({ x: 0.5, y: 0.6 });
|
||||||
|
|
||||||
@@ -1146,16 +1150,6 @@ const PopupSubMenuMenuItem = new Lang.Class({
|
|||||||
this.actor.remove_style_pseudo_class ('active');
|
this.actor.remove_style_pseudo_class ('active');
|
||||||
this._setOpenState(!this._getOpenState());
|
this._setOpenState(!this._getOpenState());
|
||||||
return Clutter.EVENT_PROPAGATE;
|
return Clutter.EVENT_PROPAGATE;
|
||||||
},
|
|
||||||
|
|
||||||
_onTouchEvent: function(actor, event) {
|
|
||||||
if (event.type() == Clutter.EventType.TOUCH_END) {
|
|
||||||
// Since we override the parent, we need to manage what the parent does
|
|
||||||
// with the active style class
|
|
||||||
this.actor.remove_style_pseudo_class ('active');
|
|
||||||
this._setOpenState(!this._getOpenState());
|
|
||||||
}
|
|
||||||
return Clutter.EVENT_PROPAGATE;
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
@@ -61,7 +61,6 @@ const RunDialog = new Lang.Class({
|
|||||||
|
|
||||||
// rt is short for "reload theme"
|
// rt is short for "reload theme"
|
||||||
'rt': Lang.bind(this, function() {
|
'rt': Lang.bind(this, function() {
|
||||||
Main.reloadThemeResource();
|
|
||||||
Main.loadTheme();
|
Main.loadTheme();
|
||||||
})
|
})
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -1,8 +1,11 @@
|
|||||||
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
||||||
|
|
||||||
|
const Clutter = imports.gi.Clutter;
|
||||||
|
const GLib = imports.gi.GLib;
|
||||||
const Gio = imports.gi.Gio;
|
const Gio = imports.gi.Gio;
|
||||||
const GnomeBluetooth = imports.gi.GnomeBluetooth;
|
const GnomeBluetooth = imports.gi.GnomeBluetooth;
|
||||||
const Lang = imports.lang;
|
const Lang = imports.lang;
|
||||||
|
const St = imports.gi.St;
|
||||||
|
|
||||||
const Main = imports.ui.main;
|
const Main = imports.ui.main;
|
||||||
const PanelMenu = imports.ui.panelMenu;
|
const PanelMenu = imports.ui.panelMenu;
|
||||||
@@ -20,8 +23,6 @@ const RfkillManagerInterface = '<node> \
|
|||||||
|
|
||||||
const RfkillManagerProxy = Gio.DBusProxy.makeProxyWrapper(RfkillManagerInterface);
|
const RfkillManagerProxy = Gio.DBusProxy.makeProxyWrapper(RfkillManagerInterface);
|
||||||
|
|
||||||
const HAD_BLUETOOTH_DEVICES_SETUP = 'had-bluetooth-devices-setup';
|
|
||||||
|
|
||||||
const Indicator = new Lang.Class({
|
const Indicator = new Lang.Class({
|
||||||
Name: 'BTIndicator',
|
Name: 'BTIndicator',
|
||||||
Extends: PanelMenu.SystemIndicator,
|
Extends: PanelMenu.SystemIndicator,
|
||||||
@@ -31,7 +32,6 @@ const Indicator = new Lang.Class({
|
|||||||
|
|
||||||
this._indicator = this._addIndicator();
|
this._indicator = this._addIndicator();
|
||||||
this._indicator.icon_name = 'bluetooth-active-symbolic';
|
this._indicator.icon_name = 'bluetooth-active-symbolic';
|
||||||
this._hadSetupDevices = global.settings.get_boolean(HAD_BLUETOOTH_DEVICES_SETUP);
|
|
||||||
|
|
||||||
this._proxy = new RfkillManagerProxy(Gio.DBus.session, BUS_NAME, OBJECT_PATH,
|
this._proxy = new RfkillManagerProxy(Gio.DBus.session, BUS_NAME, OBJECT_PATH,
|
||||||
Lang.bind(this, function(proxy, error) {
|
Lang.bind(this, function(proxy, error) {
|
||||||
@@ -44,15 +44,13 @@ const Indicator = new Lang.Class({
|
|||||||
}));
|
}));
|
||||||
this._proxy.connect('g-properties-changed', Lang.bind(this, this._sync));
|
this._proxy.connect('g-properties-changed', Lang.bind(this, this._sync));
|
||||||
|
|
||||||
|
// The Bluetooth menu only appears when Bluetooth is in use,
|
||||||
|
// so just statically build it with a "Turn Off" menu item.
|
||||||
this._item = new PopupMenu.PopupSubMenuMenuItem(_("Bluetooth"), true);
|
this._item = new PopupMenu.PopupSubMenuMenuItem(_("Bluetooth"), true);
|
||||||
this._item.icon.icon_name = 'bluetooth-active-symbolic';
|
this._item.icon.icon_name = 'bluetooth-active-symbolic';
|
||||||
|
this._item.menu.addAction(_("Turn Off"), Lang.bind(this, function() {
|
||||||
this._toggleItem = new PopupMenu.PopupMenuItem('');
|
this._proxy.BluetoothAirplaneMode = true;
|
||||||
this._toggleItem.connect('activate', Lang.bind(this, function() {
|
|
||||||
this._proxy.BluetoothAirplaneMode = !this._proxy.BluetoothAirplaneMode;
|
|
||||||
}));
|
}));
|
||||||
this._item.menu.addMenuItem(this._toggleItem);
|
|
||||||
|
|
||||||
this._item.menu.addSettingsAction(_("Bluetooth Settings"), 'gnome-bluetooth-panel.desktop');
|
this._item.menu.addSettingsAction(_("Bluetooth Settings"), 'gnome-bluetooth-panel.desktop');
|
||||||
this.menu.addMenuItem(this._item);
|
this.menu.addMenuItem(this._item);
|
||||||
|
|
||||||
@@ -70,75 +68,41 @@ const Indicator = new Lang.Class({
|
|||||||
while (ret) {
|
while (ret) {
|
||||||
let isDefault = this._model.get_value(iter,
|
let isDefault = this._model.get_value(iter,
|
||||||
GnomeBluetooth.Column.DEFAULT);
|
GnomeBluetooth.Column.DEFAULT);
|
||||||
let isPowered = this._model.get_value(iter,
|
if (isDefault)
|
||||||
GnomeBluetooth.Column.POWERED);
|
|
||||||
if (isDefault && isPowered)
|
|
||||||
return iter;
|
return iter;
|
||||||
ret = this._model.iter_next(iter);
|
ret = this._model.iter_next(iter);
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
},
|
},
|
||||||
|
|
||||||
// nDevices is the number of devices setup for the current default
|
_getNConnectedDevices: function() {
|
||||||
// adapter if one exists and is powered. If unpowered or unavailable,
|
|
||||||
// nDevice is "1" if it had setup devices associated to it the last
|
|
||||||
// time it was seen, and "-1" if not.
|
|
||||||
//
|
|
||||||
// nConnectedDevices is the number of devices connected to the default
|
|
||||||
// adapter if one exists and is powered, or -1 if it's not available.
|
|
||||||
_getNDevices: function() {
|
|
||||||
let adapter = this._getDefaultAdapter();
|
let adapter = this._getDefaultAdapter();
|
||||||
if (!adapter)
|
if (!adapter)
|
||||||
return [ this._hadSetupDevices ? 1 : -1, -1 ];
|
return 0;
|
||||||
|
|
||||||
let nConnectedDevices = 0;
|
|
||||||
let nDevices = 0;
|
let nDevices = 0;
|
||||||
let [ret, iter] = this._model.iter_children(adapter);
|
let [ret, iter] = this._model.iter_children(adapter);
|
||||||
while (ret) {
|
while (ret) {
|
||||||
let isConnected = this._model.get_value(iter,
|
let isConnected = this._model.get_value(iter,
|
||||||
GnomeBluetooth.Column.CONNECTED);
|
GnomeBluetooth.Column.CONNECTED);
|
||||||
if (isConnected)
|
if (isConnected)
|
||||||
nConnectedDevices++;
|
|
||||||
|
|
||||||
let isPaired = this._model.get_value(iter,
|
|
||||||
GnomeBluetooth.Column.PAIRED);
|
|
||||||
let isTrusted = this._model.get_value(iter,
|
|
||||||
GnomeBluetooth.Column.TRUSTED);
|
|
||||||
if (isPaired || isTrusted)
|
|
||||||
nDevices++;
|
nDevices++;
|
||||||
ret = this._model.iter_next(iter);
|
ret = this._model.iter_next(iter);
|
||||||
}
|
}
|
||||||
|
return nDevices;
|
||||||
if (this._hadSetupDevices != (nDevices > 0)) {
|
|
||||||
this._hadSetupDevices = !this._hadSetupDevices;
|
|
||||||
global.settings.set_boolean(HAD_BLUETOOTH_DEVICES_SETUP, this._hadSetupDevices);
|
|
||||||
}
|
|
||||||
|
|
||||||
return [ nDevices, nConnectedDevices];
|
|
||||||
},
|
},
|
||||||
|
|
||||||
_sync: function() {
|
_sync: function() {
|
||||||
let [ nDevices, nConnectedDevices ] = this._getNDevices();
|
let nDevices = this._getNConnectedDevices();
|
||||||
let sensitive = !Main.sessionMode.isLocked && !Main.sessionMode.isGreeter;
|
let sensitive = !Main.sessionMode.isLocked && !Main.sessionMode.isGreeter;
|
||||||
|
|
||||||
this.menu.setSensitive(sensitive);
|
this.menu.setSensitive(sensitive);
|
||||||
this._indicator.visible = nConnectedDevices > 0;
|
this._indicator.visible = nDevices > 0;
|
||||||
|
this._item.actor.visible = this._proxy.BluetoothHasAirplaneMode && !this._proxy.BluetoothAirplaneMode;
|
||||||
|
|
||||||
// Remember if there were setup devices and show the menu
|
|
||||||
// if we've seen setup devices and we're not hard blocked
|
|
||||||
if (nDevices > 0)
|
if (nDevices > 0)
|
||||||
this._item.actor.visible = !this._proxy.BluetoothHardwareAirplaneMode;
|
this._item.status.text = ngettext("%d Connected Device", "%d Connected Devices", nDevices).format(nDevices);
|
||||||
else
|
else
|
||||||
this._item.actor.visible = this._proxy.BluetoothHasAirplaneMode && !this._proxy.BluetoothAirplaneMode;
|
this._item.status.text = _("Not Connected");
|
||||||
|
|
||||||
if (nConnectedDevices > 0)
|
|
||||||
/* Translators: this is the number of connected bluetooth devices */
|
|
||||||
this._item.label.text = ngettext("%d Connected", "%d Connected", nConnectedDevices).format(nConnectedDevices);
|
|
||||||
else if (nConnectedDevices == -1)
|
|
||||||
this._item.label.text = _("Off");
|
|
||||||
else
|
|
||||||
this._item.label.text = _("Not In Use");
|
|
||||||
|
|
||||||
this._toggleItem.label.text = this._proxy.BluetoothAirplaneMode ? _("Turn On") : _("Turn Off");
|
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -62,13 +62,13 @@ const Indicator = new Lang.Class({
|
|||||||
this._indicator = this._addIndicator();
|
this._indicator = this._addIndicator();
|
||||||
this._indicator.icon_name = 'find-location-symbolic';
|
this._indicator.icon_name = 'find-location-symbolic';
|
||||||
|
|
||||||
this._item = new PopupMenu.PopupSubMenuMenuItem('', true);
|
this._item = new PopupMenu.PopupSubMenuMenuItem(_("Location"), true);
|
||||||
this._item.icon.icon_name = 'find-location-symbolic';
|
this._item.icon.icon_name = 'find-location-symbolic';
|
||||||
|
|
||||||
this._agent = Gio.DBusExportedObject.wrapJSObject(AgentIface, this);
|
this._agent = Gio.DBusExportedObject.wrapJSObject(AgentIface, this);
|
||||||
this._agent.export(Gio.DBus.system, '/org/freedesktop/GeoClue2/Agent');
|
this._agent.export(Gio.DBus.system, '/org/freedesktop/GeoClue2/Agent');
|
||||||
|
|
||||||
this._item.label.text = _("Location Enabled");
|
this._item.status.text = _("Enabled");
|
||||||
this._onOffAction = this._item.menu.addAction(_("Disable"), Lang.bind(this, this._onOnOffAction));
|
this._onOffAction = this._item.menu.addAction(_("Disable"), Lang.bind(this, this._onOnOffAction));
|
||||||
this._item.menu.addSettingsAction(_("Privacy Settings"), 'gnome-privacy-panel.desktop');
|
this._item.menu.addSettingsAction(_("Privacy Settings"), 'gnome-privacy-panel.desktop');
|
||||||
|
|
||||||
@@ -173,11 +173,10 @@ const Indicator = new Lang.Class({
|
|||||||
|
|
||||||
_updateMenuLabels: function() {
|
_updateMenuLabels: function() {
|
||||||
if (this._settings.get_boolean(ENABLED)) {
|
if (this._settings.get_boolean(ENABLED)) {
|
||||||
this._item.label.text = this._indicator.visible ? _("Location In Use")
|
this._item.status.text = this._indicator.visible ? _("In Use") : _("Enabled");
|
||||||
: _("Location Enabled");
|
|
||||||
this._onOffAction.label.text = _("Disable");
|
this._onOffAction.label.text = _("Disable");
|
||||||
} else {
|
} else {
|
||||||
this._item.label.text = _("Location Disabled");
|
this._item.status.text = _("Disabled");
|
||||||
this._onOffAction.label.text = _("Enable");
|
this._onOffAction.label.text = _("Enable");
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -257,8 +257,16 @@ const NMConnectionSection = new Lang.Class({
|
|||||||
this._radioSection.actor.visible = (nItems > 1);
|
this._radioSection.actor.visible = (nItems > 1);
|
||||||
this._labelSection.actor.visible = (nItems == 1);
|
this._labelSection.actor.visible = (nItems == 1);
|
||||||
|
|
||||||
this.item.label.text = this._getStatus();
|
this.item.status.text = this._getStatus();
|
||||||
this.item.icon.icon_name = this._getMenuIcon();
|
this.item.icon.icon_name = this._getMenuIcon();
|
||||||
|
|
||||||
|
// desc can be undefined at cold-plug, before we called
|
||||||
|
// NMGtk.disambiguate_device_names() at least once
|
||||||
|
let desc = this._getDescription();
|
||||||
|
if (desc)
|
||||||
|
this.item.label.text = desc;
|
||||||
|
else
|
||||||
|
this.item.label.text = '';
|
||||||
},
|
},
|
||||||
|
|
||||||
_getMenuIcon: function() {
|
_getMenuIcon: function() {
|
||||||
@@ -347,7 +355,6 @@ const NMConnectionDevice = new Lang.Class({
|
|||||||
this.parent(client);
|
this.parent(client);
|
||||||
this._device = device;
|
this._device = device;
|
||||||
this._settings = settings;
|
this._settings = settings;
|
||||||
this._description = '';
|
|
||||||
|
|
||||||
this._autoConnectItem = this.item.menu.addAction(_("Connect"), Lang.bind(this, this._autoConnect));
|
this._autoConnectItem = this.item.menu.addAction(_("Connect"), Lang.bind(this, this._autoConnect));
|
||||||
this._deactivateItem = this._radioSection.addAction(_("Turn Off"), Lang.bind(this, this.deactivateConnection));
|
this._deactivateItem = this._radioSection.addAction(_("Turn Off"), Lang.bind(this, this.deactivateConnection));
|
||||||
@@ -447,44 +454,38 @@ const NMConnectionDevice = new Lang.Class({
|
|||||||
|
|
||||||
switch(this._device.state) {
|
switch(this._device.state) {
|
||||||
case NetworkManager.DeviceState.DISCONNECTED:
|
case NetworkManager.DeviceState.DISCONNECTED:
|
||||||
/* Translators: %s is a network identifier */
|
return _("Off");
|
||||||
return _("%s Off").format(this._getDescription());
|
|
||||||
case NetworkManager.DeviceState.ACTIVATED:
|
case NetworkManager.DeviceState.ACTIVATED:
|
||||||
/* Translators: %s is a network identifier */
|
return _("Connected");
|
||||||
return _("%s Connected").format(this._getDescription());
|
|
||||||
case NetworkManager.DeviceState.UNMANAGED:
|
case NetworkManager.DeviceState.UNMANAGED:
|
||||||
/* Translators: this is for network devices that are physically present but are not
|
/* Translators: this is for network devices that are physically present but are not
|
||||||
under NetworkManager's control (and thus cannot be used in the menu);
|
under NetworkManager's control (and thus cannot be used in the menu) */
|
||||||
%s is a network identifier */
|
return _("Unmanaged");
|
||||||
return _("%s Unmanaged").format(this._getDescription());
|
|
||||||
case NetworkManager.DeviceState.DEACTIVATING:
|
case NetworkManager.DeviceState.DEACTIVATING:
|
||||||
/* Translators: %s is a network identifier */
|
return _("Disconnecting");
|
||||||
return _("%s Disconnecting").format(this._getDescription());
|
|
||||||
case NetworkManager.DeviceState.PREPARE:
|
case NetworkManager.DeviceState.PREPARE:
|
||||||
case NetworkManager.DeviceState.CONFIG:
|
case NetworkManager.DeviceState.CONFIG:
|
||||||
case NetworkManager.DeviceState.IP_CONFIG:
|
case NetworkManager.DeviceState.IP_CONFIG:
|
||||||
case NetworkManager.DeviceState.IP_CHECK:
|
case NetworkManager.DeviceState.IP_CHECK:
|
||||||
case NetworkManager.DeviceState.SECONDARIES:
|
case NetworkManager.DeviceState.SECONDARIES:
|
||||||
/* Translators: %s is a network identifier */
|
return _("Connecting");
|
||||||
return _("%s Connecting").format(this._getDescription());
|
|
||||||
case NetworkManager.DeviceState.NEED_AUTH:
|
case NetworkManager.DeviceState.NEED_AUTH:
|
||||||
/* Translators: this is for network connections that require some kind of key or password; %s is a network identifier */
|
/* Translators: this is for network connections that require some kind of key or password */
|
||||||
return _("%s Requires Authentication").format(this._getDescription());
|
return _("Authentication required");
|
||||||
case NetworkManager.DeviceState.UNAVAILABLE:
|
case NetworkManager.DeviceState.UNAVAILABLE:
|
||||||
// This state is actually a compound of various states (generically unavailable,
|
// This state is actually a compound of various states (generically unavailable,
|
||||||
// firmware missing), that are exposed by different properties (whose state may
|
// firmware missing), that are exposed by different properties (whose state may
|
||||||
// or may not updated when we receive state-changed).
|
// or may not updated when we receive state-changed).
|
||||||
if (this._device.firmware_missing) {
|
if (this._device.firmware_missing) {
|
||||||
/* Translators: this is for devices that require some kind of firmware or kernel
|
/* Translators: this is for devices that require some kind of firmware or kernel
|
||||||
module, which is missing; %s is a network identifier */
|
module, which is missing */
|
||||||
return _("Firmware Missing For %s").format(this._getDescription());
|
return _("Firmware missing");
|
||||||
}
|
}
|
||||||
/* Translators: this is for a network device that cannot be activated (for example it
|
/* Translators: this is for a network device that cannot be activated (for example it
|
||||||
is disabled by rfkill, or it has no coverage; %s is a network identifier */
|
is disabled by rfkill, or it has no coverage */
|
||||||
return _("%s Unavailable").format(this._getDescription());
|
return _("Unavailable");
|
||||||
case NetworkManager.DeviceState.FAILED:
|
case NetworkManager.DeviceState.FAILED:
|
||||||
/* Translators: %s is a network identifier */
|
return _("Connection failed");
|
||||||
return _("%s Connection Failed").format(this._getDescription());
|
|
||||||
default:
|
default:
|
||||||
log('Device state invalid, is %d'.format(this._device.state));
|
log('Device state invalid, is %d'.format(this._device.state));
|
||||||
return 'invalid';
|
return 'invalid';
|
||||||
@@ -584,12 +585,11 @@ const NMDeviceModem = new Lang.Class({
|
|||||||
|
|
||||||
_getStatus: function() {
|
_getStatus: function() {
|
||||||
if (!this._client.wwan_hardware_enabled)
|
if (!this._client.wwan_hardware_enabled)
|
||||||
/* Translators: %s is a network identifier */
|
return _("Hardware Disabled");
|
||||||
return _("%s Hardware Disabled").format(this._getDescription());
|
|
||||||
else if (!this._client.wwan_enabled)
|
else if (!this._client.wwan_enabled)
|
||||||
/* Translators: this is for a network device that cannot be activated
|
/* Translators: this is for a network device that cannot be activated
|
||||||
because it's disabled by rfkill (airplane mode); %s is a network identifier */
|
because it's disabled by rfkill (airplane mode) */
|
||||||
return _("%s Disabled").format(this._getDescription());
|
return _("Disabled");
|
||||||
else if (this._device.state == NetworkManager.DeviceState.ACTIVATED &&
|
else if (this._device.state == NetworkManager.DeviceState.ACTIVATED &&
|
||||||
this._mobileDevice && this._mobileDevice.operator_name)
|
this._mobileDevice && this._mobileDevice.operator_name)
|
||||||
return this._mobileDevice.operator_name;
|
return this._mobileDevice.operator_name;
|
||||||
@@ -1279,8 +1279,9 @@ const NMDeviceWireless = new Lang.Class({
|
|||||||
this._toggleItem.label.text = this._client.wireless_enabled ? _("Turn Off") : _("Turn On");
|
this._toggleItem.label.text = this._client.wireless_enabled ? _("Turn Off") : _("Turn On");
|
||||||
this._toggleItem.actor.visible = this._client.wireless_hardware_enabled;
|
this._toggleItem.actor.visible = this._client.wireless_hardware_enabled;
|
||||||
|
|
||||||
|
this.item.status.text = this._getStatus();
|
||||||
this.item.icon.icon_name = this._getMenuIcon();
|
this.item.icon.icon_name = this._getMenuIcon();
|
||||||
this.item.label.text = this._getStatus();
|
this.item.label.text = this._description;
|
||||||
},
|
},
|
||||||
|
|
||||||
setDeviceDescription: function(desc) {
|
setDeviceDescription: function(desc) {
|
||||||
@@ -1292,23 +1293,18 @@ const NMDeviceWireless = new Lang.Class({
|
|||||||
let ap = this._device.active_access_point;
|
let ap = this._device.active_access_point;
|
||||||
|
|
||||||
if (this._isHotSpotMaster())
|
if (this._isHotSpotMaster())
|
||||||
/* Translators: %s is a network identifier */
|
return _("Hotspot Active");
|
||||||
return _("%s Hotspot Active").format(this._description);
|
|
||||||
else if (this._device.state >= NetworkManager.DeviceState.PREPARE &&
|
else if (this._device.state >= NetworkManager.DeviceState.PREPARE &&
|
||||||
this._device.state < NetworkManager.DeviceState.ACTIVATED)
|
this._device.state < NetworkManager.DeviceState.ACTIVATED)
|
||||||
/* Translators: %s is a network identifier */
|
return _("Connecting");
|
||||||
return _("%s Connecting").format(this._description);
|
|
||||||
else if (ap)
|
else if (ap)
|
||||||
return ssidToLabel(ap.get_ssid());
|
return ssidToLabel(ap.get_ssid());
|
||||||
else if (!this._client.wireless_hardware_enabled)
|
else if (!this._client.wireless_hardware_enabled)
|
||||||
/* Translators: %s is a network identifier */
|
return _("Hardware Disabled");
|
||||||
return _("%s Hardware Disabled").format(this._description);
|
|
||||||
else if (!this._client.wireless_enabled)
|
else if (!this._client.wireless_enabled)
|
||||||
/* Translators: %s is a network identifier */
|
return _("Off");
|
||||||
return _("%s Off").format(this._description);
|
|
||||||
else if (this._device.state == NetworkManager.DeviceState.DISCONNECTED)
|
else if (this._device.state == NetworkManager.DeviceState.DISCONNECTED)
|
||||||
/* Translators: %s is a network identifier */
|
return _("Not Connected");
|
||||||
return _("%s Not Connected").format(this._description);
|
|
||||||
else
|
else
|
||||||
return '';
|
return '';
|
||||||
},
|
},
|
||||||
@@ -1510,7 +1506,7 @@ const NMVPNSection = new Lang.Class({
|
|||||||
return item.getName();
|
return item.getName();
|
||||||
}
|
}
|
||||||
|
|
||||||
return _("VPN Off");
|
return _("Off");
|
||||||
},
|
},
|
||||||
|
|
||||||
_getMenuIcon: function() {
|
_getMenuIcon: function() {
|
||||||
|
|||||||
@@ -1,8 +1,6 @@
|
|||||||
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
||||||
|
|
||||||
const Gio = imports.gi.Gio;
|
const Gio = imports.gi.Gio;
|
||||||
const Clutter = imports.gi.Clutter;
|
|
||||||
const St = imports.gi.St;
|
|
||||||
const Lang = imports.lang;
|
const Lang = imports.lang;
|
||||||
const UPower = imports.gi.UPowerGlib;
|
const UPower = imports.gi.UPowerGlib;
|
||||||
|
|
||||||
@@ -27,8 +25,6 @@ const DisplayDeviceInterface = '<node> \
|
|||||||
|
|
||||||
const PowerManagerProxy = Gio.DBusProxy.makeProxyWrapper(DisplayDeviceInterface);
|
const PowerManagerProxy = Gio.DBusProxy.makeProxyWrapper(DisplayDeviceInterface);
|
||||||
|
|
||||||
const SHOW_BATTERY_PERCENTAGE = 'show-battery-percentage';
|
|
||||||
|
|
||||||
const Indicator = new Lang.Class({
|
const Indicator = new Lang.Class({
|
||||||
Name: 'PowerIndicator',
|
Name: 'PowerIndicator',
|
||||||
Extends: PanelMenu.SystemIndicator,
|
Extends: PanelMenu.SystemIndicator,
|
||||||
@@ -36,15 +32,7 @@ const Indicator = new Lang.Class({
|
|||||||
_init: function() {
|
_init: function() {
|
||||||
this.parent();
|
this.parent();
|
||||||
|
|
||||||
this._desktopSettings = new Gio.Settings({ schema_id: 'org.gnome.desktop.interface' });
|
|
||||||
this._desktopSettings.connect('changed::' + SHOW_BATTERY_PERCENTAGE,
|
|
||||||
Lang.bind(this, this._sync));
|
|
||||||
|
|
||||||
this._indicator = this._addIndicator();
|
this._indicator = this._addIndicator();
|
||||||
this._percentageLabel = new St.Label({ y_expand: true,
|
|
||||||
y_align: Clutter.ActorAlign.CENTER });
|
|
||||||
this.indicators.add(this._percentageLabel, { expand: true, y_fill: true });
|
|
||||||
this.indicators.add_style_class_name('power-status');
|
|
||||||
|
|
||||||
this._proxy = new PowerManagerProxy(Gio.DBus.system, BUS_NAME, OBJECT_PATH,
|
this._proxy = new PowerManagerProxy(Gio.DBus.system, BUS_NAME, OBJECT_PATH,
|
||||||
Lang.bind(this, function(proxy, error) {
|
Lang.bind(this, function(proxy, error) {
|
||||||
@@ -95,12 +83,12 @@ const Indicator = new Lang.Class({
|
|||||||
|
|
||||||
if (this._proxy.State == UPower.DeviceState.DISCHARGING) {
|
if (this._proxy.State == UPower.DeviceState.DISCHARGING) {
|
||||||
// Translators: this is <hours>:<minutes> Remaining (<percentage>)
|
// Translators: this is <hours>:<minutes> Remaining (<percentage>)
|
||||||
return _("%d\u2236%02d Remaining (%d\u2009%%)").format(hours, minutes, this._proxy.Percentage);
|
return _("%d\u2236%02d Remaining (%d%%)").format(hours, minutes, this._proxy.Percentage);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this._proxy.State == UPower.DeviceState.CHARGING) {
|
if (this._proxy.State == UPower.DeviceState.CHARGING) {
|
||||||
// Translators: this is <hours>:<minutes> Until Full (<percentage>)
|
// Translators: this is <hours>:<minutes> Until Full (<percentage>)
|
||||||
return _("%d\u2236%02d Until Full (%d\u2009%%)").format(hours, minutes, this._proxy.Percentage);
|
return _("%d\u2236%02d Until Full (%d%%)").format(hours, minutes, this._proxy.Percentage);
|
||||||
}
|
}
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
@@ -111,12 +99,10 @@ const Indicator = new Lang.Class({
|
|||||||
let visible = this._proxy.IsPresent;
|
let visible = this._proxy.IsPresent;
|
||||||
if (visible) {
|
if (visible) {
|
||||||
this._item.actor.show();
|
this._item.actor.show();
|
||||||
this._percentageLabel.visible = this._desktopSettings.get_boolean(SHOW_BATTERY_PERCENTAGE);
|
|
||||||
} else {
|
} else {
|
||||||
// If there's no battery, then we use the power icon.
|
// If there's no battery, then we use the power icon.
|
||||||
this._item.actor.hide();
|
this._item.actor.hide();
|
||||||
this._indicator.icon_name = 'system-shutdown-symbolic';
|
this._indicator.icon_name = 'system-shutdown-symbolic';
|
||||||
this._percentageLabel.hide();
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -125,15 +111,13 @@ const Indicator = new Lang.Class({
|
|||||||
this._indicator.icon_name = icon;
|
this._indicator.icon_name = icon;
|
||||||
this._item.icon.icon_name = icon;
|
this._item.icon.icon_name = icon;
|
||||||
|
|
||||||
// The icon label
|
|
||||||
let label
|
|
||||||
if (this._proxy.State == UPower.DeviceState.FULLY_CHARGED)
|
|
||||||
label = _("%d\u2009%%").format(100);
|
|
||||||
else
|
|
||||||
label = _("%d\u2009%%").format(this._proxy.Percentage);
|
|
||||||
this._percentageLabel.clutter_text.set_markup('<span size="smaller">' + label + '</span>');
|
|
||||||
|
|
||||||
// The status label
|
// The status label
|
||||||
this._item.label.text = this._getStatus();
|
this._item.status.text = this._getStatus();
|
||||||
|
|
||||||
|
// The sub-menu heading
|
||||||
|
if (this._proxy.Type == UPower.DeviceKind.UPS)
|
||||||
|
this._item.label.text = _("UPS");
|
||||||
|
else
|
||||||
|
this._item.label.text = _("Battery");
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -85,8 +85,9 @@ const Indicator = new Lang.Class({
|
|||||||
// The menu only appears when airplane mode is on, so just
|
// The menu only appears when airplane mode is on, so just
|
||||||
// statically build it as if it was on, rather than dynamically
|
// statically build it as if it was on, rather than dynamically
|
||||||
// changing the menu contents.
|
// changing the menu contents.
|
||||||
this._item = new PopupMenu.PopupSubMenuMenuItem(_("Airplane Mode On"), true);
|
this._item = new PopupMenu.PopupSubMenuMenuItem(_("Airplane Mode"), true);
|
||||||
this._item.icon.icon_name = 'airplane-mode-symbolic';
|
this._item.icon.icon_name = 'airplane-mode-symbolic';
|
||||||
|
this._item.status.text = _("On");
|
||||||
this._offItem = this._item.menu.addAction(_("Turn Off"), Lang.bind(this, function() {
|
this._offItem = this._item.menu.addAction(_("Turn Off"), Lang.bind(this, function() {
|
||||||
this._manager.airplaneMode = false;
|
this._manager.airplaneMode = false;
|
||||||
}));
|
}));
|
||||||
|
|||||||
@@ -251,14 +251,8 @@ const Indicator = new Lang.Class({
|
|||||||
let file = Gio.File.new_for_path(iconFile);
|
let file = Gio.File.new_for_path(iconFile);
|
||||||
let gicon = new Gio.FileIcon({ file: file });
|
let gicon = new Gio.FileIcon({ file: file });
|
||||||
this._switchUserSubMenu.icon.gicon = gicon;
|
this._switchUserSubMenu.icon.gicon = gicon;
|
||||||
|
|
||||||
this._switchUserSubMenu.icon.add_style_class_name('user-icon');
|
|
||||||
this._switchUserSubMenu.icon.remove_style_class_name('default-icon');
|
|
||||||
} else {
|
} else {
|
||||||
this._switchUserSubMenu.icon.icon_name = 'avatar-default-symbolic';
|
this._switchUserSubMenu.icon.icon_name = 'avatar-default-symbolic';
|
||||||
|
|
||||||
this._switchUserSubMenu.icon.add_style_class_name('default-icon');
|
|
||||||
this._switchUserSubMenu.icon.remove_style_class_name('user-icon');
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
@@ -350,9 +344,6 @@ const Indicator = new Lang.Class({
|
|||||||
this._switchUserSubMenu.menu.addMenuItem(item);
|
this._switchUserSubMenu.menu.addMenuItem(item);
|
||||||
this._logoutItem = item;
|
this._logoutItem = item;
|
||||||
|
|
||||||
this._switchUserSubMenu.menu.addSettingsAction(_("Account Settings"),
|
|
||||||
'gnome-user-accounts-panel.desktop');
|
|
||||||
|
|
||||||
this._user.connect('notify::is-loaded', Lang.bind(this, this._updateSwitchUserSubMenu));
|
this._user.connect('notify::is-loaded', Lang.bind(this, this._updateSwitchUserSubMenu));
|
||||||
this._user.connect('changed', Lang.bind(this, this._updateSwitchUserSubMenu));
|
this._user.connect('changed', Lang.bind(this, this._updateSwitchUserSubMenu));
|
||||||
|
|
||||||
|
|||||||
@@ -465,12 +465,6 @@ const ViewSelector = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_shouldTriggerSearch: function(symbol) {
|
_shouldTriggerSearch: function(symbol) {
|
||||||
if (symbol == Clutter.Multi_key)
|
|
||||||
return true;
|
|
||||||
|
|
||||||
if (symbol == Clutter.BackSpace && this._searchActive)
|
|
||||||
return true;
|
|
||||||
|
|
||||||
let unicode = Clutter.keysym_to_unicode(symbol);
|
let unicode = Clutter.keysym_to_unicode(symbol);
|
||||||
if (unicode == 0)
|
if (unicode == 0)
|
||||||
return false;
|
return false;
|
||||||
@@ -478,7 +472,7 @@ const ViewSelector = new Lang.Class({
|
|||||||
if (getTermsForSearchString(String.fromCharCode(unicode)).length > 0)
|
if (getTermsForSearchString(String.fromCharCode(unicode)).length > 0)
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
return false;
|
return symbol == Clutter.BackSpace && this._searchActive;
|
||||||
},
|
},
|
||||||
|
|
||||||
startSearch: function(event) {
|
startSearch: function(event) {
|
||||||
|
|||||||
@@ -677,7 +677,6 @@ const WindowManager = new Lang.Class({
|
|||||||
this._minimizing = [];
|
this._minimizing = [];
|
||||||
this._unminimizing = [];
|
this._unminimizing = [];
|
||||||
this._mapping = [];
|
this._mapping = [];
|
||||||
this._resizing = [];
|
|
||||||
this._destroying = [];
|
this._destroying = [];
|
||||||
this._movingWindow = null;
|
this._movingWindow = null;
|
||||||
|
|
||||||
@@ -693,7 +692,6 @@ const WindowManager = new Lang.Class({
|
|||||||
this._minimizeWindowDone(shellwm, actor);
|
this._minimizeWindowDone(shellwm, actor);
|
||||||
this._mapWindowDone(shellwm, actor);
|
this._mapWindowDone(shellwm, actor);
|
||||||
this._destroyWindowDone(shellwm, actor);
|
this._destroyWindowDone(shellwm, actor);
|
||||||
this._sizeChangeWindowDone(shellwm, actor);
|
|
||||||
}));
|
}));
|
||||||
|
|
||||||
this._shellwm.connect('switch-workspace', Lang.bind(this, this._switchWorkspace));
|
this._shellwm.connect('switch-workspace', Lang.bind(this, this._switchWorkspace));
|
||||||
@@ -1220,120 +1218,9 @@ const WindowManager = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_sizeChangeWindow : function(shellwm, actor, whichChange, oldFrameRect, oldBufferRect) {
|
_sizeChangeWindow : function(shellwm, actor, whichChange, oldFrameRect, oldBufferRect) {
|
||||||
let types = [Meta.WindowType.NORMAL];
|
|
||||||
if (!this._shouldAnimateActor(actor, types)) {
|
|
||||||
shellwm.completed_size_change(actor);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (whichChange == Meta.SizeChange.FULLSCREEN)
|
|
||||||
this._fullscreenWindow(shellwm, actor, oldFrameRect, oldBufferRect);
|
|
||||||
else if (whichChange == Meta.SizeChange.UNFULLSCREEN)
|
|
||||||
this._unfullscreenWindow(shellwm, actor, oldFrameRect, oldBufferRect);
|
|
||||||
else
|
|
||||||
shellwm.completed_size_change(actor);
|
|
||||||
},
|
|
||||||
|
|
||||||
_fullscreenWindow: function(shellwm, actor, oldFrameRect, oldBufferRect) {
|
|
||||||
let monitor = Main.layoutManager.monitors[actor.meta_window.get_monitor()];
|
|
||||||
actor.translation_x = oldFrameRect.x - monitor.x;
|
|
||||||
actor.translation_y = oldFrameRect.y - monitor.y;
|
|
||||||
this._fullscreenAnimation(shellwm, actor, oldFrameRect);
|
|
||||||
},
|
|
||||||
|
|
||||||
_unfullscreenWindow: function(shellwm, actor, oldFrameRect, oldBufferRect) {
|
|
||||||
let targetRect = actor.meta_window.get_frame_rect();
|
|
||||||
let monitor = Main.layoutManager.monitors[actor.meta_window.get_monitor()];
|
|
||||||
actor.translation_x = -(targetRect.x - monitor.x);
|
|
||||||
actor.translation_y = -(targetRect.y - monitor.y);
|
|
||||||
this._fullscreenAnimation(shellwm, actor, oldFrameRect);
|
|
||||||
},
|
|
||||||
|
|
||||||
_fullscreenAnimation: function(shellwm, actor, oldFrameRect) {
|
|
||||||
this._resizing.push(actor);
|
|
||||||
|
|
||||||
// Position a clone of the window on top of the old position,
|
|
||||||
// while actor updates are frozen.
|
|
||||||
// Note that the MetaWindow has up to date sizing information for
|
|
||||||
// the new geometry already.
|
|
||||||
let targetRect = actor.meta_window.get_frame_rect();
|
|
||||||
let actorContent = Shell.util_get_content_for_window_actor(actor, oldFrameRect);
|
|
||||||
let actorClone = new St.Widget({ content: actorContent });
|
|
||||||
actorClone.set_offscreen_redirect(Clutter.OffscreenRedirect.ALWAYS);
|
|
||||||
actorClone.set_position(oldFrameRect.x, oldFrameRect.y);
|
|
||||||
actorClone.set_size(oldFrameRect.width, oldFrameRect.height);
|
|
||||||
Main.uiGroup.add_actor(actorClone);
|
|
||||||
|
|
||||||
actor.__fullscreenClone = actorClone;
|
|
||||||
|
|
||||||
let scaleX = targetRect.width / oldFrameRect.width;
|
|
||||||
let scaleY = targetRect.height / oldFrameRect.height;
|
|
||||||
|
|
||||||
// Now scale and fade out the clone
|
|
||||||
Tweener.addTween(actorClone,
|
|
||||||
{ x: targetRect.x,
|
|
||||||
y: targetRect.y,
|
|
||||||
scale_x: scaleX,
|
|
||||||
scale_y: scaleY,
|
|
||||||
opacity: 0,
|
|
||||||
time: WINDOW_ANIMATION_TIME,
|
|
||||||
transition: 'easeOutQuad'
|
|
||||||
});
|
|
||||||
|
|
||||||
// Now set scale the actor to size it as the clone.
|
|
||||||
// Note that the caller of this function already set a translation
|
|
||||||
// on the actor.
|
|
||||||
actor.scale_x = 1 / scaleX;
|
|
||||||
actor.scale_y = 1 / scaleY;
|
|
||||||
|
|
||||||
// Scale it to its actual new size
|
|
||||||
Tweener.addTween(actor,
|
|
||||||
{ scale_x: 1.0,
|
|
||||||
scale_y: 1.0,
|
|
||||||
translation_x: 0,
|
|
||||||
translation_y: 0,
|
|
||||||
time: WINDOW_ANIMATION_TIME,
|
|
||||||
transition: 'easeOutQuad',
|
|
||||||
onComplete: this._sizeChangeWindowDone,
|
|
||||||
onCompleteScope: this,
|
|
||||||
onCompleteParams: [shellwm, actor],
|
|
||||||
onOverwrite: this._sizeChangeWindowOverwritten,
|
|
||||||
onOverwriteScope: this,
|
|
||||||
onOverwriteParams: [shellwm, actor]
|
|
||||||
});
|
|
||||||
|
|
||||||
// Now unfreeze actor updates, to get it to the new size.
|
|
||||||
// It's important that we don't wait until the animation is completed to
|
|
||||||
// do this, otherwise our scale will be applied to the old texture size.
|
|
||||||
shellwm.completed_size_change(actor);
|
shellwm.completed_size_change(actor);
|
||||||
},
|
},
|
||||||
|
|
||||||
_sizeChangeWindowDone: function(shellwm, actor) {
|
|
||||||
if (this._removeEffect(this._resizing, actor)) {
|
|
||||||
Tweener.removeTweens(actor);
|
|
||||||
actor.scale_x = 1.0;
|
|
||||||
actor.scale_y = 1.0;
|
|
||||||
actor.translation_x = 0;
|
|
||||||
actor.translation_y = 0;
|
|
||||||
|
|
||||||
let actorClone = actor.__fullscreenClone;
|
|
||||||
if (actorClone) {
|
|
||||||
actorClone.destroy();
|
|
||||||
delete actor.__fullscreenClone;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
_sizeChangeWindowOverwritten: function(shellwm, actor) {
|
|
||||||
if (this._removeEffect(this._resizing, actor)) {
|
|
||||||
let actorClone = actor.__fullscreenClone;
|
|
||||||
if (actorClone) {
|
|
||||||
actorClone.destroy();
|
|
||||||
delete actor.__fullscreenClone;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
_hasAttachedDialogs: function(window, ignoreWindow) {
|
_hasAttachedDialogs: function(window, ignoreWindow) {
|
||||||
var count = 0;
|
var count = 0;
|
||||||
window.foreach_transient(function(win) {
|
window.foreach_transient(function(win) {
|
||||||
|
|||||||
@@ -214,7 +214,7 @@ const WindowMenuManager = new Lang.Class({
|
|||||||
menu.close();
|
menu.close();
|
||||||
});
|
});
|
||||||
|
|
||||||
this._sourceActor.set_size(Math.max(1, rect.width), Math.max(1, rect.height));
|
this._sourceActor.set_size(rect.width, rect.height);
|
||||||
this._sourceActor.set_position(rect.x, rect.y);
|
this._sourceActor.set_position(rect.x, rect.y);
|
||||||
this._sourceActor.show();
|
this._sourceActor.show();
|
||||||
|
|
||||||
|
|||||||
@@ -361,9 +361,6 @@ const WindowClone = new Lang.Class({
|
|||||||
// a long-press canceled when the pointer movement
|
// a long-press canceled when the pointer movement
|
||||||
// exceeds dnd-drag-threshold to manually start the drag
|
// exceeds dnd-drag-threshold to manually start the drag
|
||||||
if (state == Clutter.LongPressState.CANCEL) {
|
if (state == Clutter.LongPressState.CANCEL) {
|
||||||
let event = Clutter.get_current_event();
|
|
||||||
this._dragTouchSequence = event.get_event_sequence();
|
|
||||||
|
|
||||||
// A click cancels a long-press before any click handler is
|
// A click cancels a long-press before any click handler is
|
||||||
// run - make sure to not start a drag in that case
|
// run - make sure to not start a drag in that case
|
||||||
Meta.later_add(Meta.LaterType.BEFORE_REDRAW, Lang.bind(this,
|
Meta.later_add(Meta.LaterType.BEFORE_REDRAW, Lang.bind(this,
|
||||||
@@ -372,7 +369,7 @@ const WindowClone = new Lang.Class({
|
|||||||
return;
|
return;
|
||||||
let [x, y] = action.get_coords();
|
let [x, y] = action.get_coords();
|
||||||
action.release();
|
action.release();
|
||||||
this._draggable.startDrag(x, y, global.get_current_time(), this._dragTouchSequence);
|
this._draggable.startDrag(x, y, global.get_current_time());
|
||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
|||||||
@@ -80,8 +80,6 @@ const WindowClone = new Lang.Class({
|
|||||||
|
|
||||||
this.actor.connect('button-release-event',
|
this.actor.connect('button-release-event',
|
||||||
Lang.bind(this, this._onButtonRelease));
|
Lang.bind(this, this._onButtonRelease));
|
||||||
this.actor.connect('touch-event',
|
|
||||||
Lang.bind(this, this._onTouchEvent));
|
|
||||||
|
|
||||||
this.actor.connect('destroy', Lang.bind(this, this._onDestroy));
|
this.actor.connect('destroy', Lang.bind(this, this._onDestroy));
|
||||||
|
|
||||||
@@ -202,15 +200,6 @@ const WindowClone = new Lang.Class({
|
|||||||
return Clutter.EVENT_STOP;
|
return Clutter.EVENT_STOP;
|
||||||
},
|
},
|
||||||
|
|
||||||
_onTouchEvent : function (actor, event) {
|
|
||||||
if (event.type() != Clutter.EventType.TOUCH_END ||
|
|
||||||
!global.display.is_pointer_emulating_sequence(event.get_event_sequence()))
|
|
||||||
return Clutter.EVENT_PROPAGATE;
|
|
||||||
|
|
||||||
this.emit('selected', event.get_time());
|
|
||||||
return Clutter.EVENT_STOP;
|
|
||||||
},
|
|
||||||
|
|
||||||
_onDragBegin : function (draggable, time) {
|
_onDragBegin : function (draggable, time) {
|
||||||
this.inDrag = true;
|
this.inDrag = true;
|
||||||
this.emit('drag-begin');
|
this.emit('drag-begin');
|
||||||
@@ -653,7 +642,6 @@ const ThumbnailsBox = new Lang.Class({
|
|||||||
|
|
||||||
this.actor.connect('button-press-event', function() { return Clutter.EVENT_STOP; });
|
this.actor.connect('button-press-event', function() { return Clutter.EVENT_STOP; });
|
||||||
this.actor.connect('button-release-event', Lang.bind(this, this._onButtonRelease));
|
this.actor.connect('button-release-event', Lang.bind(this, this._onButtonRelease));
|
||||||
this.actor.connect('touch-event', Lang.bind(this, this._onTouchEvent));
|
|
||||||
|
|
||||||
Main.overview.connect('showing',
|
Main.overview.connect('showing',
|
||||||
Lang.bind(this, this._createThumbnails));
|
Lang.bind(this, this._createThumbnails));
|
||||||
@@ -684,31 +672,18 @@ const ThumbnailsBox = new Lang.Class({
|
|||||||
global.screen.n_workspaces > 1;
|
global.screen.n_workspaces > 1;
|
||||||
},
|
},
|
||||||
|
|
||||||
_activateThumbnailAtPoint: function (stageX, stageY, time) {
|
_onButtonRelease: function(actor, event) {
|
||||||
|
let [stageX, stageY] = event.get_coords();
|
||||||
let [r, x, y] = this.actor.transform_stage_point(stageX, stageY);
|
let [r, x, y] = this.actor.transform_stage_point(stageX, stageY);
|
||||||
|
|
||||||
for (let i = 0; i < this._thumbnails.length; i++) {
|
for (let i = 0; i < this._thumbnails.length; i++) {
|
||||||
let thumbnail = this._thumbnails[i]
|
let thumbnail = this._thumbnails[i]
|
||||||
let [w, h] = thumbnail.actor.get_transformed_size();
|
let [w, h] = thumbnail.actor.get_transformed_size();
|
||||||
if (y >= thumbnail.actor.y && y <= thumbnail.actor.y + h) {
|
if (y >= thumbnail.actor.y && y <= thumbnail.actor.y + h) {
|
||||||
thumbnail.activate(time);
|
thumbnail.activate(event.get_time());
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
|
||||||
|
|
||||||
_onButtonRelease: function(actor, event) {
|
|
||||||
let [stageX, stageY] = event.get_coords();
|
|
||||||
this._activateThumbnailAtPoint(stageX, stageY, event.get_time());
|
|
||||||
return Clutter.EVENT_STOP;
|
|
||||||
},
|
|
||||||
|
|
||||||
_onTouchEvent: function (actor, event) {
|
|
||||||
if (event.type() == Clutter.EventType.TOUCH_END &&
|
|
||||||
global.display.is_pointer_emulating_sequence(event.get_event_sequence())) {
|
|
||||||
let [stageX, stageY] = event.get_coords();
|
|
||||||
this._activateThumbnailAtPoint(stageX, stageY, event.get_time());
|
|
||||||
}
|
|
||||||
|
|
||||||
return Clutter.EVENT_STOP;
|
return Clutter.EVENT_STOP;
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -421,7 +421,7 @@ const WorkspacesDisplay = new Lang.Class({
|
|||||||
// Only switch to the workspace when there's no application
|
// Only switch to the workspace when there's no application
|
||||||
// windows open. The problem is that it's too easy to miss
|
// windows open. The problem is that it's too easy to miss
|
||||||
// an app window and get the wrong one focused.
|
// an app window and get the wrong one focused.
|
||||||
if ((action.get_button() == 1 || action.get_button() == 0) &&
|
if (action.get_button() == 1 &&
|
||||||
this._getPrimaryView().getActiveWorkspace().isEmpty())
|
this._getPrimaryView().getActiveWorkspace().isEmpty())
|
||||||
Main.overview.hide();
|
Main.overview.hide();
|
||||||
}));
|
}));
|
||||||
|
|||||||
@@ -140,7 +140,7 @@
|
|||||||
|
|
||||||
<para>
|
<para>
|
||||||
<filename>/usr/share/gnome-session/sessions/gnome.session</filename>,
|
<filename>/usr/share/gnome-session/sessions/gnome.session</filename>,
|
||||||
<filename>/usr/share/applications/org.gnome.Shell.desktop</filename>.</para>
|
<filename>/usr/share/applications/gnome-shell.desktop</filename>.</para>
|
||||||
</refsect1>
|
</refsect1>
|
||||||
|
|
||||||
<refsect1>
|
<refsect1>
|
||||||
|
|||||||
@@ -24,7 +24,6 @@ fi
|
|||||||
fr
|
fr
|
||||||
fur
|
fur
|
||||||
ga
|
ga
|
||||||
gd
|
|
||||||
gl
|
gl
|
||||||
gu
|
gu
|
||||||
he
|
he
|
||||||
|
|||||||
@@ -2,8 +2,9 @@
|
|||||||
# Please keep this file sorted alphabetically.
|
# Please keep this file sorted alphabetically.
|
||||||
[encoding: UTF-8]
|
[encoding: UTF-8]
|
||||||
data/50-gnome-shell-system.xml.in
|
data/50-gnome-shell-system.xml.in
|
||||||
|
data/gnome-shell.desktop.in.in
|
||||||
data/gnome-shell-extension-prefs.desktop.in.in
|
data/gnome-shell-extension-prefs.desktop.in.in
|
||||||
data/org.gnome.Shell.desktop.in.in
|
data/gnome-shell-wayland.desktop.in.in
|
||||||
data/org.gnome.shell.gschema.xml.in.in
|
data/org.gnome.shell.gschema.xml.in.in
|
||||||
data/org.gnome.Shell.PortalHelper.desktop.in
|
data/org.gnome.Shell.PortalHelper.desktop.in
|
||||||
js/extensionPrefs/main.js
|
js/extensionPrefs/main.js
|
||||||
|
|||||||
702
po/pt_BR.po
702
po/pt_BR.po
File diff suppressed because it is too large
Load Diff
749
po/sr@latin.po
749
po/sr@latin.po
File diff suppressed because it is too large
Load Diff
680
po/zh_CN.po
680
po/zh_CN.po
File diff suppressed because it is too large
Load Diff
548
po/zh_TW.po
548
po/zh_TW.po
File diff suppressed because it is too large
Load Diff
@@ -41,6 +41,8 @@
|
|||||||
#define N_(x) x
|
#define N_(x) x
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#define CALENDAR_SOURCES_GET_PRIVATE(o) (G_TYPE_INSTANCE_GET_PRIVATE ((o), CALENDAR_TYPE_SOURCES, CalendarSourcesPrivate))
|
||||||
|
|
||||||
typedef struct _ClientData ClientData;
|
typedef struct _ClientData ClientData;
|
||||||
typedef struct _CalendarSourceData CalendarSourceData;
|
typedef struct _CalendarSourceData CalendarSourceData;
|
||||||
|
|
||||||
@@ -64,14 +66,6 @@ struct _CalendarSourceData
|
|||||||
guint loaded : 1;
|
guint loaded : 1;
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct _CalendarSourcesPrivate CalendarSourcesPrivate;
|
|
||||||
|
|
||||||
struct _CalendarSources
|
|
||||||
{
|
|
||||||
GObject parent;
|
|
||||||
CalendarSourcesPrivate *priv;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct _CalendarSourcesPrivate
|
struct _CalendarSourcesPrivate
|
||||||
{
|
{
|
||||||
ESourceRegistry *registry;
|
ESourceRegistry *registry;
|
||||||
@@ -83,8 +77,8 @@ struct _CalendarSourcesPrivate
|
|||||||
CalendarSourceData task_sources;
|
CalendarSourceData task_sources;
|
||||||
};
|
};
|
||||||
|
|
||||||
G_DEFINE_TYPE_WITH_PRIVATE (CalendarSources, calendar_sources, G_TYPE_OBJECT)
|
static void calendar_sources_class_init (CalendarSourcesClass *klass);
|
||||||
|
static void calendar_sources_init (CalendarSources *sources);
|
||||||
static void calendar_sources_finalize (GObject *object);
|
static void calendar_sources_finalize (GObject *object);
|
||||||
|
|
||||||
static void backend_died_cb (EClient *client, CalendarSourceData *source_data);
|
static void backend_died_cb (EClient *client, CalendarSourceData *source_data);
|
||||||
@@ -114,6 +108,34 @@ client_data_free (ClientData *data)
|
|||||||
g_slice_free (ClientData, data);
|
g_slice_free (ClientData, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
GType
|
||||||
|
calendar_sources_get_type (void)
|
||||||
|
{
|
||||||
|
static GType sources_type = 0;
|
||||||
|
|
||||||
|
if (!sources_type)
|
||||||
|
{
|
||||||
|
static const GTypeInfo sources_info =
|
||||||
|
{
|
||||||
|
sizeof (CalendarSourcesClass),
|
||||||
|
NULL, /* base_init */
|
||||||
|
NULL, /* base_finalize */
|
||||||
|
(GClassInitFunc) calendar_sources_class_init,
|
||||||
|
NULL, /* class_finalize */
|
||||||
|
NULL, /* class_data */
|
||||||
|
sizeof (CalendarSources),
|
||||||
|
0, /* n_preallocs */
|
||||||
|
(GInstanceInitFunc) calendar_sources_init,
|
||||||
|
};
|
||||||
|
|
||||||
|
sources_type = g_type_register_static (G_TYPE_OBJECT,
|
||||||
|
"CalendarSources",
|
||||||
|
&sources_info, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
return sources_type;
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
calendar_sources_class_init (CalendarSourcesClass *klass)
|
calendar_sources_class_init (CalendarSourcesClass *klass)
|
||||||
{
|
{
|
||||||
@@ -123,11 +145,14 @@ calendar_sources_class_init (CalendarSourcesClass *klass)
|
|||||||
|
|
||||||
gobject_class->finalize = calendar_sources_finalize;
|
gobject_class->finalize = calendar_sources_finalize;
|
||||||
|
|
||||||
|
g_type_class_add_private (klass, sizeof (CalendarSourcesPrivate));
|
||||||
|
|
||||||
signals [APPOINTMENT_SOURCES_CHANGED] =
|
signals [APPOINTMENT_SOURCES_CHANGED] =
|
||||||
g_signal_new ("appointment-sources-changed",
|
g_signal_new ("appointment-sources-changed",
|
||||||
G_TYPE_FROM_CLASS (gobject_class),
|
G_TYPE_FROM_CLASS (gobject_class),
|
||||||
G_SIGNAL_RUN_LAST,
|
G_SIGNAL_RUN_LAST,
|
||||||
0,
|
G_STRUCT_OFFSET (CalendarSourcesClass,
|
||||||
|
appointment_sources_changed),
|
||||||
NULL,
|
NULL,
|
||||||
NULL,
|
NULL,
|
||||||
NULL,
|
NULL,
|
||||||
@@ -138,7 +163,8 @@ calendar_sources_class_init (CalendarSourcesClass *klass)
|
|||||||
g_signal_new ("task-sources-changed",
|
g_signal_new ("task-sources-changed",
|
||||||
G_TYPE_FROM_CLASS (gobject_class),
|
G_TYPE_FROM_CLASS (gobject_class),
|
||||||
G_SIGNAL_RUN_LAST,
|
G_SIGNAL_RUN_LAST,
|
||||||
0,
|
G_STRUCT_OFFSET (CalendarSourcesClass,
|
||||||
|
task_sources_changed),
|
||||||
NULL,
|
NULL,
|
||||||
NULL,
|
NULL,
|
||||||
NULL,
|
NULL,
|
||||||
@@ -153,7 +179,7 @@ calendar_sources_init (CalendarSources *sources)
|
|||||||
GDBusConnection *session_bus;
|
GDBusConnection *session_bus;
|
||||||
GVariant *result;
|
GVariant *result;
|
||||||
|
|
||||||
sources->priv = calendar_sources_get_instance_private (sources);
|
sources->priv = CALENDAR_SOURCES_GET_PRIVATE (sources);
|
||||||
|
|
||||||
/* WORKAROUND: the hardcoded timeout for e_source_registry_new_sync()
|
/* WORKAROUND: the hardcoded timeout for e_source_registry_new_sync()
|
||||||
(and other library calls that eventually call g_dbus_proxy_new[_sync]())
|
(and other library calls that eventually call g_dbus_proxy_new[_sync]())
|
||||||
@@ -175,7 +201,7 @@ calendar_sources_init (CalendarSources *sources)
|
|||||||
"/", "org.freedesktop.DBus",
|
"/", "org.freedesktop.DBus",
|
||||||
"StartServiceByName",
|
"StartServiceByName",
|
||||||
g_variant_new ("(su)",
|
g_variant_new ("(su)",
|
||||||
"org.gnome.evolution.dataserver.Sources5",
|
"org.gnome.evolution.dataserver.Sources4",
|
||||||
0),
|
0),
|
||||||
NULL,
|
NULL,
|
||||||
G_DBUS_CALL_FLAGS_NONE,
|
G_DBUS_CALL_FLAGS_NONE,
|
||||||
|
|||||||
@@ -28,10 +28,33 @@
|
|||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
#define CALENDAR_TYPE_SOURCES (calendar_sources_get_type ())
|
#define CALENDAR_TYPE_SOURCES (calendar_sources_get_type ())
|
||||||
G_DECLARE_FINAL_TYPE (CalendarSources, calendar_sources,
|
#define CALENDAR_SOURCES(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), CALENDAR_TYPE_SOURCES, CalendarSources))
|
||||||
CALENDAR, SOURCES, GObject)
|
#define CALENDAR_SOURCES_CLASS(k) (G_TYPE_CHECK_CLASS_CAST ((k), CALENDAR_TYPE_SOURCES, CalendarSourcesClass))
|
||||||
|
#define CALENDAR_IS_SOURCES(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), CALENDAR_TYPE_SOURCES))
|
||||||
|
#define CALENDAR_IS_SOURCES_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), CALENDAR_TYPE_SOURCES))
|
||||||
|
#define CALENDAR_SOURCES_GET_CLASS(o)(G_TYPE_INSTANCE_GET_CLASS ((o), CALENDAR_TYPE_SOURCES, CalendarSourcesClass))
|
||||||
|
|
||||||
|
typedef struct _CalendarSources CalendarSources;
|
||||||
|
typedef struct _CalendarSourcesClass CalendarSourcesClass;
|
||||||
|
typedef struct _CalendarSourcesPrivate CalendarSourcesPrivate;
|
||||||
|
|
||||||
|
struct _CalendarSources
|
||||||
|
{
|
||||||
|
GObject parent;
|
||||||
|
CalendarSourcesPrivate *priv;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct _CalendarSourcesClass
|
||||||
|
{
|
||||||
|
GObjectClass parent_class;
|
||||||
|
|
||||||
|
void (* appointment_sources_changed) (CalendarSources *sources);
|
||||||
|
void (* task_sources_changed) (CalendarSources *sources);
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
GType calendar_sources_get_type (void) G_GNUC_CONST;
|
||||||
CalendarSources *calendar_sources_get (void);
|
CalendarSources *calendar_sources_get (void);
|
||||||
GList *calendar_sources_get_appointment_clients (CalendarSources *sources);
|
GList *calendar_sources_get_appointment_clients (CalendarSources *sources);
|
||||||
GList *calendar_sources_get_task_clients (CalendarSources *sources);
|
GList *calendar_sources_get_task_clients (CalendarSources *sources);
|
||||||
|
|||||||
@@ -45,8 +45,8 @@ static void gnome_shell_plugin_unminimize (MetaPlugin *plugin,
|
|||||||
static void gnome_shell_plugin_size_change (MetaPlugin *plugin,
|
static void gnome_shell_plugin_size_change (MetaPlugin *plugin,
|
||||||
MetaWindowActor *actor,
|
MetaWindowActor *actor,
|
||||||
MetaSizeChange which_change,
|
MetaSizeChange which_change,
|
||||||
MetaRectangle *old_frame_rect,
|
MetaRectangle *old_rect,
|
||||||
MetaRectangle *old_buffer_rect);
|
MetaRectangle *new_rect);
|
||||||
static void gnome_shell_plugin_map (MetaPlugin *plugin,
|
static void gnome_shell_plugin_map (MetaPlugin *plugin,
|
||||||
MetaWindowActor *actor);
|
MetaWindowActor *actor);
|
||||||
static void gnome_shell_plugin_destroy (MetaPlugin *plugin,
|
static void gnome_shell_plugin_destroy (MetaPlugin *plugin,
|
||||||
|
|||||||
@@ -176,15 +176,15 @@ gtk_menu_tracker_section_sync_separators (GtkMenuTrackerSection *section,
|
|||||||
|
|
||||||
if (subsection)
|
if (subsection)
|
||||||
{
|
{
|
||||||
gboolean section_could_have_separator;
|
gboolean could_have_separator;
|
||||||
|
|
||||||
section_could_have_separator = (section->with_separators && n_items > 0) || subsection->separator_label;
|
could_have_separator = (section->with_separators && n_items > 0) || subsection->separator_label;
|
||||||
|
|
||||||
/* Only pass the parent_model and parent_index in case they may be used to create the separator. */
|
/* Only pass the parent_model and parent_index in case they may be used to create the separator. */
|
||||||
n_items += gtk_menu_tracker_section_sync_separators (subsection, tracker, offset + n_items,
|
n_items += gtk_menu_tracker_section_sync_separators (subsection, tracker, offset + n_items,
|
||||||
section_could_have_separator,
|
could_have_separator,
|
||||||
section_could_have_separator ? section->model : NULL,
|
could_have_separator ? section->model : NULL,
|
||||||
section_could_have_separator ? i : 0);
|
could_have_separator ? i : 0);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
n_items++;
|
n_items++;
|
||||||
@@ -197,11 +197,11 @@ gtk_menu_tracker_section_sync_separators (GtkMenuTrackerSection *section,
|
|||||||
if (should_have_separator > section->has_separator)
|
if (should_have_separator > section->has_separator)
|
||||||
{
|
{
|
||||||
/* Add a separator */
|
/* Add a separator */
|
||||||
GtkMenuTrackerItem *menuitem;
|
GtkMenuTrackerItem *item;
|
||||||
|
|
||||||
menuitem = _gtk_menu_tracker_item_new (tracker->observable, parent_model, parent_index, NULL, TRUE);
|
item = _gtk_menu_tracker_item_new (tracker->observable, parent_model, parent_index, NULL, TRUE);
|
||||||
(* tracker->insert_func) (menuitem, offset, tracker->user_data);
|
(* tracker->insert_func) (item, offset, tracker->user_data);
|
||||||
g_object_unref (menuitem);
|
g_object_unref (item);
|
||||||
|
|
||||||
section->has_separator = TRUE;
|
section->has_separator = TRUE;
|
||||||
}
|
}
|
||||||
|
|||||||
2
src/gvc
2
src/gvc
Submodule src/gvc updated: 0a79019088...fac3a900e5
@@ -43,6 +43,8 @@
|
|||||||
#define DIRECTORY_LOAD_ITEMS_PER_CALLBACK 100
|
#define DIRECTORY_LOAD_ITEMS_PER_CALLBACK 100
|
||||||
#define HIGH_SCORE_RATIO 0.10
|
#define HIGH_SCORE_RATIO 0.10
|
||||||
|
|
||||||
|
G_DEFINE_TYPE (ShellMimeSniffer, shell_mime_sniffer, G_TYPE_OBJECT);
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
PROP_FILE = 1,
|
PROP_FILE = 1,
|
||||||
NUM_PROPERTIES
|
NUM_PROPERTIES
|
||||||
@@ -70,26 +72,16 @@ typedef struct {
|
|||||||
gint total_items;
|
gint total_items;
|
||||||
} DeepCountState;
|
} DeepCountState;
|
||||||
|
|
||||||
typedef struct _ShellMimeSnifferPrivate ShellMimeSnifferPrivate;
|
|
||||||
|
|
||||||
struct _ShellMimeSniffer
|
|
||||||
{
|
|
||||||
GObject parent_instance;
|
|
||||||
|
|
||||||
ShellMimeSnifferPrivate *priv;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct _ShellMimeSnifferPrivate {
|
struct _ShellMimeSnifferPrivate {
|
||||||
GFile *file;
|
GFile *file;
|
||||||
|
|
||||||
GCancellable *cancellable;
|
GCancellable *cancellable;
|
||||||
guint watchdog_id;
|
guint watchdog_id;
|
||||||
|
|
||||||
GTask *task;
|
GSimpleAsyncResult *async_result;
|
||||||
|
gchar **sniffed_mime;
|
||||||
};
|
};
|
||||||
|
|
||||||
G_DEFINE_TYPE_WITH_PRIVATE (ShellMimeSniffer, shell_mime_sniffer, G_TYPE_OBJECT);
|
|
||||||
|
|
||||||
static void deep_count_load (DeepCountState *state,
|
static void deep_count_load (DeepCountState *state,
|
||||||
GFile *file);
|
GFile *file);
|
||||||
|
|
||||||
@@ -187,7 +179,6 @@ prepare_async_result (DeepCountState *state)
|
|||||||
GArray *results;
|
GArray *results;
|
||||||
GPtrArray *sniffed_mime;
|
GPtrArray *sniffed_mime;
|
||||||
SniffedResult result;
|
SniffedResult result;
|
||||||
char **mimes;
|
|
||||||
|
|
||||||
sniffed_mime = g_ptr_array_new ();
|
sniffed_mime = g_ptr_array_new ();
|
||||||
results = g_array_new (TRUE, TRUE, sizeof (SniffedResult));
|
results = g_array_new (TRUE, TRUE, sizeof (SniffedResult));
|
||||||
@@ -229,10 +220,10 @@ prepare_async_result (DeepCountState *state)
|
|||||||
|
|
||||||
out:
|
out:
|
||||||
g_ptr_array_add (sniffed_mime, NULL);
|
g_ptr_array_add (sniffed_mime, NULL);
|
||||||
mimes = (gchar **) g_ptr_array_free (sniffed_mime, FALSE);
|
self->priv->sniffed_mime = (gchar **) g_ptr_array_free (sniffed_mime, FALSE);
|
||||||
|
|
||||||
g_array_free (results, TRUE);
|
g_array_free (results, TRUE);
|
||||||
g_task_return_pointer (self->priv->task, mimes, (GDestroyNotify)g_strfreev);
|
g_simple_async_result_complete_in_idle (self->priv->async_result);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* adapted from nautilus/libnautilus-private/nautilus-directory-async.c */
|
/* adapted from nautilus/libnautilus-private/nautilus-directory-async.c */
|
||||||
@@ -425,17 +416,20 @@ query_info_async_ready_cb (GObject *source,
|
|||||||
|
|
||||||
if (error != NULL)
|
if (error != NULL)
|
||||||
{
|
{
|
||||||
g_task_return_error (self->priv->task, error);
|
g_simple_async_result_take_error (self->priv->async_result,
|
||||||
|
error);
|
||||||
|
g_simple_async_result_complete_in_idle (self->priv->async_result);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (g_file_info_get_file_type (info) != G_FILE_TYPE_DIRECTORY)
|
if (g_file_info_get_file_type (info) != G_FILE_TYPE_DIRECTORY)
|
||||||
{
|
{
|
||||||
g_task_return_new_error (self->priv->task,
|
g_simple_async_result_set_error (self->priv->async_result,
|
||||||
G_IO_ERROR,
|
G_IO_ERROR,
|
||||||
G_IO_ERROR_NOT_DIRECTORY,
|
G_IO_ERROR_NOT_DIRECTORY,
|
||||||
"Not a directory");
|
"Not a directory");
|
||||||
|
g_simple_async_result_complete_in_idle (self->priv->async_result);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -481,7 +475,7 @@ shell_mime_sniffer_dispose (GObject *object)
|
|||||||
|
|
||||||
g_clear_object (&self->priv->file);
|
g_clear_object (&self->priv->file);
|
||||||
g_clear_object (&self->priv->cancellable);
|
g_clear_object (&self->priv->cancellable);
|
||||||
g_clear_object (&self->priv->task);
|
g_clear_object (&self->priv->async_result);
|
||||||
|
|
||||||
if (self->priv->watchdog_id != 0)
|
if (self->priv->watchdog_id != 0)
|
||||||
{
|
{
|
||||||
@@ -492,6 +486,16 @@ shell_mime_sniffer_dispose (GObject *object)
|
|||||||
G_OBJECT_CLASS (shell_mime_sniffer_parent_class)->dispose (object);
|
G_OBJECT_CLASS (shell_mime_sniffer_parent_class)->dispose (object);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
shell_mime_sniffer_finalize (GObject *object)
|
||||||
|
{
|
||||||
|
ShellMimeSniffer *self = SHELL_MIME_SNIFFER (object);
|
||||||
|
|
||||||
|
g_strfreev (self->priv->sniffed_mime);
|
||||||
|
|
||||||
|
G_OBJECT_CLASS (shell_mime_sniffer_parent_class)->finalize (object);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
shell_mime_sniffer_get_property (GObject *object,
|
shell_mime_sniffer_get_property (GObject *object,
|
||||||
guint prop_id,
|
guint prop_id,
|
||||||
@@ -535,6 +539,7 @@ shell_mime_sniffer_class_init (ShellMimeSnifferClass *klass)
|
|||||||
|
|
||||||
oclass = G_OBJECT_CLASS (klass);
|
oclass = G_OBJECT_CLASS (klass);
|
||||||
oclass->dispose = shell_mime_sniffer_dispose;
|
oclass->dispose = shell_mime_sniffer_dispose;
|
||||||
|
oclass->finalize = shell_mime_sniffer_finalize;
|
||||||
oclass->get_property = shell_mime_sniffer_get_property;
|
oclass->get_property = shell_mime_sniffer_get_property;
|
||||||
oclass->set_property = shell_mime_sniffer_set_property;
|
oclass->set_property = shell_mime_sniffer_set_property;
|
||||||
|
|
||||||
@@ -545,13 +550,17 @@ shell_mime_sniffer_class_init (ShellMimeSnifferClass *klass)
|
|||||||
G_TYPE_FILE,
|
G_TYPE_FILE,
|
||||||
G_PARAM_READWRITE);
|
G_PARAM_READWRITE);
|
||||||
|
|
||||||
|
g_type_class_add_private (klass, sizeof (ShellMimeSnifferPrivate));
|
||||||
g_object_class_install_properties (oclass, NUM_PROPERTIES, properties);
|
g_object_class_install_properties (oclass, NUM_PROPERTIES, properties);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
shell_mime_sniffer_init (ShellMimeSniffer *self)
|
shell_mime_sniffer_init (ShellMimeSniffer *self)
|
||||||
{
|
{
|
||||||
self->priv = shell_mime_sniffer_get_instance_private (self);
|
self->priv =
|
||||||
|
G_TYPE_INSTANCE_GET_PRIVATE (self,
|
||||||
|
SHELL_TYPE_MIME_SNIFFER,
|
||||||
|
ShellMimeSnifferPrivate);
|
||||||
init_mimetypes ();
|
init_mimetypes ();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -569,11 +578,14 @@ shell_mime_sniffer_sniff_async (ShellMimeSniffer *self,
|
|||||||
gpointer user_data)
|
gpointer user_data)
|
||||||
{
|
{
|
||||||
g_assert (self->priv->watchdog_id == 0);
|
g_assert (self->priv->watchdog_id == 0);
|
||||||
g_assert (self->priv->task == NULL);
|
g_assert (self->priv->async_result == NULL);
|
||||||
|
|
||||||
|
self->priv->async_result =
|
||||||
|
g_simple_async_result_new (G_OBJECT (self),
|
||||||
|
callback, user_data,
|
||||||
|
shell_mime_sniffer_sniff_finish);
|
||||||
|
|
||||||
self->priv->cancellable = g_cancellable_new ();
|
self->priv->cancellable = g_cancellable_new ();
|
||||||
self->priv->task = g_task_new (self, self->priv->cancellable,
|
|
||||||
callback, user_data);
|
|
||||||
|
|
||||||
self->priv->watchdog_id =
|
self->priv->watchdog_id =
|
||||||
g_timeout_add (WATCHDOG_TIMEOUT,
|
g_timeout_add (WATCHDOG_TIMEOUT,
|
||||||
@@ -588,5 +600,8 @@ shell_mime_sniffer_sniff_finish (ShellMimeSniffer *self,
|
|||||||
GAsyncResult *res,
|
GAsyncResult *res,
|
||||||
GError **error)
|
GError **error)
|
||||||
{
|
{
|
||||||
return g_task_propagate_pointer (self->priv->task, error);
|
if (g_simple_async_result_propagate_error (self->priv->async_result, error))
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
return g_strdupv (self->priv->sniffed_mime);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -27,9 +27,30 @@
|
|||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
#define SHELL_TYPE_MIME_SNIFFER (shell_mime_sniffer_get_type ())
|
#define SHELL_TYPE_MIME_SNIFFER (shell_mime_sniffer_get_type ())
|
||||||
G_DECLARE_FINAL_TYPE (ShellMimeSniffer, shell_mime_sniffer,
|
#define SHELL_MIME_SNIFFER(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), SHELL_TYPE_MIME_SNIFFER, ShellMimeSniffer))
|
||||||
SHELL, MIME_SNIFFER, GObject)
|
#define SHELL_IS_MIME_SNIFFER(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), SHELL_TYPE_MIME_SNIFFER))
|
||||||
|
#define SHELL_MIME_SNIFFER_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), SHELL_TYPE_MIME_SNIFFER, ShellMimeSnifferClass))
|
||||||
|
#define SHELL_IS_MIME_SNIFFER_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), SHELL_TYPE_MIME_SNIFFER))
|
||||||
|
#define SHELL_MIME_SNIFFER_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), SHELL_TYPE_MIME_SNIFFER, ShellMimeSnifferClass))
|
||||||
|
|
||||||
|
typedef struct _ShellMimeSniffer ShellMimeSniffer;
|
||||||
|
typedef struct _ShellMimeSnifferPrivate ShellMimeSnifferPrivate;
|
||||||
|
typedef struct _ShellMimeSnifferClass ShellMimeSnifferClass;
|
||||||
|
|
||||||
|
struct _ShellMimeSniffer
|
||||||
|
{
|
||||||
|
GObject parent_instance;
|
||||||
|
|
||||||
|
ShellMimeSnifferPrivate *priv;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct _ShellMimeSnifferClass
|
||||||
|
{
|
||||||
|
GObjectClass parent_class;
|
||||||
|
};
|
||||||
|
|
||||||
|
GType shell_mime_sniffer_get_type (void) G_GNUC_CONST;
|
||||||
|
|
||||||
ShellMimeSniffer *shell_mime_sniffer_new (GFile *file);
|
ShellMimeSniffer *shell_mime_sniffer_new (GFile *file);
|
||||||
|
|
||||||
|
|||||||
36
src/main.c
36
src/main.c
@@ -51,11 +51,11 @@ enum {
|
|||||||
static int _shell_debug;
|
static int _shell_debug;
|
||||||
|
|
||||||
static void
|
static void
|
||||||
shell_dbus_acquire_name (GDBusProxy *bus,
|
shell_dbus_acquire_name (GDBusProxy *bus,
|
||||||
guint32 request_name_flags,
|
guint32 request_name_flags,
|
||||||
guint32 *request_name_result,
|
guint32 *request_name_result,
|
||||||
const gchar *name,
|
gchar *name,
|
||||||
gboolean fatal)
|
gboolean fatal)
|
||||||
{
|
{
|
||||||
GError *error = NULL;
|
GError *error = NULL;
|
||||||
GVariant *request_name_variant;
|
GVariant *request_name_variant;
|
||||||
@@ -69,26 +69,24 @@ shell_dbus_acquire_name (GDBusProxy *bus,
|
|||||||
&error)))
|
&error)))
|
||||||
{
|
{
|
||||||
g_printerr ("failed to acquire %s: %s\n", name, error->message);
|
g_printerr ("failed to acquire %s: %s\n", name, error->message);
|
||||||
g_clear_error (&error);
|
|
||||||
if (!fatal)
|
if (!fatal)
|
||||||
return;
|
return;
|
||||||
exit (1);
|
exit (1);
|
||||||
}
|
}
|
||||||
g_variant_get (request_name_variant, "(u)", request_name_result);
|
g_variant_get (request_name_variant, "(u)", request_name_result);
|
||||||
g_variant_unref (request_name_variant);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
shell_dbus_acquire_names (GDBusProxy *bus,
|
shell_dbus_acquire_names (GDBusProxy *bus,
|
||||||
guint32 request_name_flags,
|
guint32 request_name_flags,
|
||||||
const gchar *name,
|
gchar *name,
|
||||||
gboolean fatal, ...) G_GNUC_NULL_TERMINATED;
|
gboolean fatal, ...) G_GNUC_NULL_TERMINATED;
|
||||||
|
|
||||||
static void
|
static void
|
||||||
shell_dbus_acquire_names (GDBusProxy *bus,
|
shell_dbus_acquire_names (GDBusProxy *bus,
|
||||||
guint32 request_name_flags,
|
guint32 request_name_flags,
|
||||||
const gchar *name,
|
gchar *name,
|
||||||
gboolean fatal, ...)
|
gboolean fatal, ...)
|
||||||
{
|
{
|
||||||
va_list al;
|
va_list al;
|
||||||
guint32 request_name_result;
|
guint32 request_name_result;
|
||||||
@@ -132,12 +130,6 @@ shell_dbus_init (gboolean replace)
|
|||||||
NULL, /* cancellable */
|
NULL, /* cancellable */
|
||||||
&error);
|
&error);
|
||||||
|
|
||||||
if (!bus)
|
|
||||||
{
|
|
||||||
g_printerr ("Failed to get a session bus proxy: %s", error->message);
|
|
||||||
exit (1);
|
|
||||||
}
|
|
||||||
|
|
||||||
request_name_flags = G_BUS_NAME_OWNER_FLAGS_ALLOW_REPLACEMENT;
|
request_name_flags = G_BUS_NAME_OWNER_FLAGS_ALLOW_REPLACEMENT;
|
||||||
if (replace)
|
if (replace)
|
||||||
request_name_flags |= DBUS_NAME_FLAG_REPLACE_EXISTING;
|
request_name_flags |= DBUS_NAME_FLAG_REPLACE_EXISTING;
|
||||||
@@ -462,7 +454,7 @@ main (int argc, char **argv)
|
|||||||
|
|
||||||
/* Initialize the global object */
|
/* Initialize the global object */
|
||||||
if (session_mode == NULL)
|
if (session_mode == NULL)
|
||||||
session_mode = is_gdm_mode ? (char *)"gdm" : (char *)"user";
|
session_mode = is_gdm_mode ? "gdm" : "user";
|
||||||
|
|
||||||
_shell_global_init ("session-mode", session_mode, NULL);
|
_shell_global_init ("session-mode", session_mode, NULL);
|
||||||
|
|
||||||
|
|||||||
@@ -37,15 +37,6 @@ enum {
|
|||||||
|
|
||||||
static guint signals[LAST_SIGNAL] = { 0 };
|
static guint signals[LAST_SIGNAL] = { 0 };
|
||||||
|
|
||||||
typedef struct _ShellAppSystemPrivate ShellAppSystemPrivate;
|
|
||||||
|
|
||||||
struct _ShellAppSystem
|
|
||||||
{
|
|
||||||
GObject parent;
|
|
||||||
|
|
||||||
ShellAppSystemPrivate *priv;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct _ShellAppSystemPrivate {
|
struct _ShellAppSystemPrivate {
|
||||||
GHashTable *running_apps;
|
GHashTable *running_apps;
|
||||||
GHashTable *id_to_app;
|
GHashTable *id_to_app;
|
||||||
@@ -54,7 +45,7 @@ struct _ShellAppSystemPrivate {
|
|||||||
|
|
||||||
static void shell_app_system_finalize (GObject *object);
|
static void shell_app_system_finalize (GObject *object);
|
||||||
|
|
||||||
G_DEFINE_TYPE_WITH_PRIVATE (ShellAppSystem, shell_app_system, G_TYPE_OBJECT);
|
G_DEFINE_TYPE(ShellAppSystem, shell_app_system, G_TYPE_OBJECT);
|
||||||
|
|
||||||
static void shell_app_system_class_init(ShellAppSystemClass *klass)
|
static void shell_app_system_class_init(ShellAppSystemClass *klass)
|
||||||
{
|
{
|
||||||
@@ -73,9 +64,11 @@ static void shell_app_system_class_init(ShellAppSystemClass *klass)
|
|||||||
g_signal_new ("installed-changed",
|
g_signal_new ("installed-changed",
|
||||||
SHELL_TYPE_APP_SYSTEM,
|
SHELL_TYPE_APP_SYSTEM,
|
||||||
G_SIGNAL_RUN_LAST,
|
G_SIGNAL_RUN_LAST,
|
||||||
0,
|
G_STRUCT_OFFSET (ShellAppSystemClass, installed_changed),
|
||||||
NULL, NULL, NULL,
|
NULL, NULL, NULL,
|
||||||
G_TYPE_NONE, 0);
|
G_TYPE_NONE, 0);
|
||||||
|
|
||||||
|
g_type_class_add_private (gobject_class, sizeof (ShellAppSystemPrivate));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@@ -154,7 +147,9 @@ shell_app_system_init (ShellAppSystem *self)
|
|||||||
ShellAppSystemPrivate *priv;
|
ShellAppSystemPrivate *priv;
|
||||||
GAppInfoMonitor *monitor;
|
GAppInfoMonitor *monitor;
|
||||||
|
|
||||||
self->priv = priv = shell_app_system_get_instance_private (self);
|
self->priv = priv = G_TYPE_INSTANCE_GET_PRIVATE (self,
|
||||||
|
SHELL_TYPE_APP_SYSTEM,
|
||||||
|
ShellAppSystemPrivate);
|
||||||
|
|
||||||
priv->running_apps = g_hash_table_new_full (NULL, NULL, (GDestroyNotify) g_object_unref, NULL);
|
priv->running_apps = g_hash_table_new_full (NULL, NULL, (GDestroyNotify) g_object_unref, NULL);
|
||||||
priv->id_to_app = g_hash_table_new_full (g_str_hash, g_str_equal,
|
priv->id_to_app = g_hash_table_new_full (g_str_hash, g_str_equal,
|
||||||
@@ -187,7 +182,7 @@ shell_app_system_finalize (GObject *object)
|
|||||||
* Return Value: (transfer none): The global #ShellAppSystem singleton
|
* Return Value: (transfer none): The global #ShellAppSystem singleton
|
||||||
*/
|
*/
|
||||||
ShellAppSystem *
|
ShellAppSystem *
|
||||||
shell_app_system_get_default (void)
|
shell_app_system_get_default ()
|
||||||
{
|
{
|
||||||
static ShellAppSystem *instance = NULL;
|
static ShellAppSystem *instance = NULL;
|
||||||
|
|
||||||
@@ -353,9 +348,6 @@ _shell_app_system_notify_app_state_changed (ShellAppSystem *self,
|
|||||||
case SHELL_APP_STATE_STOPPED:
|
case SHELL_APP_STATE_STOPPED:
|
||||||
g_hash_table_remove (self->priv->running_apps, app);
|
g_hash_table_remove (self->priv->running_apps, app);
|
||||||
break;
|
break;
|
||||||
default:
|
|
||||||
g_warn_if_reached();
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
g_signal_emit (self, signals[APP_STATE_CHANGED], 0, app);
|
g_signal_emit (self, signals[APP_STATE_CHANGED], 0, app);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -8,10 +8,33 @@
|
|||||||
|
|
||||||
#include "shell-app.h"
|
#include "shell-app.h"
|
||||||
|
|
||||||
#define SHELL_TYPE_APP_SYSTEM (shell_app_system_get_type ())
|
#define SHELL_TYPE_APP_SYSTEM (shell_app_system_get_type ())
|
||||||
G_DECLARE_FINAL_TYPE (ShellAppSystem, shell_app_system,
|
#define SHELL_APP_SYSTEM(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), SHELL_TYPE_APP_SYSTEM, ShellAppSystem))
|
||||||
SHELL, APP_SYSTEM, GObject)
|
#define SHELL_APP_SYSTEM_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), SHELL_TYPE_APP_SYSTEM, ShellAppSystemClass))
|
||||||
|
#define SHELL_IS_APP_SYSTEM(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), SHELL_TYPE_APP_SYSTEM))
|
||||||
|
#define SHELL_IS_APP_SYSTEM_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), SHELL_TYPE_APP_SYSTEM))
|
||||||
|
#define SHELL_APP_SYSTEM_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), SHELL_TYPE_APP_SYSTEM, ShellAppSystemClass))
|
||||||
|
|
||||||
|
typedef struct _ShellAppSystem ShellAppSystem;
|
||||||
|
typedef struct _ShellAppSystemClass ShellAppSystemClass;
|
||||||
|
typedef struct _ShellAppSystemPrivate ShellAppSystemPrivate;
|
||||||
|
|
||||||
|
struct _ShellAppSystem
|
||||||
|
{
|
||||||
|
GObject parent;
|
||||||
|
|
||||||
|
ShellAppSystemPrivate *priv;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct _ShellAppSystemClass
|
||||||
|
{
|
||||||
|
GObjectClass parent_class;
|
||||||
|
|
||||||
|
void (*installed_changed)(ShellAppSystem *appsys, gpointer user_data);
|
||||||
|
void (*favorites_changed)(ShellAppSystem *appsys, gpointer user_data);
|
||||||
|
};
|
||||||
|
|
||||||
|
GType shell_app_system_get_type (void) G_GNUC_CONST;
|
||||||
ShellAppSystem *shell_app_system_get_default (void);
|
ShellAppSystem *shell_app_system_get_default (void);
|
||||||
|
|
||||||
ShellApp *shell_app_system_lookup_app (ShellAppSystem *system,
|
ShellApp *shell_app_system_lookup_app (ShellAppSystem *system,
|
||||||
|
|||||||
@@ -996,7 +996,7 @@ on_enable_monitoring_key_changed (GSettings *settings,
|
|||||||
* Return Value: (transfer none): The global #ShellAppUsage instance
|
* Return Value: (transfer none): The global #ShellAppUsage instance
|
||||||
*/
|
*/
|
||||||
ShellAppUsage *
|
ShellAppUsage *
|
||||||
shell_app_usage_get_default (void)
|
shell_app_usage_get_default ()
|
||||||
{
|
{
|
||||||
static ShellAppUsage *instance;
|
static ShellAppUsage *instance;
|
||||||
|
|
||||||
|
|||||||
@@ -7,9 +7,23 @@
|
|||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
|
typedef struct _ShellAppUsage ShellAppUsage;
|
||||||
|
typedef struct _ShellAppUsageClass ShellAppUsageClass;
|
||||||
|
typedef struct _ShellAppUsagePrivate ShellAppUsagePrivate;
|
||||||
|
|
||||||
#define SHELL_TYPE_APP_USAGE (shell_app_usage_get_type ())
|
#define SHELL_TYPE_APP_USAGE (shell_app_usage_get_type ())
|
||||||
G_DECLARE_FINAL_TYPE (ShellAppUsage, shell_app_usage,
|
#define SHELL_APP_USAGE(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), SHELL_TYPE_APP_USAGE, ShellAppUsage))
|
||||||
SHELL, APP_USAGE, GObject)
|
#define SHELL_APP_USAGE_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), SHELL_TYPE_APP_USAGE, ShellAppUsageClass))
|
||||||
|
#define SHELL_IS_APP_USAGE(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), SHELL_TYPE_APP_USAGE))
|
||||||
|
#define SHELL_IS_APP_USAGE_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), SHELL_TYPE_APP_USAGE))
|
||||||
|
#define SHELL_APP_USAGE_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), SHELL_TYPE_APP_USAGE, ShellAppUsageClass))
|
||||||
|
|
||||||
|
struct _ShellAppUsageClass
|
||||||
|
{
|
||||||
|
GObjectClass parent_class;
|
||||||
|
};
|
||||||
|
|
||||||
|
GType shell_app_usage_get_type (void) G_GNUC_CONST;
|
||||||
|
|
||||||
ShellAppUsage* shell_app_usage_get_default(void);
|
ShellAppUsage* shell_app_usage_get_default(void);
|
||||||
|
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user