Compare commits
	
		
			165 Commits
		
	
	
		
			3.25.1
			...
			wip/rstrod
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 9f925cf78d | ||
|   | 1fcb59104d | ||
|   | 0320a04a8b | ||
|   | fc90833475 | ||
|   | 1dd12d2d78 | ||
|   | 08ad345f23 | ||
|   | 775d77bf6d | ||
|   | 737ba1483c | ||
|   | 734511a9ae | ||
|   | 825f1cc072 | ||
|   | 4181035981 | ||
|   | ae0eeb0dca | ||
|   | 2aceeac7e0 | ||
|   | 3b75881c05 | ||
|   | c987d3d2c9 | ||
|   | 26e7962dfe | ||
|   | 7f4e914b00 | ||
|   | 6878ee99d9 | ||
|   | 865a1cf587 | ||
|   | 96a49770a4 | ||
|   | c67eabaf62 | ||
|   | 6c9a7ce84e | ||
|   | 033277b68f | ||
|   | 2582d16ca7 | ||
|   | 9e32ba61fd | ||
|   | 6a2af25d48 | ||
|   | a593e4587b | ||
|   | 76c4b0a960 | ||
|   | 5202181a4d | ||
|   | c64a38f7da | ||
|   | 6b71b79d28 | ||
|   | e845f4105a | ||
|   | d461d02cdc | ||
|   | 88b1a5d3a0 | ||
|   | 8d6efde091 | ||
|   | 3ca77e9fe0 | ||
|   | 161926c581 | ||
|   | 59a70fbc63 | ||
|   | d220e353e0 | ||
|   | 593b4318a3 | ||
|   | f77333e4d7 | ||
|   | b5860d687d | ||
|   | fbf5f98eea | ||
|   | 1c7a3ee61b | ||
|   | 74bd009c86 | ||
|   | 516d19eb39 | ||
|   | 330a28742f | ||
|   | 90f7dfd783 | ||
|   | 69a9c222d0 | ||
|   | b3d74bdb0f | ||
|   | 77e0c38d82 | ||
|   | bcec9f35d5 | ||
|   | 150252391f | ||
|   | d4541a6f81 | ||
|   | c1eaa8e52d | ||
|   | 9d77fa8341 | ||
|   | 0a8d81c095 | ||
|   | faa0ddafff | ||
|   | a426295168 | ||
|   | 0d0e90ce9a | ||
|   | 7991a53189 | ||
|   | 4427197343 | ||
|   | 4c2fd513f4 | ||
|   | b099e9a69c | ||
|   | 5962be3904 | ||
|   | b18735da52 | ||
|   | 60e7db7126 | ||
|   | ccaae5d3cc | ||
|   | c1758c4d69 | ||
|   | d815c5dfc0 | ||
|   | b73c96d14c | ||
|   | 32fdc22811 | ||
|   | 4e57b45142 | ||
|   | 1ba014d9db | ||
|   | f33560f014 | ||
|   | b50d7143d1 | ||
|   | 28d098394a | ||
|   | 755698a756 | ||
|   | 2a01606c59 | ||
|   | e2f88d67f7 | ||
|   | 358133e82f | ||
|   | 526f2c8bcf | ||
|   | 79aa404c14 | ||
|   | 2339c39ae6 | ||
|   | a782de6e06 | ||
|   | 0f8718287a | ||
|   | 2b459ff202 | ||
|   | fbc5e3709e | ||
|   | 326d5c7fb8 | ||
|   | d1c71fd00d | ||
|   | 292ac413c8 | ||
|   | fdf988c04d | ||
|   | a00a186772 | ||
|   | e3330b638a | ||
|   | bdc15d680a | ||
|   | 82e20f94f4 | ||
|   | 5221744d1d | ||
|   | 293d1697fe | ||
|   | 9c8a470934 | ||
|   | 9c4e875de4 | ||
|   | 0e922eee36 | ||
|   | 875a1d6159 | ||
|   | e995730a4d | ||
|   | 3d209838a1 | ||
|   | 69396bbc1f | ||
|   | a0140fb2c7 | ||
|   | d8e7fc403b | ||
|   | 3d6fdc8ae2 | ||
|   | 47b109d25b | ||
|   | 6ed7034a6b | ||
|   | 4e07d0b073 | ||
|   | 708f65e388 | ||
|   | 8783654b38 | ||
|   | 4c72244c2e | ||
|   | 9e0e7a4067 | ||
|   | a256a35779 | ||
|   | d5cac6559d | ||
|   | ce262b36d4 | ||
|   | 02a72b12bb | ||
|   | 7f7d18749e | ||
|   | 2e1e00c3de | ||
|   | e2838a7e06 | ||
|   | ad2cb22785 | ||
|   | 7ad6bd95f7 | ||
|   | 50d37e74a3 | ||
|   | c22287b517 | ||
|   | 73cffb3c7f | ||
|   | 4bada06917 | ||
|   | 31a4705789 | ||
|   | 60c00f0472 | ||
|   | e7bf23890b | ||
|   | 15d387df5f | ||
|   | e02d6e5285 | ||
|   | 19d0169de4 | ||
|   | 7a2d4959f2 | ||
|   | 6b3c9539f6 | ||
|   | 7e7e3ec016 | ||
|   | 83fb34608c | ||
|   | a72f0604dc | ||
|   | 4dfad536a3 | ||
|   | 0dca5e513b | ||
|   | 7090592477 | ||
|   | 63f2fdd1a4 | ||
|   | e94de67bd2 | ||
|   | 817ff52414 | ||
|   | a55599a239 | ||
|   | 94114d82ff | ||
|   | 7cc88f96c4 | ||
|   | 447bf55e45 | ||
|   | 9d53a7700a | ||
|   | 51145a3d41 | ||
|   | 1297315cc2 | ||
|   | b859a7f763 | ||
|   | 41baf0fc74 | ||
|   | c324395ee6 | ||
|   | aecd1c126a | ||
|   | 9b7304488e | ||
|   | 6362b3d057 | ||
|   | 0142fae742 | ||
|   | 73680e2433 | ||
|   | e38c26894b | ||
|   | 28ca96064b | ||
|   | be95a63a03 | ||
|   | 2a3a5dfc0b | ||
|   | 94a0ae1ec3 | 
							
								
								
									
										6
									
								
								.gitmodules
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.gitmodules
									
									
									
									
										vendored
									
									
								
							| @@ -1,6 +1,6 @@ | ||||
| [submodule "src/gvc"] | ||||
| 	path = src/gvc | ||||
| 	url = git://git.gnome.org/libgnome-volume-control | ||||
| [submodule "data/theme/gnome-shell-sass"] | ||||
| 	path = data/theme/gnome-shell-sass | ||||
| 	url = git://git.gnome.org/gnome-shell-sass | ||||
| [submodule "subprojects/gvc"] | ||||
| 	path = subprojects/gvc | ||||
| 	url = git://git.gnome.org/libgnome-volume-control | ||||
|   | ||||
							
								
								
									
										12
									
								
								HACKING
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								HACKING
									
									
									
									
									
								
							| @@ -132,7 +132,7 @@ There are many approaches to classes in JavaScript. We use our own class framewo | ||||
| (sigh), which is built in gjs. The advantage is that it supports inheriting from | ||||
| GObjects, although this feature isn't used very often in the Shell itself. | ||||
|  | ||||
|     const IconLabelMenuItem = new Lang.Class({ | ||||
|     var IconLabelMenuItem = new Lang.Class({ | ||||
|         Name: 'IconLabelMenuItem', | ||||
|         Extends: PopupMenu.PopupMenuBaseItem, | ||||
|  | ||||
| @@ -169,7 +169,7 @@ GObject Introspection is a powerful feature that allows us to have native | ||||
| bindings for almost any library built around GObject. If a library requires | ||||
| you to inherit from a type to use it, you can do so: | ||||
|  | ||||
|     const MyClutterActor = new Lang.Class({ | ||||
|     var MyClutterActor = new Lang.Class({ | ||||
|         Name: 'MyClutterActor', | ||||
|         Extends: Clutter.Actor, | ||||
|  | ||||
| @@ -215,7 +215,7 @@ that has a property called `actor`. We call this wrapper class the "delegate". | ||||
| We sometimes use expando properties to set a property called `_delegate` on | ||||
| the actor itself: | ||||
|  | ||||
|     const MyClass = new Lang.Class({ | ||||
|     var MyClass = new Lang.Class({ | ||||
|         Name: 'MyClass', | ||||
|  | ||||
|         _init: function() { | ||||
| @@ -264,7 +264,7 @@ prototype: | ||||
|     const Lang = imports.lang; | ||||
|     const FnorbLib = imports.fborbLib; | ||||
|  | ||||
|     const MyClass = new Lang.Class({ | ||||
|     var MyClass = new Lang.Class({ | ||||
|         _init: function() { | ||||
|             let fnorb = new FnorbLib.Fnorb(); | ||||
|             fnorb.connect('frobate', Lang.bind(this, this._onFnorbFrobate)); | ||||
| @@ -304,9 +304,9 @@ designed around setting properties, like Tweener. If you want to animate an | ||||
| arbitrary property, create a getter and setter, and use Tweener to animate the | ||||
| property. | ||||
|  | ||||
|     const ANIMATION_TIME = 2000; | ||||
|     var ANIMATION_TIME = 2000; | ||||
|  | ||||
|     const MyClass = new Lang.Class({ | ||||
|     var MyClass = new Lang.Class({ | ||||
|         Name: 'MyClass', | ||||
|  | ||||
|         _init: function() { | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| # Point to our macro directory and pick up user flags from the environment | ||||
| ACLOCAL_AMFLAGS  = -I m4 ${ACLOCAL_FLAGS} | ||||
|  | ||||
| SUBDIRS = data js src  tests po docs | ||||
| SUBDIRS = data js subprojects/gvc src  tests po docs | ||||
|  | ||||
| if BUILD_BROWSER_PLUGIN | ||||
| SUBDIRS += browser-plugin | ||||
|   | ||||
							
								
								
									
										60
									
								
								NEWS
									
									
									
									
									
								
							
							
						
						
									
										60
									
								
								NEWS
									
									
									
									
									
								
							| @@ -1,3 +1,63 @@ | ||||
| 3.25.4 | ||||
| ====== | ||||
| * gdm: Fix "Not listed" focus indication [Florian; #784040] | ||||
| * Fix missing icons in freedesktop notifications [Florian; #784245] | ||||
| * gdm: Disable user list when empty [Xiaoguang; #731320] | ||||
| * gdm: Allow empty reponse to PAM messages [Ray; #784360] | ||||
| * Fix blocked clicks in shutdown dialog [Florian; #781738] | ||||
| * Show OSD popup when changing volume via scroll wheel [Florian; #781028] | ||||
| * Refine list search results [Rares; #749957] | ||||
| * Replace mutter's unresponsive app dialog [Carlos; #762083] | ||||
| * Improve handling of extension errors [Florian; #781728] | ||||
| * Implement tablet rings/strips configuration [Carlos; #782033] | ||||
| * Adjust to mozjs52 update in gjs [Florian; #785084, #785090] | ||||
| * Support the meson build system [Florian; #783229] | ||||
| * Misc. bug fixes [Ray, Florian, Jonas, Marco, Shih-Yuan, Joaquim, Carlos S.; | ||||
|   #780403, #772589, #784130, #783975, #784353, #784361, #772284, #765011, | ||||
|   #765011, #765011, #784985, #781471, #785047, #736148, #736148] | ||||
|  | ||||
| Contributors: | ||||
|   Jonas Ådahl, Alessandro Bono, Michael Catanzaro, Carlos Garnacho, | ||||
|   Shih-Yuan Lee (FourDollars), Florian Müllner, Joaquim Rocha, | ||||
|   Mario Sanchez Prada, Carlos Soriano, Ray Strode, Marco Trevisan (Treviño), | ||||
|   Rares Visalom, Xiaoguang Wang | ||||
|  | ||||
| Translations: | ||||
|   Jeremy Bicha po/es, he.po, Kukuh Syafaat [id], Fabio Tomat [fur] | ||||
|  | ||||
| 3.25.3 | ||||
| ====== | ||||
| * Bypass proxies for captive portal [Bastien; #769692] | ||||
| * Correctly handle "text-shadow: none;" [Matt; #783485] | ||||
| * Add StEntry:hint-actor property [Mario; #783484] | ||||
| * Support text-shadow CSS property in StEntry [Mario; #783484] | ||||
| * Misc. bug fixes [Jonas, Florian, Bastien, Ting-Wei, Cosimo, Mario, Sebastian; | ||||
|   #777732, #783202, #783210, #783206, #783286, #783439, #783483, #783823, | ||||
|   #781950] | ||||
|  | ||||
| Contributors: | ||||
|   Jonas Ådahl, Cosimo Cecchi, Sebastian Keller, Ting-Wei Lan, Florian Müllner, | ||||
|   Bastien Nocera, Mario Sanchez Prada, Matt Watson | ||||
|  | ||||
| 3.25.2 | ||||
| ====== | ||||
| * Fix StEntry::primary-icon-clicked emission [Florian; #782190] | ||||
| * Add an optional icon parameter to PopupMenu.addAction() [Mario; #782166] | ||||
| * Allow search providers to include clipboard text with results [Daiki; #775099] | ||||
| * Reduce dependency on Caribou [Carlos; #777342] | ||||
| * Add transparency to top bar when free floating [Alessandro; #747163] | ||||
| * Animate maximize/unmaximize operations [Alessandro; #766685] | ||||
| * Misc. bug fixes [Florian, Matthias, Jeremy, Michael, Carlos, Lan; #782000, | ||||
|   #780215, #782802, #782637, #782930, #755164, #780215, #782982] | ||||
|  | ||||
| Contributors: | ||||
|   Jeremy Bicha, Michael Biebl, Alessandro Bono, Carlos Garnacho, Ting-Wei Lan, | ||||
|   Matthias Liertzer, Florian Müllner, Mario Sanchez Prada, Daiki Ueno | ||||
|  | ||||
| Translations: | ||||
|   Jordi Mas [ca], Christian Stadelmann [de], Милош Поповић [sr], | ||||
|   Милош Поповић [sr@latin], Furkan Ahmet Kara [tr] | ||||
|  | ||||
| 3.25.1 | ||||
| ====== | ||||
| * Close Wifi selection dialog on lock [Florian; #780054] | ||||
|   | ||||
							
								
								
									
										12
									
								
								autogen.sh
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								autogen.sh
									
									
									
									
									
								
							| @@ -1,10 +1,12 @@ | ||||
| #!/bin/bash | ||||
| #!/bin/sh | ||||
| # Run this to generate all the initial makefiles, etc. | ||||
|  | ||||
| srcdir=`dirname $0` | ||||
| test -z "$srcdir" && srcdir=. | ||||
|  | ||||
| pushd $srcdir | ||||
| olddir="$(pwd)" | ||||
|  | ||||
| cd "${srcdir}" | ||||
|  | ||||
| (test -f configure.ac \ | ||||
|   && test -d src) || { | ||||
| @@ -14,7 +16,7 @@ pushd $srcdir | ||||
| } | ||||
|  | ||||
| # Fetch submodules if needed | ||||
| if test ! -f src/gvc/Makefile.am || test ! -f data/theme/gnome-shell-sass/COPYING; | ||||
| if test ! -f subprojects/gvc/Makefile.am || test ! -f data/theme/gnome-shell-sass/COPYING; | ||||
| then | ||||
|   echo "+ Setting up submodules" | ||||
|   git submodule init | ||||
| @@ -26,8 +28,8 @@ gtkdocize --copy || exit 1 | ||||
| intltoolize --force --copy --automake || exit 1 | ||||
| autoreconf --verbose --force --install || exit 1 | ||||
|  | ||||
| popd | ||||
| cd "${olddir}" | ||||
|  | ||||
| if [ "$NOCONFIGURE" = "" ]; then | ||||
|     $srcdir/configure "$@" || exit 1 | ||||
|     "${srcdir}/configure" "$@" || exit 1 | ||||
| fi | ||||
|   | ||||
							
								
								
									
										19
									
								
								browser-plugin/meson.build
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								browser-plugin/meson.build
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,19 @@ | ||||
| plugin_sources = [ | ||||
|   'browser-plugin.c', | ||||
|   'npapi/npapi.h', | ||||
|   'npapi/npfunctions.h', | ||||
|   'npapi/npruntime.h', | ||||
|   'npapi/nptypes.h' | ||||
| ] | ||||
|  | ||||
| shared_module('gnome-shell-browser-plugin', plugin_sources, | ||||
|   dependencies: [gio_dep, json_glib_dep], | ||||
|   c_args: ['-DG_LOG_DOMAIN="GnomeShellBrowserPlugin"'], | ||||
|   # Browsers can unload and reload the module while browsing, which is not | ||||
|   # supported by GObject. | ||||
|   # We pass -Wl,-z,nodelete to the linker to ensure the module is never | ||||
|   # unloaded. See https://bugzilla.gnome.org/show_bug.cgi?id=737932. | ||||
|   link_args: ['-Wl,-z,nodelete'], | ||||
|   install: true, | ||||
|   install_dir: plugindir | ||||
| ) | ||||
							
								
								
									
										26
									
								
								config.h.meson
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								config.h.meson
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | ||||
| /* The prefix for our gettext translation domains. */ | ||||
| #mesondefine GETTEXT_PACKAGE | ||||
|  | ||||
| /* Version number of package */ | ||||
| #mesondefine VERSION | ||||
|  | ||||
| /* Version number of package */ | ||||
| #mesondefine PACKAGE_VERSION | ||||
|  | ||||
| /* Define to 1 if you have the `fdwalk' function. */ | ||||
| #mesondefine HAVE_FDWALK | ||||
|  | ||||
| /* Define to 1 if you have the `mallinfo' function. */ | ||||
| #mesondefine HAVE_MALLINFO | ||||
|  | ||||
| /* Define to 1 fi you have the <sys/resource.h> header file. */ | ||||
| #mesondefine HAVE_SYS_RESOURCE_H | ||||
|  | ||||
| /* Define if we have NetworkManager */ | ||||
| #mesondefine HAVE_NETWORKMANAGER | ||||
|  | ||||
| /* Define if we have systemd */ | ||||
| #mesondefine HAVE_SYSTEMD | ||||
|  | ||||
| /* Define if _NL_TIME_FIRST_WEEKDATE is available */ | ||||
| #mesondefine HAVE__NL_TIME_FIRST_WEEKDAY | ||||
							
								
								
									
										20
									
								
								configure.ac
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								configure.ac
									
									
									
									
									
								
							| @@ -1,5 +1,5 @@ | ||||
| AC_PREREQ(2.63) | ||||
| AC_INIT([gnome-shell],[3.25.1],[https://bugzilla.gnome.org/enter_bug.cgi?product=gnome-shell],[gnome-shell]) | ||||
| AC_INIT([gnome-shell],[3.25.4],[https://bugzilla.gnome.org/enter_bug.cgi?product=gnome-shell],[gnome-shell]) | ||||
| AX_IS_RELEASE([git-directory]) | ||||
|  | ||||
| AC_CONFIG_HEADERS([config.h]) | ||||
| @@ -61,7 +61,6 @@ if $PKG_CONFIG --exists gstreamer-1.0 '>=' $GSTREAMER_MIN_VERSION ; then | ||||
|    AC_MSG_RESULT(yes) | ||||
|    build_recorder=true | ||||
|    recorder_modules="gstreamer-1.0 gstreamer-base-1.0 x11 gtk+-3.0" | ||||
|    PKG_CHECK_MODULES(TEST_SHELL_RECORDER, $recorder_modules $LIBMUTTER_CLUTTER) | ||||
| else | ||||
|    AC_MSG_RESULT(no) | ||||
| fi | ||||
| @@ -85,9 +84,9 @@ AC_MSG_RESULT($enable_systemd) | ||||
|  | ||||
| GOBJECT_INTROSPECTION_MIN_VERSION=1.49.1 | ||||
| GJS_MIN_VERSION=1.47.0 | ||||
| MUTTER_MIN_VERSION=3.25.1 | ||||
| MUTTER_MIN_VERSION=3.25.3 | ||||
| GTK_MIN_VERSION=3.15.0 | ||||
| GIO_MIN_VERSION=2.45.3 | ||||
| GIO_MIN_VERSION=2.53.0 | ||||
| LIBECAL_MIN_VERSION=3.5.3 | ||||
| LIBEDATASERVER_MIN_VERSION=3.17.2 | ||||
| POLKIT_MIN_VERSION=0.100 | ||||
| @@ -159,9 +158,6 @@ AC_SUBST(MUTTER_GIR_DIR) | ||||
| MUTTER_TYPELIB_DIR=`$PKG_CONFIG --variable=typelibdir $LIBMUTTER` | ||||
| AC_SUBST(MUTTER_TYPELIB_DIR) | ||||
|  | ||||
| GJS_CONSOLE=`$PKG_CONFIG --variable=gjs_console gjs-1.0` | ||||
| AC_SUBST(GJS_CONSOLE) | ||||
|  | ||||
| GLIB_COMPILE_RESOURCES=`$PKG_CONFIG --variable glib_compile_resources gio-2.0` | ||||
| AC_SUBST(GLIB_COMPILE_RESOURCES) | ||||
|  | ||||
| @@ -190,7 +186,7 @@ if test "x$enable_networkmanager" != "xno"; then | ||||
|                      [libnm-glib | ||||
|                      libnm-util >= $NETWORKMANAGER_MIN_VERSION | ||||
|                      libnm-gtk >= $NETWORKMANAGER_MIN_VERSION | ||||
|                      libsecret-unstable], | ||||
|                      libsecret-1 >= 0.18], | ||||
|                      [have_networkmanager=yes], | ||||
|                      [have_networkmanager=no]) | ||||
|  | ||||
| @@ -250,7 +246,7 @@ if test -z "$GDBUS_CODEGEN"; then | ||||
|   AC_MSG_ERROR([gdbus-codegen not found]) | ||||
| fi | ||||
|  | ||||
| AC_PATH_PROG([SASS],[sass],[]) | ||||
| AC_PATH_PROG([SASSC],[sassc],[]) | ||||
|  | ||||
| AC_CONFIG_FILES([ | ||||
|   Makefile | ||||
| @@ -258,12 +254,12 @@ AC_CONFIG_FILES([ | ||||
|   docs/Makefile | ||||
|   docs/reference/Makefile | ||||
|   docs/reference/shell/Makefile | ||||
|   docs/reference/shell/shell-docs.sgml | ||||
|   docs/reference/shell/version.xml | ||||
|   docs/reference/st/Makefile | ||||
|   docs/reference/st/st-docs.sgml | ||||
|   docs/reference/st/version.xml | ||||
|   js/Makefile | ||||
|   src/Makefile | ||||
|   src/gvc/Makefile | ||||
|   subprojects/gvc/Makefile | ||||
|   browser-plugin/Makefile | ||||
|   tests/Makefile | ||||
|   po/Makefile.in | ||||
|   | ||||
| @@ -1,15 +1,15 @@ | ||||
| CLEANFILES = | ||||
| NULL = | ||||
|  | ||||
| portaldir = $(datadir)/xdg-desktop-portal/portals | ||||
| portal_DATA = gnome-shell.portal | ||||
|  | ||||
| desktopdir=$(datadir)/applications | ||||
| desktop_DATA = org.gnome.Shell.desktop gnome-shell-extension-prefs.desktop | ||||
|  | ||||
| if HAVE_NETWORKMANAGER | ||||
| desktop_DATA += org.gnome.Shell.PortalHelper.desktop | ||||
|  | ||||
| portaldir = $(datadir)/xdg-desktop-portal/portals | ||||
| portal_DATA = gnome-shell.portal | ||||
|  | ||||
| servicedir = $(datadir)/dbus-1/services | ||||
| service_DATA = org.gnome.Shell.PortalHelper.service | ||||
|  | ||||
| @@ -56,7 +56,6 @@ theme_sources = 						\ | ||||
|  | ||||
| dist_theme_files =						\ | ||||
| 	$(theme_sources)					\ | ||||
| 	theme/Gemfile						\ | ||||
| 	theme/HACKING						\ | ||||
| 	theme/README						\ | ||||
| 	theme/gnome-shell-sass/COPYING				\ | ||||
| @@ -64,14 +63,14 @@ dist_theme_files =						\ | ||||
| 	theme/gnome-shell-sass/NEWS				\ | ||||
| 	theme/gnome-shell-sass/README				\ | ||||
| 	theme/gnome-shell-sass/gnome-shell-sass.doap		\ | ||||
| 	theme/pad-osd.css						\ | ||||
| 	theme/pad-osd.css					\ | ||||
| 	theme/parse-sass.sh					\ | ||||
| 	$(NULL) | ||||
|  | ||||
| %.css: %.scss $(theme_sources) | ||||
| 	@if test -n "$(SASS)"; then \ | ||||
| 	@if test -n "$(SASSC)"; then \ | ||||
| 		if $(AM_V_P); then PS4= set -x; else echo "  GEN      $@"; fi; \ | ||||
| 		$(SASS) --sourcemap=none -f -q --update $<; \ | ||||
| 		$(SASSC) -a $< $@; \ | ||||
| 	fi | ||||
|  | ||||
| resource_files = $(shell $(GLIB_COMPILE_RESOURCES) --sourcedir=$(srcdir)/theme --generate-dependencies $(srcdir)/gnome-shell-theme.gresource.xml) | ||||
|   | ||||
| @@ -18,7 +18,6 @@ | ||||
|     <file>gnome-shell.css</file> | ||||
|     <file>gnome-shell-high-contrast.css</file> | ||||
|     <file>logged-in-indicator.svg</file> | ||||
|     <file>more-results.svg</file> | ||||
|     <file>no-events.svg</file> | ||||
|     <file>no-notifications.svg</file> | ||||
|     <file>noise-texture.png</file> | ||||
|   | ||||
							
								
								
									
										88
									
								
								data/meson.build
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										88
									
								
								data/meson.build
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,88 @@ | ||||
| desktop_files = [ | ||||
|   'org.gnome.Shell.desktop', | ||||
|   'gnome-shell-extension-prefs.desktop' | ||||
| ] | ||||
| service_files = [] | ||||
|  | ||||
| if have_networkmanager | ||||
|   desktop_files += 'org.gnome.Shell.PortalHelper.desktop' | ||||
|   service_files += 'org.gnome.Shell.PortalHelper.service' | ||||
| endif | ||||
|  | ||||
| desktopconf = configuration_data() | ||||
| # We substitute in bindir so it works as an autostart | ||||
| # file when built in a non-system prefix | ||||
| desktopconf.set('bindir', bindir) | ||||
| desktopconf.set('VERSION', meson.project_version()) | ||||
| foreach desktop_file : desktop_files | ||||
|   i18n.merge_file('desktop', | ||||
|     input: configure_file( | ||||
|       input: desktop_file + '.in.in', | ||||
|       output: desktop_file + '.in', | ||||
|       configuration: desktopconf | ||||
|     ), | ||||
|     output: desktop_file, | ||||
|     po_dir: '../po', | ||||
|     install: true, | ||||
|     install_dir: desktopdir, | ||||
|     type: 'desktop' | ||||
|   ) | ||||
| endforeach | ||||
|  | ||||
| serviceconf = configuration_data() | ||||
| serviceconf.set('libexecdir', libexecdir) | ||||
| foreach service_file : service_files | ||||
|   configure_file( | ||||
|     input: service_file + '.in', | ||||
|     output: service_file, | ||||
|     configuration: serviceconf, | ||||
|     install_dir: servicedir | ||||
|   ) | ||||
| endforeach | ||||
|  | ||||
|  | ||||
| dbus_interfaces = [ | ||||
|   'org.gnome.Shell.PadOsd.xml', | ||||
|   'org.gnome.Shell.Screencast.xml', | ||||
|   'org.gnome.Shell.Screenshot.xml', | ||||
|   'org.gnome.ShellSearchProvider.xml', | ||||
|   'org.gnome.ShellSearchProvider2.xml' | ||||
| ] | ||||
| install_data(dbus_interfaces, install_dir: ifacedir) | ||||
|  | ||||
|  | ||||
| subdir('theme') | ||||
|  | ||||
| theme_resources = gnome.compile_resources( | ||||
|   'gnome-shell-theme', 'gnome-shell-theme.gresource.xml', | ||||
|   source_dir: 'theme', | ||||
|   dependencies: theme_deps, | ||||
|   gresource_bundle: true, | ||||
|   install: true, | ||||
|   install_dir: pkgdatadir | ||||
| ) | ||||
|  | ||||
| perfconf = configuration_data() | ||||
| perfconf.set('datadir', datadir) | ||||
| configure_file( | ||||
|   input: 'perf-background.xml.in', | ||||
|   output: 'perf-background.xml', | ||||
|   configuration: perfconf, | ||||
|   install_dir: pkgdatadir | ||||
| ) | ||||
|  | ||||
|  | ||||
| install_data('gnome-shell.portal', install_dir: portaldir) | ||||
| install_data('50-gnome-shell-system.xml', install_dir: keysdir) | ||||
|  | ||||
|  | ||||
| schemaconf = configuration_data() | ||||
| schemaconf.set('GETTEXT_PACKAGE', meson.project_name()) | ||||
| configure_file( | ||||
|   input: 'org.gnome.shell.gschema.xml.in', | ||||
|   output: 'org.gnome.shell.gschema.xml', | ||||
|   configuration: schemaconf, | ||||
|   install_dir: schemadir | ||||
| ) | ||||
|  | ||||
| install_data('gnome-shell-overrides.convert', install_dir: convertdir) | ||||
| @@ -1 +0,0 @@ | ||||
| gem "sass", "~> 3.4.0" | ||||
| @@ -3,10 +3,10 @@ Summary | ||||
|  | ||||
| * Do not edit the CSS directly, edit the source SCSS files and process them with SASS (running | ||||
|   `make` should do that when you have the required software installed, as described below; | ||||
|   run `/.parse-sass.sh` manually if it doesn't) | ||||
| * To be able to use the lates/adequate version of sass, install ruby, gem, sass & bundle.  | ||||
|   On Fedora F20, this is done with `sudo dnf install rubygems && gem install bundle && bundle install` | ||||
|   from the same directory this README resides in. | ||||
|   run `./parse-sass.sh` manually if it doesn't) | ||||
| * Most SASS preprocessors should produce similar results, however the build system | ||||
|   integration and 'parse-sass.sh' script use sassc. You should be able to install | ||||
|   it with `pkcon install sassc` or your distribution's package manager. | ||||
|  | ||||
| How to tweak the theme | ||||
| ---------------------- | ||||
| @@ -31,6 +31,4 @@ _common.scss        - actual definitions of style for each widget. This is where | ||||
|                       your changes. | ||||
|                        | ||||
| You can read about SASS at http://sass-lang.com/documentation/. Once you make your changes to the | ||||
| _common.scss file, you can either run the ./parse-sass.sh script or keep SASS watching for changes as you | ||||
| edit. This is done by running `bundle exec sass --watch --sourcemap=none .` If sass is out of date, or is | ||||
| missing, you can install it with `bundle install`. | ||||
| _common.scss file, you can either run make or the ./parse-sass.sh script. | ||||
|   | ||||
| @@ -118,6 +118,7 @@ StEntry { | ||||
| /* Scrollbars */ | ||||
| StScrollView.vfade { | ||||
|   -st-vfade-offset: 68px; } | ||||
|  | ||||
| StScrollView.hfade { | ||||
|   -st-hfade-offset: 68px; } | ||||
|  | ||||
| @@ -152,14 +153,18 @@ StScrollBar { | ||||
| /* Check Boxes */ | ||||
| .check-box StBoxLayout { | ||||
|   spacing: .8em; } | ||||
|  | ||||
| .check-box StBin { | ||||
|   width: 24px; | ||||
|   height: 22px; | ||||
|   background-image: url("resource:///org/gnome/shell/theme/checkbox-off.svg"); } | ||||
|  | ||||
| .check-box:focus StBin { | ||||
|   background-image: url("resource:///org/gnome/shell/theme/checkbox-off-focused.svg"); } | ||||
|  | ||||
| .check-box:checked StBin { | ||||
|   background-image: url("resource:///org/gnome/shell/theme/checkbox.svg"); } | ||||
|  | ||||
| .check-box:focus:checked StBin { | ||||
|   background-image: url("resource:///org/gnome/shell/theme/checkbox-focused.svg"); } | ||||
|  | ||||
| @@ -216,11 +221,30 @@ StScrollBar { | ||||
|     color: #d6d6d1; | ||||
|     padding-bottom: .4em; } | ||||
|  | ||||
| .show-processes-dialog-subject, | ||||
| .mount-question-dialog-subject, | ||||
| .mount-dialog-subject, | ||||
| .end-session-dialog-subject { | ||||
|   font-size: 14pt; } | ||||
|  | ||||
| /* Message Dialog */ | ||||
| .message-dialog-main-layout { | ||||
|   padding: 12px 20px 0; | ||||
|   spacing: 12px; } | ||||
|  | ||||
| .message-dialog-content { | ||||
|   max-width: 28em; | ||||
|   spacing: 20px; } | ||||
|  | ||||
| .message-dialog-icon { | ||||
|   min-width: 48px; | ||||
|   icon-size: 48px; } | ||||
|  | ||||
| .message-dialog-title { | ||||
|   font-weight: bold; } | ||||
|  | ||||
| .message-dialog-subtitle { | ||||
|   color: #999999; | ||||
|   font-weight: bold; } | ||||
|  | ||||
| /* End Session Dialog */ | ||||
| .end-session-dialog { | ||||
|   spacing: 42px; | ||||
| @@ -289,75 +313,62 @@ StScrollBar { | ||||
| .shell-mount-operation-icon { | ||||
|   icon-size: 48px; } | ||||
|  | ||||
| .show-processes-dialog, | ||||
| .mount-question-dialog { | ||||
| .mount-dialog { | ||||
|   spacing: 24px; } | ||||
|   .mount-dialog .message-dialog-title { | ||||
|     padding-top: 10px; | ||||
|     padding-left: 17px; | ||||
|     padding-bottom: 6px; | ||||
|     max-width: 34em; } | ||||
|   .mount-dialog .message-dialog-title:rtl { | ||||
|     padding-left: 0px; | ||||
|     padding-right: 17px; } | ||||
|   .mount-dialog .message-dialog-body { | ||||
|     padding-left: 17px; | ||||
|     width: 28em; } | ||||
|   .mount-dialog .message-dialog-body:rtl { | ||||
|     padding-left: 0px; | ||||
|     padding-right: 17px; } | ||||
|  | ||||
| .show-processes-dialog-subject, | ||||
| .mount-question-dialog-subject { | ||||
|   padding-top: 10px; | ||||
|   padding-left: 17px; | ||||
|   padding-bottom: 6px; } | ||||
|  | ||||
| .mount-question-dialog-subject { | ||||
|   max-width: 500px; } | ||||
|  | ||||
| .show-processes-dialog-subject:rtl, | ||||
| .mount-question-dialog-subject:rtl { | ||||
|   padding-left: 0px; | ||||
|   padding-right: 17px; } | ||||
|  | ||||
| .show-processes-dialog-description, | ||||
| .mount-question-dialog-description { | ||||
|   padding-left: 17px; | ||||
|   width: 28em; } | ||||
|  | ||||
| .show-processes-dialog-description:rtl, | ||||
| .mount-question-dialog-description:rtl { | ||||
|   padding-right: 17px; } | ||||
|  | ||||
| .show-processes-dialog-app-list { | ||||
| .mount-dialog-app-list { | ||||
|   max-height: 200px; | ||||
|   padding-top: 24px; | ||||
|   padding-left: 49px; | ||||
|   padding-right: 32px; } | ||||
|  | ||||
| .show-processes-dialog-app-list:rtl { | ||||
| .mount-dialog-app-list:rtl { | ||||
|   padding-right: 49px; | ||||
|   padding-left: 32px; } | ||||
|  | ||||
| .show-processes-dialog-app-list-item { | ||||
| .mount-dialog-app-list-item { | ||||
|   color: #e6e6e6; } | ||||
|   .show-processes-dialog-app-list-item:hover { | ||||
|   .mount-dialog-app-list-item:hover { | ||||
|     color: #fff; } | ||||
|   .show-processes-dialog-app-list-item:ltr { | ||||
|   .mount-dialog-app-list-item:ltr { | ||||
|     padding-right: 1em; } | ||||
|   .show-processes-dialog-app-list-item:rtl { | ||||
|   .mount-dialog-app-list-item:rtl { | ||||
|     padding-left: 1em; } | ||||
|  | ||||
| .show-processes-dialog-app-list-item-icon:ltr { | ||||
| .mount-dialog-app-list-item-icon:ltr { | ||||
|   padding-right: 17px; } | ||||
| .show-processes-dialog-app-list-item-icon:rtl { | ||||
|  | ||||
| .mount-dialog-app-list-item-icon:rtl { | ||||
|   padding-left: 17px; } | ||||
|  | ||||
| .show-processes-dialog-app-list-item-name { | ||||
| .mount-dialog-app-list-item-name { | ||||
|   font-size: 10pt; } | ||||
|  | ||||
| /* Password or Authentication Dialog */ | ||||
| .prompt-dialog { | ||||
|   width: 500px; | ||||
|   width: 34em; | ||||
|   border: 3px solid rgba(238, 238, 236, 0.2); } | ||||
|  | ||||
| .prompt-dialog-main-layout { | ||||
|   spacing: 24px; | ||||
|   padding: 10px; } | ||||
|  | ||||
| .prompt-dialog-message-layout { | ||||
|   spacing: 16px; } | ||||
|  | ||||
| .prompt-dialog-headline { | ||||
|   font-weight: bold; | ||||
|   color: #b2b2a9; } | ||||
|   .prompt-dialog .message-dialog-main-layout { | ||||
|     spacing: 24px; | ||||
|     padding: 10px; } | ||||
|   .prompt-dialog .message-dialog-content { | ||||
|     spacing: 16px; } | ||||
|   .prompt-dialog .message-dialog-title { | ||||
|     color: #b2b2a9; } | ||||
|  | ||||
| .prompt-dialog-description:rtl { | ||||
|   text-align: right; } | ||||
| @@ -431,44 +442,17 @@ StScrollBar { | ||||
| .access-dialog { | ||||
|   spacing: 30px; } | ||||
|  | ||||
| .access-dialog-main-layout { | ||||
|   padding: 12px 20px 0; | ||||
|   spacing: 12px; } | ||||
|  | ||||
| .access-dialog-content { | ||||
|   max-width: 28em; | ||||
|   spacing: 20px; } | ||||
|  | ||||
| .access-dialog-icon { | ||||
|   min-width: 48px; | ||||
|   icon-size: 48px; } | ||||
|  | ||||
| .access-dialog-title { | ||||
|   font-weight: bold; } | ||||
|  | ||||
| .access-dialog-subtitle { | ||||
|   color: #999999; | ||||
|   font-weight: bold; } | ||||
|  | ||||
| /* Geolocation Dialog */ | ||||
| .geolocation-dialog { | ||||
|   spacing: 30px; } | ||||
|  | ||||
| .geolocation-dialog-main-layout { | ||||
|   spacing: 12px; } | ||||
| /* Extension Dialog */ | ||||
| .extension-dialog .message-dialog-main-layout { | ||||
|   spacing: 24px; | ||||
|   padding: 10px; } | ||||
|  | ||||
| .geolocation-dialog-content { | ||||
|   spacing: 20px; } | ||||
|  | ||||
| .geolocation-dialog-icon { | ||||
|   icon-size: 48px; } | ||||
|  | ||||
| .geolocation-dialog-title { | ||||
|   font-weight: bold; } | ||||
|  | ||||
| .geolocation-dialog-reason { | ||||
|   color: #999999; | ||||
|   font-weight: bold; } | ||||
| .extension-dialog .message-dialog-title { | ||||
|   color: #b2b2a9; } | ||||
|  | ||||
| /* Network Agent Dialog */ | ||||
| .network-dialog-secret-table { | ||||
| @@ -669,7 +653,9 @@ StScrollBar { | ||||
|  | ||||
| /* TOP BAR */ | ||||
| #panel { | ||||
|   background-color: black; | ||||
|   background-color: rgba(0, 0, 0, 0.2); | ||||
|   /* transition from solid to transparent */ | ||||
|   transition-duration: 500ms; | ||||
|   font-weight: bold; | ||||
|   height: 1.86em; } | ||||
|   #panel.unlock-screen, #panel.login-screen, #panel.lock-screen { | ||||
| @@ -678,7 +664,7 @@ StScrollBar { | ||||
|     spacing: 4px; } | ||||
|   #panel .panel-corner { | ||||
|     -panel-corner-radius: 6px; | ||||
|     -panel-corner-background-color: black; | ||||
|     -panel-corner-background-color: rgba(0, 0, 0, 0.2); | ||||
|     -panel-corner-border-width: 2px; | ||||
|     -panel-corner-border-color: transparent; } | ||||
|     #panel .panel-corner:active, #panel .panel-corner:overview, #panel .panel-corner:focus { | ||||
| @@ -691,14 +677,24 @@ StScrollBar { | ||||
|     -natural-hpadding: 12px; | ||||
|     -minimum-hpadding: 6px; | ||||
|     font-weight: bold; | ||||
|     color: #ccc; | ||||
|     color: #eee; | ||||
|     text-shadow: 0px 0px 2px rgba(0, 0, 0, 0.9); | ||||
|     transition-duration: 100ms; } | ||||
|     #panel .panel-button .app-menu-icon { | ||||
|       -st-icon-style: symbolic; | ||||
|       margin-left: 4px; | ||||
|       margin-right: 4px; } | ||||
|     #panel .panel-button .system-status-icon, | ||||
|     #panel .panel-button .app-menu-icon > StIcon, | ||||
|     #panel .panel-button .popup-menu-arrow { | ||||
|       icon-shadow: 0px 0px 2px rgba(0, 0, 0, 0.9); } | ||||
|     #panel .panel-button:hover { | ||||
|       color: white; } | ||||
|       color: white; | ||||
|       text-shadow: 0px 0px 8px black; } | ||||
|       #panel .panel-button:hover .system-status-icon, | ||||
|       #panel .panel-button:hover .app-menu-icon > StIcon, | ||||
|       #panel .panel-button:hover .popup-menu-arrow { | ||||
|         icon-shadow: 0px 0px 8px black; } | ||||
|     #panel .panel-button:active, #panel .panel-button:overview, #panel .panel-button:focus, #panel .panel-button:checked { | ||||
|       background-color: rgba(0, 0, 0, 0.01); | ||||
|       box-shadow: inset 0 -2px 0px #256ab1; | ||||
| @@ -708,9 +704,17 @@ StScrollBar { | ||||
|     #panel .panel-button .system-status-icon { | ||||
|       icon-size: 1.09em; | ||||
|       padding: 0 5px; } | ||||
|     .unlock-screen #panel .panel-button, .login-screen #panel .panel-button, .lock-screen #panel .panel-button { | ||||
|     .unlock-screen #panel .panel-button, | ||||
|     .login-screen #panel .panel-button, | ||||
|     .lock-screen #panel .panel-button { | ||||
|       color: white; } | ||||
|       .unlock-screen #panel .panel-button:focus, .unlock-screen #panel .panel-button:hover, .unlock-screen #panel .panel-button:active, .login-screen #panel .panel-button:focus, .login-screen #panel .panel-button:hover, .login-screen #panel .panel-button:active, .lock-screen #panel .panel-button:focus, .lock-screen #panel .panel-button:hover, .lock-screen #panel .panel-button:active { | ||||
|       .unlock-screen #panel .panel-button:focus, .unlock-screen #panel .panel-button:hover, .unlock-screen #panel .panel-button:active, | ||||
|       .login-screen #panel .panel-button:focus, | ||||
|       .login-screen #panel .panel-button:hover, | ||||
|       .login-screen #panel .panel-button:active, | ||||
|       .lock-screen #panel .panel-button:focus, | ||||
|       .lock-screen #panel .panel-button:hover, | ||||
|       .lock-screen #panel .panel-button:active { | ||||
|         color: white; } | ||||
|   #panel .panel-status-indicators-box, | ||||
|   #panel .panel-status-menu-box { | ||||
| @@ -719,6 +723,21 @@ StScrollBar { | ||||
|     spacing: 0; } | ||||
|   #panel .screencast-indicator { | ||||
|     color: #f57900; } | ||||
|   #panel.solid { | ||||
|     background-color: black; | ||||
|     /* transition from transparent to solid */ | ||||
|     transition-duration: 300ms; } | ||||
|     #panel.solid .panel-corner { | ||||
|       -panel-corner-background-color: black; } | ||||
|     #panel.solid .panel-button { | ||||
|       color: #ccc; | ||||
|       text-shadow: none; } | ||||
|       #panel.solid .panel-button:hover { | ||||
|         color: white; } | ||||
|     #panel.solid .system-status-icon, | ||||
|     #panel.solid .app-menu-icon > StIcon, | ||||
|     #panel.solid .popup-menu-arrow { | ||||
|       icon-shadow: none; } | ||||
|  | ||||
| #calendarArea { | ||||
|   padding: 0.75em 1.0em; } | ||||
| @@ -769,6 +788,7 @@ StScrollBar { | ||||
| .events-section-title:hover, | ||||
| .events-section-title:focus { | ||||
|   background-color: #0d0d0d; } | ||||
|  | ||||
| .datemenu-today-button:active, | ||||
| .world-clocks-button:active, | ||||
| .weather-button:active, | ||||
| @@ -910,7 +930,7 @@ StScrollBar { | ||||
|   color: #999999; | ||||
|   font-size: 0.7em; | ||||
|   /* HACK: the label should be baseline-aligned with a 1em label, | ||||
|            fake this with some bottom padding */ | ||||
|                      fake this with some bottom padding */ | ||||
|   padding-bottom: 0.13em; } | ||||
|  | ||||
| .message-secondary-bin > StIcon { | ||||
| @@ -1010,9 +1030,9 @@ StScrollBar { | ||||
|  | ||||
| /* NETWORK DIALOGS */ | ||||
| .nm-dialog { | ||||
|   max-height: 500px; | ||||
|   min-height: 450px; | ||||
|   min-width: 470px; } | ||||
|   max-height: 34em; | ||||
|   min-height: 31em; | ||||
|   min-width: 32em; } | ||||
|  | ||||
| .nm-dialog-content { | ||||
|   spacing: 20px; | ||||
| @@ -1130,31 +1150,30 @@ StScrollBar { | ||||
|   spacing: 3px; } | ||||
|  | ||||
| .search-section-separator { | ||||
|   -gradient-height: 1px; | ||||
|   -gradient-start: rgba(255, 255, 255, 0); | ||||
|   -gradient-end: rgba(255, 255, 255, 0.1); | ||||
|   -margin-horizontal: 1.5em; | ||||
|   height: 1px; } | ||||
|   height: 2px; | ||||
|   background-color: rgba(255, 255, 255, 0.2); } | ||||
|  | ||||
| .list-search-result-content { | ||||
|   spacing: 12px; | ||||
|   padding: 12px; } | ||||
|   spacing: 30px; } | ||||
|  | ||||
| .list-search-result-title { | ||||
|   font-size: 1.5em; | ||||
|   color: #e2e2df; } | ||||
|   color: #e2e2df; | ||||
|   spacing: 12px; } | ||||
|  | ||||
| .list-search-result-description { | ||||
|   color: #cacac4; } | ||||
|   color: rgba(202, 202, 196, 0.5); } | ||||
|  | ||||
| .list-search-provider-details { | ||||
|   width: 150px; | ||||
|   color: #e2e2df; | ||||
|   margin-top: 0.24em; } | ||||
|  | ||||
| .list-search-provider-content { | ||||
|   spacing: 20px; } | ||||
|  | ||||
| .search-provider-icon { | ||||
|   padding: 15px; } | ||||
|  | ||||
| .search-provider-icon-more { | ||||
|   width: 16px; | ||||
|   height: 16px; | ||||
|   background-image: url("resource:///org/gnome/shell/theme/more-results.svg"); } | ||||
|  | ||||
| /* DASHBOARD */ | ||||
| #dash { | ||||
|   font-size: 9pt; | ||||
| @@ -1215,6 +1234,7 @@ StScrollBar { | ||||
| .list-search-result:active, | ||||
| .list-search-result:checked { | ||||
|   background-color: rgba(23, 25, 26, 0.9); } | ||||
|  | ||||
| .search-provider-icon:focus, .search-provider-icon:selected, .search-provider-icon:hover, | ||||
| .list-search-result:focus, | ||||
| .list-search-result:selected, | ||||
| @@ -1222,7 +1242,8 @@ StScrollBar { | ||||
|   background-color: rgba(238, 238, 236, 0.1); | ||||
|   transition-duration: 200ms; } | ||||
|  | ||||
| .app-well-app:active .overview-icon, .app-well-app:checked .overview-icon, | ||||
| .app-well-app:active .overview-icon, | ||||
| .app-well-app:checked .overview-icon, | ||||
| .app-well-app.app-folder:active .overview-icon, | ||||
| .app-well-app.app-folder:checked .overview-icon, | ||||
| .show-apps:active .overview-icon, | ||||
| @@ -1231,7 +1252,10 @@ StScrollBar { | ||||
| .grid-search-result:checked .overview-icon { | ||||
|   background-color: rgba(23, 25, 26, 0.9); | ||||
|   box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.7); } | ||||
| .app-well-app:hover .overview-icon, .app-well-app:focus .overview-icon, .app-well-app:selected .overview-icon, | ||||
|  | ||||
| .app-well-app:hover .overview-icon, | ||||
| .app-well-app:focus .overview-icon, | ||||
| .app-well-app:selected .overview-icon, | ||||
| .app-well-app.app-folder:hover .overview-icon, | ||||
| .app-well-app.app-folder:focus .overview-icon, | ||||
| .app-well-app.app-folder:selected .overview-icon, | ||||
| @@ -1657,10 +1681,12 @@ StScrollBar { | ||||
|  | ||||
| .login-dialog-user-selection-box { | ||||
|   padding: 100px 0px; } | ||||
|   .login-dialog-user-selection-box .login-dialog-not-listed-label { | ||||
|     padding-left: 2px; } | ||||
|     .login-dialog-not-listed-button:focus .login-dialog-user-selection-box .login-dialog-not-listed-label, .login-dialog-not-listed-button:hover .login-dialog-user-selection-box .login-dialog-not-listed-label { | ||||
|       color: #eeeeec; } | ||||
|  | ||||
| .login-dialog-not-listed-label { | ||||
|   padding-left: 2px; } | ||||
|   .login-dialog-not-listed-button:focus .login-dialog-not-listed-label, | ||||
|   .login-dialog-not-listed-button:hover .login-dialog-not-listed-label { | ||||
|     color: #eeeeec; } | ||||
|  | ||||
| .login-dialog-not-listed-label { | ||||
|   font-size: 90%; | ||||
| @@ -1675,7 +1701,7 @@ StScrollBar { | ||||
|   spacing: 12px; | ||||
|   padding: .2em; | ||||
|   width: 23em; } | ||||
|   .login-dialog-user-list:expanded .login-dialog-user-list-item:focus { | ||||
|   .login-dialog-user-list:expanded .login-dialog-user-list-item:selected { | ||||
|     background-color: #215d9c; | ||||
|     color: #ffffff; } | ||||
|   .login-dialog-user-list:expanded .login-dialog-user-list-item:logged-in { | ||||
| @@ -1689,9 +1715,6 @@ StScrollBar { | ||||
|     padding-right: 1em; } | ||||
|   .login-dialog-user-list-item:rtl { | ||||
|     padding-left: 1em; } | ||||
|   .login-dialog-user-list-item:hover { | ||||
|     background-color: #215d9c; | ||||
|     color: #ffffff; } | ||||
|   .login-dialog-user-list-item .login-dialog-timed-login-indicator { | ||||
|     height: 2px; | ||||
|     margin: 2px 0 0 0; | ||||
| @@ -1709,6 +1732,7 @@ StScrollBar { | ||||
|  | ||||
| .user-widget-label:ltr { | ||||
|   padding-left: 18px; } | ||||
|  | ||||
| .user-widget-label:rtl { | ||||
|   padding-right: 18px; } | ||||
|  | ||||
| @@ -1836,6 +1860,7 @@ StScrollBar { | ||||
| .lg-dialog StEntry { | ||||
|   selection-background-color: #bbbbbb; | ||||
|   selected-color: #333333; } | ||||
|  | ||||
| .lg-dialog .shell-link { | ||||
|   color: #999999; } | ||||
|   .lg-dialog .shell-link:hover { | ||||
|   | ||||
 Submodule data/theme/gnome-shell-sass updated: e94bce1fcf...82941c9d93
									
								
							| @@ -118,6 +118,7 @@ StEntry { | ||||
| /* Scrollbars */ | ||||
| StScrollView.vfade { | ||||
|   -st-vfade-offset: 68px; } | ||||
|  | ||||
| StScrollView.hfade { | ||||
|   -st-hfade-offset: 68px; } | ||||
|  | ||||
| @@ -152,14 +153,18 @@ StScrollBar { | ||||
| /* Check Boxes */ | ||||
| .check-box StBoxLayout { | ||||
|   spacing: .8em; } | ||||
|  | ||||
| .check-box StBin { | ||||
|   width: 24px; | ||||
|   height: 22px; | ||||
|   background-image: url("resource:///org/gnome/shell/theme/checkbox-off.svg"); } | ||||
|  | ||||
| .check-box:focus StBin { | ||||
|   background-image: url("resource:///org/gnome/shell/theme/checkbox-off-focused.svg"); } | ||||
|  | ||||
| .check-box:checked StBin { | ||||
|   background-image: url("resource:///org/gnome/shell/theme/checkbox.svg"); } | ||||
|  | ||||
| .check-box:focus:checked StBin { | ||||
|   background-image: url("resource:///org/gnome/shell/theme/checkbox-focused.svg"); } | ||||
|  | ||||
| @@ -216,11 +221,30 @@ StScrollBar { | ||||
|     color: #d6d6d1; | ||||
|     padding-bottom: .4em; } | ||||
|  | ||||
| .show-processes-dialog-subject, | ||||
| .mount-question-dialog-subject, | ||||
| .mount-dialog-subject, | ||||
| .end-session-dialog-subject { | ||||
|   font-size: 14pt; } | ||||
|  | ||||
| /* Message Dialog */ | ||||
| .message-dialog-main-layout { | ||||
|   padding: 12px 20px 0; | ||||
|   spacing: 12px; } | ||||
|  | ||||
| .message-dialog-content { | ||||
|   max-width: 28em; | ||||
|   spacing: 20px; } | ||||
|  | ||||
| .message-dialog-icon { | ||||
|   min-width: 48px; | ||||
|   icon-size: 48px; } | ||||
|  | ||||
| .message-dialog-title { | ||||
|   font-weight: bold; } | ||||
|  | ||||
| .message-dialog-subtitle { | ||||
|   color: #8e8e80; | ||||
|   font-weight: bold; } | ||||
|  | ||||
| /* End Session Dialog */ | ||||
| .end-session-dialog { | ||||
|   spacing: 42px; | ||||
| @@ -289,75 +313,62 @@ StScrollBar { | ||||
| .shell-mount-operation-icon { | ||||
|   icon-size: 48px; } | ||||
|  | ||||
| .show-processes-dialog, | ||||
| .mount-question-dialog { | ||||
| .mount-dialog { | ||||
|   spacing: 24px; } | ||||
|   .mount-dialog .message-dialog-title { | ||||
|     padding-top: 10px; | ||||
|     padding-left: 17px; | ||||
|     padding-bottom: 6px; | ||||
|     max-width: 34em; } | ||||
|   .mount-dialog .message-dialog-title:rtl { | ||||
|     padding-left: 0px; | ||||
|     padding-right: 17px; } | ||||
|   .mount-dialog .message-dialog-body { | ||||
|     padding-left: 17px; | ||||
|     width: 28em; } | ||||
|   .mount-dialog .message-dialog-body:rtl { | ||||
|     padding-left: 0px; | ||||
|     padding-right: 17px; } | ||||
|  | ||||
| .show-processes-dialog-subject, | ||||
| .mount-question-dialog-subject { | ||||
|   padding-top: 10px; | ||||
|   padding-left: 17px; | ||||
|   padding-bottom: 6px; } | ||||
|  | ||||
| .mount-question-dialog-subject { | ||||
|   max-width: 500px; } | ||||
|  | ||||
| .show-processes-dialog-subject:rtl, | ||||
| .mount-question-dialog-subject:rtl { | ||||
|   padding-left: 0px; | ||||
|   padding-right: 17px; } | ||||
|  | ||||
| .show-processes-dialog-description, | ||||
| .mount-question-dialog-description { | ||||
|   padding-left: 17px; | ||||
|   width: 28em; } | ||||
|  | ||||
| .show-processes-dialog-description:rtl, | ||||
| .mount-question-dialog-description:rtl { | ||||
|   padding-right: 17px; } | ||||
|  | ||||
| .show-processes-dialog-app-list { | ||||
| .mount-dialog-app-list { | ||||
|   max-height: 200px; | ||||
|   padding-top: 24px; | ||||
|   padding-left: 49px; | ||||
|   padding-right: 32px; } | ||||
|  | ||||
| .show-processes-dialog-app-list:rtl { | ||||
| .mount-dialog-app-list:rtl { | ||||
|   padding-right: 49px; | ||||
|   padding-left: 32px; } | ||||
|  | ||||
| .show-processes-dialog-app-list-item { | ||||
| .mount-dialog-app-list-item { | ||||
|   color: #d6d6d1; } | ||||
|   .show-processes-dialog-app-list-item:hover { | ||||
|   .mount-dialog-app-list-item:hover { | ||||
|     color: #eeeeec; } | ||||
|   .show-processes-dialog-app-list-item:ltr { | ||||
|   .mount-dialog-app-list-item:ltr { | ||||
|     padding-right: 1em; } | ||||
|   .show-processes-dialog-app-list-item:rtl { | ||||
|   .mount-dialog-app-list-item:rtl { | ||||
|     padding-left: 1em; } | ||||
|  | ||||
| .show-processes-dialog-app-list-item-icon:ltr { | ||||
| .mount-dialog-app-list-item-icon:ltr { | ||||
|   padding-right: 17px; } | ||||
| .show-processes-dialog-app-list-item-icon:rtl { | ||||
|  | ||||
| .mount-dialog-app-list-item-icon:rtl { | ||||
|   padding-left: 17px; } | ||||
|  | ||||
| .show-processes-dialog-app-list-item-name { | ||||
| .mount-dialog-app-list-item-name { | ||||
|   font-size: 10pt; } | ||||
|  | ||||
| /* Password or Authentication Dialog */ | ||||
| .prompt-dialog { | ||||
|   width: 500px; | ||||
|   width: 34em; | ||||
|   border: 3px solid rgba(238, 238, 236, 0.2); } | ||||
|  | ||||
| .prompt-dialog-main-layout { | ||||
|   spacing: 24px; | ||||
|   padding: 10px; } | ||||
|  | ||||
| .prompt-dialog-message-layout { | ||||
|   spacing: 16px; } | ||||
|  | ||||
| .prompt-dialog-headline { | ||||
|   font-weight: bold; | ||||
|   color: #b2b2a9; } | ||||
|   .prompt-dialog .message-dialog-main-layout { | ||||
|     spacing: 24px; | ||||
|     padding: 10px; } | ||||
|   .prompt-dialog .message-dialog-content { | ||||
|     spacing: 16px; } | ||||
|   .prompt-dialog .message-dialog-title { | ||||
|     color: #b2b2a9; } | ||||
|  | ||||
| .prompt-dialog-description:rtl { | ||||
|   text-align: right; } | ||||
| @@ -431,44 +442,17 @@ StScrollBar { | ||||
| .access-dialog { | ||||
|   spacing: 30px; } | ||||
|  | ||||
| .access-dialog-main-layout { | ||||
|   padding: 12px 20px 0; | ||||
|   spacing: 12px; } | ||||
|  | ||||
| .access-dialog-content { | ||||
|   max-width: 28em; | ||||
|   spacing: 20px; } | ||||
|  | ||||
| .access-dialog-icon { | ||||
|   min-width: 48px; | ||||
|   icon-size: 48px; } | ||||
|  | ||||
| .access-dialog-title { | ||||
|   font-weight: bold; } | ||||
|  | ||||
| .access-dialog-subtitle { | ||||
|   color: #8e8e80; | ||||
|   font-weight: bold; } | ||||
|  | ||||
| /* Geolocation Dialog */ | ||||
| .geolocation-dialog { | ||||
|   spacing: 30px; } | ||||
|  | ||||
| .geolocation-dialog-main-layout { | ||||
|   spacing: 12px; } | ||||
| /* Extension Dialog */ | ||||
| .extension-dialog .message-dialog-main-layout { | ||||
|   spacing: 24px; | ||||
|   padding: 10px; } | ||||
|  | ||||
| .geolocation-dialog-content { | ||||
|   spacing: 20px; } | ||||
|  | ||||
| .geolocation-dialog-icon { | ||||
|   icon-size: 48px; } | ||||
|  | ||||
| .geolocation-dialog-title { | ||||
|   font-weight: bold; } | ||||
|  | ||||
| .geolocation-dialog-reason { | ||||
|   color: #8e8e80; | ||||
|   font-weight: bold; } | ||||
| .extension-dialog .message-dialog-title { | ||||
|   color: #b2b2a9; } | ||||
|  | ||||
| /* Network Agent Dialog */ | ||||
| .network-dialog-secret-table { | ||||
| @@ -669,7 +653,9 @@ StScrollBar { | ||||
|  | ||||
| /* TOP BAR */ | ||||
| #panel { | ||||
|   background-color: black; | ||||
|   background-color: rgba(0, 0, 0, 0.2); | ||||
|   /* transition from solid to transparent */ | ||||
|   transition-duration: 500ms; | ||||
|   font-weight: bold; | ||||
|   height: 1.86em; } | ||||
|   #panel.unlock-screen, #panel.login-screen, #panel.lock-screen { | ||||
| @@ -678,7 +664,7 @@ StScrollBar { | ||||
|     spacing: 4px; } | ||||
|   #panel .panel-corner { | ||||
|     -panel-corner-radius: 6px; | ||||
|     -panel-corner-background-color: black; | ||||
|     -panel-corner-background-color: rgba(0, 0, 0, 0.2); | ||||
|     -panel-corner-border-width: 2px; | ||||
|     -panel-corner-border-color: transparent; } | ||||
|     #panel .panel-corner:active, #panel .panel-corner:overview, #panel .panel-corner:focus { | ||||
| @@ -691,14 +677,24 @@ StScrollBar { | ||||
|     -natural-hpadding: 12px; | ||||
|     -minimum-hpadding: 6px; | ||||
|     font-weight: bold; | ||||
|     color: #ccc; | ||||
|     color: #eee; | ||||
|     text-shadow: 0px 0px 2px rgba(0, 0, 0, 0.9); | ||||
|     transition-duration: 100ms; } | ||||
|     #panel .panel-button .app-menu-icon { | ||||
|       -st-icon-style: symbolic; | ||||
|       margin-left: 4px; | ||||
|       margin-right: 4px; } | ||||
|     #panel .panel-button .system-status-icon, | ||||
|     #panel .panel-button .app-menu-icon > StIcon, | ||||
|     #panel .panel-button .popup-menu-arrow { | ||||
|       icon-shadow: 0px 0px 2px rgba(0, 0, 0, 0.9); } | ||||
|     #panel .panel-button:hover { | ||||
|       color: white; } | ||||
|       color: white; | ||||
|       text-shadow: 0px 0px 8px black; } | ||||
|       #panel .panel-button:hover .system-status-icon, | ||||
|       #panel .panel-button:hover .app-menu-icon > StIcon, | ||||
|       #panel .panel-button:hover .popup-menu-arrow { | ||||
|         icon-shadow: 0px 0px 8px black; } | ||||
|     #panel .panel-button:active, #panel .panel-button:overview, #panel .panel-button:focus, #panel .panel-button:checked { | ||||
|       background-color: rgba(0, 0, 0, 0.01); | ||||
|       box-shadow: inset 0 -2px 0px #256ab1; | ||||
| @@ -708,9 +704,17 @@ StScrollBar { | ||||
|     #panel .panel-button .system-status-icon { | ||||
|       icon-size: 1.09em; | ||||
|       padding: 0 5px; } | ||||
|     .unlock-screen #panel .panel-button, .login-screen #panel .panel-button, .lock-screen #panel .panel-button { | ||||
|     .unlock-screen #panel .panel-button, | ||||
|     .login-screen #panel .panel-button, | ||||
|     .lock-screen #panel .panel-button { | ||||
|       color: white; } | ||||
|       .unlock-screen #panel .panel-button:focus, .unlock-screen #panel .panel-button:hover, .unlock-screen #panel .panel-button:active, .login-screen #panel .panel-button:focus, .login-screen #panel .panel-button:hover, .login-screen #panel .panel-button:active, .lock-screen #panel .panel-button:focus, .lock-screen #panel .panel-button:hover, .lock-screen #panel .panel-button:active { | ||||
|       .unlock-screen #panel .panel-button:focus, .unlock-screen #panel .panel-button:hover, .unlock-screen #panel .panel-button:active, | ||||
|       .login-screen #panel .panel-button:focus, | ||||
|       .login-screen #panel .panel-button:hover, | ||||
|       .login-screen #panel .panel-button:active, | ||||
|       .lock-screen #panel .panel-button:focus, | ||||
|       .lock-screen #panel .panel-button:hover, | ||||
|       .lock-screen #panel .panel-button:active { | ||||
|         color: white; } | ||||
|   #panel .panel-status-indicators-box, | ||||
|   #panel .panel-status-menu-box { | ||||
| @@ -719,6 +723,21 @@ StScrollBar { | ||||
|     spacing: 0; } | ||||
|   #panel .screencast-indicator { | ||||
|     color: #f57900; } | ||||
|   #panel.solid { | ||||
|     background-color: black; | ||||
|     /* transition from transparent to solid */ | ||||
|     transition-duration: 300ms; } | ||||
|     #panel.solid .panel-corner { | ||||
|       -panel-corner-background-color: black; } | ||||
|     #panel.solid .panel-button { | ||||
|       color: #ccc; | ||||
|       text-shadow: none; } | ||||
|       #panel.solid .panel-button:hover { | ||||
|         color: white; } | ||||
|     #panel.solid .system-status-icon, | ||||
|     #panel.solid .app-menu-icon > StIcon, | ||||
|     #panel.solid .popup-menu-arrow { | ||||
|       icon-shadow: none; } | ||||
|  | ||||
| #calendarArea { | ||||
|   padding: 0.75em 1.0em; } | ||||
| @@ -769,6 +788,7 @@ StScrollBar { | ||||
| .events-section-title:hover, | ||||
| .events-section-title:focus { | ||||
|   background-color: #454c4c; } | ||||
|  | ||||
| .datemenu-today-button:active, | ||||
| .world-clocks-button:active, | ||||
| .weather-button:active, | ||||
| @@ -910,7 +930,7 @@ StScrollBar { | ||||
|   color: #8e8e80; | ||||
|   font-size: 0.7em; | ||||
|   /* HACK: the label should be baseline-aligned with a 1em label, | ||||
|            fake this with some bottom padding */ | ||||
|                      fake this with some bottom padding */ | ||||
|   padding-bottom: 0.13em; } | ||||
|  | ||||
| .message-secondary-bin > StIcon { | ||||
| @@ -1010,9 +1030,9 @@ StScrollBar { | ||||
|  | ||||
| /* NETWORK DIALOGS */ | ||||
| .nm-dialog { | ||||
|   max-height: 500px; | ||||
|   min-height: 450px; | ||||
|   min-width: 470px; } | ||||
|   max-height: 34em; | ||||
|   min-height: 31em; | ||||
|   min-width: 32em; } | ||||
|  | ||||
| .nm-dialog-content { | ||||
|   spacing: 20px; | ||||
| @@ -1130,31 +1150,30 @@ StScrollBar { | ||||
|   spacing: 3px; } | ||||
|  | ||||
| .search-section-separator { | ||||
|   -gradient-height: 1px; | ||||
|   -gradient-start: rgba(255, 255, 255, 0); | ||||
|   -gradient-end: rgba(255, 255, 255, 0.1); | ||||
|   -margin-horizontal: 1.5em; | ||||
|   height: 1px; } | ||||
|   height: 2px; | ||||
|   background-color: rgba(255, 255, 255, 0.2); } | ||||
|  | ||||
| .list-search-result-content { | ||||
|   spacing: 12px; | ||||
|   padding: 12px; } | ||||
|   spacing: 30px; } | ||||
|  | ||||
| .list-search-result-title { | ||||
|   font-size: 1.5em; | ||||
|   color: #e2e2df; } | ||||
|   color: #e2e2df; | ||||
|   spacing: 12px; } | ||||
|  | ||||
| .list-search-result-description { | ||||
|   color: #cacac4; } | ||||
|   color: rgba(202, 202, 196, 0.5); } | ||||
|  | ||||
| .list-search-provider-details { | ||||
|   width: 150px; | ||||
|   color: #e2e2df; | ||||
|   margin-top: 0.24em; } | ||||
|  | ||||
| .list-search-provider-content { | ||||
|   spacing: 20px; } | ||||
|  | ||||
| .search-provider-icon { | ||||
|   padding: 15px; } | ||||
|  | ||||
| .search-provider-icon-more { | ||||
|   width: 16px; | ||||
|   height: 16px; | ||||
|   background-image: url("resource:///org/gnome/shell/theme/more-results.svg"); } | ||||
|  | ||||
| /* DASHBOARD */ | ||||
| #dash { | ||||
|   font-size: 9pt; | ||||
| @@ -1215,6 +1234,7 @@ StScrollBar { | ||||
| .list-search-result:active, | ||||
| .list-search-result:checked { | ||||
|   background-color: rgba(23, 25, 26, 0.9); } | ||||
|  | ||||
| .search-provider-icon:focus, .search-provider-icon:selected, .search-provider-icon:hover, | ||||
| .list-search-result:focus, | ||||
| .list-search-result:selected, | ||||
| @@ -1222,7 +1242,8 @@ StScrollBar { | ||||
|   background-color: rgba(238, 238, 236, 0.1); | ||||
|   transition-duration: 200ms; } | ||||
|  | ||||
| .app-well-app:active .overview-icon, .app-well-app:checked .overview-icon, | ||||
| .app-well-app:active .overview-icon, | ||||
| .app-well-app:checked .overview-icon, | ||||
| .app-well-app.app-folder:active .overview-icon, | ||||
| .app-well-app.app-folder:checked .overview-icon, | ||||
| .show-apps:active .overview-icon, | ||||
| @@ -1231,7 +1252,10 @@ StScrollBar { | ||||
| .grid-search-result:checked .overview-icon { | ||||
|   background-color: rgba(23, 25, 26, 0.9); | ||||
|   box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.7); } | ||||
| .app-well-app:hover .overview-icon, .app-well-app:focus .overview-icon, .app-well-app:selected .overview-icon, | ||||
|  | ||||
| .app-well-app:hover .overview-icon, | ||||
| .app-well-app:focus .overview-icon, | ||||
| .app-well-app:selected .overview-icon, | ||||
| .app-well-app.app-folder:hover .overview-icon, | ||||
| .app-well-app.app-folder:focus .overview-icon, | ||||
| .app-well-app.app-folder:selected .overview-icon, | ||||
| @@ -1657,10 +1681,12 @@ StScrollBar { | ||||
|  | ||||
| .login-dialog-user-selection-box { | ||||
|   padding: 100px 0px; } | ||||
|   .login-dialog-user-selection-box .login-dialog-not-listed-label { | ||||
|     padding-left: 2px; } | ||||
|     .login-dialog-not-listed-button:focus .login-dialog-user-selection-box .login-dialog-not-listed-label, .login-dialog-not-listed-button:hover .login-dialog-user-selection-box .login-dialog-not-listed-label { | ||||
|       color: #eeeeec; } | ||||
|  | ||||
| .login-dialog-not-listed-label { | ||||
|   padding-left: 2px; } | ||||
|   .login-dialog-not-listed-button:focus .login-dialog-not-listed-label, | ||||
|   .login-dialog-not-listed-button:hover .login-dialog-not-listed-label { | ||||
|     color: #eeeeec; } | ||||
|  | ||||
| .login-dialog-not-listed-label { | ||||
|   font-size: 90%; | ||||
| @@ -1675,7 +1701,7 @@ StScrollBar { | ||||
|   spacing: 12px; | ||||
|   padding: .2em; | ||||
|   width: 23em; } | ||||
|   .login-dialog-user-list:expanded .login-dialog-user-list-item:focus { | ||||
|   .login-dialog-user-list:expanded .login-dialog-user-list-item:selected { | ||||
|     background-color: #215d9c; | ||||
|     color: #ffffff; } | ||||
|   .login-dialog-user-list:expanded .login-dialog-user-list-item:logged-in { | ||||
| @@ -1689,9 +1715,6 @@ StScrollBar { | ||||
|     padding-right: 1em; } | ||||
|   .login-dialog-user-list-item:rtl { | ||||
|     padding-left: 1em; } | ||||
|   .login-dialog-user-list-item:hover { | ||||
|     background-color: #215d9c; | ||||
|     color: #ffffff; } | ||||
|   .login-dialog-user-list-item .login-dialog-timed-login-indicator { | ||||
|     height: 2px; | ||||
|     margin: 2px 0 0 0; | ||||
| @@ -1709,6 +1732,7 @@ StScrollBar { | ||||
|  | ||||
| .user-widget-label:ltr { | ||||
|   padding-left: 18px; } | ||||
|  | ||||
| .user-widget-label:rtl { | ||||
|   padding-right: 18px; } | ||||
|  | ||||
| @@ -1836,6 +1860,7 @@ StScrollBar { | ||||
| .lg-dialog StEntry { | ||||
|   selection-background-color: #bbbbbb; | ||||
|   selected-color: #333333; } | ||||
|  | ||||
| .lg-dialog .shell-link { | ||||
|   color: #999999; } | ||||
|   .lg-dialog .shell-link:hover { | ||||
|   | ||||
							
								
								
									
										21
									
								
								data/theme/meson.build
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								data/theme/meson.build
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | ||||
| theme_sources = files([ | ||||
|   'gnome-shell-high-contrast.scss', | ||||
|   'gnome-shell.scss', | ||||
|   'gnome-shell-sass/_colors.scss', | ||||
|   'gnome-shell-sass/_common.scss', | ||||
|   'gnome-shell-sass/_drawing.scss', | ||||
|   'gnome-shell-sass/_high-contrast-colors.scss' | ||||
| ]) | ||||
|  | ||||
| theme_deps = [] | ||||
|  | ||||
| if sassc.found() | ||||
|   parse_sass = files('parse-sass.sh') | ||||
|  | ||||
|   theme_deps += custom_target('update-theme', | ||||
|     output: 'theme-update.stamp', | ||||
|     depend_files: theme_sources, | ||||
|     command: [parse_sass, '@OUTPUT@'], | ||||
|     build_by_default: true | ||||
|   ) | ||||
| endif | ||||
| @@ -1,114 +0,0 @@ | ||||
| <?xml version="1.0" encoding="UTF-8" standalone="no"?> | ||||
| <!-- Created with Inkscape (http://www.inkscape.org/) --> | ||||
|  | ||||
| <svg | ||||
|    xmlns:dc="http://purl.org/dc/elements/1.1/" | ||||
|    xmlns:cc="http://creativecommons.org/ns#" | ||||
|    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" | ||||
|    xmlns:svg="http://www.w3.org/2000/svg" | ||||
|    xmlns="http://www.w3.org/2000/svg" | ||||
|    xmlns:xlink="http://www.w3.org/1999/xlink" | ||||
|    xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" | ||||
|    xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" | ||||
|    width="16" | ||||
|    height="16" | ||||
|    id="svg12430" | ||||
|    version="1.1" | ||||
|    inkscape:version="0.48.4 r9939" | ||||
|    sodipodi:docname="more-results.svg"> | ||||
|   <defs | ||||
|      id="defs12432" /> | ||||
|   <sodipodi:namedview | ||||
|      id="base" | ||||
|      pagecolor="#7a7a7a" | ||||
|      bordercolor="#666666" | ||||
|      borderopacity="1.0" | ||||
|      inkscape:pageopacity="1" | ||||
|      inkscape:pageshadow="2" | ||||
|      inkscape:zoom="90.509668" | ||||
|      inkscape:cx="6.5009792" | ||||
|      inkscape:cy="8.3589595" | ||||
|      inkscape:document-units="px" | ||||
|      inkscape:current-layer="g14642-3-0" | ||||
|      showgrid="false" | ||||
|      borderlayer="true" | ||||
|      inkscape:showpageshadow="false" | ||||
|      inkscape:window-width="1440" | ||||
|      inkscape:window-height="840" | ||||
|      inkscape:window-x="0" | ||||
|      inkscape:window-y="27" | ||||
|      inkscape:window-maximized="1"> | ||||
|     <inkscape:grid | ||||
|        type="xygrid" | ||||
|        id="grid13002" /> | ||||
|   </sodipodi:namedview> | ||||
|   <metadata | ||||
|      id="metadata12435"> | ||||
|     <rdf:RDF> | ||||
|       <cc:Work | ||||
|          rdf:about=""> | ||||
|         <dc:format>image/svg+xml</dc:format> | ||||
|         <dc:type | ||||
|            rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> | ||||
|         <dc:title /> | ||||
|       </cc:Work> | ||||
|     </rdf:RDF> | ||||
|   </metadata> | ||||
|   <g | ||||
|      inkscape:label="Layer 1" | ||||
|      inkscape:groupmode="layer" | ||||
|      id="layer1" | ||||
|      transform="translate(0,-1036.3622)"> | ||||
|     <g | ||||
|        style="display:inline" | ||||
|        transform="translate(-141.99984,638.37113)" | ||||
|        inkscape:label="zoom-in" | ||||
|        id="g14642-3-0"> | ||||
|       <path | ||||
|          sodipodi:type="inkscape:offset" | ||||
|          inkscape:radius="0" | ||||
|          inkscape:original="M 145.1875 400 C 144.5248 400 144 400.54899 144 401.21875 L 144 410.78125 C 144 411.45101 144.5248 412 145.1875 412 L 154.8125 412 C 155.4752 412 156 411.45101 156 410.78125 L 156 401.21875 C 156 400.54899 155.4752 400 154.8125 400 L 145.1875 400 z M 149 403 L 151 403 L 151 405 L 153 405 L 153 407 L 151 407 L 151 409 L 149 409 L 149 407 L 147 407 L 147 405 L 149 405 L 149 403 z " | ||||
|          xlink:href="#rect11749-5-0-1-8" | ||||
|          style="color:#bebebe;fill:#000000;fill-opacity:1;stroke:none;stroke-width:2;marker:none;visibility:visible;display:inline;overflow:visible;opacity:0.8" | ||||
|          id="path13004" | ||||
|          inkscape:href="#rect11749-5-0-1-8" | ||||
|          d="M 145.1875,400 C 144.5248,400 144,400.54899 144,401.21875 l 0,9.5625 c 0,0.66976 0.5248,1.21875 1.1875,1.21875 l 9.625,0 c 0.6627,0 1.1875,-0.54899 1.1875,-1.21875 l 0,-9.5625 C 156,400.54899 155.4752,400 154.8125,400 L 145.1875,400 z m 3.8125,3 2,0 0,2 2,0 0,2 -2,0 0,2 -2,0 0,-2 -2,0 0,-2 2,0 L 149,403 Z" | ||||
|          transform="translate(0,1)" /> | ||||
|       <use | ||||
|          x="0" | ||||
|          y="0" | ||||
|          xlink:href="#path13004" | ||||
|          id="use11960" | ||||
|          transform="translate(1,-1)" | ||||
|          width="16" | ||||
|          height="16" /> | ||||
|       <use | ||||
|          x="0" | ||||
|          y="0" | ||||
|          xlink:href="#use11960" | ||||
|          id="use11962" | ||||
|          transform="translate(-2,0)" | ||||
|          width="16" | ||||
|          height="16" /> | ||||
|       <path | ||||
|          style="fill:#000000;fill-opacity:1;fill-rule:evenodd;stroke:#000000;stroke-width:0;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1" | ||||
|          d="M 7 5 L 7 7 L 5 7 L 5 9 L 7 9 L 7 11 L 9 11 L 9 9 L 11 9 L 11 7 L 9 7 L 9 5 L 7 5 z " | ||||
|          transform="translate(141.99984,397.99107)" | ||||
|          id="rect3757" /> | ||||
|       <path | ||||
|          inkscape:connector-curvature="0" | ||||
|          style="color:#bebebe;fill:#ffffff;fill-opacity:1;stroke:none;stroke-width:2;marker:none;visibility:visible;display:inline;overflow:visible" | ||||
|          d="M 145.1875,400 C 144.5248,400 144,400.54899 144,401.21875 l 0,9.5625 c 0,0.66976 0.5248,1.21875 1.1875,1.21875 l 9.625,0 c 0.6627,0 1.1875,-0.54899 1.1875,-1.21875 l 0,-9.5625 C 156,400.54899 155.4752,400 154.8125,400 L 145.1875,400 z m 3.8125,3 2,0 0,2 2,0 0,2 -2,0 0,2 -2,0 0,-2 -2,0 0,-2 2,0 L 149,403 Z" | ||||
|          id="rect11749-5-0-1-8" /> | ||||
|       <rect | ||||
|          style="fill:none;stroke:none" | ||||
|          id="rect3620-5-4" | ||||
|          width="15.981825" | ||||
|          height="16" | ||||
|          x="142" | ||||
|          y="398" | ||||
|          rx="0" | ||||
|          ry="0" /> | ||||
|     </g> | ||||
|   </g> | ||||
| </svg> | ||||
| Before Width: | Height: | Size: 4.4 KiB | 
| @@ -1,3 +1,10 @@ | ||||
| #!/usr/bin/bash | ||||
| #!/usr/bin/sh | ||||
|  | ||||
| bundle exec sass --update --sourcemap=none . | ||||
| srcdir=`dirname $0` | ||||
| stamp=${1} | ||||
| for scss in $srcdir/*.scss | ||||
| do | ||||
|   sassc -a $scss ${scss%%.scss}.css || exit 1 | ||||
| done | ||||
|  | ||||
| [ "$stamp" ] && touch $stamp | ||||
|   | ||||
							
								
								
									
										5
									
								
								docs/reference/meson.build
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								docs/reference/meson.build
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | ||||
| version_conf = configuration_data() | ||||
| version_conf.set('VERSION', meson.project_version()) | ||||
|  | ||||
| subdir('shell') | ||||
| subdir('st') | ||||
| @@ -113,14 +113,14 @@ expand_content_files= | ||||
| # e.g. GTKDOC_CFLAGS=-I$(top_srcdir) -I$(top_builddir) $(GTK_DEBUG_FLAGS) | ||||
| # e.g. GTKDOC_LIBS=$(top_builddir)/gtk/$(gtktargetlib) | ||||
| GTKDOC_CFLAGS=$(GNOME_SHELL_CFLAGS) | ||||
| GTKDOC_LIBS=$(GNOME_SHELL_LIBS) $(top_builddir)/src/libgnome-shell-menu.la $(top_builddir)/src/libgnome-shell-base.la $(top_builddir)/src/libgnome-shell.la -rpath $(MUTTER_TYPELIB_DIR) | ||||
| GTKDOC_LIBS=$(GNOME_SHELL_LIBS) $(top_builddir)/src/libgnome-shell-menu.la $(top_builddir)/src/libgnome-shell.la -rpath $(MUTTER_TYPELIB_DIR) | ||||
|  | ||||
| # This includes the standard gtk-doc make rules, copied by gtkdocize. | ||||
| include $(top_srcdir)/gtk-doc.make | ||||
|  | ||||
| # Other files to distribute | ||||
| # e.g. EXTRA_DIST += version.xml.in | ||||
| EXTRA_DIST += | ||||
| EXTRA_DIST += version.xml.in | ||||
|  | ||||
| # Files not to distribute | ||||
| # for --rebuild-types in $(SCAN_OPTIONS), e.g. $(DOC_MODULE).types | ||||
|   | ||||
							
								
								
									
										57
									
								
								docs/reference/shell/meson.build
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										57
									
								
								docs/reference/shell/meson.build
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,57 @@ | ||||
| private_headers = [ | ||||
|   'gactionmuxer.h', | ||||
|   'gactionobservable.h', | ||||
|   'gactionobserver.h', | ||||
|   'shell-network-agent.h', | ||||
|   'shell-recorder-src.h' | ||||
| ] | ||||
|  | ||||
| if not enable_recorder | ||||
|   private_headers += 'shell-recorder.h' | ||||
| endif | ||||
|  | ||||
| exclude_directories = [ | ||||
|   'calendar-server', | ||||
|   'hotplug-sniffer', | ||||
|   'st', | ||||
|   'tray' | ||||
| ] | ||||
|  | ||||
| ifaces = [ | ||||
|   ['org.gnome.Shell.Screenshot', 'org.gnome.Shell.Screenshot.xml'], | ||||
|   ['org.gnome.ShellSearchProvider', 'org.gnome.Shell.SearchProvider.xml'], | ||||
|   ['org.gnome.ShellSearchProvider2', 'org.gnome.Shell.SearchProvider2.xml'] | ||||
| ] | ||||
| foreach iface : ifaces | ||||
|   custom_target(iface[0] + ' docs', | ||||
|     input: '../../../data/@0@.xml'.format(iface[0]), | ||||
|     output: 'doc-gen-' + iface[1], | ||||
|     command: [ | ||||
|       'gdbus-codegen', | ||||
|       '--interface-prefix=@0@.'.format(iface), | ||||
|       '--generate-docbook', 'doc-gen', | ||||
|       '--output-directory', '@OUTDIR@', | ||||
|       '@INPUT@' | ||||
|     ], | ||||
|     build_by_default: true | ||||
|   ) | ||||
| endforeach | ||||
|  | ||||
| configure_file( | ||||
|   input: 'version.xml.in', | ||||
|   output: 'version.xml', | ||||
|   configuration: version_conf | ||||
| ) | ||||
|  | ||||
| gnome.gtkdoc('shell', | ||||
|   main_sgml: 'shell-docs.sgml', | ||||
|   src_dir: [ | ||||
|     join_paths(meson.source_root(), 'src'), | ||||
|     join_paths(meson.build_root(), 'src') | ||||
|   ], | ||||
|   scan_args: [ | ||||
|     '--ignore-headers=' + ' '.join(private_headers + exclude_directories), | ||||
|     '--rebuild-types' | ||||
|   ], | ||||
|   install: true | ||||
| ) | ||||
| @@ -3,12 +3,13 @@ | ||||
|                "http://www.oasis-open.org/docbook/xml/4.3/docbookx.dtd" | ||||
| [ | ||||
|   <!ENTITY % local.common.attrib "xmlns:xi  CDATA  #FIXED 'http://www.w3.org/2003/XInclude'"> | ||||
|   <!ENTITY version SYSTEM "version.xml"> | ||||
| ]> | ||||
| <book id="index"> | ||||
|   <bookinfo> | ||||
|     <title>Shell Reference Manual</title> | ||||
|     <releaseinfo> | ||||
|       for Shell @VERSION@. | ||||
|       for Shell &version;. | ||||
|       <!--The latest version of this documentation can be found on-line at | ||||
|       <ulink role="online-location" url="http://[SERVER]/shell/index.html">http://[SERVER]/shell/</ulink>.--> | ||||
|     </releaseinfo> | ||||
| @@ -51,10 +52,15 @@ | ||||
|     <xi:include href="xml/shell-mount-operation.xml"/> | ||||
|     <xi:include href="xml/shell-polkit-authentication-agent.xml"/> | ||||
|   </chapter> | ||||
|   <!-- FIXME: | ||||
|        Not generated at the moment, find out whether to blame gtk-doc or meson | ||||
|   --> | ||||
|   <!-- | ||||
|   <chapter id="object-tree"> | ||||
|     <title>Object Hierarchy</title> | ||||
|      <xi:include href="xml/tree_index.sgml"/> | ||||
|   </chapter> | ||||
|   --> | ||||
|   <index id="api-index-full"> | ||||
|     <title>API Index</title> | ||||
|     <xi:include href="xml/api-index-full.xml"><xi:fallback /></xi:include> | ||||
							
								
								
									
										1
									
								
								docs/reference/shell/version.xml.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								docs/reference/shell/version.xml.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| @VERSION@ | ||||
| @@ -85,7 +85,7 @@ include $(top_srcdir)/gtk-doc.make | ||||
|  | ||||
| # Other files to distribute | ||||
| # e.g. EXTRA_DIST += version.xml.in | ||||
| EXTRA_DIST += | ||||
| EXTRA_DIST += version.xml.in | ||||
|  | ||||
| # Files not to distribute | ||||
| # for --rebuild-types in $(SCAN_OPTIONS), e.g. $(DOC_MODULE).types | ||||
|   | ||||
							
								
								
									
										24
									
								
								docs/reference/st/meson.build
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								docs/reference/st/meson.build
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,24 @@ | ||||
| private_headers = [ | ||||
|   'st-private.h', | ||||
|   'st-theme-node-private.h' | ||||
| ] | ||||
|  | ||||
| configure_file( | ||||
|   input: 'version.xml.in', | ||||
|   output: 'version.xml', | ||||
|   configuration: version_conf | ||||
| ) | ||||
|  | ||||
| gnome.gtkdoc('st', | ||||
|   main_sgml: 'st-docs.sgml', | ||||
|   src_dir: [ | ||||
|     join_paths(meson.source_root(), 'src', 'st'), | ||||
|     join_paths(meson.build_root(), 'src', 'st') | ||||
|   ], | ||||
|   scan_args: [ | ||||
|     '--ignore-headers=' + ' '.join(private_headers), | ||||
|     '--rebuild-sections', | ||||
|     '--rebuild-types' | ||||
|   ], | ||||
|   install: true | ||||
| ) | ||||
| @@ -3,12 +3,13 @@ | ||||
|                "http://www.oasis-open.org/docbook/xml/4.3/docbookx.dtd" | ||||
| [ | ||||
|   <!ENTITY % local.common.attrib "xmlns:xi  CDATA  #FIXED 'http://www.w3.org/2003/XInclude'"> | ||||
|   <!ENTITY version SYSTEM "version.xml"> | ||||
| ]> | ||||
| <book id="index"> | ||||
|   <bookinfo> | ||||
|     <title>St Reference Manual</title> | ||||
|     <releaseinfo> | ||||
|       for St @VERSION@. | ||||
|       for St &version;. | ||||
|       <!--The latest version of this documentation can be found on-line at | ||||
|       <ulink role="online-location" url="http://[SERVER]/st/index.html">http://[SERVER]/st/</ulink>.--> | ||||
|     </releaseinfo> | ||||
| @@ -46,10 +47,15 @@ | ||||
|       <xi:include href="xml/st-texture-cache.xml"/> | ||||
|     </chapter> | ||||
|   </part> | ||||
|   <!-- FIXME: | ||||
|        Not generated at the moment, find out whether to blame gtk-doc or meson | ||||
|   --> | ||||
|   <!-- | ||||
|   <chapter id="object-tree"> | ||||
|     <title>Object Hierarchy</title> | ||||
|      <xi:include href="xml/tree_index.sgml"/> | ||||
|   </chapter> | ||||
|   --> | ||||
|   <index id="api-index-full"> | ||||
|     <title>API Index</title> | ||||
|     <xi:include href="xml/api-index-full.xml"><xi:fallback /></xi:include> | ||||
							
								
								
									
										1
									
								
								docs/reference/st/version.xml.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								docs/reference/st/version.xml.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| @VERSION@ | ||||
| @@ -32,7 +32,7 @@ function stripPrefix(string, prefix) { | ||||
|     return string; | ||||
| } | ||||
|  | ||||
| const Application = new Lang.Class({ | ||||
| var Application = new Lang.Class({ | ||||
|     Name: 'Application', | ||||
|     _init: function() { | ||||
|         GLib.set_prgname('gnome-shell-extension-prefs'); | ||||
| @@ -253,7 +253,7 @@ const Application = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const DescriptionLabel = new Lang.Class({ | ||||
| var DescriptionLabel = new Lang.Class({ | ||||
|     Name: 'DescriptionLabel', | ||||
|     Extends: Gtk.Label, | ||||
|  | ||||
| @@ -265,7 +265,7 @@ const DescriptionLabel = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const ExtensionRow = new Lang.Class({ | ||||
| var ExtensionRow = new Lang.Class({ | ||||
|     Name: 'ExtensionRow', | ||||
|     Extends: Gtk.ListBoxRow, | ||||
|  | ||||
|   | ||||
							
								
								
									
										190
									
								
								js/gdm/authList.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										190
									
								
								js/gdm/authList.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,190 @@ | ||||
| // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | ||||
| /* | ||||
|  * Copyright 2017 Red Hat, Inc | ||||
|  * | ||||
|  * This program is free software; you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU General Public License as published by | ||||
|  * the Free Software Foundation; either version 2, or (at your option) | ||||
|  * any later version. | ||||
|  * | ||||
|  * This program is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  * GNU General Public License for more details. | ||||
|  * | ||||
|  * You should have received a copy of the GNU General Public License | ||||
|  * along with this program; if not, see <http://www.gnu.org/licenses/>. | ||||
|  */ | ||||
|  | ||||
| const Clutter = imports.gi.Clutter; | ||||
| const GObject = imports.gi.GObject; | ||||
| const Gtk = imports.gi.Gtk; | ||||
| const Lang = imports.lang; | ||||
| const Meta = imports.gi.Meta; | ||||
| const Signals = imports.signals; | ||||
| const St = imports.gi.St; | ||||
|  | ||||
| const Tweener = imports.ui.tweener; | ||||
|  | ||||
| const _SCROLL_ANIMATION_TIME = 0.5; | ||||
|  | ||||
| const AuthListItem = new Lang.Class({ | ||||
|     Name: 'AuthListItem', | ||||
|  | ||||
|     _init: function(key, text) { | ||||
|         this.key = key; | ||||
|         let label = new St.Label({ style_class: 'auth-list-item-label', | ||||
|                                    y_align: Clutter.ActorAlign.CENTER }); | ||||
|         label.text = text; | ||||
|  | ||||
|         this.actor = new St.Button({ style_class: 'login-dialog-user-list-item', | ||||
|                                      button_mask: St.ButtonMask.ONE | St.ButtonMask.THREE, | ||||
|                                      can_focus: true, | ||||
|                                      child: label, | ||||
|                                      reactive: true, | ||||
|                                      x_align: St.Align.START, | ||||
|                                      x_fill: true }); | ||||
|  | ||||
|         this.actor.connect('key-focus-in', () => { | ||||
|             this._setSelected(true); | ||||
|         }); | ||||
|         this.actor.connect('key-focus-out', () => { | ||||
|             this._setSelected(false); | ||||
|         }); | ||||
|         this.actor.connect('notify::hover', () => { | ||||
|             this._setSelected(this.actor.hover); | ||||
|         }); | ||||
|  | ||||
|         this.actor.connect('clicked', Lang.bind(this, this._onClicked)); | ||||
|     }, | ||||
|  | ||||
|     _onClicked: function() { | ||||
|         this.emit('activate'); | ||||
|     }, | ||||
|  | ||||
|     _setSelected: function(selected) { | ||||
|         if (selected) { | ||||
|             this.actor.add_style_pseudo_class('selected'); | ||||
|             this.actor.grab_key_focus(); | ||||
|         } else { | ||||
|             this.actor.remove_style_pseudo_class('selected'); | ||||
|         } | ||||
|     } | ||||
| }); | ||||
| Signals.addSignalMethods(AuthListItem.prototype); | ||||
|  | ||||
| const AuthList = new Lang.Class({ | ||||
|     Name: 'AuthList', | ||||
|  | ||||
|     _init: function() { | ||||
|         this.actor = new St.ScrollView({ style_class: 'login-dialog-user-list-view'}); | ||||
|         this.actor.set_policy(Gtk.PolicyType.NEVER, | ||||
|                               Gtk.PolicyType.AUTOMATIC); | ||||
|  | ||||
|         this._box = new St.BoxLayout({ vertical: true, | ||||
|                                        style_class: 'login-dialog-user-list', | ||||
|                                        pseudo_class: 'expanded' }); | ||||
|  | ||||
|         this.actor.add_actor(this._box); | ||||
|         this._items = {}; | ||||
|  | ||||
|         this.actor.connect('key-focus-in', Lang.bind(this, this._moveFocusToItems)); | ||||
|     }, | ||||
|  | ||||
|     _moveFocusToItems: function() { | ||||
|         let hasItems = Object.keys(this._items).length > 0; | ||||
|  | ||||
|         if (!hasItems) | ||||
|             return; | ||||
|  | ||||
|         if (global.stage.get_key_focus() != this.actor) | ||||
|             return; | ||||
|  | ||||
|         let focusSet = this.actor.navigate_focus(null, Gtk.DirectionType.TAB_FORWARD, false); | ||||
|         if (!focusSet) { | ||||
|             Meta.later_add(Meta.LaterType.BEFORE_REDRAW, Lang.bind(this, function() { | ||||
|                 this._moveFocusToItems(); | ||||
|                 return false; | ||||
|             })); | ||||
|         } | ||||
|     }, | ||||
|  | ||||
|     _onItemActivated: function(activatedItem) { | ||||
|         this.emit('activate', activatedItem.key); | ||||
|     }, | ||||
|  | ||||
|     scrollToItem: function(item) { | ||||
|         let box = item.actor.get_allocation_box(); | ||||
|  | ||||
|         let adjustment = this.actor.get_vscroll_bar().get_adjustment(); | ||||
|  | ||||
|         let value = (box.y1 + adjustment.step_increment / 2.0) - (adjustment.page_size / 2.0); | ||||
|         Tweener.removeTweens(adjustment); | ||||
|         Tweener.addTween (adjustment, | ||||
|                           { value: value, | ||||
|                             time: _SCROLL_ANIMATION_TIME, | ||||
|                             transition: 'easeOutQuad' }); | ||||
|     }, | ||||
|  | ||||
|     jumpToItem: function(item) { | ||||
|         let box = item.actor.get_allocation_box(); | ||||
|  | ||||
|         let adjustment = this.actor.get_vscroll_bar().get_adjustment(); | ||||
|  | ||||
|         let value = (box.y1 + adjustment.step_increment / 2.0) - (adjustment.page_size / 2.0); | ||||
|  | ||||
|         adjustment.set_value(value); | ||||
|     }, | ||||
|  | ||||
|     getItem: function(key) { | ||||
|         let item = this._items[key]; | ||||
|  | ||||
|         if (!item) | ||||
|             return null; | ||||
|  | ||||
|         return item; | ||||
|     }, | ||||
|  | ||||
|     addItem: function(key, text) { | ||||
|         this.removeItem(key); | ||||
|  | ||||
|         let item = new AuthListItem(key, text); | ||||
|         this._box.add(item.actor, { x_fill: true }); | ||||
|  | ||||
|         this._items[key] = item; | ||||
|  | ||||
|         item.connect('activate', | ||||
|                      Lang.bind(this, this._onItemActivated)); | ||||
|  | ||||
|         // Try to keep the focused item front-and-center | ||||
|         item.actor.connect('key-focus-in', | ||||
|                            Lang.bind(this, | ||||
|                                      function() { | ||||
|                                          this.scrollToItem(item); | ||||
|                                      })); | ||||
|  | ||||
|         this._moveFocusToItems(); | ||||
|  | ||||
|         this.emit('item-added', item); | ||||
|     }, | ||||
|  | ||||
|     removeItem: function(key) { | ||||
|         let item = this._items[key]; | ||||
|  | ||||
|         if (!item) | ||||
|             return; | ||||
|  | ||||
|         item.actor.destroy(); | ||||
|         delete this._items[key]; | ||||
|     }, | ||||
|  | ||||
|     numItems: function() { | ||||
|         return Object.keys(this._items).length; | ||||
|     }, | ||||
|  | ||||
|     clear: function() { | ||||
|         this._box.destroy_all_children(); | ||||
|         this._items = {}; | ||||
|     } | ||||
| }); | ||||
| Signals.addSignalMethods(AuthList.prototype); | ||||
| @@ -3,42 +3,43 @@ | ||||
| const Clutter = imports.gi.Clutter; | ||||
| const Gio = imports.gi.Gio; | ||||
| const Lang = imports.lang; | ||||
| const Pango = imports.gi.Pango; | ||||
| const Signals = imports.signals; | ||||
| const St = imports.gi.St; | ||||
|  | ||||
| const Animation = imports.ui.animation; | ||||
| const AuthList = imports.gdm.authList; | ||||
| const Batch = imports.gdm.batch; | ||||
| const GdmUtil = imports.gdm.util; | ||||
| const Params = imports.misc.params; | ||||
| const ShellEntry = imports.ui.shellEntry; | ||||
| const Tweener = imports.ui.tweener; | ||||
| const UserWidget = imports.ui.userWidget; | ||||
| const Pango = imports.gi.Pango; | ||||
|  | ||||
| const DEFAULT_BUTTON_WELL_ICON_SIZE = 16; | ||||
| const DEFAULT_BUTTON_WELL_ANIMATION_DELAY = 1.0; | ||||
| const DEFAULT_BUTTON_WELL_ANIMATION_TIME = 0.3; | ||||
| var DEFAULT_BUTTON_WELL_ICON_SIZE = 16; | ||||
| var DEFAULT_BUTTON_WELL_ANIMATION_DELAY = 1.0; | ||||
| var DEFAULT_BUTTON_WELL_ANIMATION_TIME = 0.3; | ||||
|  | ||||
| const MESSAGE_FADE_OUT_ANIMATION_TIME = 0.5; | ||||
| var MESSAGE_FADE_OUT_ANIMATION_TIME = 0.5; | ||||
|  | ||||
| const AuthPromptMode = { | ||||
| var AuthPromptMode = { | ||||
|     UNLOCK_ONLY: 0, | ||||
|     UNLOCK_OR_LOG_IN: 1 | ||||
| }; | ||||
|  | ||||
| const AuthPromptStatus = { | ||||
| var AuthPromptStatus = { | ||||
|     NOT_VERIFYING: 0, | ||||
|     VERIFYING: 1, | ||||
|     VERIFICATION_FAILED: 2, | ||||
|     VERIFICATION_SUCCEEDED: 3 | ||||
| }; | ||||
|  | ||||
| const BeginRequestType = { | ||||
| var BeginRequestType = { | ||||
|     PROVIDE_USERNAME: 0, | ||||
|     DONT_PROVIDE_USERNAME: 1 | ||||
| }; | ||||
|  | ||||
| const AuthPrompt = new Lang.Class({ | ||||
| var AuthPrompt = new Lang.Class({ | ||||
|     Name: 'AuthPrompt', | ||||
|  | ||||
|     _init: function(gdmClient, mode) { | ||||
| @@ -57,6 +58,7 @@ const AuthPrompt = new Lang.Class({ | ||||
|  | ||||
|         this._userVerifier.connect('ask-question', Lang.bind(this, this._onAskQuestion)); | ||||
|         this._userVerifier.connect('show-message', Lang.bind(this, this._onShowMessage)); | ||||
|         this._userVerifier.connect('show-choice-list', Lang.bind(this, this._onShowChoiceList)); | ||||
|         this._userVerifier.connect('verification-failed', Lang.bind(this, this._onVerificationFailed)); | ||||
|         this._userVerifier.connect('verification-complete', Lang.bind(this, this._onVerificationComplete)); | ||||
|         this._userVerifier.connect('reset', Lang.bind(this, this._onReset)); | ||||
| @@ -117,6 +119,17 @@ const AuthPrompt = new Lang.Class({ | ||||
|         this._message.clutter_text.ellipsize = Pango.EllipsizeMode.NONE; | ||||
|         this.actor.add(this._message, { x_fill: false, x_align: St.Align.START, y_align: St.Align.START }); | ||||
|  | ||||
|         this._authList = new AuthList.AuthList(); | ||||
|         this._authList.connect('activate', (list, key) => { | ||||
|             this._userVerifier.selectChoice(this._queryingService, key); | ||||
|         }); | ||||
|         this._authList.actor.hide(); | ||||
|         this.actor.add(this._authList.actor, | ||||
|                        { expand: true, | ||||
|                          x_fill: true, | ||||
|                          y_fill: false, | ||||
|                          x_align: St.Align.START }); | ||||
|  | ||||
|         this._buttonBox = new St.BoxLayout({ style_class: 'login-dialog-button-box', | ||||
|                                              vertical: false }); | ||||
|         this.actor.add(this._buttonBox, | ||||
| @@ -188,7 +201,7 @@ const AuthPrompt = new Lang.Class({ | ||||
|                                              if (!this._userVerifier.hasPendingMessages) | ||||
|                                                  this._fadeOutMessage(); | ||||
|  | ||||
|                                              this._updateNextButtonSensitivity(this._entry.text.length > 0); | ||||
|                                              this._updateNextButtonSensitivity(this._entry.text.length > 0 || this.verificationStatus == AuthPromptStatus.VERIFYING); | ||||
|                                          })); | ||||
|         this._entry.clutter_text.connect('activate', Lang.bind(this, function() { | ||||
|             if (this.nextButton.reactive) | ||||
| @@ -222,6 +235,21 @@ const AuthPrompt = new Lang.Class({ | ||||
|         this.emit('prompted'); | ||||
|     }, | ||||
|  | ||||
|     _onShowChoiceList: function(userVerifier, serviceName, choiceList) { | ||||
|         if (this._queryingService) | ||||
|             this.clear(); | ||||
|  | ||||
|         this._queryingService = serviceName; | ||||
|  | ||||
|         if (this._preemptiveAnswer) | ||||
|             this._preemptiveAnswer = null; | ||||
|  | ||||
|         this.nextButton.label = _("Next"); | ||||
|         this.setChoiceList(choiceList); | ||||
|         this.updateSensitivity(true); | ||||
|         this.emit('prompted'); | ||||
|     }, | ||||
|  | ||||
|     _onOVirtUserAuthenticated: function() { | ||||
|         if (this.verificationStatus != AuthPromptStatus.VERIFICATION_SUCCEEDED) | ||||
|             this.reset(); | ||||
| @@ -263,7 +291,7 @@ const AuthPrompt = new Lang.Class({ | ||||
|     _onVerificationComplete: function() { | ||||
|         this.setActorInDefaultButtonWell(null); | ||||
|         this.verificationStatus = AuthPromptStatus.VERIFICATION_SUCCEEDED; | ||||
| 	this.cancelButton.reactive = false; | ||||
|         this.cancelButton.reactive = false; | ||||
|     }, | ||||
|  | ||||
|     _onReset: function() { | ||||
| @@ -350,6 +378,8 @@ const AuthPrompt = new Lang.Class({ | ||||
|     clear: function() { | ||||
|         this._entry.text = ''; | ||||
|         this.stopSpinning(); | ||||
|         this._authList.clear(); | ||||
|         this._authList.actor.hide(); | ||||
|     }, | ||||
|  | ||||
|     setPasswordChar: function(passwordChar) { | ||||
| @@ -360,12 +390,25 @@ const AuthPrompt = new Lang.Class({ | ||||
|     setQuestion: function(question) { | ||||
|         this._label.set_text(question); | ||||
|  | ||||
|         this._authList.actor.hide(); | ||||
|         this._label.show(); | ||||
|         this._entry.show(); | ||||
|  | ||||
|         this._entry.grab_key_focus(); | ||||
|     }, | ||||
|  | ||||
|     setChoiceList: function(choiceList) { | ||||
|         this._label.hide(); | ||||
|         this._entry.hide(); | ||||
|  | ||||
|         this._authList.clear(); | ||||
|         for (let key in choiceList) { | ||||
|             let text = choiceList[key]; | ||||
|             this._authList.addItem(key, text); | ||||
|         } | ||||
|         this._authList.actor.show(); | ||||
|     }, | ||||
|  | ||||
|     getAnswer: function() { | ||||
|         let text; | ||||
|  | ||||
| @@ -416,7 +459,7 @@ const AuthPrompt = new Lang.Class({ | ||||
|     }, | ||||
|  | ||||
|     updateSensitivity: function(sensitive) { | ||||
|         this._updateNextButtonSensitivity(sensitive && this._entry.text.length > 0); | ||||
|         this._updateNextButtonSensitivity(sensitive && !this._authList.actor.visible && (this._entry.text.length > 0 || this.verificationStatus == AuthPromptStatus.VERIFYING)); | ||||
|         this._entry.reactive = sensitive; | ||||
|         this._entry.clutter_text.editable = sensitive; | ||||
|     }, | ||||
|   | ||||
| @@ -47,7 +47,7 @@ | ||||
| const Lang = imports.lang; | ||||
| const Signals = imports.signals; | ||||
|  | ||||
| const Task = new Lang.Class({ | ||||
| var Task = new Lang.Class({ | ||||
|     Name: 'Task', | ||||
|  | ||||
|     _init: function(scope, handler) { | ||||
| @@ -68,7 +68,7 @@ const Task = new Lang.Class({ | ||||
| }); | ||||
| Signals.addSignalMethods(Task.prototype); | ||||
|  | ||||
| const Hold = new Lang.Class({ | ||||
| var Hold = new Lang.Class({ | ||||
|     Name: 'Hold', | ||||
|     Extends: Task, | ||||
|  | ||||
| @@ -110,7 +110,7 @@ const Hold = new Lang.Class({ | ||||
| }); | ||||
| Signals.addSignalMethods(Hold.prototype); | ||||
|  | ||||
| const Batch = new Lang.Class({ | ||||
| var Batch = new Lang.Class({ | ||||
|     Name: 'Batch', | ||||
|     Extends: Task, | ||||
|  | ||||
| @@ -185,7 +185,7 @@ const Batch = new Lang.Class({ | ||||
| }); | ||||
| Signals.addSignalMethods(Batch.prototype); | ||||
|  | ||||
| const ConcurrentBatch = new Lang.Class({ | ||||
| var ConcurrentBatch = new Lang.Class({ | ||||
|     Name: 'ConcurrentBatch', | ||||
|     Extends: Batch, | ||||
|  | ||||
| @@ -204,7 +204,7 @@ const ConcurrentBatch = new Lang.Class({ | ||||
| }); | ||||
| Signals.addSignalMethods(ConcurrentBatch.prototype); | ||||
|  | ||||
| const ConsecutiveBatch = new Lang.Class({ | ||||
| var ConsecutiveBatch = new Lang.Class({ | ||||
|     Name: 'ConsecutiveBatch', | ||||
|     Extends: Batch, | ||||
|  | ||||
|   | ||||
| @@ -51,7 +51,7 @@ const _TIMED_LOGIN_IDLE_THRESHOLD = 5.0; | ||||
| const _LOGO_ICON_HEIGHT = 48; | ||||
| const _MAX_BOTTOM_MENU_ITEMS = 5; | ||||
|  | ||||
| const UserListItem = new Lang.Class({ | ||||
| var UserListItem = new Lang.Class({ | ||||
|     Name: 'UserListItem', | ||||
|  | ||||
|     _init: function(user) { | ||||
| @@ -70,6 +70,16 @@ const UserListItem = new Lang.Class({ | ||||
|         this.actor.connect('destroy', | ||||
|                            Lang.bind(this, this._onDestroy)); | ||||
|  | ||||
|         this.actor.connect('key-focus-in', () => { | ||||
|             this._setSelected(true); | ||||
|         }); | ||||
|         this.actor.connect('key-focus-out', () => { | ||||
|             this._setSelected(false); | ||||
|         }); | ||||
|         this.actor.connect('notify::hover', () => { | ||||
|             this._setSelected(this.actor.hover); | ||||
|         }); | ||||
|  | ||||
|         this._userWidget = new UserWidget.UserWidget(this.user); | ||||
|         layout.add(this._userWidget.actor); | ||||
|  | ||||
| @@ -103,6 +113,15 @@ const UserListItem = new Lang.Class({ | ||||
|         this.emit('activate'); | ||||
|     }, | ||||
|  | ||||
|     _setSelected: function(selected) { | ||||
|         if (selected) { | ||||
|             this.actor.add_style_pseudo_class('selected'); | ||||
|             this.actor.grab_key_focus(); | ||||
|         } else { | ||||
|             this.actor.remove_style_pseudo_class('selected'); | ||||
|         } | ||||
|     }, | ||||
|  | ||||
|     showTimedLoginIndicator: function(time) { | ||||
|         let hold = new Batch.Hold(); | ||||
|  | ||||
| @@ -126,7 +145,7 @@ const UserListItem = new Lang.Class({ | ||||
| }); | ||||
| Signals.addSignalMethods(UserListItem.prototype); | ||||
|  | ||||
| const UserList = new Lang.Class({ | ||||
| var UserList = new Lang.Class({ | ||||
|     Name: 'UserList', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -269,11 +288,15 @@ const UserList = new Lang.Class({ | ||||
|  | ||||
|         item.actor.destroy(); | ||||
|         delete this._items[userName]; | ||||
|     }, | ||||
|  | ||||
|     numItems: function() { | ||||
|         return Object.keys(this._items).length; | ||||
|     } | ||||
| }); | ||||
| Signals.addSignalMethods(UserList.prototype); | ||||
|  | ||||
| const SessionMenuButton = new Lang.Class({ | ||||
| var SessionMenuButton = new Lang.Class({ | ||||
|     Name: 'SessionMenuButton', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -379,7 +402,7 @@ const SessionMenuButton = new Lang.Class({ | ||||
| }); | ||||
| Signals.addSignalMethods(SessionMenuButton.prototype); | ||||
|  | ||||
| const LoginDialog = new Lang.Class({ | ||||
| var LoginDialog = new Lang.Class({ | ||||
|     Name: 'LoginDialog', | ||||
|  | ||||
|     _init: function(parentActor) { | ||||
| @@ -395,6 +418,11 @@ const LoginDialog = new Lang.Class({ | ||||
|         this._userManager = AccountsService.UserManager.get_default() | ||||
|         this._gdmClient = new Gdm.Client(); | ||||
|  | ||||
|         try { | ||||
|             this._gdmClient.set_enabled_extensions([Gdm.UserVerifierChoiceList.interface_info().name]); | ||||
|         } catch(e) { | ||||
|         } | ||||
|  | ||||
|         this._settings = new Gio.Settings({ schema_id: GdmUtil.LOGIN_SCREEN_SCHEMA }); | ||||
|  | ||||
|         this._settings.connect('changed::' + GdmUtil.BANNER_MESSAGE_KEY, | ||||
| @@ -707,6 +735,10 @@ const LoginDialog = new Lang.Class({ | ||||
|     _updateDisableUserList: function() { | ||||
|         let disableUserList = this._settings.get_boolean(GdmUtil.DISABLE_USER_LIST_KEY); | ||||
|  | ||||
|         // Disable user list when there are no users. | ||||
|         if (this._userListLoaded && this._userList.numItems() == 0) | ||||
|             disableUserList = true; | ||||
|  | ||||
|         if (disableUserList != this._disableUserList) { | ||||
|             this._disableUserList = disableUserList; | ||||
|  | ||||
| @@ -1178,14 +1210,18 @@ const LoginDialog = new Lang.Class({ | ||||
|             this._userList.addUser(users[i]); | ||||
|         } | ||||
|  | ||||
|         this._updateDisableUserList(); | ||||
|  | ||||
|         this._userAddedId = this._userManager.connect('user-added', | ||||
|                                                       Lang.bind(this, function(userManager, user) { | ||||
|                                                           this._userList.addUser(user); | ||||
|                                                           this._updateDisableUserList(); | ||||
|                                                       })); | ||||
|  | ||||
|         this._userRemovedId = this._userManager.connect('user-removed', | ||||
|                                                         Lang.bind(this, function(userManager, user) { | ||||
|                                                             this._userList.removeUser(user); | ||||
|                                                             this._updateDisableUserList(); | ||||
|                                                         })); | ||||
|  | ||||
|         this._userChangedId = this._userManager.connect('user-changed', | ||||
| @@ -1194,6 +1230,7 @@ const LoginDialog = new Lang.Class({ | ||||
|                                                                 this._userList.removeUser(user); | ||||
|                                                             else if (!this._userList.containsUser(user) && !user.locked) | ||||
|                                                                 this._userList.addUser(user); | ||||
|                                                             this._updateDisableUserList(); | ||||
|                                                         })); | ||||
|  | ||||
|         return GLib.SOURCE_REMOVE; | ||||
|   | ||||
| @@ -27,7 +27,7 @@ function OVirtCredentials() { | ||||
|     return self; | ||||
| } | ||||
|  | ||||
| const OVirtCredentialsManager = new Lang.Class({ | ||||
| var OVirtCredentialsManager = new Lang.Class({ | ||||
|     Name: 'OVirtCredentialsManager', | ||||
|     _init: function() { | ||||
|         this._token = null; | ||||
|   | ||||
| @@ -59,7 +59,7 @@ const RealmIface = '<node> \ | ||||
| </node>'; | ||||
| const Realm = Gio.DBusProxy.makeProxyWrapper(RealmIface); | ||||
|  | ||||
| const Manager = new Lang.Class({ | ||||
| var Manager = new Lang.Class({ | ||||
|     Name: 'Manager', | ||||
|  | ||||
|     _init: function(parentActor) { | ||||
|   | ||||
| @@ -21,8 +21,8 @@ const PASSWORD_SERVICE_NAME = 'gdm-password'; | ||||
| const FINGERPRINT_SERVICE_NAME = 'gdm-fingerprint'; | ||||
| const SMARTCARD_SERVICE_NAME = 'gdm-smartcard'; | ||||
| const OVIRT_SERVICE_NAME = 'gdm-ovirtcred'; | ||||
| const FADE_ANIMATION_TIME = 0.16; | ||||
| const CLONE_FADE_ANIMATION_TIME = 0.25; | ||||
| var FADE_ANIMATION_TIME = 0.16; | ||||
| var CLONE_FADE_ANIMATION_TIME = 0.25; | ||||
|  | ||||
| const LOGIN_SCREEN_SCHEMA = 'org.gnome.login-screen'; | ||||
| const PASSWORD_AUTHENTICATION_KEY = 'enable-password-authentication'; | ||||
| @@ -36,9 +36,9 @@ const LOGO_KEY = 'logo'; | ||||
| const DISABLE_USER_LIST_KEY = 'disable-user-list'; | ||||
|  | ||||
| // Give user 48ms to read each character of a PAM message | ||||
| const USER_READ_TIME = 48 | ||||
| var USER_READ_TIME = 48 | ||||
|  | ||||
| const MessageType = { | ||||
| var MessageType = { | ||||
|     NONE: 0, | ||||
|     ERROR: 1, | ||||
|     INFO: 2, | ||||
| @@ -119,7 +119,7 @@ function cloneAndFadeOutActor(actor) { | ||||
|     return hold; | ||||
| } | ||||
|  | ||||
| const ShellUserVerifier = new Lang.Class({ | ||||
| var ShellUserVerifier = new Lang.Class({ | ||||
|     Name: 'ShellUserVerifier', | ||||
|  | ||||
|     _init: function(client, params) { | ||||
| @@ -128,6 +128,9 @@ const ShellUserVerifier = new Lang.Class({ | ||||
|  | ||||
|         this._client = client; | ||||
|  | ||||
|         this._defaultService = null; | ||||
|         this._preemptingService = null; | ||||
|  | ||||
|         this._settings = new Gio.Settings({ schema_id: LOGIN_SCREEN_SCHEMA }); | ||||
|         this._settings.connect('changed', | ||||
|                                Lang.bind(this, this._updateDefaultService)); | ||||
| @@ -138,8 +141,9 @@ const ShellUserVerifier = new Lang.Class({ | ||||
|  | ||||
|         // We check for smartcards right away, since an inserted smartcard | ||||
|         // at startup should result in immediately initiating authentication. | ||||
|         // This is different than fingeprint readers, where we only check them | ||||
|         // This is different than fingerprint readers, where we only check them | ||||
|         // after a user has been picked. | ||||
|         this.smartcardDetected = false; | ||||
|         this._checkForSmartcard(); | ||||
|  | ||||
|         this._smartcardInsertedId = this._smartcardManager.connect('smartcard-inserted', | ||||
| @@ -195,6 +199,8 @@ const ShellUserVerifier = new Lang.Class({ | ||||
|         if (this._userVerifier) { | ||||
|             this._userVerifier.run_dispose(); | ||||
|             this._userVerifier = null; | ||||
|             this._userVerifierChoiceList.run_dispose(); | ||||
|             this._userVerifierChoiceList = null; | ||||
|         } | ||||
|     }, | ||||
|  | ||||
| @@ -222,6 +228,10 @@ const ShellUserVerifier = new Lang.Class({ | ||||
|         this._oVirtCredentialsManager = null; | ||||
|     }, | ||||
|  | ||||
|     selectChoice: function(serviceName, key) { | ||||
|         this._userVerifierChoiceList.call_select_choice(serviceName, key, this._cancellable, null); | ||||
|     }, | ||||
|  | ||||
|     answerQuery: function(serviceName, answer) { | ||||
|         if (!this.hasPendingMessages) { | ||||
|             this._userVerifier.call_answer_query(serviceName, answer, this._cancellable, null); | ||||
| @@ -361,6 +371,8 @@ const ShellUserVerifier = new Lang.Class({ | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         this._userVerifierChoiceList = client.get_user_verifier_choice_list(); | ||||
|  | ||||
|         this.reauthenticating = true; | ||||
|         this._connectSignals(); | ||||
|         this._beginVerification(); | ||||
| @@ -378,6 +390,8 @@ const ShellUserVerifier = new Lang.Class({ | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         this._userVerifierChoiceList = client.get_user_verifier_choice_list(); | ||||
|  | ||||
|         this._connectSignals(); | ||||
|         this._beginVerification(); | ||||
|         this._hold.release(); | ||||
| @@ -391,6 +405,9 @@ const ShellUserVerifier = new Lang.Class({ | ||||
|         this._userVerifier.connect('conversation-stopped', Lang.bind(this, this._onConversationStopped)); | ||||
|         this._userVerifier.connect('reset', Lang.bind(this, this._onReset)); | ||||
|         this._userVerifier.connect('verification-complete', Lang.bind(this, this._onVerificationComplete)); | ||||
|  | ||||
|         if (this._userVerifierChoiceList) | ||||
|             this._userVerifierChoiceList.connect('choice-query', Lang.bind(this, this._onChoiceListQuery)); | ||||
|     }, | ||||
|  | ||||
|     _getForegroundService: function() { | ||||
| @@ -460,6 +477,13 @@ const ShellUserVerifier = new Lang.Class({ | ||||
|             this._startService(FINGERPRINT_SERVICE_NAME); | ||||
|     }, | ||||
|  | ||||
|     _onChoiceListQuery: function(client, serviceName, list) { | ||||
|         if (!this.serviceIsForeground(serviceName)) | ||||
|             return; | ||||
|  | ||||
|         this.emit('show-choice-list', serviceName, list.deep_unpack()); | ||||
|     }, | ||||
|  | ||||
|     _onInfo: function(client, serviceName, info) { | ||||
|         if (this.serviceIsForeground(serviceName)) { | ||||
|             this._queueMessage(info, MessageType.INFO); | ||||
| @@ -540,7 +564,8 @@ const ShellUserVerifier = new Lang.Class({ | ||||
|                 let signalId = this.connect('no-more-messages', | ||||
|                                             Lang.bind(this, function() { | ||||
|                                                 this.disconnect(signalId); | ||||
|                                                 this._retry(); | ||||
|                                                 if (this._cancellable && !this._cancellable.is_cancelled()) | ||||
|                                                     this._retry(); | ||||
|                                             })); | ||||
|             } | ||||
|         } else { | ||||
|   | ||||
| @@ -1,6 +1,7 @@ | ||||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <gresources> | ||||
|   <gresource prefix="/org/gnome/shell"> | ||||
|     <file>gdm/authList.js</file> | ||||
|     <file>gdm/authPrompt.js</file> | ||||
|     <file>gdm/batch.js</file> | ||||
|     <file>gdm/fingerprint.js</file> | ||||
| @@ -44,9 +45,11 @@ | ||||
|     <file>ui/boxpointer.js</file> | ||||
|     <file>ui/calendar.js</file> | ||||
|     <file>ui/checkBox.js</file> | ||||
|     <file>ui/closeDialog.js</file> | ||||
|     <file>ui/ctrlAltTab.js</file> | ||||
|     <file>ui/dash.js</file> | ||||
|     <file>ui/dateMenu.js</file> | ||||
|     <file>ui/dialog.js</file> | ||||
|     <file>ui/dnd.js</file> | ||||
|     <file>ui/edgeDragAction.js</file> | ||||
|     <file>ui/endSessionDialog.js</file> | ||||
| @@ -87,7 +90,6 @@ | ||||
|     <file>ui/screenshot.js</file> | ||||
|     <file>ui/scripting.js</file> | ||||
|     <file>ui/search.js</file> | ||||
|     <file>ui/separator.js</file> | ||||
|     <file>ui/sessionMode.js</file> | ||||
|     <file>ui/shellDBus.js</file> | ||||
|     <file>ui/shellEntry.js</file> | ||||
|   | ||||
							
								
								
									
										8
									
								
								js/meson.build
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								js/meson.build
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | ||||
| subdir('misc') | ||||
|  | ||||
| js_resources = gnome.compile_resources( | ||||
|   'js-resources', 'js-resources.gresource.xml', | ||||
|   source_dir: ['.', meson.current_build_dir()], | ||||
|   c_name: 'shell_js_resources', | ||||
|   dependencies: [config_js] | ||||
| ) | ||||
| @@ -1,19 +1,19 @@ | ||||
| // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | ||||
|  | ||||
| /* The name of this package (not localized) */ | ||||
| const PACKAGE_NAME = '@PACKAGE_NAME@'; | ||||
| var PACKAGE_NAME = '@PACKAGE_NAME@'; | ||||
| /* The version of this package */ | ||||
| const PACKAGE_VERSION = '@PACKAGE_VERSION@'; | ||||
| var PACKAGE_VERSION = '@PACKAGE_VERSION@'; | ||||
| /* 1 if gnome-bluetooth is available, 0 otherwise */ | ||||
| const HAVE_BLUETOOTH = @HAVE_BLUETOOTH@; | ||||
| var HAVE_BLUETOOTH = @HAVE_BLUETOOTH@; | ||||
| /* 1 if networkmanager is available, 0 otherwise */ | ||||
| const HAVE_NETWORKMANAGER = @HAVE_NETWORKMANAGER@; | ||||
| var HAVE_NETWORKMANAGER = @HAVE_NETWORKMANAGER@; | ||||
| /* gettext package */ | ||||
| const GETTEXT_PACKAGE = '@GETTEXT_PACKAGE@'; | ||||
| var GETTEXT_PACKAGE = '@GETTEXT_PACKAGE@'; | ||||
| /* locale dir */ | ||||
| const LOCALEDIR = '@datadir@/locale'; | ||||
| var LOCALEDIR = '@datadir@/locale'; | ||||
| /* other standard directories */ | ||||
| const LIBEXECDIR = '@libexecdir@'; | ||||
| const SYSCONFDIR = '@sysconfdir@'; | ||||
| var LIBEXECDIR = '@libexecdir@'; | ||||
| var SYSCONFDIR = '@sysconfdir@'; | ||||
| /* g-i package versions */ | ||||
| const LIBMUTTER_API_VERSION = '@LIBMUTTER_API_VERSION@' | ||||
| var LIBMUTTER_API_VERSION = '@LIBMUTTER_API_VERSION@' | ||||
|   | ||||
| @@ -11,13 +11,13 @@ const Gio = imports.gi.Gio; | ||||
| const Config = imports.misc.config; | ||||
| const FileUtils = imports.misc.fileUtils; | ||||
|  | ||||
| const ExtensionType = { | ||||
| var ExtensionType = { | ||||
|     SYSTEM: 1, | ||||
|     PER_USER: 2 | ||||
| }; | ||||
|  | ||||
| // Maps uuid -> metadata object | ||||
| const extensions = {}; | ||||
| var extensions = {}; | ||||
|  | ||||
| /** | ||||
|  * getCurrentExtension: | ||||
| @@ -158,7 +158,7 @@ function installImporter(extension) { | ||||
|     imports.searchPath = oldSearchPath; | ||||
| } | ||||
|  | ||||
| const ExtensionFinder = new Lang.Class({ | ||||
| var ExtensionFinder = new Lang.Class({ | ||||
|     Name: 'ExtensionFinder', | ||||
|  | ||||
|     _loadExtension: function(extensionDir, info, perUserDir) { | ||||
|   | ||||
| @@ -16,7 +16,7 @@ const PresenceIface = '<node> \ | ||||
| </interface> \ | ||||
| </node>'; | ||||
|  | ||||
| const PresenceStatus = { | ||||
| var PresenceStatus = { | ||||
|     AVAILABLE: 0, | ||||
|     INVISIBLE: 1, | ||||
|     BUSY: 2, | ||||
|   | ||||
| @@ -5,9 +5,9 @@ const Signals = imports.signals; | ||||
| const Clutter = imports.gi.Clutter; | ||||
| const Params = imports.misc.params; | ||||
|  | ||||
| const DEFAULT_LIMIT = 512; | ||||
| var DEFAULT_LIMIT = 512; | ||||
|  | ||||
| const HistoryManager = new Lang.Class({ | ||||
| var HistoryManager = new Lang.Class({ | ||||
|     Name: 'HistoryManager', | ||||
|  | ||||
|     _init: function(params) { | ||||
| @@ -69,7 +69,7 @@ const HistoryManager = new Lang.Class({ | ||||
|             this._indexChanged(); | ||||
|         } | ||||
|  | ||||
|         return this._historyIndex[this._history.length]; | ||||
|         return this._historyIndex ? this._history[this._historyIndex -1] : null; | ||||
|     }, | ||||
|  | ||||
|     addItem: function(input) { | ||||
|   | ||||
| @@ -36,7 +36,7 @@ function getIBusManager() { | ||||
|     return _ibusManager; | ||||
| } | ||||
|  | ||||
| const IBusManager = new Lang.Class({ | ||||
| var IBusManager = new Lang.Class({ | ||||
|     Name: 'IBusManager', | ||||
|  | ||||
|     // This is the longest we'll keep the keyboard frozen until an input | ||||
| @@ -190,7 +190,7 @@ const IBusManager = new Lang.Class({ | ||||
|     }, | ||||
|  | ||||
|     getEngineDesc: function(id) { | ||||
|         if (!IBus || !this._ready) | ||||
|         if (!IBus || !this._ready || !this._engines.hasOwnProperty(id)) | ||||
|             return null; | ||||
|  | ||||
|         return this._engines[id]; | ||||
|   | ||||
| @@ -7,9 +7,9 @@ const Meta = imports.gi.Meta; | ||||
|  | ||||
| const Main = imports.ui.main; | ||||
|  | ||||
| const DEFAULT_LOCALE = 'en_US'; | ||||
| const DEFAULT_LAYOUT = 'us'; | ||||
| const DEFAULT_VARIANT = ''; | ||||
| var DEFAULT_LOCALE = 'en_US'; | ||||
| var DEFAULT_LAYOUT = 'us'; | ||||
| var DEFAULT_VARIANT = ''; | ||||
|  | ||||
| let _xkbInfo = null; | ||||
|  | ||||
| @@ -38,7 +38,7 @@ function holdKeyboard() { | ||||
|     global.display.freeze_keyboard(global.get_current_time()); | ||||
| } | ||||
|  | ||||
| const KeyboardManager = new Lang.Class({ | ||||
| var KeyboardManager = new Lang.Class({ | ||||
|     Name: 'KeyboardManager', | ||||
|  | ||||
|     // The XKB protocol doesn't allow for more that 4 layouts in a | ||||
|   | ||||
| @@ -102,7 +102,7 @@ function getLoginManager() { | ||||
|     return _loginManager; | ||||
| } | ||||
|  | ||||
| const LoginManagerSystemd = new Lang.Class({ | ||||
| var LoginManagerSystemd = new Lang.Class({ | ||||
|     Name: 'LoginManagerSystemd', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -183,7 +183,7 @@ const LoginManagerSystemd = new Lang.Class({ | ||||
| }); | ||||
| Signals.addSignalMethods(LoginManagerSystemd.prototype); | ||||
|  | ||||
| const LoginManagerDummy = new Lang.Class({ | ||||
| var LoginManagerDummy = new Lang.Class({ | ||||
|     Name: 'LoginManagerDummy', | ||||
|  | ||||
|     getCurrentSessionProxy: function(callback) { | ||||
|   | ||||
							
								
								
									
										16
									
								
								js/misc/meson.build
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								js/misc/meson.build
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | ||||
| jsconf = configuration_data() | ||||
| jsconf.set('PACKAGE_NAME', meson.project_name()) | ||||
| jsconf.set('PACKAGE_VERSION', meson.project_version()) | ||||
| jsconf.set('GETTEXT_PACKAGE', meson.project_name()) | ||||
| jsconf.set('LIBMUTTER_API_VERSION', mutter_api_version) | ||||
| jsconf.set10('HAVE_BLUETOOTH', bt_dep.found()) | ||||
| jsconf.set10('HAVE_NETWORKMANAGER', have_networkmanager) | ||||
| jsconf.set('datadir', datadir) | ||||
| jsconf.set('libexecdir', libexecdir) | ||||
| jsconf.set('sysconfdir', sysconfdir) | ||||
|  | ||||
| config_js = configure_file( | ||||
|   input: 'config.js.in', | ||||
|   output: 'config.js', | ||||
|   configuration: jsconf | ||||
| ) | ||||
| @@ -130,7 +130,7 @@ const ModemCdmaInterface = '<node> \ | ||||
|  | ||||
| const ModemCdmaProxy = Gio.DBusProxy.makeProxyWrapper(ModemCdmaInterface); | ||||
|  | ||||
| const ModemGsm = new Lang.Class({ | ||||
| var ModemGsm = new Lang.Class({ | ||||
|     Name: 'ModemGsm', | ||||
|  | ||||
|     _init: function(path) { | ||||
| @@ -172,7 +172,7 @@ const ModemGsm = new Lang.Class({ | ||||
| }); | ||||
| Signals.addSignalMethods(ModemGsm.prototype); | ||||
|  | ||||
| const ModemCdma = new Lang.Class({ | ||||
| var ModemCdma = new Lang.Class({ | ||||
|     Name: 'ModemCdma', | ||||
|  | ||||
|     _init: function(path) { | ||||
| @@ -244,7 +244,7 @@ const BroadbandModemCdmaInterface = '<node> \ | ||||
| </node>'; | ||||
| const BroadbandModemCdmaProxy = Gio.DBusProxy.makeProxyWrapper(BroadbandModemCdmaInterface); | ||||
|  | ||||
| const BroadbandModem = new Lang.Class({ | ||||
| var BroadbandModem = new Lang.Class({ | ||||
|     Name: 'BroadbandModem', | ||||
|  | ||||
|     _init: function(path, capabilities) { | ||||
|   | ||||
| @@ -26,7 +26,7 @@ const ObjectManagerIface = '<node> \ | ||||
|  | ||||
| const ObjectManagerInfo = Gio.DBusInterfaceInfo.new_for_xml(ObjectManagerIface); | ||||
|  | ||||
| const ObjectManager = new Lang.Class({ | ||||
| var ObjectManager = new Lang.Class({ | ||||
|     Name: 'ObjectManager', | ||||
|     _init: function(params) { | ||||
|         params = Params.parse(params, { connection: null, | ||||
| @@ -46,7 +46,7 @@ const ObjectManager = new Lang.Class({ | ||||
|                                                  g_interface_info: ObjectManagerInfo, | ||||
|                                                  g_name: this._serviceName, | ||||
|                                                  g_object_path: this._managerPath, | ||||
|                                                  g_flags: Gio.DBusProxyFlags.NONE }); | ||||
|                                                  g_flags: Gio.DBusProxyFlags.DO_NOT_AUTO_START }); | ||||
|  | ||||
|         this._interfaceInfos = {}; | ||||
|         this._objects = {}; | ||||
| @@ -65,6 +65,9 @@ const ObjectManager = new Lang.Class({ | ||||
|     }, | ||||
|  | ||||
|     _tryToCompleteLoad: function() { | ||||
|         if (this._numLoadInhibitors == 0) | ||||
|             return; | ||||
|  | ||||
|         this._numLoadInhibitors--; | ||||
|         if (this._numLoadInhibitors == 0) { | ||||
|             if (this._onLoaded) | ||||
| @@ -86,7 +89,7 @@ const ObjectManager = new Lang.Class({ | ||||
|                                        g_object_path: objectPath, | ||||
|                                        g_interface_name: interfaceName, | ||||
|                                        g_interface_info: info, | ||||
|                                        g_flags: Gio.DBusProxyFlags.NONE }); | ||||
|                                        g_flags: Gio.DBusProxyFlags.DO_NOT_AUTO_START }); | ||||
|  | ||||
|         proxy.init_async(GLib.PRIORITY_DEFAULT, | ||||
|                          this._cancellable, | ||||
| @@ -181,6 +184,18 @@ const ObjectManager = new Lang.Class({ | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         this._managerProxy.connect('notify::g-name-owner', Lang.bind(this, function() { | ||||
|             if (this._managerProxy.g_name_owner) | ||||
|                 this._onNameAppeared(); | ||||
|             else | ||||
|                 this._onNameVanished(); | ||||
|         })); | ||||
|  | ||||
|         if (this._managerProxy.g_name_owner) | ||||
|             this._onNameAppeared(); | ||||
|     }, | ||||
|  | ||||
|     _onNameAppeared: function() { | ||||
|         this._managerProxy.GetManagedObjectsRemote(Lang.bind(this, function(result, error) { | ||||
|             if (!result) { | ||||
|                 if (error) { | ||||
| @@ -193,6 +208,11 @@ const ObjectManager = new Lang.Class({ | ||||
|  | ||||
|             let [objects] = result; | ||||
|  | ||||
|             if (!objects) { | ||||
|                 this._tryToCompleteLoad(); | ||||
|                 return; | ||||
|             } | ||||
|  | ||||
|             let objectPaths = Object.keys(objects); | ||||
|             for (let i = 0; i < objectPaths.length; i++) { | ||||
|                 let objectPath = objectPaths[i]; | ||||
| @@ -213,6 +233,21 @@ const ObjectManager = new Lang.Class({ | ||||
|         })); | ||||
|     }, | ||||
|  | ||||
|     _onNameVanished: function() { | ||||
|         let objectPaths = Object.keys(this._objects); | ||||
|         for (let i = 0; i < objectPaths.length; i++) { | ||||
|             let object = this._objects[objectPaths]; | ||||
|  | ||||
|             let interfaceNames = Object.keys(object); | ||||
|             for (let j = 0; i < interfaceNames.length; i++) { | ||||
|                 let interfaceName = interfaceNames[i]; | ||||
|  | ||||
|                 if (object[interfaceName]) | ||||
|                     this._removeInterface(objectPath, interfaceName); | ||||
|             } | ||||
|         } | ||||
|     }, | ||||
|  | ||||
|     _registerInterfaces: function(interfaces) { | ||||
|         for (let i = 0; i < interfaces.length; i++) { | ||||
|             let info = Gio.DBusInterfaceInfo.new_for_xml(interfaces[i]); | ||||
|   | ||||
| @@ -25,7 +25,7 @@ function getSmartcardManager() { | ||||
|     return _smartcardManager; | ||||
| } | ||||
|  | ||||
| const SmartcardManager = new Lang.Class({ | ||||
| var SmartcardManager = new Lang.Class({ | ||||
|     Name: 'SmartcardManager', | ||||
|     _init: function() { | ||||
|         this._objectManager = new ObjectManager.ObjectManager({ connection: Gio.DBus.session, | ||||
|   | ||||
| @@ -14,7 +14,7 @@ const Main = imports.ui.main; | ||||
| const Tweener = imports.ui.tweener; | ||||
| const Params = imports.misc.params; | ||||
|  | ||||
| const SCROLL_TIME = 0.1; | ||||
| var SCROLL_TIME = 0.1; | ||||
|  | ||||
| // http://daringfireball.net/2010/07/improved_regex_for_matching_urls | ||||
| const _balancedParens = '\\((?:[^\\s()<>]+|(?:\\(?:[^\\s()<>]+\\)))*\\)'; | ||||
| @@ -97,7 +97,7 @@ function spawnApp(argv) { | ||||
|                                                       Gio.AppInfoCreateFlags.SUPPORTS_STARTUP_NOTIFICATION); | ||||
|  | ||||
|         let context = global.create_app_launch_context(0, -1); | ||||
|         app.launch([], context, false); | ||||
|         app.launch([], context); | ||||
|     } catch(err) { | ||||
|         _handleSpawnError(argv[0], err); | ||||
|     } | ||||
| @@ -218,11 +218,10 @@ function formatTime(time, params) { | ||||
|     if (_desktopSettings == null) | ||||
|         _desktopSettings = new Gio.Settings({ schema_id: 'org.gnome.desktop.interface' }); | ||||
|     let clockFormat = _desktopSettings.get_string('clock-format'); | ||||
|     let hasAmPm = date.format('%p') != ''; | ||||
|  | ||||
|     params = Params.parse(params, { timeOnly: false }); | ||||
|  | ||||
|     if (clockFormat == '24h' || !hasAmPm) { | ||||
|     if (clockFormat == '24h') { | ||||
|         // Show only the time if date is on today | ||||
|         if (daysAgo < 1 || params.timeOnly) | ||||
|             /* Translators: Time in 24h format */ | ||||
| @@ -281,7 +280,10 @@ function formatTime(time, params) { | ||||
|             // xgettext:no-c-format | ||||
|             format = N_("%B %d %Y, %l\u2236%M %p"); | ||||
|     } | ||||
|     return date.format(Shell.util_translate_time_string(format)); | ||||
|  | ||||
|     let formattedTime = date.format(Shell.util_translate_time_string(format)); | ||||
|     // prepend LTR-mark to colon/ratio to force a text direction on times | ||||
|     return formattedTime.replace(/([:\u2236])/g, '\u200e$1'); | ||||
| } | ||||
|  | ||||
| function createTimeLabel(date, params) { | ||||
| @@ -348,7 +350,7 @@ function insertSorted(array, val, cmp) { | ||||
|     return pos; | ||||
| } | ||||
|  | ||||
| const CloseButton = new Lang.Class({ | ||||
| var CloseButton = new Lang.Class({ | ||||
|     Name: 'CloseButton', | ||||
|     Extends: St.Button, | ||||
|  | ||||
| @@ -437,7 +439,7 @@ function ensureActorVisibleInScrollView(scrollView, actor) { | ||||
|                        transition: 'easeOutQuad' }); | ||||
| } | ||||
|  | ||||
| const AppSettingsMonitor = new Lang.Class({ | ||||
| var AppSettingsMonitor = new Lang.Class({ | ||||
|     Name: 'AppSettingsMonitor', | ||||
|  | ||||
|     _init: function(appId, schemaId) { | ||||
|   | ||||
| @@ -11,9 +11,9 @@ const PermissionStore = imports.misc.permissionStore; | ||||
| const Util = imports.misc.util; | ||||
|  | ||||
| // Minimum time between updates to show loading indication | ||||
| const UPDATE_THRESHOLD = 10 * GLib.TIME_SPAN_MINUTE; | ||||
| var UPDATE_THRESHOLD = 10 * GLib.TIME_SPAN_MINUTE; | ||||
|  | ||||
| const WeatherClient = new Lang.Class({ | ||||
| var WeatherClient = new Lang.Class({ | ||||
|     Name: 'WeatherClient', | ||||
|  | ||||
|     _init: function() { | ||||
|   | ||||
| @@ -50,7 +50,7 @@ const HelperDBusInterface = '<node> \ | ||||
| </interface> \ | ||||
| </node>'; | ||||
|  | ||||
| const PortalHeaderBar = new Lang.Class({ | ||||
| var PortalHeaderBar = new Lang.Class({ | ||||
|     Name: 'PortalHeaderBar', | ||||
|     Extends: Gtk.HeaderBar, | ||||
|  | ||||
| @@ -115,7 +115,7 @@ const PortalHeaderBar = new Lang.Class({ | ||||
|     }, | ||||
| }); | ||||
|  | ||||
| const PortalWindow = new Lang.Class({ | ||||
| var PortalWindow = new Lang.Class({ | ||||
|     Name: 'PortalWindow', | ||||
|     Extends: Gtk.ApplicationWindow, | ||||
|  | ||||
| @@ -143,6 +143,7 @@ const PortalWindow = new Lang.Class({ | ||||
|  | ||||
|         this._webContext = WebKit.WebContext.new_ephemeral(); | ||||
|         this._webContext.set_cache_model(WebKit.CacheModel.DOCUMENT_VIEWER); | ||||
|         this._webContext.set_network_proxy_settings(WebKit.NetworkProxyMode.NO_PROXY, null); | ||||
|  | ||||
|         this._webView = WebKit.WebView.new_with_context(this._webContext); | ||||
|         this._webView.connect('decide-policy', Lang.bind(this, this._onDecidePolicy)); | ||||
| @@ -281,7 +282,7 @@ const PortalWindow = new Lang.Class({ | ||||
|     }, | ||||
| }); | ||||
|  | ||||
| const WebPortalHelper = new Lang.Class({ | ||||
| var WebPortalHelper = new Lang.Class({ | ||||
|     Name: 'WebPortalHelper', | ||||
|     Extends: Gtk.Application, | ||||
|  | ||||
| @@ -356,7 +357,7 @@ const WebPortalHelper = new Lang.Class({ | ||||
|         if (top.window != null) | ||||
|             return; | ||||
|  | ||||
|         top.window = new PortalWindow(this, top.uri, top.timestamp, Lang.bind(this, function(result) { | ||||
|         top.window = new PortalWindow(this, top.url, top.timestamp, Lang.bind(this, function(result) { | ||||
|             this._dbusImpl.emit_signal('Done', new GLib.Variant('(ou)', [top.connection, result])); | ||||
|         })); | ||||
|     }, | ||||
|   | ||||
| @@ -7,6 +7,7 @@ const Shell = imports.gi.Shell; | ||||
| const St = imports.gi.St; | ||||
|  | ||||
| const CheckBox = imports.ui.checkBox; | ||||
| const Dialog = imports.ui.dialog; | ||||
| const ModalDialog = imports.ui.modalDialog; | ||||
|  | ||||
| const RequestIface = '<node> \ | ||||
| @@ -31,13 +32,13 @@ const AccessIface = '<node> \ | ||||
| </interface> \ | ||||
| </node>'; | ||||
|  | ||||
| const DialogResponse = { | ||||
| var DialogResponse = { | ||||
|     OK: 0, | ||||
|     CANCEL: 1, | ||||
|     CLOSED: 2 | ||||
| }; | ||||
|  | ||||
| const AccessDialog = new Lang.Class({ | ||||
| var AccessDialog = new Lang.Class({ | ||||
|     Name: 'AccessDialog', | ||||
|     Extends: ModalDialog.ModalDialog, | ||||
|  | ||||
| @@ -64,29 +65,11 @@ const AccessDialog = new Lang.Class({ | ||||
|         let iconName = options['icon'] || null; | ||||
|         let choices = options['choices'] || []; | ||||
|  | ||||
|         let mainContentBox = new St.BoxLayout(); | ||||
|         mainContentBox.style_class = 'access-dialog-main-layout'; | ||||
|         this.contentLayout.add_actor(mainContentBox); | ||||
|  | ||||
|         let icon = new St.Icon({ style_class: 'access-dialog-icon', | ||||
|                                  icon_name: iconName, | ||||
|                                  y_align: Clutter.ActorAlign.START }); | ||||
|         mainContentBox.add_actor(icon); | ||||
|  | ||||
|         let messageBox = new St.BoxLayout({ vertical: true }); | ||||
|         messageBox.style_class = 'access-dialog-content', | ||||
|         mainContentBox.add_actor(messageBox); | ||||
|  | ||||
|         let label; | ||||
|         label = new St.Label({ style_class: 'access-dialog-title headline', | ||||
|                                text: title }); | ||||
|         messageBox.add_actor(label); | ||||
|  | ||||
|         label = new St.Label({ style_class: 'access-dialog-subtitle', | ||||
|                                text: subtitle }); | ||||
|         label.clutter_text.ellipsize = Pango.EllipsizeMode.NONE; | ||||
|         label.clutter_text.line_wrap = true; | ||||
|         messageBox.add_actor(label); | ||||
|         let contentParams = { title, subtitle, body }; | ||||
|         if (iconName) | ||||
|             contentParams.icon = new Gio.ThemedIcon({ name: iconName }); | ||||
|         let content = new Dialog.MessageDialogContent(contentParams); | ||||
|         this.contentLayout.add_actor(content); | ||||
|  | ||||
|         this._choices = new Map(); | ||||
|  | ||||
| @@ -98,16 +81,11 @@ const AccessDialog = new Lang.Class({ | ||||
|             let check = new CheckBox.CheckBox(); | ||||
|             check.getLabelActor().text = name; | ||||
|             check.actor.checked = selected == "true"; | ||||
|             messageBox.add_actor(check.actor); | ||||
|             content.insertBeforeBody(check.actor); | ||||
|  | ||||
|             this._choices.set(id, check); | ||||
|         } | ||||
|  | ||||
|         label = new St.Label({ text: body }); | ||||
|         label.clutter_text.ellipsize = Pango.EllipsizeMode.NONE; | ||||
|         label.clutter_text.line_wrap = true; | ||||
|         messageBox.add_actor(label); | ||||
|  | ||||
|         this.addButton({ label: denyLabel, | ||||
|                          action: () => { | ||||
|                              this._sendResponse(DialogResponse.CANCEL); | ||||
| @@ -159,7 +137,7 @@ const AccessDialog = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const AccessDialogDBus = new Lang.Class({ | ||||
| var AccessDialogDBus = new Lang.Class({ | ||||
|     Name: 'AccessDialogDBus', | ||||
|  | ||||
|     _init: function() { | ||||
|   | ||||
| @@ -14,19 +14,19 @@ const Main = imports.ui.main; | ||||
| const SwitcherPopup = imports.ui.switcherPopup; | ||||
| const Tweener = imports.ui.tweener; | ||||
|  | ||||
| const APP_ICON_HOVER_TIMEOUT = 200; // milliseconds | ||||
| var APP_ICON_HOVER_TIMEOUT = 200; // milliseconds | ||||
|  | ||||
| const THUMBNAIL_DEFAULT_SIZE = 256; | ||||
| const THUMBNAIL_POPUP_TIME = 500; // milliseconds | ||||
| const THUMBNAIL_FADE_TIME = 0.1; // seconds | ||||
| var THUMBNAIL_DEFAULT_SIZE = 256; | ||||
| var THUMBNAIL_POPUP_TIME = 500; // milliseconds | ||||
| var THUMBNAIL_FADE_TIME = 0.1; // seconds | ||||
|  | ||||
| const WINDOW_PREVIEW_SIZE = 128; | ||||
| const APP_ICON_SIZE = 96; | ||||
| const APP_ICON_SIZE_SMALL = 48; | ||||
| var WINDOW_PREVIEW_SIZE = 128; | ||||
| var APP_ICON_SIZE = 96; | ||||
| var APP_ICON_SIZE_SMALL = 48; | ||||
|  | ||||
| const baseIconSizes = [96, 64, 48, 32, 22]; | ||||
|  | ||||
| const AppIconMode = { | ||||
| var AppIconMode = { | ||||
|     THUMBNAIL_ONLY: 1, | ||||
|     APP_ICON_ONLY: 2, | ||||
|     BOTH: 3, | ||||
| @@ -58,7 +58,7 @@ function getWindows(workspace) { | ||||
|     }).filter((w, i, a) => !w.skip_taskbar && a.indexOf(w) == i); | ||||
| } | ||||
|  | ||||
| const AppSwitcherPopup = new Lang.Class({ | ||||
| var AppSwitcherPopup = new Lang.Class({ | ||||
|     Name: 'AppSwitcherPopup', | ||||
|     Extends: SwitcherPopup.SwitcherPopup, | ||||
|  | ||||
| @@ -366,7 +366,7 @@ const AppSwitcherPopup = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const CyclerHighlight = new Lang.Class({ | ||||
| var CyclerHighlight = new Lang.Class({ | ||||
|     Name: 'CyclerHighlight', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -427,7 +427,7 @@ const CyclerHighlight = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const CyclerPopup = new Lang.Class({ | ||||
| var CyclerPopup = new Lang.Class({ | ||||
|     Name: 'CyclerPopup', | ||||
|     Extends: SwitcherPopup.SwitcherPopup, | ||||
|     Abstract: true, | ||||
| @@ -488,7 +488,7 @@ const CyclerPopup = new Lang.Class({ | ||||
| }); | ||||
|  | ||||
|  | ||||
| const GroupCyclerPopup = new Lang.Class({ | ||||
| var GroupCyclerPopup = new Lang.Class({ | ||||
|     Name: 'GroupCyclerPopup', | ||||
|     Extends: CyclerPopup, | ||||
|  | ||||
| @@ -509,7 +509,7 @@ const GroupCyclerPopup = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const WindowSwitcherPopup = new Lang.Class({ | ||||
| var WindowSwitcherPopup = new Lang.Class({ | ||||
|     Name: 'WindowSwitcherPopup', | ||||
|     Extends: SwitcherPopup.SwitcherPopup, | ||||
|  | ||||
| @@ -556,7 +556,7 @@ const WindowSwitcherPopup = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const WindowCyclerPopup = new Lang.Class({ | ||||
| var WindowCyclerPopup = new Lang.Class({ | ||||
|     Name: 'WindowCyclerPopup', | ||||
|     Extends: CyclerPopup, | ||||
|  | ||||
| @@ -582,7 +582,7 @@ const WindowCyclerPopup = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const AppIcon = new Lang.Class({ | ||||
| var AppIcon = new Lang.Class({ | ||||
|     Name: 'AppIcon', | ||||
|  | ||||
|     _init: function(app) { | ||||
| @@ -603,7 +603,7 @@ const AppIcon = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const AppSwitcher = new Lang.Class({ | ||||
| var AppSwitcher = new Lang.Class({ | ||||
|     Name: 'AppSwitcher', | ||||
|     Extends: SwitcherPopup.SwitcherList, | ||||
|  | ||||
| @@ -777,7 +777,7 @@ const AppSwitcher = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const ThumbnailList = new Lang.Class({ | ||||
| var ThumbnailList = new Lang.Class({ | ||||
|     Name: 'ThumbnailList', | ||||
|     Extends: SwitcherPopup.SwitcherList, | ||||
|  | ||||
| @@ -845,7 +845,7 @@ const ThumbnailList = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const WindowIcon = new Lang.Class({ | ||||
| var WindowIcon = new Lang.Class({ | ||||
|     Name: 'WindowIcon', | ||||
|  | ||||
|     _init: function(window, mode) { | ||||
| @@ -902,7 +902,7 @@ const WindowIcon = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const WindowList = new Lang.Class({ | ||||
| var WindowList = new Lang.Class({ | ||||
|     Name: 'WindowList', | ||||
|     Extends: SwitcherPopup.SwitcherList, | ||||
|  | ||||
|   | ||||
| @@ -7,9 +7,9 @@ const St = imports.gi.St; | ||||
| const Signals = imports.signals; | ||||
| const Atk = imports.gi.Atk; | ||||
|  | ||||
| const ANIMATED_ICON_UPDATE_TIMEOUT = 16; | ||||
| var ANIMATED_ICON_UPDATE_TIMEOUT = 16; | ||||
|  | ||||
| const Animation = new Lang.Class({ | ||||
| var Animation = new Lang.Class({ | ||||
|     Name: 'Animation', | ||||
|  | ||||
|     _init: function(file, width, height, speed) { | ||||
| @@ -78,7 +78,7 @@ const Animation = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const AnimatedIcon = new Lang.Class({ | ||||
| var AnimatedIcon = new Lang.Class({ | ||||
|     Name: 'AnimatedIcon', | ||||
|     Extends: Animation, | ||||
|  | ||||
|   | ||||
| @@ -27,38 +27,38 @@ const Workspace = imports.ui.workspace; | ||||
| const Params = imports.misc.params; | ||||
| const Util = imports.misc.util; | ||||
|  | ||||
| const MAX_APPLICATION_WORK_MILLIS = 75; | ||||
| const MENU_POPUP_TIMEOUT = 600; | ||||
| const MAX_COLUMNS = 6; | ||||
| const MIN_COLUMNS = 4; | ||||
| const MIN_ROWS = 4; | ||||
| var MAX_APPLICATION_WORK_MILLIS = 75; | ||||
| var MENU_POPUP_TIMEOUT = 600; | ||||
| var MAX_COLUMNS = 6; | ||||
| var MIN_COLUMNS = 4; | ||||
| var MIN_ROWS = 4; | ||||
|  | ||||
| const INACTIVE_GRID_OPACITY = 77; | ||||
| var INACTIVE_GRID_OPACITY = 77; | ||||
| // This time needs to be less than IconGrid.EXTRA_SPACE_ANIMATION_TIME | ||||
| // to not clash with other animations | ||||
| const INACTIVE_GRID_OPACITY_ANIMATION_TIME = 0.24; | ||||
| const FOLDER_SUBICON_FRACTION = .4; | ||||
| var INACTIVE_GRID_OPACITY_ANIMATION_TIME = 0.24; | ||||
| var FOLDER_SUBICON_FRACTION = .4; | ||||
|  | ||||
| const MIN_FREQUENT_APPS_COUNT = 3; | ||||
| var MIN_FREQUENT_APPS_COUNT = 3; | ||||
|  | ||||
| const INDICATORS_BASE_TIME = 0.25; | ||||
| const INDICATORS_ANIMATION_DELAY = 0.125; | ||||
| const INDICATORS_ANIMATION_MAX_TIME = 0.75; | ||||
| var INDICATORS_BASE_TIME = 0.25; | ||||
| var INDICATORS_ANIMATION_DELAY = 0.125; | ||||
| var INDICATORS_ANIMATION_MAX_TIME = 0.75; | ||||
|  | ||||
| var VIEWS_SWITCH_TIME = 0.4; | ||||
| var VIEWS_SWITCH_ANIMATION_DELAY = 0.1; | ||||
|  | ||||
| // Follow iconGrid animations approach and divide by 2 to animate out to | ||||
| // not annoy the user when the user wants to quit appDisplay. | ||||
| // Also, make sure we don't exceed iconGrid animation total time or | ||||
| // views switch time. | ||||
| const INDICATORS_BASE_TIME_OUT = 0.125; | ||||
| const INDICATORS_ANIMATION_DELAY_OUT = 0.0625; | ||||
| const INDICATORS_ANIMATION_MAX_TIME_OUT = | ||||
| var INDICATORS_BASE_TIME_OUT = 0.125; | ||||
| var INDICATORS_ANIMATION_DELAY_OUT = 0.0625; | ||||
| var INDICATORS_ANIMATION_MAX_TIME_OUT = | ||||
|     Math.min (VIEWS_SWITCH_TIME, | ||||
|               IconGrid.ANIMATION_TIME_OUT + IconGrid.ANIMATION_MAX_DELAY_OUT_FOR_ITEM); | ||||
|  | ||||
| const PAGE_SWITCH_TIME = 0.3; | ||||
|  | ||||
| const VIEWS_SWITCH_TIME = 0.4; | ||||
| const VIEWS_SWITCH_ANIMATION_DELAY = 0.1; | ||||
| var PAGE_SWITCH_TIME = 0.3; | ||||
|  | ||||
| const SWITCHEROO_BUS_NAME = 'net.hadess.SwitcherooControl'; | ||||
| const SWITCHEROO_OBJECT_PATH = '/net/hadess/SwitcherooControl'; | ||||
| @@ -108,7 +108,7 @@ function clamp(value, min, max) { | ||||
|     return Math.max(min, Math.min(max, value)); | ||||
| } | ||||
|  | ||||
| const BaseAppView = new Lang.Class({ | ||||
| var BaseAppView = new Lang.Class({ | ||||
|     Name: 'BaseAppView', | ||||
|     Abstract: true, | ||||
|  | ||||
| @@ -219,17 +219,10 @@ const BaseAppView = new Lang.Class({ | ||||
|         } | ||||
|  | ||||
|         if (animationDirection == IconGrid.AnimationDirection.IN) { | ||||
|             let toAnimate = this._grid.actor.connect('notify::allocation', Lang.bind(this, | ||||
|                 function() { | ||||
|                     this._grid.actor.disconnect(toAnimate); | ||||
|                     // We need to hide the grid temporary to not flash it | ||||
|                     // for a frame | ||||
|                     this._grid.actor.opacity = 0; | ||||
|                     Meta.later_add(Meta.LaterType.BEFORE_REDRAW, | ||||
|                                    Lang.bind(this, function() { | ||||
|                                        this._doSpringAnimation(animationDirection) | ||||
|                                   })); | ||||
|                 })); | ||||
|             let id = this._grid.actor.connect('paint', () => { | ||||
|                 this._grid.actor.disconnect(id); | ||||
|                 this._doSpringAnimation(animationDirection); | ||||
|             }); | ||||
|         } else { | ||||
|             this._doSpringAnimation(animationDirection); | ||||
|         } | ||||
| @@ -256,7 +249,7 @@ const BaseAppView = new Lang.Class({ | ||||
| }); | ||||
| Signals.addSignalMethods(BaseAppView.prototype); | ||||
|  | ||||
| const PageIndicatorsActor = new Lang.Class({ | ||||
| var PageIndicatorsActor = new Lang.Class({ | ||||
|     Name:'PageIndicatorsActor', | ||||
|     Extends: St.BoxLayout, | ||||
|  | ||||
| @@ -280,7 +273,7 @@ const PageIndicatorsActor = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const PageIndicators = new Lang.Class({ | ||||
| var PageIndicators = new Lang.Class({ | ||||
|     Name:'PageIndicators', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -373,7 +366,7 @@ const PageIndicators = new Lang.Class({ | ||||
| }); | ||||
| Signals.addSignalMethods(PageIndicators.prototype); | ||||
|  | ||||
| const AllView = new Lang.Class({ | ||||
| var AllView = new Lang.Class({ | ||||
|     Name: 'AllView', | ||||
|     Extends: BaseAppView, | ||||
|  | ||||
| @@ -447,7 +440,10 @@ const AllView = new Lang.Class({ | ||||
|             })); | ||||
|         this._grid.connect('space-opened', Lang.bind(this, | ||||
|             function() { | ||||
|                 this._scrollView.get_effect('fade').enabled = false; | ||||
|                 let fadeEffect = this._scrollView.get_effect('fade'); | ||||
|                 if (fadeEffect) | ||||
|                     fadeEffect.enabled = false; | ||||
|  | ||||
|                 this.emit('space-ready'); | ||||
|             })); | ||||
|         this._grid.connect('space-closed', Lang.bind(this, | ||||
| @@ -658,7 +654,11 @@ const AllView = new Lang.Class({ | ||||
|  | ||||
|     _closeSpaceForPopup: function() { | ||||
|         this._updateIconOpacities(false); | ||||
|         this._scrollView.get_effect('fade').enabled = true; | ||||
|  | ||||
|         let fadeEffect = this._scrollView.get_effect('fade'); | ||||
|         if (fadeEffect) | ||||
|             fadeEffect.enabled = true; | ||||
|  | ||||
|         this._grid.closeExtraSpace(); | ||||
|     }, | ||||
|  | ||||
| @@ -792,7 +792,7 @@ const AllView = new Lang.Class({ | ||||
| }); | ||||
| Signals.addSignalMethods(AllView.prototype); | ||||
|  | ||||
| const FrequentView = new Lang.Class({ | ||||
| var FrequentView = new Lang.Class({ | ||||
|     Name: 'FrequentView', | ||||
|     Extends: BaseAppView, | ||||
|  | ||||
| @@ -866,12 +866,12 @@ const FrequentView = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const Views = { | ||||
| var Views = { | ||||
|     FREQUENT: 0, | ||||
|     ALL: 1 | ||||
| }; | ||||
|  | ||||
| const ControlsBoxLayout = Lang.Class({ | ||||
| var ControlsBoxLayout = Lang.Class({ | ||||
|     Name: 'ControlsBoxLayout', | ||||
|     Extends: Clutter.BoxLayout, | ||||
|  | ||||
| @@ -896,7 +896,7 @@ const ControlsBoxLayout = Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const ViewStackLayout = new Lang.Class({ | ||||
| var ViewStackLayout = new Lang.Class({ | ||||
|     Name: 'ViewStackLayout', | ||||
|     Extends: Clutter.BinLayout, | ||||
|     Signals: { 'allocated-size-changed': { param_types: [GObject.TYPE_INT, | ||||
| @@ -912,7 +912,7 @@ const ViewStackLayout = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const AppDisplay = new Lang.Class({ | ||||
| var AppDisplay = new Lang.Class({ | ||||
|     Name: 'AppDisplay', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -1077,12 +1077,14 @@ const AppDisplay = new Lang.Class({ | ||||
|     } | ||||
| }) | ||||
|  | ||||
| const AppSearchProvider = new Lang.Class({ | ||||
| var AppSearchProvider = new Lang.Class({ | ||||
|     Name: 'AppSearchProvider', | ||||
|  | ||||
|     _init: function() { | ||||
|         this._appSys = Shell.AppSystem.get_default(); | ||||
|         this.id = 'applications'; | ||||
|         this.isRemoteProvider = false; | ||||
|         this.canLaunchSearch = false; | ||||
|     }, | ||||
|  | ||||
|     getResultMetas: function(apps, callback) { | ||||
| @@ -1130,7 +1132,7 @@ const AppSearchProvider = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const FolderView = new Lang.Class({ | ||||
| var FolderView = new Lang.Class({ | ||||
|     Name: 'FolderView', | ||||
|     Extends: BaseAppView, | ||||
|  | ||||
| @@ -1246,11 +1248,12 @@ const FolderView = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const FolderIcon = new Lang.Class({ | ||||
| var FolderIcon = new Lang.Class({ | ||||
|     Name: 'FolderIcon', | ||||
|  | ||||
|     _init: function(id, path, parentView) { | ||||
|         this.id = id; | ||||
|         this.name = ''; | ||||
|         this._parentView = parentView; | ||||
|  | ||||
|         this._folder = new Gio.Settings({ schema_id: 'org.gnome.desktop.app-folders.folder', | ||||
| @@ -1423,7 +1426,7 @@ const FolderIcon = new Lang.Class({ | ||||
| }); | ||||
| Signals.addSignalMethods(FolderIcon.prototype); | ||||
|  | ||||
| const AppFolderPopup = new Lang.Class({ | ||||
| var AppFolderPopup = new Lang.Class({ | ||||
|     Name: 'AppFolderPopup', | ||||
|  | ||||
|     _init: function(source, side) { | ||||
| @@ -1584,7 +1587,7 @@ const AppFolderPopup = new Lang.Class({ | ||||
| }); | ||||
| Signals.addSignalMethods(AppFolderPopup.prototype); | ||||
|  | ||||
| const AppIcon = new Lang.Class({ | ||||
| var AppIcon = new Lang.Class({ | ||||
|     Name: 'AppIcon', | ||||
|  | ||||
|     _init : function(app, iconParams) { | ||||
| @@ -1830,7 +1833,7 @@ const AppIcon = new Lang.Class({ | ||||
| }); | ||||
| Signals.addSignalMethods(AppIcon.prototype); | ||||
|  | ||||
| const AppIconMenu = new Lang.Class({ | ||||
| var AppIconMenu = new Lang.Class({ | ||||
|     Name: 'AppIconMenu', | ||||
|     Extends: PopupMenu.PopupMenu, | ||||
|  | ||||
|   | ||||
| @@ -43,7 +43,7 @@ const RENAMED_DESKTOP_IDS = { | ||||
|     'totem.desktop': 'org.gnome.Totem.desktop', | ||||
| }; | ||||
|  | ||||
| const AppFavorites = new Lang.Class({ | ||||
| var AppFavorites = new Lang.Class({ | ||||
|     Name: 'AppFavorites', | ||||
|  | ||||
|     FAVORITE_APPS_KEY: 'favorite-apps', | ||||
|   | ||||
| @@ -9,7 +9,7 @@ const St = imports.gi.St; | ||||
| const Main = imports.ui.main; | ||||
| const ModalDialog = imports.ui.modalDialog; | ||||
|  | ||||
| const AudioDevice = { | ||||
| var AudioDevice = { | ||||
|     HEADPHONES: 1 << 0, | ||||
|     HEADSET:    1 << 1, | ||||
|     MICROPHONE: 1 << 2 | ||||
| @@ -28,7 +28,7 @@ const AudioDeviceSelectionIface = '<node> \ | ||||
| </interface> \ | ||||
| </node>'; | ||||
|  | ||||
| const AudioDeviceSelectionDialog = new Lang.Class({ | ||||
| var AudioDeviceSelectionDialog = new Lang.Class({ | ||||
|     Name: 'AudioDeviceSelectionDialog', | ||||
|     Extends: ModalDialog.ModalDialog, | ||||
|  | ||||
| @@ -146,7 +146,7 @@ const AudioDeviceSelectionDialog = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const AudioDeviceSelectionDBus = new Lang.Class({ | ||||
| var AudioDeviceSelectionDBus = new Lang.Class({ | ||||
|     Name: 'AudioDeviceSelectionDBus', | ||||
|  | ||||
|     _init: function() { | ||||
|   | ||||
| @@ -107,7 +107,7 @@ const Main = imports.ui.main; | ||||
| const Params = imports.misc.params; | ||||
| const Tweener = imports.ui.tweener; | ||||
|  | ||||
| const DEFAULT_BACKGROUND_COLOR = Clutter.Color.from_pixel(0x2e3436ff); | ||||
| var DEFAULT_BACKGROUND_COLOR = Clutter.Color.from_pixel(0x2e3436ff); | ||||
|  | ||||
| const BACKGROUND_SCHEMA = 'org.gnome.desktop.background'; | ||||
| const PRIMARY_COLOR_KEY = 'primary-color'; | ||||
| @@ -117,14 +117,14 @@ const BACKGROUND_STYLE_KEY = 'picture-options'; | ||||
| const PICTURE_OPACITY_KEY = 'picture-opacity'; | ||||
| const PICTURE_URI_KEY = 'picture-uri'; | ||||
|  | ||||
| const FADE_ANIMATION_TIME = 1.0; | ||||
| var FADE_ANIMATION_TIME = 1.0; | ||||
|  | ||||
| // These parameters affect how often we redraw. | ||||
| // The first is how different (percent crossfaded) the slide show | ||||
| // has to look before redrawing and the second is the minimum | ||||
| // frequency (in seconds) we're willing to wake up | ||||
| const ANIMATION_OPACITY_STEP_INCREMENT = 4.0; | ||||
| const ANIMATION_MIN_WAKEUP_INTERVAL = 1.0; | ||||
| var ANIMATION_OPACITY_STEP_INCREMENT = 4.0; | ||||
| var ANIMATION_MIN_WAKEUP_INTERVAL = 1.0; | ||||
|  | ||||
| let _backgroundCache = null; | ||||
|  | ||||
| @@ -138,7 +138,7 @@ function _fileEqual0(file1, file2) { | ||||
|     return file1.equal(file2); | ||||
| } | ||||
|  | ||||
| const BackgroundCache = new Lang.Class({ | ||||
| var BackgroundCache = new Lang.Class({ | ||||
|     Name: 'BackgroundCache', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -226,7 +226,7 @@ function getBackgroundCache() { | ||||
|     return _backgroundCache; | ||||
| } | ||||
|  | ||||
| const Background = new Lang.Class({ | ||||
| var Background = new Lang.Class({ | ||||
|     Name: 'Background', | ||||
|  | ||||
|     _init: function(params) { | ||||
| @@ -488,7 +488,7 @@ Signals.addSignalMethods(Background.prototype); | ||||
|  | ||||
| let _systemBackground; | ||||
|  | ||||
| const SystemBackground = new Lang.Class({ | ||||
| var SystemBackground = new Lang.Class({ | ||||
|     Name: 'SystemBackground', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -525,7 +525,7 @@ const SystemBackground = new Lang.Class({ | ||||
| }); | ||||
| Signals.addSignalMethods(SystemBackground.prototype); | ||||
|  | ||||
| const BackgroundSource = new Lang.Class({ | ||||
| var BackgroundSource = new Lang.Class({ | ||||
|     Name: 'BackgroundSource', | ||||
|  | ||||
|     _init: function(layoutManager, settingsSchema) { | ||||
| @@ -613,7 +613,7 @@ const BackgroundSource = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const Animation = new Lang.Class({ | ||||
| var Animation = new Lang.Class({ | ||||
|     Name: 'Animation', | ||||
|  | ||||
|     _init: function(params) { | ||||
| @@ -661,7 +661,7 @@ const Animation = new Lang.Class({ | ||||
| }); | ||||
| Signals.addSignalMethods(Animation.prototype); | ||||
|  | ||||
| const BackgroundManager = new Lang.Class({ | ||||
| var BackgroundManager = new Lang.Class({ | ||||
|     Name: 'BackgroundManager', | ||||
|  | ||||
|     _init: function(params) { | ||||
|   | ||||
| @@ -9,7 +9,7 @@ const BoxPointer = imports.ui.boxpointer; | ||||
| const Main = imports.ui.main; | ||||
| const PopupMenu = imports.ui.popupMenu; | ||||
|  | ||||
| const BackgroundMenu = new Lang.Class({ | ||||
| var BackgroundMenu = new Lang.Class({ | ||||
|     Name: 'BackgroundMenu', | ||||
|     Extends: PopupMenu.PopupMenu, | ||||
|  | ||||
|   | ||||
| @@ -10,14 +10,14 @@ const St = imports.gi.St; | ||||
| const Main = imports.ui.main; | ||||
| const Tweener = imports.ui.tweener; | ||||
|  | ||||
| const PopupAnimation = { | ||||
| var PopupAnimation = { | ||||
|     NONE:  0, | ||||
|     SLIDE: 1 << 0, | ||||
|     FADE:  1 << 1, | ||||
|     FULL:  ~0, | ||||
| }; | ||||
|  | ||||
| const POPUP_ANIMATION_TIME = 0.15; | ||||
| var POPUP_ANIMATION_TIME = 0.15; | ||||
|  | ||||
| /** | ||||
|  * BoxPointer: | ||||
| @@ -32,7 +32,7 @@ const POPUP_ANIMATION_TIME = 0.15; | ||||
|  * totally inside the monitor if possible. | ||||
|  * | ||||
|  */ | ||||
| const BoxPointer = new Lang.Class({ | ||||
| var BoxPointer = new Lang.Class({ | ||||
|     Name: 'BoxPointer', | ||||
|  | ||||
|     _init: function(arrowSide, binProperties) { | ||||
|   | ||||
| @@ -16,15 +16,15 @@ const MessageTray = imports.ui.messageTray; | ||||
| const Mpris = imports.ui.mpris; | ||||
| const Util = imports.misc.util; | ||||
|  | ||||
| const MSECS_IN_DAY = 24 * 60 * 60 * 1000; | ||||
| const SHOW_WEEKDATE_KEY = 'show-weekdate'; | ||||
| const ELLIPSIS_CHAR = '\u2026'; | ||||
| var MSECS_IN_DAY = 24 * 60 * 60 * 1000; | ||||
| var SHOW_WEEKDATE_KEY = 'show-weekdate'; | ||||
| var ELLIPSIS_CHAR = '\u2026'; | ||||
|  | ||||
| const MESSAGE_ICON_SIZE = 16; | ||||
| var MESSAGE_ICON_SIZE = 16; | ||||
|  | ||||
| // alias to prevent xgettext from picking up strings translated in GTK+ | ||||
| const gtk30_ = Gettext_gtk30.gettext; | ||||
| const NC_ = function(context, str) { return context + '\u0004' + str; }; | ||||
| var NC_ = function(context, str) { return context + '\u0004' + str; }; | ||||
|  | ||||
| function sameYear(dateA, dateB) { | ||||
|     return (dateA.getYear() == dateB.getYear()); | ||||
| @@ -92,7 +92,7 @@ function _getCalendarDayAbbreviation(dayNumber) { | ||||
|  | ||||
| // Abstraction for an appointment/event in a calendar | ||||
|  | ||||
| const CalendarEvent = new Lang.Class({ | ||||
| var CalendarEvent = new Lang.Class({ | ||||
|     Name: 'CalendarEvent', | ||||
|  | ||||
|     _init: function(id, date, end, summary, allDay) { | ||||
| @@ -108,7 +108,7 @@ const CalendarEvent = new Lang.Class({ | ||||
| // | ||||
|  | ||||
| // First, an implementation with no events | ||||
| const EmptyEventSource = new Lang.Class({ | ||||
| var EmptyEventSource = new Lang.Class({ | ||||
|     Name: 'EmptyEventSource', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -179,7 +179,7 @@ function _dateIntervalsOverlap(a0, a1, b0, b1) | ||||
| } | ||||
|  | ||||
| // an implementation that reads data from a session bus service | ||||
| const DBusEventSource = new Lang.Class({ | ||||
| var DBusEventSource = new Lang.Class({ | ||||
|     Name: 'DBusEventSource', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -366,7 +366,7 @@ const DBusEventSource = new Lang.Class({ | ||||
| }); | ||||
| Signals.addSignalMethods(DBusEventSource.prototype); | ||||
|  | ||||
| const Calendar = new Lang.Class({ | ||||
| var Calendar = new Lang.Class({ | ||||
|     Name: 'Calendar', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -697,7 +697,7 @@ const Calendar = new Lang.Class({ | ||||
| }); | ||||
| Signals.addSignalMethods(Calendar.prototype); | ||||
|  | ||||
| const EventMessage = new Lang.Class({ | ||||
| var EventMessage = new Lang.Class({ | ||||
|     Name: 'EventMessage', | ||||
|     Extends: MessageList.Message, | ||||
|  | ||||
| @@ -754,15 +754,15 @@ const EventMessage = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const NotificationMessage = new Lang.Class({ | ||||
| var NotificationMessage = new Lang.Class({ | ||||
|     Name: 'NotificationMessage', | ||||
|     Extends: MessageList.Message, | ||||
|  | ||||
|     _init: function(notification) { | ||||
|         this.notification = notification; | ||||
|  | ||||
|         this.setUseBodyMarkup(notification.bannerBodyMarkup); | ||||
|         this.parent(notification.title, notification.bannerBodyText); | ||||
|         this.setUseBodyMarkup(notification.bannerBodyMarkup); | ||||
|  | ||||
|         this.setIcon(this._getIcon()); | ||||
|  | ||||
| @@ -810,7 +810,7 @@ const NotificationMessage = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const EventsSection = new Lang.Class({ | ||||
| var EventsSection = new Lang.Class({ | ||||
|     Name: 'EventsSection', | ||||
|     Extends: MessageList.MessageListSection, | ||||
|  | ||||
| @@ -920,7 +920,7 @@ const EventsSection = new Lang.Class({ | ||||
|         let app = this._getCalendarApp(); | ||||
|         if (app.get_id() == 'evolution.desktop') | ||||
|             app = Gio.DesktopAppInfo.new('evolution-calendar.desktop'); | ||||
|         app.launch([], global.create_app_launch_context(0, -1), false); | ||||
|         app.launch([], global.create_app_launch_context(0, -1)); | ||||
|     }, | ||||
|  | ||||
|     setDate: function(date) { | ||||
| @@ -941,7 +941,7 @@ const EventsSection = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const NotificationSection = new Lang.Class({ | ||||
| var NotificationSection = new Lang.Class({ | ||||
|     Name: 'NotificationSection', | ||||
|     Extends: MessageList.MessageListSection, | ||||
|  | ||||
| @@ -1044,7 +1044,7 @@ const NotificationSection = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const Placeholder = new Lang.Class({ | ||||
| var Placeholder = new Lang.Class({ | ||||
|     Name: 'Placeholder', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -1091,7 +1091,7 @@ const Placeholder = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const CalendarMessageList = new Lang.Class({ | ||||
| var CalendarMessageList = new Lang.Class({ | ||||
|     Name: 'CalendarMessageList', | ||||
|  | ||||
|     _init: function() { | ||||
|   | ||||
| @@ -4,7 +4,7 @@ const St = imports.gi.St; | ||||
|  | ||||
| const Lang = imports.lang; | ||||
|  | ||||
| const CheckBox = new Lang.Class({ | ||||
| var CheckBox = new Lang.Class({ | ||||
|     Name: 'CheckBox', | ||||
|  | ||||
|     _init: function(label) { | ||||
|   | ||||
							
								
								
									
										138
									
								
								js/ui/closeDialog.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										138
									
								
								js/ui/closeDialog.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,138 @@ | ||||
| // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | ||||
|  | ||||
| const Clutter = imports.gi.Clutter; | ||||
| const Gio = imports.gi.Gio; | ||||
| const GObject = imports.gi.GObject; | ||||
| const Lang = imports.lang; | ||||
| const Meta = imports.gi.Meta; | ||||
| const Shell = imports.gi.Shell; | ||||
|  | ||||
| const Dialog = imports.ui.dialog; | ||||
| const Main = imports.ui.main; | ||||
| const Tweener = imports.ui.tweener; | ||||
|  | ||||
| var FROZEN_WINDOW_BRIGHTNESS = -0.3 | ||||
| var DIALOG_TRANSITION_TIME = 0.15 | ||||
|  | ||||
| var CloseDialog = new Lang.Class({ | ||||
|     Name: 'CloseDialog', | ||||
|     Extends: GObject.Object, | ||||
|     Implements: [ Meta.CloseDialog ], | ||||
|     Properties: { | ||||
|         'window': GObject.ParamSpec.override('window', Meta.CloseDialog) | ||||
|     }, | ||||
|  | ||||
|     _init: function (window) { | ||||
|         this.parent(); | ||||
|         this._window = window; | ||||
|         this._dialog = null; | ||||
|     }, | ||||
|  | ||||
|     get window() { | ||||
|         return this._window; | ||||
|     }, | ||||
|  | ||||
|     set window(window) { | ||||
|         this._window = window; | ||||
|     }, | ||||
|  | ||||
|     _createDialogContent: function () { | ||||
|         let tracker = Shell.WindowTracker.get_default(); | ||||
|         let windowApp = tracker.get_window_app(this._window); | ||||
|  | ||||
|         /* Translators: %s is an application name */ | ||||
|         let title = _("“%s” is not responding.").format(windowApp.get_name()); | ||||
|         let subtitle = _("You may choose to wait a short while for it to " + | ||||
|                          "continue or force the application to quit entirely."); | ||||
|         let icon = new Gio.ThemedIcon({ name: 'dialog-warning-symbolic' }); | ||||
|         return new Dialog.MessageDialogContent({ icon, title, subtitle }); | ||||
|     }, | ||||
|  | ||||
|     _initDialog: function () { | ||||
|         if (this._dialog) | ||||
|             return; | ||||
|  | ||||
|         let windowActor = this._window.get_compositor_private(); | ||||
|         this._dialog = new Dialog.Dialog(windowActor, 'close-dialog'); | ||||
|         this._dialog.width = windowActor.width; | ||||
|         this._dialog.height = windowActor.height; | ||||
|  | ||||
|         this._dialog.addContent(this._createDialogContent()); | ||||
|         this._dialog.addButton({ label:   _('Force Quit'), | ||||
|                                  action:  Lang.bind(this, this._onClose), | ||||
|                                  default: true }); | ||||
|         this._dialog.addButton({ label:  _('Wait'), | ||||
|                                  action: Lang.bind(this, this._onWait), | ||||
|                                  key:    Clutter.Escape }); | ||||
|  | ||||
|         global.focus_manager.add_group(this._dialog); | ||||
|     }, | ||||
|  | ||||
|     _addWindowEffect: function () { | ||||
|         // We set the effect on the surface actor, so the dialog itself | ||||
|         // (which is a child of the MetaWindowActor) does not get the | ||||
|         // effect applied itself. | ||||
|         let windowActor = this._window.get_compositor_private(); | ||||
|         let surfaceActor = windowActor.get_first_child(); | ||||
|         let effect = new Clutter.BrightnessContrastEffect(); | ||||
|         effect.set_brightness(FROZEN_WINDOW_BRIGHTNESS); | ||||
|         surfaceActor.add_effect_with_name("gnome-shell-frozen-window", effect); | ||||
|     }, | ||||
|  | ||||
|     _removeWindowEffect: function () { | ||||
|         let windowActor = this._window.get_compositor_private(); | ||||
|         let surfaceActor = windowActor.get_first_child(); | ||||
|         surfaceActor.remove_effect_by_name("gnome-shell-frozen-window"); | ||||
|     }, | ||||
|  | ||||
|     _onWait: function () { | ||||
|         this.response(Meta.CloseDialogResponse.WAIT); | ||||
|     }, | ||||
|  | ||||
|     _onClose: function () { | ||||
|         this.response(Meta.CloseDialogResponse.FORCE_CLOSE); | ||||
|     }, | ||||
|  | ||||
|     vfunc_show: function () { | ||||
|         if (this._dialog != null) | ||||
|             return; | ||||
|  | ||||
|         this._addWindowEffect(); | ||||
|         this._initDialog(); | ||||
|  | ||||
|         this._dialog.scale_y = 0; | ||||
|         this._dialog.set_pivot_point(0.5, 0.5); | ||||
|  | ||||
|         Tweener.addTween(this._dialog, | ||||
|                          { scale_y: 1, | ||||
|                            transition: 'linear', | ||||
|                            time: DIALOG_TRANSITION_TIME, | ||||
|                            onComplete: Lang.bind(this, function () { | ||||
|                                Main.layoutManager.trackChrome(this._dialog, { affectsInputRegion: true }); | ||||
|                            }) | ||||
|                          }); | ||||
|     }, | ||||
|  | ||||
|     vfunc_hide: function () { | ||||
|         if (this._dialog == null) | ||||
|             return; | ||||
|  | ||||
|         let dialog = this._dialog; | ||||
|         this._dialog = null; | ||||
|         this._removeWindowEffect(); | ||||
|  | ||||
|         Tweener.addTween(dialog, | ||||
|                          { scale_y: 0, | ||||
|                            transition: 'linear', | ||||
|                            time: DIALOG_TRANSITION_TIME, | ||||
|                            onComplete: Lang.bind(this, function () { | ||||
|                                dialog.destroy(); | ||||
|                            }) | ||||
|                          }); | ||||
|     }, | ||||
|  | ||||
|     vfunc_focus: function () { | ||||
|         if (this._dialog) | ||||
|             this._dialog.grab_key_focus(); | ||||
|     } | ||||
| }); | ||||
| @@ -2,7 +2,7 @@ | ||||
| const Lang = imports.lang; | ||||
| const Main = imports.ui.main; | ||||
|  | ||||
| const ComponentManager = new Lang.Class({ | ||||
| var ComponentManager = new Lang.Class({ | ||||
|     Name: 'ComponentManager', | ||||
|  | ||||
|     _init: function() { | ||||
|   | ||||
| @@ -11,15 +11,15 @@ const GnomeSession = imports.misc.gnomeSession; | ||||
| const Main = imports.ui.main; | ||||
| const ShellMountOperation = imports.ui.shellMountOperation; | ||||
|  | ||||
| const GNOME_SESSION_AUTOMOUNT_INHIBIT = 16; | ||||
| var GNOME_SESSION_AUTOMOUNT_INHIBIT = 16; | ||||
|  | ||||
| // GSettings keys | ||||
| const SETTINGS_SCHEMA = 'org.gnome.desktop.media-handling'; | ||||
| const SETTING_ENABLE_AUTOMOUNT = 'automount'; | ||||
|  | ||||
| const AUTORUN_EXPIRE_TIMEOUT_SECS = 10; | ||||
| var AUTORUN_EXPIRE_TIMEOUT_SECS = 10; | ||||
|  | ||||
| const AutomountManager = new Lang.Class({ | ||||
| var AutomountManager = new Lang.Class({ | ||||
|     Name: 'AutomountManager', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -242,4 +242,4 @@ const AutomountManager = new Lang.Class({ | ||||
|         GLib.Source.set_name_by_id(id, '[gnome-shell] volume.allowAutorun'); | ||||
|     } | ||||
| }); | ||||
| const Component = AutomountManager; | ||||
| var Component = AutomountManager; | ||||
|   | ||||
| @@ -7,7 +7,6 @@ const St = imports.gi.St; | ||||
| const GnomeSession = imports.misc.gnomeSession; | ||||
| const Main = imports.ui.main; | ||||
| const MessageTray = imports.ui.messageTray; | ||||
| const ShellMountOperation = imports.ui.shellMountOperation; | ||||
|  | ||||
| // GSettings keys | ||||
| const SETTINGS_SCHEMA = 'org.gnome.desktop.media-handling'; | ||||
| @@ -16,7 +15,7 @@ const SETTING_START_APP = 'autorun-x-content-start-app'; | ||||
| const SETTING_IGNORE = 'autorun-x-content-ignore'; | ||||
| const SETTING_OPEN_FOLDER = 'autorun-x-content-open-folder'; | ||||
|  | ||||
| const AutorunSetting = { | ||||
| var AutorunSetting = { | ||||
|     RUN: 0, | ||||
|     IGNORE: 1, | ||||
|     FILES: 2, | ||||
| @@ -64,8 +63,7 @@ function startAppForMount(app, mount) { | ||||
|  | ||||
|     try { | ||||
|         retval = app.launch(files,  | ||||
|                             global.create_app_launch_context(0, -1), | ||||
|                             false) | ||||
|                             global.create_app_launch_context(0, -1)); | ||||
|     } catch (e) { | ||||
|         log('Unable to launch the application ' + app.get_name() | ||||
|             + ': ' + e.toString()); | ||||
| @@ -92,7 +90,7 @@ function HotplugSniffer() { | ||||
|                                    '/org/gnome/Shell/HotplugSniffer'); | ||||
| } | ||||
|  | ||||
| const ContentTypeDiscoverer = new Lang.Class({ | ||||
| var ContentTypeDiscoverer = new Lang.Class({ | ||||
|     Name: 'ContentTypeDiscoverer', | ||||
|  | ||||
|     _init: function(callback) { | ||||
| @@ -161,7 +159,7 @@ const ContentTypeDiscoverer = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const AutorunManager = new Lang.Class({ | ||||
| var AutorunManager = new Lang.Class({ | ||||
|     Name: 'AutorunManager', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -198,7 +196,7 @@ const AutorunManager = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const AutorunDispatcher = new Lang.Class({ | ||||
| var AutorunDispatcher = new Lang.Class({ | ||||
|     Name: 'AutorunDispatcher', | ||||
|  | ||||
|     _init: function(manager) { | ||||
| @@ -294,7 +292,7 @@ const AutorunDispatcher = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const AutorunSource = new Lang.Class({ | ||||
| var AutorunSource = new Lang.Class({ | ||||
|     Name: 'AutorunSource', | ||||
|     Extends: MessageTray.Source, | ||||
|  | ||||
| @@ -321,7 +319,7 @@ const AutorunSource = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const AutorunNotification = new Lang.Class({ | ||||
| var AutorunNotification = new Lang.Class({ | ||||
|     Name: 'AutorunNotification', | ||||
|     Extends: MessageTray.Notification, | ||||
|  | ||||
| @@ -380,4 +378,4 @@ const AutorunNotification = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const Component = AutorunManager; | ||||
| var Component = AutorunManager; | ||||
|   | ||||
| @@ -10,16 +10,17 @@ const GObject = imports.gi.GObject; | ||||
| const Gcr = imports.gi.Gcr; | ||||
|  | ||||
| const Animation = imports.ui.animation; | ||||
| const Dialog = imports.ui.dialog; | ||||
| const ModalDialog = imports.ui.modalDialog; | ||||
| const ShellEntry = imports.ui.shellEntry; | ||||
| const CheckBox = imports.ui.checkBox; | ||||
| const Tweener = imports.ui.tweener; | ||||
|  | ||||
| const WORK_SPINNER_ICON_SIZE = 16; | ||||
| const WORK_SPINNER_ANIMATION_DELAY = 1.0; | ||||
| const WORK_SPINNER_ANIMATION_TIME = 0.3; | ||||
| var WORK_SPINNER_ICON_SIZE = 16; | ||||
| var WORK_SPINNER_ANIMATION_DELAY = 1.0; | ||||
| var WORK_SPINNER_ANIMATION_TIME = 0.3; | ||||
|  | ||||
| const KeyringDialog = new Lang.Class({ | ||||
| var KeyringDialog = new Lang.Class({ | ||||
|     Name: 'KeyringDialog', | ||||
|     Extends: ModalDialog.ModalDialog, | ||||
|  | ||||
| @@ -31,38 +32,24 @@ const KeyringDialog = new Lang.Class({ | ||||
|         this.prompt.connect('show-confirm', Lang.bind(this, this._onShowConfirm)); | ||||
|         this.prompt.connect('prompt-close', Lang.bind(this, this._onHidePrompt)); | ||||
|  | ||||
|         let mainContentBox = new St.BoxLayout({ style_class: 'prompt-dialog-main-layout', | ||||
|                                                 vertical: false }); | ||||
|         this.contentLayout.add(mainContentBox); | ||||
|         let icon = new Gio.ThemedIcon({ name: 'dialog-password-symbolic' }); | ||||
|         this._content = new Dialog.MessageDialogContent({ icon }); | ||||
|         this.contentLayout.add(this._content); | ||||
|  | ||||
|         let icon = new St.Icon({ icon_name: 'dialog-password-symbolic' }); | ||||
|         mainContentBox.add(icon, | ||||
|                            { x_fill:  true, | ||||
|                              y_fill:  false, | ||||
|                              x_align: St.Align.END, | ||||
|                              y_align: St.Align.START }); | ||||
|         // FIXME: Why does this break now? | ||||
|         /* | ||||
|         this.prompt.bind_property('message', this._content, 'title', GObject.BindingFlags.SYNC_CREATE); | ||||
|         this.prompt.bind_property('description', this._content, 'body', GObject.BindingFlags.SYNC_CREATE); | ||||
|         */ | ||||
|         this.prompt.connect('notify::message', () => { | ||||
|             this._content.title = this.prompt.message; | ||||
|         }); | ||||
|         this._content.title = this.prompt.message; | ||||
|  | ||||
|         this._messageBox = new St.BoxLayout({ style_class: 'prompt-dialog-message-layout', | ||||
|                                               vertical: true }); | ||||
|         mainContentBox.add(this._messageBox, | ||||
|                            { y_align: St.Align.START, expand: true, x_fill: true, y_fill: true }); | ||||
|  | ||||
|         let subject = new St.Label({ style_class: 'prompt-dialog-headline headline' }); | ||||
|         this.prompt.bind_property('message', subject, 'text', GObject.BindingFlags.SYNC_CREATE); | ||||
|  | ||||
|         this._messageBox.add(subject, | ||||
|                              { x_fill: false, | ||||
|                                y_fill:  false, | ||||
|                                x_align: St.Align.START, | ||||
|                                y_align: St.Align.START }); | ||||
|  | ||||
|         let description = new St.Label({ style_class: 'prompt-dialog-description' }); | ||||
|         description.clutter_text.ellipsize = Pango.EllipsizeMode.NONE; | ||||
|         description.clutter_text.line_wrap = true; | ||||
|         this.prompt.bind_property('description', description, 'text', GObject.BindingFlags.SYNC_CREATE); | ||||
|         this._messageBox.add(description, | ||||
|                             { y_fill:  true, | ||||
|                               y_align: St.Align.START }); | ||||
|         this.prompt.connect('notify::description', () => { | ||||
|             this._content.body = this.prompt.description; | ||||
|         }); | ||||
|         this._content.body = this.prompt.description; | ||||
|  | ||||
|         this._workSpinner = null; | ||||
|         this._controlTable = null; | ||||
| @@ -195,7 +182,7 @@ const KeyringDialog = new Lang.Class({ | ||||
|         } | ||||
|  | ||||
|         this._controlTable = table; | ||||
|         this._messageBox.add(table, { x_fill: true, y_fill: true }); | ||||
|         this._content.messageBox.add(table, { x_fill: true, y_fill: true }); | ||||
|     }, | ||||
|  | ||||
|     _updateSensitivity: function(sensitive) { | ||||
| @@ -271,7 +258,7 @@ const KeyringDialog = new Lang.Class({ | ||||
|     }, | ||||
| }); | ||||
|  | ||||
| const KeyringDummyDialog = new Lang.Class({ | ||||
| var KeyringDummyDialog = new Lang.Class({ | ||||
|     Name: 'KeyringDummyDialog', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -287,7 +274,7 @@ const KeyringDummyDialog = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const KeyringPrompter = new Lang.Class({ | ||||
| var KeyringPrompter = new Lang.Class({ | ||||
|     Name: 'KeyringPrompter', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -324,4 +311,4 @@ const KeyringPrompter = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const Component = KeyringPrompter; | ||||
| var Component = KeyringPrompter; | ||||
|   | ||||
| @@ -12,6 +12,7 @@ const Shell = imports.gi.Shell; | ||||
| const St = imports.gi.St; | ||||
|  | ||||
| const Config = imports.misc.config; | ||||
| const Dialog = imports.ui.dialog; | ||||
| const Main = imports.ui.main; | ||||
| const MessageTray = imports.ui.messageTray; | ||||
| const ModalDialog = imports.ui.modalDialog; | ||||
| @@ -20,7 +21,7 @@ const ShellEntry = imports.ui.shellEntry; | ||||
|  | ||||
| const VPN_UI_GROUP = 'VPN Plugin UI'; | ||||
|  | ||||
| const NetworkSecretDialog = new Lang.Class({ | ||||
| var NetworkSecretDialog = new Lang.Class({ | ||||
|     Name: 'NetworkSecretDialog', | ||||
|     Extends: ModalDialog.ModalDialog, | ||||
|  | ||||
| @@ -38,41 +39,12 @@ const NetworkSecretDialog = new Lang.Class({ | ||||
|         else | ||||
|             this._content = this._getContent(); | ||||
|  | ||||
|         let mainContentBox = new St.BoxLayout({ style_class: 'prompt-dialog-main-layout', | ||||
|                                                 vertical: false }); | ||||
|         this.contentLayout.add(mainContentBox, | ||||
|                                { x_fill: true, | ||||
|                                  y_fill: true }); | ||||
|  | ||||
|         let icon = new St.Icon({ icon_name: 'dialog-password-symbolic' }); | ||||
|         mainContentBox.add(icon, | ||||
|                            { x_fill:  true, | ||||
|                              y_fill:  false, | ||||
|                              x_align: St.Align.END, | ||||
|                              y_align: St.Align.START }); | ||||
|  | ||||
|         let messageBox = new St.BoxLayout({ style_class: 'prompt-dialog-message-layout', | ||||
|                                             vertical: true }); | ||||
|         mainContentBox.add(messageBox, | ||||
|                            { y_align: St.Align.START }); | ||||
|  | ||||
|         let subjectLabel = new St.Label({ style_class: 'prompt-dialog-headline headline', | ||||
|                                             text: this._content.title }); | ||||
|         messageBox.add(subjectLabel, | ||||
|                        { y_fill:  false, | ||||
|                          y_align: St.Align.START }); | ||||
|  | ||||
|         if (this._content.message != null) { | ||||
|             let descriptionLabel = new St.Label({ style_class: 'prompt-dialog-description', | ||||
|                                                   text: this._content.message }); | ||||
|             descriptionLabel.clutter_text.line_wrap = true; | ||||
|             descriptionLabel.clutter_text.ellipsize = Pango.EllipsizeMode.NONE; | ||||
|  | ||||
|             messageBox.add(descriptionLabel, | ||||
|                            { y_fill:  true, | ||||
|                              y_align: St.Align.START, | ||||
|                              expand: true }); | ||||
|         } | ||||
|         let icon = new Gio.ThemedIcon({ name: 'dialog-password-symbolic' }); | ||||
|         let contentParams = { icon, | ||||
|                               title: this._content.title, | ||||
|                               body: this._content.message }; | ||||
|         let contentBox = new Dialog.MessageDialogContent(contentParams); | ||||
|         this.contentLayout.add_actor(contentBox); | ||||
|  | ||||
|         let layout = new Clutter.GridLayout({ orientation: Clutter.Orientation.VERTICAL }); | ||||
|         let secretTable = new St.Widget({ style_class: 'network-dialog-secret-table', | ||||
| @@ -135,7 +107,7 @@ const NetworkSecretDialog = new Lang.Class({ | ||||
|                 secret.entry.clutter_text.set_password_char('\u25cf'); | ||||
|         } | ||||
|  | ||||
|         messageBox.add(secretTable); | ||||
|         contentBox.messageBox.add(secretTable); | ||||
|  | ||||
|         this._okButton = { label:  _("Connect"), | ||||
|                            action: Lang.bind(this, this._onOk), | ||||
| @@ -357,7 +329,7 @@ const NetworkSecretDialog = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const VPNRequestHandler = new Lang.Class({ | ||||
| var VPNRequestHandler = new Lang.Class({ | ||||
|     Name: 'VPNRequestHandler', | ||||
|  | ||||
|     _init: function(agent, requestId, authHelper, serviceType, connection, hints, flags) { | ||||
| @@ -603,7 +575,7 @@ const VPNRequestHandler = new Lang.Class({ | ||||
|     }, | ||||
| }); | ||||
|  | ||||
| const NetworkAgent = new Lang.Class({ | ||||
| var NetworkAgent = new Lang.Class({ | ||||
|     Name: 'NetworkAgent', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -826,4 +798,4 @@ const NetworkAgent = new Lang.Class({ | ||||
|         } | ||||
|     } | ||||
| }); | ||||
| const Component = NetworkAgent; | ||||
| var Component = NetworkAgent; | ||||
|   | ||||
| @@ -15,66 +15,35 @@ const PolkitAgent = imports.gi.PolkitAgent; | ||||
|  | ||||
| const Animation = imports.ui.animation; | ||||
| const Components = imports.ui.components; | ||||
| const Dialog = imports.ui.dialog; | ||||
| const ModalDialog = imports.ui.modalDialog; | ||||
| const ShellEntry = imports.ui.shellEntry; | ||||
| const UserWidget = imports.ui.userWidget; | ||||
| const Tweener = imports.ui.tweener; | ||||
|  | ||||
| const DIALOG_ICON_SIZE = 48; | ||||
| var DIALOG_ICON_SIZE = 48; | ||||
|  | ||||
| const WORK_SPINNER_ICON_SIZE = 16; | ||||
| const WORK_SPINNER_ANIMATION_DELAY = 1.0; | ||||
| const WORK_SPINNER_ANIMATION_TIME = 0.3; | ||||
| var WORK_SPINNER_ICON_SIZE = 16; | ||||
| var WORK_SPINNER_ANIMATION_DELAY = 1.0; | ||||
| var WORK_SPINNER_ANIMATION_TIME = 0.3; | ||||
|  | ||||
| const AuthenticationDialog = new Lang.Class({ | ||||
| var AuthenticationDialog = new Lang.Class({ | ||||
|     Name: 'AuthenticationDialog', | ||||
|     Extends: ModalDialog.ModalDialog, | ||||
|  | ||||
|     _init: function(actionId, message, cookie, userNames) { | ||||
|     _init: function(actionId, body, cookie, userNames) { | ||||
|         this.parent({ styleClass: 'prompt-dialog' }); | ||||
|  | ||||
|         this.actionId = actionId; | ||||
|         this.message = message; | ||||
|         this.message = body; | ||||
|         this.userNames = userNames; | ||||
|         this._wasDismissed = false; | ||||
|  | ||||
|         let mainContentBox = new St.BoxLayout({ style_class: 'prompt-dialog-main-layout', | ||||
|                                                 vertical: false }); | ||||
|         this.contentLayout.add(mainContentBox, | ||||
|                                { x_fill: true, | ||||
|                                  y_fill: true }); | ||||
|         let icon = new Gio.ThemedIcon({ name: 'dialog-password-symbolic' }); | ||||
|         let title = _("Authentication Required"); | ||||
|  | ||||
|         let icon = new St.Icon({ icon_name: 'dialog-password-symbolic' }); | ||||
|         mainContentBox.add(icon, | ||||
|                            { x_fill:  true, | ||||
|                              y_fill:  false, | ||||
|                              x_align: St.Align.END, | ||||
|                              y_align: St.Align.START }); | ||||
|  | ||||
|         let messageBox = new St.BoxLayout({ style_class: 'prompt-dialog-message-layout', | ||||
|                                             vertical: true }); | ||||
|         mainContentBox.add(messageBox, | ||||
|                            { expand: true, y_align: St.Align.START }); | ||||
|  | ||||
|         this._subjectLabel = new St.Label({ style_class: 'prompt-dialog-headline headline', | ||||
|                                             text: _("Authentication Required") }); | ||||
|  | ||||
|         messageBox.add(this._subjectLabel, | ||||
|                        { x_fill: false, | ||||
|                          y_fill:  false, | ||||
|                          x_align: St.Align.START, | ||||
|                          y_align: St.Align.START }); | ||||
|  | ||||
|         this._descriptionLabel = new St.Label({ style_class: 'prompt-dialog-description', | ||||
|                                                 text: message }); | ||||
|         this._descriptionLabel.clutter_text.ellipsize = Pango.EllipsizeMode.NONE; | ||||
|         this._descriptionLabel.clutter_text.line_wrap = true; | ||||
|  | ||||
|         messageBox.add(this._descriptionLabel, | ||||
|                        { x_fill: false, | ||||
|                          y_fill:  true, | ||||
|                          x_align: St.Align.START, | ||||
|                          y_align: St.Align.START }); | ||||
|         let content = new Dialog.MessageDialogContent({ icon, title, body }); | ||||
|         this.contentLayout.add_actor(content); | ||||
|  | ||||
|         if (userNames.length > 1) { | ||||
|             log('polkitAuthenticationAgent: Received ' + userNames.length + | ||||
| @@ -105,12 +74,12 @@ const AuthenticationDialog = new Lang.Class({ | ||||
|         if (userIsRoot) { | ||||
|             let userLabel = new St.Label(({ style_class: 'polkit-dialog-user-root-label', | ||||
|                                             text: userRealName })); | ||||
|             messageBox.add(userLabel, { x_fill: false, | ||||
|                                         x_align: St.Align.START }); | ||||
|             content.messageBox.add(userLabel, { x_fill: false, | ||||
|                                                 x_align: St.Align.START }); | ||||
|         } else { | ||||
|             let userBox = new St.BoxLayout({ style_class: 'polkit-dialog-user-layout', | ||||
|                                              vertical: false }); | ||||
|             messageBox.add(userBox); | ||||
|             content.messageBox.add(userBox); | ||||
|             this._userAvatar = new UserWidget.Avatar(this._user, | ||||
|                                                      { iconSize: DIALOG_ICON_SIZE, | ||||
|                                                        styleClass: 'polkit-dialog-user-icon' }); | ||||
| @@ -132,7 +101,7 @@ const AuthenticationDialog = new Lang.Class({ | ||||
|         this._onUserChanged(); | ||||
|  | ||||
|         this._passwordBox = new St.BoxLayout({ vertical: false, style_class: 'prompt-dialog-password-box' }); | ||||
|         messageBox.add(this._passwordBox); | ||||
|         content.messageBox.add(this._passwordBox); | ||||
|         this._passwordLabel = new St.Label(({ style_class: 'prompt-dialog-password-label' })); | ||||
|         this._passwordBox.add(this._passwordLabel, { y_fill: false, y_align: St.Align.MIDDLE }); | ||||
|         this._passwordEntry = new St.Entry({ style_class: 'prompt-dialog-password-entry', | ||||
| @@ -155,13 +124,13 @@ const AuthenticationDialog = new Lang.Class({ | ||||
|         this._errorMessageLabel = new St.Label({ style_class: 'prompt-dialog-error-label' }); | ||||
|         this._errorMessageLabel.clutter_text.ellipsize = Pango.EllipsizeMode.NONE; | ||||
|         this._errorMessageLabel.clutter_text.line_wrap = true; | ||||
|         messageBox.add(this._errorMessageLabel, { x_fill: false, x_align: St.Align.START }); | ||||
|         content.messageBox.add(this._errorMessageLabel, { x_fill: false, x_align: St.Align.START }); | ||||
|         this._errorMessageLabel.hide(); | ||||
|  | ||||
|         this._infoMessageLabel = new St.Label({ style_class: 'prompt-dialog-info-label' }); | ||||
|         this._infoMessageLabel.clutter_text.ellipsize = Pango.EllipsizeMode.NONE; | ||||
|         this._infoMessageLabel.clutter_text.line_wrap = true; | ||||
|         messageBox.add(this._infoMessageLabel); | ||||
|         content.messageBox.add(this._infoMessageLabel); | ||||
|         this._infoMessageLabel.hide(); | ||||
|  | ||||
|         /* text is intentionally non-blank otherwise the height is not the same as for | ||||
| @@ -173,7 +142,7 @@ const AuthenticationDialog = new Lang.Class({ | ||||
|         this._nullMessageLabel.add_style_class_name('hidden'); | ||||
|         this._nullMessageLabel.clutter_text.ellipsize = Pango.EllipsizeMode.NONE; | ||||
|         this._nullMessageLabel.clutter_text.line_wrap = true; | ||||
|         messageBox.add(this._nullMessageLabel); | ||||
|         content.messageBox.add(this._nullMessageLabel); | ||||
|         this._nullMessageLabel.show(); | ||||
|  | ||||
|         this._cancelButton = this.addButton({ label: _("Cancel"), | ||||
| @@ -370,7 +339,7 @@ const AuthenticationDialog = new Lang.Class({ | ||||
| }); | ||||
| Signals.addSignalMethods(AuthenticationDialog.prototype); | ||||
|  | ||||
| const AuthenticationAgent = new Lang.Class({ | ||||
| var AuthenticationAgent = new Lang.Class({ | ||||
|     Name: 'AuthenticationAgent', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -431,4 +400,4 @@ const AuthenticationAgent = new Lang.Class({ | ||||
|     }, | ||||
| }); | ||||
|  | ||||
| const Component = AuthenticationAgent; | ||||
| var Component = AuthenticationAgent; | ||||
|   | ||||
| @@ -29,25 +29,25 @@ const Util = imports.misc.util; | ||||
| const HAVE_TP = (Tp != null && Tpl != null); | ||||
|  | ||||
| // See Notification.appendMessage | ||||
| const SCROLLBACK_IMMEDIATE_TIME = 3 * 60; // 3 minutes | ||||
| const SCROLLBACK_RECENT_TIME = 15 * 60; // 15 minutes | ||||
| const SCROLLBACK_RECENT_LENGTH = 20; | ||||
| const SCROLLBACK_IDLE_LENGTH = 5; | ||||
| var SCROLLBACK_IMMEDIATE_TIME = 3 * 60; // 3 minutes | ||||
| var SCROLLBACK_RECENT_TIME = 15 * 60; // 15 minutes | ||||
| var SCROLLBACK_RECENT_LENGTH = 20; | ||||
| var SCROLLBACK_IDLE_LENGTH = 5; | ||||
|  | ||||
| // See Source._displayPendingMessages | ||||
| const SCROLLBACK_HISTORY_LINES = 10; | ||||
| var SCROLLBACK_HISTORY_LINES = 10; | ||||
|  | ||||
| // See Notification._onEntryChanged | ||||
| const COMPOSING_STOP_TIMEOUT = 5; | ||||
| var COMPOSING_STOP_TIMEOUT = 5; | ||||
|  | ||||
| const CHAT_EXPAND_LINES = 12; | ||||
| var CHAT_EXPAND_LINES = 12; | ||||
|  | ||||
| const NotificationDirection = { | ||||
| var NotificationDirection = { | ||||
|     SENT: 'chat-sent', | ||||
|     RECEIVED: 'chat-received' | ||||
| }; | ||||
|  | ||||
| const N_ = function(s) { return s; }; | ||||
| var N_ = function(s) { return s; }; | ||||
|  | ||||
| function makeMessageFromTpMessage(tpMessage, direction) { | ||||
|     let [text, flags] = tpMessage.to_text(); | ||||
| @@ -79,7 +79,7 @@ function makeMessageFromTplEvent(event) { | ||||
|     }; | ||||
| } | ||||
|  | ||||
| const TelepathyComponent = new Lang.Class({ | ||||
| var TelepathyComponent = new Lang.Class({ | ||||
|     Name: 'TelepathyComponent', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -113,7 +113,7 @@ const TelepathyComponent = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const TelepathyClient = HAVE_TP ? new Lang.Class({ | ||||
| var TelepathyClient = HAVE_TP ? new Lang.Class({ | ||||
|     Name: 'TelepathyClient', | ||||
|     Extends: Tp.BaseClient, | ||||
|  | ||||
| @@ -280,7 +280,7 @@ const TelepathyClient = HAVE_TP ? new Lang.Class({ | ||||
|     }, | ||||
| }) : null; | ||||
|  | ||||
| const ChatSource = new Lang.Class({ | ||||
| var ChatSource = new Lang.Class({ | ||||
|     Name: 'ChatSource', | ||||
|     Extends: MessageTray.Source, | ||||
|  | ||||
| @@ -647,7 +647,7 @@ const ChatSource = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const ChatNotification = new Lang.Class({ | ||||
| var ChatNotification = new Lang.Class({ | ||||
|     Name: 'ChatNotification', | ||||
|     Extends: MessageTray.Notification, | ||||
|  | ||||
| @@ -806,7 +806,7 @@ const ChatNotification = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const ChatLineBox = new Lang.Class({ | ||||
| var ChatLineBox = new Lang.Class({ | ||||
|     Name: 'ChatLineBox', | ||||
|     Extends: St.BoxLayout, | ||||
|  | ||||
| @@ -816,7 +816,7 @@ const ChatLineBox = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const ChatNotificationBanner = new Lang.Class({ | ||||
| var ChatNotificationBanner = new Lang.Class({ | ||||
|     Name: 'ChatNotificationBanner', | ||||
|     Extends: MessageTray.NotificationBanner, | ||||
|  | ||||
| @@ -996,4 +996,4 @@ const ChatNotificationBanner = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const Component = TelepathyComponent; | ||||
| var Component = TelepathyComponent; | ||||
|   | ||||
| @@ -12,16 +12,16 @@ const SwitcherPopup = imports.ui.switcherPopup; | ||||
| const Params = imports.misc.params; | ||||
| const Tweener = imports.ui.tweener; | ||||
|  | ||||
| const POPUP_APPICON_SIZE = 96; | ||||
| const POPUP_FADE_TIME = 0.1; // seconds | ||||
| var POPUP_APPICON_SIZE = 96; | ||||
| var POPUP_FADE_TIME = 0.1; // seconds | ||||
|  | ||||
| const SortGroup = { | ||||
| var SortGroup = { | ||||
|     TOP:    0, | ||||
|     MIDDLE: 1, | ||||
|     BOTTOM: 2 | ||||
| }; | ||||
|  | ||||
| const CtrlAltTabManager = new Lang.Class({ | ||||
| var CtrlAltTabManager = new Lang.Class({ | ||||
|     Name: 'CtrlAltTabManager', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -136,7 +136,7 @@ const CtrlAltTabManager = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const CtrlAltTabPopup = new Lang.Class({ | ||||
| var CtrlAltTabPopup = new Lang.Class({ | ||||
|     Name: 'CtrlAltTabPopup', | ||||
|     Extends: SwitcherPopup.SwitcherPopup, | ||||
|  | ||||
| @@ -167,7 +167,7 @@ const CtrlAltTabPopup = new Lang.Class({ | ||||
|     }, | ||||
| }); | ||||
|  | ||||
| const CtrlAltTabSwitcher = new Lang.Class({ | ||||
| var CtrlAltTabSwitcher = new Lang.Class({ | ||||
|     Name: 'CtrlAltTabSwitcher', | ||||
|     Extends: SwitcherPopup.SwitcherList, | ||||
|  | ||||
|   | ||||
| @@ -18,10 +18,10 @@ const Main = imports.ui.main; | ||||
| const Tweener = imports.ui.tweener; | ||||
| const Workspace = imports.ui.workspace; | ||||
|  | ||||
| const DASH_ANIMATION_TIME = 0.2; | ||||
| const DASH_ITEM_LABEL_SHOW_TIME = 0.15; | ||||
| const DASH_ITEM_LABEL_HIDE_TIME = 0.1; | ||||
| const DASH_ITEM_HOVER_TIMEOUT = 300; | ||||
| var DASH_ANIMATION_TIME = 0.2; | ||||
| var DASH_ITEM_LABEL_SHOW_TIME = 0.15; | ||||
| var DASH_ITEM_LABEL_HIDE_TIME = 0.1; | ||||
| var DASH_ITEM_HOVER_TIMEOUT = 300; | ||||
|  | ||||
| function getAppFromSource(source) { | ||||
|     if (source instanceof AppDisplay.AppIcon) { | ||||
| @@ -33,7 +33,7 @@ function getAppFromSource(source) { | ||||
|  | ||||
| // A container like StBin, but taking the child's scale into account | ||||
| // when requesting a size | ||||
| const DashItemContainer = new Lang.Class({ | ||||
| var DashItemContainer = new Lang.Class({ | ||||
|     Name: 'DashItemContainer', | ||||
|     Extends: St.Widget, | ||||
|  | ||||
| @@ -235,7 +235,7 @@ const DashItemContainer = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const ShowAppsIcon = new Lang.Class({ | ||||
| var ShowAppsIcon = new Lang.Class({ | ||||
|     Name: 'ShowAppsIcon', | ||||
|     Extends: DashItemContainer, | ||||
|  | ||||
| @@ -315,7 +315,7 @@ const ShowAppsIcon = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const DragPlaceholderItem = new Lang.Class({ | ||||
| var DragPlaceholderItem = new Lang.Class({ | ||||
|     Name: 'DragPlaceholderItem', | ||||
|     Extends: DashItemContainer, | ||||
|  | ||||
| @@ -325,7 +325,7 @@ const DragPlaceholderItem = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const EmptyDropTargetItem = new Lang.Class({ | ||||
| var EmptyDropTargetItem = new Lang.Class({ | ||||
|     Name: 'EmptyDropTargetItem', | ||||
|     Extends: DashItemContainer, | ||||
|  | ||||
| @@ -335,7 +335,7 @@ const EmptyDropTargetItem = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const DashActor = new Lang.Class({ | ||||
| var DashActor = new Lang.Class({ | ||||
|     Name: 'DashActor', | ||||
|     Extends: St.Widget, | ||||
|  | ||||
| @@ -387,7 +387,7 @@ const DashActor = new Lang.Class({ | ||||
|  | ||||
| const baseIconSizes = [ 16, 22, 24, 32, 48, 64 ]; | ||||
|  | ||||
| const Dash = new Lang.Class({ | ||||
| var Dash = new Lang.Class({ | ||||
|     Name: 'Dash', | ||||
|  | ||||
|     _init : function() { | ||||
| @@ -756,42 +756,44 @@ const Dash = new Lang.Class({ | ||||
|         let newIndex = 0; | ||||
|         let oldIndex = 0; | ||||
|         while (newIndex < newApps.length || oldIndex < oldApps.length) { | ||||
|             let oldApp = oldApps.length > oldIndex ? oldApps[oldIndex] : null; | ||||
|             let newApp = newApps.length > newIndex ? newApps[newIndex] : null; | ||||
|  | ||||
|             // No change at oldIndex/newIndex | ||||
|             if (oldApps[oldIndex] == newApps[newIndex]) { | ||||
|             if (oldApp == newApp) { | ||||
|                 oldIndex++; | ||||
|                 newIndex++; | ||||
|                 continue; | ||||
|             } | ||||
|  | ||||
|             // App removed at oldIndex | ||||
|             if (oldApps[oldIndex] && | ||||
|                 newApps.indexOf(oldApps[oldIndex]) == -1) { | ||||
|             if (oldApp && newApps.indexOf(oldApp) == -1) { | ||||
|                 removedActors.push(children[oldIndex]); | ||||
|                 oldIndex++; | ||||
|                 continue; | ||||
|             } | ||||
|  | ||||
|             // App added at newIndex | ||||
|             if (newApps[newIndex] && | ||||
|                 oldApps.indexOf(newApps[newIndex]) == -1) { | ||||
|                 addedItems.push({ app: newApps[newIndex], | ||||
|                                   item: this._createAppItem(newApps[newIndex]), | ||||
|             if (newApp && oldApps.indexOf(newApp) == -1) { | ||||
|                 addedItems.push({ app: newApp, | ||||
|                                   item: this._createAppItem(newApp), | ||||
|                                   pos: newIndex }); | ||||
|                 newIndex++; | ||||
|                 continue; | ||||
|             } | ||||
|  | ||||
|             // App moved | ||||
|             let insertHere = newApps[newIndex + 1] && | ||||
|                              newApps[newIndex + 1] == oldApps[oldIndex]; | ||||
|             let nextApp = newApps.length > newIndex + 1 ? newApps[newIndex + 1] | ||||
|                                                         : null; | ||||
|             let insertHere = nextApp && nextApp == oldApp; | ||||
|             let alreadyRemoved = removedActors.reduce(function(result, actor) { | ||||
|                 let removedApp = actor.child._delegate.app; | ||||
|                 return result || removedApp == newApps[newIndex]; | ||||
|                 return result || removedApp == newApp; | ||||
|             }, false); | ||||
|  | ||||
|             if (insertHere || alreadyRemoved) { | ||||
|                 let newItem = this._createAppItem(newApps[newIndex]); | ||||
|                 addedItems.push({ app: newApps[newIndex], | ||||
|                 let newItem = this._createAppItem(newApp); | ||||
|                 addedItems.push({ app: newApp, | ||||
|                                   item: newItem, | ||||
|                                   pos: newIndex + removedActors.length }); | ||||
|                 newIndex++; | ||||
|   | ||||
| @@ -30,7 +30,7 @@ function _isToday(date) { | ||||
|            now.getDate() == date.getDate(); | ||||
| } | ||||
|  | ||||
| const TodayButton = new Lang.Class({ | ||||
| var TodayButton = new Lang.Class({ | ||||
|     Name: 'TodayButton', | ||||
|  | ||||
|     _init: function(calendar) { | ||||
| @@ -84,7 +84,7 @@ const TodayButton = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const WorldClocksSection = new Lang.Class({ | ||||
| var WorldClocksSection = new Lang.Class({ | ||||
|     Name: 'WorldClocksSection', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -194,7 +194,7 @@ const WorldClocksSection = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const WeatherSection = new Lang.Class({ | ||||
| var WeatherSection = new Lang.Class({ | ||||
|     Name: 'WeatherSection', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -324,7 +324,7 @@ const WeatherSection = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const MessagesIndicator = new Lang.Class({ | ||||
| var MessagesIndicator = new Lang.Class({ | ||||
|     Name: 'MessagesIndicator', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -364,14 +364,13 @@ const MessagesIndicator = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const IndicatorPad = new Lang.Class({ | ||||
| var IndicatorPad = new Lang.Class({ | ||||
|     Name: 'IndicatorPad', | ||||
|     Extends: St.Widget, | ||||
|  | ||||
|     _init: function(actor) { | ||||
|         this._source = actor; | ||||
|         this._source.connect('notify::visible', | ||||
|                              Lang.bind(this, this.queue_relayout)); | ||||
|         this._source.connect('notify::visible', () => { this.queue_relayout(); }); | ||||
|         this.parent(); | ||||
|     }, | ||||
|  | ||||
| @@ -388,7 +387,7 @@ const IndicatorPad = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const FreezableBinLayout = new Lang.Class({ | ||||
| var FreezableBinLayout = new Lang.Class({ | ||||
|     Name: 'FreezableBinLayout', | ||||
|     Extends: Clutter.BinLayout, | ||||
|  | ||||
| @@ -430,7 +429,7 @@ const FreezableBinLayout = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const CalendarColumnLayout = new Lang.Class({ | ||||
| var CalendarColumnLayout = new Lang.Class({ | ||||
|     Name: 'CalendarColumnLayout', | ||||
|     Extends: Clutter.BoxLayout, | ||||
|  | ||||
| @@ -446,7 +445,7 @@ const CalendarColumnLayout = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const DateMenuButton = new Lang.Class({ | ||||
| var DateMenuButton = new Lang.Class({ | ||||
|     Name: 'DateMenuButton', | ||||
|     Extends: PanelMenu.Button, | ||||
|  | ||||
| @@ -475,6 +474,8 @@ const DateMenuButton = new Lang.Class({ | ||||
|  | ||||
|         let layout = new FreezableBinLayout(); | ||||
|         let bin = new St.Widget({ layout_manager: layout }); | ||||
|         // For some minimal compatibility with PopupMenuItem | ||||
|         bin._delegate = this; | ||||
|         this.menu.box.add_child(bin); | ||||
|  | ||||
|         hbox = new St.BoxLayout({ name: 'calendarArea' }); | ||||
|   | ||||
							
								
								
									
										231
									
								
								js/ui/dialog.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										231
									
								
								js/ui/dialog.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,231 @@ | ||||
| // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | ||||
|  | ||||
| const Clutter = imports.gi.Clutter; | ||||
| const Gio = imports.gi.Gio; | ||||
| const GObject = imports.gi.GObject; | ||||
| const Pango = imports.gi.Pango; | ||||
| const St = imports.gi.St; | ||||
| const Lang = imports.lang; | ||||
|  | ||||
| var Dialog = new Lang.Class({ | ||||
|     Name: 'Dialog', | ||||
|     Extends: St.Widget, | ||||
|  | ||||
|     _init: function (parentActor, styleClass) { | ||||
|         this.parent({ layout_manager: new Clutter.BinLayout() }); | ||||
|         this.connect('destroy', Lang.bind(this, this._onDestroy)); | ||||
|  | ||||
|         this._pressedKey = null; | ||||
|         this._buttonKeys = {}; | ||||
|         this._createDialog(); | ||||
|         this.add_child(this._dialog); | ||||
|  | ||||
|         if (styleClass != null) | ||||
|             this._dialog.add_style_class_name(styleClass); | ||||
|  | ||||
|         this._parentActor = parentActor; | ||||
|         this._eventId = this._parentActor.connect('event', Lang.bind(this, this._modalEventHandler)); | ||||
|         this._parentActor.add_child(this); | ||||
|     }, | ||||
|  | ||||
|     _createDialog: function () { | ||||
|         this._dialog = new St.BoxLayout({ style_class: 'modal-dialog', | ||||
|                                           x_align:     Clutter.ActorAlign.CENTER, | ||||
|                                           y_align:     Clutter.ActorAlign.CENTER, | ||||
|                                           vertical:    true }); | ||||
|  | ||||
|         // modal dialogs are fixed width and grow vertically; set the request | ||||
|         // mode accordingly so wrapped labels are handled correctly during | ||||
|         // size requests. | ||||
|         this._dialog.request_mode = Clutter.RequestMode.HEIGHT_FOR_WIDTH; | ||||
|  | ||||
|         this.contentLayout = new St.BoxLayout({ vertical: true, | ||||
|                                                 style_class: "modal-dialog-content-box" }); | ||||
|         this._dialog.add(this.contentLayout, | ||||
|                          { expand:  true, | ||||
|                            x_fill:  true, | ||||
|                            y_fill:  true, | ||||
|                            x_align: St.Align.MIDDLE, | ||||
|                            y_align: St.Align.START }); | ||||
|  | ||||
|         this.buttonLayout = new St.Widget ({ layout_manager: new Clutter.BoxLayout({ homogeneous:true }) }); | ||||
|         this._dialog.add(this.buttonLayout, | ||||
|                          { x_align: St.Align.MIDDLE, | ||||
|                            y_align: St.Align.START }); | ||||
|     }, | ||||
|  | ||||
|     _onDestroy: function () { | ||||
|         if (this._eventId != 0) | ||||
|             this._parentActor.disconnect(this._eventId); | ||||
|         this._eventId = 0; | ||||
|     }, | ||||
|  | ||||
|     _modalEventHandler: function (actor, event) { | ||||
|         if (event.type() == Clutter.EventType.KEY_PRESS) { | ||||
|             this._pressedKey = event.get_key_symbol(); | ||||
|         } else if (event.type() == Clutter.EventType.KEY_RELEASE) { | ||||
|             let pressedKey = this._pressedKey; | ||||
|             this._pressedKey = null; | ||||
|  | ||||
|             let symbol = event.get_key_symbol(); | ||||
|             if (symbol != pressedKey) | ||||
|                 return Clutter.EVENT_PROPAGATE; | ||||
|  | ||||
|             let buttonInfo = this._buttonKeys[symbol]; | ||||
|             if (!buttonInfo) | ||||
|                 return Clutter.EVENT_PROPAGATE; | ||||
|  | ||||
|             let { button, action } = buttonInfo; | ||||
|  | ||||
|             if (action && button.reactive) { | ||||
|                 action(); | ||||
|                 return Clutter.EVENT_STOP; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return Clutter.EVENT_PROPAGATE; | ||||
|     }, | ||||
|  | ||||
|     addContent: function (actor) { | ||||
|         this.contentLayout.add (actor, { expand: true }); | ||||
|     }, | ||||
|  | ||||
|     addButton: function (buttonInfo) { | ||||
|         let { label, action, key } = buttonInfo; | ||||
|         let isDefault = buttonInfo['default']; | ||||
|         let keys; | ||||
|  | ||||
|         if (key) | ||||
|             keys = [key]; | ||||
|         else if (isDefault) | ||||
|             keys = [Clutter.KEY_Return, Clutter.KEY_KP_Enter, Clutter.KEY_ISO_Enter]; | ||||
|         else | ||||
|             keys = []; | ||||
|  | ||||
|         let button = new St.Button({ style_class: 'modal-dialog-linked-button', | ||||
|                                      button_mask: St.ButtonMask.ONE | St.ButtonMask.THREE, | ||||
|                                      reactive:    true, | ||||
|                                      can_focus:   true, | ||||
|                                      x_expand:    true, | ||||
|                                      y_expand:    true, | ||||
|                                      label:       label }); | ||||
|         button.connect('clicked', action); | ||||
|  | ||||
|         buttonInfo['button'] = button; | ||||
|  | ||||
|         if (isDefault) | ||||
|             button.add_style_pseudo_class('default'); | ||||
|  | ||||
|         if (!this._initialKeyFocusDestroyId) | ||||
|             this._initialKeyFocus = button; | ||||
|  | ||||
|         for (let i in keys) | ||||
|             this._buttonKeys[keys[i]] = buttonInfo; | ||||
|  | ||||
|         this.buttonLayout.add_actor(button); | ||||
|  | ||||
|         return button; | ||||
|     }, | ||||
|  | ||||
|     clearButtons: function () { | ||||
|         this.buttonLayout.destroy_all_children(); | ||||
|         this._buttonKeys = {}; | ||||
|     }, | ||||
| }); | ||||
|  | ||||
| var MessageDialogContent = new Lang.Class({ | ||||
|     Name: 'MessageDialogContent', | ||||
|     Extends: St.BoxLayout, | ||||
|     Properties: { | ||||
|         'icon': GObject.ParamSpec.object('icon', 'icon', 'icon', | ||||
|                                          GObject.ParamFlags.READWRITE | | ||||
|                                          GObject.ParamFlags.CONSTRUCT, | ||||
|                                          Gio.Icon.$gtype), | ||||
|         'title': GObject.ParamSpec.string('title', 'title', 'title', | ||||
|                                           GObject.ParamFlags.READWRITE | | ||||
|                                           GObject.ParamFlags.CONSTRUCT, | ||||
|                                           null), | ||||
|         'subtitle': GObject.ParamSpec.string('subtitle', 'subtitle', 'subtitle', | ||||
|                                              GObject.ParamFlags.READWRITE | | ||||
|                                              GObject.ParamFlags.CONSTRUCT, | ||||
|                                              null), | ||||
|         'body': GObject.ParamSpec.string('body', 'body', 'body', | ||||
|                                          GObject.ParamFlags.READWRITE | | ||||
|                                          GObject.ParamFlags.CONSTRUCT, | ||||
|                                          null) | ||||
|     }, | ||||
|  | ||||
|     _init: function(params) { | ||||
|         this._icon = new St.Icon({ y_align: Clutter.ActorAlign.START }); | ||||
|         this._title = new St.Label({ style_class: 'headline' }); | ||||
|         this._subtitle = new St.Label(); | ||||
|         this._body = new St.Label(); | ||||
|  | ||||
|         ['icon', 'title', 'subtitle', 'body'].forEach(prop => { | ||||
|             this[`_${prop}`].add_style_class_name(`message-dialog-${prop}`); | ||||
|         }); | ||||
|  | ||||
|         let textProps = { ellipsize_mode: Pango.EllipsizeMode.NONE, | ||||
|                           line_wrap: true }; | ||||
|         Object.assign(this._subtitle.clutter_text, textProps); | ||||
|         Object.assign(this._body.clutter_text, textProps); | ||||
|  | ||||
|         if (!params.hasOwnProperty('style_class')) | ||||
|             params.style_class = 'message-dialog-main-layout'; | ||||
|  | ||||
|         this.parent(params); | ||||
|  | ||||
|         this.messageBox = new St.BoxLayout({ style_class: 'message-dialog-content', | ||||
|                                              x_expand: true, | ||||
|                                              vertical: true }); | ||||
|  | ||||
|         this.messageBox.add_actor(this._title); | ||||
|         this.messageBox.add_actor(this._subtitle); | ||||
|         this.messageBox.add_actor(this._body); | ||||
|  | ||||
|         this.add_actor(this._icon); | ||||
|         this.add_actor(this.messageBox); | ||||
|     }, | ||||
|  | ||||
|     get icon() { | ||||
|         return this._icon.gicon; | ||||
|     }, | ||||
|  | ||||
|     get title() { | ||||
|         return this._title.text; | ||||
|     }, | ||||
|  | ||||
|     get subtitle() { | ||||
|         return this._subtitle.text; | ||||
|     }, | ||||
|  | ||||
|     get body() { | ||||
|         return this._body.text; | ||||
|     }, | ||||
|  | ||||
|     set icon(icon) { | ||||
|         Object.assign(this._icon, { gicon: icon, visible: icon != null }); | ||||
|         this.notify('icon'); | ||||
|     }, | ||||
|  | ||||
|     set title(title) { | ||||
|         this._setLabel(this._title, 'title', title); | ||||
|     }, | ||||
|  | ||||
|     set subtitle(subtitle) { | ||||
|         this._setLabel(this._subtitle, 'subtitle', subtitle); | ||||
|     }, | ||||
|  | ||||
|     set body(body) { | ||||
|         this._setLabel(this._body, 'body', body); | ||||
|     }, | ||||
|  | ||||
|     _setLabel(label, prop, value) { | ||||
|         Object.assign(label, { text: value || '', visible: value != null }); | ||||
|         this.notify(prop); | ||||
|     }, | ||||
|  | ||||
|     insertBeforeBody: function(actor) { | ||||
|         this.messageBox.insert_child_below(actor, this._body); | ||||
|     } | ||||
| }); | ||||
							
								
								
									
										14
									
								
								js/ui/dnd.js
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								js/ui/dnd.js
									
									
									
									
									
								
							| @@ -14,26 +14,26 @@ const Main = imports.ui.main; | ||||
| const Params = imports.misc.params; | ||||
|  | ||||
| // Time to scale down to maxDragActorSize | ||||
| const SCALE_ANIMATION_TIME = 0.25; | ||||
| var SCALE_ANIMATION_TIME = 0.25; | ||||
| // Time to animate to original position on cancel | ||||
| const SNAP_BACK_ANIMATION_TIME = 0.25; | ||||
| var SNAP_BACK_ANIMATION_TIME = 0.25; | ||||
| // Time to animate to original position on success | ||||
| const REVERT_ANIMATION_TIME = 0.75; | ||||
| var REVERT_ANIMATION_TIME = 0.75; | ||||
|  | ||||
| const DragMotionResult = { | ||||
| var DragMotionResult = { | ||||
|     NO_DROP:   0, | ||||
|     COPY_DROP: 1, | ||||
|     MOVE_DROP: 2, | ||||
|     CONTINUE:  3 | ||||
| }; | ||||
|  | ||||
| const DRAG_CURSOR_MAP = { | ||||
| var DRAG_CURSOR_MAP = { | ||||
|     0: Meta.Cursor.DND_UNSUPPORTED_TARGET, | ||||
|     1: Meta.Cursor.DND_COPY, | ||||
|     2: Meta.Cursor.DND_MOVE | ||||
| }; | ||||
|  | ||||
| const DragDropResult = { | ||||
| var DragDropResult = { | ||||
|     FAILURE:  0, | ||||
|     SUCCESS:  1, | ||||
|     CONTINUE: 2 | ||||
| @@ -69,7 +69,7 @@ function removeDragMonitor(monitor) { | ||||
|         } | ||||
| } | ||||
|  | ||||
| const _Draggable = new Lang.Class({ | ||||
| var _Draggable = new Lang.Class({ | ||||
|     Name: 'Draggable', | ||||
|  | ||||
|     _init : function(actor, params) { | ||||
|   | ||||
| @@ -8,10 +8,10 @@ const St = imports.gi.St; | ||||
|  | ||||
| const Main = imports.ui.main; | ||||
|  | ||||
| const EDGE_THRESHOLD = 20; | ||||
| const DRAG_DISTANCE = 80; | ||||
| var EDGE_THRESHOLD = 20; | ||||
| var DRAG_DISTANCE = 80; | ||||
|  | ||||
| const EdgeDragAction = new Lang.Class({ | ||||
| var EdgeDragAction = new Lang.Class({ | ||||
|     Name: 'EdgeDragAction', | ||||
|     Extends: Clutter.GestureAction, | ||||
|     Signals: { 'activated': {} }, | ||||
|   | ||||
| @@ -41,7 +41,7 @@ let _endSessionDialog = null; | ||||
| const _ITEM_ICON_SIZE = 48; | ||||
| const _DIALOG_ICON_SIZE = 48; | ||||
|  | ||||
| const GSM_SESSION_MANAGER_LOGOUT_FORCE = 2; | ||||
| var GSM_SESSION_MANAGER_LOGOUT_FORCE = 2; | ||||
|  | ||||
| const EndSessionDialogIface = '<node> \ | ||||
| <interface name="org.gnome.SessionManager.EndSessionDialog"> \ | ||||
| @@ -166,7 +166,7 @@ const DialogContent = { | ||||
|     4 /* DialogType.UPGRADE_RESTART */: restartUpgradeDialogContent | ||||
| }; | ||||
|  | ||||
| const MAX_USERS_IN_SESSION_DIALOG = 5; | ||||
| var MAX_USERS_IN_SESSION_DIALOG = 5; | ||||
|  | ||||
| const LogindSessionIface = '<node> \ | ||||
| <interface name="org.freedesktop.login1.Session"> \ | ||||
| @@ -275,7 +275,7 @@ function init() { | ||||
|     _endSessionDialog = new EndSessionDialog(); | ||||
| } | ||||
|  | ||||
| const EndSessionDialog = new Lang.Class({ | ||||
| var EndSessionDialog = new Lang.Class({ | ||||
|     Name: 'EndSessionDialog', | ||||
|     Extends: ModalDialog.ModalDialog, | ||||
|  | ||||
|   | ||||
| @@ -10,7 +10,7 @@ imports.gi.versions.Gtk = '3.0'; | ||||
| imports.gi.versions.TelepathyGLib = '0.12'; | ||||
| imports.gi.versions.TelepathyLogger = '0.2'; | ||||
|  | ||||
| const Clutter = imports.gi.Clutter;; | ||||
| const Clutter = imports.gi.Clutter; | ||||
| const Gettext = imports.gettext; | ||||
| const GLib = imports.gi.GLib; | ||||
| const Gtk = imports.gi.Gtk; | ||||
|   | ||||
| @@ -17,10 +17,10 @@ const ModalDialog = imports.ui.modalDialog; | ||||
|  | ||||
| const _signals = ExtensionSystem._signals; | ||||
|  | ||||
| const REPOSITORY_URL_BASE = 'https://extensions.gnome.org'; | ||||
| const REPOSITORY_URL_DOWNLOAD = REPOSITORY_URL_BASE + '/download-extension/%s.shell-extension.zip'; | ||||
| const REPOSITORY_URL_INFO     = REPOSITORY_URL_BASE + '/extension-info/'; | ||||
| const REPOSITORY_URL_UPDATE   = REPOSITORY_URL_BASE + '/update-info/'; | ||||
| var REPOSITORY_URL_BASE = 'https://extensions.gnome.org'; | ||||
| var REPOSITORY_URL_DOWNLOAD = REPOSITORY_URL_BASE + '/download-extension/%s.shell-extension.zip'; | ||||
| var REPOSITORY_URL_INFO     = REPOSITORY_URL_BASE + '/extension-info/'; | ||||
| var REPOSITORY_URL_UPDATE   = REPOSITORY_URL_BASE + '/update-info/'; | ||||
|  | ||||
| let _httpSession; | ||||
|  | ||||
| @@ -130,12 +130,14 @@ function updateExtension(uuid) { | ||||
|             FileUtils.recursivelyMoveDir(extensionDir, oldExtensionTmpDir); | ||||
|             FileUtils.recursivelyMoveDir(newExtensionTmpDir, extensionDir); | ||||
|  | ||||
|             let extension = ExtensionUtils.createExtensionObject(uuid, extensionDir, ExtensionUtils.ExtensionType.PER_USER); | ||||
|             let extension = null; | ||||
|  | ||||
|             try { | ||||
|                 extension = ExtensionUtils.createExtensionObject(uuid, extensionDir, ExtensionUtils.ExtensionType.PER_USER); | ||||
|                 ExtensionSystem.loadExtension(extension); | ||||
|             } catch(e) { | ||||
|                 ExtensionSystem.unloadExtension(extension); | ||||
|                 if (extension) | ||||
|                     ExtensionSystem.unloadExtension(extension); | ||||
|  | ||||
|                 logError(e, 'Error loading extension %s'.format(uuid)); | ||||
|  | ||||
| @@ -181,7 +183,7 @@ function checkForUpdates() { | ||||
|     }); | ||||
| } | ||||
|  | ||||
| const InstallExtensionDialog = new Lang.Class({ | ||||
| var InstallExtensionDialog = new Lang.Class({ | ||||
|     Name: 'InstallExtensionDialog', | ||||
|     Extends: ModalDialog.ModalDialog, | ||||
|  | ||||
| @@ -203,7 +205,7 @@ const InstallExtensionDialog = new Lang.Class({ | ||||
|  | ||||
|         let message = _("Download and install “%s” from extensions.gnome.org?").format(info.name); | ||||
|  | ||||
|         let box = new St.BoxLayout({ style_class: 'prompt-dialog-main-layout', | ||||
|         let box = new St.BoxLayout({ style_class: 'message-dialog-main-layout', | ||||
|                                      vertical: false }); | ||||
|         this.contentLayout.add(box); | ||||
|  | ||||
| @@ -211,7 +213,7 @@ const InstallExtensionDialog = new Lang.Class({ | ||||
|         let icon = new St.Icon({ gicon: gicon }); | ||||
|         box.add(icon); | ||||
|  | ||||
|         let label = new St.Label({ style_class: 'prompt-dialog-headline headline', | ||||
|         let label = new St.Label({ style_class: 'message-dialog-title headline', | ||||
|                                    text: message }); | ||||
|         box.add(label); | ||||
|     }, | ||||
| @@ -242,9 +244,8 @@ const InstallExtensionDialog = new Lang.Class({ | ||||
|                 global.settings.set_strv(ExtensionSystem.ENABLED_EXTENSIONS_KEY, enabledExtensions); | ||||
|             } | ||||
|  | ||||
|             let extension = ExtensionUtils.createExtensionObject(uuid, dir, ExtensionUtils.ExtensionType.PER_USER); | ||||
|  | ||||
|             try { | ||||
|                 let extension = ExtensionUtils.createExtensionObject(uuid, dir, ExtensionUtils.ExtensionType.PER_USER); | ||||
|                 ExtensionSystem.loadExtension(extension); | ||||
|             } catch(e) { | ||||
|                 uninstallExtension(uuid); | ||||
|   | ||||
| @@ -10,7 +10,7 @@ const St = imports.gi.St; | ||||
| const ExtensionUtils = imports.misc.extensionUtils; | ||||
| const Main = imports.ui.main; | ||||
|  | ||||
| const ExtensionState = { | ||||
| var ExtensionState = { | ||||
|     ENABLED: 1, | ||||
|     DISABLED: 2, | ||||
|     ERROR: 3, | ||||
| @@ -26,7 +26,7 @@ const ExtensionState = { | ||||
| // Arrays of uuids | ||||
| var enabledExtensions; | ||||
| // Contains the order that extensions were enabled in. | ||||
| const extensionOrder = []; | ||||
| var extensionOrder = []; | ||||
|  | ||||
| // We don't really have a class to add signals on. So, create | ||||
| // a simple dummy object, add the signal methods, and export those | ||||
| @@ -34,8 +34,8 @@ const extensionOrder = []; | ||||
| var _signals = {}; | ||||
| Signals.addSignalMethods(_signals); | ||||
|  | ||||
| const connect = Lang.bind(_signals, _signals.connect); | ||||
| const disconnect = Lang.bind(_signals, _signals.disconnect); | ||||
| var connect = Lang.bind(_signals, _signals.connect); | ||||
| var disconnect = Lang.bind(_signals, _signals.disconnect); | ||||
|  | ||||
| const ENABLED_EXTENSIONS_KEY = 'enabled-extensions'; | ||||
| const DISABLE_USER_EXTENSIONS_KEY = 'disable-user-extensions'; | ||||
| @@ -199,7 +199,14 @@ function reloadExtension(oldExtension) { | ||||
|     unloadExtension(oldExtension); | ||||
|  | ||||
|     // Now, recreate the extension and load it. | ||||
|     let newExtension = ExtensionUtils.createExtensionObject(uuid, dir, type); | ||||
|     let newExtension; | ||||
|     try { | ||||
|         newExtension = ExtensionUtils.createExtensionObject(uuid, dir, type); | ||||
|     } catch(e) { | ||||
|         logExtensionError(uuid, e); | ||||
|         return; | ||||
|     } | ||||
|  | ||||
|     loadExtension(newExtension); | ||||
| } | ||||
|  | ||||
| @@ -211,14 +218,21 @@ function initExtension(uuid) { | ||||
|         throw new Error("Extension was not properly created. Call loadExtension first"); | ||||
|  | ||||
|     let extensionJs = dir.get_child('extension.js'); | ||||
|     if (!extensionJs.query_exists(null)) | ||||
|         throw new Error('Missing extension.js'); | ||||
|     if (!extensionJs.query_exists(null)) { | ||||
|         logExtensionError(uuid, new Error('Missing extension.js')); | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     let extensionModule; | ||||
|     let extensionState = null; | ||||
|  | ||||
|     ExtensionUtils.installImporter(extension); | ||||
|     extensionModule = extension.imports.extension; | ||||
|     try { | ||||
|         extensionModule = extension.imports.extension; | ||||
|     } catch(e) { | ||||
|         logExtensionError(uuid, e); | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     if (extensionModule.init) { | ||||
|         try { | ||||
| @@ -282,20 +296,12 @@ function _onVersionValidationChanged() { | ||||
|     // temporarily disable them all | ||||
|     enabledExtensions = []; | ||||
|     for (let uuid in ExtensionUtils.extensions) | ||||
|         try { | ||||
|             reloadExtension(ExtensionUtils.extensions[uuid]); | ||||
|         } catch(e) { | ||||
|             logExtensionError(uuid, e); | ||||
|         } | ||||
|         reloadExtension(ExtensionUtils.extensions[uuid]); | ||||
|     enabledExtensions = getEnabledExtensions(); | ||||
|  | ||||
|     if (Main.sessionMode.allowExtensions) { | ||||
|         enabledExtensions.forEach(function(uuid) { | ||||
|             try { | ||||
|                 enableExtension(uuid); | ||||
|             } catch(e) { | ||||
|                 logExtensionError(uuid, e); | ||||
|             } | ||||
|             enableExtension(uuid); | ||||
|         }); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -28,7 +28,7 @@ const Signals = imports.signals; | ||||
| const CARETMOVED        = 'object:text-caret-moved'; | ||||
| const STATECHANGED      = 'object:state-changed'; | ||||
|  | ||||
| const FocusCaretTracker = new Lang.Class({ | ||||
| var FocusCaretTracker = new Lang.Class({ | ||||
|     Name: 'FocusCaretTracker', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -47,30 +47,27 @@ const FocusCaretTracker = new Lang.Class({ | ||||
|     }, | ||||
|  | ||||
|     _initAtspi: function() { | ||||
|         if (!this._atspiInited) { | ||||
|             Atspi.init(); | ||||
|         if (!this._atspiInited && Atspi.init() == 0) { | ||||
|             Atspi.set_timeout(250, 250); | ||||
|             this._atspiInited = true; | ||||
|         } | ||||
|  | ||||
| 	return this._atspiInited; | ||||
|     }, | ||||
|  | ||||
|     registerFocusListener: function() { | ||||
|         if (this._focusListenerRegistered) | ||||
|         if (!this._initAtspi() || this._focusListenerRegistered) | ||||
|             return; | ||||
|  | ||||
|         this._initAtspi(); | ||||
|  | ||||
|         this._atspiListener.register(STATECHANGED + ':focused'); | ||||
|         this._atspiListener.register(STATECHANGED + ':selected'); | ||||
|         this._focusListenerRegistered = true; | ||||
|     }, | ||||
|  | ||||
|     registerCaretListener: function() { | ||||
|         if (this._caretListenerRegistered) | ||||
|         if (!this._initAtspi() || this._caretListenerRegistered) | ||||
|             return; | ||||
|  | ||||
|         this._initAtspi(); | ||||
|  | ||||
|         this._atspiListener.register(CARETMOVED); | ||||
|         this._caretListenerRegistered = true; | ||||
|     }, | ||||
|   | ||||
| @@ -46,7 +46,7 @@ function _popGrabHelper(grabHelper) { | ||||
| // your code just needs to deal with it; you shouldn't adjust behavior directly | ||||
| // after you call ungrab(), but instead pass an 'onUngrab' callback when you | ||||
| // call grab(). | ||||
| const GrabHelper = new Lang.Class({ | ||||
| var GrabHelper = new Lang.Class({ | ||||
|     Name: 'GrabHelper', | ||||
|  | ||||
|     _init: function(owner, params) { | ||||
|   | ||||
| @@ -9,12 +9,12 @@ const St = imports.gi.St; | ||||
| const BoxPointer = imports.ui.boxpointer; | ||||
| const Main = imports.ui.main; | ||||
|  | ||||
| const MAX_CANDIDATES_PER_PAGE = 16; | ||||
| var MAX_CANDIDATES_PER_PAGE = 16; | ||||
|  | ||||
| const DEFAULT_INDEX_LABELS = [ '1', '2', '3', '4', '5', '6', '7', '8', | ||||
|                                '9', '0', 'a', 'b', 'c', 'd', 'e', 'f' ]; | ||||
| var DEFAULT_INDEX_LABELS = [ '1', '2', '3', '4', '5', '6', '7', '8', | ||||
|                              '9', '0', 'a', 'b', 'c', 'd', 'e', 'f' ]; | ||||
|  | ||||
| const CandidateArea = new Lang.Class({ | ||||
| var CandidateArea = new Lang.Class({ | ||||
|     Name: 'CandidateArea', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -128,7 +128,7 @@ const CandidateArea = new Lang.Class({ | ||||
| }); | ||||
| Signals.addSignalMethods(CandidateArea.prototype); | ||||
|  | ||||
| const CandidatePopup = new Lang.Class({ | ||||
| var CandidatePopup = new Lang.Class({ | ||||
|     Name: 'CandidatePopup', | ||||
|  | ||||
|     _init: function() { | ||||
|   | ||||
| @@ -12,29 +12,29 @@ const Params = imports.misc.params; | ||||
| const Tweener = imports.ui.tweener; | ||||
| const Main = imports.ui.main; | ||||
|  | ||||
| const ICON_SIZE = 96; | ||||
| const MIN_ICON_SIZE = 16; | ||||
| var ICON_SIZE = 96; | ||||
| var MIN_ICON_SIZE = 16; | ||||
|  | ||||
| const EXTRA_SPACE_ANIMATION_TIME = 0.25; | ||||
| var EXTRA_SPACE_ANIMATION_TIME = 0.25; | ||||
|  | ||||
| const ANIMATION_TIME_IN = 0.350; | ||||
| const ANIMATION_TIME_OUT = 1/2 * ANIMATION_TIME_IN; | ||||
| const ANIMATION_MAX_DELAY_FOR_ITEM = 2/3 * ANIMATION_TIME_IN; | ||||
| const ANIMATION_BASE_DELAY_FOR_ITEM = 1/4 * ANIMATION_MAX_DELAY_FOR_ITEM; | ||||
| const ANIMATION_MAX_DELAY_OUT_FOR_ITEM = 2/3 * ANIMATION_TIME_OUT; | ||||
| const ANIMATION_FADE_IN_TIME_FOR_ITEM = 1/4 * ANIMATION_TIME_IN; | ||||
| var ANIMATION_TIME_IN = 0.350; | ||||
| var ANIMATION_TIME_OUT = 1/2 * ANIMATION_TIME_IN; | ||||
| var ANIMATION_MAX_DELAY_FOR_ITEM = 2/3 * ANIMATION_TIME_IN; | ||||
| var ANIMATION_BASE_DELAY_FOR_ITEM = 1/4 * ANIMATION_MAX_DELAY_FOR_ITEM; | ||||
| var ANIMATION_MAX_DELAY_OUT_FOR_ITEM = 2/3 * ANIMATION_TIME_OUT; | ||||
| var ANIMATION_FADE_IN_TIME_FOR_ITEM = 1/4 * ANIMATION_TIME_IN; | ||||
|  | ||||
| const ANIMATION_BOUNCE_ICON_SCALE = 1.1; | ||||
| var ANIMATION_BOUNCE_ICON_SCALE = 1.1; | ||||
|  | ||||
| const AnimationDirection = { | ||||
| var AnimationDirection = { | ||||
|     IN: 0, | ||||
|     OUT: 1 | ||||
| }; | ||||
|  | ||||
| const APPICON_ANIMATION_OUT_SCALE = 3; | ||||
| const APPICON_ANIMATION_OUT_TIME = 0.25; | ||||
| var APPICON_ANIMATION_OUT_SCALE = 3; | ||||
| var APPICON_ANIMATION_OUT_TIME = 0.25; | ||||
|  | ||||
| const BaseIcon = new Lang.Class({ | ||||
| var BaseIcon = new Lang.Class({ | ||||
|     Name: 'BaseIcon', | ||||
|  | ||||
|     _init : function(label, params) { | ||||
| @@ -240,7 +240,7 @@ function zoomOutActor(actor) { | ||||
|                     }); | ||||
| } | ||||
|  | ||||
| const IconGrid = new Lang.Class({ | ||||
| var IconGrid = new Lang.Class({ | ||||
|     Name: 'IconGrid', | ||||
|  | ||||
|     _init: function(params) { | ||||
| @@ -267,6 +267,7 @@ const IconGrid = new Lang.Class({ | ||||
|         this.actor = new St.BoxLayout({ style_class: 'icon-grid', | ||||
|                                         vertical: true }); | ||||
|         this._items = []; | ||||
|         this._clonesAnimating = []; | ||||
|         // Pulled from CSS, but hardcode some defaults here | ||||
|         this._spacing = 0; | ||||
|         this._hItemSize = this._vItemSize = ICON_SIZE; | ||||
| @@ -275,6 +276,13 @@ const IconGrid = new Lang.Class({ | ||||
|         this.actor.add(this._grid, { expand: true, y_align: St.Align.START }); | ||||
|         this.actor.connect('style-changed', Lang.bind(this, this._onStyleChanged)); | ||||
|  | ||||
|         // Cancel animations when hiding the overview, to avoid icons | ||||
|         // swarming into the void ... | ||||
|         this.actor.connect('notify::mapped', () => { | ||||
|             if (!this.actor.mapped) | ||||
|                 this._cancelAnimation(); | ||||
|         }); | ||||
|  | ||||
|         this._grid.connect('get-preferred-width', Lang.bind(this, this._getPreferredWidth)); | ||||
|         this._grid.connect('get-preferred-height', Lang.bind(this, this._getPreferredHeight)); | ||||
|         this._grid.connect('allocate', Lang.bind(this, this._allocate)); | ||||
| @@ -410,8 +418,13 @@ const IconGrid = new Lang.Class({ | ||||
|         return this._getVisibleChildren(); | ||||
|     }, | ||||
|  | ||||
|     _cancelAnimation: function() { | ||||
|         this._clonesAnimating.forEach(clone => { clone.destroy(); }); | ||||
|         this._clonesAnimating = []; | ||||
|     }, | ||||
|  | ||||
|     _animationDone: function() { | ||||
|         this._animating = false; | ||||
|         this._clonesAnimating = []; | ||||
|         this.emit('animation-done'); | ||||
|     }, | ||||
|  | ||||
| @@ -419,10 +432,7 @@ const IconGrid = new Lang.Class({ | ||||
|         if (animationDirection != AnimationDirection.IN) | ||||
|             throw new Error("Pulse animation only implements 'in' animation direction"); | ||||
|  | ||||
|         if (this._animating) | ||||
|             return; | ||||
|  | ||||
|         this._animating = true; | ||||
|         this._cancelAnimation(); | ||||
|  | ||||
|         let actors = this._getChildrenToAnimate(); | ||||
|         if (actors.length == 0) { | ||||
| @@ -470,10 +480,7 @@ const IconGrid = new Lang.Class({ | ||||
|     }, | ||||
|  | ||||
|     animateSpring: function(animationDirection, sourceActor) { | ||||
|         if (this._animating) | ||||
|             return; | ||||
|  | ||||
|         this._animating = true; | ||||
|         this._cancelAnimation(); | ||||
|  | ||||
|         let actors = this._getChildrenToAnimate(); | ||||
|         if (actors.length == 0) { | ||||
| @@ -507,6 +514,7 @@ const IconGrid = new Lang.Class({ | ||||
|             actor.reactive = false; | ||||
|  | ||||
|             let actorClone = new Clutter.Clone({ source: actor }); | ||||
|             this._clonesAnimating.push(actorClone); | ||||
|             Main.uiGroup.add_actor(actorClone); | ||||
|  | ||||
|             let [width, height,,] = this._getAllocatedChildSizeAndSpacing(actor); | ||||
| @@ -790,7 +798,7 @@ const IconGrid = new Lang.Class({ | ||||
| }); | ||||
| Signals.addSignalMethods(IconGrid.prototype); | ||||
|  | ||||
| const PaginatedIconGrid = new Lang.Class({ | ||||
| var PaginatedIconGrid = new Lang.Class({ | ||||
|     Name: 'PaginatedIconGrid', | ||||
|     Extends: IconGrid, | ||||
|  | ||||
|   | ||||
| @@ -1,5 +1,7 @@ | ||||
| // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | ||||
|  | ||||
| const FocusCaretTracker = imports.ui.focusCaretTracker; | ||||
| const Atspi = imports.gi.Atspi; | ||||
| const Caribou = imports.gi.Caribou; | ||||
| const Clutter = imports.gi.Clutter; | ||||
| const Gdk = imports.gi.Gdk; | ||||
| @@ -17,7 +19,7 @@ const Layout = imports.ui.layout; | ||||
| const Main = imports.ui.main; | ||||
| const MessageTray = imports.ui.messageTray; | ||||
|  | ||||
| const KEYBOARD_REST_TIME = Layout.KEYBOARD_ANIMATION_TIME * 2 * 1000; | ||||
| var KEYBOARD_REST_TIME = Layout.KEYBOARD_ANIMATION_TIME * 2 * 1000; | ||||
|  | ||||
| const KEYBOARD_SCHEMA = 'org.gnome.shell.keyboard'; | ||||
| const KEYBOARD_TYPE = 'keyboard-type'; | ||||
| @@ -25,43 +27,7 @@ const KEYBOARD_TYPE = 'keyboard-type'; | ||||
| const A11Y_APPLICATIONS_SCHEMA = 'org.gnome.desktop.a11y.applications'; | ||||
| const SHOW_KEYBOARD = 'screen-keyboard-enabled'; | ||||
|  | ||||
| const CARIBOU_BUS_NAME = 'org.gnome.Caribou.Daemon'; | ||||
| const CARIBOU_OBJECT_PATH = '/org/gnome/Caribou/Daemon'; | ||||
|  | ||||
| const CaribouKeyboardIface = '<node> \ | ||||
| <interface name="org.gnome.Caribou.Keyboard"> \ | ||||
| <method name="Show"> \ | ||||
|     <arg type="u" direction="in" /> \ | ||||
| </method> \ | ||||
| <method name="Hide"> \ | ||||
|     <arg type="u" direction="in" /> \ | ||||
| </method> \ | ||||
| <method name="SetCursorLocation"> \ | ||||
|     <arg type="i" direction="in" /> \ | ||||
|     <arg type="i" direction="in" /> \ | ||||
|     <arg type="i" direction="in" /> \ | ||||
|     <arg type="i" direction="in" /> \ | ||||
| </method> \ | ||||
| <method name="SetEntryLocation"> \ | ||||
|     <arg type="i" direction="in" /> \ | ||||
|     <arg type="i" direction="in" /> \ | ||||
|     <arg type="i" direction="in" /> \ | ||||
|     <arg type="i" direction="in" /> \ | ||||
| </method> \ | ||||
| <property name="Name" access="read" type="s" /> \ | ||||
| </interface> \ | ||||
| </node>'; | ||||
|  | ||||
| const CaribouDaemonIface = '<node> \ | ||||
| <interface name="org.gnome.Caribou.Daemon"> \ | ||||
| <method name="Run" /> \ | ||||
| <method name="Quit" /> \ | ||||
| </interface> \ | ||||
| </node>'; | ||||
|  | ||||
| const CaribouDaemonProxy = Gio.DBusProxy.makeProxyWrapper(CaribouDaemonIface); | ||||
|  | ||||
| const Key = new Lang.Class({ | ||||
| var Key = new Lang.Class({ | ||||
|     Name: 'Key', | ||||
|  | ||||
|     _init : function(key) { | ||||
| @@ -187,30 +153,28 @@ const Key = new Lang.Class({ | ||||
| }); | ||||
| Signals.addSignalMethods(Key.prototype); | ||||
|  | ||||
| const Keyboard = new Lang.Class({ | ||||
|     // HACK: we can't set Name, because it collides with Name dbus property | ||||
|     // Name: 'Keyboard', | ||||
| var Keyboard = new Lang.Class({ | ||||
|     Name: 'Keyboard', | ||||
|  | ||||
|     _init: function () { | ||||
|         this._impl = Gio.DBusExportedObject.wrapJSObject(CaribouKeyboardIface, this); | ||||
|         this._impl.export(Gio.DBus.session, '/org/gnome/Caribou/Keyboard'); | ||||
|  | ||||
|         this.actor = null; | ||||
|         this._focusInTray = false; | ||||
|         this._focusInExtendedKeys = false; | ||||
|  | ||||
|         this._timestamp = global.display.get_current_time_roundtrip(); | ||||
|         this._focusCaretTracker = new FocusCaretTracker.FocusCaretTracker(); | ||||
|         this._focusCaretTracker.connect('focus-changed', Lang.bind(this, this._onFocusChanged)); | ||||
|         this._focusCaretTracker.connect('caret-moved', Lang.bind(this, this._onCaretMoved)); | ||||
|         this._currentAccessible = null; | ||||
|         this._caretTrackingEnabled = false; | ||||
|         this._updateCaretPositionId = 0; | ||||
|  | ||||
|         this._keyboardSettings = new Gio.Settings({ schema_id: KEYBOARD_SCHEMA }); | ||||
|         this._keyboardSettings.connect('changed', Lang.bind(this, this._sync)); | ||||
|         this._a11yApplicationsSettings = new Gio.Settings({ schema_id: A11Y_APPLICATIONS_SCHEMA }); | ||||
|         this._a11yApplicationsSettings.connect('changed', Lang.bind(this, this._sync)); | ||||
|         this._daemonProxy = null; | ||||
|         this._a11yApplicationsSettings.connect('changed', Lang.bind(this, this._syncEnabled)); | ||||
|         this._lastDeviceId = null; | ||||
|  | ||||
|         if (Meta.is_wayland_compositor() && | ||||
|             Caribou.DisplayAdapter.set_default) | ||||
|             Caribou.DisplayAdapter.set_default(new ShellWaylandAdapter()); | ||||
|         Caribou.DisplayAdapter.set_default(new LocalAdapter()); | ||||
|  | ||||
|         Meta.get_backend().connect('last-device-changed', Lang.bind(this, | ||||
|             function (backend, deviceId) { | ||||
| @@ -219,7 +183,7 @@ const Keyboard = new Lang.Class({ | ||||
|  | ||||
|                 if (device.get_device_name().indexOf('XTEST') < 0) { | ||||
|                     this._lastDeviceId = deviceId; | ||||
|                     this._sync(); | ||||
|                     this._syncEnabled(); | ||||
|                 } | ||||
|             })); | ||||
|         this._sync(); | ||||
| @@ -240,6 +204,93 @@ const Keyboard = new Lang.Class({ | ||||
|         this._redraw(); | ||||
|     }, | ||||
|  | ||||
|     _setCaretTrackerEnabled: function (enabled) { | ||||
|         if (this._caretTrackingEnabled == enabled) | ||||
|             return; | ||||
|  | ||||
|         this._caretTrackingEnabled = enabled; | ||||
|  | ||||
|         if (enabled) { | ||||
|             this._focusCaretTracker.registerFocusListener(); | ||||
|             this._focusCaretTracker.registerCaretListener(); | ||||
|         } else { | ||||
|             this._focusCaretTracker.deregisterFocusListener(); | ||||
|             this._focusCaretTracker.deregisterCaretListener(); | ||||
|         } | ||||
|     }, | ||||
|  | ||||
|     _updateCaretPosition: function (accessible) { | ||||
|         if (this._updateCaretPositionId) | ||||
|             GLib.source_remove(this._updateCaretPositionId); | ||||
|         this._updateCaretPositionId = GLib.idle_add(GLib.PRIORITY_DEFAULT_IDLE, Lang.bind(this, function() { | ||||
|             this._updateCaretPositionId = 0; | ||||
|  | ||||
|             let currentWindow = global.screen.get_display().focus_window; | ||||
|             if (!currentWindow) | ||||
|                 return GLib.SOURCE_REMOVE; | ||||
|  | ||||
|             let windowRect = currentWindow.get_frame_rect(); | ||||
|             let text = accessible.get_text_iface(); | ||||
|             let component = accessible.get_component_iface(); | ||||
|  | ||||
|             try { | ||||
|                 let caretOffset = text.get_caret_offset(); | ||||
|                 let caretRect = text.get_character_extents(caretOffset, Atspi.CoordType.WINDOW); | ||||
|                 let focusRect = component.get_extents(Atspi.CoordType.WINDOW); | ||||
|  | ||||
|                 caretRect.x += windowRect.x; | ||||
|                 caretRect.y += windowRect.y; | ||||
|                 focusRect.x += windowRect.x; | ||||
|                 focusRect.y += windowRect.y; | ||||
|  | ||||
|                 if (caretRect.width == 0 && caretRect.height == 0) | ||||
|                     caretRect = focusRect; | ||||
|  | ||||
|                 this.setEntryLocation(focusRect.x, focusRect.y, focusRect.width, focusRect.height); | ||||
|                 this.setCursorLocation(caretRect.x, caretRect.y, caretRect.width, caretRect.height); | ||||
|             } catch (e) { | ||||
|                 log('Error updating caret position for OSK: ' + e.message); | ||||
|             } | ||||
|  | ||||
|             return GLib.SOURCE_REMOVE; | ||||
|         })); | ||||
|  | ||||
|         GLib.Source.set_name_by_id(this._updateCaretPositionId, '[gnome-shell] this._updateCaretPosition'); | ||||
|     }, | ||||
|  | ||||
|     _focusIsTextEntry: function (accessible) { | ||||
|         try { | ||||
|             let role = accessible.get_role(); | ||||
|             let stateSet = accessible.get_state_set(); | ||||
|             return stateSet.contains(Atspi.StateType.EDITABLE) || role == Atspi.Role.TERMINAL; | ||||
|         } catch (e) { | ||||
|             log('Error determining accessible role: ' + e.message); | ||||
|             return false; | ||||
|         } | ||||
|     }, | ||||
|  | ||||
|     _onFocusChanged: function (caretTracker, event) { | ||||
|         let accessible = event.source; | ||||
|         if (!this._focusIsTextEntry(accessible)) | ||||
|             return; | ||||
|  | ||||
|         let focused = event.detail1 != 0; | ||||
|         if (focused) { | ||||
|             this._currentAccessible = accessible; | ||||
|             this._updateCaretPosition(accessible); | ||||
|             this.show(Main.layoutManager.focusIndex); | ||||
|         } else if (this._currentAccessible == accessible) { | ||||
|             this._currentAccessible = null; | ||||
|             this.hide(); | ||||
|         } | ||||
|     }, | ||||
|  | ||||
|     _onCaretMoved: function (caretTracker, event) { | ||||
|         let accessible = event.source; | ||||
|         if (this._currentAccessible == accessible) | ||||
|             this._updateCaretPosition(accessible); | ||||
|     }, | ||||
|  | ||||
|     _lastDeviceIsTouchscreen: function () { | ||||
|         if (!this._lastDeviceId) | ||||
|             return false; | ||||
| @@ -253,22 +304,32 @@ const Keyboard = new Lang.Class({ | ||||
|         return device.get_device_type() == Clutter.InputDeviceType.TOUCHSCREEN_DEVICE; | ||||
|     }, | ||||
|  | ||||
|     _sync: function () { | ||||
|     _syncEnabled: function () { | ||||
|         this._enableKeyboard = this._a11yApplicationsSettings.get_boolean(SHOW_KEYBOARD) || | ||||
|                                this._lastDeviceIsTouchscreen(); | ||||
|         if (!this._enableKeyboard && !this._keyboard) | ||||
|             return; | ||||
|         if (this._enableKeyboard && this._keyboard && | ||||
|             this._keyboard.keyboard_type == this._keyboardSettings.get_string(KEYBOARD_TYPE)) | ||||
|             return; | ||||
|  | ||||
|         if (this._keyboard) | ||||
|             this._destroyKeyboard(); | ||||
|         this._setCaretTrackerEnabled(this._enableKeyboard); | ||||
|  | ||||
|         if (this._enableKeyboard) | ||||
|             this._setupKeyboard(); | ||||
|         else | ||||
|         if (this._enableKeyboard) { | ||||
|             if (!this._keyboard) | ||||
|                 this._setupKeyboard(); | ||||
|             else | ||||
|                 Main.layoutManager.showKeyboard(); | ||||
|         } else { | ||||
|             Main.layoutManager.hideKeyboard(true); | ||||
|         } | ||||
|     }, | ||||
|  | ||||
|     _sync: function () { | ||||
|         if (this._keyboard && | ||||
|             this._keyboard.keyboard_type != this._keyboardSettings.get_string(KEYBOARD_TYPE)) { | ||||
|             this._destroyKeyboard(); | ||||
|             this._setupKeyboard(); | ||||
|         } | ||||
|  | ||||
|         this._syncEnabled(); | ||||
|     }, | ||||
|  | ||||
|     _destroyKeyboard: function() { | ||||
| @@ -285,35 +346,9 @@ const Keyboard = new Lang.Class({ | ||||
|         this.actor = null; | ||||
|  | ||||
|         this._destroySource(); | ||||
|         if (this._daemonProxy) { | ||||
|             this._daemonProxy.QuitRemote(function (result, error) { | ||||
|                 if (error) { | ||||
|                     log(error.message); | ||||
|                     return; | ||||
|                 } | ||||
|             }); | ||||
|             this._daemonProxy = null; | ||||
|         } | ||||
|     }, | ||||
|  | ||||
|     _setupKeyboard: function() { | ||||
|         if (!this._daemonProxy) { | ||||
|             this._daemonProxy = new CaribouDaemonProxy(Gio.DBus.session, CARIBOU_BUS_NAME, | ||||
|                                                        CARIBOU_OBJECT_PATH, | ||||
|                                                        Lang.bind(this, function(proxy, error) { | ||||
|                                                            if (error) { | ||||
|                                                                log(error.message); | ||||
|                                                                return; | ||||
|                                                            } | ||||
|                                                        })); | ||||
|         } | ||||
|         this._daemonProxy.RunRemote(function (result, error) { | ||||
|             if (error) { | ||||
|                 log(error.message); | ||||
|                 return; | ||||
|             } | ||||
|         }); | ||||
|  | ||||
|         this.actor = new St.BoxLayout({ name: 'keyboard', vertical: true, reactive: true }); | ||||
|         Main.layoutManager.keyboardBox.add_actor(this.actor); | ||||
|         Main.layoutManager.trackChrome(this.actor); | ||||
| @@ -359,17 +394,17 @@ const Keyboard = new Lang.Class({ | ||||
|  | ||||
|         let time = global.get_current_time(); | ||||
|         if (!(focus instanceof Clutter.Text)) { | ||||
|             this.Hide(time); | ||||
|             this.hide(); | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         if (!this._showIdleId) { | ||||
|           this._showIdleId = GLib.idle_add(GLib.PRIORITY_DEFAULT_IDLE, | ||||
|                                            Lang.bind(this, function() { | ||||
|                                                this.Show(time); | ||||
|                                                this.show(Main.layoutManager.focusIndex); | ||||
|                                                return GLib.SOURCE_REMOVE; | ||||
|                                            })); | ||||
|           GLib.Source.set_name_by_id(this._showIdleId, '[gnome-shell] this.Show'); | ||||
|           GLib.Source.set_name_by_id(this._showIdleId, '[gnome-shell] this.show'); | ||||
|         } | ||||
|     }, | ||||
|  | ||||
| @@ -570,7 +605,7 @@ const Keyboard = new Lang.Class({ | ||||
|     shouldTakeEvent: function(event) { | ||||
|         let actor = event.get_source(); | ||||
|         return Main.layoutManager.keyboardBox.contains(actor) || | ||||
|                actor._extended_keys || actor.extended_key; | ||||
|                !!actor._extended_keys || !!actor.extended_key; | ||||
|     }, | ||||
|  | ||||
|     _clearKeyboardRestTimer: function() { | ||||
| @@ -581,6 +616,10 @@ const Keyboard = new Lang.Class({ | ||||
|     }, | ||||
|  | ||||
|     show: function (monitor) { | ||||
|         if (!this._enableKeyboard) | ||||
|             return; | ||||
|  | ||||
|         this._clearShowIdle(); | ||||
|         this._keyboardRequested = true; | ||||
|  | ||||
|         if (this._keyboardVisible) { | ||||
| @@ -613,6 +652,10 @@ const Keyboard = new Lang.Class({ | ||||
|     }, | ||||
|  | ||||
|     hide: function () { | ||||
|         if (!this._enableKeyboard) | ||||
|             return; | ||||
|  | ||||
|         this._clearShowIdle(); | ||||
|         this._keyboardRequested = false; | ||||
|  | ||||
|         if (!this._keyboardVisible) | ||||
| @@ -664,20 +707,6 @@ const Keyboard = new Lang.Class({ | ||||
|             this._moveTemporarily(); | ||||
|     }, | ||||
|  | ||||
|     // _compareTimestamp: | ||||
|     // | ||||
|     // Compare two timestamps taking into account | ||||
|     // CURRENT_TIME (0) | ||||
|     _compareTimestamp: function(one, two) { | ||||
|         if (one == two) | ||||
|             return 0; | ||||
|         if (one == Clutter.CURRENT_TIME) | ||||
|             return 1; | ||||
|         if (two == Clutter.CURRENT_TIME) | ||||
|             return -1; | ||||
|         return one - two; | ||||
|     }, | ||||
|  | ||||
|     _clearShowIdle: function() { | ||||
|         if (!this._showIdleId) | ||||
|             return; | ||||
| @@ -685,55 +714,22 @@ const Keyboard = new Lang.Class({ | ||||
|         this._showIdleId = 0; | ||||
|     }, | ||||
|  | ||||
|     // D-Bus methods | ||||
|     Show: function(timestamp) { | ||||
|         if (!this._enableKeyboard) | ||||
|             return; | ||||
|  | ||||
|         if (this._compareTimestamp(timestamp, this._timestamp) < 0) | ||||
|             return; | ||||
|  | ||||
|         this._clearShowIdle(); | ||||
|  | ||||
|         if (timestamp != Clutter.CURRENT_TIME) | ||||
|             this._timestamp = timestamp; | ||||
|         this.show(Main.layoutManager.focusIndex); | ||||
|     }, | ||||
|  | ||||
|     Hide: function(timestamp) { | ||||
|         if (!this._enableKeyboard) | ||||
|             return; | ||||
|  | ||||
|         if (this._compareTimestamp(timestamp, this._timestamp) < 0) | ||||
|             return; | ||||
|  | ||||
|         this._clearShowIdle(); | ||||
|  | ||||
|         if (timestamp != Clutter.CURRENT_TIME) | ||||
|             this._timestamp = timestamp; | ||||
|         this.hide(); | ||||
|     }, | ||||
|  | ||||
|     SetCursorLocation: function(x, y, w, h) { | ||||
|     setCursorLocation: function(x, y, w, h) { | ||||
|         if (!this._enableKeyboard) | ||||
|             return; | ||||
|  | ||||
| //        this._setLocation(x, y); | ||||
|     }, | ||||
|  | ||||
|     SetEntryLocation: function(x, y, w, h) { | ||||
|     setEntryLocation: function(x, y, w, h) { | ||||
|         if (!this._enableKeyboard) | ||||
|             return; | ||||
|  | ||||
| //        this._setLocation(x, y); | ||||
|     }, | ||||
|  | ||||
|     get Name() { | ||||
|         return 'gnome-shell'; | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const KeyboardSource = new Lang.Class({ | ||||
| var KeyboardSource = new Lang.Class({ | ||||
|     Name: 'KeyboardSource', | ||||
|     Extends: MessageTray.Source, | ||||
|  | ||||
| @@ -754,8 +750,8 @@ const KeyboardSource = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const ShellWaylandAdapter = new Lang.Class({ | ||||
|     Name: 'ShellWaylandAdapter', | ||||
| var LocalAdapter = new Lang.Class({ | ||||
|     Name: 'LocalAdapter', | ||||
|     Extends: Caribou.XAdapter, | ||||
|  | ||||
|     _init: function () { | ||||
|   | ||||
| @@ -18,12 +18,12 @@ const Main = imports.ui.main; | ||||
| const Params = imports.misc.params; | ||||
| const Tweener = imports.ui.tweener; | ||||
|  | ||||
| const STARTUP_ANIMATION_TIME = 0.5; | ||||
| const KEYBOARD_ANIMATION_TIME = 0.15; | ||||
| const BACKGROUND_FADE_ANIMATION_TIME = 1.0; | ||||
| var STARTUP_ANIMATION_TIME = 0.5; | ||||
| var KEYBOARD_ANIMATION_TIME = 0.15; | ||||
| var BACKGROUND_FADE_ANIMATION_TIME = 1.0; | ||||
|  | ||||
| const HOT_CORNER_PRESSURE_THRESHOLD = 100; // pixels | ||||
| const HOT_CORNER_PRESSURE_TIMEOUT = 1000; // ms | ||||
| var HOT_CORNER_PRESSURE_THRESHOLD = 100; // pixels | ||||
| var HOT_CORNER_PRESSURE_TIMEOUT = 1000; // ms | ||||
|  | ||||
| function isPopupMetaWindow(actor) { | ||||
|     switch(actor.meta_window.get_window_type()) { | ||||
| @@ -36,7 +36,7 @@ function isPopupMetaWindow(actor) { | ||||
|     } | ||||
| } | ||||
|  | ||||
| const MonitorConstraint = new Lang.Class({ | ||||
| var MonitorConstraint = new Lang.Class({ | ||||
|     Name: 'MonitorConstraint', | ||||
|     Extends: Clutter.Constraint, | ||||
|     Properties: {'primary': GObject.ParamSpec.boolean('primary',  | ||||
| @@ -147,7 +147,7 @@ const MonitorConstraint = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const Monitor = new Lang.Class({ | ||||
| var Monitor = new Lang.Class({ | ||||
|     Name: 'Monitor', | ||||
|  | ||||
|     _init: function(index, geometry) { | ||||
| @@ -169,7 +169,7 @@ const defaultParams = { | ||||
|     affectsInputRegion: true | ||||
| }; | ||||
|  | ||||
| const LayoutManager = new Lang.Class({ | ||||
| var LayoutManager = new Lang.Class({ | ||||
|     Name: 'LayoutManager', | ||||
|  | ||||
|     _init: function () { | ||||
| @@ -769,8 +769,7 @@ const LayoutManager = new Lang.Class({ | ||||
|     // @actor: a descendant of the chrome to begin tracking | ||||
|     // @params: parameters describing how to track @actor | ||||
|     // | ||||
|     // Tells the chrome to track @actor, which must be a descendant | ||||
|     // of an actor added via addChrome(). This can be used to extend the | ||||
|     // Tells the chrome to track @actor. This can be used to extend the | ||||
|     // struts or input region to cover specific children. | ||||
|     // | ||||
|     // @params can have any of the same values as in addChrome(), | ||||
| @@ -783,10 +782,9 @@ const LayoutManager = new Lang.Class({ | ||||
|             ancestor = ancestor.get_parent(); | ||||
|             index = this._findActor(ancestor); | ||||
|         } | ||||
|         if (!ancestor) | ||||
|             throw new Error('actor is not a descendent of a chrome actor'); | ||||
|  | ||||
|         let ancestorData = this._trackedActors[index]; | ||||
|         let ancestorData = ancestor ? this._trackedActors[index] | ||||
|                                     : defaultParams; | ||||
|         if (!params) | ||||
|             params = {}; | ||||
|         // We can't use Params.parse here because we want to drop | ||||
| @@ -896,7 +894,10 @@ const LayoutManager = new Lang.Class({ | ||||
|     }, | ||||
|  | ||||
|     findMonitorForActor: function(actor) { | ||||
|         return this.monitors[this.findIndexForActor(actor)]; | ||||
|         let index = this.findIndexForActor(actor); | ||||
|         if (index >= 0 && index < this.monitors.length) | ||||
|             return this.monitors[index]; | ||||
|         return null; | ||||
|     }, | ||||
|  | ||||
|     _queueUpdateRegions: function() { | ||||
| @@ -966,7 +967,11 @@ const LayoutManager = new Lang.Class({ | ||||
|             if (actorData.affectsInputRegion && wantsInputRegion && actorData.actor.get_paint_visibility()) | ||||
|                 rects.push(new Meta.Rectangle({ x: x, y: y, width: w, height: h })); | ||||
|  | ||||
|             if (actorData.affectsStruts) { | ||||
|             let monitor = null; | ||||
|             if (actorData.affectsStruts) | ||||
|                 monitor = this.findMonitorForActor(actorData.actor); | ||||
|  | ||||
|             if (monitor) { | ||||
|                 // Limit struts to the size of the screen | ||||
|                 let x1 = Math.max(x, 0); | ||||
|                 let x2 = Math.min(x + w, global.screen_width); | ||||
| @@ -983,7 +988,6 @@ const LayoutManager = new Lang.Class({ | ||||
|                 // spans the width/height across the middle of the | ||||
|                 // screen, then we don't create a strut for it at all. | ||||
|  | ||||
|                 let monitor = this.findMonitorForActor(actorData.actor); | ||||
|                 let side; | ||||
|                 if (x1 <= monitor.x && x2 >= monitor.x + monitor.width) { | ||||
|                     if (y1 <= monitor.y) | ||||
| @@ -1041,7 +1045,7 @@ Signals.addSignalMethods(LayoutManager.prototype); | ||||
| // | ||||
| // This class manages a "hot corner" that can toggle switching to | ||||
| // overview. | ||||
| const HotCorner = new Lang.Class({ | ||||
| var HotCorner = new Lang.Class({ | ||||
|     Name: 'HotCorner', | ||||
|  | ||||
|     _init : function(layoutManager, monitor, x, y) { | ||||
| @@ -1235,7 +1239,7 @@ const HotCorner = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const PressureBarrier = new Lang.Class({ | ||||
| var PressureBarrier = new Lang.Class({ | ||||
|     Name: 'PressureBarrier', | ||||
|  | ||||
|     _init: function(threshold, timeout, actionMode) { | ||||
|   | ||||
| @@ -13,7 +13,7 @@ const Overview = imports.ui.overview; | ||||
| const OverviewControls = imports.ui.overviewControls; | ||||
| const Tweener = imports.ui.tweener; | ||||
|  | ||||
| const STANDARD_TRAY_ICON_IMPLEMENTATIONS = { | ||||
| var STANDARD_TRAY_ICON_IMPLEMENTATIONS = { | ||||
|     'bluetooth-applet': 'bluetooth', | ||||
|     'gnome-volume-control-applet': 'volume', // renamed to gnome-sound-applet | ||||
|                                              // when moved to control center | ||||
| @@ -29,14 +29,14 @@ const STANDARD_TRAY_ICON_IMPLEMENTATIONS = { | ||||
| }; | ||||
|  | ||||
| // Offset of the original position from the bottom-right corner | ||||
| const CONCEALED_WIDTH = 3; | ||||
| const REVEAL_ANIMATION_TIME = 0.2; | ||||
| const TEMP_REVEAL_TIME = 2; | ||||
| var CONCEALED_WIDTH = 3; | ||||
| var REVEAL_ANIMATION_TIME = 0.2; | ||||
| var TEMP_REVEAL_TIME = 2; | ||||
|  | ||||
| const BARRIER_THRESHOLD = 70; | ||||
| const BARRIER_TIMEOUT = 1000; | ||||
| var BARRIER_THRESHOLD = 70; | ||||
| var BARRIER_TIMEOUT = 1000; | ||||
|  | ||||
| const LegacyTray = new Lang.Class({ | ||||
| var LegacyTray = new Lang.Class({ | ||||
|     Name: 'LegacyTray', | ||||
|  | ||||
|     _init: function() { | ||||
|   | ||||
| @@ -10,9 +10,9 @@ const Shell = imports.gi.Shell; | ||||
| const Params = imports.misc.params; | ||||
| const Tweener = imports.ui.tweener; | ||||
|  | ||||
| const DEFAULT_FADE_FACTOR = 0.4; | ||||
| const VIGNETTE_BRIGHTNESS = 0.8; | ||||
| const VIGNETTE_SHARPNESS = 0.7; | ||||
| var DEFAULT_FADE_FACTOR = 0.4; | ||||
| var VIGNETTE_BRIGHTNESS = 0.8; | ||||
| var VIGNETTE_SHARPNESS = 0.7; | ||||
|  | ||||
| const VIGNETTE_DECLARATIONS = '\ | ||||
| uniform float brightness;\n\ | ||||
| @@ -27,7 +27,7 @@ t = clamp(t, 0.0, 1.0);\n\ | ||||
| float pixel_brightness = mix(1.0, 1.0 - vignette_sharpness, t);\n\ | ||||
| cogl_color_out.a = cogl_color_out.a * (1 - pixel_brightness * brightness);'; | ||||
|  | ||||
| const RadialShaderQuad = new Lang.Class({ | ||||
| var RadialShaderQuad = new Lang.Class({ | ||||
|     Name: 'RadialShaderQuad', | ||||
|     Extends: Shell.GLSLQuad, | ||||
|  | ||||
| @@ -91,7 +91,7 @@ const RadialShaderQuad = new Lang.Class({ | ||||
|  * @container and will track any changes in its size. You can override | ||||
|  * this by passing an explicit width and height in @params. | ||||
|  */ | ||||
| const Lightbox = new Lang.Class({ | ||||
| var Lightbox = new Lang.Class({ | ||||
|     Name: 'Lightbox', | ||||
|  | ||||
|     _init : function(container, params) { | ||||
|   | ||||
| @@ -46,9 +46,9 @@ var commandHeader = 'const Clutter = imports.gi.Clutter; ' + | ||||
|  | ||||
| const HISTORY_KEY = 'looking-glass-history'; | ||||
| // Time between tabs for them to count as a double-tab event | ||||
| const AUTO_COMPLETE_DOUBLE_TAB_DELAY = 500; | ||||
| const AUTO_COMPLETE_SHOW_COMPLETION_ANIMATION_DURATION = 0.2; | ||||
| const AUTO_COMPLETE_GLOBAL_KEYWORDS = _getAutoCompleteGlobalKeywords(); | ||||
| var AUTO_COMPLETE_DOUBLE_TAB_DELAY = 500; | ||||
| var AUTO_COMPLETE_SHOW_COMPLETION_ANIMATION_DURATION = 0.2; | ||||
| var AUTO_COMPLETE_GLOBAL_KEYWORDS = _getAutoCompleteGlobalKeywords(); | ||||
|  | ||||
| function _getAutoCompleteGlobalKeywords() { | ||||
|     const keywords = ['true', 'false', 'null', 'new']; | ||||
| @@ -59,7 +59,7 @@ function _getAutoCompleteGlobalKeywords() { | ||||
|     return keywords.concat(windowProperties).concat(headerProperties); | ||||
| } | ||||
|  | ||||
| const AutoComplete = new Lang.Class({ | ||||
| var AutoComplete = new Lang.Class({ | ||||
|     Name: 'AutoComplete', | ||||
|  | ||||
|     _init: function(entry) { | ||||
| @@ -125,7 +125,7 @@ const AutoComplete = new Lang.Class({ | ||||
| Signals.addSignalMethods(AutoComplete.prototype); | ||||
|  | ||||
|  | ||||
| const Notebook = new Lang.Class({ | ||||
| var Notebook = new Lang.Class({ | ||||
|     Name: 'Notebook', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -263,7 +263,7 @@ function objectToString(o) { | ||||
|     } | ||||
| } | ||||
|  | ||||
| const ObjLink = new Lang.Class({ | ||||
| var ObjLink = new Lang.Class({ | ||||
|     Name: 'ObjLink', | ||||
|  | ||||
|     _init: function(lookingGlass, o, title) { | ||||
| @@ -290,7 +290,7 @@ const ObjLink = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const Result = new Lang.Class({ | ||||
| var Result = new Lang.Class({ | ||||
|     Name: 'Result', | ||||
|  | ||||
|     _init: function(lookingGlass, command, o, index) { | ||||
| @@ -313,7 +313,7 @@ const Result = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const WindowList = new Lang.Class({ | ||||
| var WindowList = new Lang.Class({ | ||||
|     Name: 'WindowList', | ||||
|  | ||||
|     _init: function(lookingGlass) { | ||||
| @@ -361,7 +361,7 @@ const WindowList = new Lang.Class({ | ||||
| }); | ||||
| Signals.addSignalMethods(WindowList.prototype); | ||||
|  | ||||
| const ObjInspector = new Lang.Class({ | ||||
| var ObjInspector = new Lang.Class({ | ||||
|     Name: 'ObjInspector', | ||||
|  | ||||
|     _init: function(lookingGlass) { | ||||
| @@ -471,7 +471,7 @@ const ObjInspector = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const RedBorderEffect = new Lang.Class({ | ||||
| var RedBorderEffect = new Lang.Class({ | ||||
|     Name: 'RedBorderEffect', | ||||
|     Extends: Clutter.Effect, | ||||
|  | ||||
| @@ -497,7 +497,7 @@ const RedBorderEffect = new Lang.Class({ | ||||
|     }, | ||||
| }); | ||||
|  | ||||
| const Inspector = new Lang.Class({ | ||||
| var Inspector = new Lang.Class({ | ||||
|     Name: 'Inspector', | ||||
|  | ||||
|     _init: function(lookingGlass) { | ||||
| @@ -631,7 +631,7 @@ const Inspector = new Lang.Class({ | ||||
|  | ||||
| Signals.addSignalMethods(Inspector.prototype); | ||||
|  | ||||
| const Extensions = new Lang.Class({ | ||||
| var Extensions = new Lang.Class({ | ||||
|     Name: 'Extensions', | ||||
|  | ||||
|     _init: function(lookingGlass) { | ||||
| @@ -774,7 +774,7 @@ const Extensions = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const LookingGlass = new Lang.Class({ | ||||
| var LookingGlass = new Lang.Class({ | ||||
|     Name: 'LookingGlass', | ||||
|  | ||||
|     _init : function() { | ||||
| @@ -783,6 +783,7 @@ const LookingGlass = new Lang.Class({ | ||||
|  | ||||
|         this._open = false; | ||||
|  | ||||
|         this._it = null; | ||||
|         this._offset = 0; | ||||
|         this._results = []; | ||||
|  | ||||
| @@ -833,19 +834,19 @@ const LookingGlass = new Lang.Class({ | ||||
|             return Clutter.EVENT_STOP; | ||||
|         })); | ||||
|  | ||||
|         let gcIcon = new St.Icon({ icon_name: 'gnome-fs-trash-full', | ||||
|         let gcIcon = new St.Icon({ icon_name: 'user-trash-full', | ||||
|                                    icon_size: 24 }); | ||||
|         toolbar.add_actor(gcIcon); | ||||
|         gcIcon.reactive = true; | ||||
|         gcIcon.connect('button-press-event', Lang.bind(this, function () { | ||||
|            gcIcon.icon_name = 'gnome-fs-trash-empty'; | ||||
|            gcIcon.icon_name = 'user-trash'; | ||||
|            System.gc(); | ||||
|            this._timeoutId = Mainloop.timeout_add(500, Lang.bind(this, function () { | ||||
|                 gcIcon.icon_name = 'gnome-fs-trash-full'; | ||||
|                 gcIcon.icon_name = 'user-trash-full'; | ||||
|                 this._timeoutId = 0; | ||||
|                 return GLib.SOURCE_REMOVE; | ||||
|            })); | ||||
|            GLib.Source.set_name_by_id(this._timeoutId, '[gnome-shell] gcIcon.icon_name = \'gnome-fs-trash-full\''); | ||||
|            GLib.Source.set_name_by_id(this._timeoutId, '[gnome-shell] gcIcon.icon_name = \'user-trash-full\''); | ||||
|            return Clutter.EVENT_PROPAGATE; | ||||
|         })); | ||||
|  | ||||
|   | ||||
| @@ -19,11 +19,11 @@ const MagnifierDBus = imports.ui.magnifierDBus; | ||||
| const Params = imports.misc.params; | ||||
| const PointerWatcher = imports.ui.pointerWatcher; | ||||
|  | ||||
| const MOUSE_POLL_FREQUENCY = 50; | ||||
| const CROSSHAIRS_CLIP_SIZE = [100, 100]; | ||||
| const NO_CHANGE = 0.0; | ||||
| var MOUSE_POLL_FREQUENCY = 50; | ||||
| var CROSSHAIRS_CLIP_SIZE = [100, 100]; | ||||
| var NO_CHANGE = 0.0; | ||||
|  | ||||
| const POINTER_REST_TIME = 1000; // milliseconds | ||||
| var POINTER_REST_TIME = 1000; // milliseconds | ||||
|  | ||||
| // Settings | ||||
| const APPLICATIONS_SCHEMA       = 'org.gnome.desktop.a11y.applications'; | ||||
| @@ -54,7 +54,7 @@ const CROSS_HAIRS_CLIP_KEY      = 'cross-hairs-clip'; | ||||
|  | ||||
| let magDBusService = null; | ||||
|  | ||||
| const Magnifier = new Lang.Class({ | ||||
| var Magnifier = new Lang.Class({ | ||||
|     Name: 'Magnifier', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -672,7 +672,7 @@ const Magnifier = new Lang.Class({ | ||||
| }); | ||||
| Signals.addSignalMethods(Magnifier.prototype); | ||||
|  | ||||
| const ZoomRegion = new Lang.Class({ | ||||
| var ZoomRegion = new Lang.Class({ | ||||
|     Name: 'ZoomRegion', | ||||
|  | ||||
|     _init: function(magnifier, mouseSourceActor) { | ||||
| @@ -1536,7 +1536,7 @@ const ZoomRegion = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const Crosshairs = new Lang.Class({ | ||||
| var Crosshairs = new Lang.Class({ | ||||
|     Name: 'Crosshairs', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -1781,7 +1781,7 @@ const Crosshairs = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const MagShaderEffects = new Lang.Class({ | ||||
| var MagShaderEffects = new Lang.Class({ | ||||
|     Name: 'MagShaderEffects', | ||||
|  | ||||
|     _init: function(uiGroupClone) { | ||||
|   | ||||
| @@ -98,7 +98,7 @@ const ZoomRegionIface = '<node> \ | ||||
| // '/org/gnome/Magnifier/ZoomRegion/zoomer1', etc. | ||||
| let _zoomRegionInstanceCount = 0; | ||||
|  | ||||
| const ShellMagnifier = new Lang.Class({ | ||||
| var ShellMagnifier = new Lang.Class({ | ||||
|     Name: 'ShellMagnifier', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -334,7 +334,7 @@ const ShellMagnifier = new Lang.Class({ | ||||
|  * @zoomerObjectPath:   String that is the path to a DBus ZoomRegion. | ||||
|  * @zoomRegion:         The actual zoom region associated with the object path. | ||||
|  */ | ||||
| const ShellMagnifierZoomRegion = new Lang.Class({ | ||||
| var ShellMagnifierZoomRegion = new Lang.Class({ | ||||
|     Name: 'ShellMagnifierZoomRegion', | ||||
|  | ||||
|     _init: function(zoomerObjectPath, zoomRegion) { | ||||
|   | ||||
| @@ -50,36 +50,36 @@ const A11Y_SCHEMA = 'org.gnome.desktop.a11y.keyboard'; | ||||
| const STICKY_KEYS_ENABLE = 'stickykeys-enable'; | ||||
| const GNOMESHELL_STARTED_MESSAGE_ID = 'f3ea493c22934e26811cd62abe8e203a'; | ||||
|  | ||||
| let componentManager = null; | ||||
| let panel = null; | ||||
| let overview = null; | ||||
| let runDialog = null; | ||||
| let lookingGlass = null; | ||||
| let wm = null; | ||||
| let legacyTray = null; | ||||
| let messageTray = null; | ||||
| let screenShield = null; | ||||
| let notificationDaemon = null; | ||||
| let windowAttentionHandler = null; | ||||
| let ctrlAltTabManager = null; | ||||
| let padOsdService = null; | ||||
| let osdWindowManager = null; | ||||
| let osdMonitorLabeler = null; | ||||
| let sessionMode = null; | ||||
| let shellAccessDialogDBusService = null; | ||||
| let shellAudioSelectionDBusService = null; | ||||
| let shellDBusService = null; | ||||
| let shellMountOpDBusService = null; | ||||
| let screenSaverDBus = null; | ||||
| let screencastService = null; | ||||
| let modalCount = 0; | ||||
| let actionMode = Shell.ActionMode.NONE; | ||||
| let modalActorFocusStack = []; | ||||
| let uiGroup = null; | ||||
| let magnifier = null; | ||||
| let xdndHandler = null; | ||||
| let keyboard = null; | ||||
| let layoutManager = null; | ||||
| var componentManager = null; | ||||
| var panel = null; | ||||
| var overview = null; | ||||
| var runDialog = null; | ||||
| var lookingGlass = null; | ||||
| var wm = null; | ||||
| var legacyTray = null; | ||||
| var messageTray = null; | ||||
| var screenShield = null; | ||||
| var notificationDaemon = null; | ||||
| var windowAttentionHandler = null; | ||||
| var ctrlAltTabManager = null; | ||||
| var padOsdService = null; | ||||
| var osdWindowManager = null; | ||||
| var osdMonitorLabeler = null; | ||||
| var sessionMode = null; | ||||
| var shellAccessDialogDBusService = null; | ||||
| var shellAudioSelectionDBusService = null; | ||||
| var shellDBusService = null; | ||||
| var shellMountOpDBusService = null; | ||||
| var screenSaverDBus = null; | ||||
| var screencastService = null; | ||||
| var modalCount = 0; | ||||
| var actionMode = Shell.ActionMode.NONE; | ||||
| var modalActorFocusStack = []; | ||||
| var uiGroup = null; | ||||
| var magnifier = null; | ||||
| var xdndHandler = null; | ||||
| var keyboard = null; | ||||
| var layoutManager = null; | ||||
| let _startDate; | ||||
| let _defaultCssStylesheet = null; | ||||
| let _cssStylesheet = null; | ||||
| @@ -552,7 +552,7 @@ function activateWindow(window, time, workspaceNum) { | ||||
|  | ||||
| // TODO - replace this timeout with some system to guess when the user might | ||||
| // be e.g. just reading the screen and not likely to interact. | ||||
| const DEFERRED_TIMEOUT_SECONDS = 20; | ||||
| var DEFERRED_TIMEOUT_SECONDS = 20; | ||||
| var _deferredWorkData = {}; | ||||
| // Work scheduled for some point in the future | ||||
| var _deferredWorkQueue = []; | ||||
| @@ -669,7 +669,7 @@ function queueDeferredWork(workId) { | ||||
|     } | ||||
| } | ||||
|  | ||||
| const RestartMessage = new Lang.Class({ | ||||
| var RestartMessage = new Lang.Class({ | ||||
|     Name: 'RestartMessage', | ||||
|     Extends: ModalDialog.ModalDialog, | ||||
|  | ||||
|   | ||||
| @@ -15,9 +15,9 @@ const Calendar = imports.ui.calendar; | ||||
| const Tweener = imports.ui.tweener; | ||||
| const Util = imports.misc.util; | ||||
|  | ||||
| const MESSAGE_ANIMATION_TIME = 0.1; | ||||
| var MESSAGE_ANIMATION_TIME = 0.1; | ||||
|  | ||||
| const DEFAULT_EXPAND_LINES = 6; | ||||
| var DEFAULT_EXPAND_LINES = 6; | ||||
|  | ||||
| function _fixMarkup(text, allowMarkup) { | ||||
|     if (allowMarkup) { | ||||
| @@ -39,7 +39,7 @@ function _fixMarkup(text, allowMarkup) { | ||||
|     return GLib.markup_escape_text(text, -1); | ||||
| } | ||||
|  | ||||
| const URLHighlighter = new Lang.Class({ | ||||
| var URLHighlighter = new Lang.Class({ | ||||
|     Name: 'URLHighlighter', | ||||
|  | ||||
|     _init: function(text, lineWrap, allowMarkup) { | ||||
| @@ -161,10 +161,15 @@ const URLHighlighter = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const ScaleLayout = new Lang.Class({ | ||||
| var ScaleLayout = new Lang.Class({ | ||||
|     Name: 'ScaleLayout', | ||||
|     Extends: Clutter.BinLayout, | ||||
|  | ||||
|     _init: function(params) { | ||||
|         this._container = null; | ||||
|         this.parent(params); | ||||
|     }, | ||||
|  | ||||
|     _connectContainer: function(container) { | ||||
|         if (this._container == container) | ||||
|             return; | ||||
| @@ -203,7 +208,7 @@ const ScaleLayout = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const LabelExpanderLayout = new Lang.Class({ | ||||
| var LabelExpanderLayout = new Lang.Class({ | ||||
|     Name: 'LabelExpanderLayout', | ||||
|     Extends: Clutter.LayoutManager, | ||||
|     Properties: { 'expansion': GObject.ParamSpec.double('expansion', | ||||
| @@ -293,12 +298,14 @@ const LabelExpanderLayout = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const Message = new Lang.Class({ | ||||
| var Message = new Lang.Class({ | ||||
|     Name: 'Message', | ||||
|  | ||||
|     _init: function(title, body) { | ||||
|         this.expanded = false; | ||||
|  | ||||
|         this._useBodyMarkup = false; | ||||
|  | ||||
|         this.actor = new St.Button({ style_class: 'message', | ||||
|                                      accessible_role: Atk.Role.NOTIFICATION, | ||||
|                                      can_focus: true, | ||||
| @@ -517,7 +524,7 @@ const Message = new Lang.Class({ | ||||
| }); | ||||
| Signals.addSignalMethods(Message.prototype); | ||||
|  | ||||
| const MessageListSection = new Lang.Class({ | ||||
| var MessageListSection = new Lang.Class({ | ||||
|     Name: 'MessageListSection', | ||||
|  | ||||
|     _init: function() { | ||||
|   | ||||
| @@ -24,23 +24,23 @@ const Util = imports.misc.util; | ||||
|  | ||||
| const SHELL_KEYBINDINGS_SCHEMA = 'org.gnome.shell.keybindings'; | ||||
|  | ||||
| const ANIMATION_TIME = 0.2; | ||||
| const NOTIFICATION_TIMEOUT = 4; | ||||
| var ANIMATION_TIME = 0.2; | ||||
| var NOTIFICATION_TIMEOUT = 4; | ||||
|  | ||||
| const HIDE_TIMEOUT = 0.2; | ||||
| const LONGER_HIDE_TIMEOUT = 0.6; | ||||
| var HIDE_TIMEOUT = 0.2; | ||||
| var LONGER_HIDE_TIMEOUT = 0.6; | ||||
|  | ||||
| const MAX_NOTIFICATIONS_IN_QUEUE = 3; | ||||
| const MAX_NOTIFICATIONS_PER_SOURCE = 3; | ||||
| const MAX_NOTIFICATION_BUTTONS = 3; | ||||
| var MAX_NOTIFICATIONS_IN_QUEUE = 3; | ||||
| var MAX_NOTIFICATIONS_PER_SOURCE = 3; | ||||
| var MAX_NOTIFICATION_BUTTONS = 3; | ||||
|  | ||||
| // We delay hiding of the tray if the mouse is within MOUSE_LEFT_ACTOR_THRESHOLD | ||||
| // range from the point where it left the tray. | ||||
| const MOUSE_LEFT_ACTOR_THRESHOLD = 20; | ||||
| var MOUSE_LEFT_ACTOR_THRESHOLD = 20; | ||||
|  | ||||
| const IDLE_TIME = 1000; | ||||
| var IDLE_TIME = 1000; | ||||
|  | ||||
| const State = { | ||||
| var State = { | ||||
|     HIDDEN:  0, | ||||
|     SHOWING: 1, | ||||
|     SHOWN:   2, | ||||
| @@ -52,7 +52,7 @@ const State = { | ||||
| // and the user did not interact with, DISMISSED for all other notifications | ||||
| // that were destroyed as a result of a user action, and SOURCE_CLOSED for the | ||||
| // notifications that were requested to be destroyed by the associated source. | ||||
| const NotificationDestroyedReason = { | ||||
| var NotificationDestroyedReason = { | ||||
|     EXPIRED: 1, | ||||
|     DISMISSED: 2, | ||||
|     SOURCE_CLOSED: 3 | ||||
| @@ -62,14 +62,14 @@ const NotificationDestroyedReason = { | ||||
| // urgency values map to the corresponding values for the notifications received | ||||
| // through the notification daemon. HIGH urgency value is used for chats received | ||||
| // through the Telepathy client. | ||||
| const Urgency = { | ||||
| var Urgency = { | ||||
|     LOW: 0, | ||||
|     NORMAL: 1, | ||||
|     HIGH: 2, | ||||
|     CRITICAL: 3 | ||||
| }; | ||||
|  | ||||
| const FocusGrabber = new Lang.Class({ | ||||
| var FocusGrabber = new Lang.Class({ | ||||
|     Name: 'FocusGrabber', | ||||
|  | ||||
|     _init: function(actor) { | ||||
| @@ -132,7 +132,7 @@ const FocusGrabber = new Lang.Class({ | ||||
| // source, such as whether to play sound or honour the critical bit. | ||||
| // | ||||
| // A notification without a policy object will inherit the default one. | ||||
| const NotificationPolicy = new Lang.Class({ | ||||
| var NotificationPolicy = new Lang.Class({ | ||||
|     Name: 'NotificationPolicy', | ||||
|  | ||||
|     _init: function(params) { | ||||
| @@ -153,7 +153,7 @@ const NotificationPolicy = new Lang.Class({ | ||||
| }); | ||||
| Signals.addSignalMethods(NotificationPolicy.prototype); | ||||
|  | ||||
| const NotificationGenericPolicy = new Lang.Class({ | ||||
| var NotificationGenericPolicy = new Lang.Class({ | ||||
|     Name: 'NotificationGenericPolicy', | ||||
|     Extends: NotificationPolicy, | ||||
|  | ||||
| @@ -202,7 +202,7 @@ const NotificationGenericPolicy = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const NotificationApplicationPolicy = new Lang.Class({ | ||||
| var NotificationApplicationPolicy = new Lang.Class({ | ||||
|     Name: 'NotificationApplicationPolicy', | ||||
|     Extends: NotificationPolicy, | ||||
|  | ||||
| @@ -328,7 +328,7 @@ const NotificationApplicationPolicy = new Lang.Class({ | ||||
| // If @params contains 'soundName' or 'soundFile', the corresponding | ||||
| // event sound is played when the notification is shown (if the policy for | ||||
| // @source allows playing sounds). | ||||
| const Notification = new Lang.Class({ | ||||
| var Notification = new Lang.Class({ | ||||
|     Name: 'Notification', | ||||
|  | ||||
|     _init: function(source, title, banner, params) { | ||||
| @@ -489,7 +489,7 @@ const Notification = new Lang.Class({ | ||||
| }); | ||||
| Signals.addSignalMethods(Notification.prototype); | ||||
|  | ||||
| const NotificationBanner = new Lang.Class({ | ||||
| var NotificationBanner = new Lang.Class({ | ||||
|     Name: 'NotificationBanner', | ||||
|     Extends: Calendar.NotificationMessage, | ||||
|  | ||||
| @@ -585,7 +585,7 @@ const NotificationBanner = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const SourceActor = new Lang.Class({ | ||||
| var SourceActor = new Lang.Class({ | ||||
|     Name: 'SourceActor', | ||||
|  | ||||
|     _init: function(source, size) { | ||||
| @@ -642,7 +642,7 @@ const SourceActor = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const SourceActorWithLabel = new Lang.Class({ | ||||
| var SourceActorWithLabel = new Lang.Class({ | ||||
|     Name: 'SourceActorWithLabel', | ||||
|     Extends: SourceActor, | ||||
|  | ||||
| @@ -715,7 +715,7 @@ const SourceActorWithLabel = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const Source = new Lang.Class({ | ||||
| var Source = new Lang.Class({ | ||||
|     Name: 'MessageTraySource', | ||||
|  | ||||
|     SOURCE_ICON_SIZE: 48, | ||||
| @@ -840,7 +840,7 @@ const Source = new Lang.Class({ | ||||
| }); | ||||
| Signals.addSignalMethods(Source.prototype); | ||||
|  | ||||
| const MessageTray = new Lang.Class({ | ||||
| var MessageTray = new Lang.Class({ | ||||
|     Name: 'MessageTray', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -1042,7 +1042,7 @@ const MessageTray = new Lang.Class({ | ||||
|     }, | ||||
|  | ||||
|     getSources: function() { | ||||
|         return [k for (k of this._sources.keys())]; | ||||
|         return [...this._sources.keys()]; | ||||
|     }, | ||||
|  | ||||
|     _onSourceEnableChanged: function(policy, source) { | ||||
| @@ -1485,7 +1485,7 @@ const MessageTray = new Lang.Class({ | ||||
| }); | ||||
| Signals.addSignalMethods(MessageTray.prototype); | ||||
|  | ||||
| const SystemNotificationSource = new Lang.Class({ | ||||
| var SystemNotificationSource = new Lang.Class({ | ||||
|     Name: 'SystemNotificationSource', | ||||
|     Extends: Source, | ||||
|  | ||||
|   | ||||
| @@ -14,15 +14,16 @@ const Atk = imports.gi.Atk; | ||||
|  | ||||
| const Params = imports.misc.params; | ||||
|  | ||||
| const Dialog = imports.ui.dialog; | ||||
| const Layout = imports.ui.layout; | ||||
| const Lightbox = imports.ui.lightbox; | ||||
| const Main = imports.ui.main; | ||||
| const Tweener = imports.ui.tweener; | ||||
|  | ||||
| const OPEN_AND_CLOSE_TIME = 0.1; | ||||
| const FADE_OUT_DIALOG_TIME = 1.0; | ||||
| var OPEN_AND_CLOSE_TIME = 0.1; | ||||
| var FADE_OUT_DIALOG_TIME = 1.0; | ||||
|  | ||||
| const State = { | ||||
| var State = { | ||||
|     OPENED: 0, | ||||
|     CLOSED: 1, | ||||
|     OPENING: 2, | ||||
| @@ -30,7 +31,7 @@ const State = { | ||||
|     FADED_OUT: 4 | ||||
| }; | ||||
|  | ||||
| const ModalDialog = new Lang.Class({ | ||||
| var ModalDialog = new Lang.Class({ | ||||
|     Name: 'ModalDialog', | ||||
|  | ||||
|     _init: function(params) { | ||||
| @@ -61,11 +62,6 @@ const ModalDialog = new Lang.Class({ | ||||
|  | ||||
|         this._group.connect('destroy', Lang.bind(this, this._onGroupDestroy)); | ||||
|  | ||||
|         this._pressedKey = null; | ||||
|         this._buttonKeys = {}; | ||||
|         this._group.connect('key-press-event', Lang.bind(this, this._onKeyPressEvent)); | ||||
|         this._group.connect('key-release-event', Lang.bind(this, this._onKeyReleaseEvent)); | ||||
|  | ||||
|         this.backgroundStack = new St.Widget({ layout_manager: new Clutter.BinLayout() }); | ||||
|         this._backgroundBin = new St.Bin({ child: this.backgroundStack, | ||||
|                                            x_fill: true, y_fill: true }); | ||||
| @@ -73,17 +69,9 @@ const ModalDialog = new Lang.Class({ | ||||
|         this._backgroundBin.add_constraint(this._monitorConstraint); | ||||
|         this._group.add_actor(this._backgroundBin); | ||||
|  | ||||
|         this.dialogLayout = new St.BoxLayout({ style_class: 'modal-dialog', | ||||
|                                                x_align:      Clutter.ActorAlign.CENTER, | ||||
|                                                y_align:      Clutter.ActorAlign.CENTER, | ||||
|                                                vertical:     true }); | ||||
|         // modal dialogs are fixed width and grow vertically; set the request | ||||
|         // mode accordingly so wrapped labels are handled correctly during | ||||
|         // size requests. | ||||
|         this.dialogLayout.request_mode = Clutter.RequestMode.HEIGHT_FOR_WIDTH; | ||||
|  | ||||
|         if (params.styleClass != null) | ||||
|             this.dialogLayout.add_style_class_name(params.styleClass); | ||||
|         this.dialogLayout = new Dialog.Dialog(this.backgroundStack, params.styleClass); | ||||
|         this.contentLayout = this.dialogLayout.contentLayout; | ||||
|         this.buttonLayout = this.dialogLayout.buttonLayout; | ||||
|  | ||||
|         if (!this._shellReactive) { | ||||
|             this._lightbox = new Lightbox.Lightbox(this._group, | ||||
| @@ -94,22 +82,6 @@ const ModalDialog = new Lang.Class({ | ||||
|             this._eventBlocker = new Clutter.Actor({ reactive: true }); | ||||
|             this.backgroundStack.add_actor(this._eventBlocker); | ||||
|         } | ||||
|         this.backgroundStack.add_actor(this.dialogLayout); | ||||
|  | ||||
|  | ||||
|         this.contentLayout = new St.BoxLayout({ vertical: true, | ||||
|                                                 style_class: "modal-dialog-content-box" }); | ||||
|         this.dialogLayout.add(this.contentLayout, | ||||
|                               { expand:  true, | ||||
|                                 x_fill:  true, | ||||
|                                 y_fill:  true, | ||||
|                                 x_align: St.Align.MIDDLE, | ||||
|                                 y_align: St.Align.START }); | ||||
|  | ||||
|         this.buttonLayout = new St.Widget ({ layout_manager: new Clutter.BoxLayout ({ homogeneous:true }) }); | ||||
|         this.dialogLayout.add(this.buttonLayout, | ||||
|                               { x_align: St.Align.MIDDLE, | ||||
|                                 y_align: St.Align.END }); | ||||
|  | ||||
|         global.focus_manager.add_group(this.dialogLayout); | ||||
|         this._initialKeyFocus = this.dialogLayout; | ||||
| @@ -122,8 +94,7 @@ const ModalDialog = new Lang.Class({ | ||||
|     }, | ||||
|  | ||||
|     clearButtons: function() { | ||||
|         this.buttonLayout.destroy_all_children(); | ||||
|         this._buttonKeys = {}; | ||||
|         this.dialogLayout.clearButtons(); | ||||
|     }, | ||||
|  | ||||
|     setButtons: function(buttons) { | ||||
| @@ -146,72 +117,8 @@ const ModalDialog = new Lang.Class({ | ||||
|         } | ||||
|     }, | ||||
|  | ||||
|     addButton: function(buttonInfo) { | ||||
|         let label = buttonInfo['label'] | ||||
|         let action = buttonInfo['action']; | ||||
|         let key = buttonInfo['key']; | ||||
|         let isDefault = buttonInfo['default']; | ||||
|  | ||||
|         let keys; | ||||
|  | ||||
|         if (key) | ||||
|             keys = [key]; | ||||
|         else if (isDefault) | ||||
|             keys = [Clutter.KEY_Return, Clutter.KEY_KP_Enter, Clutter.KEY_ISO_Enter]; | ||||
|         else | ||||
|             keys = []; | ||||
|  | ||||
|         let button = new St.Button({ style_class: 'modal-dialog-linked-button', | ||||
|                                      button_mask: St.ButtonMask.ONE | St.ButtonMask.THREE, | ||||
|                                      reactive:    true, | ||||
|                                      can_focus:   true, | ||||
|                                      x_expand:    true, | ||||
|                                      y_expand:    true, | ||||
|                                      label:       label }); | ||||
|         button.connect('clicked', action); | ||||
|  | ||||
|         buttonInfo['button'] = button; | ||||
|  | ||||
|         if (isDefault) | ||||
|             button.add_style_pseudo_class('default'); | ||||
|  | ||||
|         if (!this._initialKeyFocusDestroyId) | ||||
|             this._initialKeyFocus = button; | ||||
|  | ||||
|         for (let i in keys) | ||||
|             this._buttonKeys[keys[i]] = buttonInfo; | ||||
|  | ||||
|         this.buttonLayout.add_actor(button); | ||||
|  | ||||
|         return button; | ||||
|     }, | ||||
|  | ||||
|     _onKeyPressEvent: function(object, event) { | ||||
|         this._pressedKey = event.get_key_symbol(); | ||||
|         return Clutter.EVENT_PROPAGATE; | ||||
|     }, | ||||
|  | ||||
|     _onKeyReleaseEvent: function(object, event) { | ||||
|         let pressedKey = this._pressedKey; | ||||
|         this._pressedKey = null; | ||||
|  | ||||
|         let symbol = event.get_key_symbol(); | ||||
|         if (symbol != pressedKey) | ||||
|             return Clutter.EVENT_PROPAGATE; | ||||
|  | ||||
|         let buttonInfo = this._buttonKeys[symbol]; | ||||
|         if (!buttonInfo) | ||||
|             return Clutter.EVENT_PROPAGATE; | ||||
|  | ||||
|         let button = buttonInfo['button']; | ||||
|         let action = buttonInfo['action']; | ||||
|  | ||||
|         if (action && button.reactive) { | ||||
|             action(); | ||||
|             return Clutter.EVENT_STOP; | ||||
|         } | ||||
|  | ||||
|         return Clutter.EVENT_PROPAGATE; | ||||
|     addButton: function (buttonInfo) { | ||||
|         return this.dialogLayout.addButton(buttonInfo); | ||||
|     }, | ||||
|  | ||||
|     _onGroupDestroy: function() { | ||||
|   | ||||
| @@ -47,7 +47,7 @@ const MprisPlayerProxy = Gio.DBusProxy.makeProxyWrapper(MprisPlayerIface); | ||||
|  | ||||
| const MPRIS_PLAYER_PREFIX = 'org.mpris.MediaPlayer2.'; | ||||
|  | ||||
| const MediaMessage = new Lang.Class({ | ||||
| var MediaMessage = new Lang.Class({ | ||||
|     Name: 'MediaMessage', | ||||
|     Extends: MessageList.Message, | ||||
|  | ||||
| @@ -111,7 +111,7 @@ const MediaMessage = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const MprisPlayer = new Lang.Class({ | ||||
| var MprisPlayer = new Lang.Class({ | ||||
|     Name: 'MprisPlayer', | ||||
|  | ||||
|     _init: function(busName) { | ||||
| @@ -226,7 +226,7 @@ const MprisPlayer = new Lang.Class({ | ||||
| }); | ||||
| Signals.addSignalMethods(MprisPlayer.prototype); | ||||
|  | ||||
| const MediaSection = new Lang.Class({ | ||||
| var MediaSection = new Lang.Class({ | ||||
|     Name: 'MediaSection', | ||||
|     Extends: MessageList.MessageListSection, | ||||
|  | ||||
|   | ||||
| @@ -67,14 +67,14 @@ const FdoNotificationsIface = '<node> \ | ||||
| </interface> \ | ||||
| </node>'; | ||||
|  | ||||
| const NotificationClosedReason = { | ||||
| var NotificationClosedReason = { | ||||
|     EXPIRED: 1, | ||||
|     DISMISSED: 2, | ||||
|     APP_CLOSED: 3, | ||||
|     UNDEFINED: 4 | ||||
| }; | ||||
|  | ||||
| const Urgency = { | ||||
| var Urgency = { | ||||
|     LOW: 0, | ||||
|     NORMAL: 1, | ||||
|     CRITICAL: 2 | ||||
| @@ -91,7 +91,7 @@ const rewriteRules = { | ||||
|     ] | ||||
| }; | ||||
|  | ||||
| const FdoNotificationDaemon = new Lang.Class({ | ||||
| var FdoNotificationDaemon = new Lang.Class({ | ||||
|     Name: 'FdoNotificationDaemon', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -128,10 +128,10 @@ const FdoNotificationDaemon = new Lang.Class({ | ||||
|         switch (hints.urgency) { | ||||
|             case Urgency.LOW: | ||||
|             case Urgency.NORMAL: | ||||
|                 stockIcon = 'gtk-dialog-info'; | ||||
|                 stockIcon = 'dialog-information'; | ||||
|                 break; | ||||
|             case Urgency.CRITICAL: | ||||
|                 stockIcon = 'gtk-dialog-error'; | ||||
|                 stockIcon = 'dialog-error'; | ||||
|                 break; | ||||
|         } | ||||
|         return new Gio.ThemedIcon({ name: stockIcon }); | ||||
| @@ -186,7 +186,8 @@ const FdoNotificationDaemon = new Lang.Class({ | ||||
|             return source; | ||||
|         } | ||||
|  | ||||
|         source = new FdoNotificationDaemonSource(title, pid, sender, ndata ? ndata.hints['desktop-entry'] : null); | ||||
|         let appId = ndata ? ndata.hints['desktop-entry'] || null : null; | ||||
|         source = new FdoNotificationDaemonSource(title, pid, sender, appId); | ||||
|  | ||||
|         this._sources.push(source); | ||||
|         source.connect('destroy', Lang.bind(this, function() { | ||||
| @@ -391,10 +392,10 @@ const FdoNotificationDaemon = new Lang.Class({ | ||||
|                 notification.setUrgency(MessageTray.Urgency.CRITICAL); | ||||
|                 break; | ||||
|         } | ||||
|         notification.setResident(hints.resident == true); | ||||
|         notification.setResident(!!hints.resident); | ||||
|         // 'transient' is a reserved keyword in JS, so we have to retrieve the value | ||||
|         // of the 'transient' hint with hints['transient'] rather than hints.transient | ||||
|         notification.setTransient(hints['transient'] == true); | ||||
|         notification.setTransient(!!hints['transient']); | ||||
|  | ||||
|         let sourceGIcon = source.useNotificationIcon ? gicon : null; | ||||
|         source.processNotification(notification, sourceGIcon); | ||||
| @@ -458,7 +459,7 @@ const FdoNotificationDaemon = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const FdoNotificationDaemonSource = new Lang.Class({ | ||||
| var FdoNotificationDaemonSource = new Lang.Class({ | ||||
|     Name: 'FdoNotificationDaemonSource', | ||||
|     Extends: MessageTray.Source, | ||||
|  | ||||
| @@ -585,7 +586,7 @@ const PRIORITY_URGENCY_MAP = { | ||||
|     urgent: MessageTray.Urgency.CRITICAL | ||||
| }; | ||||
|  | ||||
| const GtkNotificationDaemonNotification = new Lang.Class({ | ||||
| var GtkNotificationDaemonNotification = new Lang.Class({ | ||||
|     Name: 'GtkNotificationDaemonNotification', | ||||
|     Extends: MessageTray.Notification, | ||||
|  | ||||
| @@ -679,7 +680,7 @@ function getPlatformData() { | ||||
|  | ||||
| function InvalidAppError() {} | ||||
|  | ||||
| const GtkNotificationDaemonAppSource = new Lang.Class({ | ||||
| var GtkNotificationDaemonAppSource = new Lang.Class({ | ||||
|     Name: 'GtkNotificationDaemonAppSource', | ||||
|     Extends: MessageTray.Source, | ||||
|  | ||||
| @@ -786,7 +787,7 @@ const GtkNotificationsIface = '<node> \ | ||||
| </interface> \ | ||||
| </node>'; | ||||
|  | ||||
| const GtkNotificationDaemon = new Lang.Class({ | ||||
| var GtkNotificationDaemon = new Lang.Class({ | ||||
|     Name: 'GtkNotificationDaemon', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -884,7 +885,7 @@ const GtkNotificationDaemon = new Lang.Class({ | ||||
|     }, | ||||
| }); | ||||
|  | ||||
| const NotificationDaemon = new Lang.Class({ | ||||
| var NotificationDaemon = new Lang.Class({ | ||||
|     Name: 'NotificationDaemon', | ||||
|  | ||||
|     _init: function() { | ||||
|   | ||||
| @@ -9,9 +9,9 @@ const Main = imports.ui.main; | ||||
| const Tweener = imports.ui.tweener; | ||||
| const Meta = imports.gi.Meta; | ||||
|  | ||||
| const FADE_TIME = 0.1; | ||||
| var FADE_TIME = 0.1; | ||||
|  | ||||
| const OsdMonitorLabel = new Lang.Class({ | ||||
| var OsdMonitorLabel = new Lang.Class({ | ||||
|     Name: 'OsdMonitorLabel', | ||||
|  | ||||
|     _init: function(monitor, label) { | ||||
| @@ -52,7 +52,7 @@ const OsdMonitorLabel = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const OsdMonitorLabeler = new Lang.Class({ | ||||
| var OsdMonitorLabeler = new Lang.Class({ | ||||
|     Name: 'OsdMonitorLabeler', | ||||
|  | ||||
|     _init: function() { | ||||
|   | ||||
| @@ -11,11 +11,11 @@ const Mainloop = imports.mainloop; | ||||
| const Tweener = imports.ui.tweener; | ||||
| const Meta = imports.gi.Meta; | ||||
|  | ||||
| const HIDE_TIMEOUT = 1500; | ||||
| const FADE_TIME = 0.1; | ||||
| const LEVEL_ANIMATION_TIME = 0.1; | ||||
| var HIDE_TIMEOUT = 1500; | ||||
| var FADE_TIME = 0.1; | ||||
| var LEVEL_ANIMATION_TIME = 0.1; | ||||
|  | ||||
| const LevelBar = new Lang.Class({ | ||||
| var LevelBar = new Lang.Class({ | ||||
|     Name: 'LevelBar', | ||||
|  | ||||
|     _init: function() { | ||||
| @@ -45,7 +45,7 @@ const LevelBar = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const OsdWindowConstraint = new Lang.Class({ | ||||
| var OsdWindowConstraint = new Lang.Class({ | ||||
|     Name: 'OsdWindowConstraint', | ||||
|     Extends: Clutter.Constraint, | ||||
|  | ||||
| @@ -77,7 +77,7 @@ const OsdWindowConstraint = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const OsdWindow = new Lang.Class({ | ||||
| var OsdWindow = new Lang.Class({ | ||||
|     Name: 'OsdWindow', | ||||
|  | ||||
|     _init: function(monitorIndex) { | ||||
| @@ -209,7 +209,7 @@ const OsdWindow = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const OsdWindowManager = new Lang.Class({ | ||||
| var OsdWindowManager = new Lang.Class({ | ||||
|     Name: 'OsdWindowManager', | ||||
|  | ||||
|     _init: function() { | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user